asksuite-citrus 1.11.2 → 1.12.0

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 (52) hide show
  1. package/esm2022/lib/asksuite-citrus.module.mjs +23 -11
  2. package/esm2022/lib/classes/bubble-toolbox.mjs +49 -0
  3. package/esm2022/lib/classes/richtext-wrapper.mjs +12 -5
  4. package/esm2022/lib/classes/toolbox.mjs +5 -8
  5. package/esm2022/lib/classes/topbar-toolbox.mjs +37 -0
  6. package/esm2022/lib/components/autocomplete/autocomplete.component.mjs +2 -2
  7. package/esm2022/lib/components/avatar/avatar.component.mjs +2 -2
  8. package/esm2022/lib/components/box/box.component.mjs +2 -2
  9. package/esm2022/lib/components/button/button.component.mjs +2 -2
  10. package/esm2022/lib/components/character-counter/character-counter.component.mjs +2 -2
  11. package/esm2022/lib/components/checkbox/checkbox.component.mjs +2 -2
  12. package/esm2022/lib/components/chips/chips.component.mjs +2 -2
  13. package/esm2022/lib/components/date-picker/date-picker-calendar/date-picker-calendar.component.mjs +2 -2
  14. package/esm2022/lib/components/date-picker/date-picker.component.mjs +2 -2
  15. package/esm2022/lib/components/dropdown-container/dropdown-container.component.mjs +2 -2
  16. package/esm2022/lib/components/input/input.component.mjs +2 -2
  17. package/esm2022/lib/components/loading-bar/loading-bar.component.mjs +17 -0
  18. package/esm2022/lib/components/modal/confirmation-modal/confirmation-modal.component.mjs +32 -0
  19. package/esm2022/lib/components/modal/modal.component.mjs +3 -3
  20. package/esm2022/lib/components/pagination/pagination.component.mjs +2 -2
  21. package/esm2022/lib/components/phone-ddi/phone-ddi.component.mjs +2 -2
  22. package/esm2022/lib/components/richtext-toolbox/richtext-toolbox.component.mjs +82 -0
  23. package/esm2022/lib/components/richtext-url-prompt/richtext-url-prompt.component.mjs +3 -3
  24. package/esm2022/lib/components/select/select.component.mjs +2 -2
  25. package/esm2022/lib/components/table/table.component.mjs +2 -2
  26. package/esm2022/lib/components/toast/toast.component.mjs +2 -2
  27. package/esm2022/lib/directives/richtext-toolbox/richtext-toolbox.directive.mjs +12 -8
  28. package/esm2022/lib/services/modal/modal.service.mjs +7 -1
  29. package/esm2022/public-api.mjs +2 -1
  30. package/esm2022/shared/validators/phone-mask.validator.mjs +1 -1
  31. package/fesm2022/asksuite-citrus.mjs +213 -161
  32. package/fesm2022/asksuite-citrus.mjs.map +1 -1
  33. package/lib/asksuite-citrus.module.d.ts +12 -9
  34. package/lib/classes/{toolbox-bubble.d.ts → bubble-toolbox.d.ts} +6 -2
  35. package/lib/classes/richtext-wrapper.d.ts +8 -3
  36. package/lib/classes/toolbox.d.ts +3 -3
  37. package/lib/classes/{toolbox-topbar.d.ts → topbar-toolbox.d.ts} +5 -1
  38. package/lib/components/loading-bar/loading-bar.component.d.ts +6 -0
  39. package/lib/components/modal/confirmation-modal/confirmation-modal.component.d.ts +18 -0
  40. package/lib/components/{richtext-toolbox-core/richtext-toolbox-core.component.d.ts → richtext-toolbox/richtext-toolbox.component.d.ts} +5 -5
  41. package/lib/directives/richtext-toolbox/richtext-toolbox.directive.d.ts +1 -0
  42. package/lib/services/modal/modal.service.d.ts +2 -0
  43. package/package.json +1 -1
  44. package/public-api.d.ts +1 -0
  45. package/shared/validators/phone-mask.validator.d.ts +2 -4
  46. package/styles/material.scss +14 -0
  47. package/styles/styles.scss +5 -0
  48. package/esm2022/lib/classes/toolbox-bubble.mjs +0 -46
  49. package/esm2022/lib/classes/toolbox-topbar.mjs +0 -34
  50. package/esm2022/lib/components/richtext-toolbox-core/richtext-toolbox-core.component.mjs +0 -82
  51. package/esm2022/lib/services/quill-builder.service.mjs +0 -18
  52. package/lib/services/quill-builder.service.d.ts +0 -8
@@ -28,11 +28,14 @@ import { TableComponent } from './components/table/table.component';
28
28
  import { PaginationComponent } from './components/pagination/pagination.component';
29
29
  import { PaginatePipe } from './pipes/paginate/paginate.pipe';
30
30
  import { RichtextUrlPromptComponent } from './components/richtext-url-prompt/richtext-url-prompt.component';
31
- import { RichtextToolboxCoreComponent } from './components/richtext-toolbox-core/richtext-toolbox-core.component';
31
+ import { RichtextToolboxComponent } from './components/richtext-toolbox/richtext-toolbox.component';
32
32
  import { PhoneDdiComponent } from './components/phone-ddi/phone-ddi.component';
33
33
  import { NgxMaskDirective, NgxMaskPipe, provideNgxMask } from "ngx-mask";
34
34
  import { FLAG_PROVIDER_URL } from "../shared/providers/flag.provider";
35
35
  import { ForceBreakLinePipe } from "./pipes/force-break-line/force-break-line.pipe";
36
+ import { ConfirmationModalComponent } from './components/modal/confirmation-modal/confirmation-modal.component';
37
+ import { LoadingBarComponent } from './components/loading-bar/loading-bar.component';
38
+ import { MatProgressBarModule } from "@angular/material/progress-bar";
36
39
  import * as i0 from "@angular/core";
37
40
  import * as i1 from "@ngx-translate/core";
38
41
  export class AsksuiteCitrusModule {
@@ -82,9 +85,11 @@ export class AsksuiteCitrusModule {
82
85
  PaginatePipe,
83
86
  RichtextToolboxDirective,
84
87
  RichtextUrlPromptComponent,
85
- RichtextToolboxCoreComponent,
88
+ RichtextToolboxComponent,
86
89
  AskTextButtonDirective,
87
- ForceBreakLinePipe], imports: [CommonModule,
90
+ ForceBreakLinePipe,
91
+ ConfirmationModalComponent,
92
+ LoadingBarComponent], imports: [CommonModule,
88
93
  FormsModule,
89
94
  ReactiveFormsModule,
90
95
  CdkOverlayOrigin,
@@ -92,7 +97,8 @@ export class AsksuiteCitrusModule {
92
97
  OverlayModule, i1.TranslateModule, NgxSkeletonLoaderModule,
93
98
  MatTooltipModule,
94
99
  NgxMaskDirective,
95
- NgxMaskPipe], exports: [ButtonComponent,
100
+ NgxMaskPipe,
101
+ MatProgressBarModule], exports: [ButtonComponent,
96
102
  InputComponent,
97
103
  SelectComponent,
98
104
  BoxComponent,
@@ -123,7 +129,8 @@ export class AsksuiteCitrusModule {
123
129
  PaginationComponent,
124
130
  PaginatePipe,
125
131
  RichtextToolboxDirective,
126
- ForceBreakLinePipe] }); }
132
+ ForceBreakLinePipe,
133
+ LoadingBarComponent] }); }
127
134
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AsksuiteCitrusModule, providers: [
128
135
  provideNgxMask()
129
136
  ], imports: [CommonModule,
@@ -132,7 +139,8 @@ export class AsksuiteCitrusModule {
132
139
  OverlayModule,
133
140
  TranslateModule.forChild(),
134
141
  NgxSkeletonLoaderModule,
135
- MatTooltipModule] }); }
142
+ MatTooltipModule,
143
+ MatProgressBarModule] }); }
136
144
  }
137
145
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AsksuiteCitrusModule, decorators: [{
138
146
  type: NgModule,
@@ -172,9 +180,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
172
180
  PaginatePipe,
173
181
  RichtextToolboxDirective,
174
182
  RichtextUrlPromptComponent,
175
- RichtextToolboxCoreComponent,
183
+ RichtextToolboxComponent,
176
184
  AskTextButtonDirective,
177
- ForceBreakLinePipe
185
+ ForceBreakLinePipe,
186
+ ConfirmationModalComponent,
187
+ LoadingBarComponent
178
188
  ],
179
189
  imports: [
180
190
  CommonModule,
@@ -187,7 +197,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
187
197
  NgxSkeletonLoaderModule,
188
198
  MatTooltipModule,
189
199
  NgxMaskDirective,
190
- NgxMaskPipe
200
+ NgxMaskPipe,
201
+ MatProgressBarModule
191
202
  ],
192
203
  exports: [
193
204
  ButtonComponent,
@@ -221,11 +232,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
221
232
  PaginationComponent,
222
233
  PaginatePipe,
223
234
  RichtextToolboxDirective,
224
- ForceBreakLinePipe
235
+ ForceBreakLinePipe,
236
+ LoadingBarComponent
225
237
  ],
226
238
  providers: [
227
239
  provideNgxMask()
228
240
  ]
229
241
  }]
230
242
  }] });
