@eui/components 18.0.0-rc.25 → 18.0.0-rc.27

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 (107) hide show
  1. package/docs/components/ChartComponent.html +10 -124
  2. package/docs/components/EuiEditorCountersComponent.html +15 -202
  3. package/docs/components/EuiNotificationItemComponent.html +5 -62
  4. package/docs/components/EuiNotificationItemV2Component.html +5 -62
  5. package/docs/components/EuiNotificationsComponent.html +40 -512
  6. package/docs/components/EuiNotificationsV2Component.html +40 -507
  7. package/docs/components/EuiPageColumnComponent.html +2 -2
  8. package/docs/components/EuiPaginatorComponent.html +15 -209
  9. package/docs/components/EuiSelectComponent.html +0 -62
  10. package/docs/components/EuiTreeComponent.html +45 -558
  11. package/docs/components/EuiWizardComponent.html +15 -202
  12. package/docs/components/EuiWizardStepComponent.html +30 -388
  13. package/docs/components/QuillEditorComponent.html +20 -326
  14. package/docs/dependencies.html +1 -3
  15. package/docs/directives/AutoResizeDirective.html +5 -62
  16. package/docs/directives/EuiNgSelectOptionDirective.html +0 -62
  17. package/docs/js/menu-wc.js +3 -3
  18. package/docs/js/menu-wc_es5.js +1 -1
  19. package/docs/js/search/search_index.js +2 -2
  20. package/esm2022/eui-card/eui-card.component.mjs +2 -2
  21. package/esm2022/eui-fieldset/eui-fieldset.component.mjs +2 -2
  22. package/esm2022/eui-overlay/eui-overlay.component.mjs +2 -2
  23. package/esm2022/eui-page/components/eui-page-column/eui-page-column.component.mjs +9 -6
  24. package/esm2022/eui-page/eui-page.component.mjs +2 -2
  25. package/esm2022/eui-paginator/eui-paginator.component.mjs +12 -28
  26. package/esm2022/eui-select/eui-select-option.directive.mjs +6 -12
  27. package/esm2022/eui-select/eui-select.component.mjs +6 -11
  28. package/esm2022/eui-table/eui-table.component.mjs +2 -2
  29. package/esm2022/eui-table-v2/eui-table-v2.component.mjs +2 -2
  30. package/esm2022/eui-tabs/eui-tab/eui-tab.component.mjs +2 -2
  31. package/esm2022/eui-tabs/eui-tabs.component.mjs +2 -2
  32. package/esm2022/eui-textarea/auto-resize.directive.mjs +7 -12
  33. package/esm2022/eui-textarea/eui-textarea.component.mjs +2 -2
  34. package/esm2022/eui-tree/eui-tree.component.mjs +32 -79
  35. package/esm2022/eui-wizard/eui-wizard-step.component.mjs +21 -52
  36. package/esm2022/eui-wizard/eui-wizard.component.mjs +12 -28
  37. package/esm2022/externals/charts/chart/chart.component.mjs +9 -12
  38. package/esm2022/externals/eui-editor/counters/eui-editor-counters.component.mjs +12 -28
  39. package/esm2022/externals/quill/quill-editor.component.mjs +17 -43
  40. package/esm2022/layout/eui-app/eui-app-sidebar/sidebar.component.mjs +2 -2
  41. package/esm2022/layout/eui-notifications/eui-notification-item.component.mjs +6 -12
  42. package/esm2022/layout/eui-notifications/eui-notifications.component.mjs +27 -68
  43. package/esm2022/layout/eui-notifications-v2/eui-notification-item.component.mjs +6 -12
  44. package/esm2022/layout/eui-notifications-v2/eui-notifications.component.mjs +30 -77
  45. package/eui-page/components/eui-page-column/eui-page-column.component.d.ts +1 -1
  46. package/eui-page/components/eui-page-column/eui-page-column.component.d.ts.map +1 -1
  47. package/eui-paginator/eui-paginator.component.d.ts +6 -10
  48. package/eui-paginator/eui-paginator.component.d.ts.map +1 -1
  49. package/eui-select/eui-select-option.directive.d.ts +2 -4
  50. package/eui-select/eui-select-option.directive.d.ts.map +1 -1
  51. package/eui-select/eui-select.component.d.ts +2 -3
  52. package/eui-select/eui-select.component.d.ts.map +1 -1
  53. package/eui-textarea/auto-resize.directive.d.ts +3 -5
  54. package/eui-textarea/auto-resize.directive.d.ts.map +1 -1
  55. package/eui-tree/eui-tree.component.d.ts +18 -28
  56. package/eui-tree/eui-tree.component.d.ts.map +1 -1
  57. package/eui-wizard/eui-wizard-step.component.d.ts +12 -19
  58. package/eui-wizard/eui-wizard-step.component.d.ts.map +1 -1
  59. package/eui-wizard/eui-wizard.component.d.ts +6 -10
  60. package/eui-wizard/eui-wizard.component.d.ts.map +1 -1
  61. package/externals/charts/chart/chart.component.d.ts +4 -7
  62. package/externals/charts/chart/chart.component.d.ts.map +1 -1
  63. package/externals/eui-editor/counters/eui-editor-counters.component.d.ts +6 -10
  64. package/externals/eui-editor/counters/eui-editor-counters.component.d.ts.map +1 -1
  65. package/externals/quill/quill-editor.component.d.ts +10 -16
  66. package/externals/quill/quill-editor.component.d.ts.map +1 -1
  67. package/fesm2022/eui-components-eui-card.mjs +2 -2
  68. package/fesm2022/eui-components-eui-card.mjs.map +1 -1
  69. package/fesm2022/eui-components-eui-fieldset.mjs +2 -2
  70. package/fesm2022/eui-components-eui-fieldset.mjs.map +1 -1
  71. package/fesm2022/eui-components-eui-overlay.mjs +2 -2
  72. package/fesm2022/eui-components-eui-overlay.mjs.map +1 -1
  73. package/fesm2022/eui-components-eui-page.mjs +9 -7
  74. package/fesm2022/eui-components-eui-page.mjs.map +1 -1
  75. package/fesm2022/eui-components-eui-paginator.mjs +11 -27
  76. package/fesm2022/eui-components-eui-paginator.mjs.map +1 -1
  77. package/fesm2022/eui-components-eui-select.mjs +9 -19
  78. package/fesm2022/eui-components-eui-select.mjs.map +1 -1
  79. package/fesm2022/eui-components-eui-table-v2.mjs +2 -2
  80. package/fesm2022/eui-components-eui-table-v2.mjs.map +1 -1
  81. package/fesm2022/eui-components-eui-table.mjs +2 -2
  82. package/fesm2022/eui-components-eui-table.mjs.map +1 -1
  83. package/fesm2022/eui-components-eui-tabs.mjs +4 -4
  84. package/fesm2022/eui-components-eui-tabs.mjs.map +1 -1
  85. package/fesm2022/eui-components-eui-textarea.mjs +6 -11
  86. package/fesm2022/eui-components-eui-textarea.mjs.map +1 -1
  87. package/fesm2022/eui-components-eui-tree.mjs +31 -78
  88. package/fesm2022/eui-components-eui-tree.mjs.map +1 -1
  89. package/fesm2022/eui-components-eui-wizard.mjs +30 -76
  90. package/fesm2022/eui-components-eui-wizard.mjs.map +1 -1
  91. package/fesm2022/eui-components-externals-charts.mjs +8 -11
  92. package/fesm2022/eui-components-externals-charts.mjs.map +1 -1
  93. package/fesm2022/eui-components-externals-eui-editor.mjs +11 -26
  94. package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
  95. package/fesm2022/eui-components-externals-quill.mjs +16 -42
  96. package/fesm2022/eui-components-externals-quill.mjs.map +1 -1
  97. package/fesm2022/eui-components-layout.mjs +63 -159
  98. package/fesm2022/eui-components-layout.mjs.map +1 -1
  99. package/layout/eui-notifications/eui-notification-item.component.d.ts +2 -4
  100. package/layout/eui-notifications/eui-notification-item.component.d.ts.map +1 -1
  101. package/layout/eui-notifications/eui-notifications.component.d.ts +16 -25
  102. package/layout/eui-notifications/eui-notifications.component.d.ts.map +1 -1
  103. package/layout/eui-notifications-v2/eui-notification-item.component.d.ts +2 -4
  104. package/layout/eui-notifications-v2/eui-notification-item.component.d.ts.map +1 -1
  105. package/layout/eui-notifications-v2/eui-notifications.component.d.ts +16 -25
  106. package/layout/eui-notifications-v2/eui-notifications.component.d.ts.map +1 -1
  107. package/package.json +3 -3
@@ -1,10 +1,9 @@
1
1
  import { isPlatformServer } from '@angular/common';
2
2
  import { QUILL_CONFIG_TOKEN, } from './quill-editor.interfaces';
3
- import { Component, EventEmitter, forwardRef, Inject, Input, Output, PLATFORM_ID, SecurityContext, ViewEncapsulation, } from '@angular/core';
3
+ import { booleanAttribute, Component, EventEmitter, forwardRef, Inject, Input, Output, PLATFORM_ID, SecurityContext, ViewEncapsulation, } from '@angular/core';
4
4
  import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
5
5
  import { DOCUMENT } from '@angular/common';
6
6
  import { defaultModules } from './quill-defaults';
7
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
8
7
  import * as i0 from "@angular/core";
9
8
  import * as i1 from "@angular/platform-browser";
10
9
  import * as i2 from "./loader.service";
@@ -13,36 +12,6 @@ const getFormat = (format, configFormat) => {
13
12
  return passedFormat || 'html';
14
13
  };
