mirror of
https://github.com/facebook/lexical.git
synced 2025-05-17 06:59:17 +08:00
114 lines
4.5 KiB
JavaScript
114 lines
4.5 KiB
JavaScript
/**
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
*/
|
|
|
|
import {selectAll, toggleBold} from '../keyboardShortcuts/index.mjs';
|
|
import {
|
|
assertHTML,
|
|
click,
|
|
focusEditor,
|
|
html,
|
|
initialize,
|
|
insertUploadImage,
|
|
sleep,
|
|
test,
|
|
waitForSelector,
|
|
} from '../utils/index.mjs';
|
|
|
|
test.use({acceptDownloads: true});
|
|
test.describe('File', () => {
|
|
test.beforeEach(({isCollab, page}) => initialize({isCollab, page}));
|
|
|
|
test(`Can import/export`, async ({page, isPlainText}) => {
|
|
test.skip(isPlainText);
|
|
await focusEditor(page);
|
|
await toggleBold(page);
|
|
await page.keyboard.type('Hello');
|
|
await toggleBold(page);
|
|
await page.keyboard.type(' World');
|
|
await page.keyboard.press('Enter');
|
|
await page.keyboard.type('1. one');
|
|
await page.keyboard.press('Enter');
|
|
await page.keyboard.type('two');
|
|
await page.keyboard.press('Enter');
|
|
|
|
await insertUploadImage(page, [
|
|
'packages/lexical-playground/src/images/yellow-flower-small.jpg',
|
|
]);
|
|
|
|
await waitForSelector(page, '.editor-image img');
|
|
|
|
const expectedHtml = html`
|
|
<p
|
|
class="PlaygroundEditorTheme__paragraph PlaygroundEditorTheme__ltr"
|
|
dir="ltr">
|
|
<strong
|
|
class="PlaygroundEditorTheme__textBold"
|
|
data-lexical-text="true">
|
|
Hello
|
|
</strong>
|
|
<span data-lexical-text="true">World</span>
|
|
</p>
|
|
<ol class="PlaygroundEditorTheme__ol1">
|
|
<li
|
|
class="PlaygroundEditorTheme__listItem PlaygroundEditorTheme__ltr"
|
|
dir="ltr"
|
|
value="1">
|
|
<span data-lexical-text="true">one</span>
|
|
</li>
|
|
<li
|
|
class="PlaygroundEditorTheme__listItem PlaygroundEditorTheme__ltr"
|
|
dir="ltr"
|
|
value="2">
|
|
<span data-lexical-text="true">two</span>
|
|
</li>
|
|
<li class="PlaygroundEditorTheme__listItem" value="3">
|
|
<span
|
|
class="editor-image"
|
|
contenteditable="false"
|
|
data-lexical-decorator="true">
|
|
<div draggable="false">
|
|
<img
|
|
alt=""
|
|
draggable="false"
|
|
src=""
|
|
style="height: inherit; max-width: 500px; width: inherit;" />
|
|
</div>
|
|
</span>
|
|
<br />
|
|
</li>
|
|
</ol>
|
|
`;
|
|
|
|
await assertHTML(page, expectedHtml);
|
|
|
|
const [download] = await Promise.all([
|
|
page.waitForEvent('download'),
|
|
click(page, '.action-button.export'),
|
|
]);
|
|
const filePath = await download.path();
|
|
|
|
await focusEditor(page);
|
|
await selectAll(page);
|
|
await page.keyboard.press('Backspace');
|
|
await assertHTML(
|
|
page,
|
|
html`
|
|
<p class="PlaygroundEditorTheme__paragraph"><br /></p>
|
|
`,
|
|
);
|
|
|
|
page.on('filechooser', (fileChooser) => {
|
|
fileChooser.setFiles([filePath]);
|
|
});
|
|
await click(page, '.action-button.import');
|
|
await sleep(200);
|
|
|
|
await assertHTML(page, expectedHtml);
|
|
});
|
|
});
|