asksuite-citrus 1.11.1 → 1.11.3
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/asksuite-citrus.module.mjs +4 -4
- package/esm2022/lib/classes/bubble-toolbox.mjs +49 -0
- package/esm2022/lib/classes/richtext-wrapper.mjs +13 -6
- package/esm2022/lib/classes/toolbox.mjs +5 -8
- package/esm2022/lib/classes/topbar-toolbox.mjs +37 -0
- package/esm2022/lib/components/richtext-toolbox/richtext-toolbox.component.mjs +82 -0
- package/esm2022/lib/components/richtext-url-prompt/richtext-url-prompt.component.mjs +3 -3
- package/esm2022/lib/constants/url-regex.constant.mjs +2 -2
- package/esm2022/lib/directives/richtext-toolbox/richtext-toolbox.directive.mjs +12 -8
- package/fesm2022/asksuite-citrus.mjs +43 -44
- package/fesm2022/asksuite-citrus.mjs.map +1 -1
- package/lib/asksuite-citrus.module.d.ts +2 -2
- package/lib/classes/{toolbox-bubble.d.ts → bubble-toolbox.d.ts} +6 -2
- package/lib/classes/richtext-wrapper.d.ts +8 -3
- package/lib/classes/toolbox.d.ts +3 -3
- package/lib/classes/{toolbox-topbar.d.ts → topbar-toolbox.d.ts} +5 -1
- package/lib/components/{richtext-toolbox-core/richtext-toolbox-core.component.d.ts → richtext-toolbox/richtext-toolbox.component.d.ts} +5 -5
- package/lib/directives/richtext-toolbox/richtext-toolbox.directive.d.ts +1 -0
- package/package.json +1 -1
- package/esm2022/lib/classes/toolbox-bubble.mjs +0 -46
- package/esm2022/lib/classes/toolbox-topbar.mjs +0 -34
- package/esm2022/lib/components/richtext-toolbox-core/richtext-toolbox-core.component.mjs +0 -82
- package/esm2022/lib/services/quill-builder.service.mjs +0 -18
- package/lib/services/quill-builder.service.d.ts +0 -8
@@ -28,7 +28,7 @@ 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 {
|
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";
|
@@ -82,7 +82,7 @@ export class AsksuiteCitrusModule {
|
|
82
82
|
PaginatePipe,
|
83
83
|
RichtextToolboxDirective,
|
84
84
|
RichtextUrlPromptComponent,
|
85
|
-
|
85
|
+
RichtextToolboxComponent,
|
86
86
|
AskTextButtonDirective,
|
87
87
|
ForceBreakLinePipe], imports: [CommonModule,
|
88
88
|
FormsModule,
|
@@ -172,7 +172,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
172
172
|
PaginatePipe,
|
173
173
|
RichtextToolboxDirective,
|
174
174
|
RichtextUrlPromptComponent,
|
175
|
-
|
175
|
+
RichtextToolboxComponent,
|
176
176
|
AskTextButtonDirective,
|
177
177
|
ForceBreakLinePipe
|
178
178
|
],
|
@@ -228,4 +228,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
228
228
|
]
|
229
229
|
}]
|
230
230
|
}] });
|
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"]}
|
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 { 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\";\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  ],\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"]}
|
@@ -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,
|
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: {
|
@@ -243,7 +242,7 @@ export class RichtextWrapper {
|
|
243
242
|
text = this.quill.getText(selection.index, selection.length);
|
244
243
|
const ops = [];
|
245
244
|
let str = node.data;
|
246
|
-
|
245
|
+
matches.forEach(function (match) {
|
247
246
|
const split = str.split(match);
|
248
247
|
const beforeLink = split.shift();
|
249
248
|
ops.push({ insert: beforeLink });
|
@@ -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[1]].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 {
|
2
|
+
import { RichtextWrapperProxy } from './richtext-wrapper';
|
3
3
|
import { ALL_TOOLS, TOOL_FUNCTION_MAP, TOOL_ICON_MAP } from '../constants/richtext-toolbox.constants';
|
4
|
-
import {
|
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,
|
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(
|
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":"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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, 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
|
@@ -0,0 +1,82 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, Output, ViewChildren, } from '@angular/core';
|
2
|
+
import { AskDropdownDirective } from '../../directives';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@angular/common";
|
5
|
+
import * as i2 from "../../directives/ask-dropdown.directive";
|
6
|
+
import * as i3 from "../richtext-url-prompt/richtext-url-prompt.component";
|
7
|
+
export class RichtextToolboxComponent {
|
8
|
+
constructor() {
|
9
|
+
this.close = new EventEmitter();
|
10
|
+
this.tool = new EventEmitter();
|
11
|
+
this.type = 'topbar';
|
12
|
+
this.class = '';
|
13
|
+
this._toolbarItems = [];
|
14
|
+
this.urlIdx = -1;
|
15
|
+
this.isUrlMode = false;
|
16
|
+
}
|
17
|
+
get toolbarItems() {
|
18
|
+
return this._toolbarItems;
|
19
|
+
}
|
20
|
+
set toolbarItems(value) {
|
21
|
+
this._toolbarItems = value;
|
22
|
+
this.urlIdx = value.findIndex((item) => item.tool === 'link');
|
23
|
+
}
|
24
|
+
get linkTool() {
|
25
|
+
return this.toolbarItems[this.urlIdx];
|
26
|
+
}
|
27
|
+
get urlDropdownRef() {
|
28
|
+
return this.dropdowns?.get(this.urlIdx);
|
29
|
+
}
|
30
|
+
ngOnChanges(sp) {
|
31
|
+
if (sp['type'] && !this.class) {
|
32
|
+
this.class = this.type === 'bubble' ? 'bubble-toolbox' : 'top-toolbox';
|
33
|
+
}
|
34
|
+
}
|
35
|
+
onTool(toolbarItem) {
|
36
|
+
if (toolbarItem.disabled)
|
37
|
+
return;
|
38
|
+
if (toolbarItem.tool === 'link') {
|
39
|
+
if (this.type === 'bubble')
|
40
|
+
this.isUrlMode = true;
|
41
|
+
}
|
42
|
+
else {
|
43
|
+
this.tool.emit(toolbarItem);
|
44
|
+
}
|
45
|
+
}
|
46
|
+
onUrl(link) {
|
47
|
+
this.tool.emit({ ...this.linkTool, value: link });
|
48
|
+
this.closeUrlInput();
|
49
|
+
}
|
50
|
+
trackByToolFn(index, item) {
|
51
|
+
return item.tool;
|
52
|
+
}
|
53
|
+
closeUrlInput() {
|
54
|
+
if (this.isUrlMode)
|
55
|
+
this.isUrlMode = false;
|
56
|
+
else
|
57
|
+
this.urlDropdownRef.close();
|
58
|
+
}
|
59
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: RichtextToolboxComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
60
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: RichtextToolboxComponent, selector: "ask-richtext-toolbox", inputs: { toolbarItems: "toolbarItems", type: "type", class: "class" }, outputs: { close: "close", tool: "tool" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "dropdowns", predicate: AskDropdownDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"!isUrlMode; else urlTemplate\">\n <button\n class=\"button\"\n *ngFor=\"let tool of toolbarItems; trackBy: trackByToolFn\"\n [disabled]=\"tool.disabled\"\n (click)=\"onTool(tool)\"\n [askDropdown]=\"tool.tool === 'link' && type === 'topbar' ? urlTemplate : undefined\"\n positions=\"BOTTOM_LEFT\"\n [attr.data-testid]=\"'button-'+tool.tool\"\n >\n <span\n class=\"material-icons icon\"\n [ngClass]=\"{\n '-selected': tool.selected,\n '-disabled': tool.disabled,\n '-bubble': type === 'bubble',\n }\"\n >\n {{ tool.icon }}\n </span>\n </button>\n</ng-container>\n\n<ng-template #urlTemplate>\n <ask-richtext-url-prompt\n data-testid=\"url-prompt\"\n [url]=\"linkTool?.value || ''\"\n (url)=\"onUrl($event)\"\n (keydown.escape)=\"closeUrlInput()\"\n />\n</ng-template>\n", styles: ["@import\"https://cdn.quilljs.com/1.0.0/quill.core.css\";:root{--asksuite-orange: #FF5724;--white: #FFF;--grey-50: #F5F7FA;--grey-100: #E4E7EB;--grey-200: #CBD2D9;--grey-300: #9AA5B1;--grey-400: #7B8794;--grey-500: #616E7C;--grey-600: #52606D;--grey-700: #3E4C59;--grey-800: #2A3042;--grey-900: #1F2933;--yellow-50: #FFF8E2;--yellow-200: #FFECB3;--success-green: #4BAF50;--warning-yellow: #FFC107;--error-red: #E8453E;--shadow: rgba(42, 48, 66, .1607843137);--lightblue-tag: #CDF9F3;--lavender-tag: #D4DAF3;--green-tag: #CEEEAA;--pink-tag: #FBC5FF;--orange-tag: #FED5C9;--purple-tag: #DDBFE5;--yellow-tag: #FFE0B2;--blue-tag: #B2E5FD;--brown-tag: #EFC89C;--whatsapp-green: #68B35D;--facebook-blue: #0084FF;--instagram-pink: #D53E91;--google-blue: #345DC8;--telegram-blue: #34AADF;--telephone-yellow: #FECB00;--primary-background: #FFF;--secondary-background: #EFF3F8;--hover-background: #F5F7FA;--divider-background: #E4E7EB;--font-color-100: #2A3042;--font-color-200: #616E7C;--font-color-300: #9AA5B1}:root{--font-default: $font-default;--font-code: $font-code}:root{--font-xs: $font-xs;--font-sm: $font-sm;--font-md: $font-md;--font-lg: $font-lg;--font-xl: $font-xl;--font-xxl: $font-xxl}:root{--font-weight-regular: $font-weight-regular;--font-weight-medium: $font-weight-medium}:root{--radii-px: $radii-px;--radii-xs: $radii-xs;--radii-sm: $radii-sm;--radii-md: $radii-md;--radii-lg: $radii-lg;--radii-full: $radii-full}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scale-in-center{animation:scale-in-center .3s ease-in-out both}@keyframes scale-in-center{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:1}}.scale-out-center{animation:scale-out-center .3s ease-in-out both}@keyframes scale-out-center{0%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:1}}.ask-tooltip{background-color:#7b8794;color:#fff;padding:4px;border-radius:8px;position:relative}.ask-tooltip>div{text-align:center!important}.ask-tooltip:after{position:absolute;content:\"\";width:10px;height:10px;background-color:inherit}.ask-tooltip.-above{margin-bottom:4px}.ask-tooltip.-above:after{bottom:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-below{margin-top:4px}.ask-tooltip.-below:after{top:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-after,.ask-tooltip.-right{margin-left:4px}.ask-tooltip.-after:after,.ask-tooltip.-right:after{left:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-tooltip.-before,.ask-tooltip.-left{margin-right:4px}.ask-tooltip.-before:after,.ask-tooltip.-left:after{right:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-button{padding:8px 24px;border-radius:6px;border:none;outline:none;height:48px;font-size:1rem;transition:background-color .1s,box-shadow .1s;cursor:pointer;font-weight:500;background:white;color:var(--grey-500)}.ask-button:not(.-primary,.-secondary){box-shadow:0 1px 2px #2a304229}.ask-button:not(.-primary):hover:not(:disabled){box-shadow:0 0 6px #2a304229}.ask-button:hover:not(:disabled){box-shadow:0 0 6px #ff572466}.ask-button:active:not(:disabled){background-color:#f34915}.ask-button:disabled{cursor:not-allowed;background-color:#9aa5b1}.ask-button.-primary{background:#FF5724;color:#fff}.ask-text-button{padding:8px 16px;border:none;border-radius:4px;outline:none;background:none;color:var(--asksuite-orange);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3ms}.ask-text-button:hover{text-decoration:none;background:#F5F7FA}.ask-text-button:disabled{cursor:not-allowed;color:#9aa5b1}.ask-text-button.-primary{color:var(--asksuite-orange)}.ask-text-button.-secondary{color:#616e7c}.ask-modal-header{display:block;position:relative;flex-shrink:0;box-sizing:border-box;margin:0 0 1px;padding:0 24px 9px}.ask-modal-body{flex-grow:1;box-sizing:border-box;margin:0;overflow:auto;padding:20px 24px;max-height:65vh;display:block}.ask-modal-footer{display:flex;position:relative;flex-shrink:0;flex-wrap:wrap;align-items:center;justify-content:flex-end;box-sizing:border-box;min-height:52px;margin:0;padding:8px;border-top:1px solid rgba(0,0,0,0)}.ql-editor{padding:14px 16px;font-size:.875rem;word-break:break-word}.bubble-toolbox{position:absolute;background-color:var(--grey-800);border-radius:8px;z-index:999}.top-toolbox{background-color:var(--grey-100)}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:\"liga\";-webkit-font-smoothing:antialiased}*{box-sizing:border-box}*,button,select,textarea{font-family:Inter,sans-serif;font-weight:400}input{font-size:1rem}.ask-badge{position:relative}.ask-badge>.badge{position:absolute;display:flex;justify-content:center;align-items:center;background-color:var(--bg-color);color:#fff;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;border-radius:50%;box-shadow:0 2px 6px -1px #00000080}.ask-badge>.badge.-primary{--bg-color: var(--asksuite-orange)}.ask-badge>.badge.-secondary{--bg-color: var(--grey-800)}.ask-badge>.badge.-top{top:-10px}.ask-badge>.badge.-bottom{bottom:-10px}.ask-badge>.badge.-left{left:-10px}.ask-badge>.badge.-right{right:-10px}.ask-badge>.badge.-small{width:18px;height:18px;font-size:10px}.ask-badge>.badge.-regular{width:22px;height:22px;font-size:11px}.ask-badge>.badge.-large{width:28px;height:28px;font-size:12px}.ask-dropdown-top-right{margin-left:8px}.ask-dropdown-top-left{margin-right:8px}.ask-dropdown-bottom-right,.ask-dropdown-bottom-left{margin-top:8px}.ask-tooltip{white-space:break-spaces}:host{display:flex}.button{background:none;color:inherit;border:none;margin:0;font:inherit;cursor:pointer;outline:inherit;line-height:0;color:#7b8794;padding:8px}.icon.-bubble{color:var(--white)}.icon.-disabled{color:var(--grey-200)}.icon.-selected{color:#ff5724}.icon.-bubble.-disabled{color:var(--grey-600)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.AskDropdownDirective, selector: "[askDropdown]", inputs: ["askDropdown", "dropdownName", "positions", "dropdownDisabled", "dropdownOpenOnHover", "mouseThreshold"], outputs: ["askDropdownOnClose"] }, { kind: "component", type: i3.RichtextUrlPromptComponent, selector: "ask-richtext-url-prompt", inputs: ["url"], outputs: ["url"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
61
|
+
}
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: RichtextToolboxComponent, decorators: [{
|
63
|
+
type: Component,
|
64
|
+
args: [{ selector: 'ask-richtext-toolbox', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"!isUrlMode; else urlTemplate\">\n <button\n class=\"button\"\n *ngFor=\"let tool of toolbarItems; trackBy: trackByToolFn\"\n [disabled]=\"tool.disabled\"\n (click)=\"onTool(tool)\"\n [askDropdown]=\"tool.tool === 'link' && type === 'topbar' ? urlTemplate : undefined\"\n positions=\"BOTTOM_LEFT\"\n [attr.data-testid]=\"'button-'+tool.tool\"\n >\n <span\n class=\"material-icons icon\"\n [ngClass]=\"{\n '-selected': tool.selected,\n '-disabled': tool.disabled,\n '-bubble': type === 'bubble',\n }\"\n >\n {{ tool.icon }}\n </span>\n </button>\n</ng-container>\n\n<ng-template #urlTemplate>\n <ask-richtext-url-prompt\n data-testid=\"url-prompt\"\n [url]=\"linkTool?.value || ''\"\n (url)=\"onUrl($event)\"\n (keydown.escape)=\"closeUrlInput()\"\n />\n</ng-template>\n", styles: ["@import\"https://cdn.quilljs.com/1.0.0/quill.core.css\";:root{--asksuite-orange: #FF5724;--white: #FFF;--grey-50: #F5F7FA;--grey-100: #E4E7EB;--grey-200: #CBD2D9;--grey-300: #9AA5B1;--grey-400: #7B8794;--grey-500: #616E7C;--grey-600: #52606D;--grey-700: #3E4C59;--grey-800: #2A3042;--grey-900: #1F2933;--yellow-50: #FFF8E2;--yellow-200: #FFECB3;--success-green: #4BAF50;--warning-yellow: #FFC107;--error-red: #E8453E;--shadow: rgba(42, 48, 66, .1607843137);--lightblue-tag: #CDF9F3;--lavender-tag: #D4DAF3;--green-tag: #CEEEAA;--pink-tag: #FBC5FF;--orange-tag: #FED5C9;--purple-tag: #DDBFE5;--yellow-tag: #FFE0B2;--blue-tag: #B2E5FD;--brown-tag: #EFC89C;--whatsapp-green: #68B35D;--facebook-blue: #0084FF;--instagram-pink: #D53E91;--google-blue: #345DC8;--telegram-blue: #34AADF;--telephone-yellow: #FECB00;--primary-background: #FFF;--secondary-background: #EFF3F8;--hover-background: #F5F7FA;--divider-background: #E4E7EB;--font-color-100: #2A3042;--font-color-200: #616E7C;--font-color-300: #9AA5B1}:root{--font-default: $font-default;--font-code: $font-code}:root{--font-xs: $font-xs;--font-sm: $font-sm;--font-md: $font-md;--font-lg: $font-lg;--font-xl: $font-xl;--font-xxl: $font-xxl}:root{--font-weight-regular: $font-weight-regular;--font-weight-medium: $font-weight-medium}:root{--radii-px: $radii-px;--radii-xs: $radii-xs;--radii-sm: $radii-sm;--radii-md: $radii-md;--radii-lg: $radii-lg;--radii-full: $radii-full}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scale-in-center{animation:scale-in-center .3s ease-in-out both}@keyframes scale-in-center{0%{transform:scale(0);opacity:1}to{transform:scale(1);opacity:1}}.scale-out-center{animation:scale-out-center .3s ease-in-out both}@keyframes scale-out-center{0%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:1}}.ask-tooltip{background-color:#7b8794;color:#fff;padding:4px;border-radius:8px;position:relative}.ask-tooltip>div{text-align:center!important}.ask-tooltip:after{position:absolute;content:\"\";width:10px;height:10px;background-color:inherit}.ask-tooltip.-above{margin-bottom:4px}.ask-tooltip.-above:after{bottom:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-below{margin-top:4px}.ask-tooltip.-below:after{top:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.ask-tooltip.-after,.ask-tooltip.-right{margin-left:4px}.ask-tooltip.-after:after,.ask-tooltip.-right:after{left:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-tooltip.-before,.ask-tooltip.-left{margin-right:4px}.ask-tooltip.-before:after,.ask-tooltip.-left:after{right:-5px;top:50%;transform:translateY(-50%) rotate(45deg)}.ask-button{padding:8px 24px;border-radius:6px;border:none;outline:none;height:48px;font-size:1rem;transition:background-color .1s,box-shadow .1s;cursor:pointer;font-weight:500;background:white;color:var(--grey-500)}.ask-button:not(.-primary,.-secondary){box-shadow:0 1px 2px #2a304229}.ask-button:not(.-primary):hover:not(:disabled){box-shadow:0 0 6px #2a304229}.ask-button:hover:not(:disabled){box-shadow:0 0 6px #ff572466}.ask-button:active:not(:disabled){background-color:#f34915}.ask-button:disabled{cursor:not-allowed;background-color:#9aa5b1}.ask-button.-primary{background:#FF5724;color:#fff}.ask-text-button{padding:8px 16px;border:none;border-radius:4px;outline:none;background:none;color:var(--asksuite-orange);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3ms}.ask-text-button:hover{text-decoration:none;background:#F5F7FA}.ask-text-button:disabled{cursor:not-allowed;color:#9aa5b1}.ask-text-button.-primary{color:var(--asksuite-orange)}.ask-text-button.-secondary{color:#616e7c}.ask-modal-header{display:block;position:relative;flex-shrink:0;box-sizing:border-box;margin:0 0 1px;padding:0 24px 9px}.ask-modal-body{flex-grow:1;box-sizing:border-box;margin:0;overflow:auto;padding:20px 24px;max-height:65vh;display:block}.ask-modal-footer{display:flex;position:relative;flex-shrink:0;flex-wrap:wrap;align-items:center;justify-content:flex-end;box-sizing:border-box;min-height:52px;margin:0;padding:8px;border-top:1px solid rgba(0,0,0,0)}.ql-editor{padding:14px 16px;font-size:.875rem;word-break:break-word}.bubble-toolbox{position:absolute;background-color:var(--grey-800);border-radius:8px;z-index:999}.top-toolbox{background-color:var(--grey-100)}.material-icons{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:\"liga\";-webkit-font-smoothing:antialiased}*{box-sizing:border-box}*,button,select,textarea{font-family:Inter,sans-serif;font-weight:400}input{font-size:1rem}.ask-badge{position:relative}.ask-badge>.badge{position:absolute;display:flex;justify-content:center;align-items:center;background-color:var(--bg-color);color:#fff;font-size:12px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;border-radius:50%;box-shadow:0 2px 6px -1px #00000080}.ask-badge>.badge.-primary{--bg-color: var(--asksuite-orange)}.ask-badge>.badge.-secondary{--bg-color: var(--grey-800)}.ask-badge>.badge.-top{top:-10px}.ask-badge>.badge.-bottom{bottom:-10px}.ask-badge>.badge.-left{left:-10px}.ask-badge>.badge.-right{right:-10px}.ask-badge>.badge.-small{width:18px;height:18px;font-size:10px}.ask-badge>.badge.-regular{width:22px;height:22px;font-size:11px}.ask-badge>.badge.-large{width:28px;height:28px;font-size:12px}.ask-dropdown-top-right{margin-left:8px}.ask-dropdown-top-left{margin-right:8px}.ask-dropdown-bottom-right,.ask-dropdown-bottom-left{margin-top:8px}.ask-tooltip{white-space:break-spaces}:host{display:flex}.button{background:none;color:inherit;border:none;margin:0;font:inherit;cursor:pointer;outline:inherit;line-height:0;color:#7b8794;padding:8px}.icon.-bubble{color:var(--white)}.icon.-disabled{color:var(--grey-200)}.icon.-selected{color:#ff5724}.icon.-bubble.-disabled{color:var(--grey-600)}\n"] }]
|
65
|
+
}], propDecorators: { dropdowns: [{
|
66
|
+
type: ViewChildren,
|
67
|
+
args: [AskDropdownDirective]
|
68
|
+
}], close: [{
|
69
|
+
type: Output
|
70
|
+
}], tool: [{
|
71
|
+
type: Output
|
72
|
+
}], toolbarItems: [{
|
73
|
+
type: Input
|
74
|
+
}], type: [{
|
75
|
+
type: Input
|
76
|
+
}], class: [{
|
77
|
+
type: Input
|
78
|
+
}, {
|
79
|
+
type: HostBinding,
|
80
|
+
args: ['class']
|
81
|
+
}] } });
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmljaHRleHQtdG9vbGJveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9jb21wb25lbnRzL3JpY2h0ZXh0LXRvb2xib3gvcmljaHRleHQtdG9vbGJveC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL2xpYi9jb21wb25lbnRzL3JpY2h0ZXh0LXRvb2xib3gvcmljaHRleHQtdG9vbGJveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osV0FBVyxFQUNYLEtBQUssRUFDTCxNQUFNLEVBR04sWUFBWSxHQUNiLE1BQU0sZUFBZSxDQUFDO0FBSXZCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7OztBQVF4RCxNQUFNLE9BQU8sd0JBQXdCO0lBTnJDO1FBV1ksVUFBSyxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDakMsU0FBSSxHQUFHLElBQUksWUFBWSxFQUFlLENBQUM7UUFTeEMsU0FBSSxHQUF3QixRQUFRLENBQUM7UUFDZixVQUFLLEdBQThDLEVBQUUsQ0FBQztRQUU3RSxrQkFBYSxHQUFrQixFQUFFLENBQUM7UUFDbEMsV0FBTSxHQUFXLENBQUMsQ0FBQyxDQUFDO1FBQ2xCLGNBQVMsR0FBRyxLQUFLLENBQUM7S0EyQzdCO0lBdkRDLElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM1QixDQUFDO0lBQ0QsSUFBYSxZQUFZLENBQUMsS0FBb0I7UUFDNUMsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7UUFDM0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLE1BQU0sQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFTRCxJQUFjLFFBQVE7UUFDcEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsSUFBWSxjQUFjO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLFNBQVMsRUFBRSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFRCxXQUFXLENBQUMsRUFBaUI7UUFDM0IsSUFBRyxFQUFFLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFDO1lBQzNCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUM7U0FDeEU7SUFDSCxDQUFDO0lBRUQsTUFBTSxDQUFDLFdBQXdCO1FBQzdCLElBQUksV0FBVyxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBRWpDLElBQUksV0FBVyxDQUFDLElBQUksS0FBSyxNQUFNLEVBQUM7WUFDOUIsSUFBRyxJQUFJLENBQUMsSUFBSSxLQUFLLFFBQVE7Z0JBQ3ZCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1NBQ3pCO2FBQUk7WUFDSCxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztTQUM3QjtJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsSUFBWTtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLFFBQVMsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNuRCxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUE7SUFDdEIsQ0FBQztJQUVELGFBQWEsQ0FBQyxLQUFhLEVBQUUsSUFBaUI7UUFDNUMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFUyxhQUFhO1FBQ3JCLElBQUcsSUFBSSxDQUFDLFNBQVM7WUFDZixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQzs7WUFFdkIsSUFBSSxDQUFDLGNBQWUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNqQyxDQUFDOzhHQTlEVSx3QkFBd0I7a0dBQXhCLHdCQUF3Qiw4UEFDckIsb0JBQW9CLHFFQ3ZCcEMsdzJCQStCQTs7MkZEVGEsd0JBQXdCO2tCQU5wQyxTQUFTOytCQUNFLHNCQUFzQixtQkFHZix1QkFBdUIsQ0FBQyxNQUFNOzhCQUkvQyxTQUFTO3NCQURSLFlBQVk7dUJBQUMsb0JBQW9CO2dCQUl4QixLQUFLO3NCQUFkLE1BQU07Z0JBQ0csSUFBSTtzQkFBYixNQUFNO2dCQUtNLFlBQVk7c0JBQXhCLEtBQUs7Z0JBSUcsSUFBSTtzQkFBWixLQUFLO2dCQUN5QixLQUFLO3NCQUFuQyxLQUFLOztzQkFBSSxXQUFXO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIEhvc3RCaW5kaW5nLFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBRdWVyeUxpc3QsXG4gIFNpbXBsZUNoYW5nZXMsXG4gIFZpZXdDaGlsZHJlbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBUb29sYmFySXRlbSxcbn0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9yaWNodGV4dC10b29sYm94LmludGVyZmFjZSc7XG5pbXBvcnQgeyBBc2tEcm9wZG93bkRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhc2stcmljaHRleHQtdG9vbGJveCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9yaWNodGV4dC10b29sYm94LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcmljaHRleHQtdG9vbGJveC5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgUmljaHRleHRUb29sYm94Q29tcG9uZW50IHtcbiAgQFZpZXdDaGlsZHJlbihBc2tEcm9wZG93bkRpcmVjdGl2ZSlcbiAgZHJvcGRvd25zPzogUXVlcnlMaXN0PEFza0Ryb3Bkb3duRGlyZWN0aXZlPjtcblxuICBcbiAgQE91dHB1dCgpIGNsb3NlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBAT3V0cHV0KCkgdG9vbCA9IG5ldyBFdmVudEVtaXR0ZXI8VG9vbGJhckl0ZW0+KCk7XG5cbiAgZ2V0IHRvb2xiYXJJdGVtcygpe1xuICAgIHJldHVybiB0aGlzLl90b29sYmFySXRlbXM7XG4gIH1cbiAgQElucHV0KCkgc2V0IHRvb2xiYXJJdGVtcyh2YWx1ZTogVG9vbGJhckl0ZW1bXSkge1xuICAgIHRoaXMuX3Rvb2xiYXJJdGVtcyA9IHZhbHVlO1xuICAgIHRoaXMudXJsSWR4ID0gdmFsdWUuZmluZEluZGV4KChpdGVtKSA9PiBpdGVtLnRvb2wgPT09ICdsaW5rJyk7XG4gIH1cbiAgQElucHV0KCkgdHlwZTogJ3RvcGJhcicgfCAnYnViYmxlJyA9ICd0b3BiYXInO1xuICBASW5wdXQoKSBASG9zdEJpbmRpbmcoJ2NsYXNzJykgY2xhc3M6ICd0b3AtdG9vbGJveCcgfCAnYnViYmxlLXRvb2xib3gnIHwgc3RyaW5nID0gJyc7XG4gIFxuICBwcml2YXRlIF90b29sYmFySXRlbXM6IFRvb2xiYXJJdGVtW10gPSBbXTtcbiAgcHJpdmF0ZSB1cmxJZHg6IG51bWJlciA9IC0xO1xuICBwcm90ZWN0ZWQgaXNVcmxNb2RlID0gZmFsc2U7XG5cblxuICBwcm90ZWN0ZWQgZ2V0IGxpbmtUb29sKCk6IFRvb2xiYXJJdGVtIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy50b29sYmFySXRlbXNbdGhpcy51cmxJZHhdO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXQgdXJsRHJvcGRvd25SZWYoKSB7XG4gICAgcmV0dXJuIHRoaXMuZHJvcGRvd25zPy5nZXQodGhpcy51cmxJZHgpO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoc3A6IFNpbXBsZUNoYW5nZXMpIHtcbiAgICBpZihzcFsndHlwZSddICYmICF0aGlzLmNsYXNzKXtcbiAgICAgIHRoaXMuY2xhc3MgPSB0aGlzLnR5cGUgPT09ICdidWJibGUnID8gJ2J1YmJsZS10b29sYm94JyA6ICd0b3AtdG9vbGJveCc7XG4gICAgfVxuICB9XG5cbiAgb25Ub29sKHRvb2xiYXJJdGVtOiBUb29sYmFySXRlbSkge1xuICAgIGlmICh0b29sYmFySXRlbS5kaXNhYmxlZCkgcmV0dXJuO1xuXG4gICAgaWYgKHRvb2xiYXJJdGVtLnRvb2wgPT09ICdsaW5rJyl7XG4gICAgICBpZih0aGlzLnR5cGUgPT09ICdidWJibGUnKVxuICAgICAgICB0aGlzLmlzVXJsTW9kZSA9IHRydWU7ICAgICAgXG4gICAgfWVsc2V7XG4gICAgICB0aGlzLnRvb2wuZW1pdCh0b29sYmFySXRlbSk7XG4gICAgfVxuICB9XG5cbiAgb25VcmwobGluazogc3RyaW5nKSB7XG4gICAgdGhpcy50b29sLmVtaXQoeyAuLi50aGlzLmxpbmtUb29sISwgdmFsdWU6IGxpbmsgfSk7XG4gICAgdGhpcy5jbG9zZVVybElucHV0KClcbiAgfVxuXG4gIHRyYWNrQnlUb29sRm4oaW5kZXg6IG51bWJlciwgaXRlbTogVG9vbGJhckl0ZW0pIHtcbiAgICByZXR1cm4gaXRlbS50b29sO1xuICB9XG5cbiAgcHJvdGVjdGVkIGNsb3NlVXJsSW5wdXQoKXtcbiAgICBpZih0aGlzLmlzVXJsTW9kZSlcbiAgICAgIHRoaXMuaXNVcmxNb2RlID0gZmFsc2U7XG4gICAgZWxzZVxuICAgICAgdGhpcy51cmxEcm9wZG93blJlZiEuY2xvc2UoKTtcbiAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFpc1VybE1vZGU7IGVsc2UgdXJsVGVtcGxhdGVcIj5cbiAgPGJ1dHRvblxuICAgIGNsYXNzPVwiYnV0dG9uXCJcbiAgICAqbmdGb3I9XCJsZXQgdG9vbCBvZiB0b29sYmFySXRlbXM7IHRyYWNrQnk6IHRyYWNrQnlUb29sRm5cIlxuICAgIFtkaXNhYmxlZF09XCJ0b29sLmRpc2FibGVkXCJcbiAgICAoY2xpY2spPVwib25Ub29sKHRvb2wpXCJcbiAgICBbYXNrRHJvcGRvd25dPVwidG9vbC50b29sID09PSAnbGluaycgJiYgdHlwZSA9PT0gJ3RvcGJhcicgPyB1cmxUZW1wbGF0ZSA6IHVuZGVmaW5lZFwiXG4gICAgcG9zaXRpb25zPVwiQk9UVE9NX0xFRlRcIlxuICAgIFthdHRyLmRhdGEtdGVzdGlkXT1cIididXR0b24tJyt0b29sLnRvb2xcIlxuICA+XG4gICAgPHNwYW5cbiAgICAgIGNsYXNzPVwibWF0ZXJpYWwtaWNvbnMgaWNvblwiXG4gICAgICBbbmdDbGFzc109XCJ7XG4gICAgICAnLXNlbGVjdGVkJzogdG9vbC5zZWxlY3RlZCxcbiAgICAgICctZGlzYWJsZWQnOiB0b29sLmRpc2FibGVkLFxuICAgICAgJy1idWJibGUnOiB0eXBlID09PSAnYnViYmxlJyxcbiAgICB9XCJcbiAgICA+XG4gICAgICB7eyB0b29sLmljb24gfX1cbiAgICA8L3NwYW4+XG4gIDwvYnV0dG9uPlxuPC9uZy1jb250YWluZXI+XG5cbjxuZy10ZW1wbGF0ZSAjdXJsVGVtcGxhdGU+XG4gIDxhc2stcmljaHRleHQtdXJsLXByb21wdFxuICAgIGRhdGEtdGVzdGlkPVwidXJsLXByb21wdFwiXG4gICAgW3VybF09XCJsaW5rVG9vbD8udmFsdWUgfHwgJydcIlxuICAgICh1cmwpPVwib25VcmwoJGV2ZW50KVwiXG4gICAgKGtleWRvd24uZXNjYXBlKT1cImNsb3NlVXJsSW5wdXQoKVwiXG4gIC8+XG48L25nLXRlbXBsYXRlPlxuIl19
|