15
14
  export class QuillEditorComponent {
16
- get readOnly() {
17
- return this._readOnly;
18
- }
19
- set readOnly(value) {
20
- this._readOnly = coerceBooleanProperty(value);
21
- }
22
- get required() {
23
- return this._required;
24
- }
25
- set required(value) {
26
- this._required = coerceBooleanProperty(value);
27
- }
28
- get sanitize() {
29
- return this._sanitize;
30
- }
31
- set sanitize(value) {
32
- this._sanitize = coerceBooleanProperty(value);
33
- }
34
- get strict() {
35
- return this._strict;
36
- }
37
- set strict(value) {
38
- this._strict = coerceBooleanProperty(value);
39
- }
40
- get preserveWhitespace() {
41
- return this._preserveWhitespace;
42
- }
43
- set preserveWhitespace(value) {
44
- this._preserveWhitespace = coerceBooleanProperty(value);
45
- }
46
15
  constructor(elementRef, domSanitizer, doc,
47
16
  // eslint-disable-next-line @typescript-eslint/ban-types
48
17
  platformId, renderer, zone, config, loader) {
@@ -68,10 +37,10 @@ export class QuillEditorComponent {
68
37
  this.onFocus = new EventEmitter();
69
38
  // eslint-disable-next-line @angular-eslint/no-output-on-prefix
70
39
  this.onBlur = new EventEmitter();
71
- this._required = false;
72
- this._sanitize = false;
73
- this._strict = true;
74
- this._preserveWhitespace = false;
40
+ this.required = false;
41
+ this.sanitize = false;
42
+ this.strict = true;
43
+ this.preserveWhitespace = false;
75
44
  this.disabled = false; // used to store initial value before ViewInit
76
45
  this.valueGetter = (quillEditor, editorElement) => {
77
46
  let html = editorElement.querySelector('.ql-editor')?.innerHTML;
@@ -438,7 +407,7 @@ export class QuillEditorComponent {
438
407
  QuillInstance.register('blots/scroll', Scroll, true);
439
408
  }
440
409
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: QuillEditorComponent, deps: [{ token: i0.ElementRef }, { token: i1.DomSanitizer }, { token: DOCUMENT }, { token: PLATFORM_ID }, { token: i0.Renderer2 }, { token: i0.NgZone }, { token: QUILL_CONFIG_TOKEN }, { token: i2.LoaderService }], target: i0.ɵɵFactoryTarget.Component }); }
441
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: QuillEditorComponent, selector: "quill-editor", inputs: { id: "id", format: "format", theme: "theme", modules: "modules", debug: "debug", placeholder: "placeholder", maxLength: "maxLength", minLength: "minLength", formats: "formats", customToolbarPosition: "customToolbarPosition", styles: "styles", scrollingContainer: "scrollingContainer", bounds: "bounds", customOptions: "customOptions", trackChanges: "trackChanges", hasImageFeature: "hasImageFeature", readOnly: "readOnly", required: "required", sanitize: "sanitize", strict: "strict", preserveWhitespace: "preserveWhitespace", valueGetter: "valueGetter", valueSetter: "valueSetter" }, outputs: { onEditorCreated: "onEditorCreated", onContentChanged: "onContentChanged", onSelectionChanged: "onSelectionChanged", onFocus: "onFocus", onBlur: "onBlur" }, providers: [
410
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: QuillEditorComponent, selector: "quill-editor", inputs: { id: "id", format: "format", theme: "theme", modules: "modules", debug: "debug", placeholder: "placeholder", maxLength: "maxLength", minLength: "minLength", formats: "formats", customToolbarPosition: "customToolbarPosition", styles: "styles", scrollingContainer: "scrollingContainer", bounds: "bounds", customOptions: "customOptions", trackChanges: "trackChanges", hasImageFeature: "hasImageFeature", readOnly: ["readOnly", "readOnly", booleanAttribute], required: ["required", "required", booleanAttribute], sanitize: ["sanitize", "sanitize", booleanAttribute], strict: ["strict", "strict", booleanAttribute], preserveWhitespace: ["preserveWhitespace", "preserveWhitespace", booleanAttribute], valueGetter: "valueGetter", valueSetter: "valueSetter" }, outputs: { onEditorCreated: "onEditorCreated", onContentChanged: "onContentChanged", onSelectionChanged: "onSelectionChanged", onFocus: "onFocus", onBlur: "onBlur" }, providers: [
442
411
  {
443
412
  multi: true,
444
413
  provide: NG_VALUE_ACCESSOR,
@@ -523,18 +492,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
523
492
  }], onBlur: [{
524
493
  type: Output
525
494
  }], readOnly: [{
526
- type: Input
495
+ type: Input,
496
+ args: [{ transform: booleanAttribute }]
527
497
  }], required: [{
528
- type: Input
498
+ type: Input,
499
+ args: [{ transform: booleanAttribute }]
529
500
  }], sanitize: [{
530
- type: Input
501
+ type: Input,
502
+ args: [{ transform: booleanAttribute }]
531
503
  }], strict: [{
532
- type: Input
504
+ type: Input,
505
+ args: [{ transform: booleanAttribute }]
533
506
  }], preserveWhitespace: [{
534
- type: Input
507
+ type: Input,
508
+ args: [{ transform: booleanAttribute }]
535
509
  }], valueGetter: [{
536
510
  type: Input
537
511
  }], valueSetter: [{
538
512
  type: Input
539
513
  }] } });
