diff --git a/drupal/modules/avoindata-ckeditor5-plugins/css/styles.css b/drupal/modules/avoindata-ckeditor5-plugins/css/styles.css index e6c22c9988..7714e29798 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/css/styles.css +++ b/drupal/modules/avoindata-ckeditor5-plugins/css/styles.css @@ -39,6 +39,11 @@ display: inline-block; width: calc(100% - 45px); } +.avoindata-expander-title h2, +.avoindata-expander-title h3, +.avoindata-expander-title h4 { + margin: 0; +} .avoindata-expander-content { display: none; padding: 0 20px 15px; @@ -257,6 +262,12 @@ a.external svg { color: #2a6ebb; display: block; } +.ck-content .avoindata-expander .avoindata-expander-title h2, +.ck-content .avoindata-expander .avoindata-expander-title h3, +.ck-content .avoindata-expander .avoindata-expander-title h4 { + margin: 0; + margin-top: 1em; +} .ck-content .avoindata-expander .avoindata-expander-content { padding: 0 20px 15px; } diff --git a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExample.js b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExample.js index 33246060bc..a324dd80a5 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExample.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExample.js @@ -1 +1 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.CKEditor5=t():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataExample=t())}(self,(()=>(()=>{var e={"ckeditor5/src/core.js":(e,t,a)=>{e.exports=a("dll-reference CKEditor5.dll")("./src/core.js")},"ckeditor5/src/ui.js":(e,t,a)=>{e.exports=a("dll-reference CKEditor5.dll")("./src/ui.js")},"ckeditor5/src/widget.js":(e,t,a)=>{e.exports=a("dll-reference CKEditor5.dll")("./src/widget.js")},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},t={};function a(n){var o=t[n];if(void 0!==o)return o.exports;var i=t[n]={exports:{}};return e[n](i,i.exports,a),i.exports}a.d=(e,t)=>{for(var n in t)a.o(t,n)&&!a.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{var e;a.g.importScripts&&(e=a.g.location+"");var t=a.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var n=t.getElementsByTagName("script");if(n.length)for(var o=n.length-1;o>-1&&!e;)e=n[o--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),a.p=e})();var n={};return(()=>{"use strict";a.d(n,{default:()=>s});var e=a("ckeditor5/src/core.js"),t=a("ckeditor5/src/widget.js");class o extends e.Command{execute(){const{model:e}=this.editor;e.change((t=>{const a=function(e){const t=e.createElement("avoindataExample"),a=e.createElement("avoindataExampleTitle"),n=e.createElement("avoindataExampleContent");e.append(a,t),e.append(n,t);const o=e.createElement("paragraph");e.insertText("Title",o,0),e.append(o,a);const i=e.createElement("paragraph");return e.insertText("Content",i,0),e.append(i,n),t}(t);e.insertContent(a)}))}refresh(){const{model:e}=this.editor,{selection:t}=e.document,a=e.schema.findAllowedParent(t.getFirstPosition(),"avoindataExample");this.isEnabled=null!==a}}class i extends e.Plugin{static get requires(){return[t.Widget]}init(){this._defineSchema(),this._defineConverters(),this.editor.commands.add("insertAvoindataExampleCommand",new o(this.editor))}_defineSchema(){const e=this.editor.model.schema;e.register("avoindataExample",{isObject:!0,allowWhere:"$block"}),e.register("avoindataExampleTitle",{isLimit:!0,allowIn:"avoindataExample",allowContentOf:"$root"}),e.register("avoindataExampleContent",{isLimit:!0,allowIn:"avoindataExample",allowContentOf:"$root"}),e.addChildCheck(((e,t)=>{if((e.endsWith("avoindataExampleContent")||e.endsWith("avoindataExampleTitle"))&&"avoindataExample"===t.name)return!1}))}_defineConverters(){const{conversion:e}=this.editor;e.for("upcast").elementToElement({model:"avoindataExample",view:{name:"div",classes:"avoindata-example"}}),e.for("upcast").elementToElement({model:"avoindataExampleTitle",view:{name:"div",classes:"avoindata-example-title"}}),e.for("upcast").elementToElement({model:"avoindataExampleContent",view:{name:"div",classes:"avoindata-example-content"}}),e.for("dataDowncast").elementToElement({model:"avoindataExample",view:{name:"div",classes:"avoindata-example"}}),e.for("dataDowncast").elementToElement({model:"avoindataExampleTitle",view:{name:"div",classes:"avoindata-example-title"}}),e.for("dataDowncast").elementToElement({model:"avoindataExampleContent",view:{name:"div",classes:"avoindata-example-content"}}),e.for("editingDowncast").elementToElement({model:"avoindataExample",view:(e,{writer:a})=>{const n=a.createContainerElement("div",{class:"avoindata-example"});return(0,t.toWidget)(n,a,{label:"Avoindata Example"})}}),e.for("editingDowncast").elementToElement({model:"avoindataExampleTitle",view:(e,{writer:a})=>{const n=a.createEditableElement("div",{class:"avoindata-example-title"});return(0,t.toWidgetEditable)(n,a)}}),e.for("editingDowncast").elementToElement({model:"avoindataExampleContent",view:(e,{writer:a})=>{const n=a.createEditableElement("div",{class:"avoindata-example-content"});return(0,t.toWidgetEditable)(n,a)}})}}var r=a("ckeditor5/src/ui.js");class l extends e.Plugin{init(){const e=this.editor;e.ui.componentFactory.add("avoindataExample",(t=>{const a=e.commands.get("insertAvoindataExampleCommand"),n=new r.ButtonView(t);return n.set({label:e.t("Avoindata Example"),icon:'\n \n \n \n \n\n',tooltip:!0}),n.bind("isOn","isEnabled").to(a,"value","isEnabled"),this.listenTo(n,"execute",(()=>e.execute("insertAvoindataExampleCommand"))),n}))}}a.p;class d extends e.Plugin{static get requires(){return[i,l]}}const s={AvoindataExample:d}})(),n=n.default})())); \ No newline at end of file +!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports.CKEditor5=n():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataExample=n())}(self,(()=>(()=>{var __webpack_modules__={"./src/avoindataExample/avoindataExample.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ AvoindataExample)\n/* harmony export */ });\n/* harmony import */ var _avoindataExampleEditing__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataExampleEditing */ "./src/avoindataExample/avoindataExampleEditing.js");\n/* harmony import */ var _avoindataExampleUI__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./avoindataExampleUI */ "./src/avoindataExample/avoindataExampleUI.js");\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ckeditor5/src/core */ "ckeditor5/src/core.js");\n/* harmony import */ var _css_styles_css__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../css/styles.css */ "./css/styles.css");\n/**\n * @file This is what CKEditor refers to as a master (glue) plugin. Its role is\n * just to load the “editing” and “UI” components of this Plugin. Those\n * components could be included in this file, but\n *\n * I.e, this file\'s purpose is to integrate all the separate parts of the plugin\n * before it\'s made discoverable via index.js.\n */\n\n// The contents of AvoindataExampleUI and AvoindataExampleEditing could be included in this\n// file, but it is recommended to separate these concerns in different files.\n\n\n\n\n\nclass AvoindataExample extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__.Plugin {\n // Note that AvoindataExampleEditing and AvoindataExampleUI also extend `Plugin`, but these\n // are not seen as individual plugins by CKEditor 5. CKEditor 5 will only\n // discover the plugins explicitly exported in index.js.\n static get requires() {\n return [_avoindataExampleEditing__WEBPACK_IMPORTED_MODULE_0__["default"], _avoindataExampleUI__WEBPACK_IMPORTED_MODULE_1__["default"]];\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/./src/avoindataExample/avoindataExample.js?')},"./src/avoindataExample/avoindataExampleEditing.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataExampleEditing)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/widget */ \"ckeditor5/src/widget.js\");\n/* harmony import */ var _insertAvoindataExampleCommand__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./insertAvoindataExampleCommand */ \"./src/avoindataExample/insertAvoindataExampleCommand.js\");\n\n\n\n\n\n/**\n * CKEditor 5 plugins do not work directly with the DOM. They are defined as\n * plugin-specific data models that are then converted to markup that\n * is inserted in the DOM.\n *\n * CKEditor 5 internally interacts with expander as this model:\n * \n * \n * \n * \n *\n * Which is converted for the browser/user as this markup\n *
\n *
\n *
Title
\n *
\n *
Content
\n *
\n *\n * This file has the logic for defining the avoindataExample model, and for how it is\n * converted to standard DOM markup.\n */\nclass AvoindataExampleEditing extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n static get requires() {\n return [ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.Widget];\n }\n\n init() {\n this._defineSchema();\n this._defineConverters();\n this.editor.commands.add(\n 'insertAvoindataExampleCommand',\n new _insertAvoindataExampleCommand__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.editor),\n );\n }\n\n /*\n * This registers the structure that will be seen by CKEditor 5 as\n * \n * \n * \n * \n *\n * The logic in _defineConverters() will determine how this is converted to\n * markup.\n */\n _defineSchema() {\n // Schemas are registered via the central `editor` object.\n const schema = this.editor.model.schema;\n\n schema.register('avoindataExample', {\n // Behaves like a self-contained object (e.g. an image).\n isObject: true,\n // Allow in places where other blocks are allowed (e.g. directly in the root).\n allowWhere: '$block',\n });\n\n schema.register('avoindataExampleTitle', {\n // This creates a boundary for external actions such as clicking and\n // and keypress. For example, when the cursor is inside this box, the\n // keyboard shortcut for \"select all\" will be limited to the contents of\n // the box.\n isLimit: true,\n // This is only to be used within avoindataExample.\n allowIn: 'avoindataExample',\n // Allow content that is allowed in blocks (e.g. text with attributes).\n allowContentOf: '$root',\n });\n\n schema.register('avoindataExampleContent', {\n isLimit: true,\n allowIn: 'avoindataExample',\n allowContentOf: '$root',\n });\n\n schema.addChildCheck((context, childDefinition) => {\n // Disallow avoindataExample inside avoindataExampleContent.\n if (\n (context.endsWith('avoindataExampleContent') || context.endsWith('avoindataExampleTitle')) &&\n childDefinition.name === 'avoindataExample'\n ) {\n return false;\n }\n });\n }\n\n /**\n * Converters determine how CKEditor 5 models are converted into markup and\n * vice-versa.\n */\n _defineConverters() {\n // Converters are registered via the central editor object.\n const { conversion } = this.editor;\n\n // Upcast Converters: determine how existing HTML is interpreted by the\n // editor. These trigger when an editor instance loads.\n //\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model.\n conversion.for('upcast').elementToElement({\n model: 'avoindataExample',\n view: {\n name: 'div',\n classes: 'avoindata-example',\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of ,\n // as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataExampleTitle',\n view: {\n name: 'div',\n classes: 'avoindata-example-title',\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of\n // , as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataExampleContent',\n view: {\n name: 'div',\n classes: 'avoindata-example-content',\n },\n });\n\n // Data Downcast Converters: converts stored model data into HTML.\n // These trigger when content is saved.\n //\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataExample',\n view: {\n name: 'div',\n classes: 'avoindata-example',\n },\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataExampleTitle',\n view: {\n name: 'div',\n classes: 'avoindata-example-title',\n },\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataExampleContent',\n view: {\n name: 'div',\n classes: 'avoindata-example-content',\n },\n });\n\n // Editing Downcast Converters. These render the content to the user for\n // editing, i.e. this determines what gets seen in the editor. These trigger\n // after the Data Upcast Converters, and are re-triggered any time there\n // are changes to any of the models' properties.\n //\n // Convert the model into a container widget in the editor UI.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataExample',\n view: (modelElement, { writer: viewWriter }) => {\n const section = viewWriter.createContainerElement('div', {\n class: 'avoindata-example',\n });\n\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidget)(section, viewWriter, { label: 'Avoindata Example' });\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataExampleTitle',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-example-title',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataExampleContent',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-example-content',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n // Extra converters for the older format ckeditor4 plugins\n conversion.for('upcast').elementToElement({\n model: 'avoindataExampleTitle',\n view: {\n name: 'h2',\n classes: 'avoindata-example-title',\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataExampleTitle',\n view: {\n name: 'h3',\n classes: 'avoindata-example-title',\n },\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/./src/avoindataExample/avoindataExampleEditing.js?")},"./src/avoindataExample/avoindataExampleUI.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataExampleUI)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/ui */ \"ckeditor5/src/ui.js\");\n/* harmony import */ var _icons_icon_example_svg_source__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../icons/icon-example.svg?source */ \"./icons/icon-example.svg?source\");\n/**\n * @file registers the avoindataExample toolbar button and binds functionality to it.\n */\n\n\n\n\n\nclass AvoindataExampleUI extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n init() {\n const editor = this.editor;\n\n // This will register the avoindataExample toolbar button.\n editor.ui.componentFactory.add('avoindataExample', (locale) => {\n const command = editor.commands.get('insertAvoindataExampleCommand');\n const buttonView = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.ButtonView(locale);\n\n // Create the toolbar button.\n buttonView.set({\n label: editor.t('Avoindata Example'),\n icon: _icons_icon_example_svg_source__WEBPACK_IMPORTED_MODULE_2__,\n tooltip: true,\n });\n\n // Bind the state of the button to the command.\n buttonView.bind('isOn', 'isEnabled').to(command, 'value', 'isEnabled');\n\n // Execute the command when the button is clicked (executed).\n this.listenTo(buttonView, 'execute', () =>\n editor.execute('insertAvoindataExampleCommand'),\n );\n\n return buttonView;\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/./src/avoindataExample/avoindataExampleUI.js?")},"./src/avoindataExample/index.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _avoindataExample__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataExample */ "./src/avoindataExample/avoindataExample.js");\n/**\n * @file The build process always expects an index.js file. Anything exported\n * here will be recognized by CKEditor 5 as an available plugin. Multiple\n * plugins can be exported in this one file.\n *\n * I.e. this file\'s purpose is to make plugin(s) discoverable.\n */\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n AvoindataExample: _avoindataExample__WEBPACK_IMPORTED_MODULE_0__["default"],\n});\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/./src/avoindataExample/index.js?')},"./src/avoindataExample/insertAvoindataExampleCommand.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ InsertAvoindataExampleCommand)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/**\n * @file defines InsertAvoindataExampleCommand, which is executed when the avoindataExample\n * toolbar button is pressed.\n */\n\n\n\nclass InsertAvoindataExampleCommand extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Command {\n execute() {\n const { model } = this.editor;\n\n model.change((writer) => {\n // Insert * at the current selection position\n // in a way that will result in creating a valid model structure.\n const avoindataExample = createAvoindataExample(writer);\n model.insertContent(avoindataExample);\n });\n }\n\n refresh() {\n const { model } = this.editor;\n const { selection } = model.document;\n\n // Determine if the cursor (selection) is in a position where adding a\n // avoindataExample is permitted. This is based on the schema of the model(s)\n // currently containing the cursor.\n const allowedIn = model.schema.findAllowedParent(\n selection.getFirstPosition(),\n 'avoindataExample',\n );\n\n // If the cursor is not in a location where a avoindataExample can be added, return\n // null so the addition doesn't happen.\n this.isEnabled = allowedIn !== null;\n }\n}\n\nfunction createAvoindataExample(writer) {\n // Create instances of the elements registered with the editor in\n // avoindataexpanderediting.js.\n const avoindataExample = writer.createElement('avoindataExample');\n const avoindataExampleTitle = writer.createElement('avoindataExampleTitle');\n const avoindataExampleContent = writer.createElement('avoindataExampleContent');\n\n // Append the title and content elements to the avoindataExample, which matches\n // the parent/child relationship as defined in their schemas.\n writer.append(avoindataExampleTitle, avoindataExample);\n writer.append(avoindataExampleContent, avoindataExample);\n\n // The text content will automatically be wrapped in a\n // `

`.\n const title = writer.createElement('paragraph');\n writer.insertText('Title', title, 0);\n writer.append(title, avoindataExampleTitle);\n const content = writer.createElement('paragraph');\n writer.insertText('Content', content, 0);\n writer.append(content, avoindataExampleContent);\n\n // Return the element to be added to the editor.\n return avoindataExample;\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/./src/avoindataExample/insertAvoindataExampleCommand.js?")},"./css/styles.css":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../css/styles.css";\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/./css/styles.css?')},"./icons/icon-example.svg?source":module=>{"use strict";eval('module.exports = "\\n \\n \\n \\n \\n\\n";\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/./icons/icon-example.svg?')},"ckeditor5/src/core.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/core.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/delegated_./core.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/ui.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/ui.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/delegated_./ui.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/widget.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/widget.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataExample/delegated_./widget.js_from_dll-reference_CKEditor5.dll?')},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},__webpack_module_cache__={};function __webpack_require__(e){var n=__webpack_module_cache__[e];if(void 0!==n)return n.exports;var a=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](a,a.exports,__webpack_require__),a.exports}__webpack_require__.d=(e,n)=>{for(var a in n)__webpack_require__.o(n,a)&&!__webpack_require__.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:n[a]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.o=(e,n)=>Object.prototype.hasOwnProperty.call(e,n),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;__webpack_require__.g.importScripts&&(e=__webpack_require__.g.location+"");var n=__webpack_require__.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var a=n.getElementsByTagName("script");if(a.length)for(var t=a.length-1;t>-1&&!e;)e=a[t--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=e})();var __webpack_exports__=__webpack_require__("./src/avoindataExample/index.js");return __webpack_exports__=__webpack_exports__.default,__webpack_exports__})())); \ No newline at end of file diff --git a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExpander.js b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExpander.js index 0a70c7c335..29c7071d24 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExpander.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExpander.js @@ -1 +1 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.CKEditor5=t():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataExpander=t())}(self,(()=>(()=>{var e={"ckeditor5/src/core.js":(e,t,a)=>{e.exports=a("dll-reference CKEditor5.dll")("./src/core.js")},"ckeditor5/src/ui.js":(e,t,a)=>{e.exports=a("dll-reference CKEditor5.dll")("./src/ui.js")},"ckeditor5/src/widget.js":(e,t,a)=>{e.exports=a("dll-reference CKEditor5.dll")("./src/widget.js")},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},t={};function a(n){var r=t[n];if(void 0!==r)return r.exports;var o=t[n]={exports:{}};return e[n](o,o.exports,a),o.exports}a.d=(e,t)=>{for(var n in t)a.o(t,n)&&!a.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{var e;a.g.importScripts&&(e=a.g.location+"");var t=a.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var n=t.getElementsByTagName("script");if(n.length)for(var r=n.length-1;r>-1&&!e;)e=n[r--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),a.p=e})();var n={};return(()=>{"use strict";a.d(n,{default:()=>l});var e=a("ckeditor5/src/core.js"),t=a("ckeditor5/src/widget.js");class r extends e.Command{execute(){const{model:e}=this.editor;e.change((t=>{const a=function(e){const t=e.createElement("avoindataExpander"),a=e.createElement("avoindataExpanderTitle"),n=e.createElement("avoindataExpanderContent");e.append(a,t),e.append(n,t);const r=e.createElement("paragraph");e.insertText("Title",r,0),e.append(r,a);const o=e.createElement("paragraph");return e.insertText("Content",o,0),e.append(o,n),t}(t);e.insertContent(a)}))}refresh(){const{model:e}=this.editor,{selection:t}=e.document,a=e.schema.findAllowedParent(t.getFirstPosition(),"avoindataExpander");this.isEnabled=null!==a}}class o extends e.Plugin{static get requires(){return[t.Widget]}init(){this._defineSchema(),this._defineConverters(),this.editor.commands.add("insertAvoindataExpanderCommand",new r(this.editor))}_defineSchema(){const e=this.editor.model.schema;e.register("avoindataExpander",{isObject:!0,allowWhere:"$block"}),e.register("avoindataExpanderTitle",{isLimit:!0,allowIn:"avoindataExpander",allowContentOf:"$root"}),e.register("avoindataExpanderContent",{isLimit:!0,allowIn:"avoindataExpander",allowContentOf:"$root"}),e.addChildCheck(((e,t)=>{if((e.endsWith("avoindataExpanderContent")||e.endsWith("avoindataExpanderTitle"))&&"avoindataExpander"===t.name)return!1}))}_defineConverters(){const{conversion:e}=this.editor;e.for("upcast").elementToElement({model:"avoindataExpander",view:{name:"div",classes:"avoindata-expander"}}),e.for("upcast").elementToElement({model:"avoindataExpanderTitle",view:{name:"div",classes:"avoindata-expander-title"}}),e.for("upcast").elementToElement({model:"avoindataExpanderContent",view:{name:"div",classes:"avoindata-expander-content"}}),e.for("dataDowncast").elementToElement({model:"avoindataExpander",view:{name:"div",classes:"avoindata-expander"}}),e.for("dataDowncast").elementToStructure({model:"avoindataExpanderTitle",view:(e,{writer:t})=>t.createContainerElement("div",{class:"avoindata-expander-header"},[t.createContainerElement("div",{class:"avoindata-expander-title"},[t.createSlot()]),t.createContainerElement("span",{class:"icon-wrapper pull-right"},[t.createEmptyElement("i",{class:"fas fa-angle-down"})])])}),e.for("dataDowncast").elementToElement({model:"avoindataExpanderContent",view:{name:"div",classes:"avoindata-expander-content"}}),e.for("editingDowncast").elementToElement({model:"avoindataExpander",view:(e,{writer:a})=>{const n=a.createContainerElement("div",{class:"avoindata-expander"});return(0,t.toWidget)(n,a,{label:"Avoindata Expander"})}}),e.for("editingDowncast").elementToElement({model:"avoindataExpanderTitle",view:(e,{writer:a})=>{const n=a.createEditableElement("div",{class:"avoindata-expander-title"});return(0,t.toWidgetEditable)(n,a)}}),e.for("editingDowncast").elementToElement({model:"avoindataExpanderContent",view:(e,{writer:a})=>{const n=a.createEditableElement("div",{class:"avoindata-expander-content"});return(0,t.toWidgetEditable)(n,a)}}),e.for("upcast").elementToElement({model:"avoindataExpanderTitle",view:{name:"h2",classes:"avoindata-expander-title"}})}}var i=a("ckeditor5/src/ui.js");class d extends e.Plugin{init(){const e=this.editor;e.ui.componentFactory.add("avoindataExpander",(t=>{const a=e.commands.get("insertAvoindataExpanderCommand"),n=new i.ButtonView(t);return n.set({label:e.t("Avoindata Expander"),icon:'\n\t\n\t\t\n\t\t\n\t\n\n',tooltip:!0}),n.bind("isOn","isEnabled").to(a,"value","isEnabled"),this.listenTo(n,"execute",(()=>e.execute("insertAvoindataExpanderCommand"))),n}))}}a.p;class s extends e.Plugin{static get requires(){return[o,d]}}const l={AvoindataExpander:s}})(),n=n.default})())); \ No newline at end of file +!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports.CKEditor5=n():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataExpander=n())}(self,(()=>(()=>{var __webpack_modules__={"./src/avoindataExpander/avoindataExpander.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ AvoindataExpander)\n/* harmony export */ });\n/* harmony import */ var _avoindataExpanderEditing__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataExpanderEditing */ "./src/avoindataExpander/avoindataExpanderEditing.js");\n/* harmony import */ var _avoindataExpanderUI__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./avoindataExpanderUI */ "./src/avoindataExpander/avoindataExpanderUI.js");\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ckeditor5/src/core */ "ckeditor5/src/core.js");\n/* harmony import */ var _css_styles_css__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../css/styles.css */ "./css/styles.css");\n/**\n * @file This is what CKEditor refers to as a master (glue) plugin. Its role is\n * just to load the “editing” and “UI” components of this Plugin. Those\n * components could be included in this file, but\n *\n * I.e, this file\'s purpose is to integrate all the separate parts of the plugin\n * before it\'s made discoverable via index.js.\n */\n\n// The contents of AvoindataExpanderUI and AvoindataExpanderEditing could be included in this\n// file, but it is recommended to separate these concerns in different files.\n\n\n\n\n\nclass AvoindataExpander extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__.Plugin {\n // Note that ExpanderEditing and ExpanderUI also extend `Plugin`, but these\n // are not seen as individual plugins by CKEditor 5. CKEditor 5 will only\n // discover the plugins explicitly exported in index.js.\n static get requires() {\n return [_avoindataExpanderEditing__WEBPACK_IMPORTED_MODULE_0__["default"], _avoindataExpanderUI__WEBPACK_IMPORTED_MODULE_1__["default"]];\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/./src/avoindataExpander/avoindataExpander.js?')},"./src/avoindataExpander/avoindataExpanderEditing.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataExpanderEditing)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/widget */ \"ckeditor5/src/widget.js\");\n/* harmony import */ var _insertAvoindataExpanderCommand__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./insertAvoindataExpanderCommand */ \"./src/avoindataExpander/insertAvoindataExpanderCommand.js\");\n\n\n\n\n\n/**\n * CKEditor 5 plugins do not work directly with the DOM. They are defined as\n * plugin-specific data models that are then converted to markup that\n * is inserted in the DOM.\n *\n * CKEditor 5 internally interacts with expander as this model:\n * \n * \n * \n * \n *\n * Which is converted for the browser/user as this markup\n *

\n
\n
Title
\n \n
\n
Content
\n
\n *\n * This file has the logic for defining the avoindataExpander model, and for how it is\n * converted to standard DOM markup.\n */\nclass AvoindataExpanderEditing extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n static get requires() {\n return [ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.Widget];\n }\n\n init() {\n this._defineSchema();\n this._defineConverters();\n this.editor.commands.add(\n 'insertAvoindataExpanderCommand',\n new _insertAvoindataExpanderCommand__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.editor),\n );\n }\n\n /*\n * This registers the structure that will be seen by CKEditor 5 as\n * \n * \n * \n * \n *\n * The logic in _defineConverters() will determine how this is converted to\n * markup.\n */\n _defineSchema() {\n // Schemas are registered via the central `editor` object.\n const schema = this.editor.model.schema;\n\n schema.register('avoindataExpander', {\n // Behaves like a self-contained object (e.g. an image).\n isObject: true,\n // Allow in places where other blocks are allowed (e.g. directly in the root).\n allowWhere: '$block',\n });\n\n schema.register('avoindataExpanderTitle', {\n // This creates a boundary for external actions such as clicking and\n // and keypress. For example, when the cursor is inside this box, the\n // keyboard shortcut for \"select all\" will be limited to the contents of\n // the box.\n isLimit: true,\n // This is only to be used within simpleBox.\n allowIn: 'avoindataExpander',\n // Allow content that is allowed in blocks (e.g. text with attributes).\n allowContentOf: '$root',\n });\n\n schema.register('avoindataExpanderContent', {\n isLimit: true,\n allowIn: 'avoindataExpander',\n allowContentOf: '$root',\n });\n\n schema.addChildCheck((context, childDefinition) => {\n // Disallow avoindataExpander inside avoindataExpanderContent.\n if (\n (context.endsWith('avoindataExpanderContent') || context.endsWith('avoindataExpanderTitle')) &&\n childDefinition.name === 'avoindataExpander'\n ) {\n return false;\n }\n });\n }\n\n /**\n * Converters determine how CKEditor 5 models are converted into markup and\n * vice-versa.\n */\n _defineConverters() {\n // Converters are registered via the central editor object.\n const { conversion } = this.editor;\n\n // Upcast Converters: determine how existing HTML is interpreted by the\n // editor. These trigger when an editor instance loads.\n //\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model.\n conversion.for('upcast').elementToElement({\n model: 'avoindataExpander',\n view: {\n name: 'div',\n classes: 'avoindata-expander',\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of ,\n // as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataExpanderTitle',\n view: {\n name: 'div',\n classes: 'avoindata-expander-title',\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of\n // , as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataExpanderContent',\n view: {\n name: 'div',\n classes: 'avoindata-expander-content',\n },\n });\n\n // Data Downcast Converters: converts stored model data into HTML.\n // These trigger when content is saved.\n //\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataExpander',\n view: {\n name: 'div',\n classes: 'avoindata-expander',\n },\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToStructure({\n model: 'avoindataExpanderTitle',\n view: (modelElement, { writer }) => {\n return writer.createContainerElement('div', { class: 'avoindata-expander-header' }, [\n writer.createContainerElement('div', { class: 'avoindata-expander-title' }, [\n writer.createSlot()\n ]),\n writer.createContainerElement('span', { class: 'icon-wrapper pull-right' }, [\n writer.createEmptyElement('i', { class: 'fas fa-angle-down' })\n ])\n ])\n }\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataExpanderContent',\n view: {\n name: 'div',\n classes: 'avoindata-expander-content',\n },\n });\n\n // Editing Downcast Converters. These render the content to the user for\n // editing, i.e. this determines what gets seen in the editor. These trigger\n // after the Data Upcast Converters, and are re-triggered any time there\n // are changes to any of the models' properties.\n //\n // Convert the model into a container widget in the editor UI.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataExpander',\n view: (modelElement, { writer: viewWriter }) => {\n const section = viewWriter.createContainerElement('div', {\n class: 'avoindata-expander',\n });\n\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidget)(section, viewWriter, { label: 'Avoindata Expander' });\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataExpanderTitle',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-expander-title',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataExpanderContent',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-expander-content',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n // Extra converters for the older format ckeditor4 plugins\n conversion.for('upcast').elementToElement({\n model: 'avoindataExpanderTitle',\n view: {\n name: 'h2',\n classes: 'avoindata-expander-title',\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataExpanderTitle',\n view: {\n name: 'h3',\n classes: 'avoindata-expander-title',\n },\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/./src/avoindataExpander/avoindataExpanderEditing.js?")},"./src/avoindataExpander/avoindataExpanderUI.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataExpanderUI)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/ui */ \"ckeditor5/src/ui.js\");\n/* harmony import */ var _icons_icon_expander_svg_source__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../icons/icon-expander.svg?source */ \"./icons/icon-expander.svg?source\");\n/**\n * @file registers the avoindataExpander toolbar button and binds functionality to it.\n */\n\n\n\n\n\nclass AvoindataExpanderUI extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n init() {\n const editor = this.editor;\n\n // This will register the avoindataExpander toolbar button.\n editor.ui.componentFactory.add('avoindataExpander', (locale) => {\n const command = editor.commands.get('insertAvoindataExpanderCommand');\n const buttonView = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.ButtonView(locale);\n\n // Create the toolbar button.\n buttonView.set({\n label: editor.t('Avoindata Expander'),\n icon: _icons_icon_expander_svg_source__WEBPACK_IMPORTED_MODULE_2__,\n tooltip: true,\n });\n\n // Bind the state of the button to the command.\n buttonView.bind('isOn', 'isEnabled').to(command, 'value', 'isEnabled');\n\n // Execute the command when the button is clicked (executed).\n this.listenTo(buttonView, 'execute', () =>\n editor.execute('insertAvoindataExpanderCommand'),\n );\n\n return buttonView;\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/./src/avoindataExpander/avoindataExpanderUI.js?")},"./src/avoindataExpander/index.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _avoindataExpander__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataExpander */ "./src/avoindataExpander/avoindataExpander.js");\n/**\n * @file The build process always expects an index.js file. Anything exported\n * here will be recognized by CKEditor 5 as an available plugin. Multiple\n * plugins can be exported in this one file.\n *\n * I.e. this file\'s purpose is to make plugin(s) discoverable.\n */\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n AvoindataExpander: _avoindataExpander__WEBPACK_IMPORTED_MODULE_0__["default"],\n});\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/./src/avoindataExpander/index.js?')},"./src/avoindataExpander/insertAvoindataExpanderCommand.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ InsertAvoindataExpanderCommand)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/**\n * @file defines InsertAvoindataExpanderCommand, which is executed when the avoindataExpander\n * toolbar button is pressed.\n */\n\n\n\nclass InsertAvoindataExpanderCommand extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Command {\n execute() {\n const { model } = this.editor;\n\n model.change((writer) => {\n // Insert * at the current selection position\n // in a way that will result in creating a valid model structure.\n const avoindataExpander = createAvoindataExpander(writer);\n model.insertContent(avoindataExpander);\n });\n }\n\n refresh() {\n const { model } = this.editor;\n const { selection } = model.document;\n\n // Determine if the cursor (selection) is in a position where adding a\n // avoindataExpander is permitted. This is based on the schema of the model(s)\n // currently containing the cursor.\n const allowedIn = model.schema.findAllowedParent(\n selection.getFirstPosition(),\n 'avoindataExpander',\n );\n\n // If the cursor is not in a location where a avoindataExpander can be added, return\n // null so the addition doesn't happen.\n this.isEnabled = allowedIn !== null;\n }\n}\n\nfunction createAvoindataExpander(writer) {\n // Create instances of the three elements registered with the editor in\n // avoindataexpanderediting.js.\n const avoindataExpander = writer.createElement('avoindataExpander');\n const avoindataExpanderTitle = writer.createElement('avoindataExpanderTitle');\n const avoindataExpanderContent = writer.createElement('avoindataExpanderContent');\n\n // Append the title and content elements to the avoindataExpander, which matches\n // the parent/child relationship as defined in their schemas.\n writer.append(avoindataExpanderTitle, avoindataExpander);\n writer.append(avoindataExpanderContent, avoindataExpander);\n\n // The text content will automatically be wrapped in a\n // `

`.\n const title = writer.createElement('heading4');\n writer.insertText('Title', title, 0);\n writer.append(title, avoindataExpanderTitle);\n const content = writer.createElement('paragraph');\n writer.insertText('Content', content, 0);\n writer.append(content, avoindataExpanderContent);\n\n // Return the element to be added to the editor.\n return avoindataExpander;\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/./src/avoindataExpander/insertAvoindataExpanderCommand.js?")},"./css/styles.css":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../css/styles.css";\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/./css/styles.css?')},"./icons/icon-expander.svg?source":module=>{"use strict";eval('module.exports = "\\n\\t\\n\\t\\t\\n\\t\\t\\n\\t\\n\\n";\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/./icons/icon-expander.svg?')},"ckeditor5/src/core.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/core.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/delegated_./core.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/ui.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/ui.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/delegated_./ui.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/widget.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/widget.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataExpander/delegated_./widget.js_from_dll-reference_CKEditor5.dll?')},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},__webpack_module_cache__={};function __webpack_require__(e){var n=__webpack_module_cache__[e];if(void 0!==n)return n.exports;var a=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](a,a.exports,__webpack_require__),a.exports}__webpack_require__.d=(e,n)=>{for(var a in n)__webpack_require__.o(n,a)&&!__webpack_require__.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:n[a]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.o=(e,n)=>Object.prototype.hasOwnProperty.call(e,n),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;__webpack_require__.g.importScripts&&(e=__webpack_require__.g.location+"");var n=__webpack_require__.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var a=n.getElementsByTagName("script");if(a.length)for(var t=a.length-1;t>-1&&!e;)e=a[t--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=e})();var __webpack_exports__=__webpack_require__("./src/avoindataExpander/index.js");return __webpack_exports__=__webpack_exports__.default,__webpack_exports__})())); \ No newline at end of file diff --git a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExternalLink.js b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExternalLink.js index 0ece72ffc3..fa9fca2c90 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExternalLink.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataExternalLink.js @@ -1 +1 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.CKEditor5=t():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataExternalLink=t())}(self,(()=>(()=>{var e={"ckeditor5/src/core.js":(e,t,r)=>{e.exports=r("dll-reference CKEditor5.dll")("./src/core.js")},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},t={};function r(o){var n=t[o];if(void 0!==n)return n.exports;var i=t[o]={exports:{}};return e[o](i,i.exports,r),i.exports}r.d=(e,t)=>{for(var o in t)r.o(t,o)&&!r.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:t[o]})},r.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{var e;r.g.importScripts&&(e=r.g.location+"");var t=r.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var o=t.getElementsByTagName("script");if(o.length)for(var n=o.length-1;n>-1&&!e;)e=o[n--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),r.p=e})();var o={};return(()=>{"use strict";r.d(o,{default:()=>n});var e=r("ckeditor5/src/core.js");r.p;class t extends e.Plugin{init(){const{conversion:e}=this.editor;e.for("upcast").elementToAttribute({model:"linkIsExternal",view:{name:"a",classes:["external"],attributes:["aria-label","target"]}}),e.for("upcast").add((e=>{e.on("element:svg",((e,t,r)=>{const{consumable:o}=r,{viewItem:n}=t,i={name:"svg",attributes:["viewBox"]},s={name:"use",attributes:["href"]};if(!o.test(n,i))return;if(1!==n.childCount)return;const a=n.getChild(0);a.is("element","use")&&o.test(a,s)&&a?.getAttribute("href")?.includes("avoindata_external-link")&&(o.consume(n,i),o.consume(a,s))}))}))}static get pluginName(){return"AvoindataExternalLink"}}const n={AvoindataExternalLink:t}})(),o=o.default})())); \ No newline at end of file +!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports.CKEditor5=n():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataExternalLink=n())}(self,(()=>(()=>{var __webpack_modules__={"./src/avoindataExternalLink/avoindataExternalLink.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataExternalLink)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var _css_styles_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../css/styles.css */ \"./css/styles.css\");\n\n\n\nclass AvoindataExternalLink extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n init() {\n const { conversion } = this.editor;\n\n // Upcast Converter for the old ckeditor4 plugin format\n conversion.for('upcast').elementToAttribute({\n model: 'linkIsExternal',\n view: {\n name: 'a',\n classes: ['external'],\n attributes: ['aria-label', 'target'],\n },\n });\n\n // Extra consumption for the leftover svg icon\n conversion.for('upcast').add(dispatcher => {\n // Look for every view svg element.\n dispatcher.on('element:svg', (evt, data, conversionApi) => {\n // Get all the necessary items from the conversion API object.\n const {\n consumable\n } = conversionApi;\n\n // Get view item from data object.\n const { viewItem } = data;\n\n // Define elements consumables.\n const svg = { name: 'svg', attributes: ['viewBox'] };\n const use = { name: 'use', attributes: ['href'] };\n\n // Tests if the view element can be consumed.\n if (!consumable.test(viewItem, svg)) {\n return;\n }\n\n // Check if there is only one child.\n if (viewItem.childCount !== 1) {\n return;\n }\n\n // Get the first child element.\n const firstChildItem = viewItem.getChild(0);\n\n // Check if the first element is a div.\n if (!firstChildItem.is('element', 'use')) {\n return;\n }\n\n // Tests if the first child element can be consumed.\n if (!consumable.test(firstChildItem, use)) {\n return;\n }\n\n // If a use tag inside a svg has the string 'avoindata_external-link' within the href\n // we can assume it's the old ckeditor4 plugin format and simply get rid of them\n if (firstChildItem?.getAttribute('href')?.includes('avoindata_external-link')) {\n // Consume the main outer wrapper element.\n consumable.consume(viewItem, svg);\n // Consume the inner wrapper element.\n consumable.consume(firstChildItem, use);\n }\n });\n });\n }\n\n static get pluginName() {\n return 'AvoindataExternalLink';\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExternalLink/./src/avoindataExternalLink/avoindataExternalLink.js?")},"./src/avoindataExternalLink/index.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _avoindataExternalLink__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataExternalLink */ "./src/avoindataExternalLink/avoindataExternalLink.js");\n/**\n * @file The build process always expects an index.js file. Anything exported\n * here will be recognized by CKEditor 5 as an available plugin. Multiple\n * plugins can be exported in this one file.\n *\n * I.e. this file\'s purpose is to make plugin(s) discoverable.\n */\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n AvoindataExternalLink: _avoindataExternalLink__WEBPACK_IMPORTED_MODULE_0__["default"],\n});\n\n\n//# sourceURL=webpack://CKEditor5.avoindataExternalLink/./src/avoindataExternalLink/index.js?')},"./css/styles.css":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../css/styles.css";\n\n//# sourceURL=webpack://CKEditor5.avoindataExternalLink/./css/styles.css?')},"ckeditor5/src/core.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/core.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataExternalLink/delegated_./core.js_from_dll-reference_CKEditor5.dll?')},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},__webpack_module_cache__={};function __webpack_require__(e){var n=__webpack_module_cache__[e];if(void 0!==n)return n.exports;var r=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](r,r.exports,__webpack_require__),r.exports}__webpack_require__.d=(e,n)=>{for(var r in n)__webpack_require__.o(n,r)&&!__webpack_require__.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:n[r]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.o=(e,n)=>Object.prototype.hasOwnProperty.call(e,n),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;__webpack_require__.g.importScripts&&(e=__webpack_require__.g.location+"");var n=__webpack_require__.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var r=n.getElementsByTagName("script");if(r.length)for(var t=r.length-1;t>-1&&!e;)e=r[t--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=e})();var __webpack_exports__=__webpack_require__("./src/avoindataExternalLink/index.js");return __webpack_exports__=__webpack_exports__.default,__webpack_exports__})())); \ No newline at end of file diff --git a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataHint.js b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataHint.js index 39534fdb7e..cb79ab3799 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataHint.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataHint.js @@ -1 +1 @@ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.CKEditor5=e():(t.CKEditor5=t.CKEditor5||{},t.CKEditor5.avoindataHint=e())}(self,(()=>(()=>{var t={"ckeditor5/src/core.js":(t,e,n)=>{t.exports=n("dll-reference CKEditor5.dll")("./src/core.js")},"ckeditor5/src/ui.js":(t,e,n)=>{t.exports=n("dll-reference CKEditor5.dll")("./src/ui.js")},"ckeditor5/src/widget.js":(t,e,n)=>{t.exports=n("dll-reference CKEditor5.dll")("./src/widget.js")},"dll-reference CKEditor5.dll":t=>{"use strict";t.exports=CKEditor5.dll}},e={};function n(i){var o=e[i];if(void 0!==o)return o.exports;var a=e[i]={exports:{}};return t[i](a,a.exports,n),a.exports}n.d=(t,e)=>{for(var i in e)n.o(e,i)&&!n.o(t,i)&&Object.defineProperty(t,i,{enumerable:!0,get:e[i]})},n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}(),n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{var t;n.g.importScripts&&(t=n.g.location+"");var e=n.g.document;if(!t&&e&&(e.currentScript&&(t=e.currentScript.src),!t)){var i=e.getElementsByTagName("script");if(i.length)for(var o=i.length-1;o>-1&&!t;)t=i[o--].src}if(!t)throw new Error("Automatic publicPath is not supported in this browser");t=t.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),n.p=t})();var i={};return(()=>{"use strict";n.d(i,{default:()=>l});var t=n("ckeditor5/src/core.js"),e=n("ckeditor5/src/widget.js");class o extends t.Command{execute(){const{model:t}=this.editor;t.change((e=>{const n=function(t){const e=t.createElement("avoindataHint"),n=t.createElement("avoindataHintIcon"),i=t.createElement("avoindataHintContent");t.append(n,e),t.append(i,e);const o=t.createElement("paragraph");return t.insertText("Content",o,0),t.append(o,i),e}(e);t.insertContent(n)}))}refresh(){const{model:t}=this.editor,{selection:e}=t.document,n=t.schema.findAllowedParent(e.getFirstPosition(),"avoindataHint");this.isEnabled=null!==n}}const a=n.p+"../icons/icon-hint.svg";class r extends t.Plugin{static get requires(){return[e.Widget]}init(){this._defineSchema(),this._defineConverters(),this.editor.commands.add("insertAvoindataHintCommand",new o(this.editor))}_defineSchema(){const t=this.editor.model.schema;t.register("avoindataHint",{isObject:!0,allowWhere:"$block"}),t.register("avoindataHintIcon",{isObject:!0,isContent:!0,isInline:!0,isBlock:!1,isSelectable:!1,isLimit:!1,allowIn:"avoindataHint",allowAttributes:["src","alt","class"]}),t.register("avoindataHintContent",{isLimit:!0,allowIn:"avoindataHint",allowContentOf:"$root"}),t.addChildCheck(((t,e)=>{if(t.endsWith("avoindataHintContent")&&"avoindataHint"===e.name)return!1}))}_defineConverters(){const{conversion:t}=this.editor;t.for("upcast").elementToElement({model:"avoindataHint",view:{name:"div",classes:"avoindata-hint"}}),t.for("upcast").elementToElement({model:"avoindataHintIcon",view:{name:"img",classes:"avoindata-hint-icon"}}),t.for("upcast").elementToElement({model:"avoindataHintContent",view:{name:"div",classes:"avoindata-hint-content"}}),t.for("dataDowncast").elementToElement({model:"avoindataHint",view:{name:"div",classes:"avoindata-hint"}}),t.for("downcast").elementToElement({model:"avoindataHintIcon",view:(t,{writer:e})=>e.createEmptyElement("img",{class:"avoindata-hint-icon",src:a})}),t.for("dataDowncast").elementToElement({model:"avoindataHintContent",view:{name:"div",classes:"avoindata-hint-content"}}),t.for("editingDowncast").elementToElement({model:"avoindataHint",view:(t,{writer:n})=>{const i=n.createContainerElement("div",{class:"avoindata-hint"});return(0,e.toWidget)(i,n,{label:"Avoindata Hint"})}}),t.for("editingDowncast").elementToElement({model:"avoindataHintContent",view:(t,{writer:n})=>{const i=n.createEditableElement("div",{class:"avoindata-hint-content"});return(0,e.toWidgetEditable)(i,n)}}),t.for("upcast").elementToElement({model:"avoindataHintIcon",view:{name:"img",classes:"avoindata-hint-image"}})}}var s=n("ckeditor5/src/ui.js");class d extends t.Plugin{init(){const t=this.editor;t.ui.componentFactory.add("avoindataHint",(e=>{const n=t.commands.get("insertAvoindataHintCommand"),i=new s.ButtonView(e);return i.set({label:t.t("Avoindata Hint"),icon:'\n \n \n \n\n',tooltip:!0}),i.bind("isOn","isEnabled").to(n,"value","isEnabled"),this.listenTo(i,"execute",(()=>t.execute("insertAvoindataHintCommand"))),i}))}}n.p;class c extends t.Plugin{static get requires(){return[r,d]}}const l={AvoindataHint:c}})(),i=i.default})())); \ No newline at end of file +!function(n,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.CKEditor5=e():(n.CKEditor5=n.CKEditor5||{},n.CKEditor5.avoindataHint=e())}(self,(()=>(()=>{var __webpack_modules__={"./src/avoindataHint/avoindataHint.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ AvoindataHint)\n/* harmony export */ });\n/* harmony import */ var _avoindataHintEditing__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataHintEditing */ "./src/avoindataHint/avoindataHintEditing.js");\n/* harmony import */ var _avoindataHintUI__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./avoindataHintUI */ "./src/avoindataHint/avoindataHintUI.js");\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ckeditor5/src/core */ "ckeditor5/src/core.js");\n/* harmony import */ var _css_styles_css__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../css/styles.css */ "./css/styles.css");\n/**\n * @file This is what CKEditor refers to as a master (glue) plugin. Its role is\n * just to load the “editing” and “UI” components of this Plugin. Those\n * components could be included in this file, but\n *\n * I.e, this file\'s purpose is to integrate all the separate parts of the plugin\n * before it\'s made discoverable via index.js.\n */\n\n// The contents of AvoindataHintUI and AvoindataHintEditing could be included in this\n// file, but it is recommended to separate these concerns in different files.\n\n\n\n\n\nclass AvoindataHint extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__.Plugin {\n // Note that AvoindataHintEditing and AvoindataHintUI also extend `Plugin`, but these\n // are not seen as individual plugins by CKEditor 5. CKEditor 5 will only\n // discover the plugins explicitly exported in index.js.\n static get requires() {\n return [_avoindataHintEditing__WEBPACK_IMPORTED_MODULE_0__["default"], _avoindataHintUI__WEBPACK_IMPORTED_MODULE_1__["default"]];\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./src/avoindataHint/avoindataHint.js?')},"./src/avoindataHint/avoindataHintEditing.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataHintEditing)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/widget */ \"ckeditor5/src/widget.js\");\n/* harmony import */ var _insertAvoindataHintCommand__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./insertAvoindataHintCommand */ \"./src/avoindataHint/insertAvoindataHintCommand.js\");\n/* harmony import */ var _icons_icon_hint_svg__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../icons/icon-hint.svg */ \"./icons/icon-hint.svg\");\n\n\n\n\n\n\n/**\n * CKEditor 5 plugins do not work directly with the DOM. They are defined as\n * plugin-specific data models that are then converted to markup that\n * is inserted in the DOM.\n *\n * CKEditor 5 internally interacts with expander as this model:\n * \n * \n * \n * \n * \n * \n * \n *\n * Which is converted for the browser/user as this markup\n *

\n *
\n * \n *
Title
\n *
\n *
Content
\n *
\n *\n * This file has the logic for defining the avoindataHint model, and for how it is\n * converted to standard DOM markup.\n */\nclass AvoindataHintEditing extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n static get requires() {\n return [ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.Widget];\n }\n\n init() {\n this._defineSchema();\n this._defineConverters();\n this.editor.commands.add(\n 'insertAvoindataHintCommand',\n new _insertAvoindataHintCommand__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.editor),\n );\n }\n\n /*\n * This registers the structure that will be seen by CKEditor 5 as\n * \n * \n * \n * \n * \n * \n *\n * The logic in _defineConverters() will determine how this is converted to\n * markup.\n */\n _defineSchema() {\n // Schemas are registered via the central `editor` object.\n const schema = this.editor.model.schema;\n\n schema.register('avoindataHint', {\n // Behaves like a self-contained object (e.g. an image).\n isObject: true,\n // Allow in places where other blocks are allowed (e.g. directly in the root).\n allowWhere: '$block',\n });\n\n schema.register('avoindataHintIcon', {\n isObject: true,\n isContent: true,\n isInline: true,\n isBlock: false,\n isSelectable: false,\n isLimit: false,\n // This is only to be used within avoindataHint.\n allowIn: 'avoindataHint',\n allowAttributes: ['src', 'alt', 'class']\n });\n\n schema.register('avoindataHintContent', {\n isLimit: true,\n allowIn: 'avoindataHint',\n allowContentOf: '$root',\n });\n\n schema.addChildCheck((context, childDefinition) => {\n // Disallow avoindataHint inside avoindataHintContent.\n if (\n context.endsWith('avoindataHintContent') &&\n childDefinition.name === 'avoindataHint'\n ) {\n return false;\n }\n });\n }\n\n /**\n * Converters determine how CKEditor 5 models are converted into markup and\n * vice-versa.\n */\n _defineConverters() {\n // Converters are registered via the central editor object.\n const { conversion } = this.editor;\n\n // Upcast Converters: determine how existing HTML is interpreted by the\n // editor. These trigger when an editor instance loads.\n //\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model.\n conversion.for('upcast').elementToElement({\n model: 'avoindataHint',\n view: {\n name: 'div',\n classes: 'avoindata-hint',\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataHintIcon',\n view: {\n name: 'img',\n classes: 'avoindata-hint-icon',\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of\n // , as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataHintContent',\n view: {\n name: 'div',\n classes: 'avoindata-hint-content',\n },\n });\n\n // Data Downcast Converters: converts stored model data into HTML.\n // These trigger when content is saved.\n //\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataHint',\n view: {\n name: 'div',\n classes: 'avoindata-hint',\n },\n });\n\n // Instances of are saved as\n // \"Avoindata
.\n conversion.for('downcast').elementToElement({\n model: 'avoindataHintIcon',\n view: (modelElement, { writer }) => {\n return writer.createEmptyElement('img', { class: \"avoindata-hint-icon\", src: _icons_icon_hint_svg__WEBPACK_IMPORTED_MODULE_3__ })\n }\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataHintContent',\n view: {\n name: 'div',\n classes: 'avoindata-hint-content',\n },\n });\n\n // Editing Downcast Converters. These render the content to the user for\n // editing, i.e. this determines what gets seen in the editor. These trigger\n // after the Data Upcast Converters, and are re-triggered any time there\n // are changes to any of the models' properties.\n //\n // Convert the model into a container widget in the editor UI.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataHint',\n view: (modelElement, { writer: viewWriter }) => {\n const section = viewWriter.createContainerElement('div', {\n class: 'avoindata-hint',\n });\n\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidget)(section, viewWriter, { label: 'Avoindata Hint' });\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataHintContent',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-hint-content',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataHintIcon',\n view: {\n name: 'img',\n classes: 'avoindata-hint-image',\n },\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./src/avoindataHint/avoindataHintEditing.js?")},"./src/avoindataHint/avoindataHintUI.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataHintUI)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/ui */ \"ckeditor5/src/ui.js\");\n/* harmony import */ var _icons_icon_hint_svg_source__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../icons/icon-hint.svg?source */ \"./icons/icon-hint.svg?source\");\n/**\n * @file registers the avoindataHint toolbar button and binds functionality to it.\n */\n\n\n\n\n\nclass AvoindataHintUI extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n init() {\n const editor = this.editor;\n\n // This will register the avoindataHint toolbar button.\n editor.ui.componentFactory.add('avoindataHint', (locale) => {\n const command = editor.commands.get('insertAvoindataHintCommand');\n const buttonView = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.ButtonView(locale);\n\n // Create the toolbar button.\n buttonView.set({\n label: editor.t('Avoindata Hint'),\n icon: _icons_icon_hint_svg_source__WEBPACK_IMPORTED_MODULE_2__,\n tooltip: true,\n });\n\n // Bind the state of the button to the command.\n buttonView.bind('isOn', 'isEnabled').to(command, 'value', 'isEnabled');\n\n // Execute the command when the button is clicked (executed).\n this.listenTo(buttonView, 'execute', () =>\n editor.execute('insertAvoindataHintCommand'),\n );\n\n return buttonView;\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./src/avoindataHint/avoindataHintUI.js?")},"./src/avoindataHint/index.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _avoindataHint__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataHint */ "./src/avoindataHint/avoindataHint.js");\n/**\n * @file The build process always expects an index.js file. Anything exported\n * here will be recognized by CKEditor 5 as an available plugin. Multiple\n * plugins can be exported in this one file.\n *\n * I.e. this file\'s purpose is to make plugin(s) discoverable.\n */\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n AvoindataHint: _avoindataHint__WEBPACK_IMPORTED_MODULE_0__["default"],\n});\n\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./src/avoindataHint/index.js?')},"./src/avoindataHint/insertAvoindataHintCommand.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ InsertAvoindataHintCommand)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/**\n * @file defines InsertAvoindataHintCommand, which is executed when the avoindataHint\n * toolbar button is pressed.\n */\n\n\n\nclass InsertAvoindataHintCommand extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Command {\n execute() {\n const { model } = this.editor;\n\n model.change((writer) => {\n // Insert * at the current selection position\n // in a way that will result in creating a valid model structure.\n const avoindataHint = createAvoindataHint(writer);\n model.insertContent(avoindataHint);\n });\n }\n\n refresh() {\n const { model } = this.editor;\n const { selection } = model.document;\n\n // Determine if the cursor (selection) is in a position where adding a\n // avoindataHint is permitted. This is based on the schema of the model(s)\n // currently containing the cursor.\n const allowedIn = model.schema.findAllowedParent(\n selection.getFirstPosition(),\n 'avoindataHint',\n );\n\n // If the cursor is not in a location where a avoindataHint can be added, return\n // null so the addition doesn't happen.\n this.isEnabled = allowedIn !== null;\n }\n}\n\nfunction createAvoindataHint(writer) {\n // Create instances of the elements registered with the editor in\n // avoindataexpanderediting.js.\n const avoindataHint = writer.createElement('avoindataHint');\n const avoindataHintIcon = writer.createElement('avoindataHintIcon');\n const avoindataHintContent = writer.createElement('avoindataHintContent');\n\n // Append the title and content elements to the avoindataHint, which matches\n // the parent/child relationship as defined in their schemas.\n writer.append(avoindataHintIcon, avoindataHint);\n writer.append(avoindataHintContent, avoindataHint);\n\n // The text content will automatically be wrapped in a\n // `

`.\n const content = writer.createElement('paragraph');\n writer.insertText('Content', content, 0);\n writer.append(content, avoindataHintContent);\n\n // Return the element to be added to the editor.\n return avoindataHint;\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./src/avoindataHint/insertAvoindataHintCommand.js?")},"./css/styles.css":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../css/styles.css";\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./css/styles.css?')},"./icons/icon-hint.svg":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../icons/icon-hint.svg";\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./icons/icon-hint.svg?')},"./icons/icon-hint.svg?source":module=>{"use strict";eval('module.exports = "\\n \\n \\n \\n\\n";\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/./icons/icon-hint.svg?')},"ckeditor5/src/core.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/core.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/delegated_./core.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/ui.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/ui.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/delegated_./ui.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/widget.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/widget.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataHint/delegated_./widget.js_from_dll-reference_CKEditor5.dll?')},"dll-reference CKEditor5.dll":n=>{"use strict";n.exports=CKEditor5.dll}},__webpack_module_cache__={};function __webpack_require__(n){var e=__webpack_module_cache__[n];if(void 0!==e)return e.exports;var t=__webpack_module_cache__[n]={exports:{}};return __webpack_modules__[n](t,t.exports,__webpack_require__),t.exports}__webpack_require__.d=(n,e)=>{for(var t in e)__webpack_require__.o(e,t)&&!__webpack_require__.o(n,t)&&Object.defineProperty(n,t,{enumerable:!0,get:e[t]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(n){if("object"==typeof window)return window}}(),__webpack_require__.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),__webpack_require__.r=n=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},(()=>{var n;__webpack_require__.g.importScripts&&(n=__webpack_require__.g.location+"");var e=__webpack_require__.g.document;if(!n&&e&&(e.currentScript&&(n=e.currentScript.src),!n)){var t=e.getElementsByTagName("script");if(t.length)for(var i=t.length-1;i>-1&&!n;)n=t[i--].src}if(!n)throw new Error("Automatic publicPath is not supported in this browser");n=n.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=n})();var __webpack_exports__=__webpack_require__("./src/avoindataHint/index.js");return __webpack_exports__=__webpack_exports__.default,__webpack_exports__})())); \ No newline at end of file diff --git a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataNote.js b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataNote.js index 4817d67591..c27d698b6f 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataNote.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataNote.js @@ -1 +1 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.CKEditor5=t():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataNote=t())}(self,(()=>(()=>{var e={"ckeditor5/src/core.js":(e,t,o)=>{e.exports=o("dll-reference CKEditor5.dll")("./src/core.js")},"ckeditor5/src/ui.js":(e,t,o)=>{e.exports=o("dll-reference CKEditor5.dll")("./src/ui.js")},"ckeditor5/src/widget.js":(e,t,o)=>{e.exports=o("dll-reference CKEditor5.dll")("./src/widget.js")},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},t={};function o(n){var a=t[n];if(void 0!==a)return a.exports;var i=t[n]={exports:{}};return e[n](i,i.exports,o),i.exports}o.d=(e,t)=>{for(var n in t)o.o(t,n)&&!o.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},o.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),o.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{var e;o.g.importScripts&&(e=o.g.location+"");var t=o.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var n=t.getElementsByTagName("script");if(n.length)for(var a=n.length-1;a>-1&&!e;)e=n[a--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),o.p=e})();var n={};return(()=>{"use strict";o.d(n,{default:()=>c});var e=o("ckeditor5/src/core.js"),t=o("ckeditor5/src/widget.js");class a extends e.Command{execute(){const{model:e}=this.editor;e.change((t=>{const o=function(e){const t=e.createElement("avoindataNote"),o=e.createElement("avoindataNoteIcon"),n=e.createElement("avoindataNoteTitle"),a=e.createElement("avoindataNoteContent");e.append(o,t),e.append(n,t),e.append(a,t);const i=e.createElement("paragraph");e.insertText("Title",i,0),e.append(i,n);const r=e.createElement("paragraph");return e.insertText("Content",r,0),e.append(r,a),t}(t);e.insertContent(o)}))}refresh(){const{model:e}=this.editor,{selection:t}=e.document,o=e.schema.findAllowedParent(t.getFirstPosition(),"avoindataNote");this.isEnabled=null!==o}}const i=o.p+"../icons/icon-note.svg";class r extends e.Plugin{static get requires(){return[t.Widget]}init(){this._defineSchema(),this._defineConverters(),this.editor.commands.add("insertAvoindataNoteCommand",new a(this.editor))}_defineSchema(){const e=this.editor.model.schema;e.register("avoindataNote",{isObject:!0,allowWhere:"$block"}),e.register("avoindataNoteIcon",{isObject:!0,isContent:!0,isInline:!0,isBlock:!1,isSelectable:!1,isLimit:!1,allowIn:"avoindataNote",allowAttributes:["src","alt","class"]}),e.register("avoindataNoteTitle",{isLimit:!0,allowIn:"avoindataNote",allowContentOf:"$root"}),e.register("avoindataNoteContent",{isLimit:!0,allowIn:"avoindataNote",allowContentOf:"$root"}),e.addChildCheck(((e,t)=>{if((e.endsWith("avoindataNoteContent")||e.endsWith("avoindataNoteTitle"))&&"avoindataNote"===t.name)return!1}))}_defineConverters(){const{conversion:e}=this.editor;e.for("upcast").elementToElement({model:"avoindataNote",view:{name:"div",classes:"avoindata-note"}}),e.for("upcast").elementToElement({model:"avoindataNoteIcon",view:{name:"img",classes:"avoindata-note-icon"}}),e.for("upcast").elementToElement({model:"avoindataNoteTitle",view:{name:"div",classes:"avoindata-note-title"}}),e.for("upcast").elementToElement({model:"avoindataNoteContent",view:{name:"div",classes:"avoindata-note-content"}}),e.for("dataDowncast").elementToElement({model:"avoindataNote",view:{name:"div",classes:"avoindata-note"}}),e.for("dataDowncast").elementToElement({model:"avoindataNoteIcon",view:(e,{writer:t})=>t.createUIElement("img",{class:"avoindata-note-icon",src:i,alt:"Avoindata Note icon"})}),e.for("dataDowncast").elementToElement({model:"avoindataNoteTitle",view:{name:"div",classes:"avoindata-note-title"}}),e.for("dataDowncast").elementToElement({model:"avoindataNoteContent",view:{name:"div",classes:"avoindata-note-content"}}),e.for("editingDowncast").elementToElement({model:"avoindataNote",view:(e,{writer:o})=>{const n=o.createContainerElement("div",{class:"avoindata-note"});return(0,t.toWidget)(n,o,{label:"Avoindata Note"})}}),e.for("editingDowncast").elementToStructure({model:"avoindataNoteIcon",view:(e,{writer:t})=>t.createUIElement("img",{class:"avoindata-note-icon",src:i,alt:"Avoindata Note icon"})}),e.for("editingDowncast").elementToElement({model:"avoindataNoteTitle",view:(e,{writer:o})=>{const n=o.createEditableElement("div",{class:"avoindata-note-title"});return(0,t.toWidgetEditable)(n,o)}}),e.for("editingDowncast").elementToElement({model:"avoindataNoteContent",view:(e,{writer:o})=>{const n=o.createEditableElement("div",{class:"avoindata-note-content"});return(0,t.toWidgetEditable)(n,o)}}),e.for("upcast").elementToElement({model:"avoindataNoteIcon",view:{name:"img",classes:"avoindata-note-header-image"}})}}var s=o("ckeditor5/src/ui.js");class d extends e.Plugin{init(){const e=this.editor;e.ui.componentFactory.add("avoindataNote",(t=>{const o=e.commands.get("insertAvoindataNoteCommand"),n=new s.ButtonView(t);return n.set({label:e.t("Avoindata Note"),icon:'\n \n \n \n\n',tooltip:!0}),n.bind("isOn","isEnabled").to(o,"value","isEnabled"),this.listenTo(n,"execute",(()=>e.execute("insertAvoindataNoteCommand"))),n}))}}o.p;class l extends e.Plugin{static get requires(){return[r,d]}}const c={AvoindataNote:l}})(),n=n.default})())); \ No newline at end of file +!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports.CKEditor5=n():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataNote=n())}(self,(()=>(()=>{var __webpack_modules__={"./src/avoindataNote/avoindataNote.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ AvoindataNote)\n/* harmony export */ });\n/* harmony import */ var _avoindataNoteEditing__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataNoteEditing */ "./src/avoindataNote/avoindataNoteEditing.js");\n/* harmony import */ var _avoindataNoteUI__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./avoindataNoteUI */ "./src/avoindataNote/avoindataNoteUI.js");\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ckeditor5/src/core */ "ckeditor5/src/core.js");\n/* harmony import */ var _css_styles_css__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../css/styles.css */ "./css/styles.css");\n/**\n * @file This is what CKEditor refers to as a master (glue) plugin. Its role is\n * just to load the “editing” and “UI” components of this Plugin. Those\n * components could be included in this file, but\n *\n * I.e, this file\'s purpose is to integrate all the separate parts of the plugin\n * before it\'s made discoverable via index.js.\n */\n\n// The contents of AvoindataNoteUI and AvoindataNoteEditing could be included in this\n// file, but it is recommended to separate these concerns in different files.\n\n\n\n\n\nclass AvoindataNote extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__.Plugin {\n // Note that AvoindataNoteEditing and AvoindataNoteUI also extend `Plugin`, but these\n // are not seen as individual plugins by CKEditor 5. CKEditor 5 will only\n // discover the plugins explicitly exported in index.js.\n static get requires() {\n return [_avoindataNoteEditing__WEBPACK_IMPORTED_MODULE_0__["default"], _avoindataNoteUI__WEBPACK_IMPORTED_MODULE_1__["default"]];\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./src/avoindataNote/avoindataNote.js?')},"./src/avoindataNote/avoindataNoteEditing.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataNoteEditing)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/widget */ \"ckeditor5/src/widget.js\");\n/* harmony import */ var _insertAvoindataNoteCommand__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./insertAvoindataNoteCommand */ \"./src/avoindataNote/insertAvoindataNoteCommand.js\");\n/* harmony import */ var _icons_icon_note_svg__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../icons/icon-note.svg */ \"./icons/icon-note.svg\");\n\n\n\n\n\n\n\n/**\n * CKEditor 5 plugins do not work directly with the DOM. They are defined as\n * plugin-specific data models that are then converted to markup that\n * is inserted in the DOM.\n *\n * CKEditor 5 internally interacts with expander as this model:\n * \n * \n * \n * \n * \n * \n * \n *\n * Which is converted for the browser/user as this markup\n *

\n *
\n * \n *
Title
\n *
\n *
Content
\n *
\n *\n * This file has the logic for defining the avoindataNote model, and for how it is\n * converted to standard DOM markup.\n */\nclass AvoindataNoteEditing extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n static get requires() {\n return [ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.Widget];\n }\n\n init() {\n this._defineSchema();\n this._defineConverters();\n this.editor.commands.add(\n 'insertAvoindataNoteCommand',\n new _insertAvoindataNoteCommand__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.editor),\n );\n }\n\n /*\n * This registers the structure that will be seen by CKEditor 5 as\n * \n * \n * \n * \n * \n * \n * \n *\n * The logic in _defineConverters() will determine how this is converted to\n * markup.\n */\n _defineSchema() {\n // Schemas are registered via the central `editor` object.\n const schema = this.editor.model.schema;\n\n schema.register('avoindataNote', {\n // Behaves like a self-contained object (e.g. an image).\n isObject: true,\n // Allow in places where other blocks are allowed (e.g. directly in the root).\n allowWhere: '$block',\n });\n\n schema.register('avoindataNoteIcon', {\n isObject: true,\n isContent: true,\n isInline: true,\n isBlock: false,\n isSelectable: false,\n isLimit: false,\n // This is only to be used within avoindataNote.\n allowIn: 'avoindataNote',\n allowAttributes: ['src', 'alt', 'class']\n });\n\n schema.register('avoindataNoteTitle', {\n // This creates a boundary for external actions such as clicking and\n // and keypress. For example, when the cursor is inside this box, the\n // keyboard shortcut for \"select all\" will be limited to the contents of\n // the box.\n isLimit: true,\n // This is only to be used within avoindataNote.\n allowIn: 'avoindataNote',\n // Allow content that is allowed in blocks (e.g. text with attributes).\n allowContentOf: '$root',\n });\n\n schema.register('avoindataNoteContent', {\n isLimit: true,\n allowIn: 'avoindataNote',\n allowContentOf: '$root',\n });\n\n schema.addChildCheck((context, childDefinition) => {\n // Disallow avoindataNote inside avoindataNoteContent.\n if (\n (context.endsWith('avoindataNoteContent') || context.endsWith('avoindataNoteTitle')) &&\n childDefinition.name === 'avoindataNote'\n ) {\n return false;\n }\n });\n }\n\n /**\n * Converters determine how CKEditor 5 models are converted into markup and\n * vice-versa.\n */\n _defineConverters() {\n // Converters are registered via the central editor object.\n const { conversion } = this.editor;\n\n // Upcast Converters: determine how existing HTML is interpreted by the\n // editor. These trigger when an editor instance loads.\n //\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model.\n conversion.for('upcast').elementToElement({\n model: 'avoindataNote',\n view: {\n name: 'div',\n classes: 'avoindata-note',\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataNoteIcon',\n view: {\n name: 'img',\n classes: 'avoindata-note-icon'\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of ,\n // as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataNoteTitle',\n view: {\n name: 'div',\n classes: 'avoindata-note-title',\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of\n // , as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataNoteContent',\n view: {\n name: 'div',\n classes: 'avoindata-note-content',\n },\n });\n\n // Data Downcast Converters: converts stored model data into HTML.\n // These trigger when content is saved.\n //\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataNote',\n view: {\n name: 'div',\n classes: 'avoindata-note',\n },\n });\n\n // Instances of are saved as\n // \"Avoindata
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataNoteIcon',\n view: (modelElement, { writer }) => {\n return writer.createUIElement('img', { class: 'avoindata-note-icon', src: _icons_icon_note_svg__WEBPACK_IMPORTED_MODULE_3__, alt: \"Avoindata Note icon\" });\n }\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataNoteTitle',\n view: {\n name: 'div',\n classes: 'avoindata-note-title',\n },\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataNoteContent',\n view: {\n name: 'div',\n classes: 'avoindata-note-content',\n },\n });\n\n // Editing Downcast Converters. These render the content to the user for\n // editing, i.e. this determines what gets seen in the editor. These trigger\n // after the Data Upcast Converters, and are re-triggered any time there\n // are changes to any of the models' properties.\n //\n // Convert the model into a container widget in the editor UI.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataNote',\n view: (modelElement, { writer: viewWriter }) => {\n const section = viewWriter.createContainerElement('div', {\n class: 'avoindata-note',\n });\n\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidget)(section, viewWriter, { label: 'Avoindata Note' });\n },\n });\n\n // Convert the model into an UI element in the editor UI.\n conversion.for('editingDowncast').elementToStructure({\n model: 'avoindataNoteIcon',\n view: (modelElement, { writer }) => {\n return writer.createUIElement('img', { class: 'avoindata-note-icon', src: _icons_icon_note_svg__WEBPACK_IMPORTED_MODULE_3__, alt: \"Avoindata Note icon\" });\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataNoteTitle',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-note-title',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataNoteContent',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-note-content',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataNoteIcon',\n view: {\n name: 'img',\n classes: 'avoindata-note-header-image'\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataNoteTitle',\n view: {\n name: 'h2',\n classes: 'avoindata-note-title'\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataNoteTitle',\n view: {\n name: 'h3',\n classes: 'avoindata-note-title'\n },\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./src/avoindataNote/avoindataNoteEditing.js?")},"./src/avoindataNote/avoindataNoteUI.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataNoteUI)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/ui */ \"ckeditor5/src/ui.js\");\n/* harmony import */ var _icons_icon_note_svg_source__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../icons/icon-note.svg?source */ \"./icons/icon-note.svg?source\");\n/**\n * @file registers the avoindataNote toolbar button and binds functionality to it.\n */\n\n\n\n\n\nclass AvoindataNoteUI extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n init() {\n const editor = this.editor;\n\n // This will register the avoindataNote toolbar button.\n editor.ui.componentFactory.add('avoindataNote', (locale) => {\n const command = editor.commands.get('insertAvoindataNoteCommand');\n const buttonView = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.ButtonView(locale);\n\n // Create the toolbar button.\n buttonView.set({\n label: editor.t('Avoindata Note'),\n icon: _icons_icon_note_svg_source__WEBPACK_IMPORTED_MODULE_2__,\n tooltip: true,\n });\n\n // Bind the state of the button to the command.\n buttonView.bind('isOn', 'isEnabled').to(command, 'value', 'isEnabled');\n\n // Execute the command when the button is clicked (executed).\n this.listenTo(buttonView, 'execute', () =>\n editor.execute('insertAvoindataNoteCommand'),\n );\n\n return buttonView;\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./src/avoindataNote/avoindataNoteUI.js?")},"./src/avoindataNote/index.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _avoindataNote__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataNote */ "./src/avoindataNote/avoindataNote.js");\n/**\n * @file The build process always expects an index.js file. Anything exported\n * here will be recognized by CKEditor 5 as an available plugin. Multiple\n * plugins can be exported in this one file.\n *\n * I.e. this file\'s purpose is to make plugin(s) discoverable.\n */\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n AvoindataNote: _avoindataNote__WEBPACK_IMPORTED_MODULE_0__["default"],\n});\n\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./src/avoindataNote/index.js?')},"./src/avoindataNote/insertAvoindataNoteCommand.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ InsertAvoindataNoteCommand)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/**\n * @file defines InsertAvoindataNoteCommand, which is executed when the avoindataNote\n * toolbar button is pressed.\n */\n\n\n\nclass InsertAvoindataNoteCommand extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Command {\n execute() {\n const { model } = this.editor;\n\n model.change((writer) => {\n // Insert * at the current selection position\n // in a way that will result in creating a valid model structure.\n const avoindataNote = createAvoindataNote(writer);\n model.insertContent(avoindataNote);\n });\n }\n\n refresh() {\n const { model } = this.editor;\n const { selection } = model.document;\n\n // Determine if the cursor (selection) is in a position where adding a\n // avoindataNote is permitted. This is based on the schema of the model(s)\n // currently containing the cursor.\n const allowedIn = model.schema.findAllowedParent(\n selection.getFirstPosition(),\n 'avoindataNote',\n );\n\n // If the cursor is not in a location where a avoindataNote can be added, return\n // null so the addition doesn't happen.\n this.isEnabled = allowedIn !== null;\n }\n}\n\nfunction createAvoindataNote(writer) {\n // Create instances of the elements registered with the editor in\n // avoindataexpanderediting.js.\n const avoindataNote = writer.createElement('avoindataNote');\n const avoindataNoteIcon = writer.createElement('avoindataNoteIcon');\n const avoindataNoteTitle = writer.createElement('avoindataNoteTitle');\n const avoindataNoteContent = writer.createElement('avoindataNoteContent');\n\n // Append the title and content elements to the avoindataNote, which matches\n // the parent/child relationship as defined in their schemas.\n writer.append(avoindataNoteIcon, avoindataNote);\n writer.append(avoindataNoteTitle, avoindataNote);\n writer.append(avoindataNoteContent, avoindataNote);\n\n // The text content will automatically be wrapped in a\n // `

`.\n const title = writer.createElement('heading4');\n writer.insertText('Title', title, 0);\n writer.append(title, avoindataNoteTitle);\n const content = writer.createElement('paragraph');\n writer.insertText('Content', content, 0);\n writer.append(content, avoindataNoteContent);\n\n // Return the element to be added to the editor.\n return avoindataNote;\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./src/avoindataNote/insertAvoindataNoteCommand.js?")},"./css/styles.css":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../css/styles.css";\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./css/styles.css?')},"./icons/icon-note.svg":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../icons/icon-note.svg";\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./icons/icon-note.svg?')},"./icons/icon-note.svg?source":module=>{"use strict";eval('module.exports = "\\n \\n \\n \\n\\n";\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/./icons/icon-note.svg?')},"ckeditor5/src/core.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/core.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/delegated_./core.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/ui.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/ui.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/delegated_./ui.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/widget.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/widget.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataNote/delegated_./widget.js_from_dll-reference_CKEditor5.dll?')},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},__webpack_module_cache__={};function __webpack_require__(e){var n=__webpack_module_cache__[e];if(void 0!==n)return n.exports;var t=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](t,t.exports,__webpack_require__),t.exports}__webpack_require__.d=(e,n)=>{for(var t in n)__webpack_require__.o(n,t)&&!__webpack_require__.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:n[t]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.o=(e,n)=>Object.prototype.hasOwnProperty.call(e,n),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;__webpack_require__.g.importScripts&&(e=__webpack_require__.g.location+"");var n=__webpack_require__.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var t=n.getElementsByTagName("script");if(t.length)for(var o=t.length-1;o>-1&&!e;)e=t[o--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=e})();var __webpack_exports__=__webpack_require__("./src/avoindataNote/index.js");return __webpack_exports__=__webpack_exports__.default,__webpack_exports__})())); \ No newline at end of file diff --git a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataSection.js b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataSection.js index f8be29ee57..16d2a37b02 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataSection.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/js/avoindataSection.js @@ -1 +1 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.CKEditor5=t():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataSection=t())}(self,(()=>(()=>{var e={"ckeditor5/src/core.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/core.js")},"ckeditor5/src/ui.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/ui.js")},"ckeditor5/src/widget.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/widget.js")},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},t={};function i(n){var o=t[n];if(void 0!==o)return o.exports;var a=t[n]={exports:{}};return e[n](a,a.exports,i),a.exports}i.d=(e,t)=>{for(var n in t)i.o(t,n)&&!i.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},i.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),i.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{var e;i.g.importScripts&&(e=i.g.location+"");var t=i.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var n=t.getElementsByTagName("script");if(n.length)for(var o=n.length-1;o>-1&&!e;)e=n[o--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),i.p=e})();var n={};return(()=>{"use strict";i.d(n,{default:()=>d});var e=i("ckeditor5/src/core.js"),t=i("ckeditor5/src/widget.js");class o extends e.Command{execute(e){const{model:t}=this.editor;t.change((i=>{const n=i.model.document.selection?.getSelectedElement();if(n&&"avoindataSection"==n.name)i.setAttribute("avoindataSectionId",e,n);else{const n=function(e,t){const i=e.createElement("avoindataSection",{avoindataSectionId:t}),n=e.createElement("avoindataSectionTitle"),o=e.createElement("avoindataSectionContent");e.append(n,i),e.append(o,i);const a=e.createElement("paragraph");e.insertText("Title",a,0),e.append(a,n);const s=e.createElement("paragraph");return e.insertText("Content",s,0),e.append(s,o),i}(i,e);t.insertContent(n);const o=i.createSelection(n.getChild(0),"in");i.setSelection(o)}}))}refresh(){const{model:e}=this.editor,{selection:t}=e.document,i=e.schema.findAllowedParent(t.getFirstPosition(),"avoindataSection");this.isEnabled=null!==i}}class a extends e.Plugin{static get requires(){return[t.Widget]}init(){this._defineSchema(),this._defineConverters(),this.editor.commands.add("insertAvoindataSectionCommand",new o(this.editor))}_defineSchema(){const e=this.editor.model.schema;e.register("avoindataSection",{isObject:!0,allowWhere:"$block",allowAttributes:["avoindataSectionId"],allowContentOf:"$block"}),e.register("avoindataSectionTitle",{isLimit:!0,allowIn:"avoindataSection",allowContentOf:"$root"}),e.register("avoindataSectionContent",{isLimit:!0,allowIn:"avoindataSection",allowContentOf:"$root"}),e.addChildCheck(((e,t)=>{if((e.endsWith("avoindataSectionContent")||e.endsWith("avoindataSectionTitle"))&&"avoindataSection"===t.name)return!1}))}_defineConverters(){const{conversion:e}=this.editor;e.for("upcast").elementToElement({model:(e,{writer:t})=>t.createElement("avoindataSection",{avoindataSectionId:e.getAttribute("id")}),view:{name:"div",classes:"avoindata-section",attributes:["id"]}}),e.for("upcast").elementToElement({model:"avoindataSectionTitle",view:{name:"div",classes:"avoindata-section-title"}}),e.for("upcast").elementToElement({model:"avoindataSectionContent",view:{name:"div",classes:"avoindata-section-content"}}),e.for("dataDowncast").elementToElement({model:{name:"avoindataSection",attributes:["avoindataSectionId"]},view:(e,{writer:t})=>t.createContainerElement("div",{class:"avoindata-section",id:e.getAttribute("avoindataSectionId")})}),e.for("dataDowncast").elementToElement({model:"avoindataSectionTitle",view:{name:"div",classes:"avoindata-section-title"}}),e.for("dataDowncast").elementToElement({model:"avoindataSectionContent",view:{name:"div",classes:"avoindata-section-content"}}),e.for("editingDowncast").elementToElement({model:{name:"avoindataSection",attributes:["avoindataSectionId"]},view:(e,{writer:i})=>{const n=i.createContainerElement("div",{class:"avoindata-section",id:e.getAttribute("avoindataSectionId")});return(0,t.toWidget)(n,i,{label:"Avoindata Section widget"})}}),e.for("editingDowncast").elementToElement({model:"avoindataSectionTitle",view:(e,{writer:i})=>{const n=i.createEditableElement("div",{class:"avoindata-section-title"});return(0,t.toWidgetEditable)(n,i)}}),e.for("editingDowncast").elementToElement({model:"avoindataSectionContent",view:(e,{writer:i})=>{const n=i.createEditableElement("div",{class:"avoindata-section-content"});return(0,t.toWidgetEditable)(n,i)}}),e.for("upcast").elementToElement({model:"avoindataSectionTitle",view:{name:"h3",classes:"avoindata-section__title"}}),e.for("upcast").elementToElement({model:"avoindataSectionContent",view:{name:"div",classes:"avoindata-section__content"}})}}var s=i("ckeditor5/src/ui.js");class r extends s.View{constructor(e){super(e),this.heading=new s.LabelView(this.locale),this.heading.setTemplate({tag:"div",attributes:{class:["title"]},children:["Avoindata section"]}),this.idInputView=this._createInput("Id"),this.saveButtonView=this._createButton("Save",null,"btn btn-primary"),this.saveButtonView.type="submit",this.cancelButtonView=this._createButton("Cancel",null,"btn btn-secondary"),this.cancelButtonView.delegate("execute").to(this,"cancel"),this.childViews=this.createCollection([this.heading,this.idInputView,this.saveButtonView,this.cancelButtonView]),this.setTemplate({tag:"form",attributes:{class:["ck","ck-reset_all-excluded","avoindata-section-id-form"],tabindex:"-1"},children:this.childViews})}render(){super.render(),(0,s.submitHandler)({view:this})}focus(){this.childViews.get(1).focus()}_createInput(e){const t=new s.LabeledFieldView(this.locale,s.createLabeledInputText);return t.label=e,t}_createButton(e,t,i){const n=new s.ButtonView;return n.set({label:e,icon:t,tooltip:!0,class:i,withText:!0}),n}}class c extends e.Plugin{static get requires(){return[s.ContextualBalloon]}init(){const e=this.editor;this._balloon=e.plugins.get(s.ContextualBalloon),this.formView=this._createFormView();const t=e.commands.get("insertAvoindataSectionCommand");e.ui.componentFactory.add("avoindataSection",(i=>{const n=new s.ButtonView(i);return n.set({label:e.t("Avoindata Section"),icon:'\n \n \n \n \n\n',tooltip:!0}),n.bind("isOn","isEnabled").to(t,"value","isEnabled"),this.listenTo(n,"execute",(()=>{this._showUI()})),n}))}_createFormView(){const e=this.editor,t=new r(e.locale);return this.listenTo(t,"submit",(()=>{const i=t.idInputView.fieldView.element.value;e.model.change((t=>{e.execute("insertAvoindataSectionCommand",i)})),this._hideUI()})),this.listenTo(t,"cancel",(()=>{this._hideUI()})),(0,s.clickOutsideHandler)({emitter:t,activator:()=>this._balloon.visibleView===t,contextElements:[this._balloon.view.element],callback:()=>this._hideUI()}),t}_showUI(){const e=this.editor.model.document.selection;this._balloon.add({view:this.formView,position:this._getBalloonPositionData()});const t=e.getSelectedElement()?.getAttribute("avoindataSectionId")||"";this.formView.idInputView.fieldView.value=t,this.formView.focus()}_hideUI(){this.formView.idInputView.fieldView.value="",this.formView.element.reset(),this._balloon.remove(this.formView),this.editor.editing.view.focus()}_getBalloonPositionData(){const e=this.editor.editing.view,t=e.document;let i=null;return i=()=>e.domConverter.viewRangeToDom(t.selection.getFirstRange()),{target:i}}}i.p;class l extends e.Plugin{static get requires(){return[a,c]}}const d={AvoindataSection:l}})(),n=n.default})())); \ No newline at end of file +!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n():"function"==typeof define&&define.amd?define([],n):"object"==typeof exports?exports.CKEditor5=n():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.avoindataSection=n())}(self,(()=>(()=>{var __webpack_modules__={"./src/avoindataSection/avoindataSection.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (/* binding */ AvoindataSection)\n/* harmony export */ });\n/* harmony import */ var _avoindataSectionEditing__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataSectionEditing */ "./src/avoindataSection/avoindataSectionEditing.js");\n/* harmony import */ var _avoindataSectionUI__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./avoindataSectionUI */ "./src/avoindataSection/avoindataSectionUI.js");\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ckeditor5/src/core */ "ckeditor5/src/core.js");\n/* harmony import */ var _css_styles_css__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../css/styles.css */ "./css/styles.css");\n/**\n * @file This is what CKEditor refers to as a master (glue) plugin. Its role is\n * just to load the “editing” and “UI” components of this Plugin. Those\n * components could be included in this file, but\n *\n * I.e, this file\'s purpose is to integrate all the separate parts of the plugin\n * before it\'s made discoverable via index.js.\n */\n\n// The contents of AvoindataSectionUI and AvoindataSectionEditing could be included in this\n// file, but it is recommended to separate these concerns in different files.\n\n\n\n\n\nclass AvoindataSection extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_2__.Plugin {\n // Note that AvoindataSectionEditing and AvoindataSectionUI also extend `Plugin`, but these\n // are not seen as individual plugins by CKEditor 5. CKEditor 5 will only\n // discover the plugins explicitly exported in index.js.\n static get requires() {\n return [_avoindataSectionEditing__WEBPACK_IMPORTED_MODULE_0__["default"], _avoindataSectionUI__WEBPACK_IMPORTED_MODULE_1__["default"]];\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./src/avoindataSection/avoindataSection.js?')},"./src/avoindataSection/avoindataSectionEditing.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataSectionEditing)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/widget */ \"ckeditor5/src/widget.js\");\n/* harmony import */ var _insertAvoindataSectionCommand__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./insertAvoindataSectionCommand */ \"./src/avoindataSection/insertAvoindataSectionCommand.js\");\n\n\n\n\n\n/**\n * CKEditor 5 plugins do not work directly with the DOM. They are defined as\n * plugin-specific data models that are then converted to markup that\n * is inserted in the DOM.\n *\n * CKEditor 5 internally interacts with section as this model:\n * \n * \n * \n * \n *\n * Which is converted for the browser/user as this markup\n *

\n *
Title
\n *
Content
\n *
\n *\n * This file has the logic for defining the avoindataSection model, and for how it is\n * converted to standard DOM markup.\n */\nclass AvoindataSectionEditing extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n static get requires() {\n return [ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.Widget];\n }\n\n init() {\n this._defineSchema();\n this._defineConverters();\n this.editor.commands.add(\n 'insertAvoindataSectionCommand',\n new _insertAvoindataSectionCommand__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.editor),\n );\n }\n\n /*\n * This registers the structure that will be seen by CKEditor 5 as\n * \n * \n * \n * \n *\n * The logic in _defineConverters() will determine how this is converted to\n * markup.\n */\n _defineSchema() {\n // Schemas are registered via the central `editor` object.\n const schema = this.editor.model.schema;\n\n schema.register('avoindataSection', {\n // Behaves like a self-contained object (e.g. an image).\n isObject: true,\n // Allow in places where other blocks are allowed (e.g. directly in the root).\n allowWhere: '$block',\n allowAttributes: ['avoindataSectionId'],\n allowContentOf: '$block',\n });\n\n schema.register('avoindataSectionTitle', {\n // This creates a boundary for external actions such as clicking and\n // and keypress. For section, when the cursor is inside this box, the\n // keyboard shortcut for \"select all\" will be limited to the contents of\n // the box.\n isLimit: true,\n // This is only to be used within avoindataSection.\n allowIn: 'avoindataSection',\n // Allow content that is allowed in blocks (e.g. text with attributes).\n allowContentOf: '$root',\n });\n\n schema.register('avoindataSectionContent', {\n isLimit: true,\n allowIn: 'avoindataSection',\n allowContentOf: '$root',\n });\n\n schema.addChildCheck((context, childDefinition) => {\n // Disallow avoindataSection inside avoindataSectionContent.\n if (\n (context.endsWith('avoindataSectionContent') || context.endsWith('avoindataSectionTitle')) &&\n childDefinition.name === 'avoindataSection'\n ) {\n return false;\n }\n });\n }\n\n /**\n * Converters determine how CKEditor 5 models are converted into markup and\n * vice-versa.\n */\n _defineConverters() {\n // Converters are registered via the central editor object.\n const { conversion } = this.editor;\n\n // Upcast Converters: determine how existing HTML is interpreted by the\n // editor. These trigger when an editor instance loads.\n //\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model.\n conversion.for('upcast').elementToElement({\n model: (viewElement, { writer }) => {\n return writer.createElement('avoindataSection', { avoindataSectionId: viewElement.getAttribute('id') });\n },\n view: {\n name: 'div',\n classes: 'avoindata-section',\n attributes: ['id']\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of ,\n // as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataSectionTitle',\n view: {\n name: 'div',\n classes: 'avoindata-section-title',\n },\n });\n\n // If
is present in the existing markup\n // processed by CKEditor, then CKEditor recognizes and loads it as a\n // model, provided it is a child element of\n // , as required by the schema.\n conversion.for('upcast').elementToElement({\n model: 'avoindataSectionContent',\n view: {\n name: 'div',\n classes: 'avoindata-section-content',\n },\n });\n\n // Data Downcast Converters: converts stored model data into HTML.\n // These trigger when content is saved.\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: {\n name: 'avoindataSection',\n attributes: ['avoindataSectionId']\n },\n view: (modelElement, { writer }) => {\n return writer.createContainerElement(\n 'div', { class: 'avoindata-section', id: modelElement.getAttribute('avoindataSectionId') }\n );\n }\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataSectionTitle',\n view: {\n name: 'div',\n classes: 'avoindata-section-title',\n },\n });\n\n // Instances of are saved as\n //
{{inner content}}
.\n conversion.for('dataDowncast').elementToElement({\n model: 'avoindataSectionContent',\n view: {\n name: 'div',\n classes: 'avoindata-section-content',\n },\n });\n\n // Editing Downcast Converters. These render the content to the user for\n // editing, i.e. this determines what gets seen in the editor. These trigger\n // after the Data Upcast Converters, and are re-triggered any time there\n // are changes to any of the models' properties.\n //\n // Convert the model into a container widget in the editor UI.\n conversion.for('editingDowncast').elementToElement({\n model: {\n name: 'avoindataSection',\n attributes: ['avoindataSectionId']\n },\n view: (modelElement, { writer: viewWriter }) => {\n const section = viewWriter.createContainerElement('div', {\n class: 'avoindata-section',\n id: modelElement.getAttribute('avoindataSectionId')\n });\n\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidget)(section, viewWriter, { label: 'Avoindata Section widget' });\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataSectionTitle',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-section-title',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n // Convert the model into an editable
widget.\n conversion.for('editingDowncast').elementToElement({\n model: 'avoindataSectionContent',\n view: (modelElement, { writer: viewWriter }) => {\n const div = viewWriter.createEditableElement('div', {\n class: 'avoindata-section-content',\n });\n return (0,ckeditor5_src_widget__WEBPACK_IMPORTED_MODULE_1__.toWidgetEditable)(div, viewWriter);\n },\n });\n\n\n\n // Extra converters for the older format ckeditor4 plugins\n conversion.for('upcast').elementToElement({\n model: 'avoindataSectionTitle',\n view: {\n name: 'h2',\n classes: 'avoindata-section__title',\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataSectionTitle',\n view: {\n name: 'h3',\n classes: 'avoindata-section__title',\n },\n });\n\n conversion.for('upcast').elementToElement({\n model: 'avoindataSectionContent',\n view: {\n name: 'div',\n classes: 'avoindata-section__content',\n },\n });\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./src/avoindataSection/avoindataSectionEditing.js?")},"./src/avoindataSection/avoindataSectionUI.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ AvoindataSectionUI)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/* harmony import */ var ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/ui */ \"ckeditor5/src/ui.js\");\n/* harmony import */ var _avoindataSectionView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./avoindataSectionView */ \"./src/avoindataSection/avoindataSectionView.js\");\n/* harmony import */ var _icons_icon_section_svg_source__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../icons/icon-section.svg?source */ \"./icons/icon-section.svg?source\");\n/**\n * @file registers the avoindataSection toolbar button and binds functionality to it.\n */\n\n\n\n\n\n\nclass AvoindataSectionUI extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Plugin {\n static get requires() {\n return [ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.ContextualBalloon];\n }\n\n init() {\n const editor = this.editor;\n // Create the balloon and the form view.\n this._balloon = editor.plugins.get(ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.ContextualBalloon);\n this.formView = this._createFormView();\n const command = editor.commands.get('insertAvoindataSectionCommand');\n\n // This will register the avoindataSection toolbar button.\n editor.ui.componentFactory.add('avoindataSection', (locale) => {\n const buttonView = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.ButtonView(locale);\n\n // Create the toolbar button.\n buttonView.set({\n label: editor.t('Avoindata Section'),\n icon: _icons_icon_section_svg_source__WEBPACK_IMPORTED_MODULE_3__,\n tooltip: true\n });\n\n // Bind the state of the button to the command.\n buttonView.bind('isOn', 'isEnabled').to(command, 'value', 'isEnabled');\n\n // Execute the command when the button is clicked (executed).\n /* this.listenTo(buttonView, 'execute', () =>\n editor.execute('insertAvoindataSectionCommand'),\n ); */\n\n // Show the UI on button click.\n this.listenTo(buttonView, 'execute', () => {\n this._showUI();\n });\n\n return buttonView;\n });\n }\n\n _createFormView() {\n const editor = this.editor;\n const formView = new _avoindataSectionView__WEBPACK_IMPORTED_MODULE_2__[\"default\"](editor.locale);\n\n // Execute the command after clicking the \"Save\" button.\n this.listenTo(formView, 'submit', () => {\n // Grab values from the input fields.\n const id = formView.idInputView.fieldView.element.value;\n\n editor.model.change(writer => {\n editor.execute('insertAvoindataSectionCommand', id);\n });\n\n // Hide the form view after submit.\n this._hideUI();\n });\n\n // Hide the form view after clicking the \"Cancel\" button.\n this.listenTo(formView, 'cancel', () => {\n this._hideUI();\n });\n\n // Hide the form view when clicking outside the balloon.\n (0,ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_1__.clickOutsideHandler)({\n emitter: formView,\n activator: () => this._balloon.visibleView === formView,\n contextElements: [this._balloon.view.element],\n callback: () => this._hideUI()\n });\n\n return formView;\n }\n\n _showUI() {\n const selection = this.editor.model.document.selection;\n\n this._balloon.add({\n view: this.formView,\n position: this._getBalloonPositionData()\n });\n\n const id = selection.getSelectedElement()?.getAttribute('avoindataSectionId') || '';\n this.formView.idInputView.fieldView.value = id;\n\n this.formView.focus();\n }\n\n _hideUI() {\n // Clear the input field values and reset the form.\n this.formView.idInputView.fieldView.value = '';\n this.formView.element.reset();\n\n this._balloon.remove(this.formView);\n\n // Focus the editing view after inserting the abbreviation so the user can start typing the content\n // right away and keep the editor focused.\n this.editor.editing.view.focus();\n }\n\n _getBalloonPositionData() {\n const view = this.editor.editing.view;\n const viewDocument = view.document;\n let target = null;\n\n // Set a target position by converting view selection range to DOM\n target = () => view.domConverter.viewRangeToDom(viewDocument.selection.getFirstRange());\n\n return {\n target\n };\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./src/avoindataSection/avoindataSectionUI.js?")},"./src/avoindataSection/avoindataSectionView.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ FormView)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/ui */ \"ckeditor5/src/ui.js\");\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n\n\n\nclass FormView extends ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_0__.View {\n constructor(locale) {\n super(locale);\n\n this.heading = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_0__.LabelView(this.locale);\n this.heading.setTemplate({\n tag: 'div',\n attributes: {\n class: ['title']\n },\n children: ['Avoindata section']\n })\n\n this.idInputView = this._createInput('Id');\n\n this.saveButtonView = this._createButton('Save', null, 'btn btn-primary');\n // Submit type of the button will trigger the submit event on entire form when clicked\n // (see submitHandler() in render() below).\n this.saveButtonView.type = 'submit';\n\n this.cancelButtonView = this._createButton('Cancel', null, 'btn btn-secondary');\n\n // Delegate ButtonView#execute to FormView#cancel\n this.cancelButtonView.delegate('execute').to(this, 'cancel');\n\n this.childViews = this.createCollection([\n this.heading,\n this.idInputView,\n this.saveButtonView,\n this.cancelButtonView\n ]);\n\n this.setTemplate({\n tag: 'form',\n attributes: {\n class: ['ck', 'ck-reset_all-excluded', 'avoindata-section-id-form'],\n tabindex: '-1'\n },\n children: this.childViews\n });\n }\n\n render() {\n super.render();\n\n // Submit the form when the user clicked the save button or pressed enter in the input.\n (0,ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_0__.submitHandler)({\n view: this\n });\n }\n\n focus() {\n this.childViews.get(1).focus();\n }\n\n _createInput(label) {\n const labeledInput = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_0__.LabeledFieldView(this.locale, ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_0__.createLabeledInputText);\n\n labeledInput.label = label;\n\n return labeledInput;\n }\n\n _createButton(label, icon, className) {\n const button = new ckeditor5_src_ui__WEBPACK_IMPORTED_MODULE_0__.ButtonView();\n\n button.set({\n label,\n icon,\n tooltip: true,\n class: className,\n withText: true,\n });\n\n return button;\n }\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./src/avoindataSection/avoindataSectionView.js?")},"./src/avoindataSection/index.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval('__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _avoindataSection__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./avoindataSection */ "./src/avoindataSection/avoindataSection.js");\n/**\n * @file The build process always expects an index.js file. Anything exported\n * here will be recognized by CKEditor 5 as an available plugin. Multiple\n * plugins can be exported in this one file.\n *\n * I.e. this file\'s purpose is to make plugin(s) discoverable.\n */\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n AvoindataSection: _avoindataSection__WEBPACK_IMPORTED_MODULE_0__["default"],\n});\n\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./src/avoindataSection/index.js?')},"./src/avoindataSection/insertAvoindataSectionCommand.js":(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ InsertAvoindataSectionCommand)\n/* harmony export */ });\n/* harmony import */ var ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ckeditor5/src/core */ \"ckeditor5/src/core.js\");\n/**\n * @file defines InsertAvoindataSectionCommand, which is executed when the avoindataSection\n * toolbar button is pressed.\n */\n\n\n\nclass InsertAvoindataSectionCommand extends ckeditor5_src_core__WEBPACK_IMPORTED_MODULE_0__.Command {\n execute(id) {\n const { model } = this.editor;\n\n model.change((writer) => {\n const existingElement = writer.model.document.selection?.getSelectedElement();\n\n if (existingElement && existingElement.name == 'avoindataSection') {\n writer.setAttribute('avoindataSectionId', id, existingElement);\n } else {\n // Insert * at the current selection position\n // in a way that will result in creating a valid model structure.\n const avoindataSection = createAvoindataSection(writer, id);\n model.insertContent(avoindataSection);\n const selection = writer.createSelection(avoindataSection.getChild(0), 'in');\n writer.setSelection(selection)\n }\n });\n }\n\n refresh() {\n const { model } = this.editor;\n const { selection } = model.document;\n\n // Determine if the cursor (selection) is in a position where adding a\n // avoindataSection is permitted. This is based on the schema of the model(s)\n // currently containing the cursor.\n const allowedIn = model.schema.findAllowedParent(\n selection.getFirstPosition(),\n 'avoindataSection',\n );\n\n // If the cursor is not in a location where a avoindataSection can be added, return\n // null so the addition doesn't happen.\n this.isEnabled = allowedIn !== null;\n }\n}\n\nfunction createAvoindataSection(writer, id) {\n // Create instances of the elements registered with the editor in avoindataexpanderediting.js.\n const avoindataSection = writer.createElement('avoindataSection', { avoindataSectionId: id });\n const avoindataSectionTitle = writer.createElement('avoindataSectionTitle');\n const avoindataSectionContent = writer.createElement('avoindataSectionContent');\n\n // Append the title and content elements to the avoindataSection, which matches\n // the parent/child relationship as defined in their schemas.\n writer.append(avoindataSectionTitle, avoindataSection);\n writer.append(avoindataSectionContent, avoindataSection);\n\n // The text content will automatically be wrapped in a\n // `

`.\n const title = writer.createElement('heading3');\n writer.insertText('Title', title, 0);\n writer.append(title, avoindataSectionTitle);\n const content = writer.createElement('paragraph');\n writer.insertText('Content', content, 0);\n writer.append(content, avoindataSectionContent);\n\n // Return the element to be added to the editor.\n return avoindataSection;\n}\n\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./src/avoindataSection/insertAvoindataSectionCommand.js?")},"./css/styles.css":(module,__unused_webpack_exports,__webpack_require__)=>{"use strict";eval('module.exports = __webpack_require__.p + "../css/styles.css";\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./css/styles.css?')},"./icons/icon-section.svg?source":module=>{"use strict";eval('module.exports = "\\n \\n \\n \\n \\n\\n";\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/./icons/icon-section.svg?')},"ckeditor5/src/core.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/core.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/delegated_./core.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/ui.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/ui.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/delegated_./ui.js_from_dll-reference_CKEditor5.dll?')},"ckeditor5/src/widget.js":(module,__unused_webpack_exports,__webpack_require__)=>{eval('module.exports = (__webpack_require__(/*! dll-reference CKEditor5.dll */ "dll-reference CKEditor5.dll"))("./src/widget.js");\n\n//# sourceURL=webpack://CKEditor5.avoindataSection/delegated_./widget.js_from_dll-reference_CKEditor5.dll?')},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},__webpack_module_cache__={};function __webpack_require__(e){var n=__webpack_module_cache__[e];if(void 0!==n)return n.exports;var t=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](t,t.exports,__webpack_require__),t.exports}__webpack_require__.d=(e,n)=>{for(var t in n)__webpack_require__.o(n,t)&&!__webpack_require__.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:n[t]})},__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),__webpack_require__.o=(e,n)=>Object.prototype.hasOwnProperty.call(e,n),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{var e;__webpack_require__.g.importScripts&&(e=__webpack_require__.g.location+"");var n=__webpack_require__.g.document;if(!e&&n&&(n.currentScript&&(e=n.currentScript.src),!e)){var t=n.getElementsByTagName("script");if(t.length)for(var i=t.length-1;i>-1&&!e;)e=t[i--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=e})();var __webpack_exports__=__webpack_require__("./src/avoindataSection/index.js");return __webpack_exports__=__webpack_exports__.default,__webpack_exports__})())); \ No newline at end of file diff --git a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExample/avoindataExampleEditing.js b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExample/avoindataExampleEditing.js index 1c1778821b..b587474e70 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExample/avoindataExampleEditing.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExample/avoindataExampleEditing.js @@ -206,5 +206,22 @@ export default class AvoindataExampleEditing extends Plugin { return toWidgetEditable(div, viewWriter); }, }); + + // Extra converters for the older format ckeditor4 plugins + conversion.for('upcast').elementToElement({ + model: 'avoindataExampleTitle', + view: { + name: 'h2', + classes: 'avoindata-example-title', + }, + }); + + conversion.for('upcast').elementToElement({ + model: 'avoindataExampleTitle', + view: { + name: 'h3', + classes: 'avoindata-example-title', + }, + }); } } diff --git a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/avoindataExpanderEditing.js b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/avoindataExpanderEditing.js index 815614601e..c2cffbf13d 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/avoindataExpanderEditing.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/avoindataExpanderEditing.js @@ -222,5 +222,13 @@ export default class AvoindataExpanderEditing extends Plugin { classes: 'avoindata-expander-title', }, }); + + conversion.for('upcast').elementToElement({ + model: 'avoindataExpanderTitle', + view: { + name: 'h3', + classes: 'avoindata-expander-title', + }, + }); } } diff --git a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/insertAvoindataExpanderCommand.js b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/insertAvoindataExpanderCommand.js index 9fff3f65b4..e6fc82bda7 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/insertAvoindataExpanderCommand.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataExpander/insertAvoindataExpanderCommand.js @@ -49,7 +49,7 @@ function createAvoindataExpander(writer) { // The text content will automatically be wrapped in a // `

`. - const title = writer.createElement('paragraph'); + const title = writer.createElement('heading4'); writer.insertText('Title', title, 0); writer.append(title, avoindataExpanderTitle); const content = writer.createElement('paragraph'); diff --git a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/avoindataNoteEditing.js b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/avoindataNoteEditing.js index 3727233b2a..0eba77bf7a 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/avoindataNoteEditing.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/avoindataNoteEditing.js @@ -260,5 +260,21 @@ export default class AvoindataNoteEditing extends Plugin { classes: 'avoindata-note-header-image' }, }); + + conversion.for('upcast').elementToElement({ + model: 'avoindataNoteTitle', + view: { + name: 'h2', + classes: 'avoindata-note-title' + }, + }); + + conversion.for('upcast').elementToElement({ + model: 'avoindataNoteTitle', + view: { + name: 'h3', + classes: 'avoindata-note-title' + }, + }); } } diff --git a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/insertAvoindataNoteCommand.js b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/insertAvoindataNoteCommand.js index 0cb1625243..621fbe3deb 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/insertAvoindataNoteCommand.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataNote/insertAvoindataNoteCommand.js @@ -51,7 +51,7 @@ function createAvoindataNote(writer) { // The text content will automatically be wrapped in a // `

`. - const title = writer.createElement('paragraph'); + const title = writer.createElement('heading4'); writer.insertText('Title', title, 0); writer.append(title, avoindataNoteTitle); const content = writer.createElement('paragraph'); diff --git a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/avoindataSectionEditing.js b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/avoindataSectionEditing.js index 49a05d70c0..43690a1e65 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/avoindataSectionEditing.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/avoindataSectionEditing.js @@ -221,6 +221,14 @@ export default class AvoindataSectionEditing extends Plugin { // Extra converters for the older format ckeditor4 plugins + conversion.for('upcast').elementToElement({ + model: 'avoindataSectionTitle', + view: { + name: 'h2', + classes: 'avoindata-section__title', + }, + }); + conversion.for('upcast').elementToElement({ model: 'avoindataSectionTitle', view: { diff --git a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/insertAvoindataSectionCommand.js b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/insertAvoindataSectionCommand.js index b7d0d87374..829d99cf38 100644 --- a/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/insertAvoindataSectionCommand.js +++ b/drupal/modules/avoindata-ckeditor5-plugins/src/avoindataSection/insertAvoindataSectionCommand.js @@ -56,7 +56,7 @@ function createAvoindataSection(writer, id) { // The text content will automatically be wrapped in a // `

`. - const title = writer.createElement('paragraph'); + const title = writer.createElement('heading3'); writer.insertText('Title', title, 0); writer.append(title, avoindataSectionTitle); const content = writer.createElement('paragraph'); diff --git a/opendata-assets/src/less/drupal/custom-elements.less b/opendata-assets/src/less/drupal/custom-elements.less index d5f6e73413..0623e6caf5 100644 --- a/opendata-assets/src/less/drupal/custom-elements.less +++ b/opendata-assets/src/less/drupal/custom-elements.less @@ -47,6 +47,12 @@ padding: 20px 0 20px 20px; display: inline-block; width: calc(100% - 45px); + + h2, + h3, + h4 { + margin: 0; + } } .avoindata-expander-content { diff --git a/opendata-assets/src/less/drupal/editor.less b/opendata-assets/src/less/drupal/editor.less index 09217b60e3..46a1f2ffb4 100644 --- a/opendata-assets/src/less/drupal/editor.less +++ b/opendata-assets/src/less/drupal/editor.less @@ -42,13 +42,21 @@ border: 1px solid #ecedee; margin: 0; - .avoindata-expander-title { + + .avoindata-expander-title { font-size: 18px; font-weight: 600; line-height: 27px; padding: 0 20px 5px; color: #2a6ebb; display: block; + + h2, + h3, + h4 { + margin: 0; + margin-top: 1em; + } } .avoindata-expander-content {