mirror of
https://github.com/enso-org/enso.git
synced 2025-01-08 10:08:16 +03:00
0b6b1f0954
Context menu, copy button, multi-component actions https://github.com/user-attachments/assets/14243102-3848-43fc-82bb-a48648536985 - The 'More' menu can now be opened under the mouse, through the context menu action (right click/control-click on Mac/menu button on keyboard). - Add copy-components button to menu. - The menu can now be opened while multiple components are selected; if the clicked component was among the selected components, the selection will be preserved. Some menu actions--currently *copy* and *delete*, apply to all selected components. These actions will change their displayed labels when multiple components are selected. If a single-component action is executed, the component it was applied to will become the sole selection. Fixes #11633, #11634
101 lines
4.0 KiB
TypeScript
101 lines
4.0 KiB
TypeScript
import test from 'playwright/test'
|
|
import * as actions from './actions'
|
|
import { expect } from './customExpect'
|
|
import { CONTROL_KEY } from './keyboard'
|
|
import * as locate from './locate'
|
|
|
|
test('Edit comment by click', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const nodeComment = locate.nodeComment(locate.graphNodeByBinding(page, 'final'))
|
|
await expect(nodeComment).toHaveText('This node can be entered')
|
|
|
|
await nodeComment.click()
|
|
await page.keyboard.press(`${CONTROL_KEY}+A`)
|
|
const NEW_COMMENT = 'New comment text'
|
|
await nodeComment.fill(NEW_COMMENT)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(nodeComment).not.toBeFocused()
|
|
await expect(nodeComment).toHaveText(NEW_COMMENT)
|
|
})
|
|
|
|
test('Start editing comment via menu', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const node = locate.graphNodeByBinding(page, 'final')
|
|
await node.click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'More' }).click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'Comment' }).click()
|
|
await expect(locate.nodeComment(node)).toBeFocused()
|
|
})
|
|
|
|
test('Start editing comment via context menu', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const node = locate.graphNodeByBinding(page, 'final')
|
|
await node.click({ button: 'right' })
|
|
await page.getByRole('button', { name: 'Add Comment' }).click()
|
|
await expect(locate.nodeComment(node)).toBeFocused()
|
|
})
|
|
|
|
test('Start editing comment via context menu when multiple components initially selected', async ({
|
|
page,
|
|
}) => {
|
|
await actions.goToGraph(page)
|
|
const otherNode = locate.graphNodeByBinding(page, 'sum')
|
|
await otherNode.click()
|
|
const node = locate.graphNodeByBinding(page, 'final')
|
|
await node.click({ modifiers: ['Shift'] })
|
|
const anotherNode = locate.graphNodeByBinding(page, 'list')
|
|
await anotherNode.click({ modifiers: ['Shift'] })
|
|
await node.click({ button: 'right' })
|
|
await expect(locate.selectedNodes(page)).toHaveCount(3)
|
|
await page.getByRole('button', { name: 'Add Comment' }).click()
|
|
await expect(locate.selectedNodes(page)).toHaveCount(1)
|
|
await expect(locate.nodeComment(node)).toBeFocused()
|
|
})
|
|
|
|
test('Add new comment via menu', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const INITIAL_NODE_COMMENTS = 1
|
|
await expect(locate.nodeComment(page)).toHaveCount(INITIAL_NODE_COMMENTS)
|
|
const node = locate.graphNodeByBinding(page, 'data')
|
|
const nodeComment = locate.nodeComment(node)
|
|
|
|
await node.click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'More' }).click()
|
|
await locate.circularMenu(node).getByRole('button', { name: 'Comment' }).click()
|
|
await expect(locate.nodeComment(node)).toBeFocused()
|
|
const NEW_COMMENT = 'New comment text'
|
|
await nodeComment.fill(NEW_COMMENT)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(nodeComment).not.toBeFocused()
|
|
await expect(nodeComment).toHaveText(NEW_COMMENT)
|
|
await expect(locate.nodeComment(page)).toHaveCount(INITIAL_NODE_COMMENTS + 1)
|
|
})
|
|
|
|
test('Delete comment by clearing text', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const nodeComment = locate.nodeComment(locate.graphNodeByBinding(page, 'final'))
|
|
await expect(nodeComment).toHaveText('This node can be entered')
|
|
|
|
await nodeComment.click()
|
|
await page.keyboard.press(`${CONTROL_KEY}+A`)
|
|
await page.keyboard.press(`Delete`)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(nodeComment).not.toExist()
|
|
})
|
|
|
|
test('URL added to comment is rendered as link', async ({ page }) => {
|
|
await actions.goToGraph(page)
|
|
const nodeComment = locate.nodeComment(locate.graphNodeByBinding(page, 'final'))
|
|
await expect(nodeComment).toHaveText('This node can be entered')
|
|
await expect(nodeComment.locator('a')).not.toExist()
|
|
|
|
await nodeComment.click()
|
|
await page.keyboard.press(`${CONTROL_KEY}+A`)
|
|
const NEW_COMMENT = "Here's a URL: https://example.com"
|
|
await nodeComment.fill(NEW_COMMENT)
|
|
await page.keyboard.press(`Enter`)
|
|
await expect(nodeComment).not.toBeFocused()
|
|
await expect(nodeComment).toHaveText(NEW_COMMENT)
|
|
await expect(nodeComment.locator('a')).toHaveCount(1)
|
|
})
|