Files
2024-07-10 13:15:31 +00:00

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);
});
});