// = require quill.min // = require decidim/editor/linebreak_module // = require_self ((exports) => { const quillFormats = ["bold", "italic", "link", "underline", "header", "list", "video", "image", "alt", "break"]; const createQuillEditor = (container) => { const toolbar = $(container).data("toolbar"); const disabled = $(container).data("disabled"); let quillToolbar = [ ["bold", "italic", "underline", "linebreak"], [{ list: "ordered" }, { list: "bullet" }], ["link", "clean"] ]; if (toolbar === "full") { quillToolbar = [ [{ header: [1, 2, 3, 4, 5, 6, false] }], ...quillToolbar, ["video"] ]; } else if (toolbar === "basic") { quillToolbar = [ ...quillToolbar, ["video"] ]; } const $input = $(container).siblings('input[type="hidden"]'); container.innerHTML = $input.val() || ""; const quill = new Quill(container, { modules: { linebreak: {}, toolbar: { container: quillToolbar, handlers: { "linebreak": exports.Decidim.Editor.lineBreakButtonHandler } } }, formats: quillFormats, theme: "snow" }); if (disabled) { quill.disable(); } quill.on("text-change", () => { const text = quill.getText(); // Triggers CustomEvent with the cursor position // It is required in input_mentions.js let event = new CustomEvent("quill-position", { detail: quill.getSelection() }); container.dispatchEvent(event); if (text === "\n" || text === "\n\n") { $input.val(""); } else { $input.val(quill.root.innerHTML); } }); // After editor is ready, linebreak_module deletes two extraneous new lines quill.emitter.emit("editor-ready"); return quill; }; const quillEditor = () => { $(".editor-container").each((_idx, container) => { createQuillEditor(container); }); }; exports.Decidim = exports.Decidim || {}; exports.Decidim.quillEditor = quillEditor; exports.Decidim.createQuillEditor = createQuillEditor; })(window);