231
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asksuite-citrus.module.js","sourceRoot":"","sources":["../../../../projects/asksuite-citrus/src/lib/asksuite-citrus.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {ModuleWithProviders, NgModule} from '@angular/core';\nimport {ButtonComponent} from './components/button/button.component';\nimport {CommonModule} from '@angular/common';\nimport {MatTooltipModule} from '@angular/material/tooltip';\nimport {InputComponent} from './components/input/input.component';\nimport {SelectComponent} from './components/select/select.component';\nimport {BoxComponent} from './components/box/box.component';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {AvatarComponent} from './components/avatar/avatar.component';\nimport {DropdownContainerComponent} from './components/dropdown-container/dropdown-container.component';\nimport {AutocompleteComponent} from './components/autocomplete/autocomplete.component';\nimport {CdkConnectedOverlay, CdkOverlayOrigin, OverlayModule,} from '@angular/cdk/overlay';\nimport {ChipsComponent} from './components/chips/chips.component';\nimport {CheckboxComponent} from './components/checkbox/checkbox.component';\nimport {DatePickerComponent} from './components/date-picker/date-picker.component';\nimport {\n  DatePickerCalendarComponent\n} from './components/date-picker/date-picker-calendar/date-picker-calendar.component';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {SkeletonComponent} from './components/skeleton/skeleton.component';\nimport {NgxSkeletonLoaderModule} from 'ngx-skeleton-loader';\nimport {ToastComponent} from './components/toast/toast.component';\nimport {SpinnerComponent} from \"./directives/spinner/spinner.component\";\nimport {\n  AskButtonDirective,\n  AskDropdownDirective,\n  AskTextButtonDirective,\n  AskTooltipDirective,\n  AutofocusDirective,\n  BadgeDirective,\n  RichtextToolboxDirective,\n  ScrollDirective,\n  SpinnerDirective\n} from \"./directives\";\nimport {ModalBodyDirective, ModalComponent, ModalFooterDirective, ModalHeaderDirective} from './components/modal';\nimport {CharacterCounterComponent} from './components/character-counter/character-counter.component';\nimport {AccordionComponent} from \"./components/accordion/accordion.component\";\nimport {ExtendablePanelComponent} from \"./components/accordion/extendable-panel/extendable-panel.component\";\nimport {TableComponent} from './components/table/table.component';\nimport {PaginationComponent} from './components/pagination/pagination.component';\nimport {PaginatePipe} from './pipes/paginate/paginate.pipe';\nimport {RichtextUrlPromptComponent} from './components/richtext-url-prompt/richtext-url-prompt.component';\nimport {RichtextToolboxCoreComponent} from './components/richtext-toolbox-core/richtext-toolbox-core.component';\nimport {PhoneDdiComponent} from './components/phone-ddi/phone-ddi.component';\nimport {NgxMaskDirective, NgxMaskPipe, provideNgxMask} from \"ngx-mask\";\nimport {FLAG_PROVIDER_URL} from \"../shared/providers/flag.provider\";\nimport {ForceBreakLinePipe} from \"./pipes/force-break-line/force-break-line.pipe\";\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    InputComponent,\n    SelectComponent,\n    BoxComponent,\n    AvatarComponent,\n    DropdownContainerComponent,\n    AskDropdownDirective,\n    AutocompleteComponent,\n    PhoneDdiComponent,\n    ChipsComponent,\n    CheckboxComponent,\n    DatePickerComponent,\n    DatePickerCalendarComponent,\n    SkeletonComponent,\n    SpinnerComponent,\n    SpinnerDirective,\n    BadgeDirective,\n    AutofocusDirective,\n    ScrollDirective,\n    AskTooltipDirective,\n    ToastComponent,\n    AskButtonDirective,\n    ModalComponent,\n    ModalBodyDirective,\n    ModalHeaderDirective,\n    ModalFooterDirective,\n    CharacterCounterComponent,\n    AccordionComponent,\n    ExtendablePanelComponent,\n    TableComponent,\n    PaginationComponent,\n    PaginatePipe,\n    RichtextToolboxDirective,\n    RichtextUrlPromptComponent,\n    RichtextToolboxCoreComponent,\n    AskTextButtonDirective,\n    ForceBreakLinePipe\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    OverlayModule,\n    TranslateModule.forChild(),\n    NgxSkeletonLoaderModule,\n    MatTooltipModule,\n    NgxMaskDirective,\n    NgxMaskPipe\n  ],\n  exports: [\n    ButtonComponent,\n    InputComponent,\n    SelectComponent,\n    BoxComponent,\n    AvatarComponent,\n    DropdownContainerComponent,\n    AskDropdownDirective,\n    AutocompleteComponent,\n    PhoneDdiComponent,\n    ChipsComponent,\n    CheckboxComponent,\n    DatePickerComponent,\n    DatePickerCalendarComponent,\n    SkeletonComponent,\n    SpinnerDirective,\n    BadgeDirective,\n    AutofocusDirective,\n    ScrollDirective,\n    AskTooltipDirective,\n    AskButtonDirective,\n    AskTextButtonDirective,\n    ModalBodyDirective,\n    ModalHeaderDirective,\n    ModalFooterDirective,\n    CharacterCounterComponent,\n    AccordionComponent,\n    ExtendablePanelComponent,\n    TableComponent,\n    PaginationComponent,\n    PaginatePipe,\n    RichtextToolboxDirective,\n    ForceBreakLinePipe\n  ],\n  providers: [\n    provideNgxMask()\n  ]\n})\nexport class AsksuiteCitrusModule {\n  static forRoot(params?: { flagUrl?: string }): ModuleWithProviders<AsksuiteCitrusModule> {\n    return {\n      ngModule: AsksuiteCitrusModule,\n      providers: [\n        {\n          provide: FLAG_PROVIDER_URL,\n          useValue: params?.flagUrl || ''\n        }\n      ]\n    }\n  }\n}\n"]}
243
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asksuite-citrus.module.js","sourceRoot":"","sources":["../../../../projects/asksuite-citrus/src/lib/asksuite-citrus.module.ts"],"names":[],"mappings":"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","sourcesContent":["import {ModuleWithProviders, NgModule} from '@angular/core';\nimport {ButtonComponent} from './components/button/button.component';\nimport {CommonModule} from '@angular/common';\nimport {MatTooltipModule} from '@angular/material/tooltip';\nimport {InputComponent} from './components/input/input.component';\nimport {SelectComponent} from './components/select/select.component';\nimport {BoxComponent} from './components/box/box.component';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {AvatarComponent} from './components/avatar/avatar.component';\nimport {DropdownContainerComponent} from './components/dropdown-container/dropdown-container.component';\nimport {AutocompleteComponent} from './components/autocomplete/autocomplete.component';\nimport {CdkConnectedOverlay, CdkOverlayOrigin, OverlayModule,} from '@angular/cdk/overlay';\nimport {ChipsComponent} from './components/chips/chips.component';\nimport {CheckboxComponent} from './components/checkbox/checkbox.component';\nimport {DatePickerComponent} from './components/date-picker/date-picker.component';\nimport {\n  DatePickerCalendarComponent\n} from './components/date-picker/date-picker-calendar/date-picker-calendar.component';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {SkeletonComponent} from './components/skeleton/skeleton.component';\nimport {NgxSkeletonLoaderModule} from 'ngx-skeleton-loader';\nimport {ToastComponent} from './components/toast/toast.component';\nimport {SpinnerComponent} from \"./directives/spinner/spinner.component\";\nimport {\n  AskButtonDirective,\n  AskDropdownDirective,\n  AskTextButtonDirective,\n  AskTooltipDirective,\n  AutofocusDirective,\n  BadgeDirective,\n  RichtextToolboxDirective,\n  ScrollDirective,\n  SpinnerDirective\n} from \"./directives\";\nimport {ModalBodyDirective, ModalComponent, ModalFooterDirective, ModalHeaderDirective} from './components/modal';\nimport {CharacterCounterComponent} from './components/character-counter/character-counter.component';\nimport {AccordionComponent} from \"./components/accordion/accordion.component\";\nimport {ExtendablePanelComponent} from \"./components/accordion/extendable-panel/extendable-panel.component\";\nimport { TableComponent } from './components/table/table.component';\nimport { PaginationComponent } from './components/pagination/pagination.component';\nimport { PaginatePipe } from './pipes/paginate/paginate.pipe';\nimport { RichtextUrlPromptComponent } from './components/richtext-url-prompt/richtext-url-prompt.component';\nimport { RichtextToolboxComponent } from './components/richtext-toolbox/richtext-toolbox.component';\nimport {PhoneDdiComponent} from './components/phone-ddi/phone-ddi.component';\nimport {NgxMaskDirective, NgxMaskPipe, provideNgxMask} from \"ngx-mask\";\nimport {FLAG_PROVIDER_URL} from \"../shared/providers/flag.provider\";\nimport {ForceBreakLinePipe} from \"./pipes/force-break-line/force-break-line.pipe\";\nimport { ConfirmationModalComponent } from './components/modal/confirmation-modal/confirmation-modal.component';\nimport { LoadingBarComponent } from './components/loading-bar/loading-bar.component';\nimport {MatProgressBarModule} from \"@angular/material/progress-bar\";\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    InputComponent,\n    SelectComponent,\n    BoxComponent,\n    AvatarComponent,\n    DropdownContainerComponent,\n    AskDropdownDirective,\n    AutocompleteComponent,\n    PhoneDdiComponent,\n    ChipsComponent,\n    CheckboxComponent,\n    DatePickerComponent,\n    DatePickerCalendarComponent,\n    SkeletonComponent,\n    SpinnerComponent,\n    SpinnerDirective,\n    BadgeDirective,\n    AutofocusDirective,\n    ScrollDirective,\n    AskTooltipDirective,\n    ToastComponent,\n    AskButtonDirective,\n    ModalComponent,\n    ModalBodyDirective,\n    ModalHeaderDirective,\n    ModalFooterDirective,\n    CharacterCounterComponent,\n    AccordionComponent,\n    ExtendablePanelComponent,\n    TableComponent,\n    PaginationComponent,\n    PaginatePipe,\n    RichtextToolboxDirective,\n    RichtextUrlPromptComponent,\n    RichtextToolboxComponent,\n    AskTextButtonDirective,\n    ForceBreakLinePipe,\n    ConfirmationModalComponent,\n    LoadingBarComponent\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    OverlayModule,\n    TranslateModule.forChild(),\n    NgxSkeletonLoaderModule,\n    MatTooltipModule,\n    NgxMaskDirective,\n    NgxMaskPipe,\n    MatProgressBarModule\n  ],\n  exports: [\n    ButtonComponent,\n    InputComponent,\n    SelectComponent,\n    BoxComponent,\n    AvatarComponent,\n    DropdownContainerComponent,\n    AskDropdownDirective,\n    AutocompleteComponent,\n    PhoneDdiComponent,\n    ChipsComponent,\n    CheckboxComponent,\n    DatePickerComponent,\n    DatePickerCalendarComponent,\n    SkeletonComponent,\n    SpinnerDirective,\n    BadgeDirective,\n    AutofocusDirective,\n    ScrollDirective,\n    AskTooltipDirective,\n    AskButtonDirective,\n    AskTextButtonDirective,\n    ModalBodyDirective,\n    ModalHeaderDirective,\n    ModalFooterDirective,\n    CharacterCounterComponent,\n    AccordionComponent,\n    ExtendablePanelComponent,\n    TableComponent,\n    PaginationComponent,\n    PaginatePipe,\n    RichtextToolboxDirective,\n    ForceBreakLinePipe,\n    LoadingBarComponent\n  ],\n  providers: [\n    provideNgxMask()\n  ]\n})\nexport class AsksuiteCitrusModule {\n  static forRoot(params?: { flagUrl?: string }): ModuleWithProviders<AsksuiteCitrusModule> {\n    return {\n      ngModule: AsksuiteCitrusModule,\n      providers: [\n        {\n          provide: FLAG_PROVIDER_URL,\n          useValue: params?.flagUrl || ''\n        }\n      ]\n    }\n  }\n}\n"]}
@@ -0,0 +1,49 @@
1
+ import { Toolbox } from "./toolbox";
2
+ const TOOLBOX_HEIGHT = 40;
3
+ const MARGIN = 8;
4
+ const MOUSE_EVENT = 'mouseup';
5
+ class BubbleToolbox extends Toolbox {
6
+ constructor(injector) {
7
+ super(injector);
8
+ }
9
+ move(bounds) {
10
+ this.renderer2.setStyle(this.componentEl, 'top', `${bounds.top - (TOOLBOX_HEIGHT + MARGIN)}px`);
11
+ this.renderer2.setStyle(this.componentEl, 'left', `${bounds.left}px`);
12
+ }
13
+ listenOutsideClicks() {
14
+ this.clickListener = (event) => {
15
+ if (!this.componentEl?.contains(event.target)
16
+ && this.isVisible()) {
17
+ this.destroyComponent();
18
+ }
19
+ };
20
+ document.body.addEventListener(MOUSE_EVENT, this.clickListener);
21
+ }
22
+ onToolsChanged(state) {
23
+ super.onToolsChanged(state);
24
+ const { hasSelection, hasFocus, bounds } = state;
25
+ if (hasSelection && bounds) {
26
+ if (!this.isVisible())
27
+ this.displayComponent();
28
+ this.move(bounds);
29
+ }
30
+ else {
31
+ if (this.isVisible() && hasFocus)
32
+ this.destroyComponent();
33
+ }
34
+ }
35
+ displayComponent() {
36
+ super.displayComponent();
37
+ this.listenOutsideClicks();
38
+ this.renderer2.appendChild(this.hostEl?.nativeElement, this.componentEl);
39
+ this.componentRef.setInput('type', 'bubble');
40
+ }
41
+ destroyComponent() {
42
+ document.body.removeEventListener(MOUSE_EVENT, this.clickListener);
43
+ super.destroyComponent();
44
+ }
45
+ }
46
+ export const BubbleToolboxProxy = {
47
+ BubbleToolbox
48
+ };
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnViYmxlLXRvb2xib3guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9jbGFzc2VzL2J1YmJsZS10b29sYm94LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFHcEMsTUFBTSxjQUFjLEdBQUcsRUFBRSxDQUFDO0FBQzFCLE1BQU0sTUFBTSxHQUFHLENBQUMsQ0FBQztBQUNqQixNQUFNLFdBQVcsR0FBRyxTQUFTLENBQUE7QUFFN0IsTUFBTSxhQUFjLFNBQVEsT0FBTztJQUcvQixZQUFZLFFBQWtCO1FBQzVCLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNsQixDQUFDO0lBRU8sSUFBSSxDQUFDLE1BQW9CO1FBQy9CLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUMsS0FBSyxFQUFDLEdBQUcsTUFBTSxDQUFDLEdBQUcsR0FBRyxDQUFDLGNBQWMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUYsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBQyxNQUFNLEVBQUMsR0FBRyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQztJQUN0RSxDQUFDO0lBRU8sbUJBQW1CO1FBQ3pCLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUM3QixJQUNFLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsS0FBSyxDQUFDLE1BQWMsQ0FBQzttQkFDOUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUNwQjtnQkFDQyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQzthQUN6QjtRQUNILENBQUMsQ0FBQTtRQUNELFFBQVEsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNsRSxDQUFDO0lBRVEsY0FBYyxDQUFDLEtBQWlCO1FBQ3ZDLEtBQUssQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDM0IsTUFBTSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEdBQUcsS0FBSyxDQUFDO1FBQ2pELElBQUksWUFBWSxJQUFJLE1BQU0sRUFBRTtZQUMxQixJQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRTtnQkFDbEIsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7WUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUNuQjthQUFNO1lBQ0wsSUFBRyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksUUFBUTtnQkFDN0IsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7U0FDM0I7SUFDSCxDQUFDO0lBRVEsZ0JBQWdCO1FBQ3ZCLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsYUFBYSxFQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN4RSxJQUFJLENBQUMsWUFBYSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUMsUUFBUSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVRLGdCQUFnQjtRQUN2QixRQUFRLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsYUFBYyxDQUFDLENBQUM7UUFDcEUsS0FBSyxDQUFDLGdCQUFnQixFQUFFLENBQUM7SUFDM0IsQ0FBQztDQUNGO0FBR0gsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUc7SUFDaEMsYUFBYTtDQUNkLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RvciB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBCb3VuZHNTdGF0aWMgfSBmcm9tIFwicXVpbGxcIjtcbmltcG9ydCB7IFRvb2xib3ggfSBmcm9tIFwiLi90b29sYm94XCI7XG5pbXBvcnQgeyBUb29sc1N0YXRlIH0gZnJvbSBcIi4uL2ludGVyZmFjZXMvcmljaHRleHQtdG9vbGJveC5pbnRlcmZhY2VcIjtcblxuY29uc3QgVE9PTEJPWF9IRUlHSFQgPSA0MDtcbmNvbnN0IE1BUkdJTiA9IDg7XG5jb25zdCBNT1VTRV9FVkVOVCA9ICdtb3VzZXVwJ1xuXG5jbGFzcyBCdWJibGVUb29sYm94IGV4dGVuZHMgVG9vbGJveCB7XG4gICAgcHJpdmF0ZSBjbGlja0xpc3RlbmVyPzogKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB2b2lkO1xuICBcbiAgICBjb25zdHJ1Y3RvcihpbmplY3RvcjogSW5qZWN0b3IpIHtcbiAgICAgIHN1cGVyKGluamVjdG9yKTtcbiAgICB9XG4gIFxuICAgIHByaXZhdGUgbW92ZShib3VuZHM6IEJvdW5kc1N0YXRpYykge1xuICAgICAgdGhpcy5yZW5kZXJlcjIuc2V0U3R5bGUodGhpcy5jb21wb25lbnRFbCwndG9wJyxgJHtib3VuZHMudG9wIC0gKFRPT0xCT1hfSEVJR0hUICsgTUFSR0lOKX1weGApO1xuICAgICAgdGhpcy5yZW5kZXJlcjIuc2V0U3R5bGUodGhpcy5jb21wb25lbnRFbCwnbGVmdCcsYCR7Ym91bmRzLmxlZnR9cHhgKTtcbiAgICB9XG4gIFxuICAgIHByaXZhdGUgbGlzdGVuT3V0c2lkZUNsaWNrcygpe1xuICAgICAgdGhpcy5jbGlja0xpc3RlbmVyID0gKGV2ZW50KSA9PiB7XG4gICAgICAgIGlmKFxuICAgICAgICAgICF0aGlzLmNvbXBvbmVudEVsPy5jb250YWlucyhldmVudC50YXJnZXQgYXMgTm9kZSkgXG4gICAgICAgICAgJiYgdGhpcy5pc1Zpc2libGUoKVxuICAgICAgICApe1xuICAgICAgICAgIHRoaXMuZGVzdHJveUNvbXBvbmVudCgpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBkb2N1bWVudC5ib2R5LmFkZEV2ZW50TGlzdGVuZXIoTU9VU0VfRVZFTlQsIHRoaXMuY2xpY2tMaXN0ZW5lcik7XG4gICAgfVxuICAgIFxuICAgIG92ZXJyaWRlIG9uVG9vbHNDaGFuZ2VkKHN0YXRlOiBUb29sc1N0YXRlKTogdm9pZCB7XG4gICAgICBzdXBlci5vblRvb2xzQ2hhbmdlZChzdGF0ZSlcbiAgICAgIGNvbnN0IHsgaGFzU2VsZWN0aW9uLCBoYXNGb2N1cywgYm91bmRzIH0gPSBzdGF0ZTtcbiAgICAgIGlmIChoYXNTZWxlY3Rpb24gJiYgYm91bmRzKSB7XG4gICAgICAgIGlmKCF0aGlzLmlzVmlzaWJsZSgpKVxuICAgICAgICAgIHRoaXMuZGlzcGxheUNvbXBvbmVudCgpO1xuICAgICAgICB0aGlzLm1vdmUoYm91bmRzKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlmKHRoaXMuaXNWaXNpYmxlKCkgJiYgaGFzRm9jdXMpXG4gICAgICAgICAgdGhpcy5kZXN0cm95Q29tcG9uZW50KCk7XG4gICAgICB9XG4gICAgfVxuICBcbiAgICBvdmVycmlkZSBkaXNwbGF5Q29tcG9uZW50KCkge1xuICAgICAgc3VwZXIuZGlzcGxheUNvbXBvbmVudCgpO1xuICAgICAgdGhpcy5saXN0ZW5PdXRzaWRlQ2xpY2tzKCk7XG4gICAgICB0aGlzLnJlbmRlcmVyMi5hcHBlbmRDaGlsZCh0aGlzLmhvc3RFbD8ubmF0aXZlRWxlbWVudCx0aGlzLmNvbXBvbmVudEVsKTtcbiAgICAgIHRoaXMuY29tcG9uZW50UmVmIS5zZXRJbnB1dCgndHlwZScsJ2J1YmJsZScpO1xuICAgIH1cblxuICAgIG92ZXJyaWRlIGRlc3Ryb3lDb21wb25lbnQoKSB7XG4gICAgICBkb2N1bWVudC5ib2R5LnJlbW92ZUV2ZW50TGlzdGVuZXIoTU9VU0VfRVZFTlQsIHRoaXMuY2xpY2tMaXN0ZW5lciEpO1xuICAgICAgc3VwZXIuZGVzdHJveUNvbXBvbmVudCgpO1xuICAgIH1cbiAgfVxuXG5cbmV4cG9ydCBjb25zdCBCdWJibGVUb29sYm94UHJveHkgPSB7XG4gIEJ1YmJsZVRvb2xib3hcbn0iXX0=
@@ -1,3 +1,4 @@
1
+ import Quill from 'quill';
1
2
  import { BehaviorSubject, Subject, filter, fromEvent, map } from 'rxjs';
