252 lines
9.6 KiB
JavaScript
252 lines
9.6 KiB
JavaScript
/** @odoo-module **/
|
|
|
|
import wTourUtils from "@website/js/tours/tour_utils";
|
|
import { whenReady } from "@odoo/owl";
|
|
|
|
wTourUtils.registerWebsitePreviewTour('rte_translator', {
|
|
test: true,
|
|
url: '/',
|
|
edition: true,
|
|
wait_for: whenReady(),
|
|
}, () => [
|
|
wTourUtils.goToTheme(),
|
|
{
|
|
content: "click on Add a language",
|
|
trigger: "we-button[data-add-language]"
|
|
}, {
|
|
content: "confirm leave editor",
|
|
trigger: ".modal-dialog button.btn-primary"
|
|
}, {
|
|
content: "type Parseltongue",
|
|
trigger: 'div[name="lang_ids"] .o_input_dropdown input',
|
|
run: 'text Parseltongue',
|
|
}, {
|
|
content: 'select Parseltongue',
|
|
trigger: '.dropdown-item:contains(Parseltongue)',
|
|
}, {
|
|
content: "load Parseltongue",
|
|
trigger: '.modal-footer .btn-primary',
|
|
extra_trigger: '.modal-dialog div[name="lang_ids"] .rounded-pill .o_tag_badge_text:contains(Parseltongue)',
|
|
}, {
|
|
content: "click language dropdown (2)",
|
|
trigger: 'iframe .js_language_selector .dropdown-toggle',
|
|
timeout: 60000,
|
|
}, {
|
|
content: "go to english version",
|
|
trigger: 'iframe .js_language_selector a[data-url_code="en"]',
|
|
extra_trigger: 'iframe html[lang*="pa-GB"]',
|
|
}, {
|
|
content: "Open new page menu",
|
|
trigger: ".o_menu_systray .o_new_content_container > a",
|
|
extra_trigger: 'iframe html[lang*="en-US"]',
|
|
consumeVisibleOnly: true,
|
|
}, {
|
|
content: "click on new page",
|
|
trigger: '.o_new_content_element a',
|
|
}, {
|
|
content: "click on Use this template",
|
|
trigger: ".o_page_template button.btn-primary",
|
|
}, {
|
|
content: "insert file name",
|
|
trigger: '.modal-dialog input[type="text"]',
|
|
run: 'text rte_translator.xml',
|
|
}, {
|
|
content: "create file",
|
|
trigger: '.modal-dialog button.btn-primary',
|
|
extra_trigger: 'input[type="text"]:propValue(rte_translator.xml)',
|
|
}, {
|
|
content: "click on the 'page manager' button",
|
|
trigger: 'button[name="website.action_website_pages_list"]',
|
|
}, {
|
|
content: "click on the record to display the xml file in the iframe",
|
|
trigger: 'td:contains("rte_translator.xml")',
|
|
}, {
|
|
content: "Open new page menu",
|
|
trigger: ".o_menu_systray .o_new_content_container > a",
|
|
consumeVisibleOnly: true,
|
|
}, {
|
|
content: "click on new page",
|
|
trigger: '.o_new_content_element a',
|
|
}, {
|
|
content: "click on Use this template",
|
|
trigger: ".o_page_template button.btn-primary",
|
|
}, {
|
|
content: "insert page name",
|
|
trigger: '.modal-dialog input[type="text"]',
|
|
run: 'text rte_translator',
|
|
}, {
|
|
content: "create page",
|
|
trigger: '.modal-dialog button.btn-primary',
|
|
extra_trigger: 'input[type="text"]:propValue(rte_translator)',
|
|
},
|
|
wTourUtils.dragNDrop({
|
|
id: "s_cover",
|
|
name: "Cover"
|
|
}), {
|
|
content: "change content",
|
|
trigger: 'iframe #wrap',
|
|
run: function () {
|
|
$('iframe:not(.o_ignore_in_tour)').contents().find("#wrap p:first").replaceWith('<p>Write one or <font style="background-color: yellow;">two paragraphs <b>describing</b></font> your product or\
|
|
<font style="color: rgb(255, 0, 0);">services</font>. To be successful your content needs to be\
|
|
useful to your <a href="/999">readers</a>.</p> <input value="test translate default value" placeholder="test translate placeholder"/>\
|
|
<p><b></b> is an HTML tag & is empty</p>');
|
|
$('iframe:not(.o_ignore_in_tour)').contents().find("#wrap img").attr("title", "test translate image title");
|
|
}
|
|
}, {
|
|
content: "ensure change was applied",
|
|
trigger: 'iframe #wrap p:first b',
|
|
isCheck: true,
|
|
},
|
|
...wTourUtils.clickOnSave(),
|
|
{
|
|
content: "click language dropdown (3)",
|
|
trigger: 'iframe .js_language_selector .dropdown-toggle',
|
|
}, {
|
|
content: "click on Parseltongue version",
|
|
trigger: 'iframe .js_language_selector a[data-url_code="pa_GB"]',
|
|
extra_trigger: 'iframe html[lang*="en"]',
|
|
}, {
|
|
content: "translate",
|
|
trigger: '.o_menu_systray .o_translate_website_container > a',
|
|
extra_trigger: 'iframe html:not(:has(#wrap p span))',
|
|
}, {
|
|
content: "close modal",
|
|
trigger: '.modal-footer .btn-secondary',
|
|
}, {
|
|
content: "check if translation is activate",
|
|
trigger: 'iframe [data-oe-translation-initial-sha]',
|
|
}, {
|
|
content: "translate text",
|
|
extra_trigger: '#oe_snippets.o_loaded',
|
|
trigger: 'iframe #wrap p font:first',
|
|
run: function (actionHelper) {
|
|
actionHelper.text('translated Parseltongue text');
|
|
const { Wysiwyg } = odoo.loader.modules.get('@web_editor/js/wysiwyg/wysiwyg');
|
|
Wysiwyg.setRange(this.$anchor.contents()[0], 22);
|
|
this.$anchor.trigger($.Event("keyup", {key: '_'}));
|
|
this.$anchor.trigger('input');
|
|
},
|
|
}, {
|
|
content: "translate text with special char",
|
|
trigger: 'iframe #wrap input + p span:first',
|
|
run: function (actionHelper) {
|
|
actionHelper.click();
|
|
this.$anchor.prepend('<{translated}>');
|
|
const { Wysiwyg } = odoo.loader.modules.get('@web_editor/js/wysiwyg/wysiwyg');
|
|
Wysiwyg.setRange(this.$anchor.contents()[0], 0);
|
|
this.$anchor.trigger($.Event("keyup", {key: '_'}));
|
|
this.$anchor.trigger('input');
|
|
},
|
|
}, {
|
|
content: "click on input",
|
|
trigger: 'iframe #wrap input:first',
|
|
extra_trigger: 'iframe #wrap .o_dirty font:first:contains(translated Parseltongue text)',
|
|
run: 'click',
|
|
}, {
|
|
content: "translate placeholder",
|
|
trigger: '.modal-dialog input:first',
|
|
run: 'text test Parseltongue placeholder',
|
|
}, {
|
|
content: "translate default value",
|
|
trigger: '.modal-dialog input:last',
|
|
run: 'text test Parseltongue default value',
|
|
}, {
|
|
content: "close modal",
|
|
trigger: '.modal-footer .btn-primary',
|
|
extra_trigger: '.modal input:propValue(test Parseltongue placeholder)',
|
|
}, {
|
|
content: "check: input marked as translated",
|
|
trigger: 'iframe input[placeholder="test Parseltongue placeholder"].oe_translated',
|
|
run: () => {},
|
|
},
|
|
...wTourUtils.clickOnSave(),
|
|
{
|
|
content: "check: content is translated",
|
|
trigger: 'iframe #wrap p font:first:contains(translated Parseltongue text)',
|
|
run: function () {}, // it's a check
|
|
}, {
|
|
content: "check: content with special char is translated",
|
|
trigger: "iframe #wrap input + p:contains(<{translated}><b></b> is an HTML\xa0tag & )",
|
|
run: function () {}, // it's a check
|
|
|
|
}, {
|
|
content: "check: placeholder translation",
|
|
trigger: 'iframe input[placeholder="test Parseltongue placeholder"]',
|
|
run: function () {}, // it's a check
|
|
}, {
|
|
content: "check: default value translation",
|
|
trigger: 'iframe input[value="test Parseltongue default value"]',
|
|
run: () => {},
|
|
}, {
|
|
content: "open language selector",
|
|
trigger: 'iframe .js_language_selector button:first',
|
|
extra_trigger: 'iframe html[lang*="pa-GB"]:not(:has(#wrap p span))',
|
|
}, {
|
|
content: "return to english version",
|
|
trigger: 'iframe .js_language_selector a[data-url_code="en"]',
|
|
}, {
|
|
content: "Check body",
|
|
trigger: "iframe body:not(:has(#wrap p font:first:containsExact(paragraphs <b>describing</b>)))",
|
|
run: function () {}, // it's a check
|
|
},
|
|
...wTourUtils.clickOnEditAndWaitEditMode(),
|
|
{
|
|
content: "select text",
|
|
trigger: 'iframe #wrap p',
|
|
run: function (actionHelper) {
|
|
actionHelper.click();
|
|
var el = this.$anchor[0];
|
|
var mousedown = document.createEvent('MouseEvents');
|
|
mousedown.initMouseEvent('mousedown', true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, el);
|
|
el.dispatchEvent(mousedown);
|
|
var mouseup = document.createEvent('MouseEvents');
|
|
const { Wysiwyg } = odoo.loader.modules.get('@web_editor/js/wysiwyg/wysiwyg');
|
|
Wysiwyg.setRange(el.childNodes[2], 6, el.childNodes[2], 13);
|
|
mouseup.initMouseEvent('mouseup', true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, el);
|
|
el.dispatchEvent(mouseup);
|
|
},
|
|
// This is disabled for now because it reveals a bug that is fixed in saas-15.1
|
|
// and considered a tradeoff in 15.0. The bug concerns the invalidation of
|
|
// translations when inserting tags with more than one character. Whereas <u>
|
|
// didn't trigger an invalidation, <span style="text-decoration-line: underline;">
|
|
// does.
|
|
// }, {
|
|
// content: "underline",
|
|
// trigger: '.oe-toolbar #underline',
|
|
},
|
|
...wTourUtils.clickOnSave(),
|
|
{
|
|
content: "click language dropdown (4)",
|
|
trigger: 'iframe .js_language_selector .dropdown-toggle',
|
|
}, {
|
|
content: "return in Parseltongue",
|
|
trigger: 'iframe html[lang="en-US"] .js_language_selector .js_change_lang[data-url_code="pa_GB"]',
|
|
}, {
|
|
content: "check bis: content is translated",
|
|
trigger: 'iframe #wrap p font:first:contains(translated Parseltongue text)',
|
|
extra_trigger: 'iframe html[lang*="pa-GB"]',
|
|
}, {
|
|
content: "check bis: placeholder translation",
|
|
trigger: 'iframe input[placeholder="test Parseltongue placeholder"]',
|
|
}, {
|
|
content: "open site menu",
|
|
trigger: 'button[data-menu-xmlid="website.menu_site"]',
|
|
}, {
|
|
content: "Open HTML editor",
|
|
trigger: 'a[data-menu-xmlid="website.menu_ace_editor"]',
|
|
}, {
|
|
content: "Check that the editor is not showing translated content (1)",
|
|
trigger: '.ace_text-layer .ace_line:contains("an HTML")',
|
|
run: function (actions) {
|
|
var lineEscapedText = $(this.$anchor.text()).last().text();
|
|
if (lineEscapedText !== "<b></b> is an HTML tag & is empty") {
|
|
console.error('The HTML editor should display the correct untranslated content');
|
|
$('iframe:not(.o_ignore_in_tour)').contents().find('body').addClass('rte_translator_error');
|
|
}
|
|
},
|
|
}, {
|
|
content: "Check that the editor is not showing translated content (2)",
|
|
trigger: 'iframe body:not(.rte_translator_error)',
|
|
run: function () {},
|
|
}]);
|