@wizishop/wizi-block 4.2.2-beta → 4.2.23-beta

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/assets/i18n/en.json +1 -1
  2. package/assets/i18n/fr.json +1 -1
  3. package/bundles/wizishop-wizi-block.umd.js +602 -385
  4. package/bundles/wizishop-wizi-block.umd.js.map +1 -1
  5. package/bundles/wizishop-wizi-block.umd.min.js +1 -1
  6. package/bundles/wizishop-wizi-block.umd.min.js.map +1 -1
  7. package/esm2015/lib/components/configs/configs.component.js +2 -2
  8. package/esm2015/lib/dtos/blocks/parent-block.dto.js +3 -2
  9. package/esm2015/lib/dtos/blocks/witness/witness-background-one.dto.js +2 -2
  10. package/esm2015/lib/dtos/forms/forms.dto.js +2 -2
  11. package/esm2015/lib/shared/components/editorjs/editorjs.component.js +27 -7
  12. package/esm2015/lib/shared/components/editorjs/tools/inline/link-tool.component.js +76 -15
  13. package/esm2015/lib/shared/components/editorjs/tools/inline/text-background-color-tool.component.js +5 -7
  14. package/esm2015/lib/shared/components/editorjs/tools/inline/text-color-tool.component.js +4 -2
  15. package/esm2015/lib/shared/components/editorjs/tools/inline/text-size-tool.component.js +4 -3
  16. package/esm2015/lib/shared/components/editorjs/tools/inline/tool-type/inline-style-tool.component.js +51 -20
  17. package/esm2015/lib/shared/components/editorjs/tools/paragraph/text-type-tool.component.js +3 -2
  18. package/esm2015/lib/shared/components/editorjs/tools/paragraph/tool-type/paragraph-style-tool.component.js +35 -7
  19. package/esm2015/lib/shared/components/editorjs/tools/paragraph/tool-type/text-edition.component.js +5 -6
  20. package/esm2015/lib/shared/components/editorjs/tools/utils/editorjs-conversion.service.js +13 -1
  21. package/esm2015/lib/shared/components/editorjs/tools/utils/editorjs-tool.component.js +35 -2
  22. package/esm2015/lib/shared/components/editorjs/tools/utils/editorjs-translation.service.js +20 -0
  23. package/esm2015/lib/structures/text-backgrounds/four-rows-icon-text/text-backgrounds-four-rows-icon-text.component.js +7 -2
  24. package/esm2015/lib/structures/text-backgrounds/three-rows-icon-text/text-backgrounds-three-rows-icon-text.component.js +2 -2
  25. package/esm2015/lib/structures/text-backgrounds/two-rows-icon-text/text-backgrounds-two-rows-icon-text.component.js +2 -2
  26. package/esm2015/lib/structures/texts/quadruple-numbers/texts-quadruple-numbers.component.js +2 -2
  27. package/esm2015/lib/structures/timer/airport/timer-airport.component.js +2 -2
  28. package/esm2015/lib/structures/timer/background/timer-background.component.js +2 -2
  29. package/esm2015/lib/structures/timer/clock/timer-clock.component.js +2 -2
  30. package/esm2015/lib/structures/timer/multiple-img/timer-multiple-img.component.js +2 -2
  31. package/esm2015/lib/structures/timer/simple/timer-simple.component.js +2 -2
  32. package/esm2015/lib/wizi-block.component.js +4 -4
  33. package/esm2015/wizishop-wizi-block.js +227 -226
  34. package/fesm2015/wizishop-wizi-block.js +276 -74
  35. package/fesm2015/wizishop-wizi-block.js.map +1 -1
  36. package/lib/shared/components/editorjs/editorjs.component.d.ts +5 -1
  37. package/lib/shared/components/editorjs/tools/inline/link-tool.component.d.ts +1 -0
  38. package/lib/shared/components/editorjs/tools/inline/tool-type/inline-style-tool.component.d.ts +2 -2
  39. package/lib/shared/components/editorjs/tools/paragraph/tool-type/paragraph-style-tool.component.d.ts +5 -0
  40. package/lib/shared/components/editorjs/tools/utils/editorjs-tool.component.d.ts +2 -0
  41. package/lib/shared/components/editorjs/tools/utils/editorjs-translation.service.d.ts +7 -0
  42. package/lib/structures/text-backgrounds/four-rows-icon-text/text-backgrounds-four-rows-icon-text.component.d.ts +1 -0
  43. package/package.json +1 -1
  44. package/wizi-block.scss +2133 -1869
  45. package/wizishop-wizi-block.d.ts +226 -225
  46. package/wizishop-wizi-block.metadata.json +1 -1
@@ -1,5 +1,6 @@
1
1
  import { __awaiter } from "tslib";
