website/static/tests/tours/website_style_edition.js

108 lines
4.3 KiB
JavaScript
Raw Permalink Normal View History

/** @odoo-module **/
import weUtils from "@web_editor/js/common/utils";
import wTourUtils from "@website/js/tours/tour_utils";
const TARGET_FONT_SIZE = 30;
const TARGET_BODY_BG_COLOR = '#00FF00';
const TARGET_BODY_BG_COLOR_V2 = 'rgb(0, 255, 0)';
const TARGET_BODY_COLOR = '#FF00FF';
const TARGET_BODY_COLOR_V2 = 'rgb(255, 0, 255)';
const checkFontSize = function () {
const style = document.defaultView.getComputedStyle(this.$anchor[0]);
if (!weUtils.areCssValuesEqual(style.fontSize, `${TARGET_FONT_SIZE}px`, 'font-size', this.$anchor)) {
console.error(`Expected the font-size to be equal to ${TARGET_FONT_SIZE}px but found ${style.fontSize} instead`);
}
};
const checkBodyBgColor = function () {
const style = document.defaultView.getComputedStyle(this.$anchor[0]);
if (!weUtils.areCssValuesEqual(style.backgroundColor, `${TARGET_BODY_BG_COLOR}`, 'background-color', this.$anchor)) {
console.error(`Expected the background color to be equal to ${TARGET_BODY_BG_COLOR} but found ${style.backgroundColor} instead`);
}
};
const checkBodyColor = function () {
const style = document.defaultView.getComputedStyle(this.$anchor[0]);
if (!weUtils.areCssValuesEqual(style.color, `${TARGET_BODY_COLOR}`, 'color', this.$anchor)) {
console.error(`Expected the color to be equal to ${TARGET_BODY_COLOR} but found ${style.color} instead`);
}
};
wTourUtils.registerWebsitePreviewTour("website_style_edition", {
test: true,
url: '/',
edition: true,
}, () => [
wTourUtils.goToTheme(),
{
content: "Change font size",
trigger: '[data-variable="font-size-base"] input',
run: `text_blur ${TARGET_FONT_SIZE}`,
}, {
content: "Check the font size was properly adapted",
trigger: 'iframe #wrapwrap',
// Waiting the CSS to be reloaded: the code adds a new assets bundle with
// a #t=... at the end then removes the old one.
extra_trigger: 'iframe html:not(:has(link[href$="web.assets_frontend.min.css"]))',
run: checkFontSize,
}, {
content: "Open the color combinations area",
trigger: '.o_we_theme_presets_collapse we-toggler',
}, {
content: "Open a color combination",
trigger: '.o_we_cc_preview_wrapper',
}, {
content: "Edit the background color of that color combination",
trigger: '.o_we_theme_presets_collapse we-collapse .o_we_so_color_palette:eq(0)',
}, {
content: "Choose a color",
trigger: `.o_we_color_btn[style*="background-color:${TARGET_BODY_BG_COLOR}"]`,
}, {
content: "Check the body background color was properly adapted",
trigger: 'iframe body',
extra_trigger: `
.o_we_theme_presets_collapse we-collapse .o_we_so_color_palette:eq(0) .o_we_color_preview[style*="${TARGET_BODY_BG_COLOR}"],
.o_we_theme_presets_collapse we-collapse .o_we_so_color_palette:eq(0) .o_we_color_preview[style*="${TARGET_BODY_BG_COLOR_V2}"]
`,
run: checkBodyBgColor,
}, {
content: "Edit the text color of that color combination",
trigger: '.o_we_theme_presets_collapse we-collapse .o_we_so_color_palette:eq(1)',
}, {
content: "Choose a color",
trigger: `.o_we_color_btn[style*="background-color:${TARGET_BODY_COLOR}"]`,
}, {
content: "Check the body color was properly adapted",
trigger: 'iframe body',
extra_trigger: `
.o_we_theme_presets_collapse we-collapse .o_we_so_color_palette:eq(1) .o_we_color_preview[style*="${TARGET_BODY_COLOR}"],
.o_we_theme_presets_collapse we-collapse .o_we_so_color_palette:eq(1) .o_we_color_preview[style*="${TARGET_BODY_COLOR_V2}"]
`,
run: checkBodyColor,
},
...wTourUtils.clickOnSave(),
{
content: "Check the font size is still ok outside of edit mode",
trigger: 'iframe body #wrapwrap',
run: checkFontSize,
}, {
content: "Check the body background color is still ok outside of edit mode",
trigger: 'iframe body',
run: checkBodyBgColor,
}, {
content: "Check the body color is still ok outside of edit mode",
trigger: 'iframe body',
run: checkBodyColor,
},
...wTourUtils.clickOnEditAndWaitEditMode(),
wTourUtils.goToTheme(),
{
content: "Click on the Background Image selection",
trigger: '[data-customize-body-bg-type="\'image\'"]:not(.active)',
extra_trigger: '[data-customize-body-bg-type="NONE"].active',
}, {
content: "The media dialog should open",
trigger: '.o_select_media_dialog',
run: () => {}, // It's a check.
}]);