@worktile/theia 16.2.0-next.0 → 16.2.1

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 (56) hide show
  1. package/components/plugin-menu/plugin-menu.component.d.ts +4 -3
  2. package/components/toolbar/toolbar.component.d.ts +1 -1
  3. package/custom-types.d.ts +1 -0
  4. package/editor.component.d.ts +4 -2
  5. package/editor.module.d.ts +1 -1
  6. package/esm2022/components/plugin-menu/plugin-menu.component.mjs +7 -6
  7. package/esm2022/components/toolbar/toolbar.component.mjs +6 -5
  8. package/esm2022/custom-types.mjs +1 -1
  9. package/esm2022/editor.component.mjs +13 -9
  10. package/esm2022/interfaces/editor.mjs +2 -1
  11. package/esm2022/interfaces/image.mjs +1 -1
  12. package/esm2022/plugins/code/code.component.mjs +13 -17
  13. package/esm2022/plugins/deserialize/deserialize-html.plugin.mjs +11 -5
  14. package/esm2022/plugins/deserialize/deserialize-md.plugin.mjs +14 -8
  15. package/esm2022/plugins/image/image.component.mjs +16 -17
  16. package/esm2022/plugins/image/image.editor.mjs +37 -22
  17. package/esm2022/plugins/link/hover/link-hover.component.mjs +3 -3
  18. package/esm2022/plugins/link/link.component.mjs +3 -2
  19. package/esm2022/plugins/mention/mention.plugin.mjs +3 -2
  20. package/esm2022/plugins/quick-insert/quick-insert.plugin.mjs +10 -7
  21. package/esm2022/plugins/table/components/table.component.mjs +69 -48
  22. package/esm2022/plugins/table/components/td/td.component.mjs +15 -13
  23. package/esm2022/plugins/table/components/toolbar/table-options.component.mjs +6 -3
  24. package/esm2022/plugins/table/components/toolbar/table-toolbar.component.mjs +20 -24
  25. package/esm2022/plugins/table/table.service.mjs +6 -6
  26. package/esm2022/plugins/table/table.store.mjs +42 -14
  27. package/esm2022/plugins/table/table.types.mjs +8 -1
  28. package/esm2022/plugins/table/utils/is-selection-in-table.mjs +2 -2
  29. package/esm2022/plugins/table/utils/merge-cell.mjs +7 -7
  30. package/esm2022/plugins/table/utils/table-position.mjs +3 -5
  31. package/esm2022/queries/index.mjs +49 -49
  32. package/esm2022/utils/get-mode.mjs +14 -0
  33. package/esm2022/utils/index.mjs +2 -1
  34. package/fesm2022/worktile-theia.mjs +1099 -1004
  35. package/fesm2022/worktile-theia.mjs.map +1 -1
  36. package/interfaces/editor.d.ts +3 -2
  37. package/interfaces/image.d.ts +5 -4
  38. package/package.json +4 -4
  39. package/plugins/code/code.component.d.ts +2 -3
  40. package/plugins/image/image.component.d.ts +1 -1
  41. package/plugins/image/image.editor.d.ts +7 -0
  42. package/plugins/table/components/table.component.d.ts +8 -7
  43. package/plugins/table/components/table.component.scss +1 -1
  44. package/plugins/table/components/td/td.component.d.ts +9 -8
  45. package/plugins/table/components/toolbar/table-toolbar.component.d.ts +8 -7
  46. package/plugins/table/table.service.d.ts +2 -2
  47. package/plugins/table/table.store.d.ts +5 -3
  48. package/plugins/table/table.types.d.ts +9 -3
  49. package/plugins/table/utils/is-selection-in-table.d.ts +1 -1
  50. package/plugins/table/utils/merge-cell.d.ts +1 -1
  51. package/plugins/table/utils/table-position.d.ts +1 -1
  52. package/queries/index.d.ts +48 -48
  53. package/queries/is-range-across-blocks.d.ts +1 -1
  54. package/styles/editor.scss +7 -0
  55. package/utils/get-mode.d.ts +5 -0
  56. package/utils/index.d.ts +1 -0
@@ -1,11 +1,11 @@
1
- import { OnInit, OnDestroy, ElementRef, ChangeDetectorRef, NgZone } from '@angular/core';
1
+ import { ChangeDetectorRef, ElementRef, NgZone, OnDestroy, OnInit } from '@angular/core';
2
2
  import { MixinBase } from 'ngx-tethys/core';
3
+ import { ThyDropdownDirective } from 'ngx-tethys/dropdown';
4
+ import { ThyPopoverRef } from 'ngx-tethys/popover';
3
5
  import { Editor, PathRef } from 'slate';
4
6
  import { ThePluginMenuItemType } from '../../constants/plugin-menu';
5
7
  import { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig } from '../../interfaces/plugins/plugin-menu';
6
8
  import { TheListboxChangeEvent, TheListboxOptionDirective } from '../listbox/listbox';
7
- import { ThyDropdownDirective } from 'ngx-tethys/dropdown';
8
- import { ThyPopoverRef } from 'ngx-tethys/popover';
9
9
  import * as i0 from "@angular/core";
10
10
  declare const ThePluginMenuComponent_base: import("ngx-tethys/core").Constructor<import("ngx-tethys/core").ThyUnsubscribe> & typeof MixinBase;
