tldraw/apps/examples/e2e/tests/test-shapes.spec.ts
Steve Ruiz ddb73cb6cf
Tighten up editor ui (#2102)
This PR tightens up the editor UI. It removes padding around the editor.

![Kapture 2023-10-28 at 18 27
15](https://github.com/tldraw/tldraw/assets/23072548/18075308-7b62-43a1-8c80-ff4e4136197b)

<img width="1196" alt="image"
src="https://github.com/tldraw/tldraw/assets/23072548/a8205ef1-b142-4fdc-9745-e400c0c4939a">

<img width="1196" alt="image"
src="https://github.com/tldraw/tldraw/assets/23072548/87e9dcd1-39f5-466a-a256-9cbd2ff2cf7e">

### Change Type

- [x] `minor` — New feature

### Release Notes

- Small adjustment to editor ui.
2023-10-28 21:58:32 +00:00

183 lines
5.5 KiB
TypeScript

import test, { Page, expect } from '@playwright/test'
import { getAllShapeTypes, setupPage } from '../shared-e2e'
export function sleep(ms: number) {
return new Promise((resolve) => setTimeout(resolve, ms))
}
const clickableShapeCreators = [
{ tool: 'draw', shape: 'draw' },
{ tool: 'frame', shape: 'frame' },
{ tool: 'note', shape: 'note' },
{ tool: 'text', shape: 'text' },
{ tool: 'rectangle', shape: 'geo' },
{ tool: 'ellipse', shape: 'geo' },
{ tool: 'triangle', shape: 'geo' },
{ tool: 'diamond', shape: 'geo' },
{ tool: 'cloud', shape: 'geo' },
{ tool: 'hexagon', shape: 'geo' },
// { tool: 'octagon', shape: 'geo' },
{ tool: 'star', shape: 'geo' },
{ tool: 'rhombus', shape: 'geo' },
{ tool: 'oval', shape: 'geo' },
{ tool: 'trapezoid', shape: 'geo' },
{ tool: 'arrow-right', shape: 'geo' },
{ tool: 'arrow-left', shape: 'geo' },
{ tool: 'arrow-up', shape: 'geo' },
{ tool: 'arrow-down', shape: 'geo' },
{ tool: 'x-box', shape: 'geo' },
{ tool: 'check-box', shape: 'geo' },
]
const draggableShapeCreators = [
{ tool: 'draw', shape: 'draw' },
{ tool: 'arrow', shape: 'arrow' },
{ tool: 'frame', shape: 'frame' },
{ tool: 'note', shape: 'note' },
{ tool: 'text', shape: 'text' },
{ tool: 'line', shape: 'line' },
{ tool: 'rectangle', shape: 'geo' },
{ tool: 'ellipse', shape: 'geo' },
{ tool: 'triangle', shape: 'geo' },
{ tool: 'diamond', shape: 'geo' },
{ tool: 'cloud', shape: 'geo' },
{ tool: 'hexagon', shape: 'geo' },
// { tool: 'octagon', shape: 'geo' },
{ tool: 'star', shape: 'geo' },
{ tool: 'rhombus', shape: 'geo' },
{ tool: 'oval', shape: 'geo' },
{ tool: 'trapezoid', shape: 'geo' },
{ tool: 'arrow-right', shape: 'geo' },
{ tool: 'arrow-left', shape: 'geo' },
{ tool: 'arrow-up', shape: 'geo' },
{ tool: 'arrow-down', shape: 'geo' },
{ tool: 'x-box', shape: 'geo' },
{ tool: 'check-box', shape: 'geo' },
]
const otherTools = [{ tool: 'select' }, { tool: 'eraser' }, { tool: 'laser' }]
let page: Page
test.describe('Shape Tools', () => {
test.beforeAll(async ({ browser }) => {
page = await browser.newPage()
await setupPage(page)
})
test('creates shapes with other tools', async () => {
await page.keyboard.press('Control+a')
await page.keyboard.press('Backspace')
expect(await getAllShapeTypes(page)).toEqual([])
for (const { tool } of otherTools) {
// Find and click the button
if (!(await page.getByTestId(`tools.${tool}`).isVisible())) {
if (!(await page.getByTestId(`tools.more`).isVisible())) {
throw Error(`Tool more is not visible`)
}
await page.getByTestId('tools.more').click()
if (!(await page.getByTestId(`tools.more.${tool}`).isVisible())) {
throw Error(`Tool in more panel is not visible`)
}
await page.getByTestId(`tools.more.${tool}`).click()
await page.getByTestId(`tools.more`).click()
}
if (!(await page.getByTestId(`tools.${tool}`).isVisible())) {
throw Error(`Tool ${tool} is not visible`)
}
await page.getByTestId(`tools.${tool}`).click()
// Button should be selected
expect(
await page
.getByTestId(`tools.${tool}`)
.elementHandle()
.then((d) => d?.getAttribute('data-state'))
).toBe('selected')
}
})
test('creates shapes clickable tools', async () => {
await page.keyboard.press('v')
await page.keyboard.press('Control+a')
await page.keyboard.press('Backspace')
expect(await getAllShapeTypes(page)).toEqual([])
for (const { tool, shape } of clickableShapeCreators) {
// Find and click the button
if (!(await page.getByTestId(`tools.${tool}`).isVisible())) {
await page.getByTestId('tools.more').click()
await page.getByTestId(`tools.more.${tool}`).click()
await page.getByTestId('tools.more').click()
}
await page.getByTestId(`tools.${tool}`).click()
// Button should be selected
expect(
await page
.getByTestId(`tools.${tool}`)
.elementHandle()
.then((d) => d?.getAttribute('data-state'))
).toBe('selected')
// Click on the page
await page.mouse.click(200, 200)
// We should have a corresponding shape in the page
expect(await getAllShapeTypes(page)).toEqual([shape])
// Reset for next time
await page.mouse.click(50, 50) // to ensure we're not focused
await page.keyboard.press('v') // go to the select tool
await page.keyboard.press('Control+a')
await page.keyboard.press('Backspace')
}
expect(await getAllShapeTypes(page)).toEqual([])
})
test('creates shapes with draggable tools', async () => {
await page.keyboard.press('Control+a')
await page.keyboard.press('Backspace')
expect(await getAllShapeTypes(page)).toEqual([])
for (const { tool, shape } of draggableShapeCreators) {
// Find and click the button
if (!(await page.getByTestId(`tools.${tool}`).isVisible())) {
await page.getByTestId('tools.more').click()
await page.getByTestId(`tools.more.${tool}`).click()
await page.getByTestId('tools.more').click()
}
await page.getByTestId(`tools.${tool}`).click()
// Button should be selected
expect(
await page
.getByTestId(`tools.${tool}`)
.elementHandle()
.then((d) => d?.getAttribute('data-state'))
).toBe('selected')
// Click and drag
await page.mouse.move(200, 200)
await page.mouse.down()
await page.mouse.move(250, 250)
await page.mouse.up()
// We should have a corresponding shape in the page
expect(await getAllShapeTypes(page)).toEqual([shape])
// Reset for next time
await page.mouse.click(50, 50) // to ensure we're not focused
await page.keyboard.press('v')
await page.keyboard.press('Control+a')
await page.keyboard.press('Backspace')
}
})
})