diff --git a/addons/html_builder/static/src/plugins/embed_code_option.js b/addons/html_builder/static/src/plugins/embed_code_option.js new file mode 100644 index 0000000000000..0e5c2100cff3e --- /dev/null +++ b/addons/html_builder/static/src/plugins/embed_code_option.js @@ -0,0 +1,79 @@ +import { Plugin } from "@html_editor/plugin"; +import { EmbedCodeOptionDialog } from "@html_builder/plugins/embed_code_option_dialog"; +import { withSequence } from "@html_editor/utils/resource"; +import { _t } from "@web/core/l10n/translation"; +import { registry } from "@web/core/registry"; +import { cloneContentEls } from "@website/js/utils"; + +class EmbedCodeOptionPlugin extends Plugin { + static id = "EmbedCodeOption"; + + resources = { + builder_options: [ + withSequence(5, { + template: "html_builder.EmbedCodeOption", + selector: ".s_embed_code", + }), + ], + builder_actions: this.getActions(), + clean_for_save_handlers: this.cleanForSave.bind(this), + }; + + getTemplateEl(editingElement) { + return editingElement.querySelector("template.s_embed_code_saved"); + } + + getActions() { + return { + editCode: { + load: async ({ editingElement }) => { + let newContent; + await new Promise((resolve) => { + this.services.dialog.add( + EmbedCodeOptionDialog, + { + title: _t("Edit embedded code"), + value: this.getTemplateEl(editingElement).innerHTML.trim(), + mode: "xml", + confirm: (newValue) => { + newContent = newValue; + }, + }, + { onClose: resolve } + ); + }); + return newContent; + }, + apply: ({ editingElement, loadResult: content }) => { + if (!content) { + return; + } + // Remove scripts tags from the DOM as we don't want them to + // interfere during edition, but keeps them in a + // `