// @watch start
// templates/repo/diff/**
// web_src/css/features/imagediff.css
// web_src/css/modules/tab.css
// web_src/js/modules/tab.ts
// @watch end
import {expect} from '@playwright/test';
import {save_visual, test, dynamic_id} from './utils_e2e.ts';
test.use({user: 'user2'});
test('Repository image diff', async ({page}) => {
// Generate a temporary SVG and edit it.
let response = await page.goto('/user2/repo1/_new/master', {waitUntil: 'domcontentloaded'});
expect(response?.status()).toBe(200);
const filename = `${dynamic_id()}.svg`;
await page.getByPlaceholder('Name your fileā¦').fill(filename);
await page.locator('.monaco-editor').click();
await page.keyboard.type('\n');
await page.locator('.quick-pull-choice input[value="direct"]').click();
await page.getByRole('button', {name: 'Commit changes'}).click();
response = await page.goto(`/user2/repo1/_edit/master/${filename}`, {waitUntil: 'domcontentloaded'});
expect(response?.status()).toBe(200);
await page.locator('.monaco-editor').click();
await page.keyboard.press('Meta+KeyA');
await page.keyboard.type('\n');
await page.locator('.quick-pull-choice input[value="direct"]').click();
await page.getByRole('button', {name: 'Commit changes'}).click();
// Go to the commit page, where a image diff is shown.
await page.locator('.commit-summary a.default-link').click();
// Exhaustively test tabs works as expected
await expect(page.locator('.item[data-tab="diff-side-by-side-1"]')).toContainClass('active');
await expect(page.locator('.item[data-tab="diff-swipe-1"]')).not.toContainClass('active');
await expect(page.locator('.item[data-tab="diff-overlay-1"]')).not.toContainClass('active');
await expect(page.locator('.tab[data-tab="diff-side-by-side-1"]')).toBeVisible();
await expect(page.locator('.tab[data-tab="diff-swipe-1"]')).toBeHidden();
await expect(page.locator('.tab[data-tab="diff-overlay-1"]')).toBeHidden();
await save_visual(page);
await page.getByText('Swipe').click();
await expect(page.locator('.item[data-tab="diff-side-by-side-1"]')).not.toContainClass('active');
await expect(page.locator('.item[data-tab="diff-swipe-1"]')).toContainClass('active');
await expect(page.locator('.item[data-tab="diff-overlay-1"]')).not.toContainClass('active');
await expect(page.locator('.tab[data-tab="diff-side-by-side-1"]')).toBeHidden();
await expect(page.locator('.tab[data-tab="diff-swipe-1"]')).toBeVisible();
await expect(page.locator('.tab[data-tab="diff-overlay-1"]')).toBeHidden();
await save_visual(page);
await page.getByText('Overlay').click();
await expect(page.locator('.item[data-tab="diff-side-by-side-1"]')).not.toContainClass('active');
await expect(page.locator('.item[data-tab="diff-swipe-1"]')).not.toContainClass('active');
await expect(page.locator('.item[data-tab="diff-overlay-1"]')).toContainClass('active');
await expect(page.locator('.tab[data-tab="diff-side-by-side-1"]')).toBeHidden();
await expect(page.locator('.tab[data-tab="diff-swipe-1"]')).toBeHidden();
await expect(page.locator('.tab[data-tab="diff-overlay-1"]')).toBeVisible();
await save_visual(page);
});