2
2
  import { isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';
3
+ import { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';
3
4
  import { InlineStyleTool } from './tool-type/inline-style-tool.component';
4
5
  // @dynamic
5
6
  export class LinkTool extends InlineStyleTool {
@@ -30,6 +31,8 @@ export class LinkTool extends InlineStyleTool {
30
31
  linkInputId: 'linkInput',
31
32
  targetCheckboxId: 'targetCheckbox',
32
33
  obfuscationCheckboxId: 'obfuscationCheckbox',
34
+ addButtonClass: 'ce-inline-actions--link__add',
35
+ deleteButtonClass: 'ce-inline-actions--link__delete',
33
36
  };
34
37
  this.attributeName = 'data-htap,href';
35
38
  this.attributesToApply = [];
@@ -90,10 +93,11 @@ export class LinkTool extends InlineStyleTool {
90
93
  if (!this.parentEditor) {
91
94
  this.parentEditor = this.findParentEditor();
92
95
  }
96
+ let uuid = this.parentEditor.getAttribute('id').replace('editorJs-', '');
93
97
  this.attributesToApply = [];
94
- let targetCheckbox = this.parentEditor.querySelector('#' + this.linkCss['targetCheckboxId']);
95
- let obfuscationCheckbox = this.parentEditor.querySelector('#' + this.linkCss['obfuscationCheckboxId']);
96
- let linkInput = this.parentEditor.querySelector('#' + this.linkCss['linkInputId']);
98
+ let targetCheckbox = this.parentEditor.querySelector('#' + this.linkCss['targetCheckboxId'] + uuid);
99
+ let obfuscationCheckbox = this.parentEditor.querySelector('#' + this.linkCss['obfuscationCheckboxId'] + uuid);
100
+ let linkInput = this.parentEditor.querySelector('#' + this.linkCss['linkInputId'] + uuid);
97
101
  if (targetCheckbox.checked) {
98
102
  this.attributesToApply.push({
99
103
  name: 'target',
@@ -122,7 +126,25 @@ export class LinkTool extends InlineStyleTool {
122
126
  this.openLinkDropdown();
123
127
  });
124
128
  }
129
+ deleteLink() {
130
+ return __awaiter(this, void 0, void 0, function* () {
131
+ if (!this.parentEditor) {
132
+ this.parentEditor = this.findParentEditor();
133
+ }
134
+ this.tag = 'A';
135
+ this.attributesToApply = null;
136
+ this.modifies.tag = true;
137
+ this.resetUserSelection();
138
+ yield this.surround(null, true);
139
+ this.checkState(this.currentSelection);
140
+ this.openLinkDropdown();
141
+ });
142
+ }
125
143
  renderActions() {
144
+ if (!this.parentEditor) {
145
+ this.parentEditor = this.findParentEditor();
146
+ }
147
+ let uuid = this.parentEditor.getAttribute('id').replace('editorJs-', '');
126
148
  let container = document.createElement('div');
127
149
  container.className = this.linkCss['container'] + ' hidden';
128
150
  let linkContainer = document.createElement('div');
@@ -132,27 +154,31 @@ export class LinkTool extends InlineStyleTool {
132
154
  let obfuscationContainer = document.createElement('div');
133
155
  obfuscationContainer.className = this.linkCss['obfuscationContainer'];
134
156
  let applyButton = document.createElement('button');
135
- applyButton.innerText = this.api.i18n.t('add');
157
+ applyButton.className = this.linkCss['addButtonClass'];
158
+ applyButton.innerText = editorJSI18nDictionnary.messages.tools.link['add'];
136
159
  applyButton.addEventListener('click', () => this.applyLink());
137
160
  let linkInput = document.createElement('input');
138
- linkInput.setAttribute('id', this.linkCss['linkInputId']);
139
- linkInput.setAttribute('placeholder', this.api.i18n.t('placeholder'));
161
+ linkInput.setAttribute('id', this.linkCss['linkInputId'] + uuid);
162
+ linkInput.setAttribute('placeholder', editorJSI18nDictionnary.messages.tools.link['placeholder']);
140
163
  let targetCheckbox = document.createElement('input');
141
- targetCheckbox.setAttribute('id', this.linkCss['targetCheckboxId']);
164
+ targetCheckbox.setAttribute('id', this.linkCss['targetCheckboxId'] + uuid);
142
165
  targetCheckbox.setAttribute('type', 'checkbox');
143
166
  let targetLabel = document.createElement('label');
144
- targetLabel.innerText = this.api.i18n.t('external');
145
- targetLabel.setAttribute('for', this.linkCss['targetCheckboxId']);
167
+ targetLabel.innerText = editorJSI18nDictionnary.messages.tools.link['external'];
168
+ targetLabel.setAttribute('for', this.linkCss['targetCheckboxId'] + uuid);
146
169
  let obfuscationCheckbox = document.createElement('input');
147
- obfuscationCheckbox.setAttribute('id', this.linkCss['obfuscationCheckboxId']);
170
+ obfuscationCheckbox.setAttribute('id', this.linkCss['obfuscationCheckboxId'] + uuid);
148
171
  obfuscationCheckbox.setAttribute('type', 'checkbox');
149
172
  let obfuscationLabel = document.createElement('label');
150
- obfuscationLabel.innerText = this.api.i18n.t('obfuscated');
151
- obfuscationLabel.setAttribute('for', this.linkCss['obfuscationCheckboxId']);
173
+ obfuscationLabel.innerText = editorJSI18nDictionnary.messages.tools.link['obfuscated'];
174
+ obfuscationLabel.setAttribute('for', this.linkCss['obfuscationCheckboxId'] + uuid);
152
175
  let obfuscationTooltipContainer = document.createElement('div');
153
176
  let obbfuscationTooltip = document.createElement('div');
154
- obbfuscationTooltip.innerHTML = this.api.i18n.t('info');
177
+ obbfuscationTooltip.innerHTML = editorJSI18nDictionnary.messages.tools.link['info'];
155
178
  obfuscationTooltipContainer.appendChild(obbfuscationTooltip);
179
+ let deleteButton = document.createElement('button');
180
+ deleteButton.className = this.linkCss['deleteButtonClass'] + ' hidden';
181
+ deleteButton.addEventListener('click', () => this.deleteLink());
156
182
  linkContainer.appendChild(linkInput);
157
183
  targetContainer.appendChild(targetCheckbox);
158
184
  targetContainer.appendChild(targetLabel);
@@ -163,9 +189,42 @@ export class LinkTool extends InlineStyleTool {
163
189
  container.appendChild(targetContainer);
164
190
  container.appendChild(obfuscationContainer);
165
191
  container.appendChild(applyButton);
192
+ container.appendChild(deleteButton);
166
193
  return container;
167
194
  }
168
- showActions(mark) { }
195
+ showActions(mark) {
196
+ if (!this.parentEditor) {
197
+ this.parentEditor = this.findParentEditor();
198
+ }
199
+ let uuid = this.parentEditor.getAttribute('id').replace('editorJs-', '');
200
+ let targetCheckbox = this.parentEditor.querySelector('#' + this.linkCss['targetCheckboxId'] + uuid);
201
+ let obfuscationCheckbox = this.parentEditor.querySelector('#' + this.linkCss['obfuscationCheckboxId'] + uuid);
202
+ let linkInput = this.parentEditor.querySelector('#' + this.linkCss['linkInputId'] + uuid);
203
+ let deleteButton = this.parentEditor.querySelector('.' + this.linkCss['deleteButtonClass']);
204
+ let addButton = this.parentEditor.querySelector('.' + this.linkCss['addButtonClass']);
205
+ linkInput.value = '';
206
+ if (this.checkState(this.getSelection())) {
207
+ let selection = this.getSelection();
208
+ let element = this.hasStyle(selection.anchorNode);
209
+ linkInput.value = element.getAttribute(element.tagName.toLowerCase() === 'a' ? 'href' : 'data-htap');
210
+ targetCheckbox.checked = element.getAttribute('target') === '_blank';
211
+ obfuscationCheckbox.checked = element.tagName.toLowerCase() === 'span';
212
+ if (deleteButton.classList.contains('hidden')) {
213
+ deleteButton.classList.remove('hidden');
214
+ }
215
+ if (!addButton.classList.contains('hidden')) {
216
+ addButton.classList.add('hidden');
217
+ }
218
+ }
219
+ else {
220
+ if (!deleteButton.classList.contains('hidden')) {
221
+ deleteButton.classList.add('hidden');
222
+ }
223
+ if (addButton.classList.contains('hidden')) {
224
+ addButton.classList.remove('hidden');
225
+ }
226
+ }
227
+ }
169
228
  hideActions() { }
170
229
  openLinkDropdown() {
171
230
  if (!this.parentEditor) {
@@ -175,6 +234,7 @@ export class LinkTool extends InlineStyleTool {
175
234
  this.saveUserSelection();
176
235
  if (linkDropdown) {
177
236
  if (linkDropdown.classList.contains('hidden')) {
237
+ this.showActions(null);
178
238
  let viewportOffset = linkDropdown.getBoundingClientRect();
179
239
  if (viewportOffset.left + linkDropdown.offsetWidth > document.body.offsetWidth) {
180
240
  let left = parseInt(window.getComputedStyle(linkDropdown, null).getPropertyValue('left')) -
@@ -194,6 +254,7 @@ export class LinkTool extends InlineStyleTool {
194
254
  }, 400);
195
255
  }
196
256
  else {
257
+ this.resetUserSelection();
197
258
  this.isLinkDropdownOpen = false;
198
259
  linkDropdown.classList.add('hidden');
199
260
  }
@@ -218,4 +279,4 @@ export class LinkTool extends InlineStyleTool {
218
279
  }
219
280
  }
220
281
  LinkTool.title = 'Link';
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/link-tool.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { AttributeObject, isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';\nimport { InlineStyleTool } from './tool-type/inline-style-tool.component';\n\n// @dynamic\nexport class LinkTool extends InlineStyleTool implements InlineTool {\n    public static title = 'Link';\n\n    private readonly commandName: string = 'link';\n\n    private readonly CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--link',\n    };\n\n    private nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    private api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    hasSeparatorBefore = true;\n\n    modifies = {\n        tag: false,\n        style: false,\n        class: false,\n        attribute: true,\n    };\n\n    linkCss: Object = {\n        container: 'ce-inline-actions--link',\n        linkContainer: 'ce-inline-actions--link__container',\n        targetContainer: 'ce-inline-actions--link__target',\n        obfuscationContainer: 'ce-inline-actions--link__obfuscation',\n        linkInputId: 'linkInput',\n        targetCheckboxId: 'targetCheckbox',\n        obfuscationCheckboxId: 'obfuscationCheckbox',\n    };\n\n    attributeName: string = 'data-htap,href';\n\n    attributesToApply: Array<AttributeObject> | null = [];\n\n    isLinkDropdownOpen: boolean = false;\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    public get shortcut() {\n        return 'CMD+K';\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        this.nodes.button.addEventListener('click', () => this.openLinkDropdown());\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyLink: boolean = false) {\n        if (applyLink) {\n            this.saveUserSelection();\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n        }\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        const isActive = this.hasStyle(<HTMLElement>selection.anchorNode) ? true : false;\n        this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);\n\n        return isActive;\n    }\n\n    async applyLink() {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        this.attributesToApply = [];\n\n        let targetCheckbox = this.parentEditor.querySelector('#' + this.linkCss['targetCheckboxId']) as HTMLInputElement;\n        let obfuscationCheckbox = this.parentEditor.querySelector('#' + this.linkCss['obfuscationCheckboxId']) as HTMLInputElement;\n        let linkInput = this.parentEditor.querySelector('#' + this.linkCss['linkInputId']) as HTMLInputElement;\n        if (targetCheckbox.checked) {\n            this.attributesToApply.push({\n                name: 'target',\n                value: '_blank',\n            });\n        }\n        if (obfuscationCheckbox.checked) {\n            this.tag = 'SPAN';\n            this.modifies.tag = false;\n            this.attributesToApply.push({\n                name: 'data-htap',\n                value: btoa(linkInput.value),\n            });\n        } else {\n            this.tag = 'A';\n            this.modifies.tag = true;\n            this.attributesToApply.push({\n                name: 'href',\n                value: linkInput.value,\n            });\n        }\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkState(this.currentSelection);\n        this.openLinkDropdown();\n    }\n\n    renderActions() {\n        let container = document.createElement('div');\n        container.className = this.linkCss['container'] + ' hidden';\n\n        let linkContainer = document.createElement('div');\n        linkContainer.className = this.linkCss['linkContainer'];\n        let targetContainer = document.createElement('div');\n        targetContainer.className = this.linkCss['targetContainer'];\n        let obfuscationContainer = document.createElement('div');\n        obfuscationContainer.className = this.linkCss['obfuscationContainer'];\n        let applyButton = document.createElement('button');\n        applyButton.innerText = this.api.i18n.t('add');\n        applyButton.addEventListener('click', () => this.applyLink());\n\n        let linkInput = document.createElement('input');\n        linkInput.setAttribute('id', this.linkCss['linkInputId']);\n        linkInput.setAttribute('placeholder', this.api.i18n.t('placeholder'));\n        let targetCheckbox = document.createElement('input');\n        targetCheckbox.setAttribute('id', this.linkCss['targetCheckboxId']);\n        targetCheckbox.setAttribute('type', 'checkbox');\n        let targetLabel = document.createElement('label');\n        targetLabel.innerText = this.api.i18n.t('external');\n        targetLabel.setAttribute('for', this.linkCss['targetCheckboxId']);\n        let obfuscationCheckbox = document.createElement('input');\n        obfuscationCheckbox.setAttribute('id', this.linkCss['obfuscationCheckboxId']);\n        obfuscationCheckbox.setAttribute('type', 'checkbox');\n        let obfuscationLabel = document.createElement('label');\n        obfuscationLabel.innerText = this.api.i18n.t('obfuscated');\n        obfuscationLabel.setAttribute('for', this.linkCss['obfuscationCheckboxId']);\n        let obfuscationTooltipContainer = document.createElement('div');\n        let obbfuscationTooltip = document.createElement('div');\n        obbfuscationTooltip.innerHTML = this.api.i18n.t('info');\n        obfuscationTooltipContainer.appendChild(obbfuscationTooltip);\n\n        linkContainer.appendChild(linkInput);\n        targetContainer.appendChild(targetCheckbox);\n        targetContainer.appendChild(targetLabel);\n        obfuscationContainer.appendChild(obfuscationCheckbox);\n        obfuscationContainer.appendChild(obfuscationLabel);\n        obfuscationContainer.appendChild(obfuscationTooltipContainer);\n\n        container.appendChild(linkContainer);\n        container.appendChild(targetContainer);\n        container.appendChild(obfuscationContainer);\n        container.appendChild(applyButton);\n\n        return container;\n    }\n\n    showActions(mark) {}\n\n    hideActions() {}\n\n    openLinkDropdown() {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        let linkDropdown = this.parentEditor.querySelector('.' + this.linkCss['container']);\n        this.saveUserSelection();\n        if (linkDropdown) {\n            if (linkDropdown.classList.contains('hidden')) {\n                let viewportOffset = linkDropdown.getBoundingClientRect();\n                if (viewportOffset.left + (<HTMLElement>linkDropdown).offsetWidth > document.body.offsetWidth) {\n                    let left =\n                        parseInt(window.getComputedStyle(linkDropdown, null).getPropertyValue('left')) -\n                        (viewportOffset.left + (<HTMLElement>linkDropdown).offsetWidth - document.body.offsetWidth);\n                    (<HTMLElement>linkDropdown).style.left = left.toString() + 'px';\n                }\n                (<HTMLElement>linkDropdown).style.top =\n                    '-' +\n                    (\n                        (<HTMLElement>this.parentEditor.querySelector('.ce-inline-toolbar__buttons')).offsetHeight -\n                        (this.nodes.button.offsetTop + this.nodes.button.offsetHeight)\n                    ).toString() +\n                    'px';\n                linkDropdown.classList.remove('hidden');\n                this.currentSelection = this.getSelection();\n                document.addEventListener('click', ($event) => this.isLinkDropdownFocusedOut($event));\n                setTimeout(() => {\n                    this.isLinkDropdownOpen = true;\n                }, 400);\n            } else {\n                this.isLinkDropdownOpen = false;\n                linkDropdown.classList.add('hidden');\n            }\n        }\n    }\n\n    isLinkDropdownFocusedOut($event) {\n        let colorSelection = this.parentEditor.querySelector('.' + this.linkCss['container']);\n        if (this.isLinkDropdownOpen) {\n            let element = $event.target;\n            while (element) {\n                if (element.classList.contains(this.linkCss['container'])) {\n                    return;\n                }\n                element = element.parentElement;\n            }\n            document.removeEventListener('click', ($event) => this.isLinkDropdownFocusedOut($event));\n            this.isLinkDropdownOpen = false;\n            colorSelection.classList.add('hidden');\n            this.api.toolbar.close();\n            return true;\n        }\n    }\n}\n"]}
282
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/link-tool.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { AttributeObject, isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';\nimport { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';\nimport { InlineStyleTool } from './tool-type/inline-style-tool.component';\n\n// @dynamic\nexport class LinkTool extends InlineStyleTool implements InlineTool {\n    public static title = 'Link';\n\n    private readonly commandName: string = 'link';\n\n    private readonly CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--link',\n    };\n\n    private nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    private api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    hasSeparatorBefore = true;\n\n    modifies = {\n        tag: false,\n        style: false,\n        class: false,\n        attribute: true,\n    };\n\n    linkCss: Object = {\n        container: 'ce-inline-actions--link',\n        linkContainer: 'ce-inline-actions--link__container',\n        targetContainer: 'ce-inline-actions--link__target',\n        obfuscationContainer: 'ce-inline-actions--link__obfuscation',\n        linkInputId: 'linkInput',\n        targetCheckboxId: 'targetCheckbox',\n        obfuscationCheckboxId: 'obfuscationCheckbox',\n        addButtonClass: 'ce-inline-actions--link__add',\n        deleteButtonClass: 'ce-inline-actions--link__delete',\n    };\n\n    attributeName: string = 'data-htap,href';\n\n    attributesToApply: Array<AttributeObject> | null = [];\n\n    isLinkDropdownOpen: boolean = false;\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    public get shortcut() {\n        return 'CMD+K';\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        this.nodes.button.addEventListener('click', () => this.openLinkDropdown());\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyLink: boolean = false) {\n        if (applyLink) {\n            this.saveUserSelection();\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n        }\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        const isActive = this.hasStyle(<HTMLElement>selection.anchorNode) ? true : false;\n        this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);\n\n        return isActive;\n    }\n\n    async applyLink() {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        let uuid = this.parentEditor.getAttribute('id').replace('editorJs-', '');\n        this.attributesToApply = [];\n\n        let targetCheckbox = this.parentEditor.querySelector('#' + this.linkCss['targetCheckboxId'] + uuid) as HTMLInputElement;\n        let obfuscationCheckbox = this.parentEditor.querySelector('#' + this.linkCss['obfuscationCheckboxId'] + uuid) as HTMLInputElement;\n        let linkInput = this.parentEditor.querySelector('#' + this.linkCss['linkInputId'] + uuid) as HTMLInputElement;\n\n        if (targetCheckbox.checked) {\n            this.attributesToApply.push({\n                name: 'target',\n                value: '_blank',\n            });\n        }\n        if (obfuscationCheckbox.checked) {\n            this.tag = 'SPAN';\n            this.modifies.tag = false;\n            this.attributesToApply.push({\n                name: 'data-htap',\n                value: btoa(linkInput.value),\n            });\n        } else {\n            this.tag = 'A';\n            this.modifies.tag = true;\n            this.attributesToApply.push({\n                name: 'href',\n                value: linkInput.value,\n            });\n        }\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkState(this.currentSelection);\n        this.openLinkDropdown();\n    }\n\n    async deleteLink() {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        this.tag = 'A';\n        this.attributesToApply = null;\n        this.modifies.tag = true;\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkState(this.currentSelection);\n        this.openLinkDropdown();\n    }\n\n    renderActions() {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        let uuid = this.parentEditor.getAttribute('id').replace('editorJs-', '');\n        let container = document.createElement('div');\n        container.className = this.linkCss['container'] + ' hidden';\n\n        let linkContainer = document.createElement('div');\n        linkContainer.className = this.linkCss['linkContainer'];\n        let targetContainer = document.createElement('div');\n        targetContainer.className = this.linkCss['targetContainer'];\n        let obfuscationContainer = document.createElement('div');\n        obfuscationContainer.className = this.linkCss['obfuscationContainer'];\n        let applyButton = document.createElement('button');\n        applyButton.className = this.linkCss['addButtonClass'];\n        applyButton.innerText = editorJSI18nDictionnary.messages.tools.link['add'];\n        applyButton.addEventListener('click', () => this.applyLink());\n\n        let linkInput = document.createElement('input');\n        linkInput.setAttribute('id', this.linkCss['linkInputId'] + uuid);\n        linkInput.setAttribute('placeholder', editorJSI18nDictionnary.messages.tools.link['placeholder']);\n        let targetCheckbox = document.createElement('input');\n        targetCheckbox.setAttribute('id', this.linkCss['targetCheckboxId'] + uuid);\n        targetCheckbox.setAttribute('type', 'checkbox');\n        let targetLabel = document.createElement('label');\n        targetLabel.innerText = editorJSI18nDictionnary.messages.tools.link['external'];\n        targetLabel.setAttribute('for', this.linkCss['targetCheckboxId'] + uuid);\n        let obfuscationCheckbox = document.createElement('input');\n        obfuscationCheckbox.setAttribute('id', this.linkCss['obfuscationCheckboxId'] + uuid);\n        obfuscationCheckbox.setAttribute('type', 'checkbox');\n        let obfuscationLabel = document.createElement('label');\n        obfuscationLabel.innerText = editorJSI18nDictionnary.messages.tools.link['obfuscated'];\n        obfuscationLabel.setAttribute('for', this.linkCss['obfuscationCheckboxId'] + uuid);\n        let obfuscationTooltipContainer = document.createElement('div');\n        let obbfuscationTooltip = document.createElement('div');\n        obbfuscationTooltip.innerHTML = editorJSI18nDictionnary.messages.tools.link['info'];\n        obfuscationTooltipContainer.appendChild(obbfuscationTooltip);\n        let deleteButton = document.createElement('button');\n        deleteButton.className = this.linkCss['deleteButtonClass'] + ' hidden';\n        deleteButton.addEventListener('click', () => this.deleteLink());\n\n        linkContainer.appendChild(linkInput);\n        targetContainer.appendChild(targetCheckbox);\n        targetContainer.appendChild(targetLabel);\n        obfuscationContainer.appendChild(obfuscationCheckbox);\n        obfuscationContainer.appendChild(obfuscationLabel);\n        obfuscationContainer.appendChild(obfuscationTooltipContainer);\n\n        container.appendChild(linkContainer);\n        container.appendChild(targetContainer);\n        container.appendChild(obfuscationContainer);\n        container.appendChild(applyButton);\n        container.appendChild(deleteButton);\n\n        return container;\n    }\n\n    showActions(mark) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        let uuid = this.parentEditor.getAttribute('id').replace('editorJs-', '');\n\n        let targetCheckbox = this.parentEditor.querySelector('#' + this.linkCss['targetCheckboxId'] + uuid) as HTMLInputElement;\n        let obfuscationCheckbox = this.parentEditor.querySelector('#' + this.linkCss['obfuscationCheckboxId'] + uuid) as HTMLInputElement;\n        let linkInput = this.parentEditor.querySelector('#' + this.linkCss['linkInputId'] + uuid) as HTMLInputElement;\n        let deleteButton = this.parentEditor.querySelector('.' + this.linkCss['deleteButtonClass']);\n        let addButton = this.parentEditor.querySelector('.' + this.linkCss['addButtonClass']);\n        linkInput.value = '';\n        if (this.checkState(this.getSelection())) {\n            let selection = this.getSelection();\n            let element = this.hasStyle(<HTMLElement>selection.anchorNode);\n            linkInput.value = element.getAttribute(element.tagName.toLowerCase() === 'a' ? 'href' : 'data-htap');\n            targetCheckbox.checked = element.getAttribute('target') === '_blank';\n            obfuscationCheckbox.checked = element.tagName.toLowerCase() === 'span';\n            if (deleteButton.classList.contains('hidden')) {\n                deleteButton.classList.remove('hidden');\n            }\n            if (!addButton.classList.contains('hidden')) {\n                addButton.classList.add('hidden');\n            }\n        } else {\n            if (!deleteButton.classList.contains('hidden')) {\n                deleteButton.classList.add('hidden');\n            }\n            if (addButton.classList.contains('hidden')) {\n                addButton.classList.remove('hidden');\n            }\n        }\n    }\n\n    hideActions() {}\n\n    openLinkDropdown() {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        let linkDropdown = this.parentEditor.querySelector('.' + this.linkCss['container']);\n        this.saveUserSelection();\n        if (linkDropdown) {\n            if (linkDropdown.classList.contains('hidden')) {\n                this.showActions(null);\n                let viewportOffset = linkDropdown.getBoundingClientRect();\n                if (viewportOffset.left + (<HTMLElement>linkDropdown).offsetWidth > document.body.offsetWidth) {\n                    let left =\n                        parseInt(window.getComputedStyle(linkDropdown, null).getPropertyValue('left')) -\n                        (viewportOffset.left + (<HTMLElement>linkDropdown).offsetWidth - document.body.offsetWidth);\n                    (<HTMLElement>linkDropdown).style.left = left.toString() + 'px';\n                }\n                (<HTMLElement>linkDropdown).style.top =\n                    '-' +\n                    (\n                        (<HTMLElement>this.parentEditor.querySelector('.ce-inline-toolbar__buttons')).offsetHeight -\n                        (this.nodes.button.offsetTop + this.nodes.button.offsetHeight)\n                    ).toString() +\n                    'px';\n                linkDropdown.classList.remove('hidden');\n                this.currentSelection = this.getSelection();\n                document.addEventListener('click', ($event) => this.isLinkDropdownFocusedOut($event));\n                setTimeout(() => {\n                    this.isLinkDropdownOpen = true;\n                }, 400);\n            } else {\n                this.resetUserSelection();\n                this.isLinkDropdownOpen = false;\n                linkDropdown.classList.add('hidden');\n            }\n        }\n    }\n\n    isLinkDropdownFocusedOut($event) {\n        let colorSelection = this.parentEditor.querySelector('.' + this.linkCss['container']);\n        if (this.isLinkDropdownOpen) {\n            let element = $event.target;\n            while (element) {\n                if (element.classList.contains(this.linkCss['container'])) {\n                    return;\n                }\n                element = element.parentElement;\n            }\n            document.removeEventListener('click', ($event) => this.isLinkDropdownFocusedOut($event));\n            this.isLinkDropdownOpen = false;\n            colorSelection.classList.add('hidden');\n            this.api.toolbar.close();\n            return true;\n        }\n    }\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import { __awaiter } from "tslib";
2
2
  import { isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';
3
+ import { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';
3
4
  import { ColorTool } from './tool-type/color-tool.component';
4
5
  // @dynamic
5
6
  export class TextBackgroundColorTool extends ColorTool {
@@ -73,12 +74,8 @@ export class TextBackgroundColorTool extends ColorTool {
73
74
  }
74
75
  applyColor(color, inputToFocus = null) {
75
76
  return __awaiter(this, void 0, void 0, function* () {
76
- console.log('applyColor');
77
77
  let colorIndicator = this.nodes.button.querySelectorAll('.' + this.CSS.colorIndicatorModifier)[0];
78
78
  this.style.input = color;
79
- console.log('this.style.input');
80
- console.log(this.style.input);
81
- console.warn(color);
82
79
  this.resetUserSelection();
83
80
  yield this.surround(null, true);
84
81
  this.checkDefaultColors();
@@ -98,6 +95,7 @@ export class TextBackgroundColorTool extends ColorTool {
98
95
  if (!isBlockFocused) {
99
96
  setBlockFocus(this.parentEditor);
100
97
  }
98
+ this.checkDefaultColors();
101
99
  const isActive = this.hasStyle(selection.anchorNode) ? true : false;
102
100
  this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);
103
101
  return isActive;
@@ -123,13 +121,13 @@ export class TextBackgroundColorTool extends ColorTool {
123
121
  let removeColorContainerIcon = document.createElement('span');
124
122
  removeColorContainer.classList.add(this.CSS.removeBackgroundColorClass);
125
123
  removeColorContainer.addEventListener('click', () => this.applyColor('rgba(0,0,0,0)'));
126
- removeColorContainer.innerText = this.api.i18n.t('None');
124
+ removeColorContainer.innerText = editorJSI18nDictionnary.messages.tools.textBackgroundColor['None'];
127
125
  removeColorContainer.appendChild(removeColorContainerIcon);
128
126
  this.colorSelection.appendChild(removeColorContainer);
129
127
  let customColor = document.createElement('div');
130
128
  customColor.className = this.colorSelectionCss['container'];
131
129
  let text = document.createElement('p');
132
- text.innerText = this.api.i18n.t('customColor');
130
+ text.innerText = editorJSI18nDictionnary.messages.tools.textBackgroundColor['customColor'];
133
131
  let button = document.createElement('div');
134
132
  button.addEventListener('click', (event) => this.openCustomColorPicker(event));
135
133
  let container = this.createCustomColorPicker();
@@ -155,4 +153,4 @@ export class TextBackgroundColorTool extends ColorTool {
155
153
  }
156
154
  }
157
155
  TextBackgroundColorTool.title = 'Background Color';
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-background-color-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/text-background-color-tool.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { isBlockFocused, setBlockFocus, StyleObject } from '../utils/editorjs-tool.component';\nimport { ColorTool } from './tool-type/color-tool.component';\n\n// @dynamic\nexport class TextBackgroundColorTool extends ColorTool implements InlineTool {\n    public static title = 'Background Color';\n\n    private readonly commandName: string = 'textbackgroundcolor';\n\n    CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--textBackgroundColor',\n        colorIndicatorModifier: 'ce-inline-tool--textBackgroundColor__colorIndicator',\n        colorSelectionModifier: 'ce-inline-actions--backgroundColor',\n        colorPickerId: 'colorPicker-textBackgroundColor',\n        removeBackgroundColorClass: 'ce-inline-tool--textBackgroundColor__remove',\n    };\n\n    nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    style: StyleObject = {\n        property: 'background-color',\n        value: '$1',\n        default: 'transparent',\n        input: '',\n    };\n\n    modifies = {\n        tag: false,\n        style: true,\n        class: false,\n        attribute: false,\n    };\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n        this.nodes.button.addEventListener('click', () => this.openColorPicker());\n        this.colorIndicator = document.createElement('span');\n        this.colorIndicator.classList.add(this.CSS.colorIndicatorModifier);\n        this.colorIndicator.setAttribute(\n            'style',\n            'background-color:' + this.getCurrentColorApplied(this.getSelection().anchorNode.parentElement)\n        );\n        this.nodes.button.append(this.colorIndicator);\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyColor: boolean = false) {\n        if (applyColor) {\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n        }\n    }\n\n    async applyColor(color: string, inputToFocus: HTMLInputElement = null): Promise<void> {\n        console.log('applyColor');\n        let colorIndicator = this.nodes.button.querySelectorAll('.' + this.CSS.colorIndicatorModifier)[0];\n        this.style.input = color;\n        console.log('this.style.input');\n        console.log(this.style.input);\n        console.warn(color);\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkDefaultColors();\n        this.checkState(this.currentSelection);\n        colorIndicator.setAttribute('style', 'background-color:' + color);\n        this.saveUserSelection();\n        if (inputToFocus) {\n            inputToFocus.focus();\n        }\n        //this.hideActions();\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        const isActive = this.hasStyle(<HTMLElement>selection.anchorNode) ? true : false;\n        this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);\n\n        return isActive;\n    }\n\n    renderActions() {\n        this.colorSelection = document.createElement('div');\n        this.colorSelection.className = this.colorSelectionCss['wrapper'] + ' hidden ' + this.CSS.colorSelectionModifier;\n        this.colors.forEach((colorRow) => {\n            let row = document.createElement('div');\n            row.className = this.colorSelectionCss['row'];\n            colorRow.forEach((color) => {\n                if (color && color !== '') {\n                    let colorElement = document.createElement('div');\n                    colorElement.className = this.colorSelectionCss['item'];\n                    colorElement.setAttribute('style', 'background-color:' + color);\n                    colorElement.addEventListener('click', () => this.applyColor(color));\n                    row.appendChild(colorElement);\n                }\n            });\n            this.colorSelection.appendChild(row);\n        });\n        let removeColorContainer = document.createElement('div');\n        let removeColorContainerIcon = document.createElement('span');\n        removeColorContainer.classList.add(this.CSS.removeBackgroundColorClass);\n        removeColorContainer.addEventListener('click', () => this.applyColor('rgba(0,0,0,0)'));\n        removeColorContainer.innerText = this.api.i18n.t('None');\n        removeColorContainer.appendChild(removeColorContainerIcon);\n        this.colorSelection.appendChild(removeColorContainer);\n\n        let customColor = document.createElement('div');\n        customColor.className = this.colorSelectionCss['container'];\n        let text = document.createElement('p');\n        text.innerText = this.api.i18n.t('customColor');\n        let button = document.createElement('div');\n        button.addEventListener('click', (event) => this.openCustomColorPicker(event));\n        let container = this.createCustomColorPicker();\n        button.appendChild(container);\n\n        customColor.appendChild(text);\n        customColor.appendChild(button);\n        this.colorSelection.appendChild(customColor);\n\n        return this.colorSelection;\n    }\n\n    showActions(mark) {\n        this.style.input = mark && mark.style && mark.style.backgroundColor ? mark.style.backgroundColor : '#f5f1cc';\n\n        this.colorSelection.onchange = () => {\n            mark.style.backgroundColor = this.style.input;\n        };\n        this.colorSelection.hidden = false;\n    }\n\n    hideActions() {\n        let colorSelection = document.querySelectorAll('.' + this.CSS.colorSelectionModifier)[0];\n        this.isColorSelectionOpen = false;\n        if (!colorSelection.classList.contains('hidden')) {\n            colorSelection.classList.add('hidden');\n        }\n    }\n}\n"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-background-color-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/text-background-color-tool.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { isBlockFocused, setBlockFocus, StyleObject } from '../utils/editorjs-tool.component';\nimport { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';\nimport { ColorTool } from './tool-type/color-tool.component';\n\n// @dynamic\nexport class TextBackgroundColorTool extends ColorTool implements InlineTool {\n    public static title = 'Background Color';\n\n    private readonly commandName: string = 'textbackgroundcolor';\n\n    CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--textBackgroundColor',\n        colorIndicatorModifier: 'ce-inline-tool--textBackgroundColor__colorIndicator',\n        colorSelectionModifier: 'ce-inline-actions--backgroundColor',\n        colorPickerId: 'colorPicker-textBackgroundColor',\n        removeBackgroundColorClass: 'ce-inline-tool--textBackgroundColor__remove',\n    };\n\n    nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    style: StyleObject = {\n        property: 'background-color',\n        value: '$1',\n        default: 'transparent',\n        input: '',\n    };\n\n    modifies = {\n        tag: false,\n        style: true,\n        class: false,\n        attribute: false,\n    };\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n        this.nodes.button.addEventListener('click', () => this.openColorPicker());\n        this.colorIndicator = document.createElement('span');\n        this.colorIndicator.classList.add(this.CSS.colorIndicatorModifier);\n        this.colorIndicator.setAttribute(\n            'style',\n            'background-color:' + this.getCurrentColorApplied(this.getSelection().anchorNode.parentElement)\n        );\n        this.nodes.button.append(this.colorIndicator);\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyColor: boolean = false) {\n        if (applyColor) {\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n        }\n    }\n\n    async applyColor(color: string, inputToFocus: HTMLInputElement = null): Promise<void> {\n        let colorIndicator = this.nodes.button.querySelectorAll('.' + this.CSS.colorIndicatorModifier)[0];\n        this.style.input = color;\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkDefaultColors();\n        this.checkState(this.currentSelection);\n        colorIndicator.setAttribute('style', 'background-color:' + color);\n        this.saveUserSelection();\n        if (inputToFocus) {\n            inputToFocus.focus();\n        }\n        //this.hideActions();\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        this.checkDefaultColors();\n        const isActive = this.hasStyle(<HTMLElement>selection.anchorNode) ? true : false;\n        this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);\n\n        return isActive;\n    }\n\n    renderActions() {\n        this.colorSelection = document.createElement('div');\n        this.colorSelection.className = this.colorSelectionCss['wrapper'] + ' hidden ' + this.CSS.colorSelectionModifier;\n        this.colors.forEach((colorRow) => {\n            let row = document.createElement('div');\n            row.className = this.colorSelectionCss['row'];\n            colorRow.forEach((color) => {\n                if (color && color !== '') {\n                    let colorElement = document.createElement('div');\n                    colorElement.className = this.colorSelectionCss['item'];\n                    colorElement.setAttribute('style', 'background-color:' + color);\n                    colorElement.addEventListener('click', () => this.applyColor(color));\n                    row.appendChild(colorElement);\n                }\n            });\n            this.colorSelection.appendChild(row);\n        });\n        let removeColorContainer = document.createElement('div');\n        let removeColorContainerIcon = document.createElement('span');\n        removeColorContainer.classList.add(this.CSS.removeBackgroundColorClass);\n        removeColorContainer.addEventListener('click', () => this.applyColor('rgba(0,0,0,0)'));\n        removeColorContainer.innerText = editorJSI18nDictionnary.messages.tools.textBackgroundColor['None'];\n        removeColorContainer.appendChild(removeColorContainerIcon);\n        this.colorSelection.appendChild(removeColorContainer);\n\n        let customColor = document.createElement('div');\n        customColor.className = this.colorSelectionCss['container'];\n        let text = document.createElement('p');\n        text.innerText = editorJSI18nDictionnary.messages.tools.textBackgroundColor['customColor'];\n        let button = document.createElement('div');\n        button.addEventListener('click', (event) => this.openCustomColorPicker(event));\n        let container = this.createCustomColorPicker();\n        button.appendChild(container);\n\n        customColor.appendChild(text);\n        customColor.appendChild(button);\n        this.colorSelection.appendChild(customColor);\n\n        return this.colorSelection;\n    }\n\n    showActions(mark) {\n        this.style.input = mark && mark.style && mark.style.backgroundColor ? mark.style.backgroundColor : '#f5f1cc';\n\n        this.colorSelection.onchange = () => {\n            mark.style.backgroundColor = this.style.input;\n        };\n        this.colorSelection.hidden = false;\n    }\n\n    hideActions() {\n        let colorSelection = document.querySelectorAll('.' + this.CSS.colorSelectionModifier)[0];\n        this.isColorSelectionOpen = false;\n        if (!colorSelection.classList.contains('hidden')) {\n            colorSelection.classList.add('hidden');\n        }\n    }\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import { __awaiter } from "tslib";
2
2
  import { isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';
3
+ import { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';
3
4
  import { ColorTool } from './tool-type/color-tool.component';
4
5
  // @dynamic
5
6
  export class TextColorTool extends ColorTool {
@@ -93,6 +94,7 @@ export class TextColorTool extends ColorTool {
93
94
  if (!isBlockFocused) {
94
95
  setBlockFocus(this.parentEditor);
95
96
  }
97
+ this.checkDefaultColors();
96
98
  const isActive = this.hasStyle(selection.anchorNode) ? true : false;
97
99
  this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);
98
100
  return isActive;
@@ -117,7 +119,7 @@ export class TextColorTool extends ColorTool {
117
119
  let customColor = document.createElement('div');
118
120
  customColor.className = this.colorSelectionCss['container'];
119
121
  let text = document.createElement('p');
120
- text.innerText = this.api.i18n.t('customColor');
122
+ text.innerText = editorJSI18nDictionnary.messages.tools.textBackgroundColor['customColor'];
121
123
  let button = document.createElement('div');
122
124
  button.addEventListener('click', (event) => this.openCustomColorPicker(event));
123
125
  let container = this.createCustomColorPicker();
@@ -143,4 +145,4 @@ export class TextColorTool extends ColorTool {
143
145
  }
144
146
  }
145
147
  TextColorTool.title = 'Text Color';
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-color-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/text-color-tool.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { isBlockFocused, setBlockFocus, StyleObject } from '../utils/editorjs-tool.component';\nimport { ColorTool } from './tool-type/color-tool.component';\n\n// @dynamic\nexport class TextColorTool extends ColorTool implements InlineTool {\n    public static title = 'Text Color';\n\n    private readonly commandName: string = 'textcolor';\n\n    CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--textColor',\n        colorIndicatorModifier: 'ce-inline-tool--textColor__colorIndicator',\n        colorSelectionModifier: 'ce-inline-actions--textColor',\n        colorPickerId: 'colorPicker-textColor',\n    };\n\n    nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    style: StyleObject = {\n        property: 'color',\n        value: '$1',\n        default: 'initial',\n        input: '#f5f1cc',\n    };\n\n    modifies = {\n        tag: false,\n        style: true,\n        class: false,\n        attribute: false,\n    };\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n        this.nodes.button.addEventListener('click', () => this.openColorPicker());\n        this.colorIndicator = document.createElement('span');\n        this.colorIndicator.classList.add(this.CSS.colorIndicatorModifier);\n        this.colorIndicator.setAttribute(\n            'style',\n            'background-color:' + this.getCurrentColorApplied(this.getSelection().anchorNode.parentElement)\n        );\n        this.nodes.button.append(this.colorIndicator);\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyColor: boolean = false) {\n        if (applyColor) {\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n        }\n    }\n\n    async applyColor(color: string, inputToFocus: HTMLInputElement = null): Promise<void> {\n        let colorIndicator = this.nodes.button.querySelectorAll('.' + this.CSS.colorIndicatorModifier)[0];\n        this.style.input = color;\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkDefaultColors();\n        this.checkState(this.currentSelection);\n        colorIndicator.setAttribute('style', 'background-color:' + color);\n        this.saveUserSelection();\n        if (inputToFocus) {\n            inputToFocus.focus();\n        }\n        //this.hideActions();\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        const isActive = this.hasStyle(<HTMLElement>selection.anchorNode) ? true : false;\n        this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);\n\n        return isActive;\n    }\n\n    renderActions() {\n        this.colorSelection = document.createElement('div');\n        this.colorSelection.className = this.colorSelectionCss['wrapper'] + ' hidden ' + this.CSS.colorSelectionModifier;\n        this.colors.forEach((colorRow) => {\n            let row = document.createElement('div');\n            row.className = this.colorSelectionCss['row'];\n            colorRow.forEach((color) => {\n                if (color && color !== '') {\n                    let colorElement = document.createElement('div');\n                    colorElement.className = this.colorSelectionCss['item'];\n                    colorElement.setAttribute('style', 'background-color:' + color);\n                    colorElement.addEventListener('click', () => this.applyColor(color));\n                    row.appendChild(colorElement);\n                }\n            });\n            this.colorSelection.appendChild(row);\n        });\n        let customColor = document.createElement('div');\n        customColor.className = this.colorSelectionCss['container'];\n        let text = document.createElement('p');\n        text.innerText = this.api.i18n.t('customColor');\n        let button = document.createElement('div');\n        button.addEventListener('click', (event) => this.openCustomColorPicker(event));\n        let container = this.createCustomColorPicker();\n        button.appendChild(container);\n\n        customColor.appendChild(text);\n        customColor.appendChild(button);\n        this.colorSelection.appendChild(customColor);\n\n        return this.colorSelection;\n    }\n\n    showActions(mark) {\n        this.style.input = mark && mark.style && mark.style.backgroundColor ? mark.style.backgroundColor : '#f5f1cc';\n\n        this.colorSelection.onchange = () => {\n            mark.style.backgroundColor = this.style.input;\n        };\n        this.colorSelection.hidden = false;\n    }\n\n    hideActions() {\n        let colorSelection = document.querySelectorAll('.' + this.CSS.colorSelectionModifier)[0];\n        this.isColorSelectionOpen = false;\n        if (!colorSelection.classList.contains('hidden')) {\n            colorSelection.classList.add('hidden');\n        }\n    }\n}\n"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-color-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/text-color-tool.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { isBlockFocused, setBlockFocus, StyleObject } from '../utils/editorjs-tool.component';\nimport { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';\nimport { ColorTool } from './tool-type/color-tool.component';\n\n// @dynamic\nexport class TextColorTool extends ColorTool implements InlineTool {\n    public static title = 'Text Color';\n\n    private readonly commandName: string = 'textcolor';\n\n    CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--textColor',\n        colorIndicatorModifier: 'ce-inline-tool--textColor__colorIndicator',\n        colorSelectionModifier: 'ce-inline-actions--textColor',\n        colorPickerId: 'colorPicker-textColor',\n    };\n\n    nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    style: StyleObject = {\n        property: 'color',\n        value: '$1',\n        default: 'initial',\n        input: '#f5f1cc',\n    };\n\n    modifies = {\n        tag: false,\n        style: true,\n        class: false,\n        attribute: false,\n    };\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n        this.nodes.button.addEventListener('click', () => this.openColorPicker());\n        this.colorIndicator = document.createElement('span');\n        this.colorIndicator.classList.add(this.CSS.colorIndicatorModifier);\n        this.colorIndicator.setAttribute(\n            'style',\n            'background-color:' + this.getCurrentColorApplied(this.getSelection().anchorNode.parentElement)\n        );\n        this.nodes.button.append(this.colorIndicator);\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyColor: boolean = false) {\n        if (applyColor) {\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n        }\n    }\n\n    async applyColor(color: string, inputToFocus: HTMLInputElement = null): Promise<void> {\n        let colorIndicator = this.nodes.button.querySelectorAll('.' + this.CSS.colorIndicatorModifier)[0];\n        this.style.input = color;\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkDefaultColors();\n        this.checkState(this.currentSelection);\n        colorIndicator.setAttribute('style', 'background-color:' + color);\n        this.saveUserSelection();\n        if (inputToFocus) {\n            inputToFocus.focus();\n        }\n        //this.hideActions();\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        this.checkDefaultColors();\n        const isActive = this.hasStyle(<HTMLElement>selection.anchorNode) ? true : false;\n        this.nodes.button.classList.toggle(this.CSS.buttonActive, isActive);\n\n        return isActive;\n    }\n\n    renderActions() {\n        this.colorSelection = document.createElement('div');\n        this.colorSelection.className = this.colorSelectionCss['wrapper'] + ' hidden ' + this.CSS.colorSelectionModifier;\n        this.colors.forEach((colorRow) => {\n            let row = document.createElement('div');\n            row.className = this.colorSelectionCss['row'];\n            colorRow.forEach((color) => {\n                if (color && color !== '') {\n                    let colorElement = document.createElement('div');\n                    colorElement.className = this.colorSelectionCss['item'];\n                    colorElement.setAttribute('style', 'background-color:' + color);\n                    colorElement.addEventListener('click', () => this.applyColor(color));\n                    row.appendChild(colorElement);\n                }\n            });\n            this.colorSelection.appendChild(row);\n        });\n        let customColor = document.createElement('div');\n        customColor.className = this.colorSelectionCss['container'];\n        let text = document.createElement('p');\n        text.innerText = editorJSI18nDictionnary.messages.tools.textBackgroundColor['customColor'];\n        let button = document.createElement('div');\n        button.addEventListener('click', (event) => this.openCustomColorPicker(event));\n        let container = this.createCustomColorPicker();\n        button.appendChild(container);\n\n        customColor.appendChild(text);\n        customColor.appendChild(button);\n        this.colorSelection.appendChild(customColor);\n\n        return this.colorSelection;\n    }\n\n    showActions(mark) {\n        this.style.input = mark && mark.style && mark.style.backgroundColor ? mark.style.backgroundColor : '#f5f1cc';\n\n        this.colorSelection.onchange = () => {\n            mark.style.backgroundColor = this.style.input;\n        };\n        this.colorSelection.hidden = false;\n    }\n\n    hideActions() {\n        let colorSelection = document.querySelectorAll('.' + this.CSS.colorSelectionModifier)[0];\n        this.isColorSelectionOpen = false;\n        if (!colorSelection.classList.contains('hidden')) {\n            colorSelection.classList.add('hidden');\n        }\n    }\n}\n"]}
@@ -2,6 +2,7 @@ import { __awaiter } from "tslib";
2
2
  import { InlineTextTool } from './tool-type/text-tool.component';
3
3
  import { TEXT_SIZES } from '../utils/texts.component';
4
4
  import { isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';
5
+ import { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';
5
6
  // @dynamic
6
7
  export class textSizeTool extends InlineTextTool {
7
8
  constructor({ api }) {
@@ -55,7 +56,7 @@ export class textSizeTool extends InlineTextTool {
55
56
  this.nodes.button.addEventListener('click', () => this.openDropdown());
56
57
  this.textSizes.forEach((textSize) => {
57
58
  let span = document.createElement('span');
58
- span.innerText = this.api.i18n.t(textSize.name);
59
+ span.innerText = editorJSI18nDictionnary.messages.tools.textSize[textSize.name];
59
60
  this.nodes.button.appendChild(span);
60
61
  });
61
62
  let dropdownArrow = document.createElement('span');
@@ -100,7 +101,7 @@ export class textSizeTool extends InlineTextTool {
100
101
  this.textSizes.forEach((textSize) => {
101
102
  let row = document.createElement('div');
102
103
  row.className = this.dropdownCss['row'];
103
- row.innerText = this.api.i18n.t(textSize.name);
104
+ row.innerText = editorJSI18nDictionnary.messages.tools.textSize[textSize.name];
104
105
  row.addEventListener('click', () => this.applyTextStyle(textSize.class));
105
106
  textSizeDropdown.appendChild(row);
106
107
  });
@@ -130,4 +131,4 @@ export class textSizeTool extends InlineTextTool {
130
131
  }
131
132
  }
132
133
  textSizeTool.title = 'Text Size';
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-size-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/text-size-tool.component.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAY,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAEjF,WAAW;AACX,MAAM,OAAO,YAAa,SAAQ,cAAc;IAwD5C,YAAY,EAAE,GAAG,EAAE;QACf,KAAK,EAAE,CAAC;QAtDK,gBAAW,GAAW,UAAU,CAAC;QAElD,QAAG,GAAG;YACF,MAAM,EAAE,gBAAgB;YACxB,YAAY,EAAE,wBAAwB;YACtC,cAAc,EAAE,0BAA0B;YAC1C,mBAAmB,EAAE,iCAAiC;YACtD,qBAAqB,EAAE,6BAA6B;SACvD,CAAC;QAEF,UAAK,GAAkC;YACnC,MAAM,EAAE,SAAS;SACpB,CAAC;QAMF,QAAG,GAAG,MAAM,CAAC;QAEb,cAAS,GAAoB,UAAU,CAAC;QAExC,iBAAY,GAAG,EAAE,CAAC;QAElB,YAAO,GAAG,EAAE,CAAC;QAEb,aAAQ,GAAG;YACP,GAAG,EAAE,KAAK;YACV,KAAK,EAAE,KAAK;YACZ,KAAK,EAAE,IAAI;YACX,SAAS,EAAE,KAAK;SACnB,CAAC;QAwBE,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAxBM,MAAM,KAAK,QAAQ;QACtB,OAAO,IAAI,CAAC;IAChB,CAAC;IAEM,MAAM,KAAK,QAAQ;QACtB,OAAO;YACH,CAAC,EAAE,EAAE;SACW,CAAC;IACzB,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAI,KAAK,CAAC,KAAK;QACX,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QAEpB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC;IACtF,CAAC;IAQD,MAAM;QACF,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAsB,CAAC;QAC1E,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,GAAG,QAAQ,CAAC;QAClC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC1E,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACxD;QACD,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QACvE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAChC,IAAI,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC1C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAChD,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QAEH,IAAI,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QACnD,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QAC1D,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAE7C,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC7B,CAAC;IAEK,QAAQ,CAAC,KAAY,EAAE,aAAsB,KAAK;;YACpD,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,UAAU,EAAE;gBACZ,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;gBACrC,IAAI,CAAC,aAAa,EAAE,CAAC;aACxB;QACL,CAAC;KAAA;IAED,UAAU,CAAC,SAAS;QAChB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC/C;QACD,IAAI,CAAC,cAAc,EAAE;YACjB,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACpC;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAc,SAAS,CAAC,UAAU,CAAC,CAAC;QACjE,MAAM,QAAQ,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAExC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAChC,IAAI,QAAQ,CAAC,KAAK,KAAK,EAAE,EAAE;gBACvB,IAAI,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,GAAG;oBAC7C,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;iBACnD;qBAAM;oBACH,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;iBACtD;aACJ;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED,aAAa;QACT,IAAI,gBAAgB,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACrD,gBAAgB,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,GAAG,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,qBAAqB,CAAC;QACzG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;YAChC,IAAI,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACxC,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACxC,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC/C,GAAG,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;YACzE,gBAAgB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,OAAO,KAAK,EAAE,EAAE;YACrB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;gBAChC,IAAI,IAAI,CAAC,OAAO,KAAK,EAAE,EAAE;oBACrB,IAAI,CAAC,OAAO,IAAI,GAAG,CAAC;iBACvB;gBACD,IAAI,CAAC,OAAO,IAAI,QAAQ,CAAC,KAAK,CAAC;YACnC,CAAC,CAAC,CAAC;SACN;QACD,OAAO,gBAAgB,CAAC;IAC5B,CAAC;IAED,WAAW,CAAC,IAAI;QACZ,+GAA+G;IACnH,CAAC;IAED,WAAW,KAAI,CAAC;IAEV,cAAc,CAAC,YAAoB;;YACrC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;YACjC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAChC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACvC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,EAAE,CAAC;QACvB,CAAC;KAAA;;AApJa,kBAAK,GAAG,WAAW,CAAC","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { InlineTextTool } from './tool-type/text-tool.component';\nimport { TextSize, TEXT_SIZES } from '../utils/texts.component';\nimport { isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';\n\n// @dynamic\nexport class textSizeTool extends InlineTextTool implements InlineTool {\n    public static title = 'Text Size';\n\n    private readonly commandName: string = 'textSize';\n\n    CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--textSize',\n        arrowButtonModifier: 'ce-inline-tool--textSize__arrow',\n        textSelectionModifier: 'ce-inline-actions--textSize',\n    };\n\n    nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    textSizes: Array<TextSize> = TEXT_SIZES;\n\n    classToApply = '';\n\n    classes = '';\n\n    modifies = {\n        tag: false,\n        style: false,\n        class: true,\n        attribute: false,\n    };\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n        this.nodes.button.addEventListener('click', () => this.openDropdown());\n        this.textSizes.forEach((textSize) => {\n            let span = document.createElement('span');\n            span.innerText = this.api.i18n.t(textSize.name);\n            this.nodes.button.appendChild(span);\n        });\n\n        let dropdownArrow = document.createElement('span');\n        dropdownArrow.classList.add(this.CSS.arrowButtonModifier);\n        this.nodes.button.appendChild(dropdownArrow);\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyStyle: boolean = false) {\n        this.saveUserSelection();\n        if (applyStyle) {\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n            this.closeDropdown();\n        }\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        const element = this.hasStyle(<HTMLElement>selection.anchorNode);\n        const isActive = element ? true : false;\n\n        this.textSizes.forEach((textSize) => {\n            if (textSize.class !== '') {\n                if (element?.classList.contains(textSize.class)) {\n                    this.nodes.button.classList.add(textSize.class);\n                } else {\n                    this.nodes.button.classList.remove(textSize.class);\n                }\n            }\n        });\n\n        return isActive;\n    }\n\n    renderActions() {\n        let textSizeDropdown = document.createElement('div');\n        textSizeDropdown.className = this.dropdownCss['container'] + ' hidden ' + this.CSS.textSelectionModifier;\n        this.textSizes.forEach((textSize) => {\n            let row = document.createElement('div');\n            row.className = this.dropdownCss['row'];\n            row.innerText = this.api.i18n.t(textSize.name);\n            row.addEventListener('click', () => this.applyTextStyle(textSize.class));\n            textSizeDropdown.appendChild(row);\n        });\n        if (this.classes === '') {\n            this.textSizes.forEach((textSize) => {\n                if (this.classes !== '') {\n                    this.classes += ',';\n                }\n                this.classes += textSize.class;\n            });\n        }\n        return textSizeDropdown;\n    }\n\n    showActions(mark) {\n        //this.style.input = mark && mark.style && mark.style.backgroundColor ? mark.style.backgroundColor : '#f5f1cc';\n    }\n\n    hideActions() {}\n\n    async applyTextStyle(classToApply: string) {\n        this.classToApply = classToApply;\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkState(this.currentSelection);\n        this.saveUserSelection();\n        this.hideActions();\n    }\n}\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-size-tool.component.js","sourceRoot":"/home/pauline/Documents/workspace/wizi-block/projects/wizi-block/src/","sources":["lib/shared/components/editorjs/tools/inline/text-size-tool.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InlineTool, SanitizerConfig } from '@editorjs/editorjs';\nimport { InlineTextTool } from './tool-type/text-tool.component';\nimport { TextSize, TEXT_SIZES } from '../utils/texts.component';\nimport { isBlockFocused, setBlockFocus } from '../utils/editorjs-tool.component';\nimport { editorJSI18nDictionnary } from '../utils/editorjs-translation.service';\n\n// @dynamic\nexport class textSizeTool extends InlineTextTool implements InlineTool {\n    public static title = 'Text Size';\n\n    private readonly commandName: string = 'textSize';\n\n    CSS = {\n        button: 'ce-inline-tool',\n        buttonActive: 'ce-inline-tool--active',\n        buttonModifier: 'ce-inline-tool--textSize',\n        arrowButtonModifier: 'ce-inline-tool--textSize__arrow',\n        textSelectionModifier: 'ce-inline-actions--textSize',\n    };\n\n    nodes: { button: HTMLButtonElement } = {\n        button: undefined,\n    };\n\n    api: any;\n\n    private _state: boolean;\n\n    tag = 'SPAN';\n\n    textSizes: Array<TextSize> = TEXT_SIZES;\n\n    classToApply = '';\n\n    classes = '';\n\n    modifies = {\n        tag: false,\n        style: false,\n        class: true,\n        attribute: false,\n    };\n\n    public static get isInline() {\n        return true;\n    }\n\n    public static get sanitize(): SanitizerConfig {\n        return {\n            b: {},\n        } as SanitizerConfig;\n    }\n\n    get state() {\n        return this._state;\n    }\n\n    set state(state) {\n        this._state = state;\n\n        this.nodes.button.classList.toggle(this.api.styles.inlineToolButtonActive, state);\n    }\n\n    constructor({ api }) {\n        super();\n        this.api = api;\n        this._state = false;\n    }\n\n    render() {\n        this.nodes.button = document.createElement('button') as HTMLButtonElement;\n        this.nodes.button.type = 'button';\n        this.nodes.button.classList.add(this.CSS.button, this.CSS.buttonModifier);\n        if (this.hasSeparatorBefore) {\n            this.nodes.button.classList.add(this.separatorClass);\n        }\n        this.nodes.button.addEventListener('click', () => this.openDropdown());\n        this.textSizes.forEach((textSize) => {\n            let span = document.createElement('span');\n            span.innerText = editorJSI18nDictionnary.messages.tools.textSize[textSize.name];\n            this.nodes.button.appendChild(span);\n        });\n\n        let dropdownArrow = document.createElement('span');\n        dropdownArrow.classList.add(this.CSS.arrowButtonModifier);\n        this.nodes.button.appendChild(dropdownArrow);\n\n        return this.nodes.button;\n    }\n\n    async surround(range: Range, applyStyle: boolean = false) {\n        this.saveUserSelection();\n        if (applyStyle) {\n            await this.execCommandStyle(this.tag);\n            this.checkState(this.getSelection());\n            this.closeDropdown();\n        }\n    }\n\n    checkState(selection) {\n        if (!this.parentEditor) {\n            this.parentEditor = this.findParentEditor();\n        }\n        if (!isBlockFocused) {\n            setBlockFocus(this.parentEditor);\n        }\n        const element = this.hasStyle(<HTMLElement>selection.anchorNode);\n        const isActive = element ? true : false;\n\n        this.textSizes.forEach((textSize) => {\n            if (textSize.class !== '') {\n                if (element?.classList.contains(textSize.class)) {\n                    this.nodes.button.classList.add(textSize.class);\n                } else {\n                    this.nodes.button.classList.remove(textSize.class);\n                }\n            }\n        });\n\n        return isActive;\n    }\n\n    renderActions() {\n        let textSizeDropdown = document.createElement('div');\n        textSizeDropdown.className = this.dropdownCss['container'] + ' hidden ' + this.CSS.textSelectionModifier;\n        this.textSizes.forEach((textSize) => {\n            let row = document.createElement('div');\n            row.className = this.dropdownCss['row'];\n            row.innerText = editorJSI18nDictionnary.messages.tools.textSize[textSize.name];\n            row.addEventListener('click', () => this.applyTextStyle(textSize.class));\n            textSizeDropdown.appendChild(row);\n        });\n        if (this.classes === '') {\n            this.textSizes.forEach((textSize) => {\n                if (this.classes !== '') {\n                    this.classes += ',';\n                }\n                this.classes += textSize.class;\n            });\n        }\n        return textSizeDropdown;\n    }\n\n    showActions(mark) {\n        //this.style.input = mark && mark.style && mark.style.backgroundColor ? mark.style.backgroundColor : '#f5f1cc';\n    }\n\n    hideActions() {}\n\n    async applyTextStyle(classToApply: string) {\n        this.classToApply = classToApply;\n        this.resetUserSelection();\n        await this.surround(null, true);\n        this.checkState(this.currentSelection);\n        this.saveUserSelection();\n        this.hideActions();\n    }\n}\n"]}