upskill-event-manager/wordpress-dev/tests/e2e/ui-styling-review.test.ts
bengizmo c2c5e2802e feat: Implement harmonized CSS framework with theme-based styling
- Created comprehensive harmonized CSS framework (hvac-harmonized.css) based on Astra theme analysis
- Built enhanced styling for all plugin pages using CSS custom properties and modern design patterns
- Updated CSS enqueue system to load harmonized framework as foundation for all pages
- Enhanced dashboard, login, and certificate pages with consistent theme-integrated styling
- Maintained backward compatibility with existing CSS files
- Added proper dependency management and versioning for CSS files
- Improved accessibility with WCAG-compliant color contrasts and focus states
- Implemented responsive design patterns and modern typography scale

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-05-23 09:48:30 -03:00

199 lines
No EOL
7.4 KiB
TypeScript

import { test, expect } from '@playwright/test';
test.describe('UI Styling Review - Full Page Screenshots', () => {
const pages = [
{ name: 'Community Login', url: '/community-login' },
{ name: 'HVAC Dashboard', url: '/hvac-dashboard' },
{ name: 'Generate Certificates', url: '/generate-certificates' },
{ name: 'Certificate Reports', url: '/certificate-reports' },
{ name: 'Trainer Profile', url: '/trainer-profile' },
{ name: 'My Events', url: '/my-events' },
{ name: 'Create Event', url: '/create-event' },
{ name: 'Event Summary', url: '/event-summary' },
{ name: 'Email Attendees', url: '/email-attendees' }
];
// Test logged out states
test('Screenshot all pages - Logged Out', async ({ page }) => {
console.log('=== Taking Screenshots of All Pages (Logged Out) ===');
for (const pageInfo of pages) {
try {
console.log(`📸 Capturing: ${pageInfo.name} (${pageInfo.url})`);
await page.goto(`https://upskill-staging.measurequick.com${pageInfo.url}`, {
waitUntil: 'networkidle',
timeout: 30000
});
// Wait for page to fully load
await page.waitForLoadState('networkidle');
await page.waitForTimeout(2000);
// Take full page screenshot
await page.screenshot({
path: `test-results/ui-review-${pageInfo.name.toLowerCase().replace(/\s+/g, '-')}-logged-out.png`,
fullPage: true
});
console.log(`✅ Captured: ${pageInfo.name}`);
} catch (error) {
console.log(`⚠️ Failed to capture ${pageInfo.name}: ${error.message}`);
}
}
});
// Test logged in states
test('Screenshot all pages - Logged In', async ({ page }) => {
console.log('=== Taking Screenshots of All Pages (Logged In) ===');
// Login first
await page.goto('https://upskill-staging.measurequick.com/community-login');
await page.fill('#user_login', 'test_trainer');
await page.fill('#user_pass', 'Test123!');
await page.click('#wp-submit');
await page.waitForURL('**/hvac-dashboard/**');
await page.waitForLoadState('networkidle');
console.log('✅ Logged in successfully');
for (const pageInfo of pages) {
try {
console.log(`📸 Capturing: ${pageInfo.name} (${pageInfo.url})`);
await page.goto(`https://upskill-staging.measurequick.com${pageInfo.url}`, {
waitUntil: 'networkidle',
timeout: 30000
});
// Wait for page to fully load
await page.waitForLoadState('networkidle');
await page.waitForTimeout(2000);
// Special handling for pages with dynamic content
if (pageInfo.name === 'Generate Certificates') {
// Try to select an event to show the full interface
const eventSelector = page.locator('#event_id');
if (await eventSelector.isVisible()) {
const options = await eventSelector.locator('option:not([value=""])').count();
if (options > 0) {
await eventSelector.selectOption({ index: 1 });
await page.waitForTimeout(2000); // Wait for AJAX
}
}
}
if (pageInfo.name === 'Event Summary') {
// Try to find any event to view
const eventLinks = page.locator('a[href*="/event-summary/"]');
const linkCount = await eventLinks.count();
if (linkCount > 0) {
await eventLinks.first().click();
await page.waitForLoadState('networkidle');
await page.waitForTimeout(2000);
}
}
// Take full page screenshot
await page.screenshot({
path: `test-results/ui-review-${pageInfo.name.toLowerCase().replace(/\s+/g, '-')}-logged-in.png`,
fullPage: true
});
console.log(`✅ Captured: ${pageInfo.name}`);
} catch (error) {
console.log(`⚠️ Failed to capture ${pageInfo.name}: ${error.message}`);
// Take screenshot anyway to see error state
try {
await page.screenshot({
path: `test-results/ui-review-${pageInfo.name.toLowerCase().replace(/\s+/g, '-')}-error.png`,
fullPage: true
});
} catch (screenshotError) {
console.log(`❌ Could not take error screenshot: ${screenshotError.message}`);
}
}
}
});
// Test WordPress theme analysis
test('Analyze WordPress Theme Styling', async ({ page }) => {
console.log('=== Analyzing WordPress Theme Styling ===');
// Go to homepage to analyze theme
await page.goto('https://upskill-staging.measurequick.com/', { waitUntil: 'networkidle' });
// Extract theme colors, fonts, and styling
const themeAnalysis = await page.evaluate(() => {
const computedStyle = getComputedStyle(document.body);
const headerStyle = getComputedStyle(document.querySelector('h1, .site-title, header') || document.body);
const linkStyle = getComputedStyle(document.querySelector('a') || document.body);
return {
bodyFont: computedStyle.fontFamily,
bodyFontSize: computedStyle.fontSize,
bodyColor: computedStyle.color,
bodyBackground: computedStyle.backgroundColor,
headerFont: headerStyle.fontFamily,
headerColor: headerStyle.color,
linkColor: linkStyle.color,
primaryColor: getComputedStyle(document.documentElement).getPropertyValue('--wp--preset--color--primary') || 'not-set',
secondaryColor: getComputedStyle(document.documentElement).getPropertyValue('--wp--preset--color--secondary') || 'not-set'
};
});
console.log('🎨 WordPress Theme Analysis:', themeAnalysis);
// Take homepage screenshot
await page.screenshot({
path: 'test-results/ui-review-wordpress-homepage.png',
fullPage: true
});
console.log('✅ WordPress theme analysis complete');
});
// Test mobile responsiveness
test('Mobile Responsiveness Check', async ({ page }) => {
console.log('=== Mobile Responsiveness Check ===');
// Set mobile viewport
await page.setViewportSize({ width: 375, height: 667 }); // iPhone SE
// Login
await page.goto('https://upskill-staging.measurequick.com/community-login');
await page.fill('#user_login', 'test_trainer');
await page.fill('#user_pass', 'Test123!');
await page.click('#wp-submit');
await page.waitForURL('**/hvac-dashboard/**');
await page.waitForLoadState('networkidle');
// Test key pages on mobile
const mobilePages = [
{ name: 'Dashboard', url: '/hvac-dashboard' },
{ name: 'Generate Certificates', url: '/generate-certificates' },
{ name: 'Certificate Reports', url: '/certificate-reports' }
];
for (const pageInfo of mobilePages) {
try {
console.log(`📱 Mobile test: ${pageInfo.name}`);
await page.goto(`https://upskill-staging.measurequick.com${pageInfo.url}`, {
waitUntil: 'networkidle'
});
await page.waitForTimeout(2000);
await page.screenshot({
path: `test-results/ui-review-${pageInfo.name.toLowerCase().replace(/\s+/g, '-')}-mobile.png`,
fullPage: true
});
console.log(`✅ Mobile captured: ${pageInfo.name}`);
} catch (error) {
console.log(`⚠️ Mobile test failed for ${pageInfo.name}: ${error.message}`);
}
}
});
});