540
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-editor.component.js","sourceRoot":"","sources":["../../../../externals/quill/quill-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport {\n    QUILL_CONFIG_TOKEN,\n    QuillConfig,\n    QuillFormat,\n    QuillModules,\n} from './quill-editor.interfaces';\n\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    Output,\n    PLATFORM_ID,\n    Renderer2,\n    SecurityContext,\n    SimpleChanges,\n    ViewEncapsulation,\n} from '@angular/core';\n\nimport { ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator } from '@angular/forms';\n\nimport { DOCUMENT } from '@angular/common';\nimport { defaultModules } from './quill-defaults';\nimport { ContentChange, EditorChangeContent, SelectionChange, Range } from './models/editor.model';\nimport { coerceBooleanProperty, BooleanInput } from '@angular/cdk/coercion';\nimport { LoaderService } from './loader.service';\n\n// Because quill uses `document` directly, we cannot `import` during SSR\n// instead, we load dynamically via `require('quill')` in `ngAfterViewInit()`\n// eslint-disable-next-line no-var\ndeclare var require: any;\n// eslint-disable-next-line no-var\ndeclare var Quill: any;\n// let Quill: any = window['Quill'];\n\nexport interface CustomOption {\n    import: string;\n    whitelist: any[];\n}\n\nconst getFormat = (format?: QuillFormat, configFormat?: QuillFormat): QuillFormat => {\n    const passedFormat = format || configFormat;\n    return passedFormat || 'html';\n};\n\n@Component({\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        {\n            multi: true,\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => QuillEditorComponent),\n        },\n        {\n            multi: true,\n            provide: NG_VALIDATORS,\n            useExisting: forwardRef(() => QuillEditorComponent),\n        },\n    ],\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'quill-editor',\n    template: ` <ng-content select=\"[quill-editor-toolbar]\"></ng-content> `,\n})\nexport class QuillEditorComponent implements AfterViewInit, ControlValueAccessor, OnChanges, OnDestroy, Validator {\n    quillEditor: any;\n    editorElem: HTMLElement | undefined;\n    content: any;\n    protected loaded = false;\n\n    @Input() id: string;\n    @Input() format?: 'object' | 'html' | 'text' | 'json';\n    @Input() theme?: string;\n    @Input() modules?: QuillModules;\n    @Input() debug?: 'warn' | 'log' | 'error' | false;\n    @Input() placeholder?: string;\n    @Input() maxLength?: number;\n    @Input() minLength?: number;\n    @Input() formats?: string[] | null;\n    @Input() customToolbarPosition: 'top' | 'bottom' = 'top';\n    @Input() styles: any = null;\n    @Input() scrollingContainer?: HTMLElement | string | null;\n    @Input() bounds?: HTMLElement | string;\n    @Input() customOptions: CustomOption[] = [];\n    @Input() trackChanges?: 'user' | 'all';\n    @Input() hasImageFeature: boolean;\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onEditorCreated: EventEmitter<any> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onContentChanged: EventEmitter<ContentChange> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onSelectionChanged: EventEmitter<SelectionChange> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onFocus: EventEmitter<{\n        editor: any;\n        source: string;\n    }> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onBlur: EventEmitter<{\n        editor: any;\n        source: string;\n    }> = new EventEmitter();\n\n    @Input()\n    get readOnly(): boolean {\n        return this._readOnly;\n    }\n    set readOnly(value: BooleanInput) {\n        this._readOnly = coerceBooleanProperty(value);\n    }\n    private _readOnly?: boolean;\n    @Input()\n    get required(): boolean {\n        return this._required;\n    }\n    set required(value: BooleanInput) {\n        this._required = coerceBooleanProperty(value);\n    }\n    private _required = false;\n    @Input()\n    get sanitize(): boolean {\n        return this._sanitize;\n    }\n    set sanitize(value: BooleanInput) {\n        this._sanitize = coerceBooleanProperty(value);\n    }\n    private _sanitize = false;\n    @Input()\n    get strict(): boolean {\n        return this._strict;\n    }\n    set strict(value: BooleanInput) {\n        this._strict = coerceBooleanProperty(value);\n    }\n    private _strict = true;\n    @Input()\n    get preserveWhitespace(): boolean {\n        return this._preserveWhitespace;\n    }\n    set preserveWhitespace(value: BooleanInput) {\n        this._preserveWhitespace = coerceBooleanProperty(value);\n    }\n    private _preserveWhitespace = false;\n\n    private disabled = false; // used to store initial value before ViewInit\n\n    constructor(\n        private elementRef: ElementRef,\n        private domSanitizer: DomSanitizer,\n        @Inject(DOCUMENT) private doc: any,\n        // eslint-disable-next-line @typescript-eslint/ban-types\n        @Inject(PLATFORM_ID) private platformId: Object,\n        private renderer: Renderer2,\n        private zone: NgZone,\n        @Inject(QUILL_CONFIG_TOKEN) private config: QuillConfig,\n        private loader: LoaderService,\n    ) {}\n\n    // eslint-disable-next-line no-empty,no-empty-function,@typescript-eslint/no-empty-function, @typescript-eslint/explicit-function-return-type\n    onModelChange(_modelValue?: any) {}\n    // eslint-disable-next-line no-empty, no-empty-function, @typescript-eslint/no-empty-function, @typescript-eslint/explicit-function-return-type\n    onModelTouched() {}\n\n    @Input()\n    valueGetter = (quillEditor: any, editorElement: HTMLElement): string | any => {\n        let html: string | null = editorElement.querySelector('.ql-editor')?.innerHTML;\n        if (html === '<p><br></p>' || html === '<div><br><div>') {\n            html = null;\n        }\n        let modelValue = html;\n        const format = getFormat(this.format, this.config.format);\n\n        if (format === 'text') {\n            modelValue = quillEditor.getText();\n        } else if (format === 'object') {\n            modelValue = quillEditor.getContents();\n        } else if (format === 'json') {\n            try {\n                modelValue = JSON.stringify(quillEditor.getContents());\n            } catch (e) {\n                modelValue = quillEditor.getText();\n            }\n        }\n\n        return modelValue;\n    };\n\n    @Input()\n    valueSetter = (quillEditor: any, value: any): any => {\n        const format = getFormat(this.format, this.config.format);\n        if (format === 'html') {\n            if (this.sanitize) {\n                value = this.domSanitizer.sanitize(SecurityContext.HTML, value);\n            }\n            return quillEditor.clipboard.convert({ html: value });\n        } else if (format === 'json') {\n            try {\n                return JSON.parse(value);\n            } catch (e) {\n                return [{ insert: value }];\n            }\n        }\n\n        return value;\n    };\n\n    ngAfterViewInit(): void {\n        // const loader = new LoaderService();\n        this.loader.load().subscribe({\n            complete: () => {\n                // setup keyboard bindings from BetterTable if present\n                const QuillBetterTable = window['quillBetterTable'];\n                if(QuillBetterTable) {\n                    // check if already registered\n                    if(!window['Quill'].imports.hasOwnProperty('modules/better-table')) {\n                        window['Quill'].register({ 'modules/better-table': QuillBetterTable });\n                    }\n                    if(!this.config.modules.keyboard) {\n                        this.config.modules.keyboard = {\n                            bindings: QuillBetterTable?.keyboardBindings,\n                        };\n                    }\n                }\n\n                if (isPlatformServer(this.platformId)) {\n                    return;\n                }\n                if (!Quill) {\n                    // Quill = require('quill')\n                    Quill = window['Quill'];\n                }\n                this.overrideScrollBehavior(Quill);\n\n                this.loaded = true;\n\n                this.elementRef.nativeElement.insertAdjacentHTML(\n                    this.customToolbarPosition === 'top' ? 'beforeend' : 'afterbegin',\n                    this.preserveWhitespace ? '<pre quill-editor-element></pre>' : '<div quill-editor-element></div>'\n                );\n\n                this.editorElem = this.elementRef.nativeElement.querySelector('[quill-editor-element]');\n\n                const toolbarElem = this.elementRef.nativeElement.querySelector('[quill-editor-toolbar]');\n                let modules = this.modules || this.config.modules || defaultModules;\n                if (modules.toolbar === undefined) {\n                    modules.toolbar = defaultModules.toolbar;\n                }\n\n                let placeholder = this.placeholder !== undefined ? this.placeholder : this.config.placeholder;\n                if (placeholder === undefined) {\n                    placeholder = 'Insert text here ...';\n                }\n\n                if (toolbarElem) {\n                    // eslint-disable-next-line dot-notation,@typescript-eslint/dot-notation\n                    modules['toolbar'] = toolbarElem;\n                }\n\n                if (!this.hasImageFeature) {\n                    modules['uploader'] = { handler: () => false };\n                } else {\n                    modules['uploader'] = { mimetypes: ['image/png', 'image/jpeg'] };\n                }\n\n                if (this.styles) {\n                    Object.keys(this.styles).forEach((key: string) => {\n                        this.renderer.setStyle(this.editorElem, key, this.styles[key]);\n                    });\n                }\n\n                this.customOptions.forEach((customOption) => {\n                    const newCustomOption = Quill.import(customOption.import);\n                    newCustomOption.whitelist = customOption.whitelist;\n                    Quill.register(newCustomOption, true);\n                });\n\n                let bounds = this.bounds && this.bounds === 'self' ? this.editorElem : this.bounds;\n                if (!bounds) {\n                    bounds = this.config.bounds ? this.config.bounds : this.doc.body;\n                }\n\n                let debug = this.debug;\n                if (!debug && debug !== false && this.config.debug) {\n                    debug = this.config.debug;\n                }\n\n                let readOnly = this.readOnly;\n                if (!readOnly && this.readOnly !== false) {\n                    readOnly = this.config.readOnly !== undefined ? this.config.readOnly : false;\n                }\n\n                let scrollingContainer = this.scrollingContainer;\n                if (!scrollingContainer && this.scrollingContainer !== null) {\n                    scrollingContainer =\n                        this.config.scrollingContainer === null || this.config.scrollingContainer ? this.config.scrollingContainer : null;\n                }\n\n                let formats = this.formats;\n                if (!formats && formats === undefined) {\n                    formats = this.config.formats || this.config.formats === null ? this.config.formats : undefined;\n                }\n                Quill.formats = { ...Quill.formats, [this.id]: formats };\n\n                if (formats && formats.indexOf('table') !== -1) {\n                    modules = {\n                        ...modules,\n                        'better-table': false,\n                    }\n                }\n\n                this.quillEditor = new Quill(this.editorElem, {\n                    bounds,\n                    debug,\n                    formats,\n                    modules,\n                    placeholder,\n                    readOnly,\n                    scrollingContainer,\n                    strict: this.strict,\n                    theme: this.theme || (this.config.theme ? this.config.theme : 'snow'),\n                });\n                this.quillEditor.container.firstChild.id = this.id;\n\n                if (this.content) {\n                    const format = getFormat(this.format, this.config.format);\n                    if (format === 'object') {\n                        this.quillEditor.setContents(this.content, 'silent');\n                    } else if (format === 'text') {\n                        this.quillEditor.setText(this.content, 'silent');\n                    } else if (format === 'json') {\n                        try {\n                            this.quillEditor.setContents(JSON.parse(this.content), 'silent');\n                        } catch (e) {\n                            this.quillEditor.setText(this.content, 'silent');\n                        }\n                    } else {\n                        if (this.sanitize) {\n                            this.content = this.domSanitizer.sanitize(SecurityContext.HTML, this.content);\n                        }\n                        const contents = this.quillEditor.clipboard.convert(this.content);\n                        this.quillEditor.setContents(contents, 'silent');\n                    }\n\n                    this.quillEditor.history.clear();\n                }\n\n                // initialize disabled status based on this.disabled as default value\n                this.setDisabledState();\n\n                this.onEditorCreated.emit(this.quillEditor);\n\n                // mark model as touched if editor lost focus\n                this.quillEditor.on('selection-change', this.selectionChangeHandler);\n\n                // update model if text changes\n                this.quillEditor.on('text-change', this.textChangeHandler);\n            }\n        });\n    }\n\n    selectionChangeHandler = (range: Range | null, oldRange: Range | null, source: string): void => {\n        this.zone.run(() => {\n            if (range === null) {\n                this.onBlur.emit({\n                    editor: this.quillEditor,\n                    source,\n                });\n            } else if (oldRange === null) {\n                this.onFocus.emit({\n                    editor: this.quillEditor,\n                    source,\n                });\n            }\n\n            this.onSelectionChanged.emit({\n                editor: this.quillEditor,\n                oldRange,\n                range,\n                source,\n            });\n\n            if (!range && this.onModelTouched) {\n                this.onModelTouched();\n            }\n        });\n    };\n\n    textChangeHandler = (delta: any, oldDelta: any, source: string): void => {\n        // only emit changes emitted by user interactions\n\n        const text = this.quillEditor.getText();\n        const content = this.quillEditor.getContents();\n\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        let html: string | null = this.editorElem!.querySelector('.ql-editor')!.innerHTML;\n        if (html === '<p><br></p>' || html === '<div><br><div>') {\n            html = null;\n        }\n\n        this.zone.run(() => {\n            const trackChanges = this.trackChanges || this.config.trackChanges;\n            if ((source === Quill.sources.USER || (trackChanges && trackChanges === 'all')) && this.onModelChange) {\n                this.onModelChange(\n                    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n                    this.valueGetter(this.quillEditor, this.editorElem!)\n                );\n            }\n\n            this.onContentChanged.emit({\n                content,\n                delta,\n                editor: this.quillEditor,\n                html,\n                oldDelta,\n                source,\n                text,\n            });\n        });\n    };\n\n    ngOnDestroy(): void {\n        if (this.quillEditor) {\n            this.quillEditor.off('selection-change', this.selectionChangeHandler);\n            this.quillEditor.off('text-change', this.textChangeHandler);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!this.quillEditor) {\n            return;\n        }\n        if (changes.id) {\n            this.quillEditor.container.firstChild.id = changes.id.currentValue;\n            Quill.formats = { ...Quill.formats, [this.id]: this.formats };\n        }\n        if (changes['readOnly']) {\n            this.quillEditor.enable(!changes['readOnly'].currentValue);\n        }\n        if (changes['placeholder']) {\n            this.quillEditor.root.dataset.placeholder = changes['placeholder'].currentValue;\n        }\n        if (changes['styles']) {\n            const currentStyling = changes['styles'].currentValue;\n            const previousStyling = changes['styles'].previousValue;\n\n            if (previousStyling) {\n                Object.keys(previousStyling).forEach((key: string) => {\n                    this.renderer.removeStyle(this.editorElem, key);\n                });\n            }\n            if (currentStyling) {\n                Object.keys(currentStyling).forEach((key: string) => {\n                    this.renderer.setStyle(this.editorElem, key, this.styles[key]);\n                });\n            }\n        }\n        if (changes['formats']) {\n            const currentFormats = changes['formats'].currentValue;\n            Quill.formats = { ...Quill.formats, [this.id]: currentFormats };\n        }\n    }\n\n    writeValue(currentValue: any): void {\n        this.content = currentValue;\n        const format = getFormat(this.format, this.config.format);\n\n        if (this.quillEditor) {\n            if (currentValue) {\n                if (format === 'text') {\n                    this.quillEditor.setText(currentValue);\n                } else {\n                    this.quillEditor.setContents(this.valueSetter(this.quillEditor, this.content));\n                }\n                return;\n            }\n            this.quillEditor.setText('');\n        }\n    }\n\n    setDisabledState(isDisabled: boolean = this.disabled): void {\n        // store initial value to set appropriate disabled status after ViewInit\n        this.disabled = isDisabled;\n        if (this.quillEditor) {\n            if (isDisabled) {\n                this.quillEditor.disable();\n                this.renderer.setAttribute(this.elementRef.nativeElement, 'disabled', 'disabled');\n            } else {\n                if (!this.readOnly) {\n                    this.quillEditor.enable();\n                }\n                this.renderer.removeAttribute(this.elementRef.nativeElement, 'disabled');\n            }\n        }\n    }\n\n    registerOnChange(fn: (modelValue: any) => void): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onModelTouched = fn;\n    }\n\n    validate(): any {\n        if (!this.quillEditor) {\n            return null;\n        }\n\n        const err: {\n            minLengthError?: {\n                given: number;\n                minLength: number;\n            };\n            maxLengthError?: {\n                given: number;\n                maxLength: number;\n            };\n            requiredError?: { empty: boolean };\n        } = {};\n        let valid = true;\n\n        const textLength = this.quillEditor.getText().trim().length;\n\n        if (this.minLength && textLength && textLength < this.minLength) {\n            err.minLengthError = {\n                given: textLength,\n                minLength: this.minLength,\n            };\n\n            valid = false;\n        }\n\n        if (this.maxLength && textLength > this.maxLength) {\n            err.maxLengthError = {\n                given: textLength,\n                maxLength: this.maxLength,\n            };\n\n            valid = false;\n        }\n\n        if (this.required && !textLength) {\n            err.requiredError = {\n                empty: true,\n            };\n\n            valid = false;\n        }\n\n        return valid ? null : err;\n    }\n\n    /**\n     * Override the default Quill scroll behavior to take into account the formats array and skip non-found ones. Then\n     * registers the plugin to the Quill editor.\n     *\n     * @param QuillInstance The Quill class (not the instance)\n     * @private\n     */\n    private overrideScrollBehavior(QuillInstance: any): void {\n        // the Built-in Scroll Class is not exported, so we need to import it\n        const BuiltinScroll = QuillInstance.import('blots/scroll');\n        /**\n         * Override the default Quill scroll behavior to take into account the formats array and skip non-found ones.\n         */\n        class Scroll extends BuiltinScroll {\n            formatAt(index: number, length: number, format: string, value: any): void {\n                const elementId = this.domNode.id;\n                const instanceFormats = QuillInstance.formats[elementId];\n                // checks the formats array to see if the format is blacklisted\n                if (instanceFormats && instanceFormats.find((f) => f === format)) {\n                    return;\n                }\n                // continue with default behavior\n                super.formatAt(index, length, format, value);\n            }\n        }\n        /** register the Scroll override */\n        QuillInstance.register('blots/scroll', Scroll, true);\n    }\n}\n"]}
514
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-editor.component.js","sourceRoot":"","sources":["../../../../externals/quill/quill-editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport {\n    QUILL_CONFIG_TOKEN,\n    QuillConfig,\n    QuillFormat,\n    QuillModules,\n} from './quill-editor.interfaces';\n\nimport {\n    AfterViewInit,\n    booleanAttribute,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    Output,\n    PLATFORM_ID,\n    Renderer2,\n    SecurityContext,\n    SimpleChanges,\n    ViewEncapsulation,\n} from '@angular/core';\n\nimport { ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator } from '@angular/forms';\n\nimport { DOCUMENT } from '@angular/common';\nimport { defaultModules } from './quill-defaults';\nimport { ContentChange, SelectionChange, Range } from './models/editor.model';\nimport { LoaderService } from './loader.service';\n\n// Because quill uses `document` directly, we cannot `import` during SSR\n// instead, we load dynamically via `require('quill')` in `ngAfterViewInit()`\n// eslint-disable-next-line no-var\ndeclare var require: any;\n// eslint-disable-next-line no-var\ndeclare var Quill: any;\n// let Quill: any = window['Quill'];\n\nexport interface CustomOption {\n    import: string;\n    whitelist: any[];\n}\n\nconst getFormat = (format?: QuillFormat, configFormat?: QuillFormat): QuillFormat => {\n    const passedFormat = format || configFormat;\n    return passedFormat || 'html';\n};\n\n@Component({\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        {\n            multi: true,\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => QuillEditorComponent),\n        },\n        {\n            multi: true,\n            provide: NG_VALIDATORS,\n            useExisting: forwardRef(() => QuillEditorComponent),\n        },\n    ],\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'quill-editor',\n    template: ` <ng-content select=\"[quill-editor-toolbar]\"></ng-content> `,\n})\nexport class QuillEditorComponent implements AfterViewInit, ControlValueAccessor, OnChanges, OnDestroy, Validator {\n    quillEditor: any;\n    editorElem: HTMLElement | undefined;\n    content: any;\n    protected loaded = false;\n\n    @Input() id: string;\n    @Input() format?: 'object' | 'html' | 'text' | 'json';\n    @Input() theme?: string;\n    @Input() modules?: QuillModules;\n    @Input() debug?: 'warn' | 'log' | 'error' | false;\n    @Input() placeholder?: string;\n    @Input() maxLength?: number;\n    @Input() minLength?: number;\n    @Input() formats?: string[] | null;\n    @Input() customToolbarPosition: 'top' | 'bottom' = 'top';\n    @Input() styles: any = null;\n    @Input() scrollingContainer?: HTMLElement | string | null;\n    @Input() bounds?: HTMLElement | string;\n    @Input() customOptions: CustomOption[] = [];\n    @Input() trackChanges?: 'user' | 'all';\n    @Input() hasImageFeature: boolean;\n\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onEditorCreated: EventEmitter<any> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onContentChanged: EventEmitter<ContentChange> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onSelectionChanged: EventEmitter<SelectionChange> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onFocus: EventEmitter<{\n        editor: any;\n        source: string;\n    }> = new EventEmitter();\n    // eslint-disable-next-line @angular-eslint/no-output-on-prefix\n    @Output() onBlur: EventEmitter<{\n        editor: any;\n        source: string;\n    }> = new EventEmitter();\n\n    @Input({ transform: booleanAttribute }) readOnly?: boolean;\n    @Input({ transform: booleanAttribute }) required = false;\n    @Input({ transform: booleanAttribute }) sanitize = false;\n    @Input({ transform: booleanAttribute }) strict = true;\n    @Input({ transform: booleanAttribute }) preserveWhitespace = false;\n\n    private disabled = false; // used to store initial value before ViewInit\n\n    constructor(\n        private elementRef: ElementRef,\n        private domSanitizer: DomSanitizer,\n        @Inject(DOCUMENT) private doc: any,\n        // eslint-disable-next-line @typescript-eslint/ban-types\n        @Inject(PLATFORM_ID) private platformId: Object,\n        private renderer: Renderer2,\n        private zone: NgZone,\n        @Inject(QUILL_CONFIG_TOKEN) private config: QuillConfig,\n        private loader: LoaderService,\n    ) {}\n\n    // eslint-disable-next-line no-empty,no-empty-function,@typescript-eslint/no-empty-function, @typescript-eslint/explicit-function-return-type\n    onModelChange(_modelValue?: any) {}\n    // eslint-disable-next-line no-empty, no-empty-function, @typescript-eslint/no-empty-function, @typescript-eslint/explicit-function-return-type\n    onModelTouched() {}\n\n    @Input()\n    valueGetter = (quillEditor: any, editorElement: HTMLElement): string | any => {\n        let html: string | null = editorElement.querySelector('.ql-editor')?.innerHTML;\n        if (html === '<p><br></p>' || html === '<div><br><div>') {\n            html = null;\n        }\n        let modelValue = html;\n        const format = getFormat(this.format, this.config.format);\n\n        if (format === 'text') {\n            modelValue = quillEditor.getText();\n        } else if (format === 'object') {\n            modelValue = quillEditor.getContents();\n        } else if (format === 'json') {\n            try {\n                modelValue = JSON.stringify(quillEditor.getContents());\n            } catch (e) {\n                modelValue = quillEditor.getText();\n            }\n        }\n\n        return modelValue;\n    };\n\n    @Input()\n    valueSetter = (quillEditor: any, value: any): any => {\n        const format = getFormat(this.format, this.config.format);\n        if (format === 'html') {\n            if (this.sanitize) {\n                value = this.domSanitizer.sanitize(SecurityContext.HTML, value);\n            }\n            return quillEditor.clipboard.convert({ html: value });\n        } else if (format === 'json') {\n            try {\n                return JSON.parse(value);\n            } catch (e) {\n                return [{ insert: value }];\n            }\n        }\n\n        return value;\n    };\n\n    ngAfterViewInit(): void {\n        // const loader = new LoaderService();\n        this.loader.load().subscribe({\n            complete: () => {\n                // setup keyboard bindings from BetterTable if present\n                const QuillBetterTable = window['quillBetterTable'];\n                if(QuillBetterTable) {\n                    // check if already registered\n                    if(!window['Quill'].imports.hasOwnProperty('modules/better-table')) {\n                        window['Quill'].register({ 'modules/better-table': QuillBetterTable });\n                    }\n                    if(!this.config.modules.keyboard) {\n                        this.config.modules.keyboard = {\n                            bindings: QuillBetterTable?.keyboardBindings,\n                        };\n                    }\n                }\n\n                if (isPlatformServer(this.platformId)) {\n                    return;\n                }\n                if (!Quill) {\n                    // Quill = require('quill')\n                    Quill = window['Quill'];\n                }\n                this.overrideScrollBehavior(Quill);\n\n                this.loaded = true;\n\n                this.elementRef.nativeElement.insertAdjacentHTML(\n                    this.customToolbarPosition === 'top' ? 'beforeend' : 'afterbegin',\n                    this.preserveWhitespace ? '<pre quill-editor-element></pre>' : '<div quill-editor-element></div>'\n                );\n\n                this.editorElem = this.elementRef.nativeElement.querySelector('[quill-editor-element]');\n\n                const toolbarElem = this.elementRef.nativeElement.querySelector('[quill-editor-toolbar]');\n                let modules = this.modules || this.config.modules || defaultModules;\n                if (modules.toolbar === undefined) {\n                    modules.toolbar = defaultModules.toolbar;\n                }\n\n                let placeholder = this.placeholder !== undefined ? this.placeholder : this.config.placeholder;\n                if (placeholder === undefined) {\n                    placeholder = 'Insert text here ...';\n                }\n\n                if (toolbarElem) {\n                    // eslint-disable-next-line dot-notation,@typescript-eslint/dot-notation\n                    modules['toolbar'] = toolbarElem;\n                }\n\n                if (!this.hasImageFeature) {\n                    modules['uploader'] = { handler: () => false };\n                } else {\n                    modules['uploader'] = { mimetypes: ['image/png', 'image/jpeg'] };\n                }\n\n                if (this.styles) {\n                    Object.keys(this.styles).forEach((key: string) => {\n                        this.renderer.setStyle(this.editorElem, key, this.styles[key]);\n                    });\n                }\n\n                this.customOptions.forEach((customOption) => {\n                    const newCustomOption = Quill.import(customOption.import);\n                    newCustomOption.whitelist = customOption.whitelist;\n                    Quill.register(newCustomOption, true);\n                });\n\n                let bounds = this.bounds && this.bounds === 'self' ? this.editorElem : this.bounds;\n                if (!bounds) {\n                    bounds = this.config.bounds ? this.config.bounds : this.doc.body;\n                }\n\n                let debug = this.debug;\n                if (!debug && debug !== false && this.config.debug) {\n                    debug = this.config.debug;\n                }\n\n                let readOnly = this.readOnly;\n                if (!readOnly && this.readOnly !== false) {\n                    readOnly = this.config.readOnly !== undefined ? this.config.readOnly : false;\n                }\n\n                let scrollingContainer = this.scrollingContainer;\n                if (!scrollingContainer && this.scrollingContainer !== null) {\n                    scrollingContainer =\n                        this.config.scrollingContainer === null || this.config.scrollingContainer ? this.config.scrollingContainer : null;\n                }\n\n                let formats = this.formats;\n                if (!formats && formats === undefined) {\n                    formats = this.config.formats || this.config.formats === null ? this.config.formats : undefined;\n                }\n                Quill.formats = { ...Quill.formats, [this.id]: formats };\n\n                if (formats && formats.indexOf('table') !== -1) {\n                    modules = {\n                        ...modules,\n                        'better-table': false,\n                    }\n                }\n\n                this.quillEditor = new Quill(this.editorElem, {\n                    bounds,\n                    debug,\n                    formats,\n                    modules,\n                    placeholder,\n                    readOnly,\n                    scrollingContainer,\n                    strict: this.strict,\n                    theme: this.theme || (this.config.theme ? this.config.theme : 'snow'),\n                });\n                this.quillEditor.container.firstChild.id = this.id;\n\n                if (this.content) {\n                    const format = getFormat(this.format, this.config.format);\n                    if (format === 'object') {\n                        this.quillEditor.setContents(this.content, 'silent');\n                    } else if (format === 'text') {\n                        this.quillEditor.setText(this.content, 'silent');\n                    } else if (format === 'json') {\n                        try {\n                            this.quillEditor.setContents(JSON.parse(this.content), 'silent');\n                        } catch (e) {\n                            this.quillEditor.setText(this.content, 'silent');\n                        }\n                    } else {\n                        if (this.sanitize) {\n                            this.content = this.domSanitizer.sanitize(SecurityContext.HTML, this.content);\n                        }\n                        const contents = this.quillEditor.clipboard.convert(this.content);\n                        this.quillEditor.setContents(contents, 'silent');\n                    }\n\n                    this.quillEditor.history.clear();\n                }\n\n                // initialize disabled status based on this.disabled as default value\n                this.setDisabledState();\n\n                this.onEditorCreated.emit(this.quillEditor);\n\n                // mark model as touched if editor lost focus\n                this.quillEditor.on('selection-change', this.selectionChangeHandler);\n\n                // update model if text changes\n                this.quillEditor.on('text-change', this.textChangeHandler);\n            }\n        });\n    }\n\n    selectionChangeHandler = (range: Range | null, oldRange: Range | null, source: string): void => {\n        this.zone.run(() => {\n            if (range === null) {\n                this.onBlur.emit({\n                    editor: this.quillEditor,\n                    source,\n                });\n            } else if (oldRange === null) {\n                this.onFocus.emit({\n                    editor: this.quillEditor,\n                    source,\n                });\n            }\n\n            this.onSelectionChanged.emit({\n                editor: this.quillEditor,\n                oldRange,\n                range,\n                source,\n            });\n\n            if (!range && this.onModelTouched) {\n                this.onModelTouched();\n            }\n        });\n    };\n\n    textChangeHandler = (delta: any, oldDelta: any, source: string): void => {\n        // only emit changes emitted by user interactions\n\n        const text = this.quillEditor.getText();\n        const content = this.quillEditor.getContents();\n\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        let html: string | null = this.editorElem!.querySelector('.ql-editor')!.innerHTML;\n        if (html === '<p><br></p>' || html === '<div><br><div>') {\n            html = null;\n        }\n\n        this.zone.run(() => {\n            const trackChanges = this.trackChanges || this.config.trackChanges;\n            if ((source === Quill.sources.USER || (trackChanges && trackChanges === 'all')) && this.onModelChange) {\n                this.onModelChange(\n                    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n                    this.valueGetter(this.quillEditor, this.editorElem!)\n                );\n            }\n\n            this.onContentChanged.emit({\n                content,\n                delta,\n                editor: this.quillEditor,\n                html,\n                oldDelta,\n                source,\n                text,\n            });\n        });\n    };\n\n    ngOnDestroy(): void {\n        if (this.quillEditor) {\n            this.quillEditor.off('selection-change', this.selectionChangeHandler);\n            this.quillEditor.off('text-change', this.textChangeHandler);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!this.quillEditor) {\n            return;\n        }\n        if (changes.id) {\n            this.quillEditor.container.firstChild.id = changes.id.currentValue;\n            Quill.formats = { ...Quill.formats, [this.id]: this.formats };\n        }\n        if (changes['readOnly']) {\n            this.quillEditor.enable(!changes['readOnly'].currentValue);\n        }\n        if (changes['placeholder']) {\n            this.quillEditor.root.dataset.placeholder = changes['placeholder'].currentValue;\n        }\n        if (changes['styles']) {\n            const currentStyling = changes['styles'].currentValue;\n            const previousStyling = changes['styles'].previousValue;\n\n            if (previousStyling) {\n                Object.keys(previousStyling).forEach((key: string) => {\n                    this.renderer.removeStyle(this.editorElem, key);\n                });\n            }\n            if (currentStyling) {\n                Object.keys(currentStyling).forEach((key: string) => {\n                    this.renderer.setStyle(this.editorElem, key, this.styles[key]);\n                });\n            }\n        }\n        if (changes['formats']) {\n            const currentFormats = changes['formats'].currentValue;\n            Quill.formats = { ...Quill.formats, [this.id]: currentFormats };\n        }\n    }\n\n    writeValue(currentValue: any): void {\n        this.content = currentValue;\n        const format = getFormat(this.format, this.config.format);\n\n        if (this.quillEditor) {\n            if (currentValue) {\n                if (format === 'text') {\n                    this.quillEditor.setText(currentValue);\n                } else {\n                    this.quillEditor.setContents(this.valueSetter(this.quillEditor, this.content));\n                }\n                return;\n            }\n            this.quillEditor.setText('');\n        }\n    }\n\n    setDisabledState(isDisabled: boolean = this.disabled): void {\n        // store initial value to set appropriate disabled status after ViewInit\n        this.disabled = isDisabled;\n        if (this.quillEditor) {\n            if (isDisabled) {\n                this.quillEditor.disable();\n                this.renderer.setAttribute(this.elementRef.nativeElement, 'disabled', 'disabled');\n            } else {\n                if (!this.readOnly) {\n                    this.quillEditor.enable();\n                }\n                this.renderer.removeAttribute(this.elementRef.nativeElement, 'disabled');\n            }\n        }\n    }\n\n    registerOnChange(fn: (modelValue: any) => void): void {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onModelTouched = fn;\n    }\n\n    validate(): any {\n        if (!this.quillEditor) {\n            return null;\n        }\n\n        const err: {\n            minLengthError?: {\n                given: number;\n                minLength: number;\n            };\n            maxLengthError?: {\n                given: number;\n                maxLength: number;\n            };\n            requiredError?: { empty: boolean };\n        } = {};\n        let valid = true;\n\n        const textLength = this.quillEditor.getText().trim().length;\n\n        if (this.minLength && textLength && textLength < this.minLength) {\n            err.minLengthError = {\n                given: textLength,\n                minLength: this.minLength,\n            };\n\n            valid = false;\n        }\n\n        if (this.maxLength && textLength > this.maxLength) {\n            err.maxLengthError = {\n                given: textLength,\n                maxLength: this.maxLength,\n            };\n\n            valid = false;\n        }\n\n        if (this.required && !textLength) {\n            err.requiredError = {\n                empty: true,\n            };\n\n            valid = false;\n        }\n\n        return valid ? null : err;\n    }\n\n    /**\n     * Override the default Quill scroll behavior to take into account the formats array and skip non-found ones. Then\n     * registers the plugin to the Quill editor.\n     *\n     * @param QuillInstance The Quill class (not the instance)\n     * @private\n     */\n    private overrideScrollBehavior(QuillInstance: any): void {\n        // the Built-in Scroll Class is not exported, so we need to import it\n        const BuiltinScroll = QuillInstance.import('blots/scroll');\n        /**\n         * Override the default Quill scroll behavior to take into account the formats array and skip non-found ones.\n         */\n        class Scroll extends BuiltinScroll {\n            formatAt(index: number, length: number, format: string, value: any): void {\n                const elementId = this.domNode.id;\n                const instanceFormats = QuillInstance.formats[elementId];\n                // checks the formats array to see if the format is blacklisted\n                if (instanceFormats && instanceFormats.find((f) => f === format)) {\n                    return;\n                }\n                // continue with default behavior\n                super.formatAt(index, length, format, value);\n            }\n        }\n        /** register the Scroll override */\n        QuillInstance.register('blots/scroll', Scroll, true);\n    }\n}\n"]}
@@ -35,11 +35,11 @@ export class EuiAppSidebarComponent {
35
35
  CssUtils.removeSidebarCssVars();
36
36
  }
