mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-12 12:28:42 +00:00
fix(editor): text color on toolbar when connector is selected (#12360)
Closes: [BS-3511](https://linear.app/affine-design/issue/BS-3511/当选中-connector-时,toolbar-上文字颜色选项颜色显示不正确) <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **Tests** - Added end-to-end tests for the edgeless connector feature, verifying toolbar text color functionality and theme-based color changes. - **Refactor** - Improved performance of text toolbar actions by optimizing internal data handling for font and color selection. No changes to visible behavior. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
This commit is contained in:
65
tests/affine-local/e2e/blocksuite/edgeless/connector.spec.ts
Normal file
65
tests/affine-local/e2e/blocksuite/edgeless/connector.spec.ts
Normal file
@@ -0,0 +1,65 @@
|
||||
import { test } from '@affine-test/kit/playwright';
|
||||
import {
|
||||
clickEdgelessModeButton,
|
||||
clickView,
|
||||
dblclickView,
|
||||
dragView,
|
||||
locateEditorContainer,
|
||||
locateToolbar,
|
||||
setEdgelessTool,
|
||||
} from '@affine-test/kit/utils/editor';
|
||||
import { openHomePage } from '@affine-test/kit/utils/load-page';
|
||||
import {
|
||||
clickNewPageButton,
|
||||
switchEdgelessTheme,
|
||||
waitForEditorLoad,
|
||||
} from '@affine-test/kit/utils/page-logic';
|
||||
import { expect } from '@playwright/test';
|
||||
|
||||
test.beforeEach(async ({ page }) => {
|
||||
await openHomePage(page);
|
||||
await waitForEditorLoad(page);
|
||||
await clickNewPageButton(page);
|
||||
await clickEdgelessModeButton(page);
|
||||
const container = locateEditorContainer(page);
|
||||
await container.click();
|
||||
});
|
||||
|
||||
test('should correct text color on toolbar', async ({ page }) => {
|
||||
await setEdgelessTool(page, 'connector');
|
||||
await dragView(page, [100, 300], [200, 400]);
|
||||
await dblclickView(page, [150, 350]);
|
||||
|
||||
await expect(
|
||||
page.locator('edgeless-connector-label-editor rich-text')
|
||||
).toBeVisible();
|
||||
await page.keyboard.type('label');
|
||||
await page.keyboard.press('Escape');
|
||||
|
||||
const toolbar = locateToolbar(page);
|
||||
const textColorContainer = toolbar.locator(
|
||||
'edgeless-color-picker-button.text-color'
|
||||
);
|
||||
const textColorBtn = textColorContainer.getByLabel('Text color');
|
||||
const blackBtn = textColorContainer
|
||||
.locator('edgeless-color-button[active]')
|
||||
.getByLabel('Black');
|
||||
|
||||
await expect(textColorContainer).toBeVisible();
|
||||
|
||||
await textColorBtn.click();
|
||||
await expect(blackBtn).toHaveCount(1);
|
||||
|
||||
const svgFillColor = await blackBtn.locator('svg').getAttribute('fill');
|
||||
expect(svgFillColor).toBe('#000000');
|
||||
|
||||
await switchEdgelessTheme(page, 'dark');
|
||||
|
||||
await clickView(page, [150, 350]);
|
||||
await textColorBtn.click();
|
||||
|
||||
await expect(blackBtn).toHaveCount(1);
|
||||
|
||||
const svgFillColor2 = await blackBtn.locator('svg').getAttribute('fill');
|
||||
expect(svgFillColor2).toBe('#ffffff');
|
||||
});
|
||||
Reference in New Issue
Block a user