145 lines
4.0 KiB
JavaScript
145 lines
4.0 KiB
JavaScript
import { click, fillIn, visit } from "@ember/test-helpers";
|
|
import { test } from "qunit";
|
|
import { acceptance, query } from "discourse/tests/helpers/qunit-helpers";
|
|
import selectKit from "discourse/tests/helpers/select-kit-helper";
|
|
import { i18n } from 'discourse-i18n';
|
|
|
|
acceptance("Spoiler Button", function (needs) {
|
|
needs.user();
|
|
needs.settings({ spoiler_enabled: true });
|
|
|
|
test("spoiler button", async (assert) => {
|
|
const popUpMenu = selectKit(".toolbar-popup-menu-options");
|
|
|
|
await visit("/");
|
|
|
|
assert.dom("#create-topic").exists("the create button is visible");
|
|
|
|
await click("#create-topic");
|
|
const categoryChooser = selectKit(".category-chooser");
|
|
await categoryChooser.expand();
|
|
await categoryChooser.selectRowByValue(2);
|
|
await popUpMenu.expand();
|
|
await popUpMenu.selectRowByName(i18n("spoiler.title"));
|
|
|
|
assert.strictEqual(
|
|
query(".d-editor-input").value,
|
|
`[spoiler]${i18n("composer.spoiler_text")}[/spoiler]`,
|
|
"it should contain the right output"
|
|
);
|
|
|
|
let textarea = query(".d-editor-input");
|
|
assert.strictEqual(
|
|
textarea.selectionStart,
|
|
9,
|
|
"it should start highlighting at the right position"
|
|
);
|
|
assert.strictEqual(
|
|
textarea.selectionEnd,
|
|
i18n("composer.spoiler_text").length + 9,
|
|
"it should end highlighting at the right position"
|
|
);
|
|
|
|
await fillIn(".d-editor-input", "This is hidden");
|
|
|
|
textarea.selectionStart = 0;
|
|
textarea.selectionEnd = textarea.value.length;
|
|
|
|
await popUpMenu.expand();
|
|
await popUpMenu.selectRowByName(i18n("spoiler.title"));
|
|
|
|
assert.strictEqual(
|
|
query(".d-editor-input").value,
|
|
`[spoiler]This is hidden[/spoiler]`,
|
|
"it should contain the right output"
|
|
);
|
|
|
|
assert.strictEqual(
|
|
textarea.selectionStart,
|
|
9,
|
|
"it should start highlighting at the right position"
|
|
);
|
|
assert.strictEqual(
|
|
textarea.selectionEnd,
|
|
23,
|
|
"it should end highlighting at the right position"
|
|
);
|
|
|
|
await fillIn(".d-editor-input", "Before this is hidden After");
|
|
|
|
textarea.selectionStart = 7;
|
|
textarea.selectionEnd = 21;
|
|
|
|
await popUpMenu.expand();
|
|
await popUpMenu.selectRowByName(i18n("spoiler.title"));
|
|
|
|
assert.strictEqual(
|
|
query(".d-editor-input").value,
|
|
`Before [spoiler]this is hidden[/spoiler] After`,
|
|
"it should contain the right output"
|
|
);
|
|
|
|
assert.strictEqual(
|
|
textarea.selectionStart,
|
|
16,
|
|
"it should start highlighting at the right position"
|
|
);
|
|
assert.strictEqual(
|
|
textarea.selectionEnd,
|
|
30,
|
|
"it should end highlighting at the right position"
|
|
);
|
|
|
|
await fillIn(".d-editor-input", "Before\nthis is hidden\nAfter");
|
|
|
|
textarea.selectionStart = 7;
|
|
textarea.selectionEnd = 21;
|
|
|
|
await popUpMenu.expand();
|
|
await popUpMenu.selectRowByName(i18n("spoiler.title"));
|
|
|
|
assert.strictEqual(
|
|
query(".d-editor-input").value,
|
|
`Before\n[spoiler]this is hidden[/spoiler]\nAfter`,
|
|
"it should contain the right output"
|
|
);
|
|
|
|
assert.strictEqual(
|
|
textarea.selectionStart,
|
|
16,
|
|
"it should start highlighting at the right position"
|
|
);
|
|
assert.strictEqual(
|
|
textarea.selectionEnd,
|
|
30,
|
|
"it should end highlighting at the right position"
|
|
);
|
|
|
|
// enforce block mode when selected text is multiline
|
|
await fillIn(".d-editor-input", "Before\nthis is\n\nhidden\nAfter");
|
|
|
|
textarea.selectionStart = 7;
|
|
textarea.selectionEnd = 22;
|
|
|
|
await popUpMenu.expand();
|
|
await popUpMenu.selectRowByName(i18n("spoiler.title"));
|
|
|
|
assert.strictEqual(
|
|
query(".d-editor-input").value,
|
|
`Before\n[spoiler]\nthis is\n\nhidden\n[/spoiler]\nAfter`,
|
|
"it should contain the right output"
|
|
);
|
|
|
|
assert.strictEqual(
|
|
textarea.selectionStart,
|
|
17,
|
|
"it should start highlighting at the right position"
|
|
);
|
|
assert.strictEqual(
|
|
textarea.selectionEnd,
|
|
32,
|
|
"it should end highlighting at the right position"
|
|
);
|
|
});
|
|
});
|