2
3
  import { URL_REGEX } from '../constants/url-regex.constant';
3
4
  export class RichtextWrapper {
@@ -18,10 +19,9 @@ export class RichtextWrapper {
18
19
  get listenEnter$() {
19
20
  return this.enter$.asObservable();
20
21
  }
21
- constructor(ngZone, cd, quillBuilder, elementRef) {
22
+ constructor(ngZone, cd, elementRef) {
22
23
  this.ngZone = ngZone;
23
24
  this.cd = cd;
24
- this.quillBuilder = quillBuilder;
25
25
  this.elementRef = elementRef;
26
26
  this.stateSub = new BehaviorSubject({
27
27
  hasSelection: false,
@@ -85,10 +85,9 @@ export class RichtextWrapper {
85
85
  }
86
86
  };
87
87
  this.state$ = this.stateSub.asObservable();
88
- const Quill = this.quillBuilder.getQuill();
89
88
  const editorId = `editor-${new Date().getTime()}`;
90
89
  this.elementRef.nativeElement.setAttribute('id', editorId);
91
- this.quill = new Quill(`#${editorId}`, {
90
+ this.quill = new QuillProxy.Quill(`#${editorId}`, {
92
91
  placeholder: '',
93
92
  modules: {
94
93
  clipboard: {
@@ -294,4 +293,12 @@ export class RichtextWrapper {
294
293
  });
295
294
  }
296
295
  }
297
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"richtext-wrapper.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/classes/richtext-wrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, ElementRef, NgZone } from '@angular/core';\nimport Quill, { BoundsStatic, RangeStatic, SelectionChangeHandler, Sources, TextChangeHandler } from 'quill';\nimport { BehaviorSubject, Subject, Subscription, filter, fromEvent, map } from 'rxjs';\nimport {\n  RichTextFunctions,\n  RichtextFormats,\n  Tool,\n  ToolKeys,\n  ToolsState,\n} from '../interfaces/richtext-toolbox.interface';\nimport { URL_REGEX } from '../constants/url-regex.constant';\nimport { QuillBuilderService } from '../services/quill-builder.service';\n\nexport class RichtextWrapper implements RichTextFunctions {\n  private quill!: Quill;\n  private stateSub = new BehaviorSubject<ToolsState>({\n    hasSelection: false,\n    hasFocus: false,\n    formats: {\n      italic: false,\n      bold: false,\n      underline: false,\n      strike: false,\n      link: '',\n      list_bulleted: false,\n      list_numbered: false,\n      justify_left: false,\n      justify_center: false,\n      justify_right: false,\n    },\n    disabledTools: []\n  });\n  private esc$ = new Subject<boolean>();\n  private enter$ = new Subject<boolean>();\n  private maxLength = -1;\n  private breakOnEnter = false;\n\n  private textChangeHandler: TextChangeHandler = () => {\n    this.update();\n  };\n\n  private selectionChangeHandler: SelectionChangeHandler = (\n    value: RangeStatic,\n    oldRange: RangeStatic,\n    source: Sources\n  ) => {\n    this.update();\n  };\n\n  private bindings = {\n    bold: {\n      handler: () => {\n        this.setBold();\n        return false;\n      },\n    },\n    italic: {\n      handler: () => {\n        this.setItalic();\n        return false;\n      },\n    },\n    underline: {\n      handler: () => {\n        this.setUnderline();\n        return false;\n      },\n    },\n    escape:{\n      key: 'escape',\n      handler: () => {\n        this.esc$.next(true);\n        return false;\n      }\n    },\n    enter: {\n      key: 'enter',\n      handler: () => {\n        this.enter$.next(true);\n        return this.breakOnEnter;\n      }\n    }\n\n  };\n  private maxLengthSubscription?: Subscription;\n\n  public get state(){\n      return this.stateSub.value\n  }\n  \n  public state$ = this.stateSub.asObservable();\n    \n  public get listenTextChanges$(){\n    return fromEvent(this.quill, 'text-change')\n      .pipe(map(() => this.quill.root.innerHTML)); \n  }\n\n  public get listenOnTouched$(){\n    return fromEvent(this.quill, 'selection-change')\n      .pipe(map(() => !this.quill.getSelection(false)));\n  }\n\n  public get listenEscape$(){\n    return this.esc$.asObservable()\n  }\n\n  public get listenEnter$(){\n    return this.enter$.asObservable();\n  }\n\n  constructor(\n    private ngZone: NgZone,\n    private cd: ChangeDetectorRef,\n    private quillBuilder: QuillBuilderService,\n    private elementRef: ElementRef<HTMLElement>,\n  ) {\n    const Quill = this.quillBuilder.getQuill();\n    const editorId = `editor-${new Date().getTime()}`;\n    this.elementRef.nativeElement.setAttribute('id', editorId);\n    this.quill = new Quill(`#${editorId}`, {\n      placeholder: '',\n      modules: {\n        clipboard: {\n          matchers: [[Node.TEXT_NODE, this.urlMatcher.bind(this)]],\n        },\n        keyboard: { bindings: this.bindings },\n      },\n    });\n    this.listenEditorChanges();\n  }\n\n  public setItalic() {\n    if(this.isToolDisabled('italic')) return;\n    this.quill.format('italic', !this.state.formats.italic);\n    this.update();\n  }\n\n  public setBold() {\n    if(this.isToolDisabled('bold')) return\n    this.quill.format('bold', !this.state.formats.bold);\n    this.update();\n  }\n\n  public setUnderline() {\n    if(this.isToolDisabled('underline')) return;\n    this.quill.format('underline', !this.state.formats.underline);\n    this.update();\n  }\n\n  public setStrike() {\n    if(this.isToolDisabled('strike')) return;\n    this.quill.format('strike', !this.state.formats.strike);\n    this.update();\n  }\n\n  public setListNumbered() {\n    if(this.isToolDisabled('list_numbered')) return;\n    if (this.state.formats.list_numbered)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'ordered');\n    this.update();\n  }\n\n  public setListBulleted() {\n    if(this.isToolDisabled('list_bulleted')) return;\n    if (this.state.formats.list_bulleted)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'bulleted');\n    this.update();\n  }\n\n  public setLink(link: string) {\n    if(this.isToolDisabled('link')) return;\n\n    const range = this.quill.getSelection(true);\n\n    if (range && !range.length) {\n      const [textBloat, offset] = this.quill.getLeaf(range!.index);\n\n      const start = range!.index - offset;\n      const length = textBloat.length();\n\n      this.quill.formatText(start, length, 'link', link);\n    } else {\n      this.quill.format('link', link);\n    }\n\n    this.update();\n  }\n\n  public setJustifyLeft() {\n    if(this.isToolDisabled('justify_left')) return;\n    this.quill.format('align', null);\n    this.update();\n  }\n\n  public setJustifyCenter() {\n    if(this.isToolDisabled('justify_center')) return;\n    this.quill.format('align', 'center');\n    this.update();\n  }\n\n  public setJustifyRight() {\n    if(this.isToolDisabled('justify_right')) return;\n    this.quill.format('align', 'right');\n    this.update();\n  }\n\n  public setRemove() {\n    const selection = this.quill.getSelection();\n    if (selection) this.quill.removeFormat(selection!.index, selection!.length);\n    this.update();\n  }\n\n  public setPlaceholder(placeholder: string){\n    this.quill.root.dataset['placeholder'] = placeholder;\n  }\n\n  public setText(text: string){\n    this.quill.setContents(this.quill.clipboard.convert(text));\n  }\n\n  public setMaxLength(length: number){\n    this.maxLength = length;\n\n    this.maxLengthSubscription?.unsubscribe();\n    if(this.maxLength > 0)\n      this.maxLengthSubscription = \n        fromEvent(this.quill, 'text-change')\n        .pipe(filter(() => this.quill.getLength() > this.maxLength))\n        .subscribe(() => {\n          this.quill.deleteText(this.maxLength, this.quill.getLength());\n      })\n  }\n\n  public setDisabledTools(tools: ToolKeys){\n    if(JSON.stringify(tools) !== JSON.stringify(this.stateSub.value.disabledTools))\n      this.stateSub.next({...this.stateSub.value, disabledTools: tools, })\n  }\n\n  public setEditorClass(className: string){\n    if(!className) return;\n    this.quill.root.classList.add(className);\n  }\n\n  public getEditorElement(){\n    return this.quill.root;\n  }\n\n  public disable(){\n    this.quill.disable();\n  }\n\n  public enable(){\n    this.quill.enable();\n  }\n\n  public focus(){\n    this.quill.focus();\n  }\n\n  public setBreakOnEnter(breakOnEnter: boolean){\n    this.breakOnEnter = breakOnEnter;\n  }\n\n  public destroy() {\n    this.quill.off('selection-change', this.selectionChangeHandler);\n    this.quill.off('text-change', this.textChangeHandler);\n    this.esc$.unsubscribe();\n    this.enter$.unsubscribe();\n    this.stateSub.unsubscribe();\n    this.maxLengthSubscription?.unsubscribe();\n  }\n\n  private isToolDisabled(tool: Tool){\n    return this.stateSub.value.disabledTools.includes(tool)\n  }\n\n  private urlMatcher(node: any, delta: any) {\n    if (typeof node.data !== 'string') return;\n    const matches = node.data.match(URL_REGEX);\n\n    if (matches && matches.length > 0) {\n      let text = '';\n      const selection = this.quill.getSelection(true);\n      if (selection.length)\n        text = this.quill.getText(selection!.index, selection!.length);\n\n      const ops = [];\n      let str = node.data;\n      matches.forEach(function (match: any) {\n        const split = str.split(match);\n        const beforeLink = split.shift();\n        ops.push({ insert: beforeLink });\n        ops.push({ insert: text || match, attributes: { link: match } });\n        str = split.join(match);\n      });\n      ops.push({ insert: str });\n      delta.ops = ops;\n    }\n\n    return delta;\n  }\n\n  private listenEditorChanges() {\n    this.quill.on('selection-change', this.selectionChangeHandler);\n    this.quill.on('text-change', this.textChangeHandler);\n  }\n\n\n  private update() {\n    let bounds: BoundsStatic | undefined;\n    let formatsArr;\n\n    const range = this.quill.getSelection(false);\n    if  (range){ \n      bounds = this.quill.getBounds(range.index, range.length);\n      formatsArr = this.quill.getFormat(range) as any;\n    }\n\n    const formats: RichtextFormats = {\n      italic: formatsArr?.italic || false,\n      bold: formatsArr?.bold || false,\n      underline: formatsArr?.underline || false,\n      strike: formatsArr?.strike || false,\n      link: formatsArr?.link || '',\n      list_bulleted: formatsArr?.list === 'bullet',\n      list_numbered: formatsArr?.list === 'ordered',\n      justify_left: formatsArr?.align === 'left',\n      justify_center: formatsArr?.align === 'center',\n      justify_right: formatsArr?.align === 'right',\n    };\n\n    const hasSelection = !!range?.length;\n    const hasFocus = !!range;\n\n    const newState: ToolsState = { \n      ...this.stateSub.value, \n      hasSelection, \n      formats, \n      bounds, \n      hasFocus \n    };\n\n    this.ngZone.run(() => {\n      this.stateSub.next(newState);\n      this.cd.markForCheck();\n    })\n  }\n}\n"]}
296
+ //to work around testing problems
297
+ export const QuillProxy = {
298
+ Quill
299
+ };
300
+ //to work around testing problems
301
+ export const RichtextWrapperProxy = {
302
+ RichtextWrapper
303
+ };
304
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"richtext-wrapper.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/classes/richtext-wrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, ElementRef, NgZone } from '@angular/core';\nimport Quill, { BoundsStatic, RangeStatic, SelectionChangeHandler, Sources, TextChangeHandler } from 'quill';\nimport { BehaviorSubject, Subject, Subscription, filter, fromEvent, map } from 'rxjs';\nimport {\n  RichTextFunctions,\n  RichtextFormats,\n  Tool,\n  ToolKeys,\n  ToolsState,\n} from '../interfaces/richtext-toolbox.interface';\nimport { URL_REGEX } from '../constants/url-regex.constant';\n\nexport class RichtextWrapper implements RichTextFunctions {\n  private quill!: Quill;\n  private stateSub = new BehaviorSubject<ToolsState>({\n    hasSelection: false,\n    hasFocus: false,\n    formats: {\n      italic: false,\n      bold: false,\n      underline: false,\n      strike: false,\n      link: '',\n      list_bulleted: false,\n      list_numbered: false,\n      justify_left: false,\n      justify_center: false,\n      justify_right: false,\n    },\n    disabledTools: []\n  });\n  private esc$ = new Subject<boolean>();\n  private enter$ = new Subject<boolean>();\n  private maxLength = -1;\n  private breakOnEnter = false;\n\n  private textChangeHandler: TextChangeHandler = () => {\n    this.update();\n  };\n\n  private selectionChangeHandler: SelectionChangeHandler = (\n    value: RangeStatic,\n    oldRange: RangeStatic,\n    source: Sources\n  ) => {\n    this.update();\n  };\n\n  private bindings = {\n    bold: {\n      handler: () => {\n        this.setBold();\n        return false;\n      },\n    },\n    italic: {\n      handler: () => {\n        this.setItalic();\n        return false;\n      },\n    },\n    underline: {\n      handler: () => {\n        this.setUnderline();\n        return false;\n      },\n    },\n    escape:{\n      key: 'escape',\n      handler: () => {\n        this.esc$.next(true);\n        return false;\n      }\n    },\n    enter: {\n      key: 'enter',\n      handler: () => {\n        this.enter$.next(true);\n        return this.breakOnEnter;\n      }\n    }\n\n  };\n  private maxLengthSubscription?: Subscription;\n\n  public get state(){\n      return this.stateSub.value\n  }\n  \n  public state$ = this.stateSub.asObservable();\n    \n  public get listenTextChanges$(){\n    return fromEvent(this.quill, 'text-change')\n      .pipe(map(() => this.quill.root.innerHTML)); \n  }\n\n  public get listenOnTouched$(){\n    return fromEvent(this.quill, 'selection-change')\n      .pipe(map(() => !this.quill.getSelection(false)));\n  }\n\n  public get listenEscape$(){\n    return this.esc$.asObservable()\n  }\n\n  public get listenEnter$(){\n    return this.enter$.asObservable();\n  }\n\n  constructor(\n    private ngZone: NgZone,\n    private cd: ChangeDetectorRef,\n    private elementRef: ElementRef<HTMLElement>,\n  ) {\n    const editorId = `editor-${new Date().getTime()}`;\n    this.elementRef.nativeElement.setAttribute('id', editorId);\n    this.quill = new QuillProxy.Quill(`#${editorId}`, {\n      placeholder: '',\n      modules: {\n        clipboard: {\n          matchers: [[Node.TEXT_NODE, this.urlMatcher.bind(this)]],\n        },\n        keyboard: { bindings: this.bindings },\n      },\n    });\n    this.listenEditorChanges();\n  }\n\n  public setItalic() {\n    if(this.isToolDisabled('italic')) return;\n    this.quill.format('italic', !this.state.formats.italic);\n    this.update();\n  }\n\n  public setBold() {\n    if(this.isToolDisabled('bold')) return\n    this.quill.format('bold', !this.state.formats.bold);\n    this.update();\n  }\n\n  public setUnderline() {\n    if(this.isToolDisabled('underline')) return;\n    this.quill.format('underline', !this.state.formats.underline);\n    this.update();\n  }\n\n  public setStrike() {\n    if(this.isToolDisabled('strike')) return;\n    this.quill.format('strike', !this.state.formats.strike);\n    this.update();\n  }\n\n  public setListNumbered() {\n    if(this.isToolDisabled('list_numbered')) return;\n    if (this.state.formats.list_numbered)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'ordered');\n    this.update();\n  }\n\n  public setListBulleted() {\n    if(this.isToolDisabled('list_bulleted')) return;\n    if (this.state.formats.list_bulleted)\n      this.quill.format('list', null);\n    else  \n      this.quill.format('list', 'bulleted');\n    this.update();\n  }\n\n  public setLink(link: string) {\n    if(this.isToolDisabled('link')) return;\n\n    const range = this.quill.getSelection(true);\n\n    if (range && !range.length) {\n      const [textBloat, offset] = this.quill.getLeaf(range!.index);\n\n      const start = range!.index - offset;\n      const length = textBloat.length();\n\n      this.quill.formatText(start, length, 'link', link);\n    } else {\n      this.quill.format('link', link);\n    }\n\n    this.update();\n  }\n\n  public setJustifyLeft() {\n    if(this.isToolDisabled('justify_left')) return;\n    this.quill.format('align', null);\n    this.update();\n  }\n\n  public setJustifyCenter() {\n    if(this.isToolDisabled('justify_center')) return;\n    this.quill.format('align', 'center');\n    this.update();\n  }\n\n  public setJustifyRight() {\n    if(this.isToolDisabled('justify_right')) return;\n    this.quill.format('align', 'right');\n    this.update();\n  }\n\n  public setRemove() {\n    const selection = this.quill.getSelection();\n    if (selection) this.quill.removeFormat(selection!.index, selection!.length);\n    this.update();\n  }\n\n  public setPlaceholder(placeholder: string){\n    this.quill.root.dataset['placeholder'] = placeholder;\n  }\n\n  public setText(text: string){\n    this.quill.setContents(this.quill.clipboard.convert(text));\n  }\n\n  public setMaxLength(length: number){\n    this.maxLength = length;\n\n    this.maxLengthSubscription?.unsubscribe();\n    if(this.maxLength > 0)\n      this.maxLengthSubscription = \n        fromEvent(this.quill, 'text-change')\n        .pipe(filter(() => this.quill.getLength() > this.maxLength))\n        .subscribe(() => {\n          this.quill.deleteText(this.maxLength, this.quill.getLength());\n      })\n  }\n\n  public setDisabledTools(tools: ToolKeys){\n    if(JSON.stringify(tools) !== JSON.stringify(this.stateSub.value.disabledTools))\n      this.stateSub.next({...this.stateSub.value, disabledTools: tools, })\n  }\n\n  public setEditorClass(className: string){\n    if(!className) return;\n    this.quill.root.classList.add(className);\n  }\n\n  public getEditorElement(){\n    return this.quill.root;\n  }\n\n  public disable(){\n    this.quill.disable();\n  }\n\n  public enable(){\n    this.quill.enable();\n  }\n\n  public focus(){\n    this.quill.focus();\n  }\n\n  public setBreakOnEnter(breakOnEnter: boolean){\n    this.breakOnEnter = breakOnEnter;\n  }\n\n  public destroy() {\n    this.quill.off('selection-change', this.selectionChangeHandler);\n    this.quill.off('text-change', this.textChangeHandler);\n    this.esc$.unsubscribe();\n    this.enter$.unsubscribe();\n    this.stateSub.unsubscribe();\n    this.maxLengthSubscription?.unsubscribe();\n  }\n\n  private isToolDisabled(tool: Tool){\n    return this.stateSub.value.disabledTools.includes(tool)\n  }\n\n  private urlMatcher(node: any, delta: any) {\n    if (typeof node.data !== 'string') return;\n    const matches = node.data.match(URL_REGEX);\n\n    if (matches && matches.length > 0) {\n      let text = '';\n      const selection = this.quill.getSelection(true);\n      if (selection.length)\n        text = this.quill.getText(selection!.index, selection!.length);\n\n      const ops = [];\n      let str = node.data;\n      matches.forEach(function (match: any) {\n        const split = str.split(match);\n        const beforeLink = split.shift();\n        ops.push({ insert: beforeLink });\n        ops.push({ insert: text || match, attributes: { link: match } });\n        str = split.join(match);\n      });\n      ops.push({ insert: str });\n      delta.ops = ops;\n    }\n\n    return delta;\n  }\n\n  private listenEditorChanges() {\n    this.quill.on('selection-change', this.selectionChangeHandler);\n    this.quill.on('text-change', this.textChangeHandler);\n  }\n\n\n  private update() {\n    let bounds: BoundsStatic | undefined;\n    let formatsArr;\n\n    const range = this.quill.getSelection(false);\n    if  (range){ \n      bounds = this.quill.getBounds(range.index, range.length);\n      formatsArr = this.quill.getFormat(range) as any;\n    }\n\n    const formats: RichtextFormats = {\n      italic: formatsArr?.italic || false,\n      bold: formatsArr?.bold || false,\n      underline: formatsArr?.underline || false,\n      strike: formatsArr?.strike || false,\n      link: formatsArr?.link || '',\n      list_bulleted: formatsArr?.list === 'bullet',\n      list_numbered: formatsArr?.list === 'ordered',\n      justify_left: formatsArr?.align === 'left',\n      justify_center: formatsArr?.align === 'center',\n      justify_right: formatsArr?.align === 'right',\n    };\n\n    const hasSelection = !!range?.length;\n    const hasFocus = !!range;\n\n    const newState: ToolsState = { \n      ...this.stateSub.value, \n      hasSelection, \n      formats, \n      bounds, \n      hasFocus \n    };\n\n    this.ngZone.run(() => {\n      this.stateSub.next(newState);\n      this.cd.markForCheck();\n    })\n  }\n}\n\n//to work around testing problems \nexport const QuillProxy ={\n  Quill\n}\n\n//to work around testing problems \nexport const RichtextWrapperProxy = {\n  RichtextWrapper\n}"]}
@@ -1,9 +1,8 @@
1
1
  import { ChangeDetectorRef, ElementRef, NgZone, Renderer2, ViewContainerRef, } from '@angular/core';
2
- import { RichtextWrapper } from './richtext-wrapper';
2
+ import { RichtextWrapperProxy } from './richtext-wrapper';
3
3
  import { ALL_TOOLS, TOOL_FUNCTION_MAP, TOOL_ICON_MAP } from '../constants/richtext-toolbox.constants';
4
- import { RichtextToolboxCoreComponent } from '../components/richtext-toolbox-core/richtext-toolbox-core.component';
4
+ import { RichtextToolboxComponent } from '../components/richtext-toolbox/richtext-toolbox.component';
5
5
  import { delay } from 'rxjs';
6
- import { QuillBuilderService } from '../services/quill-builder.service';
7
6
  export class Toolbox {
8
7
  get component() {
9
8
  return this.componentRef?.instance;
@@ -17,9 +16,8 @@ export class Toolbox {
17
16
  this.renderer2 = injector.get(Renderer2);
18
17
  this.ngZone = injector.get(NgZone);
19
18
  this.cd = injector.get(ChangeDetectorRef);
20
- const quillBuilder = injector.get(QuillBuilderService);
21
19
  this.parentEl = this.renderer2.parentNode(this.hostEl.nativeElement);
22
- this.richtextWrapper = new RichtextWrapper(this.ngZone, this.cd, quillBuilder, this.hostEl);
20
+ this.richtextWrapper = new RichtextWrapperProxy.RichtextWrapper(this.ngZone, this.cd, this.hostEl);
23
21
  this.listenRichtextState();
24
22
  }
25
23
  destroyAll() {
@@ -66,7 +64,6 @@ export class Toolbox {
66
64
  toolFunctionName: TOOL_FUNCTION_MAP[tool],
67
65
  selected: false,
68
66
  disabled: true,
69
- value: '',
70
67
  };
71
68
  });
72
69
  }
@@ -82,7 +79,7 @@ export class Toolbox {
82
79
  this.componentRef?.destroy();
83
80
  }
84
81
  displayComponent() {
85
- this.componentRef = this.viewContainerRef.createComponent(RichtextToolboxCoreComponent);
82
+ this.componentRef = this.viewContainerRef.createComponent(RichtextToolboxComponent);
86
83
  this.componentRef.setInput('toolbarItems', this.prepareUpdatedTools(this.richtextWrapper.state));
87
84
  this.componentRef.setInput('class', this.toolboxInput?.class);
88
85
  this.component.tool.subscribe((tool) => {
@@ -106,4 +103,4 @@ export class Toolbox {
106
103
  });
107
104
  }
108
105
  }
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbox.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/classes/toolbox.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentRef,\n  ElementRef,\n  Injector,\n  NgZone,\n  Renderer2,\n  ViewContainerRef,\n} from '@angular/core';\nimport { RichtextWrapper } from './richtext-wrapper';\nimport { ALL_TOOLS, TOOL_FUNCTION_MAP, TOOL_ICON_MAP } from '../constants/richtext-toolbox.constants';\nimport { Tool, ToolKeys, ToolbarItem, ToolboxInput, ToolsState } from '../interfaces/richtext-toolbox.interface';\nimport { RichtextToolboxCoreComponent } from '../components/richtext-toolbox-core/richtext-toolbox-core.component';\nimport { Subscription, delay } from 'rxjs';\nimport { QuillBuilderService } from '../services/quill-builder.service';\n\nexport abstract class Toolbox {\n  public readonly richtextWrapper: RichtextWrapper;\n\n  protected hostEl: ElementRef<HTMLElement>;\n  protected viewContainerRef: ViewContainerRef;\n  protected renderer2: Renderer2;\n  protected ngZone: NgZone;\n  protected cd: ChangeDetectorRef;\n\n  protected componentRef?: ComponentRef<RichtextToolboxCoreComponent>;\n\n  protected get component(){\n    return this.componentRef?.instance;\n  }\n\n  protected get componentEl(): HTMLElement | undefined{\n    return this.componentRef?.location.nativeElement;\n  }\n\n  private parentEl?: HTMLElement\n  private toolboxInput?: ToolboxInput\n  private _subscription?: Subscription;\n\n  constructor(injector: Injector) {\n    this.hostEl = injector.get(ElementRef<HTMLElement>);\n    this.viewContainerRef = injector.get(ViewContainerRef);\n    this.renderer2 = injector.get(Renderer2);\n    this.ngZone = injector.get(NgZone);\n    this.cd = injector.get(ChangeDetectorRef);\n    const quillBuilder = injector.get(QuillBuilderService);\n\n    this.parentEl = this.renderer2.parentNode(this.hostEl!.nativeElement);\n    this.richtextWrapper = new RichtextWrapper(this.ngZone,this.cd,quillBuilder,this.hostEl);\n    this.listenRichtextState();\n  }\n\n  public destroyAll() {\n    this._subscription?.unsubscribe();\n    this.richtextWrapper.destroy();\n    this.destroyComponent();\n  }\n\n  public toggleInputDisplay(display: boolean) {\n      if(display){\n        if(!this.isInputVisible())\n          this.renderer2.appendChild(this.parentEl, this.hostEl?.nativeElement);\n      }else {\n        if(this.isInputVisible())\n          this.renderer2.removeChild(this.parentEl, this.hostEl?.nativeElement);\n      }\n  };\n\n  public setToolInput(toolInput: ToolboxInput){\n    this.toolboxInput = toolInput;\n    if(this.component){\n      this.richtextWrapper.setDisabledTools(\n        this.getDisabledTools(\n          this.toolboxInput!.availableTools,\n          this.toolboxInput!.disabledTools\n        )\n      );\n      this.componentRef?.setInput('class', toolInput.class);\n    }\n  }\n\n  private isInputVisible(){\n    return this.parentEl?.contains(this.hostEl?.nativeElement)\n  }\n\n  private getDisabledTools(availableTools: ToolKeys, disabledTools: ToolKeys){\n    const unavailableTools = ALL_TOOLS.filter(tool => !availableTools.includes(tool));\n    return [...new Set([...unavailableTools, ...disabledTools])];\n  }\n\n  private listenRichtextState() {\n    this._subscription = this.richtextWrapper.state$\n      .pipe(delay(1))\n      .subscribe((value) => {this.onToolsChanged(value)});\n  }\n\n  private getDefaultTools(): ToolbarItem[]{\n    return [...(this.toolboxInput?.availableTools || []), 'clear' as Tool]\n    .map((tool: Tool) => {\n      return {\n        tool,\n        icon: TOOL_ICON_MAP[tool],\n        toolFunctionName: TOOL_FUNCTION_MAP[tool],\n        selected: false,\n        disabled: true,\n        value: '',\n      };\n    })\n  }\n\n  protected onToolsChanged(toolsState: ToolsState){\n    if(!this.componentRef) return;\n    this.componentRef.setInput('toolbarItems', this.prepareUpdatedTools(toolsState));\n  }\n\n  protected isVisible() {\n    return this.hostEl.nativeElement.contains(this.componentEl!);\n  }\n\n  protected destroyComponent() {\n    this.componentRef?.destroy();\n  }\n\n  protected displayComponent(): void {\n    this.componentRef = this.viewContainerRef.createComponent(RichtextToolboxCoreComponent);\n    this.componentRef.setInput('toolbarItems', this.prepareUpdatedTools(this.richtextWrapper.state));\n    this.componentRef.setInput('class', this.toolboxInput?.class);\n    this.component!.tool.subscribe((tool: ToolbarItem) => {\n      this.richtextWrapper[tool.toolFunctionName](tool?.value as any)\n    })\n  }\n\n  protected prepareUpdatedTools(toolState: ToolsState): ToolbarItem[]{\n    let tools = this.getDefaultTools()\n    const {formats, disabledTools} = toolState;\n\n    return  tools.map((tool) => {\n      if(tool.tool === 'clear'){\n        tool.disabled = false;\n      } else {\n        tool.selected = !!formats[tool.tool];\n        tool.disabled = disabledTools.includes(tool.tool);\n        if(tool.tool === 'link')\n          tool.value = formats[tool.tool];\n      }\n\n      return tool;\n    });\n  }\n}"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbox.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/lib/classes/toolbox.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EAEjB,UAAU,EAEV,MAAM,EACN,SAAS,EACT,gBAAgB,GACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC3E,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,yCAAyC,CAAC;AAEtG,OAAO,EAAE,wBAAwB,EAAE,MAAM,2DAA2D,CAAC;AACrG,OAAO,EAAgB,KAAK,EAAE,MAAM,MAAM,CAAC;AAE3C,MAAM,OAAgB,OAAO;IAW3B,IAAc,SAAS;QACrB,OAAO,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC;IACrC,CAAC;IAED,IAAc,WAAW;QACvB,OAAO,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,aAAa,CAAC;IACnD,CAAC;IAMD,YAAY,QAAkB;QAC5B,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAA,UAAuB,CAAA,CAAC,CAAC;QACpD,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QACvD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACnC,IAAI,CAAC,EAAE,GAAG,QAAQ,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QAE1C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,MAAO,CAAC,aAAa,CAAC,CAAC;QACtE,IAAI,CAAC,eAAe,GAAG,IAAI,oBAAoB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAC,IAAI,CAAC,EAAE,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjG,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,aAAa,EAAE,WAAW,EAAE,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;QAC/B,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAEM,kBAAkB,CAAC,OAAgB;QACtC,IAAG,OAAO,EAAC;YACT,IAAG,CAAC,IAAI,CAAC,cAAc,EAAE;gBACvB,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;SACzE;aAAK;YACJ,IAAG,IAAI,CAAC,cAAc,EAAE;gBACtB,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;SACzE;IACL,CAAC;IAAA,CAAC;IAEK,YAAY,CAAC,SAAuB;QACzC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAC9B,IAAG,IAAI,CAAC,SAAS,EAAC;YAChB,IAAI,CAAC,eAAe,CAAC,gBAAgB,CACnC,IAAI,CAAC,gBAAgB,CACnB,IAAI,CAAC,YAAa,CAAC,cAAc,EACjC,IAAI,CAAC,YAAa,CAAC,aAAa,CACjC,CACF,CAAC;YACF,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC,OAAO,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;SACvD;IACH,CAAC;IAEO,cAAc;QACpB,OAAO,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC5D,CAAC;IAEO,gBAAgB,CAAC,cAAwB,EAAE,aAAuB;QACxE,MAAM,gBAAgB,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;QAClF,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,gBAAgB,EAAE,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;IAC/D,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM;aAC7C,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;aACd,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,GAAE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA,CAAA,CAAC,CAAC,CAAC;IACxD,CAAC;IAEO,eAAe;QACrB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,cAAc,IAAI,EAAE,CAAC,EAAE,OAAe,CAAC;aACrE,GAAG,CAAC,CAAC,IAAU,EAAE,EAAE;YAClB,OAAO;gBACL,IAAI;gBACJ,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC;gBACzB,gBAAgB,EAAE,iBAAiB,CAAC,IAAI,CAAC;gBACzC,QAAQ,EAAE,KAAK;gBACf,QAAQ,EAAE,IAAI;aACf,CAAC;QACJ,CAAC,CAAC,CAAA;IACJ,CAAC;IAES,cAAc,CAAC,UAAsB;QAC7C,IAAG,CAAC,IAAI,CAAC,YAAY;YAAE,OAAO;QAC9B,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,cAAc,EAAE,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC,CAAC;IACnF,CAAC;IAES,SAAS;QACjB,OAAO,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAY,CAAC,CAAC;IAC/D,CAAC;IAES,gBAAgB;QACxB,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,CAAC;IAC/B,CAAC;IAES,gBAAgB;QACxB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,wBAAwB,CAAC,CAAC;QACpF,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,cAAc,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;QACjG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;QAC9D,IAAI,CAAC,SAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAiB,EAAE,EAAE;YACnD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,EAAE,KAAY,CAAC,CAAA;QACjE,CAAC,CAAC,CAAA;IACJ,CAAC;IAES,mBAAmB,CAAC,SAAqB;QACjD,IAAI,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,CAAA;QAClC,MAAM,EAAC,OAAO,EAAE,aAAa,EAAC,GAAG,SAAS,CAAC;QAE3C,OAAQ,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACzB,IAAG,IAAI,CAAC,IAAI,KAAK,OAAO,EAAC;gBACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACvB;iBAAM;gBACL,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACrC,IAAI,CAAC,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClD,IAAG,IAAI,CAAC,IAAI,KAAK,MAAM;oBACrB,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACnC;YAED,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC;CACF","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentRef,\n  ElementRef,\n  Injector,\n  NgZone,\n  Renderer2,\n  ViewContainerRef,\n} from '@angular/core';\nimport { RichtextWrapper, RichtextWrapperProxy } from './richtext-wrapper';\nimport { ALL_TOOLS, TOOL_FUNCTION_MAP, TOOL_ICON_MAP } from '../constants/richtext-toolbox.constants';\nimport { Tool, ToolKeys, ToolbarItem, ToolboxInput, ToolsState } from '../interfaces/richtext-toolbox.interface';\nimport { RichtextToolboxComponent } from '../components/richtext-toolbox/richtext-toolbox.component';\nimport { Subscription, delay } from 'rxjs';\n\nexport abstract class Toolbox {\n  public readonly richtextWrapper: RichtextWrapper;\n\n  protected hostEl: ElementRef<HTMLElement>;\n  protected viewContainerRef: ViewContainerRef;\n  protected renderer2: Renderer2;\n  protected ngZone: NgZone;\n  protected cd: ChangeDetectorRef;\n\n  protected componentRef?: ComponentRef<RichtextToolboxComponent>;\n\n  protected get component(){\n    return this.componentRef?.instance;\n  }\n\n  protected get componentEl(): HTMLElement | undefined{\n    return this.componentRef?.location.nativeElement;\n  }\n\n  private parentEl?: HTMLElement\n  private toolboxInput?: ToolboxInput\n  private _subscription?: Subscription;\n\n  constructor(injector: Injector) {\n    this.hostEl = injector.get(ElementRef<HTMLElement>);\n    this.viewContainerRef = injector.get(ViewContainerRef);\n    this.renderer2 = injector.get(Renderer2);\n    this.ngZone = injector.get(NgZone);\n    this.cd = injector.get(ChangeDetectorRef);\n\n    this.parentEl = this.renderer2.parentNode(this.hostEl!.nativeElement);\n    this.richtextWrapper = new RichtextWrapperProxy.RichtextWrapper(this.ngZone,this.cd,this.hostEl);\n    this.listenRichtextState();\n  }\n\n  public destroyAll() {\n    this._subscription?.unsubscribe();\n    this.richtextWrapper.destroy();\n    this.destroyComponent();\n  }\n\n  public toggleInputDisplay(display: boolean) {\n      if(display){\n        if(!this.isInputVisible())\n          this.renderer2.appendChild(this.parentEl, this.hostEl?.nativeElement);\n      }else {\n        if(this.isInputVisible())\n          this.renderer2.removeChild(this.parentEl, this.hostEl?.nativeElement);\n      }\n  };\n\n  public setToolInput(toolInput: ToolboxInput){\n    this.toolboxInput = toolInput;\n    if(this.component){\n      this.richtextWrapper.setDisabledTools(\n        this.getDisabledTools(\n          this.toolboxInput!.availableTools,\n          this.toolboxInput!.disabledTools\n        )\n      );\n      this.componentRef?.setInput('class', toolInput.class);\n    }\n  }\n\n  private isInputVisible(){\n    return this.parentEl?.contains(this.hostEl?.nativeElement)\n  }\n\n  private getDisabledTools(availableTools: ToolKeys, disabledTools: ToolKeys){\n    const unavailableTools = ALL_TOOLS.filter(tool => !availableTools.includes(tool));\n    return [...new Set([...unavailableTools, ...disabledTools])];\n  }\n\n  private listenRichtextState() {\n    this._subscription = this.richtextWrapper.state$\n      .pipe(delay(1))\n      .subscribe((value) => {this.onToolsChanged(value)});\n  }\n\n  private getDefaultTools(): ToolbarItem[]{\n    return [...(this.toolboxInput?.availableTools || []), 'clear' as Tool]\n    .map((tool: Tool) => {\n      return {\n        tool,\n        icon: TOOL_ICON_MAP[tool],\n        toolFunctionName: TOOL_FUNCTION_MAP[tool],\n        selected: false,\n        disabled: true,\n      };\n    })\n  }\n\n  protected onToolsChanged(toolsState: ToolsState){\n    if(!this.componentRef) return;\n    this.componentRef.setInput('toolbarItems', this.prepareUpdatedTools(toolsState));\n  }\n\n  protected isVisible() {\n    return this.hostEl.nativeElement.contains(this.componentEl!);\n  }\n\n  protected destroyComponent() {\n    this.componentRef?.destroy();\n  }\n\n  protected displayComponent(): void {\n    this.componentRef = this.viewContainerRef.createComponent(RichtextToolboxComponent);\n    this.componentRef.setInput('toolbarItems', this.prepareUpdatedTools(this.richtextWrapper.state));\n    this.componentRef.setInput('class', this.toolboxInput?.class);\n    this.component!.tool.subscribe((tool: ToolbarItem) => {\n      this.richtextWrapper[tool.toolFunctionName](tool?.value as any)\n    })\n  }\n\n  protected prepareUpdatedTools(toolState: ToolsState): ToolbarItem[]{\n    let tools = this.getDefaultTools()\n    const {formats, disabledTools} = toolState;\n\n    return  tools.map((tool) => {\n      if(tool.tool === 'clear'){\n        tool.disabled = false;\n      } else {\n        tool.selected = !!formats[tool.tool];\n        tool.disabled = disabledTools.includes(tool.tool);\n        if(tool.tool === 'link')\n          tool.value = formats[tool.tool];\n      }\n\n      return tool;\n    });\n  }\n}"]}
@@ -0,0 +1,37 @@
1
+ import { Toolbox } from "./toolbox";
2
+ class TopbarToolbox extends Toolbox {
3
+ constructor(injector) {
4
+ super(injector);
5
+ this.displayComponent();
6
+ }
7
+ displayComponent() {
8
+ super.displayComponent();
9
+ const parentElement = this.renderer2.parentNode(this.hostEl?.nativeElement);
10
+ this.renderer2.appendChild(parentElement, this.componentEl);
11
+ this.renderer2.appendChild(parentElement, this.hostEl?.nativeElement);
12
+ this.componentRef.setInput('type', 'topbar');
13
+ }
14
+ prepareUpdatedTools(toolState) {
15
+ const toolbarItems = super.prepareUpdatedTools(toolState);
16
+ const { formats, hasSelection, hasFocus } = toolState;
17
+ toolbarItems.forEach(tool => {
18
+ if (!hasFocus) {
19
+ tool.disabled = true;
20
+ return;
21
+ }
22
+ if (tool.tool === 'clear') {
23
+ tool.disabled = !hasSelection;
24
+ }
25
+ else if (tool.tool === 'link') {
26
+ tool.selected = !!formats.link;
27
+ tool.disabled = !hasSelection && !formats.link;
28
+ tool.value = formats?.link;
29
+ }
30
+ });
31
+ return toolbarItems;
32
+ }
33
+ }
34
+ export const TopbarToolboxProxy = {
35
+ TopbarToolbox
36
+ };
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9wYmFyLXRvb2xib3guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9jbGFzc2VzL3RvcGJhci10b29sYm94LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFHcEMsTUFBTSxhQUFjLFNBQVEsT0FBTztJQUUvQixZQUFZLFFBQWtCO1FBQzVCLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNoQixJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBR1EsZ0JBQWdCO1FBQ3ZCLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3pCLE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFDLENBQUM7UUFDNUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsYUFBYSxFQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzRCxJQUFJLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLE1BQU0sRUFBRSxhQUFhLENBQUMsQ0FBQztRQUN0RSxJQUFJLENBQUMsWUFBYSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUMsUUFBUSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVRLG1CQUFtQixDQUFDLFNBQXFCO1FBQ2hELE1BQU0sWUFBWSxHQUFHLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUMxRCxNQUFNLEVBQUUsT0FBTyxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsR0FBRyxTQUFTLENBQUM7UUFFdEQsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUMxQixJQUFHLENBQUMsUUFBUSxFQUFFO2dCQUNaLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFBO2dCQUNwQixPQUFPO2FBQ1I7WUFFRCxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFFO2dCQUN6QixJQUFJLENBQUMsUUFBUSxHQUFHLENBQUMsWUFBWSxDQUFDO2FBQy9CO2lCQUFNLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxNQUFNLEVBQUU7Z0JBQy9CLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7Z0JBQy9CLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxZQUFZLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO2dCQUMvQyxJQUFJLENBQUMsS0FBSyxHQUFHLE9BQU8sRUFBRSxJQUFJLENBQUM7YUFDNUI7UUFDSCxDQUFDLENBQUMsQ0FBQTtRQUNKLE9BQU8sWUFBWSxDQUFBO0lBQ25CLENBQUM7Q0FDRjtBQUdELE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHO0lBQ2hDLGFBQWE7Q0FDZCxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0b3IgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgVG9vbGJveCB9IGZyb20gXCIuL3Rvb2xib3hcIjtcbmltcG9ydCB7IFRvb2xiYXJJdGVtLCBUb29sc1N0YXRlIH0gZnJvbSBcIi4uL2ludGVyZmFjZXMvcmljaHRleHQtdG9vbGJveC5pbnRlcmZhY2VcIjtcblxuY2xhc3MgVG9wYmFyVG9vbGJveCBleHRlbmRzIFRvb2xib3gge1xuXG4gICAgY29uc3RydWN0b3IoaW5qZWN0b3I6IEluamVjdG9yKSB7XG4gICAgICBzdXBlcihpbmplY3Rvcik7XG4gICAgICB0aGlzLmRpc3BsYXlDb21wb25lbnQoKTtcbiAgICB9XG4gIFxuICBcbiAgICBvdmVycmlkZSBkaXNwbGF5Q29tcG9uZW50KCk6IHZvaWQge1xuICAgICAgc3VwZXIuZGlzcGxheUNvbXBvbmVudCgpO1xuICAgICAgY29uc3QgcGFyZW50RWxlbWVudCA9IHRoaXMucmVuZGVyZXIyLnBhcmVudE5vZGUodGhpcy5ob3N0RWw/Lm5hdGl2ZUVsZW1lbnQpO1xuICAgICAgdGhpcy5yZW5kZXJlcjIuYXBwZW5kQ2hpbGQocGFyZW50RWxlbWVudCx0aGlzLmNvbXBvbmVudEVsKTtcbiAgICAgIHRoaXMucmVuZGVyZXIyLmFwcGVuZENoaWxkKHBhcmVudEVsZW1lbnQsIHRoaXMuaG9zdEVsPy5uYXRpdmVFbGVtZW50KTtcbiAgICAgIHRoaXMuY29tcG9uZW50UmVmIS5zZXRJbnB1dCgndHlwZScsJ3RvcGJhcicpO1xuICAgIH1cblxuICAgIG92ZXJyaWRlIHByZXBhcmVVcGRhdGVkVG9vbHModG9vbFN0YXRlOiBUb29sc1N0YXRlKTogVG9vbGJhckl0ZW1bXXtcbiAgICAgIGNvbnN0IHRvb2xiYXJJdGVtcyA9IHN1cGVyLnByZXBhcmVVcGRhdGVkVG9vbHModG9vbFN0YXRlKTtcbiAgICAgIGNvbnN0IHsgZm9ybWF0cywgaGFzU2VsZWN0aW9uLCBoYXNGb2N1cyB9ID0gdG9vbFN0YXRlO1xuXG4gICAgICB0b29sYmFySXRlbXMuZm9yRWFjaCh0b29sID0+IHtcbiAgICAgICAgaWYoIWhhc0ZvY3VzKSB7XG4gICAgICAgICAgdG9vbC5kaXNhYmxlZCA9IHRydWVcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBpZiAodG9vbC50b29sID09PSAnY2xlYXInKSB7XG4gICAgICAgICAgdG9vbC5kaXNhYmxlZCA9ICFoYXNTZWxlY3Rpb247XG4gICAgICAgIH0gZWxzZSBpZiAodG9vbC50b29sID09PSAnbGluaycpIHtcbiAgICAgICAgICB0b29sLnNlbGVjdGVkID0gISFmb3JtYXRzLmxpbms7XG4gICAgICAgICAgdG9vbC5kaXNhYmxlZCA9ICFoYXNTZWxlY3Rpb24gJiYgIWZvcm1hdHMubGluaztcbiAgICAgICAgICB0b29sLnZhbHVlID0gZm9ybWF0cz8ubGluaztcbiAgICAgICAgfVxuICAgICAgfSlcbiAgICByZXR1cm4gdG9vbGJhckl0ZW1zXG4gICAgfVxuICB9XG4gIFxuXG4gIGV4cG9ydCBjb25zdCBUb3BiYXJUb29sYm94UHJveHkgPSB7XG4gICAgVG9wYmFyVG9vbGJveFxuICB9Il19