11
11
  export declare class ThePluginMenuComponent extends ThePluginMenuComponent_base implements OnInit, OnDestroy {
@@ -27,6 +27,7 @@ export declare class ThePluginMenuComponent extends ThePluginMenuComponent_base
27
27
  expandPopoverOptions: {
28
28
  placement: string;
29
29
  width: string;
30
+ minWidth: string;
30
31
  };
31
32
  tableSelectPopoverConfig: {
32
33
  panelClass: string;
@@ -1,4 +1,4 @@
1
- import { OnInit, ViewContainerRef, OnChanges, SimpleChanges, ComponentRef, ElementRef, OnDestroy, NgZone, TemplateRef, ChangeDetectorRef } from '@angular/core';
1
+ import { ChangeDetectorRef, ComponentRef, ElementRef, NgZone, OnChanges, OnDestroy, OnInit, SimpleChanges, TemplateRef, ViewContainerRef } from '@angular/core';
2
2
  import { Editor } from 'slate';
3
3
  import { ComponentType } from 'slate-angular';
4
4
  import { ToolbarAlignment, ToolbarItem, ToolbarItemsComposeReturn } from '../../interfaces/toolbar';
package/custom-types.d.ts CHANGED
@@ -72,6 +72,7 @@ export interface ImageElement extends TheElement {
72
72
  layout?: LayoutTypes;
73
73
  reSized?: boolean;
74
74
  size?: number;
75
+ externalSource?: boolean;
75
76
  }
76
77
  export interface TableElement extends TheElement {
77
78
  type: ElementKinds.table;
@@ -1,4 +1,4 @@
1
- import { OnInit, OnDestroy, ViewContainerRef, ElementRef, EventEmitter, OnChanges, SimpleChanges, NgZone, ChangeDetectorRef } from '@angular/core';
1
+ import { OnInit, OnDestroy, ViewContainerRef, ElementRef, EventEmitter, OnChanges, SimpleChanges, NgZone, ChangeDetectorRef, Injector } from '@angular/core';
2
2
  import { MixinBase } from 'ngx-tethys/core';
3
3
  import { Editor, Text, Element, Descendant, Range, NodeEntry } from 'slate';
4
4
  import { DOMRange, SlateError } from 'slate-angular';
@@ -12,6 +12,7 @@ import { ThyIconRegistry } from 'ngx-tethys/icon';
12
12
  import * as i0 from "@angular/core";
13
13
  declare const TheEditorComponent_base: import("ngx-tethys/core").Constructor<import("ngx-tethys/core").ThyUnsubscribe> & typeof MixinBase;
14
14
  export declare class TheEditorComponent extends TheEditorComponent_base implements OnInit, OnChanges, OnDestroy {
15
+ private injector;
15
16
  private theContextService;
16
17
  private viewContainerRef;
17
18
  private elementRef;
@@ -38,13 +39,14 @@ export declare class TheEditorComponent extends TheEditorComponent_base implemen
38
39
  editor: TheEditor;
39
40
  editorValue: Descendant[];
40
41
  globalToolbarClass: string[];
42
+ isMobileMode: boolean;
41
43
  decorate: (nodeEntry: NodeEntry) => Range[];
42
44
  get theGlobalToolbarInstance(): TheToolbarComponent;
43
45
  get maxHeight(): string;
44
46
  elementToHtml: WeakMap<Element, string>;
45
47
  private onChangeCallback;
46
48
  private onTouchedCallback;
47
- constructor(theContextService: TheContextService, viewContainerRef: ViewContainerRef, elementRef: ElementRef, ngZone: NgZone, cdr: ChangeDetectorRef, iconRegistry: ThyIconRegistry);
49
+ constructor(injector: Injector, theContextService: TheContextService, viewContainerRef: ViewContainerRef, elementRef: ElementRef, ngZone: NgZone, cdr: ChangeDetectorRef, iconRegistry: ThyIconRegistry);
48
50
  ngOnInit(): void;
49
51
  ngOnChanges(changes: SimpleChanges): void;
50
52
  ngOnDestroy(): void;
@@ -101,7 +101,7 @@ import * as i68 from "ngx-tethys/input-number";
101
101
  import * as i69 from "ngx-tethys/color-picker";
102
102
  import * as i70 from "ng-codemirror";
103
103
  import * as i71 from "./components/column-resize/column-resize.module";
104
- export declare const COMPONENTS: (typeof TheDefaultElementComponent | typeof TheToolbarGroupComponent | typeof TheToolbarItemComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarComponent | typeof TheListboxOptionDirective | typeof TheListboxGroupDirective | typeof TheListboxDirective | typeof ThePreventDefaultDirective | typeof ThePluginMenuComponent | typeof TheVerticalToolbarItemComponent | typeof TheContextMenuComponent | typeof TheTableOptionsComponent | typeof TheTextComponent | typeof TheColorToolbarItemComponent | typeof TheConversionHintComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheInlineToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent)[];
104
+ export declare const COMPONENTS: (typeof TheDefaultElementComponent | typeof TheToolbarGroupComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarItemComponent | typeof TheToolbarComponent | typeof TheListboxOptionDirective | typeof TheListboxGroupDirective | typeof TheListboxDirective | typeof ThePreventDefaultDirective | typeof ThePluginMenuComponent | typeof TheVerticalToolbarItemComponent | typeof TheContextMenuComponent | typeof TheTableOptionsComponent | typeof TheTextComponent | typeof TheColorToolbarItemComponent | typeof TheConversionHintComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheInlineToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent)[];
105
105
  export declare const PLUGIN_COMPONENTS: (typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheLinkComponent | typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheTemplateComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheImageComponent | typeof TheTableRowComponent | typeof TheTdComponent | typeof TheTodoItemComponent)[];
106
106
  export declare class TheEditorModule {
107
107
  static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorModule, never>;
@@ -1,12 +1,12 @@
1
- import { Component, Input, HostBinding, ViewChildren } from '@angular/core';
2
- import { mixinUnsubscribe, MixinBase, ScrollToService } from 'ngx-tethys/core';
1
+ import { Component, HostBinding, Input, ViewChildren } from '@angular/core';
2
+ import { MixinBase, ScrollToService, mixinUnsubscribe } from 'ngx-tethys/core';
3
+ import { ThyDropdownDirective } from 'ngx-tethys/dropdown';
3
4
  import { Editor, Node } from 'slate';
4
5
  import { AngularEditor } from 'slate-angular';
5
- import { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';
6
6
  import { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';
7
+ import { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';
7
8
  import { ThePluginMenu } from '../../interfaces/plugins/plugin-menu';
8
9
  import { QuickInsertEditor } from '../../plugins/public-api';
9
- import { ThyDropdownDirective } from 'ngx-tethys/dropdown';
10
10
  import { refocus } from '../../utils/refocus';
11
11
  import * as i0 from "@angular/core";
12
12
  import * as i1 from "ngx-tethys/popover";
@@ -40,7 +40,8 @@ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
40
40
  };
41
41
  this.expandPopoverOptions = {
42
42
  placement: 'rightTop',
43
- width: '262px'
43
+ width: '262px',
44
+ minWidth: '262px'
44
45
  };
45
46
  this.tableSelectPopoverConfig = {
46
47
  panelClass: 'plugin-menu-table-select-container',
@@ -201,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
201
202
  }], autoActiveFirstItem: [{
202
203
  type: Input
203
204
  }] } });
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/plugin-menu/plugin-menu.component.ts","../../../../../packages/src/components/plugin-menu/plugin-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ElementRef, ChangeDetectorRef, HostBinding, ViewChildren, NgZone } from '@angular/core';\nimport { mixinUnsubscribe, MixinBase, ScrollToService } from 'ngx-tethys/core';\nimport { Editor, Node, PathRef, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport {\n    ThePluginMenu,\n    ThePluginMenuGroup,\n    ThePluginMenuItem,\n    ThePluginMenuItemConfig,\n    ThePluginMenuItemWrap\n} from '../../interfaces/plugins/plugin-menu';\nimport { QuickInsertEditor } from '../../plugins/public-api';\nimport { TheListboxChangeEvent, TheListboxOptionDirective } from '../listbox/listbox';\nimport { ThyDropdownDirective } from 'ngx-tethys/dropdown';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { refocus } from '../../utils/refocus';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html'\n})\nexport class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    listBoxAutoActiveFirstItem = true;\n\n    pathRef: PathRef;\n\n    keyboardContainer: HTMLElement;\n\n    _pluginMenu: ThePluginMenu;\n\n    groupMenu: ThePluginMenu = [];\n\n    iconMenu: ThePluginMenu = [];\n\n    ThePluginMenuItemType = ThePluginMenuItemType;\n\n    keyWords: string;\n\n    thyMessage = '暂无数据';\n\n    scrollContainer: HTMLElement;\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '262px'\n    };\n\n    tableSelectPopoverConfig = {\n        panelClass: 'plugin-menu-table-select-container',\n        minWidth: 0,\n        //  避免重写\n        originActiveClass: 'thy-popover-origin-active'\n    };\n\n    @ViewChildren('dropdownTriggers', { read: ThyDropdownDirective }) dropdownTriggers: ThyDropdownDirective[];\n\n    @HostBinding('class') containerClassName = `the-plugin-menu-container`;\n\n    @Input() editor: Editor;\n\n    @Input() theDisplaySearch: boolean = false;\n\n    @Input() thePluginMenu: ThePluginMenuItemConfig[];\n\n    @Input() sceneKey?: string;\n\n    @Input() subPanelClass: string | string[];\n\n    @Input() autoActiveFirstItem: boolean = true;\n\n    constructor(\n        public elementRef: ElementRef<HTMLElement>,\n        public cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private thyPopoverRef: ThyPopoverRef<ThePluginMenuComponent>\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.autoActiveFirstItem || this.theDisplaySearch) {\n            this.listBoxAutoActiveFirstItem = false;\n        }\n        this.initializeSearch();\n        this.initializePluginMenu();\n        this.buildMenus();\n        setTimeout(() => {\n            this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');\n        }, 0);\n    }\n\n    initializeSearch() {\n        if (this.theDisplaySearch) {\n            this.keyboardContainer = this.elementRef.nativeElement;\n            setTimeout(() => {\n                // 记住位置\n                if (this.editor.selection) {\n                    this.pathRef = Editor.pathRef(this.editor, this.editor.selection.anchor.path);\n                }\n                this.elementRef.nativeElement.querySelector('input').focus();\n            }, 0);\n        } else {\n            this.keyboardContainer = AngularEditor.toDOMNode(this.editor, this.editor);\n        }\n    }\n\n    initializePluginMenu() {\n        const currentMenu = this.thePluginMenu || DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\n    }\n\n    buildMenus() {\n        this.iconMenu = [];\n        this.groupMenu = [];\n        this._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n            const isHidden = item?.isHidden && item.isHidden(this.editor);\n            if (ThePluginMenu.isMenuItem(item)) {\n                item.isMenuItem = true;\n                item.disabled = item.isDisabled && item.isDisabled(this.editor);\n                if (this.keyWords && !isHidden && item.keywords && item.keywords?.includes(this.keyWords)) {\n                    this.groupMenu.push(item);\n                }\n                if (!isHidden && item.children && item.children.length > 0) {\n                    item.children?.forEach((child: ThePluginMenuItemWrap | 'divider') => {\n                        if (child === 'divider') return;\n                        child.isMenuItem = true;\n                        child.disabled = child.isDisabled && child.isDisabled(this.editor);\n                        const isHiddenChid = item.isHidden && item.isHidden(this.editor);\n                        if (this.keyWords && !isHiddenChid && child.keywords && child.keywords?.includes(this.keyWords)) {\n                            this.groupMenu.push(child);\n                        }\n                    });\n                }\n            }\n            if (!this.keyWords && !isHidden) {\n                item?.type === ThePluginMenuItemType.icon ? this.iconMenu.push(item) : this.groupMenu.push(item);\n            }\n        });\n\n        if (this.keyWords && this.groupMenu.length > 0) {\n            this.groupMenu.unshift(this.searchGroup);\n        }\n\n        this.cdr.markForCheck();\n    }\n\n    handleItemSelection(menuItem: ThePluginMenuItem) {\n        if (menuItem.isDisabled && menuItem.isDisabled(this.editor)) {\n            return;\n        }\n        if (!this.editor.selection) {\n            refocus(this.editor);\n        }\n        if (!this.theDisplaySearch) {\n            this.removeKeywords();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeKeywords = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && Node.string(node).length > 0) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        if (this.autoActiveFirstItem) {\n            this.listBoxAutoActiveFirstItem = true;\n        }\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n        if (this.scrollContainer) {\n            this.scrollContainer.scrollTop = 0;\n        }\n    }\n\n    theListboxChange(event: TheListboxChangeEvent) {\n        if (event.type === 'select') {\n            this.handleItemSelection(event.option.theOptionValue as ThePluginMenuItem);\n        }\n        if (event.type === 'child') {\n            const dropdown = this.findDropdownTrigger(event.option.parentOption);\n            this.ngZone.run(() => {\n                dropdown.show();\n            });\n        }\n        if (event.type === 'parent') {\n            const dropdown = this.findDropdownTrigger(event.option);\n            dropdown.hide();\n        }\n        if (event.type === 'turn' && !event.option.parentOption) {\n            ScrollToService.scrollToElement(event.option.elementRef.nativeElement, this.scrollContainer);\n        }\n    }\n\n    findDropdownTrigger(option: TheListboxOptionDirective) {\n        const dropdown = this.dropdownTriggers.find(value => {\n            return value['elementRef'].nativeElement === option.elementRef.nativeElement;\n        });\n        return dropdown;\n    }\n\n    trackByFn(index: ThePluginMenuItem, item: any) {\n        return item?.key ?? index;\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n  <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"搜索\" thyIconPosition=\"after\" (ngModelChange)=\"updateKeywords(keyWords)\">\n  </thy-input-search>\n</div>\n\n<div\n  *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n  theListBox\n  [keyboardContainer]=\"keyboardContainer\"\n  [autoActiveFirstItem]=\"listBoxAutoActiveFirstItem\"\n  (theListboxChange)=\"theListboxChange($event)\"\n  class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n  <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex pl-5 py-1\">\n    <ng-container *ngFor=\"let item of iconMenu; trackBy: trackByFn\">\n      <a\n        *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n        href=\"javascript:;\"\n        class=\"mt-2\"\n        thyAction\n        theListboxOption\n        [theOptionValue]=\"item\"\n        [thyActionIcon]=\"item.icon\"\n        [thyTooltip]=\"item?.name\"\n        [thyDisabled]=\"item.disabled\"\n        [theOptionDisabled]=\"item.disabled\"\n        thePreventDefault\n        (click)=\"handleItemSelection(item)\"\n      ></a>\n    </ng-container>\n  </div>\n\n  <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n  <div theListboxGroup>\n    <ng-container *ngFor=\"let item of groupMenu; trackBy: trackByFn\">\n      <ng-container *ngIf=\"item.isMenuItem && !(item.children?.length > 0) && item.key !== 'table'\">\n        <div\n          thyDropdownMenuItem\n          theListboxOption\n          [theOptionValue]=\"item\"\n          class=\"py-0\"\n          thePreventDefault\n          [thyDisabled]=\"item.disabled\"\n          [theOptionDisabled]=\"item.disabled\"\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n          </div>\n          <div class=\"menu-content d-flex align-items-center\">\n            <div class=\"menu-item-title w-100\">\n              {{ item.name }}\n            </div>\n          </div>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"item.isMenuItem && item.children?.length > 0\" #hasExpanded>\n        <div\n          #dropdownTriggers\n          [thyDropdown]=\"expand\"\n          thyTrigger=\"hover\"\n          thyDropdownMenuItem\n          [thyDisabled]=\"item.disabled\"\n          theListboxOption\n          [theOptionValue]=\"item\"\n          [theOptionDisabled]=\"item.disabled\"\n          [thyPopoverOptions]=\"expandPopoverOptions\"\n          class=\"py-0\"\n          thePreventDefault\n          [thyPanelClass]=\"subPanelClass\"\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n          </div>\n          <div class=\"menu-content d-flex align-items-center\">\n            <div class=\"menu-item-title w-100\">\n              {{ item.name }}\n            </div>\n          </div>\n          <div *ngIf=\"item.children?.length > 0\">\n            <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n          </div>\n          <thy-dropdown-menu #expand>\n            <div class=\"the-plugin-menu-container expand-menu\" theListboxGroup>\n              <ng-container *ngFor=\"let child of item.children\">\n                <div\n                  *ngIf=\"child.type === ThePluginMenuItemType.group\"\n                  thyDropdownMenuItem\n                  theListboxOption\n                  class=\"py-0\"\n                  thePreventDefault\n                  [theOptionDisabled]=\"item.disabled\"\n                  [thyDisabled]=\"child.disabled\"\n                  (click)=\"handleItemSelection(child)\"\n                  [theOptionValue]=\"child\"\n                >\n                  <div *ngIf=\"child.menuIcon\" class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"child.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n                  </div>\n                  <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                      {{ child.name }}\n                    </div>\n                  </div>\n                </div>\n                <thy-divider *ngIf=\"child === 'divider'\" class=\"my-2\"></thy-divider>\n              </ng-container>\n            </div>\n          </thy-dropdown-menu>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"item.isMenuItem && item.key === 'table'\">\n        <div\n          #dropdownTriggers\n          [thyPopover]=\"tableSelect\"\n          thyPlacement=\"rightTop\"\n          thyTrigger=\"hover\"\n          thyDropdownMenuItem\n          theListboxOption\n          [thyConfig]=\"tableSelectPopoverConfig\"\n          [theOptionValue]=\"item\"\n          [theOptionDisabled]=\"item.disabled\"\n          [thyDisabled]=\"item.disabled\"\n          class=\"py-0\"\n          thePreventDefault\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n          </div>\n          <div class=\"menu-content d-flex align-items-center\">\n            <div class=\"menu-item-title w-100\">\n              {{ item.name }}\n            </div>\n          </div>\n          <div>\n            <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n          </div>\n\n          <ng-template #tableSelect>\n            <table-select\n              class=\"plugin-menu-table the-table-selector-panel\"\n              [editor]=\"editor\"\n              [beforeInsert]=\"removeKeywords\"\n            ></table-select>\n          </ng-template>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"!item.isMenuItem\" #menuGroup>\n        <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n      </ng-container>\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #thyEmpty>\n  <div class=\"empty d-flex align-items-center justify-content-center\">\n    <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n  </div>\n</ng-template>\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/plugin-menu/plugin-menu.component.ts","../../../../../packages/src/components/plugin-menu/plugin-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, HostBinding, Input, NgZone, OnDestroy, OnInit, ViewChildren } from '@angular/core';\nimport { MixinBase, ScrollToService, mixinUnsubscribe } from 'ngx-tethys/core';\nimport { ThyDropdownDirective } from 'ngx-tethys/dropdown';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor, Node, PathRef, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport {\n    ThePluginMenu,\n    ThePluginMenuGroup,\n    ThePluginMenuItem,\n    ThePluginMenuItemConfig,\n    ThePluginMenuItemWrap\n} from '../../interfaces/plugins/plugin-menu';\nimport { QuickInsertEditor } from '../../plugins/public-api';\nimport { refocus } from '../../utils/refocus';\nimport { TheListboxChangeEvent, TheListboxOptionDirective } from '../listbox/listbox';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html'\n})\nexport class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    listBoxAutoActiveFirstItem = true;\n\n    pathRef: PathRef;\n\n    keyboardContainer: HTMLElement;\n\n    _pluginMenu: ThePluginMenu;\n\n    groupMenu: ThePluginMenu = [];\n\n    iconMenu: ThePluginMenu = [];\n\n    ThePluginMenuItemType = ThePluginMenuItemType;\n\n    keyWords: string;\n\n    thyMessage = '暂无数据';\n\n    scrollContainer: HTMLElement;\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '262px',\n        minWidth: '262px'\n    };\n\n    tableSelectPopoverConfig = {\n        panelClass: 'plugin-menu-table-select-container',\n        minWidth: 0,\n        //  避免重写\n        originActiveClass: 'thy-popover-origin-active'\n    };\n\n    @ViewChildren('dropdownTriggers', { read: ThyDropdownDirective }) dropdownTriggers: ThyDropdownDirective[];\n\n    @HostBinding('class') containerClassName = `the-plugin-menu-container`;\n\n    @Input() editor: Editor;\n\n    @Input() theDisplaySearch: boolean = false;\n\n    @Input() thePluginMenu: ThePluginMenuItemConfig[];\n\n    @Input() sceneKey?: string;\n\n    @Input() subPanelClass: string | string[];\n\n    @Input() autoActiveFirstItem: boolean = true;\n\n    constructor(\n        public elementRef: ElementRef<HTMLElement>,\n        public cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private thyPopoverRef: ThyPopoverRef<ThePluginMenuComponent>\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.autoActiveFirstItem || this.theDisplaySearch) {\n            this.listBoxAutoActiveFirstItem = false;\n        }\n        this.initializeSearch();\n        this.initializePluginMenu();\n        this.buildMenus();\n        setTimeout(() => {\n            this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');\n        }, 0);\n    }\n\n    initializeSearch() {\n        if (this.theDisplaySearch) {\n            this.keyboardContainer = this.elementRef.nativeElement;\n            setTimeout(() => {\n                // 记住位置\n                if (this.editor.selection) {\n                    this.pathRef = Editor.pathRef(this.editor, this.editor.selection.anchor.path);\n                }\n                this.elementRef.nativeElement.querySelector('input').focus();\n            }, 0);\n        } else {\n            this.keyboardContainer = AngularEditor.toDOMNode(this.editor, this.editor);\n        }\n    }\n\n    initializePluginMenu() {\n        const currentMenu = this.thePluginMenu || DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\n    }\n\n    buildMenus() {\n        this.iconMenu = [];\n        this.groupMenu = [];\n        this._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n            const isHidden = item?.isHidden && item.isHidden(this.editor);\n            if (ThePluginMenu.isMenuItem(item)) {\n                item.isMenuItem = true;\n                item.disabled = item.isDisabled && item.isDisabled(this.editor);\n                if (this.keyWords && !isHidden && item.keywords && item.keywords?.includes(this.keyWords)) {\n                    this.groupMenu.push(item);\n                }\n                if (!isHidden && item.children && item.children.length > 0) {\n                    item.children?.forEach((child: ThePluginMenuItemWrap | 'divider') => {\n                        if (child === 'divider') return;\n                        child.isMenuItem = true;\n                        child.disabled = child.isDisabled && child.isDisabled(this.editor);\n                        const isHiddenChid = item.isHidden && item.isHidden(this.editor);\n                        if (this.keyWords && !isHiddenChid && child.keywords && child.keywords?.includes(this.keyWords)) {\n                            this.groupMenu.push(child);\n                        }\n                    });\n                }\n            }\n            if (!this.keyWords && !isHidden) {\n                item?.type === ThePluginMenuItemType.icon ? this.iconMenu.push(item) : this.groupMenu.push(item);\n            }\n        });\n\n        if (this.keyWords && this.groupMenu.length > 0) {\n            this.groupMenu.unshift(this.searchGroup);\n        }\n\n        this.cdr.markForCheck();\n    }\n\n    handleItemSelection(menuItem: ThePluginMenuItem) {\n        if (menuItem.isDisabled && menuItem.isDisabled(this.editor)) {\n            return;\n        }\n        if (!this.editor.selection) {\n            refocus(this.editor);\n        }\n        if (!this.theDisplaySearch) {\n            this.removeKeywords();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeKeywords = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && Node.string(node).length > 0) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        if (this.autoActiveFirstItem) {\n            this.listBoxAutoActiveFirstItem = true;\n        }\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n        if (this.scrollContainer) {\n            this.scrollContainer.scrollTop = 0;\n        }\n    }\n\n    theListboxChange(event: TheListboxChangeEvent) {\n        if (event.type === 'select') {\n            this.handleItemSelection(event.option.theOptionValue as ThePluginMenuItem);\n        }\n        if (event.type === 'child') {\n            const dropdown = this.findDropdownTrigger(event.option.parentOption);\n            this.ngZone.run(() => {\n                dropdown.show();\n            });\n        }\n        if (event.type === 'parent') {\n            const dropdown = this.findDropdownTrigger(event.option);\n            dropdown.hide();\n        }\n        if (event.type === 'turn' && !event.option.parentOption) {\n            ScrollToService.scrollToElement(event.option.elementRef.nativeElement, this.scrollContainer);\n        }\n    }\n\n    findDropdownTrigger(option: TheListboxOptionDirective) {\n        const dropdown = this.dropdownTriggers.find(value => {\n            return value['elementRef'].nativeElement === option.elementRef.nativeElement;\n        });\n        return dropdown;\n    }\n\n    trackByFn(index: ThePluginMenuItem, item: any) {\n        return item?.key ?? index;\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n  <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"搜索\" thyIconPosition=\"after\" (ngModelChange)=\"updateKeywords(keyWords)\">\n  </thy-input-search>\n</div>\n\n<div\n  *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n  theListBox\n  [keyboardContainer]=\"keyboardContainer\"\n  [autoActiveFirstItem]=\"listBoxAutoActiveFirstItem\"\n  (theListboxChange)=\"theListboxChange($event)\"\n  class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n  <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex pl-5 py-1\">\n    <ng-container *ngFor=\"let item of iconMenu; trackBy: trackByFn\">\n      <a\n        *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n        href=\"javascript:;\"\n        class=\"mt-2\"\n        thyAction\n        theListboxOption\n        [theOptionValue]=\"item\"\n        [thyActionIcon]=\"item.icon\"\n        [thyTooltip]=\"item?.name\"\n        [thyDisabled]=\"item.disabled\"\n        [theOptionDisabled]=\"item.disabled\"\n        thePreventDefault\n        (click)=\"handleItemSelection(item)\"\n      ></a>\n    </ng-container>\n  </div>\n\n  <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n  <div theListboxGroup>\n    <ng-container *ngFor=\"let item of groupMenu; trackBy: trackByFn\">\n      <ng-container *ngIf=\"item.isMenuItem && !(item.children?.length > 0) && item.key !== 'table'\">\n        <div\n          thyDropdownMenuItem\n          theListboxOption\n          [theOptionValue]=\"item\"\n          class=\"py-0\"\n          thePreventDefault\n          [thyDisabled]=\"item.disabled\"\n          [theOptionDisabled]=\"item.disabled\"\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n          </div>\n          <div class=\"menu-content d-flex align-items-center\">\n            <div class=\"menu-item-title w-100\">\n              {{ item.name }}\n            </div>\n          </div>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"item.isMenuItem && item.children?.length > 0\" #hasExpanded>\n        <div\n          #dropdownTriggers\n          [thyDropdown]=\"expand\"\n          thyTrigger=\"hover\"\n          thyDropdownMenuItem\n          [thyDisabled]=\"item.disabled\"\n          theListboxOption\n          [theOptionValue]=\"item\"\n          [theOptionDisabled]=\"item.disabled\"\n          [thyPopoverOptions]=\"expandPopoverOptions\"\n          class=\"py-0\"\n          thePreventDefault\n          [thyPanelClass]=\"subPanelClass\"\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n          </div>\n          <div class=\"menu-content d-flex align-items-center\">\n            <div class=\"menu-item-title w-100\">\n              {{ item.name }}\n            </div>\n          </div>\n          <div *ngIf=\"item.children?.length > 0\">\n            <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n          </div>\n          <thy-dropdown-menu #expand>\n            <div class=\"the-plugin-menu-container expand-menu\" theListboxGroup>\n              <ng-container *ngFor=\"let child of item.children\">\n                <div\n                  *ngIf=\"child.type === ThePluginMenuItemType.group\"\n                  thyDropdownMenuItem\n                  theListboxOption\n                  class=\"py-0\"\n                  thePreventDefault\n                  [theOptionDisabled]=\"item.disabled\"\n                  [thyDisabled]=\"child.disabled\"\n                  (click)=\"handleItemSelection(child)\"\n                  [theOptionValue]=\"child\"\n                >\n                  <div *ngIf=\"child.menuIcon\" class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"child.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n                  </div>\n                  <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                      {{ child.name }}\n                    </div>\n                  </div>\n                </div>\n                <thy-divider *ngIf=\"child === 'divider'\" class=\"my-2\"></thy-divider>\n              </ng-container>\n            </div>\n          </thy-dropdown-menu>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"item.isMenuItem && item.key === 'table'\">\n        <div\n          #dropdownTriggers\n          [thyPopover]=\"tableSelect\"\n          thyPlacement=\"rightTop\"\n          thyTrigger=\"hover\"\n          thyDropdownMenuItem\n          theListboxOption\n          [thyConfig]=\"tableSelectPopoverConfig\"\n          [theOptionValue]=\"item\"\n          [theOptionDisabled]=\"item.disabled\"\n          [thyDisabled]=\"item.disabled\"\n          class=\"py-0\"\n          thePreventDefault\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></thy-icon>\n          </div>\n          <div class=\"menu-content d-flex align-items-center\">\n            <div class=\"menu-item-title w-100\">\n              {{ item.name }}\n            </div>\n          </div>\n          <div>\n            <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n          </div>\n\n          <ng-template #tableSelect>\n            <table-select\n              class=\"plugin-menu-table the-table-selector-panel\"\n              [editor]=\"editor\"\n              [beforeInsert]=\"removeKeywords\"\n            ></table-select>\n          </ng-template>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"!item.isMenuItem\" #menuGroup>\n        <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n      </ng-container>\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #thyEmpty>\n  <div class=\"empty d-flex align-items-center justify-content-center\">\n    <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n  </div>\n</ng-template>\n"]}
@@ -1,11 +1,11 @@
1
- import { Component, Input, ViewChild, ViewContainerRef, Inject, HostBinding } from '@angular/core';
1
+ import { Component, HostBinding, Inject, Input, ViewChild, ViewContainerRef } from '@angular/core';
2
2
  import { ThyDividerComponent } from 'ngx-tethys/divider';
3
3
  import { Editor, Element } from 'slate';
4
- import { ToolbarItemType } from '../../interfaces/toolbar';
5
- import { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';
6
4
  import { ElementKinds, ToolbarActionTypes } from '../../constants/node-types';
7
- import { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';
5
+ import { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';
6
+ import { ToolbarItemType } from '../../interfaces/toolbar';
8
7
  import { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';
8
+ import { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "@angular/common";
11
11
  export class TheToolbarComponent {
@@ -213,6 +213,7 @@ export class TheToolbarComponent {
213
213
  createToolbarSplit() {
214
214
  const compRef = this.toolbarContainer.createComponent(ThyDividerComponent);
215
215
  compRef.instance.thyVertical = true;
216
+ compRef.instance.thyColor = 'light';
216
217
  compRef.location.nativeElement.classList.add('mx-2');
217
218
  }
218
219
  createMoreGroup(group) {
@@ -263,4 +264,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
263
264
  type: HostBinding,
264
265
  args: ['style.justifyContent']
265
266
  }] } });
266
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar/toolbar.component.ts","../../../../../packages/src/components/toolbar/toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    OnInit,\n    ViewChild,\n    ViewContainerRef,\n    OnChanges,\n    SimpleChanges,\n    ComponentRef,\n    ElementRef,\n    OnDestroy,\n    NgZone,\n    Inject,\n    TemplateRef,\n    ChangeDetectorRef,\n    HostBinding\n} from '@angular/core';\nimport { ThyDividerComponent } from 'ngx-tethys/divider';\nimport { Editor, Element } from 'slate';\nimport { ComponentType } from 'slate-angular';\nimport { ToolbarAlignment, ToolbarItem, ToolbarItemsComposeReturn, ToolbarItemType } from '../../interfaces/toolbar';\nimport { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';\nimport { ElementKinds, ToolbarActionTypes } from '../../constants/node-types';\nimport { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';\nimport { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';\nimport type { TheToolbarGroupComponent } from '../toolbar-group/toolbar-group.component';\nimport { TheBaseToolbarItem, TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';\n\n@Component({\n    selector: 'the-toolbar',\n    templateUrl: 'toolbar.component.html',\n    host: {\n        class: 'the-toolbar-container d-flex align-items-center'\n    }\n})\nexport class TheToolbarComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() editor: Editor;\n\n    @Input() toolbarItems: ToolbarItem[] = [];\n\n    @Input() align: ToolbarAlignment;\n\n    @Input() containerClass: string[] = [];\n\n    @Input() isMore = true;\n\n    @Input() afterTemplate: TemplateRef<any>;\n\n    @ViewChild('toolbarContainer', { read: ViewContainerRef, static: true }) toolbarContainer: ViewContainerRef;\n\n    @HostBinding('style.justifyContent') get justifyContent() {\n        return this.align;\n    }\n\n    components: Map<string, ComponentRef<any>> = new Map<string, ComponentRef<any>>();\n\n    composeToolbarItems: ToolbarItemsComposeReturn;\n\n    moreGroupMenu = ToolbarMoreGroup;\n\n    resizeObserver: ResizeObserver;\n\n    elementWidth = 0;\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private elementRef: ElementRef,\n        private ngZone: NgZone,\n        @Inject(TheToolbarGroupToken) private toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>\n    ) {}\n\n    ngOnInit() {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.selectionChange(this.editor);\n        this.isMore && this.resizeElement();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const toolbarItems = changes.toolbarItems;\n        if (toolbarItems && !toolbarItems.firstChange) {\n            this.renderToolbarView();\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.resizeObserver) {\n            this.resizeObserver.disconnect();\n        }\n    }\n\n    public setToolbarClass() {\n        if (this.editor && !!this.containerClass.length) {\n            this.elementRef.nativeElement.classList.add(...this.containerClass);\n        }\n    }\n\n    private resizeElement() {\n        const editableElement = this.elementRef.nativeElement;\n        // @ts-ignore\n        this.resizeObserver = new ResizeObserver(entries => {\n            for (let entry of entries) {\n                const { width } = entry.contentRect;\n                if (this.isMore && this.elementWidth !== width) {\n                    this.elementWidth = width;\n                    this.renderToolbarView();\n                }\n            }\n        });\n        this.resizeObserver.observe(editableElement);\n    }\n\n    private isTableActive() {\n        const [table] = Editor.nodes(this.editor, { match: n => Element.isElement(n) && n.type === ElementKinds.table });\n        return !!table;\n    }\n\n    public selectionChange(editor: Editor) {\n        if (this.isMore) {\n            this.renderToolbarView();\n        }\n\n        const toolbarItems = [...this.toolbarItems, this.moreGroupMenu];\n        for (const item of toolbarItems) {\n            if (item.key !== ToolbarActionTypes.split) {\n                const itemComponent = this.components.get(item.key);\n                if (itemComponent && itemComponent.instance.selectionChange) {\n                    itemComponent.instance.selectionChange(editor);\n                }\n            }\n        }\n    }\n\n    public renderToolbarView(): void {\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\n\n        if (items.length === this.composeToolbarItems?.items?.length && group?.length === this.composeToolbarItems?.group?.length) {\n            return;\n        }\n        this.composeToolbarItems = toolbarItems;\n        this.components.clear();\n        this.toolbarContainer.clear();\n\n        this.ngZone.run(() => {\n            for (const item of items) {\n                if (item.key === ToolbarActionTypes.split) {\n                    this.createToolbarSplit();\n                    continue;\n                }\n                this.createToolbarItem(item);\n            }\n            this.createMoreGroup(group);\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * calculation display toolbar and more grouped toolbars\n     *\n     *\t┌────────────────────────────────────────  GlobalToolbarView ───────────────────────────────────┐\n     *\t| ┌─────────────────────────────────────── #children ─────────────────────────────────────────┐ |\n     *\t| |   ┌─────── #itemsView ────────┐ ┌──────────────────────┐ ┌── #groupedItemsDropdown ───┐   | |\n     *\t| |   |       #ungroupedItems     | | ToolbarSeparatorView | |        #groupedItems       |   | |\n     *\t| |   └──────────────────────────-┘ └──────────────────────┘ └────────────────────────────┘   | |\n     *\t| |                                  \\---------- only when toolbar items overflow --------/   | |\n     *\t| └───────────────────────────────────────────────────────────────────────────────────────────┘ |\n     *\t└───────────────────────────────────────────────────────────────────────────────────────────────┘\n     * split width: 13px\n     * item width: default item: 32px; dropdown item: 48px\n     * default paddingRight: 4px\n     * set aside 50px\n     */\n    private toolbarItemsCompose(): ToolbarItemsComposeReturn {\n        let elementWidth = this.isMore ? this.elementWidth : null;\n        // dropdown item + paddingRight\n        const maxItemWidth = 52;\n        // default item + paddingRight\n        const defaultItemWidth = 36;\n        const splitWidth = 13;\n        const items: ToolbarItem[] = [];\n        const group: ToolbarItem[] = [];\n\n        for (let i = 0; i < this.toolbarItems.length; i++) {\n            const item = this.toolbarItems[i];\n            if (!this.isMore) {\n                items.push(item);\n                continue;\n            }\n\n            let itemWidth = defaultItemWidth;\n\n            switch (item.key) {\n                case ElementKinds.headingList:\n                    itemWidth = 74;\n                    break;\n                case ToolbarActionTypes.split:\n                    itemWidth = splitWidth;\n                    break;\n                case ToolbarActionTypes.verticalAlign:\n                    itemWidth = this.isTableActive() ? maxItemWidth : 0;\n                    break;\n                default:\n                    const isCustomComponent = item?.type === ToolbarItemType.dropdown || !!item?.iconComponent;\n                    itemWidth = isCustomComponent ? maxItemWidth : defaultItemWidth;\n            }\n\n            const remainingWidth = i === this.toolbarItems.length - 1 ? itemWidth : itemWidth + splitWidth;\n            const allowRender = elementWidth && elementWidth >= remainingWidth;\n            elementWidth -= itemWidth;\n\n            if (allowRender) {\n                items.push(item);\n            } else {\n                const isFirstSplit = group.length === 0 && item.key === ToolbarActionTypes.split;\n                !isFirstSplit && group.push(item);\n            }\n        }\n\n        return {\n            items: this.pureToolbarItems(items),\n            group\n        };\n    }\n\n    /**\n     * externally designated more group\n     */\n    private toolbarItemsAndMoreCompose() {\n        const items = [];\n        const group = [];\n\n        for (const item of this.toolbarItems) {\n            if (item.key === ToolbarActionTypes.split) {\n                items.push(item);\n                continue;\n            }\n            items.push(item);\n        }\n\n        return {\n            items: this.pureToolbarItems(items),\n            group\n        };\n    }\n\n    /**\n     * filter adjacent repeated dividers\n     * @param {ToolbarItem[]} items\n     * @returns\n     * @memberof TheToolbarComponent\n     */\n    pureToolbarItems(items: ToolbarItem[]) {\n        if (!Array.isArray(items)) {\n            return [];\n        }\n        return items.filter((a, i) => {\n            if (i > 0 && items[i - 1].key !== ToolbarActionTypes.split) {\n                return true;\n            }\n            return a.key !== ToolbarActionTypes.split;\n        });\n    }\n\n    private createToolbarItem(item: ToolbarItem) {\n        const { iconComponent, type, dropdownMode, dropdownItemKey, includes, ...args } = item;\n        const viewComponent = this.viewComponentType(type);\n        const compRef = this.toolbarContainer.createComponent<TheBaseToolbarItem>(iconComponent ? iconComponent : viewComponent);\n\n        compRef.instance.editor = this.editor;\n        compRef.instance.toolbarItem = item;\n        this.components.set(item.key, compRef);\n        if (item.type === ToolbarItemType.dropdown) {\n            const dropdownRef = compRef as unknown as ComponentRef<TheBaseToolbarDropdown>;\n            dropdownRef.instance.dropdownItemKey = item.dropdownItemKey;\n            dropdownRef.instance.menus = includes as ToolbarItem[];\n            dropdownRef.instance.mode = dropdownMode;\n        }\n    }\n\n    private createToolbarSplit() {\n        const compRef = this.toolbarContainer.createComponent(ThyDividerComponent);\n        compRef.instance.thyVertical = true;\n        compRef.location.nativeElement.classList.add('mx-2');\n    }\n\n    private createMoreGroup(group: ToolbarItem[]) {\n        if (group.length > 0) {\n            const compRef = this.toolbarContainer.createComponent(this.toolbarGroupComponent);\n            compRef.instance.editor = this.editor;\n            compRef.instance.menus = group;\n            compRef.instance.item = this.moreGroupMenu;\n            this.components.set(this.moreGroupMenu.key, compRef);\n        }\n    }\n\n    private viewComponentType(type: ToolbarItemType) {\n        if (type === ToolbarItemType.default) {\n            return TheToolbarItemComponent;\n        }\n        if (type === ToolbarItemType.dropdown) {\n            return TheToolbarDropdownComponent;\n        }\n        return TheToolbarItemComponent;\n    }\n}\n","<ng-container #toolbarContainer></ng-container>\n<ng-content></ng-content>\n<ng-template *ngIf=\"afterTemplate\" [ngTemplateOutlet]=\"afterTemplate\"></ng-template>\n"]}
267
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar/toolbar.component.ts","../../../../../packages/src/components/toolbar/toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { ThyDividerComponent } from 'ngx-tethys/divider';\nimport { Editor, Element } from 'slate';\nimport { ComponentType } from 'slate-angular';\nimport { ElementKinds, ToolbarActionTypes } from '../../constants/node-types';\nimport { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';\nimport { TheBaseToolbarDropdown, TheBaseToolbarItem } from '../../core/toolbar-item/base-toolbar-item';\nimport { ToolbarAlignment, ToolbarItem, ToolbarItemType, ToolbarItemsComposeReturn } from '../../interfaces/toolbar';\nimport { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';\nimport type { TheToolbarGroupComponent } from '../toolbar-group/toolbar-group.component';\nimport { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';\n\n@Component({\n    selector: 'the-toolbar',\n    templateUrl: 'toolbar.component.html',\n    host: {\n        class: 'the-toolbar-container d-flex align-items-center'\n    }\n})\nexport class TheToolbarComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() editor: Editor;\n\n    @Input() toolbarItems: ToolbarItem[] = [];\n\n    @Input() align: ToolbarAlignment;\n\n    @Input() containerClass: string[] = [];\n\n    @Input() isMore = true;\n\n    @Input() afterTemplate: TemplateRef<any>;\n\n    @ViewChild('toolbarContainer', { read: ViewContainerRef, static: true }) toolbarContainer: ViewContainerRef;\n\n    @HostBinding('style.justifyContent') get justifyContent() {\n        return this.align;\n    }\n\n    components: Map<string, ComponentRef<any>> = new Map<string, ComponentRef<any>>();\n\n    composeToolbarItems: ToolbarItemsComposeReturn;\n\n    moreGroupMenu = ToolbarMoreGroup;\n\n    resizeObserver: ResizeObserver;\n\n    elementWidth = 0;\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private elementRef: ElementRef,\n        private ngZone: NgZone,\n        @Inject(TheToolbarGroupToken) private toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>\n    ) {}\n\n    ngOnInit() {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.selectionChange(this.editor);\n        this.isMore && this.resizeElement();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const toolbarItems = changes.toolbarItems;\n        if (toolbarItems && !toolbarItems.firstChange) {\n            this.renderToolbarView();\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.resizeObserver) {\n            this.resizeObserver.disconnect();\n        }\n    }\n\n    public setToolbarClass() {\n        if (this.editor && !!this.containerClass.length) {\n            this.elementRef.nativeElement.classList.add(...this.containerClass);\n        }\n    }\n\n    private resizeElement() {\n        const editableElement = this.elementRef.nativeElement;\n        // @ts-ignore\n        this.resizeObserver = new ResizeObserver(entries => {\n            for (let entry of entries) {\n                const { width } = entry.contentRect;\n                if (this.isMore && this.elementWidth !== width) {\n                    this.elementWidth = width;\n                    this.renderToolbarView();\n                }\n            }\n        });\n        this.resizeObserver.observe(editableElement);\n    }\n\n    private isTableActive() {\n        const [table] = Editor.nodes(this.editor, { match: n => Element.isElement(n) && n.type === ElementKinds.table });\n        return !!table;\n    }\n\n    public selectionChange(editor: Editor) {\n        if (this.isMore) {\n            this.renderToolbarView();\n        }\n\n        const toolbarItems = [...this.toolbarItems, this.moreGroupMenu];\n        for (const item of toolbarItems) {\n            if (item.key !== ToolbarActionTypes.split) {\n                const itemComponent = this.components.get(item.key);\n                if (itemComponent && itemComponent.instance.selectionChange) {\n                    itemComponent.instance.selectionChange(editor);\n                }\n            }\n        }\n    }\n\n    public renderToolbarView(): void {\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\n\n        if (items.length === this.composeToolbarItems?.items?.length && group?.length === this.composeToolbarItems?.group?.length) {\n            return;\n        }\n        this.composeToolbarItems = toolbarItems;\n        this.components.clear();\n        this.toolbarContainer.clear();\n\n        this.ngZone.run(() => {\n            for (const item of items) {\n                if (item.key === ToolbarActionTypes.split) {\n                    this.createToolbarSplit();\n                    continue;\n                }\n                this.createToolbarItem(item);\n            }\n            this.createMoreGroup(group);\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * calculation display toolbar and more grouped toolbars\n     *\n     *\t┌────────────────────────────────────────  GlobalToolbarView ───────────────────────────────────┐\n     *\t| ┌─────────────────────────────────────── #children ─────────────────────────────────────────┐ |\n     *\t| |   ┌─────── #itemsView ────────┐ ┌──────────────────────┐ ┌── #groupedItemsDropdown ───┐   | |\n     *\t| |   |       #ungroupedItems     | | ToolbarSeparatorView | |        #groupedItems       |   | |\n     *\t| |   └──────────────────────────-┘ └──────────────────────┘ └────────────────────────────┘   | |\n     *\t| |                                  \\---------- only when toolbar items overflow --------/   | |\n     *\t| └───────────────────────────────────────────────────────────────────────────────────────────┘ |\n     *\t└───────────────────────────────────────────────────────────────────────────────────────────────┘\n     * split width: 13px\n     * item width: default item: 32px; dropdown item: 48px\n     * default paddingRight: 4px\n     * set aside 50px\n     */\n    private toolbarItemsCompose(): ToolbarItemsComposeReturn {\n        let elementWidth = this.isMore ? this.elementWidth : null;\n        // dropdown item + paddingRight\n        const maxItemWidth = 52;\n        // default item + paddingRight\n        const defaultItemWidth = 36;\n        const splitWidth = 13;\n        const items: ToolbarItem[] = [];\n        const group: ToolbarItem[] = [];\n\n        for (let i = 0; i < this.toolbarItems.length; i++) {\n            const item = this.toolbarItems[i];\n            if (!this.isMore) {\n                items.push(item);\n                continue;\n            }\n\n            let itemWidth = defaultItemWidth;\n\n            switch (item.key) {\n                case ElementKinds.headingList:\n                    itemWidth = 74;\n                    break;\n                case ToolbarActionTypes.split:\n                    itemWidth = splitWidth;\n                    break;\n                case ToolbarActionTypes.verticalAlign:\n                    itemWidth = this.isTableActive() ? maxItemWidth : 0;\n                    break;\n                default:\n                    const isCustomComponent = item?.type === ToolbarItemType.dropdown || !!item?.iconComponent;\n                    itemWidth = isCustomComponent ? maxItemWidth : defaultItemWidth;\n            }\n\n            const remainingWidth = i === this.toolbarItems.length - 1 ? itemWidth : itemWidth + splitWidth;\n            const allowRender = elementWidth && elementWidth >= remainingWidth;\n            elementWidth -= itemWidth;\n\n            if (allowRender) {\n                items.push(item);\n            } else {\n                const isFirstSplit = group.length === 0 && item.key === ToolbarActionTypes.split;\n                !isFirstSplit && group.push(item);\n            }\n        }\n\n        return {\n            items: this.pureToolbarItems(items),\n            group\n        };\n    }\n\n    /**\n     * externally designated more group\n     */\n    private toolbarItemsAndMoreCompose() {\n        const items = [];\n        const group = [];\n\n        for (const item of this.toolbarItems) {\n            if (item.key === ToolbarActionTypes.split) {\n                items.push(item);\n                continue;\n            }\n            items.push(item);\n        }\n\n        return {\n            items: this.pureToolbarItems(items),\n            group\n        };\n    }\n\n    /**\n     * filter adjacent repeated dividers\n     * @param {ToolbarItem[]} items\n     * @returns\n     * @memberof TheToolbarComponent\n     */\n    pureToolbarItems(items: ToolbarItem[]) {\n        if (!Array.isArray(items)) {\n            return [];\n        }\n        return items.filter((a, i) => {\n            if (i > 0 && items[i - 1].key !== ToolbarActionTypes.split) {\n                return true;\n            }\n            return a.key !== ToolbarActionTypes.split;\n        });\n    }\n\n    private createToolbarItem(item: ToolbarItem) {\n        const { iconComponent, type, dropdownMode, dropdownItemKey, includes, ...args } = item;\n        const viewComponent = this.viewComponentType(type);\n        const compRef = this.toolbarContainer.createComponent<TheBaseToolbarItem>(iconComponent ? iconComponent : viewComponent);\n\n        compRef.instance.editor = this.editor;\n        compRef.instance.toolbarItem = item;\n        this.components.set(item.key, compRef);\n        if (item.type === ToolbarItemType.dropdown) {\n            const dropdownRef = compRef as unknown as ComponentRef<TheBaseToolbarDropdown>;\n            dropdownRef.instance.dropdownItemKey = item.dropdownItemKey;\n            dropdownRef.instance.menus = includes as ToolbarItem[];\n            dropdownRef.instance.mode = dropdownMode;\n        }\n    }\n\n    private createToolbarSplit() {\n        const compRef = this.toolbarContainer.createComponent(ThyDividerComponent);\n        compRef.instance.thyVertical = true;\n        compRef.instance.thyColor = 'light';\n        compRef.location.nativeElement.classList.add('mx-2');\n    }\n\n    private createMoreGroup(group: ToolbarItem[]) {\n        if (group.length > 0) {\n            const compRef = this.toolbarContainer.createComponent(this.toolbarGroupComponent);\n            compRef.instance.editor = this.editor;\n            compRef.instance.menus = group;\n            compRef.instance.item = this.moreGroupMenu;\n            this.components.set(this.moreGroupMenu.key, compRef);\n        }\n    }\n\n    private viewComponentType(type: ToolbarItemType) {\n        if (type === ToolbarItemType.default) {\n            return TheToolbarItemComponent;\n        }\n        if (type === ToolbarItemType.dropdown) {\n            return TheToolbarDropdownComponent;\n        }\n        return TheToolbarItemComponent;\n    }\n}\n","<ng-container #toolbarContainer></ng-container>\n<ng-content></ng-content>\n<ng-template *ngIf=\"afterTemplate\" [ngTemplateOutlet]=\"afterTemplate\"></ng-template>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvc3JjL2N1c3RvbS10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2FmZVVybCB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgRGVzY2VuZGFudCwgRWxlbWVudCB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IEFsaWdubWVudCwgRWxlbWVudEtpbmRzLCBMYXlvdXRUeXBlcywgVmVydGljYWxBbGlnbm1lbnQgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBCbG9ja0VsZW1lbnRLaW5kcywgSW5saW5lRWxlbWVudEtpbmRzLCBUaGVFZGl0b3IgfSBmcm9tICcuL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgVGhlVGFibGVDb2x1bW4sIFRoZVRhYmxlT3B0aW9ucyB9IGZyb20gJy4vcGx1Z2lucy90YWJsZS90YWJsZS50eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGhlRWxlbWVudDxUID0gQmxvY2tFbGVtZW50S2luZHMgfCBJbmxpbmVFbGVtZW50S2luZHM+IHtcbiAgICB0eXBlOiBUO1xuICAgIGNoaWxkcmVuOiBEZXNjZW5kYW50W107XG4gICAga2V5Pzogc3RyaW5nO1xuICAgIF9pZD86IHN0cmluZztcbiAgICB2b2lkcz86IGJvb2xlYW47XG4gICAgYWxpZ24/OiBBbGlnbm1lbnQ7XG4gICAgaW5kZW50PzogbnVtYmVyO1xuICAgIHRleHRJbmRlbnQ/OiBudW1iZXI7XG4gICAgdmVydGljYWxBbGlnbj86IFZlcnRpY2FsQWxpZ25tZW50O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhcmFncmFwaEVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMucGFyYWdyYXBoO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJsb2NrUXVvdGVFbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLmJsb2NrcXVvdGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQnVsbGV0ZWRMaXN0RWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5idWxsZXRlZExpc3Q7XG4gICAgc3RhcnQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTnVtYmVyZWRMaXN0RWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5udW1iZXJlZExpc3Q7XG4gICAgc3RhcnQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdEl0ZW1FbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLmxpc3RJdGVtO1xuICAgIHN0YXJ0PzogbnVtYmVyO1xuICAgIGNoaWxkcmVuOiBFbGVtZW50W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlua0VsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMubGluaztcbiAgICB1cmw6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUb2RvSXRlbUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuY2hlY2tJdGVtO1xuICAgIGNoZWNrZWQ6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGVhZGluZ09uZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ18xO1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nVHdvRWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5oZWFkaW5nXzI7XG59XG5leHBvcnQgaW50ZXJmYWNlIEhlYWRpbmdUaHJlZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ18zO1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nRm91ckVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ180O1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nRml2ZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ181O1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nU2l4RWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5oZWFkaW5nXzY7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2VFbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLmltYWdlO1xuICAgIGNoaWxkcmVuOiBFbXB0eVRleHRbXTtcbiAgICBmaWxlPzogRmlsZTtcbiAgICBuYW1lPzogc3RyaW5nO1xuICAgIHdpZHRoPzogbnVtYmVyO1xuICAgIGhlaWdodD86IG51bWJlcjtcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgdGh1bWJVcmw/OiBzdHJpbmc7XG4gICAgb3JpZ2luVXJsPzogc3RyaW5nO1xuICAgIGFsaWduPzogQWxpZ25tZW50O1xuICAgIGxheW91dD86IExheW91dFR5cGVzO1xuICAgIHJlU2l6ZWQ/OiBib29sZWFuO1xuICAgIHNpemU/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVFbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLnRhYmxlO1xuICAgIGNoaWxkcmVuOiBUYWJsZVJvd0VsZW1lbnRbXTtcbiAgICBjb2x1bW5zPzogVGhlVGFibGVDb2x1bW5bXTtcbiAgICBvcHRpb25zPzogVGhlVGFibGVPcHRpb25zO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlUm93RWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy50YWJsZVJvdztcbiAgICBjaGlsZHJlbjogVGFibGVDZWxsRWxlbWVudFtdO1xuICAgIGhlYWRlcj86IGJvb2xlYW47XG4gICAgaGVpZ2h0PzogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlQ2VsbEVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICBrZXk/OiBzdHJpbmc7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLnRhYmxlQ2VsbDtcbiAgICBjb2xzcGFuPzogbnVtYmVyO1xuICAgIHJvd3NwYW4/OiBudW1iZXI7XG4gICAgaGlkZGVuPzogYm9vbGVhbjtcbiAgICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSHJFbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLmhyO1xuICAgIGNoaWxkcmVuOiBFbXB0eVRleHRbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb2RlRWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5jb2RlO1xuICAgIGNoaWxkcmVuOiBFbXB0eVRleHRbXTtcbiAgICBjb250ZW50Pzogc3RyaW5nO1xuICAgIGxhbmd1YWdlPzogc3RyaW5nO1xuICAgIGhlaWdodD86IG51bWJlcjtcbiAgICBhdXRvV3JhcD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWRpdGFibGVWb2lkRWxlbWVudCB7XG4gICAgdHlwZTogJ2VkaXRhYmxlLXZvaWQnO1xuICAgIGNoaWxkcmVuOiBFbXB0eVRleHRbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJbmxpbmVDb2RlRWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5pbmxpbmVDb2RlO1xufVxuXG5leHBvcnQgdHlwZSBDdXN0b21FbGVtZW50ID1cbiAgICB8IEJsb2NrUXVvdGVFbGVtZW50XG4gICAgfCBOdW1iZXJlZExpc3RFbGVtZW50XG4gICAgfCBCdWxsZXRlZExpc3RFbGVtZW50XG4gICAgfCBUb2RvSXRlbUVsZW1lbnRcbiAgICB8IEhlYWRpbmdPbmVFbGVtZW50XG4gICAgfCBIZWFkaW5nVHdvRWxlbWVudFxuICAgIHwgSGVhZGluZ1RocmVlRWxlbWVudFxuICAgIHwgSGVhZGluZ0ZvdXJFbGVtZW50XG4gICAgfCBIZWFkaW5nRml2ZUVsZW1lbnRcbiAgICB8IEhlYWRpbmdTaXhFbGVtZW50XG4gICAgfCBJbWFnZUVsZW1lbnRcbiAgICB8IExpbmtFbGVtZW50XG4gICAgfCBMaXN0SXRlbUVsZW1lbnRcbiAgICB8IFBhcmFncmFwaEVsZW1lbnRcbiAgICB8IFRhYmxlRWxlbWVudFxuICAgIHwgVGFibGVSb3dFbGVtZW50XG4gICAgfCBUYWJsZUNlbGxFbGVtZW50XG4gICAgfCBIckVsZW1lbnRcbiAgICB8IElubGluZUNvZGVFbGVtZW50XG4gICAgfCBDb2RlRWxlbWVudDtcblxuZXhwb3J0IHR5cGUgQ3VzdG9tVGV4dCA9IHtcbiAgICBib2xkPzogYm9vbGVhbjtcbiAgICBpdGFsaWM/OiBib29sZWFuO1xuICAgIGNvZGU/OiBib29sZWFuO1xuICAgIHRleHQ6IHN0cmluZztcbiAgICB1bmRlcmxpbmVkPzogYm9vbGVhbjtcbiAgICBjb2xvcj86IHN0cmluZztcbiAgICBbYGJhY2tncm91bmQtY29sb3JgXT86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEVtcHR5VGV4dCA9IHtcbiAgICB0ZXh0OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBDdXN0b21FZGl0b3IgPSBUaGVFZGl0b3I7XG5cbnR5cGUgR2V0PFQsIFAgZXh0ZW5kcyBrZXlvZiBUPiA9IFRbUF07XG5leHBvcnQgdHlwZSBDdXN0b21FbGVtZW50S2luZHMgPSBHZXQ8RWxlbWVudCwgJ3R5cGUnPjtcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGFja2FnZXMvc3JjL2N1c3RvbS10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzY2VuZGFudCwgRWxlbWVudCB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IEFsaWdubWVudCwgRWxlbWVudEtpbmRzLCBMYXlvdXRUeXBlcywgVmVydGljYWxBbGlnbm1lbnQgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBCbG9ja0VsZW1lbnRLaW5kcywgSW5saW5lRWxlbWVudEtpbmRzLCBUaGVFZGl0b3IgfSBmcm9tICcuL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgVGhlVGFibGVDb2x1bW4sIFRoZVRhYmxlT3B0aW9ucyB9IGZyb20gJy4vcGx1Z2lucy90YWJsZS90YWJsZS50eXBlcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGhlRWxlbWVudDxUID0gQmxvY2tFbGVtZW50S2luZHMgfCBJbmxpbmVFbGVtZW50S2luZHM+IHtcbiAgICB0eXBlOiBUO1xuICAgIGNoaWxkcmVuOiBEZXNjZW5kYW50W107XG4gICAga2V5Pzogc3RyaW5nO1xuICAgIF9pZD86IHN0cmluZztcbiAgICB2b2lkcz86IGJvb2xlYW47XG4gICAgYWxpZ24/OiBBbGlnbm1lbnQ7XG4gICAgaW5kZW50PzogbnVtYmVyO1xuICAgIHRleHRJbmRlbnQ/OiBudW1iZXI7XG4gICAgdmVydGljYWxBbGlnbj86IFZlcnRpY2FsQWxpZ25tZW50O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhcmFncmFwaEVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMucGFyYWdyYXBoO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJsb2NrUXVvdGVFbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLmJsb2NrcXVvdGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQnVsbGV0ZWRMaXN0RWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5idWxsZXRlZExpc3Q7XG4gICAgc3RhcnQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTnVtYmVyZWRMaXN0RWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5udW1iZXJlZExpc3Q7XG4gICAgc3RhcnQ/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdEl0ZW1FbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLmxpc3RJdGVtO1xuICAgIHN0YXJ0PzogbnVtYmVyO1xuICAgIGNoaWxkcmVuOiBFbGVtZW50W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlua0VsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMubGluaztcbiAgICB1cmw6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUb2RvSXRlbUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuY2hlY2tJdGVtO1xuICAgIGNoZWNrZWQ6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGVhZGluZ09uZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ18xO1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nVHdvRWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5oZWFkaW5nXzI7XG59XG5leHBvcnQgaW50ZXJmYWNlIEhlYWRpbmdUaHJlZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ18zO1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nRm91ckVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ180O1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nRml2ZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaGVhZGluZ181O1xufVxuZXhwb3J0IGludGVyZmFjZSBIZWFkaW5nU2l4RWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5oZWFkaW5nXzY7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2VFbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAgdHlwZTogRWxlbWVudEtpbmRzLmltYWdlO1xuICAgIGNoaWxkcmVuOiBFbXB0eVRleHRbXTtcbiAgICBmaWxlPzogRmlsZTtcbiAgICBuYW1lPzogc3RyaW5nO1xuICAgIHdpZHRoPzogbnVtYmVyO1xuICAgIGhlaWdodD86IG51bWJlcjtcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgdGh1bWJVcmw/OiBzdHJpbmc7XG4gICAgb3JpZ2luVXJsPzogc3RyaW5nO1xuICAgIGFsaWduPzogQWxpZ25tZW50O1xuICAgIGxheW91dD86IExheW91dFR5cGVzO1xuICAgIHJlU2l6ZWQ/OiBib29sZWFuO1xuICAgIHNpemU/OiBudW1iZXI7XG4gICAgZXh0ZXJuYWxTb3VyY2U/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlRWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy50YWJsZTtcbiAgICBjaGlsZHJlbjogVGFibGVSb3dFbGVtZW50W107XG4gICAgY29sdW1ucz86IFRoZVRhYmxlQ29sdW1uW107XG4gICAgb3B0aW9ucz86IFRoZVRhYmxlT3B0aW9ucztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZVJvd0VsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMudGFibGVSb3c7XG4gICAgY2hpbGRyZW46IFRhYmxlQ2VsbEVsZW1lbnRbXTtcbiAgICBoZWFkZXI/OiBib29sZWFuO1xuICAgIGhlaWdodD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUYWJsZUNlbGxFbGVtZW50IGV4dGVuZHMgVGhlRWxlbWVudCB7XG4gICAga2V5Pzogc3RyaW5nO1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy50YWJsZUNlbGw7XG4gICAgY29sc3Bhbj86IG51bWJlcjtcbiAgICByb3dzcGFuPzogbnVtYmVyO1xuICAgIGhpZGRlbj86IGJvb2xlYW47XG4gICAgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEhyRWxlbWVudCBleHRlbmRzIFRoZUVsZW1lbnQge1xuICAgIHR5cGU6IEVsZW1lbnRLaW5kcy5ocjtcbiAgICBjaGlsZHJlbjogRW1wdHlUZXh0W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29kZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuY29kZTtcbiAgICBjaGlsZHJlbjogRW1wdHlUZXh0W107XG4gICAgY29udGVudD86IHN0cmluZztcbiAgICBsYW5ndWFnZT86IHN0cmluZztcbiAgICBoZWlnaHQ/OiBudW1iZXI7XG4gICAgYXV0b1dyYXA/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVkaXRhYmxlVm9pZEVsZW1lbnQge1xuICAgIHR5cGU6ICdlZGl0YWJsZS12b2lkJztcbiAgICBjaGlsZHJlbjogRW1wdHlUZXh0W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5saW5lQ29kZUVsZW1lbnQgZXh0ZW5kcyBUaGVFbGVtZW50IHtcbiAgICB0eXBlOiBFbGVtZW50S2luZHMuaW5saW5lQ29kZTtcbn1cblxuZXhwb3J0IHR5cGUgQ3VzdG9tRWxlbWVudCA9XG4gICAgfCBCbG9ja1F1b3RlRWxlbWVudFxuICAgIHwgTnVtYmVyZWRMaXN0RWxlbWVudFxuICAgIHwgQnVsbGV0ZWRMaXN0RWxlbWVudFxuICAgIHwgVG9kb0l0ZW1FbGVtZW50XG4gICAgfCBIZWFkaW5nT25lRWxlbWVudFxuICAgIHwgSGVhZGluZ1R3b0VsZW1lbnRcbiAgICB8IEhlYWRpbmdUaHJlZUVsZW1lbnRcbiAgICB8IEhlYWRpbmdGb3VyRWxlbWVudFxuICAgIHwgSGVhZGluZ0ZpdmVFbGVtZW50XG4gICAgfCBIZWFkaW5nU2l4RWxlbWVudFxuICAgIHwgSW1hZ2VFbGVtZW50XG4gICAgfCBMaW5rRWxlbWVudFxuICAgIHwgTGlzdEl0ZW1FbGVtZW50XG4gICAgfCBQYXJhZ3JhcGhFbGVtZW50XG4gICAgfCBUYWJsZUVsZW1lbnRcbiAgICB8IFRhYmxlUm93RWxlbWVudFxuICAgIHwgVGFibGVDZWxsRWxlbWVudFxuICAgIHwgSHJFbGVtZW50XG4gICAgfCBJbmxpbmVDb2RlRWxlbWVudFxuICAgIHwgQ29kZUVsZW1lbnQ7XG5cbmV4cG9ydCB0eXBlIEN1c3RvbVRleHQgPSB7XG4gICAgYm9sZD86IGJvb2xlYW47XG4gICAgaXRhbGljPzogYm9vbGVhbjtcbiAgICBjb2RlPzogYm9vbGVhbjtcbiAgICB0ZXh0OiBzdHJpbmc7XG4gICAgdW5kZXJsaW5lZD86IGJvb2xlYW47XG4gICAgY29sb3I/OiBzdHJpbmc7XG4gICAgW2BiYWNrZ3JvdW5kLWNvbG9yYF0/OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBFbXB0eVRleHQgPSB7XG4gICAgdGV4dDogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgQ3VzdG9tRWRpdG9yID0gVGhlRWRpdG9yO1xuXG50eXBlIEdldDxULCBQIGV4dGVuZHMga2V5b2YgVD4gPSBUW1BdO1xuZXhwb3J0IHR5cGUgQ3VzdG9tRWxlbWVudEtpbmRzID0gR2V0PEVsZW1lbnQsICd0eXBlJz47XG4iXX0=