ets-fe-ng-sdk 18.0.88 → 18.0.89
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.
- package/esm2022/lib/Shared/components/rich-text-editor/rich-text-editor.component.mjs +3 -7
- package/esm2022/lib/Shared/components/rich-text-editor-rf/rich-text-editor-rf.component.mjs +3 -7
- package/fesm2022/ets-fe-ng-sdk.mjs +4 -10
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Services/utility.service.d.ts +1 -1
- package/lib/Shared/components/btn/btn.component.d.ts +1 -1
- package/lib/Shared/components/info-dialog/info-dialog.component.d.ts +1 -1
- package/lib/Shared/components/table/table-https/table-https.component.d.ts +3 -3
- package/package.json +1 -1
|
@@ -2,7 +2,6 @@ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/cor
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { QuillEditorComponent, QuillModule, } from 'ngx-quill';
|
|
4
4
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
|
-
// import 'quill-emoji/dist/quill-emoji.js';
|
|
6
5
|
import 'quill-mention';
|
|
7
6
|
import { lastValueFrom } from 'rxjs';
|
|
8
7
|
import * as i0 from "@angular/core";
|
|
@@ -46,9 +45,6 @@ export class RichTextEditorComponent {
|
|
|
46
45
|
*/
|
|
47
46
|
setModules() {
|
|
48
47
|
this.modules = {
|
|
49
|
-
'emoji-shortname': true,
|
|
50
|
-
'emoji-textarea': true,
|
|
51
|
-
'emoji-toolbar': true,
|
|
52
48
|
formula: true,
|
|
53
49
|
imageResize: {},
|
|
54
50
|
syntax: true,
|
|
@@ -127,11 +123,11 @@ export class RichTextEditorComponent {
|
|
|
127
123
|
// );
|
|
128
124
|
}
|
|
129
125
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
130
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorComponent, isStandalone: true, selector: "rich-text-editor", inputs: { enabled: "enabled", disabled: "disabled", form: "form", name: "name", content: "content" }, outputs: { contentChange: "contentChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], ngImport: i0, template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
126
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorComponent, isStandalone: true, selector: "rich-text-editor", inputs: { enabled: "enabled", disabled: "disabled", form: "form", name: "name", content: "content" }, outputs: { contentChange: "contentChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], ngImport: i0, template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: QuillModule }, { kind: "component", type: i2.QuillEditorComponent, selector: "quill-editor" }, { kind: "component", type: i2.QuillViewHTMLComponent, selector: "quill-view-html", inputs: ["content", "theme", "sanitize"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
131
127
|
}
|
|
132
128
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorComponent, decorators: [{
|
|
133
129
|
type: Component,
|
|
134
|
-
args: [{ selector: 'rich-text-editor', standalone: true, imports: [CommonModule, QuillModule, ReactiveFormsModule, FormsModule], template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
130
|
+
args: [{ selector: 'rich-text-editor', standalone: true, imports: [CommonModule, QuillModule, ReactiveFormsModule, FormsModule], template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"] }]
|
|
135
131
|
}], ctorParameters: () => [], propDecorators: { editor: [{
|
|
136
132
|
type: ViewChild,
|
|
137
133
|
args: [QuillEditorComponent]
|
|
@@ -149,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
149
145
|
}], contentChange: [{
|
|
150
146
|
type: Output
|
|
151
147
|
}] } });
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rich-text-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor/rich-text-editor.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor/rich-text-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  ContentChange,\n  QuillEditorComponent,\n  QuillModule,\n  QuillModules,\n} from 'ngx-quill';\nimport { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\n// import 'quill-emoji/dist/quill-emoji.js'; \nimport 'quill-mention';\nimport { Observable, lastValueFrom } from 'rxjs';\n\n@Component({\n  selector: 'rich-text-editor',\n  standalone: true,\n  imports: [CommonModule, QuillModule, ReactiveFormsModule, FormsModule],\n  templateUrl: './rich-text-editor.component.html',\n  styleUrls: ['./rich-text-editor.component.scss'],\n})\nexport class RichTextEditorComponent {\n  @ViewChild(QuillEditorComponent) editor: QuillEditorComponent;\n  @Input() enabled: boolean = true;\n  /**\n   * Makes the editor non-editable and hides the toolbar\n   */\n  @Input() set disabled(v: boolean) {\n    this.enabled = !v;\n  }\n  /**\n   * Formgroup for the content\n   */\n  @Input() form: FormGroup;\n  /**\n   * Formcontrol name for the field\n   */\n  @Input() name: string;\n  /**\n   * Content when using ngModel\n   */\n  @Input('content') content;\n  // @Input('content') set _content(v) {\n  //   // debugger;\n  //   this.content = v;\n  //   this.htmlString = v || '';\n  // }\n  /**\n   * Content change emission when using ngModel\n   */\n  @Output() contentChange = new EventEmitter();\n  users: {\n    fullName: string;\n    userName: string;\n    code: string;\n  }[] = [];\n  // content;\n  htmlString;\n  modules: QuillModules;\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.setModules();\n  }\n  searchUsers: (\n    query: string,\n  ) => Observable<{ userName?: string; fullName?: string }[]>;\n  /**\n   * Sets the toolbar options and plugins for tagging users and resizing images\n   */\n  setModules() {\n    this.modules = {\n      'emoji-shortname': true,\n      'emoji-textarea': true,\n      'emoji-toolbar': true,\n      formula: true,\n      imageResize: {},\n      syntax: true,\n      mention: {\n        allowedChars: /^[A-Za-z\\sÅÄÖåäö]*$/,\n        onSelect: (item, insertItem) => {\n          const editor = this.editor.quillEditor;\n          insertItem(item);\n          // necessary because quill-mention triggers changes as 'api' instead of 'user'\n          editor.insertText(editor.getLength() - 1, '', 'user');\n        },\n        source: async (searchTerm, renderList) => {\n          const values = (\n            await lastValueFrom(this.searchUsers(searchTerm))\n          ).map((x) => ({\n            id: x.userName,\n            value: x.fullName,\n          }));\n          if (searchTerm.length === 0) {\n            renderList(values, searchTerm);\n          } else {\n            const matches = [];\n\n            values.forEach((entry) => {\n              if (\n                entry.value.toLowerCase().indexOf(searchTerm.toLowerCase()) !==\n                -1\n              ) {\n                matches.push(entry);\n              }\n            });\n            renderList(matches, searchTerm);\n          }\n        },\n      },\n      toolbar: [\n        ['bold', 'italic', 'underline', 'strike'], // toggled buttons\n        ['blockquote', 'code-block'],\n\n        [{ header: 1 }, { header: 2 }], // custom button values\n        [{ list: 'ordered' }, { list: 'bullet' }],\n        [{ script: 'sub' }, { script: 'super' }], // superscript/subscript\n        [{ indent: '-1' }, { indent: '+1' }], // outdent/indent\n        [{ direction: 'rtl' }], // text direction\n\n        [{ size: ['small', false, 'large', 'huge'] }], // custom dropdown\n        [{ header: [1, 2, 3, 4, 5, 6, false] }],\n\n        [{ color: [] }, { background: [] }], // dropdown with defaults from theme\n        [{ font: [] }],\n        [{ align: [] }],\n\n        ['clean'], // remove formatting button\n\n        ['link', 'image', 'video'], // link and image, video\n      ],\n    };\n  }\n  enable = () => {\n    this.enabled = true;\n  };\n\n  disable = () => {\n    this.enabled = false;\n  };\n  onContentChanged(e: ContentChange) {\n    // console.log(e);\n    this.contentChange.emit(e.html);\n  }\n  get getContent() {\n    return this.content;\n  }\n  reset = () => {\n    this.content = undefined;\n  };\n  addBindingCreated(quill: any) {\n    // quill.keyboard.addBinding(\n    //   {\n    //     key: 'b',\n    //   },\n    //   (range, context) => {\n    //     // tslint:disable-next-line:no-console\n    //     console.log('KEYBINDING B', range, context);\n    //   }\n    // );\n    // quill.keyboard.addBinding(\n    //   {\n    //     key: 'B',\n    //     shiftKey: true,\n    //   } as any,\n    //   (range, context) => {\n    //     // tslint:disable-next-line:no-console\n    //     console.log('KEYBINDING SHIFT + B', range, context);\n    //   }\n    // );\n  }\n}\n","@if (form) {\n  <div [formGroup]=\"form\">\n    @if (enabled) {\n      <quill-editor\n        [modules]=\"modules\"\n        formControlName=\"{{ name }}\"\n        theme=\"snow\"\n        class=\"w-100\"\n        (onContentChanged)=\"onContentChanged($event)\"\n        (onEditorCreated)=\"addBindingCreated($event)\" />\n    }\n  </div>\n} @else {\n  <div>\n    <quill-editor\n      *ngIf=\"enabled\"\n      [modules]=\"modules\"\n      [(ngModel)]=\"content\"\n      theme=\"snow\"\n      class=\"w-100\"\n      (onContentChanged)=\"onContentChanged($event)\"\n      (onEditorCreated)=\"addBindingCreated($event)\" />\n  </div>\n}\n<ng-template #elseTemplate>\n  <div>\n    @if (enabled) {\n      <quill-editor\n        [modules]=\"modules\"\n        [(ngModel)]=\"content\"\n        theme=\"snow\"\n        class=\"w-100\"\n        (onContentChanged)=\"onContentChanged($event)\"\n        (onEditorCreated)=\"addBindingCreated($event)\" />\n    }\n  </div>\n</ng-template>\n\n@if (!enabled) {\n  <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n"]}
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rich-text-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor/rich-text-editor.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor/rich-text-editor.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEL,oBAAoB,EACpB,WAAW,GAEZ,MAAM,WAAW,CAAC;AACnB,OAAO,EAAa,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC7E,OAAO,eAAe,CAAC;AACvB,OAAO,EAAc,aAAa,EAAE,MAAM,MAAM,CAAC;;;;;AASjD,MAAM,OAAO,uBAAuB;IAGlC;;OAEG;IACH,IAAa,QAAQ,CAAC,CAAU;QAC9B,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;IACpB,CAAC;IA+BD;QArCS,YAAO,GAAY,IAAI,CAAC;QAmBjC,sCAAsC;QACtC,iBAAiB;QACjB,sBAAsB;QACtB,+BAA+B;QAC/B,IAAI;QACJ;;WAEG;QACO,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QAC7C,UAAK,GAIC,EAAE,CAAC;QA4ET,WAAM,GAAG,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC,CAAC;QAEF,YAAO,GAAG,GAAG,EAAE;YACb,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACvB,CAAC,CAAC;QAQF,UAAK,GAAG,GAAG,EAAE;YACX,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;QAC3B,CAAC,CAAC;IAvFa,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAID;;OAEG;IACH,UAAU;QACR,IAAI,CAAC,OAAO,GAAG;YACb,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,EAAE;YACf,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE;gBACP,YAAY,EAAE,qBAAqB;gBACnC,QAAQ,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,EAAE;oBAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;oBACvC,UAAU,CAAC,IAAI,CAAC,CAAC;oBACjB,8EAA8E;oBAC9E,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,EAAE,GAAG,CAAC,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;gBACxD,CAAC;gBACD,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,EAAE;oBACvC,MAAM,MAAM,GAAG,CACb,MAAM,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,CAClD,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;wBACZ,EAAE,EAAE,CAAC,CAAC,QAAQ;wBACd,KAAK,EAAE,CAAC,CAAC,QAAQ;qBAClB,CAAC,CAAC,CAAC;oBACJ,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;wBAC5B,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;oBACjC,CAAC;yBAAM,CAAC;wBACN,MAAM,OAAO,GAAG,EAAE,CAAC;wBAEnB,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;4BACvB,IACE,KAAK,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;gCAC3D,CAAC,CAAC,EACF,CAAC;gCACD,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;4BACtB,CAAC;wBACH,CAAC,CAAC,CAAC;wBACH,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;oBAClC,CAAC;gBACH,CAAC;aACF;YACD,OAAO,EAAE;gBACP,CAAC,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,CAAC,EAAE,kBAAkB;gBAC7D,CAAC,YAAY,EAAE,YAAY,CAAC;gBAE5B,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,uBAAuB;gBACvD,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;gBACzC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,EAAE,wBAAwB;gBAClE,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,EAAE,iBAAiB;gBACvD,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,iBAAiB;gBAEzC,CAAC,EAAE,IAAI,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE,kBAAkB;gBACjE,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,CAAC;gBAEvC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,EAAE,oCAAoC;gBACzE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC;gBACd,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;gBAEf,CAAC,OAAO,CAAC,EAAE,2BAA2B;gBAEtC,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,wBAAwB;aACrD;SACF,CAAC;IACJ,CAAC;IAQD,gBAAgB,CAAC,CAAgB;QAC/B,kBAAkB;QAClB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IACD,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAID,iBAAiB,CAAC,KAAU;QAC1B,6BAA6B;QAC7B,MAAM;QACN,gBAAgB;QAChB,OAAO;QACP,0BAA0B;QAC1B,6CAA6C;QAC7C,mDAAmD;QACnD,MAAM;QACN,KAAK;QACL,6BAA6B;QAC7B,MAAM;QACN,gBAAgB;QAChB,sBAAsB;QACtB,cAAc;QACd,0BAA0B;QAC1B,6CAA6C;QAC7C,2DAA2D;QAC3D,MAAM;QACN,KAAK;IACP,CAAC;8GAnJU,uBAAuB;kGAAvB,uBAAuB,uQACvB,oBAAoB,gDC1BjC,ujCAyCA,scDpBY,YAAY,kIAAE,WAAW,6OAAE,mBAAmB,mlBAAE,WAAW;;2FAI1D,uBAAuB;kBAPnC,SAAS;+BACE,kBAAkB,cAChB,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,mBAAmB,EAAE,WAAW,CAAC;wDAKrC,MAAM;sBAAtC,SAAS;uBAAC,oBAAoB;gBACtB,OAAO;sBAAf,KAAK;gBAIO,QAAQ;sBAApB,KAAK;gBAMG,IAAI;sBAAZ,KAAK;gBAIG,IAAI;sBAAZ,KAAK;gBAIY,OAAO;sBAAxB,KAAK;uBAAC,SAAS;gBASN,aAAa;sBAAtB,MAAM","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport {\n  ContentChange,\n  QuillEditorComponent,\n  QuillModule,\n  QuillModules,\n} from 'ngx-quill';\nimport { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport 'quill-mention';\nimport { Observable, lastValueFrom } from 'rxjs';\n\n@Component({\n  selector: 'rich-text-editor',\n  standalone: true,\n  imports: [CommonModule, QuillModule, ReactiveFormsModule, FormsModule],\n  templateUrl: './rich-text-editor.component.html',\n  styleUrls: ['./rich-text-editor.component.scss'],\n})\nexport class RichTextEditorComponent {\n  @ViewChild(QuillEditorComponent) editor: QuillEditorComponent;\n  @Input() enabled: boolean = true;\n  /**\n   * Makes the editor non-editable and hides the toolbar\n   */\n  @Input() set disabled(v: boolean) {\n    this.enabled = !v;\n  }\n  /**\n   * Formgroup for the content\n   */\n  @Input() form: FormGroup;\n  /**\n   * Formcontrol name for the field\n   */\n  @Input() name: string;\n  /**\n   * Content when using ngModel\n   */\n  @Input('content') content;\n  // @Input('content') set _content(v) {\n  //   // debugger;\n  //   this.content = v;\n  //   this.htmlString = v || '';\n  // }\n  /**\n   * Content change emission when using ngModel\n   */\n  @Output() contentChange = new EventEmitter();\n  users: {\n    fullName: string;\n    userName: string;\n    code: string;\n  }[] = [];\n  // content;\n  htmlString;\n  modules: QuillModules;\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.setModules();\n  }\n  searchUsers: (\n    query: string,\n  ) => Observable<{ userName?: string; fullName?: string }[]>;\n  /**\n   * Sets the toolbar options and plugins for tagging users and resizing images\n   */\n  setModules() {\n    this.modules = {\n      formula: true,\n      imageResize: {},\n      syntax: true,\n      mention: {\n        allowedChars: /^[A-Za-z\\sÅÄÖåäö]*$/,\n        onSelect: (item, insertItem) => {\n          const editor = this.editor.quillEditor;\n          insertItem(item);\n          // necessary because quill-mention triggers changes as 'api' instead of 'user'\n          editor.insertText(editor.getLength() - 1, '', 'user');\n        },\n        source: async (searchTerm, renderList) => {\n          const values = (\n            await lastValueFrom(this.searchUsers(searchTerm))\n          ).map((x) => ({\n            id: x.userName,\n            value: x.fullName,\n          }));\n          if (searchTerm.length === 0) {\n            renderList(values, searchTerm);\n          } else {\n            const matches = [];\n\n            values.forEach((entry) => {\n              if (\n                entry.value.toLowerCase().indexOf(searchTerm.toLowerCase()) !==\n                -1\n              ) {\n                matches.push(entry);\n              }\n            });\n            renderList(matches, searchTerm);\n          }\n        },\n      },\n      toolbar: [\n        ['bold', 'italic', 'underline', 'strike'], // toggled buttons\n        ['blockquote', 'code-block'],\n\n        [{ header: 1 }, { header: 2 }], // custom button values\n        [{ list: 'ordered' }, { list: 'bullet' }],\n        [{ script: 'sub' }, { script: 'super' }], // superscript/subscript\n        [{ indent: '-1' }, { indent: '+1' }], // outdent/indent\n        [{ direction: 'rtl' }], // text direction\n\n        [{ size: ['small', false, 'large', 'huge'] }], // custom dropdown\n        [{ header: [1, 2, 3, 4, 5, 6, false] }],\n\n        [{ color: [] }, { background: [] }], // dropdown with defaults from theme\n        [{ font: [] }],\n        [{ align: [] }],\n\n        ['clean'], // remove formatting button\n\n        ['link', 'image', 'video'], // link and image, video\n      ],\n    };\n  }\n  enable = () => {\n    this.enabled = true;\n  };\n\n  disable = () => {\n    this.enabled = false;\n  };\n  onContentChanged(e: ContentChange) {\n    // console.log(e);\n    this.contentChange.emit(e.html);\n  }\n  get getContent() {\n    return this.content;\n  }\n  reset = () => {\n    this.content = undefined;\n  };\n  addBindingCreated(quill: any) {\n    // quill.keyboard.addBinding(\n    //   {\n    //     key: 'b',\n    //   },\n    //   (range, context) => {\n    //     // tslint:disable-next-line:no-console\n    //     console.log('KEYBINDING B', range, context);\n    //   }\n    // );\n    // quill.keyboard.addBinding(\n    //   {\n    //     key: 'B',\n    //     shiftKey: true,\n    //   } as any,\n    //   (range, context) => {\n    //     // tslint:disable-next-line:no-console\n    //     console.log('KEYBINDING SHIFT + B', range, context);\n    //   }\n    // );\n  }\n}\n","@if (form) {\n  <div [formGroup]=\"form\">\n    @if (enabled) {\n      <quill-editor\n        [modules]=\"modules\"\n        formControlName=\"{{ name }}\"\n        theme=\"snow\"\n        class=\"w-100\"\n        (onContentChanged)=\"onContentChanged($event)\"\n        (onEditorCreated)=\"addBindingCreated($event)\" />\n    }\n  </div>\n} @else {\n  <div>\n    <quill-editor\n      *ngIf=\"enabled\"\n      [modules]=\"modules\"\n      [(ngModel)]=\"content\"\n      theme=\"snow\"\n      class=\"w-100\"\n      (onContentChanged)=\"onContentChanged($event)\"\n      (onEditorCreated)=\"addBindingCreated($event)\" />\n  </div>\n}\n<ng-template #elseTemplate>\n  <div>\n    @if (enabled) {\n      <quill-editor\n        [modules]=\"modules\"\n        [(ngModel)]=\"content\"\n        theme=\"snow\"\n        class=\"w-100\"\n        (onContentChanged)=\"onContentChanged($event)\"\n        (onEditorCreated)=\"addBindingCreated($event)\" />\n    }\n  </div>\n</ng-template>\n\n@if (!enabled) {\n  <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n"]}
|
|
@@ -2,7 +2,6 @@ import { Component, ViewChild, signal } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { QuillEditorComponent, QuillModule } from 'ngx-quill';
|
|
4
4
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
|
-
// import 'quill-emoji/dist/quill-emoji.js';
|
|
6
5
|
import 'quill-mention';
|
|
7
6
|
import { firstValueFrom } from 'rxjs';
|
|
8
7
|
import { InputLabelComponent } from '../input/input-label/input-label.component';
|
|
@@ -19,9 +18,6 @@ export class RichTextEditorRFComponent extends InputBasicComponent {
|
|
|
19
18
|
super(...arguments);
|
|
20
19
|
this.users = [];
|
|
21
20
|
this.modules = signal({
|
|
22
|
-
'emoji-shortname': true,
|
|
23
|
-
'emoji-textarea': true,
|
|
24
|
-
'emoji-toolbar': true,
|
|
25
21
|
resize: {},
|
|
26
22
|
syntax: true,
|
|
27
23
|
mention: {
|
|
@@ -68,7 +64,7 @@ export class RichTextEditorRFComponent extends InputBasicComponent {
|
|
|
68
64
|
return this.iS.onContentChanged($event, this.form(), this.name());
|
|
69
65
|
}
|
|
70
66
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorRFComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorRFComponent, isStandalone: true, selector: "rich-text-editor-rf", viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorRFComponent, isStandalone: true, selector: "rich-text-editor-rf", viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: QuillModule }, { kind: "component", type: i2.QuillEditorComponent, selector: "quill-editor" }, { kind: "component", type: i2.QuillViewHTMLComponent, selector: "quill-view-html", inputs: ["content", "theme", "sanitize"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }, { kind: "component", type: InputLabelComponent, selector: "app-input-label", inputs: ["colored", "form", "hint", "inlineHint", "id", "invalidCheckbox", "isRequired", "label", "labelLink", "lblCl", "light", "mini", "showLabel", "showRequiredTag", "small", "stacked", "theme", "xsmall"] }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["maxLength", "minLength", "control", "customMessage", "debug", "ignoreDirtiness", "input", "label", "hideOverflow"], outputs: ["labelChange"] }] }); }
|
|
72
68
|
}
|
|
73
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorRFComponent, decorators: [{
|
|
74
70
|
type: Component,
|
|
@@ -80,9 +76,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
80
76
|
ToAnyPipe,
|
|
81
77
|
InputLabelComponent,
|
|
82
78
|
ValidationMessageComponent,
|
|
83
|
-
], template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
79
|
+
], template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"] }]
|
|
84
80
|
}], propDecorators: { editor: [{
|
|
85
81
|
type: ViewChild,
|
|
86
82
|
args: [QuillEditorComponent]
|
|
87
83
|
}] } });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rich-text-editor-rf.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor-rf/rich-text-editor-rf.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor-rf/rich-text-editor-rf.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, signal } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ContentChange, QuillEditorComponent, QuillModule, QuillModules } from 'ngx-quill';\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\n// import 'quill-emoji/dist/quill-emoji.js';\nimport 'quill-mention';\nimport { firstValueFrom } from 'rxjs';\nimport { InputLabelComponent } from '../input/input-label/input-label.component';\nimport { ToAnyPipe } from '../../pipes/utility.pipe';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\n// debugger;\n\n@Component({\n  selector: 'rich-text-editor-rf',\n  standalone: true,\n  templateUrl: './rich-text-editor-rf.component.html',\n  styleUrls: ['./rich-text-editor-rf.component.scss'],\n  imports: [\n    CommonModule,\n    QuillModule,\n    ReactiveFormsModule,\n    FormsModule,\n    ToAnyPipe,\n    InputLabelComponent,\n    ValidationMessageComponent,\n  ],\n})\nexport class RichTextEditorRFComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n  TControl = any,\n  TOption = any,\n> extends InputBasicComponent<TFormGroup, TControl, TOption> {\n  onContentChanged($event: ContentChange) {\n    return this.iS.onContentChanged($event, this.form() as FormGroup<TFormGroup>, this.name());\n  }\n  @ViewChild(QuillEditorComponent) editor!: QuillEditorComponent;\n\n  users: {\n    fullName: string;\n    userName: string;\n    code: string;\n  }[] = [];\n\n  htmlString;\n  modules = signal<QuillModules>({\n    'emoji-shortname': true,\n    'emoji-textarea': true,\n    'emoji-toolbar': true,\n    resize: {},\n    syntax: true,\n    mention: {\n      allowedChars: /^[A-Za-z\\sÅÄÖåäö]*$/,\n      onSelect: (item, insertItem) => {\n        const editor = this.editor.quillEditor;\n        insertItem(item);\n        // necessary because quill-mention triggers changes as 'api' instead of 'user'\n        editor.insertText(editor.getLength() - 1, '', 'user');\n      },\n      source: async (searchTerm, renderList) => {\n        const values = (await firstValueFrom(this.iS.searchUsers(searchTerm))).map((x) => ({\n          id: x.userName,\n          value: x.fullName,\n        }));\n        if (searchTerm.length === 0) {\n          renderList(values, searchTerm);\n        } else {\n          const matches = values.filter(\n            (entry) => entry.value?.toLowerCase().indexOf(searchTerm.toLowerCase()) !== -1,\n          );\n          renderList(matches, searchTerm);\n        }\n      },\n    },\n    toolbar: [\n      ['bold', 'italic', 'underline', 'strike'], // toggled buttons\n      ['blockquote', 'code-block'],\n\n      [{ header: 1 }, { header: 2 }], // custom button values\n      [{ list: 'ordered' }, { list: 'bullet' }],\n      [{ script: 'sub' }, { script: 'super' }], // superscript/subscript\n      [{ indent: '-1' }, { indent: '+1' }], // outdent/indent\n      [{ direction: 'rtl' }], // text direction\n\n      [{ size: ['small', false, 'large', 'huge'] }], // custom dropdown\n      [{ header: [1, 2, 3, 4, 5, 6, false] }],\n\n      [{ color: [] }, { background: [] }], // dropdown with defaults from theme\n      [{ font: [] }],\n      [{ align: [] }],\n\n      ['clean'], // remove formatting button\n\n      ['link', 'image', 'video'], // link and image, video\n    ],\n  });\n}\n","@if (computedShowLabel()) {\n  <app-input-label\n    [colored]=\"coloredSignal()\"\n    [form]=\"form()\"\n    [hint]=\"hint()\"\n    [id]=\"idSignal()\"\n    [invalidCheckbox]=\"invalidCheckboxSignal()\"\n    [isRequired]=\"isRequiredSignal()\"\n    [label]=\"labelSignal()\"\n    [lblCl]=\"lblCl()\"\n    [light]=\"light()\"\n    [mini]=\"miniSignal()\"\n    [ngClass]=\"{ 'w-100': stackedSignal() }\"\n    [inlineHint]=\"inlineHint()\"\n    [showRequiredTag]=\"showRequiredTagSignal()\"\n    [showLabel]=\"showLabelSignal()\"\n    [small]=\"smallSignal()\"\n    [stacked]=\"stackedSignal()\"\n    [theme]=\"theme()\"\n    [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n  <div [formGroup]=\"form() | toAny\">\n    <quill-editor\n      [modules]=\"modules()\"\n      [formControlName]=\"nameStrSignal()\"\n      theme=\"snow\"\n      class=\"w-100\"\n      (onContentChanged)=\"onContentChanged($event)\" />\n  </div>\n} @else {\n  <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n"]}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rich-text-editor-rf.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor-rf/rich-text-editor-rf.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/rich-text-editor-rf/rich-text-editor-rf.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, signal } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ContentChange, QuillEditorComponent, QuillModule, QuillModules } from 'ngx-quill';\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport 'quill-mention';\nimport { firstValueFrom } from 'rxjs';\nimport { InputLabelComponent } from '../input/input-label/input-label.component';\nimport { ToAnyPipe } from '../../pipes/utility.pipe';\nimport { InputBasicComponent } from '../input/input-basic.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\n// debugger;\n\n@Component({\n  selector: 'rich-text-editor-rf',\n  standalone: true,\n  templateUrl: './rich-text-editor-rf.component.html',\n  styleUrls: ['./rich-text-editor-rf.component.scss'],\n  imports: [\n    CommonModule,\n    QuillModule,\n    ReactiveFormsModule,\n    FormsModule,\n    ToAnyPipe,\n    InputLabelComponent,\n    ValidationMessageComponent,\n  ],\n})\nexport class RichTextEditorRFComponent<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n  TControl = any,\n  TOption = any,\n> extends InputBasicComponent<TFormGroup, TControl, TOption> {\n  onContentChanged($event: ContentChange) {\n    return this.iS.onContentChanged($event, this.form() as FormGroup<TFormGroup>, this.name());\n  }\n  @ViewChild(QuillEditorComponent) editor!: QuillEditorComponent;\n\n  users: {\n    fullName: string;\n    userName: string;\n    code: string;\n  }[] = [];\n\n  htmlString;\n  modules = signal<QuillModules>({\n    resize: {},\n    syntax: true,\n    mention: {\n      allowedChars: /^[A-Za-z\\sÅÄÖåäö]*$/,\n      onSelect: (item, insertItem) => {\n        const editor = this.editor.quillEditor;\n        insertItem(item);\n        // necessary because quill-mention triggers changes as 'api' instead of 'user'\n        editor.insertText(editor.getLength() - 1, '', 'user');\n      },\n      source: async (searchTerm, renderList) => {\n        const values = (await firstValueFrom(this.iS.searchUsers(searchTerm))).map((x) => ({\n          id: x.userName,\n          value: x.fullName,\n        }));\n        if (searchTerm.length === 0) {\n          renderList(values, searchTerm);\n        } else {\n          const matches = values.filter(\n            (entry) => entry.value?.toLowerCase().indexOf(searchTerm.toLowerCase()) !== -1,\n          );\n          renderList(matches, searchTerm);\n        }\n      },\n    },\n    toolbar: [\n      ['bold', 'italic', 'underline', 'strike'], // toggled buttons\n      ['blockquote', 'code-block'],\n\n      [{ header: 1 }, { header: 2 }], // custom button values\n      [{ list: 'ordered' }, { list: 'bullet' }],\n      [{ script: 'sub' }, { script: 'super' }], // superscript/subscript\n      [{ indent: '-1' }, { indent: '+1' }], // outdent/indent\n      [{ direction: 'rtl' }], // text direction\n\n      [{ size: ['small', false, 'large', 'huge'] }], // custom dropdown\n      [{ header: [1, 2, 3, 4, 5, 6, false] }],\n\n      [{ color: [] }, { background: [] }], // dropdown with defaults from theme\n      [{ font: [] }],\n      [{ align: [] }],\n\n      ['clean'], // remove formatting button\n\n      ['link', 'image', 'video'], // link and image, video\n    ],\n  });\n}\n","@if (computedShowLabel()) {\n  <app-input-label\n    [colored]=\"coloredSignal()\"\n    [form]=\"form()\"\n    [hint]=\"hint()\"\n    [id]=\"idSignal()\"\n    [invalidCheckbox]=\"invalidCheckboxSignal()\"\n    [isRequired]=\"isRequiredSignal()\"\n    [label]=\"labelSignal()\"\n    [lblCl]=\"lblCl()\"\n    [light]=\"light()\"\n    [mini]=\"miniSignal()\"\n    [ngClass]=\"{ 'w-100': stackedSignal() }\"\n    [inlineHint]=\"inlineHint()\"\n    [showRequiredTag]=\"showRequiredTagSignal()\"\n    [showLabel]=\"showLabelSignal()\"\n    [small]=\"smallSignal()\"\n    [stacked]=\"stackedSignal()\"\n    [theme]=\"theme()\"\n    [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n  <div [formGroup]=\"form() | toAny\">\n    <quill-editor\n      [modules]=\"modules()\"\n      [formControlName]=\"nameStrSignal()\"\n      theme=\"snow\"\n      class=\"w-100\"\n      (onContentChanged)=\"onContentChanged($event)\" />\n  </div>\n} @else {\n  <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n  <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n"]}
|
|
@@ -11945,9 +11945,6 @@ class RichTextEditorRFComponent extends InputBasicComponent {
|
|
|
11945
11945
|
super(...arguments);
|
|
11946
11946
|
this.users = [];
|
|
11947
11947
|
this.modules = signal({
|
|
11948
|
-
'emoji-shortname': true,
|
|
11949
|
-
'emoji-textarea': true,
|
|
11950
|
-
'emoji-toolbar': true,
|
|
11951
11948
|
resize: {},
|
|
11952
11949
|
syntax: true,
|
|
11953
11950
|
mention: {
|
|
@@ -11994,7 +11991,7 @@ class RichTextEditorRFComponent extends InputBasicComponent {
|
|
|
11994
11991
|
return this.iS.onContentChanged($event, this.form(), this.name());
|
|
11995
11992
|
}
|
|
11996
11993
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorRFComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
11997
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorRFComponent, isStandalone: true, selector: "rich-text-editor-rf", viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
11994
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorRFComponent, isStandalone: true, selector: "rich-text-editor-rf", viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: QuillModule }, { kind: "component", type: i2$2.QuillEditorComponent, selector: "quill-editor" }, { kind: "component", type: i2$2.QuillViewHTMLComponent, selector: "quill-view-html", inputs: ["content", "theme", "sanitize"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "pipe", type: ToAnyPipe, name: "toAny" }, { kind: "component", type: InputLabelComponent, selector: "app-input-label", inputs: ["colored", "form", "hint", "inlineHint", "id", "invalidCheckbox", "isRequired", "label", "labelLink", "lblCl", "light", "mini", "showLabel", "showRequiredTag", "small", "stacked", "theme", "xsmall"] }, { kind: "component", type: ValidationMessageComponent, selector: "app-validation-message", inputs: ["maxLength", "minLength", "control", "customMessage", "debug", "ignoreDirtiness", "input", "label", "hideOverflow"], outputs: ["labelChange"] }] }); }
|
|
11998
11995
|
}
|
|
11999
11996
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorRFComponent, decorators: [{
|
|
12000
11997
|
type: Component,
|
|
@@ -12006,7 +12003,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
12006
12003
|
ToAnyPipe,
|
|
12007
12004
|
InputLabelComponent,
|
|
12008
12005
|
ValidationMessageComponent,
|
|
12009
|
-
], template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
12006
|
+
], template: "@if (computedShowLabel()) {\n <app-input-label\n [colored]=\"coloredSignal()\"\n [form]=\"form()\"\n [hint]=\"hint()\"\n [id]=\"idSignal()\"\n [invalidCheckbox]=\"invalidCheckboxSignal()\"\n [isRequired]=\"isRequiredSignal()\"\n [label]=\"labelSignal()\"\n [lblCl]=\"lblCl()\"\n [light]=\"light()\"\n [mini]=\"miniSignal()\"\n [ngClass]=\"{ 'w-100': stackedSignal() }\"\n [inlineHint]=\"inlineHint()\"\n [showRequiredTag]=\"showRequiredTagSignal()\"\n [showLabel]=\"showLabelSignal()\"\n [small]=\"smallSignal()\"\n [stacked]=\"stackedSignal()\"\n [theme]=\"theme()\"\n [xsmall]=\"xsmall()\" />\n}\n@if (!disabledSignal()) {\n <div [formGroup]=\"form() | toAny\">\n <quill-editor\n [modules]=\"modules()\"\n [formControlName]=\"nameStrSignal()\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\" />\n </div>\n} @else {\n <quill-view-html [content]=\"valueSignal()\" theme=\"snow\" class=\"w-100\" />\n}\n\n@if (showValidationMsgSignal()) {\n <app-validation-message [label]=\"labelSignal()\" [control]=\"control()\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"] }]
|
|
12010
12007
|
}], propDecorators: { editor: [{
|
|
12011
12008
|
type: ViewChild,
|
|
12012
12009
|
args: [QuillEditorComponent]
|
|
@@ -14030,9 +14027,6 @@ class RichTextEditorComponent {
|
|
|
14030
14027
|
*/
|
|
14031
14028
|
setModules() {
|
|
14032
14029
|
this.modules = {
|
|
14033
|
-
'emoji-shortname': true,
|
|
14034
|
-
'emoji-textarea': true,
|
|
14035
|
-
'emoji-toolbar': true,
|
|
14036
14030
|
formula: true,
|
|
14037
14031
|
imageResize: {},
|
|
14038
14032
|
syntax: true,
|
|
@@ -14111,11 +14105,11 @@ class RichTextEditorComponent {
|
|
|
14111
14105
|
// );
|
|
14112
14106
|
}
|
|
14113
14107
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
14114
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorComponent, isStandalone: true, selector: "rich-text-editor", inputs: { enabled: "enabled", disabled: "disabled", form: "form", name: "name", content: "content" }, outputs: { contentChange: "contentChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], ngImport: i0, template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
14108
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: RichTextEditorComponent, isStandalone: true, selector: "rich-text-editor", inputs: { enabled: "enabled", disabled: "disabled", form: "form", name: "name", content: "content" }, outputs: { contentChange: "contentChange" }, viewQueries: [{ propertyName: "editor", first: true, predicate: QuillEditorComponent, descendants: true }], ngImport: i0, template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: QuillModule }, { kind: "component", type: i2$2.QuillEditorComponent, selector: "quill-editor" }, { kind: "component", type: i2$2.QuillViewHTMLComponent, selector: "quill-view-html", inputs: ["content", "theme", "sanitize"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
14115
14109
|
}
|
|
14116
14110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: RichTextEditorComponent, decorators: [{
|
|
14117
14111
|
type: Component,
|
|
14118
|
-
args: [{ selector: 'rich-text-editor', standalone: true, imports: [CommonModule, QuillModule, ReactiveFormsModule, FormsModule], template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options
|
|
14112
|
+
args: [{ selector: 'rich-text-editor', standalone: true, imports: [CommonModule, QuillModule, ReactiveFormsModule, FormsModule], template: "@if (form) {\n <div [formGroup]=\"form\">\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n formControlName=\"{{ name }}\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n} @else {\n <div>\n <quill-editor\n *ngIf=\"enabled\"\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n </div>\n}\n<ng-template #elseTemplate>\n <div>\n @if (enabled) {\n <quill-editor\n [modules]=\"modules\"\n [(ngModel)]=\"content\"\n theme=\"snow\"\n class=\"w-100\"\n (onContentChanged)=\"onContentChanged($event)\"\n (onEditorCreated)=\"addBindingCreated($event)\" />\n }\n </div>\n</ng-template>\n\n@if (!enabled) {\n <quill-view-html [content]=\"content\" theme=\"snow\" class=\"w-100\" />\n}\n", styles: [":host ::ng-deep .ql-container{border-radius:0 0 var(--border-radius) var(--border-radius)}:host ::ng-deep .ql-toolbar{border-radius:var(--border-radius) var(--border-radius) 0 0}:host ::ng-deep .ql-picker-label,:host ::ng-deep .ql-picker-options{border-radius:var(--border-radius)}:host ::ng-deep .ql-mention-list-container{height:300px}:host ::ng-deep .ngx-quill-view-html .ql-editor{padding:0}\n"] }]
|
|
14119
14113
|
}], ctorParameters: () => [], propDecorators: { editor: [{
|
|
14120
14114
|
type: ViewChild,
|
|
14121
14115
|
args: [QuillEditorComponent]
|