37
37
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiAppSidebarComponent, deps: [{ token: i1.EuiAppShellService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
38
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: EuiAppSidebarComponent, selector: "eui-app-sidebar", host: { listeners: { "body:click": "close()" }, properties: { "class": "this.string" } }, ngImport: i0, template: "<aside class=\"eui-app-sidebar-content\">\n <ng-content select=\"eui-app-sidebar-header-user-profile\"></ng-content>\n <ng-content select=\"eui-app-sidebar-header\"></ng-content>\n <ng-content select=\"eui-app-sidebar-body\"></ng-content>\n <ng-content select=\"eui-app-sidebar-footer\"></ng-content>\n <ng-content select=\"eui-app-sidebar-drawer\"></ng-content>\n</aside>\n", styles: [".eui-app-sidebar{background-color:var(--eui-c-bg);height:100%;left:0;position:fixed;top:calc(var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height));transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in;width:var(--eui-app-sidebar-width);box-shadow:var(--eui-sh-10)}.eui-app.ff.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:calc(var(--eui-app-sidebar-width-close-active) + 16px)}.modal-open .eui-app-sidebar{z-index:auto}.eui-app-sidebar-content{border-right:1px solid var(--eui-c-neutral-bg-light);background-color:#f9f9f9;box-shadow:0 8px 10px #b7c0cebf;display:flex;flex-direction:column;height:100%;max-height:calc(100% - (var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height)));overflow:hidden;position:relative}.eui-app-sidebar-header{align-items:center;background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-bg-light);display:flex;width:100%}.eui-app-sidebar-body{display:flex;height:100%;max-height:calc(100% - (var(--eui-app-sidebar-header-height) + var(--eui-app-sidebar-footer-height)));overflow-x:hidden;overflow-y:scroll}.eui-app-sidebar-body::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-c-neutral-bg-light)}.eui-app-sidebar-body::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app-sidebar-body::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app-sidebar-body::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-body{max-height:100%}.eui-app-sidebar-footer{align-items:center;display:flex;flex:0 0 auto;justify-content:center;padding:var(--eui-s-xs)}.eui-app-sidebar-menu{display:flex;height:100%;width:100%}@media screen and (max-width: 767px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:50%}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);width:var(--eui-app-sidebar-width-active)}}@media screen and (min-width: 996px){.sidebar--hover .eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:var(--eui-app-sidebar-width-close)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-header{display:none}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-footer{text-indent:-9999px}.sidebar--hidden.sidebar--close .eui-app-sidebar{margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);display:initial;margin-left:0;width:var(--eui-app-sidebar-width-active);z-index:var(--eui-zi-sidebar)}}.eui-app-sidebar-drawer{display:none}.eui-app.sidebar--open.md .eui-app-sidebar-drawer,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer{display:flex;height:100%;position:fixed;top:100vh;transition:top .25s ease-in-out}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content{background:var(--eui-c-bg);border-top:1px solid var(--eui-c-neutral-lightest);height:calc(100% - var(--eui-app-sidebar-header-user-profile));overflow-y:auto;padding:var(--eui-s-s);width:100%}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-c-neutral-bg-light)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.eui-app.sidebar--open.md .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer--expanded{top:var(--eui-app-sidebar-header-user-profile);position:absolute;width:100%}.eui-app.sidebar--close.md .eui-app-sidebar-drawer,.eui-app.sidebar--close.xs .eui-app-sidebar-drawer,.eui-app.sidebar--close.sm .eui-app-sidebar-drawer{position:fixed;top:100vh}@media screen and (max-width: 767px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:50%}}\n"], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
38
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: EuiAppSidebarComponent, selector: "eui-app-sidebar", host: { listeners: { "body:click": "close()" }, properties: { "class": "this.string" } }, ngImport: i0, template: "<aside class=\"eui-app-sidebar-content\">\n <ng-content select=\"eui-app-sidebar-header-user-profile\"></ng-content>\n <ng-content select=\"eui-app-sidebar-header\"></ng-content>\n <ng-content select=\"eui-app-sidebar-body\"></ng-content>\n <ng-content select=\"eui-app-sidebar-footer\"></ng-content>\n <ng-content select=\"eui-app-sidebar-drawer\"></ng-content>\n</aside>\n", styles: [".eui-app-sidebar{background-color:var(--eui-c-bg);height:100%;left:0;position:fixed;top:calc(var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height));transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in;width:var(--eui-app-sidebar-width);box-shadow:var(--eui-sh-10)}.eui-app.ff.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:calc(var(--eui-app-sidebar-width-close-active) + 16px)}.modal-open .eui-app-sidebar{z-index:auto}.eui-app-sidebar-content{border-right:1px solid var(--eui-c-neutral-bg-light);background-color:#f9f9f9;box-shadow:0 8px 10px #b7c0cebf;display:flex;flex-direction:column;height:100%;max-height:calc(100% - (var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height)));overflow:hidden;position:relative}.eui-app-sidebar-header{align-items:center;background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-bg-light);display:flex;width:100%}.eui-app-sidebar-body{display:flex;height:100%;max-height:calc(100% - (var(--eui-app-sidebar-header-height) + var(--eui-app-sidebar-footer-height)));overflow-x:hidden;overflow-y:scroll}.eui-app-sidebar-body::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-c-neutral-bg-light)}.eui-app-sidebar-body::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app-sidebar-body::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app-sidebar-body::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-body{max-height:100%}.eui-app-sidebar-footer{align-items:center;display:flex;flex:0 0 auto;justify-content:center;padding:var(--eui-s-xs)}.eui-app-sidebar-menu{display:flex;height:100%;width:100%}@media screen and (max-width: 767px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:50%}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);width:var(--eui-app-sidebar-width-active)}}@media screen and (min-width: 996px){.sidebar--hover .eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:var(--eui-app-sidebar-width-close)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-header{display:none}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-footer{text-indent:-9999px}.sidebar--hidden.sidebar--close .eui-app-sidebar{margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);display:initial;margin-left:0;width:var(--eui-app-sidebar-width-active);z-index:var(--eui-zi-sidebar)}}.eui-app-sidebar-drawer{display:none}.eui-app.sidebar--open.md .eui-app-sidebar-drawer,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer{display:flex;height:100%;position:fixed;top:100vh;transition:top .25s ease-in-out}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content{background:var(--eui-c-bg);border-top:1px solid var(--eui-c-neutral-lightest);height:calc(100% - var(--eui-app-sidebar-header-user-profile));overflow-y:auto;padding:var(--eui-s-s);width:100%}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-c-neutral-bg-light)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.eui-app.sidebar--open.md .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer--expanded{top:var(--eui-app-sidebar-header-user-profile);position:absolute;width:100%}.eui-app.sidebar--close.md .eui-app-sidebar-drawer,.eui-app.sidebar--close.xs .eui-app-sidebar-drawer,.eui-app.sidebar--close.sm .eui-app-sidebar-drawer{position:fixed;top:100vh}@media screen and (max-width: 767px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:50%}}\n"], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
39
39
  }
40
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiAppSidebarComponent, decorators: [{
41
41
  type: Component,
42
- args: [{ selector: 'eui-app-sidebar', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, template: "<aside class=\"eui-app-sidebar-content\">\n <ng-content select=\"eui-app-sidebar-header-user-profile\"></ng-content>\n <ng-content select=\"eui-app-sidebar-header\"></ng-content>\n <ng-content select=\"eui-app-sidebar-body\"></ng-content>\n <ng-content select=\"eui-app-sidebar-footer\"></ng-content>\n <ng-content select=\"eui-app-sidebar-drawer\"></ng-content>\n</aside>\n", styles: [".eui-app-sidebar{background-color:var(--eui-c-bg);height:100%;left:0;position:fixed;top:calc(var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height));transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in;width:var(--eui-app-sidebar-width);box-shadow:var(--eui-sh-10)}.eui-app.ff.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:calc(var(--eui-app-sidebar-width-close-active) + 16px)}.modal-open .eui-app-sidebar{z-index:auto}.eui-app-sidebar-content{border-right:1px solid var(--eui-c-neutral-bg-light);background-color:#f9f9f9;box-shadow:0 8px 10px #b7c0cebf;display:flex;flex-direction:column;height:100%;max-height:calc(100% - (var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height)));overflow:hidden;position:relative}.eui-app-sidebar-header{align-items:center;background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-bg-light);display:flex;width:100%}.eui-app-sidebar-body{display:flex;height:100%;max-height:calc(100% - (var(--eui-app-sidebar-header-height) + var(--eui-app-sidebar-footer-height)));overflow-x:hidden;overflow-y:scroll}.eui-app-sidebar-body::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-c-neutral-bg-light)}.eui-app-sidebar-body::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app-sidebar-body::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app-sidebar-body::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-body{max-height:100%}.eui-app-sidebar-footer{align-items:center;display:flex;flex:0 0 auto;justify-content:center;padding:var(--eui-s-xs)}.eui-app-sidebar-menu{display:flex;height:100%;width:100%}@media screen and (max-width: 767px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:50%}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);width:var(--eui-app-sidebar-width-active)}}@media screen and (min-width: 996px){.sidebar--hover .eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:var(--eui-app-sidebar-width-close)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-header{display:none}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-footer{text-indent:-9999px}.sidebar--hidden.sidebar--close .eui-app-sidebar{margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);display:initial;margin-left:0;width:var(--eui-app-sidebar-width-active);z-index:var(--eui-zi-sidebar)}}.eui-app-sidebar-drawer{display:none}.eui-app.sidebar--open.md .eui-app-sidebar-drawer,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer{display:flex;height:100%;position:fixed;top:100vh;transition:top .25s ease-in-out}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content{background:var(--eui-c-bg);border-top:1px solid var(--eui-c-neutral-lightest);height:calc(100% - var(--eui-app-sidebar-header-user-profile));overflow-y:auto;padding:var(--eui-s-s);width:100%}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-c-neutral-bg-light)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.eui-app.sidebar--open.md .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer--expanded{top:var(--eui-app-sidebar-header-user-profile);position:absolute;width:100%}.eui-app.sidebar--close.md .eui-app-sidebar-drawer,.eui-app.sidebar--close.xs .eui-app-sidebar-drawer,.eui-app.sidebar--close.sm .eui-app-sidebar-drawer{position:fixed;top:100vh}@media screen and (max-width: 767px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:50%}}\n"] }]
42
+ args: [{ selector: 'eui-app-sidebar', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, template: "<aside class=\"eui-app-sidebar-content\">\n <ng-content select=\"eui-app-sidebar-header-user-profile\"></ng-content>\n <ng-content select=\"eui-app-sidebar-header\"></ng-content>\n <ng-content select=\"eui-app-sidebar-body\"></ng-content>\n <ng-content select=\"eui-app-sidebar-footer\"></ng-content>\n <ng-content select=\"eui-app-sidebar-drawer\"></ng-content>\n</aside>\n", styles: [".eui-app-sidebar{background-color:var(--eui-c-bg);height:100%;left:0;position:fixed;top:calc(var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height));transition:top .1s ease,width .1s ease-in,margin-left .1s ease-in;width:var(--eui-app-sidebar-width);box-shadow:var(--eui-sh-10)}.eui-app.ff.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:calc(var(--eui-app-sidebar-width-close-active) + 16px)}.modal-open .eui-app-sidebar{z-index:auto}.eui-app-sidebar-content{border-right:1px solid var(--eui-c-neutral-bg-light);background-color:#f9f9f9;box-shadow:0 8px 10px #b7c0cebf;display:flex;flex-direction:column;height:100%;max-height:calc(100% - (var(--eui-app-header-height) + var(--eui-app-toolbar-height) + var(--eui-app-top-message-height)));overflow:hidden;position:relative}.eui-app-sidebar-header{align-items:center;background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-bg-light);display:flex;width:100%}.eui-app-sidebar-body{display:flex;height:100%;max-height:calc(100% - (var(--eui-app-sidebar-header-height) + var(--eui-app-sidebar-footer-height)));overflow-x:hidden;overflow-y:scroll}.eui-app-sidebar-body::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-c-neutral-bg-light)}.eui-app-sidebar-body::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app-sidebar-body::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app-sidebar-body::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-body{max-height:100%}.eui-app-sidebar-footer{align-items:center;display:flex;flex:0 0 auto;justify-content:center;padding:var(--eui-s-xs)}.eui-app-sidebar-menu{display:flex;height:100%;width:100%}@media screen and (max-width: 767px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.eui-app-sidebar-body{max-height:100%}.sidebar--close .eui-app-sidebar{box-shadow:none!important;margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--open .eui-app-sidebar{display:initial;margin-left:0;width:50%}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);width:var(--eui-app-sidebar-width-active)}}@media screen and (min-width: 996px){.sidebar--hover .eui-app-sidebar{z-index:var(--eui-zi-sidebar)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar{width:var(--eui-app-sidebar-width-close)}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-header{display:none}.sidebar--close:not(.sidebar--hover) .eui-app-sidebar-footer{text-indent:-9999px}.sidebar--hidden.sidebar--close .eui-app-sidebar{margin-left:calc(var(--eui-app-sidebar-width-active) * -1)}.sidebar--hidden.sidebar--open .eui-app-sidebar{box-shadow:var(--eui-sh-4);display:initial;margin-left:0;width:var(--eui-app-sidebar-width-active);z-index:var(--eui-zi-sidebar)}}.eui-app-sidebar-drawer{display:none}.eui-app.sidebar--open.md .eui-app-sidebar-drawer,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer{display:flex;height:100%;position:fixed;top:100vh;transition:top .25s ease-in-out}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content{background:var(--eui-c-bg);border-top:1px solid var(--eui-c-neutral-lightest);height:calc(100% - var(--eui-app-sidebar-header-user-profile));overflow-y:auto;padding:var(--eui-s-s);width:100%}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-c-neutral-bg-light)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-app.sidebar--open.md .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer-content::-webkit-scrollbar-track,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer-content::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.eui-app.sidebar--open.md .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.xs .eui-app-sidebar-drawer--expanded,.eui-app.sidebar--open.sm .eui-app-sidebar-drawer--expanded{top:var(--eui-app-sidebar-header-user-profile);position:absolute;width:100%}.eui-app.sidebar--close.md .eui-app-sidebar-drawer,.eui-app.sidebar--close.xs .eui-app-sidebar-drawer,.eui-app.sidebar--close.sm .eui-app-sidebar-drawer{position:fixed;top:100vh}@media screen and (max-width: 767px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:75%}}@media screen and (min-width: 768px) and (max-width: 995px){.eui-app-sidebar-drawer,.eui-app-sidebar-drawer--expanded{width:50%}}\n"] }]
43
43
  }], ctorParameters: () => [{ type: i1.EuiAppShellService, decorators: [{
44
44
  type: Optional
45
45
  }] }], propDecorators: { string: [{
@@ -1,5 +1,4 @@
1
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
2
- import { Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';
1
+ import { booleanAttribute, Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';
3
2
  import { consumeEvent } from '@eui/core';
4
3
  import * as i0 from "@angular/core";
5
4
  import * as i1 from "@angular/common";
@@ -14,13 +13,7 @@ export class EuiNotificationItemComponent {
14
13
  this.markAsReadLabel = null;
15
14
  this.dateFormat = 'dd/MM/YYYY';
16
15
  this.tooltipSize = 'auto';
17
- this._isShowMarkAsRead = true;
18
- }
19
- get isShowMarkAsRead() {
20
- return this._isShowMarkAsRead;
21
- }
22
- set isShowMarkAsRead(value) {
23
- this._isShowMarkAsRead = coerceBooleanProperty(value);
16
+ this.isShowMarkAsRead = true;
24
17
  }
25
18
  onItemClick() {
26
19
  this.itemClick.emit(this.item);
@@ -36,7 +29,7 @@ export class EuiNotificationItemComponent {
36
29
  return this.item.metadata?.read ? 'neutral-lightest' : 'neutral-light';
37
30
  }
38
31
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiNotificationItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
39
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: EuiNotificationItemComponent, selector: "eui-notification-item", inputs: { markAsReadLabel: "markAsReadLabel", item: "item", dateFormat: "dateFormat", isShowMarkAsRead: "isShowMarkAsRead" }, outputs: { itemClick: "itemClick", itemMarkAsRead: "itemMarkAsRead" }, host: { properties: { "class": "this.string" } }, ngImport: i0, template: "<div\n class=\"eui-notification-item-content\"\n (click)=\"onItemClick()\"\n [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n <div class=\"eui-notification-item-content-top eui-u-f-s\">\n <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n <span\n *ngIf=\"item.metadata?.new\"\n class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n </span>\n <span>{{ item.metadata?.date | date: dateFormat }}</span>\n </div>\n <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n </div>\n </div>\n <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n <ng-template [ngIf]=\"item.metadata?.url\">\n <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\">\n <div\n class=\"eui-notification-item-content-middle__label\"\n [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n {{ item.label | translate | euiTruncate: 200 }}\n </div>\n <div\n *ngIf=\"item.subLabel\"\n class=\"eui-notification-item-content-middle__sub-label\"\n [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n </a>\n </ng-template>\n\n <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n <a class=\"eui-u-text-link-external\"\n href=\"{{ item.metadata.urlExternal }}\"\n [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\">\n <div\n class=\"eui-notification-item-content-middle__label\"\n [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n {{ item.label | translate | euiTruncate: 200 }}\n </div>\n <div\n *ngIf=\"item.subLabel\"\n class=\"eui-notification-item-content-middle__sub-label\"\n [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n </a>\n </ng-template>\n\n <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n <div\n class=\"eui-notification-item-content-middle__label\"\n [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n {{ item.label | translate | euiTruncate: 200 }}\n </div>\n <div\n *ngIf=\"item.subLabel\"\n class=\"eui-notification-item-content-middle__sub-label\"\n [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n </ng-template>\n </span>\n <div class=\"eui-notification-item-content-bottom\">\n <a *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n href=\"javascript:void(0)\"\n class=\"eui-u-text-link\"\n (click)=\"onItemMarkAsRead($event)\">\n {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n </a>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.EuiTruncatePipe, name: "euiTruncate" }] }); }
32
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: EuiNotificationItemComponent, selector: "eui-notification-item", inputs: { markAsReadLabel: "markAsReadLabel", item: "item", dateFormat: "dateFormat", isShowMarkAsRead: ["isShowMarkAsRead", "isShowMarkAsRead", booleanAttribute] }, outputs: { itemClick: "itemClick", itemMarkAsRead: "itemMarkAsRead" }, host: { properties: { "class": "this.string" } }, ngImport: i0, template: "<div\n class=\"eui-notification-item-content\"\n (click)=\"onItemClick()\"\n [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n <div class=\"eui-notification-item-content-top eui-u-f-s\">\n <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n <span\n *ngIf=\"item.metadata?.new\"\n class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n </span>\n <span>{{ item.metadata?.date | date: dateFormat }}</span>\n </div>\n <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n </div>\n </div>\n <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n <ng-template [ngIf]=\"item.metadata?.url\">\n <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\">\n <div\n class=\"eui-notification-item-content-middle__label\"\n [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n {{ item.label | translate | euiTruncate: 200 }}\n </div>\n <div\n *ngIf=\"item.subLabel\"\n class=\"eui-notification-item-content-middle__sub-label\"\n [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n </a>\n </ng-template>\n\n <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n <a class=\"eui-u-text-link-external\"\n href=\"{{ item.metadata.urlExternal }}\"\n [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\">\n <div\n class=\"eui-notification-item-content-middle__label\"\n [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n {{ item.label | translate | euiTruncate: 200 }}\n </div>\n <div\n *ngIf=\"item.subLabel\"\n class=\"eui-notification-item-content-middle__sub-label\"\n [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n </a>\n </ng-template>\n\n <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n <div\n class=\"eui-notification-item-content-middle__label\"\n [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n {{ item.label | translate | euiTruncate: 200 }}\n </div>\n <div\n *ngIf=\"item.subLabel\"\n class=\"eui-notification-item-content-middle__sub-label\"\n [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n </ng-template>\n </span>\n <div class=\"eui-notification-item-content-bottom\">\n <a *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n href=\"javascript:void(0)\"\n class=\"eui-u-text-link\"\n (click)=\"onItemMarkAsRead($event)\">\n {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n </a>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.EuiTruncatePipe, name: "euiTruncate" }] }); }
40
33
  }
41
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiNotificationItemComponent, decorators: [{
42
35
  type: Component,
@@ -55,6 +48,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
55
48
  }], dateFormat: [{
56
49
  type: Input
57
50
  }], isShowMarkAsRead: [{
58
- type: Input
51
+ type: Input,
52
+ args: [{ transform: booleanAttribute }]
59
53
  }] } });
60
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notification-item.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications/eui-notification-item.component.ts","../../../../layout/eui-notifications/eui-notification-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAgB,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEpF,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;;;;;;AAMzC,MAAM,OAAO,4BAA4B;IAJzC;QAK0B,WAAM,GAAG,uBAAuB,CAAC;QAC7C,cAAS,GAA+B,IAAI,YAAY,EAAgB,CAAC;QACzE,mBAAc,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAC/E,oBAAe,GAAW,IAAI,CAAC;QAI/B,eAAU,GAAG,YAAY,CAAC;QACnC,gBAAW,GAAG,MAAM,CAAC;QAQb,sBAAiB,GAAG,IAAI,CAAC;KAkBpC;IAzBG,IACI,gBAAgB;QAChB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAClC,CAAC;IACD,IAAI,gBAAgB,CAAC,KAAmB;QACpC,IAAI,CAAC,iBAAiB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC1D,CAAC;IAGD,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,gBAAgB,CAAC,KAAY;QACzB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,YAAY,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,eAAe,CAAC;IAC3E,CAAC;8GAjCQ,4BAA4B;kGAA5B,4BAA4B,oTCTzC,ypHAsEA;;2FD7Da,4BAA4B;kBAJxC,SAAS;+BACI,uBAAuB;8BAIX,MAAM;sBAA3B,WAAW;uBAAC,OAAO;gBACV,SAAS;sBAAlB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,eAAe;sBAAvB,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAGF,gBAAgB;sBADnB,KAAK","sourcesContent":["import { coerceBooleanProperty, BooleanInput } from '@angular/cdk/coercion';\nimport { Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\nimport { UxLinkLegacy } from '@eui/core';\nimport { consumeEvent } from '@eui/core';\n\n@Component({\n    selector: 'eui-notification-item',\n    templateUrl: './eui-notification-item.component.html',\n})\nexport class EuiNotificationItemComponent {\n    @HostBinding('class') string = 'eui-notification-item';\n    @Output() itemClick: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Output() itemMarkAsRead: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Input() markAsReadLabel: string = null;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() item: any;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    tooltipSize = 'auto';\n    @Input()\n    get isShowMarkAsRead(): boolean {\n        return this._isShowMarkAsRead;\n    }\n    set isShowMarkAsRead(value: BooleanInput) {\n        this._isShowMarkAsRead = coerceBooleanProperty(value);\n    }\n    private _isShowMarkAsRead = true;\n\n    onItemClick(): void {\n        this.itemClick.emit(this.item);\n    }\n\n    onItemMarkAsRead(event: Event): void {\n        if (this.item.metadata) {\n            this.item.metadata.read = true;\n        }\n        this.itemMarkAsRead.emit(this.item);\n        consumeEvent(event);\n    }\n\n    get iconColor(): string {\n        return this.item.metadata?.read ? 'neutral-lightest' : 'neutral-light';\n    }\n\n}\n","<div\n    class=\"eui-notification-item-content\"\n    (click)=\"onItemClick()\"\n    [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n    <div class=\"eui-notification-item-content-top eui-u-f-s\">\n        <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n            <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n                <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n                <span\n                    *ngIf=\"item.metadata?.new\"\n                    class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n            </span>\n            <span>{{ item.metadata?.date | date: dateFormat }}</span>\n        </div>\n        <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n            <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n        </div>\n    </div>\n    <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n        <ng-template [ngIf]=\"item.metadata?.url\">\n            <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n            <a class=\"eui-u-text-link-external\"\n                href=\"{{ item.metadata.urlExternal }}\"\n                [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n            <div\n                class=\"eui-notification-item-content-middle__label\"\n                [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                {{ item.label | translate | euiTruncate: 200 }}\n            </div>\n            <div\n                *ngIf=\"item.subLabel\"\n                class=\"eui-notification-item-content-middle__sub-label\"\n                [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n        </ng-template>\n    </span>\n    <div class=\"eui-notification-item-content-bottom\">\n        <a *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n            href=\"javascript:void(0)\"\n            class=\"eui-u-text-link\"\n            (click)=\"onItemMarkAsRead($event)\">\n            {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n        </a>\n    </div>\n</div>\n"]}
54
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notification-item.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications/eui-notification-item.component.ts","../../../../layout/eui-notifications/eui-notification-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEtG,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;;;;;;AAMzC,MAAM,OAAO,4BAA4B;IAJzC;QAK0B,WAAM,GAAG,uBAAuB,CAAC;QAC7C,cAAS,GAA+B,IAAI,YAAY,EAAgB,CAAC;QACzE,mBAAc,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAC/E,oBAAe,GAAW,IAAI,CAAC;QAI/B,eAAU,GAAG,YAAY,CAAC;QACnC,gBAAW,GAAG,MAAM,CAAC;QACkB,qBAAgB,GAAG,IAAI,CAAC;KAkBlE;IAhBG,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,gBAAgB,CAAC,KAAY;QACzB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,YAAY,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,eAAe,CAAC;IAC3E,CAAC;8GA1BQ,4BAA4B;kGAA5B,4BAA4B,sLAUjB,gBAAgB,sJClBxC,ypHAsEA;;2FD9Da,4BAA4B;kBAJxC,SAAS;+BACI,uBAAuB;8BAIX,MAAM;sBAA3B,WAAW;uBAAC,OAAO;gBACV,SAAS;sBAAlB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,eAAe;sBAAvB,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEiC,gBAAgB;sBAAtD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { booleanAttribute, Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\nimport { UxLinkLegacy } from '@eui/core';\nimport { consumeEvent } from '@eui/core';\n\n@Component({\n    selector: 'eui-notification-item',\n    templateUrl: './eui-notification-item.component.html',\n})\nexport class EuiNotificationItemComponent {\n    @HostBinding('class') string = 'eui-notification-item';\n    @Output() itemClick: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Output() itemMarkAsRead: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Input() markAsReadLabel: string = null;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() item: any;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    tooltipSize = 'auto';\n    @Input({ transform: booleanAttribute })isShowMarkAsRead = true;\n\n    onItemClick(): void {\n        this.itemClick.emit(this.item);\n    }\n\n    onItemMarkAsRead(event: Event): void {\n        if (this.item.metadata) {\n            this.item.metadata.read = true;\n        }\n        this.itemMarkAsRead.emit(this.item);\n        consumeEvent(event);\n    }\n\n    get iconColor(): string {\n        return this.item.metadata?.read ? 'neutral-lightest' : 'neutral-light';\n    }\n\n}\n","<div\n    class=\"eui-notification-item-content\"\n    (click)=\"onItemClick()\"\n    [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n    <div class=\"eui-notification-item-content-top eui-u-f-s\">\n        <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n            <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n                <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n                <span\n                    *ngIf=\"item.metadata?.new\"\n                    class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n            </span>\n            <span>{{ item.metadata?.date | date: dateFormat }}</span>\n        </div>\n        <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n            <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n        </div>\n    </div>\n    <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n        <ng-template [ngIf]=\"item.metadata?.url\">\n            <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n            <a class=\"eui-u-text-link-external\"\n                href=\"{{ item.metadata.urlExternal }}\"\n                [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n            <div\n                class=\"eui-notification-item-content-middle__label\"\n                [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                {{ item.label | translate | euiTruncate: 200 }}\n            </div>\n            <div\n                *ngIf=\"item.subLabel\"\n                class=\"eui-notification-item-content-middle__sub-label\"\n                [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n        </ng-template>\n    </span>\n    <div class=\"eui-notification-item-content-bottom\">\n        <a *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n            href=\"javascript:void(0)\"\n            class=\"eui-u-text-link\"\n            (click)=\"onItemMarkAsRead($event)\">\n            {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n        </a>\n    </div>\n</div>\n"]}