@worktile/theia 14.2.1 → 14.2.4

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.
@@ -147,7 +147,8 @@ export class TheToolbarComponent {
147
147
  items.push(item);
148
148
  }
149
149
  else {
150
- group.push(item);
150
+ const isFirstSplit = group.length === 0 && item.key === ToolbarActionTypes.split;
151
+ !isFirstSplit && group.push(item);
151
152
  }
152
153
  }
153
154
  return {
@@ -257,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
257
258
  type: HostBinding,
258
259
  args: ['style.justifyContent']
259
260
  }] } });
260
- //# 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    moreGroupMenu = ToolbarMoreGroup;\n\n    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(): void {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.selectionChange(this.editor);\n\n        if (this.isMore) {\n            this.resizeElement();\n        }\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        this.renderToolbarView();\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        this.components.clear();\n        this.toolbarContainer.clear();\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\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        });\n        this.cdr.markForCheck();\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 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 = 13;\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 + defaultItemWidth;\n            const allowRender = elementWidth && elementWidth >= remainingWidth;\n            elementWidth -= itemWidth;\n\n            if (allowRender) {\n                items.push(item);\n            } else {\n                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"]}
261
+ //# 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    moreGroupMenu = ToolbarMoreGroup;\n\n    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(): void {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.selectionChange(this.editor);\n\n        if (this.isMore) {\n            this.resizeElement();\n        }\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        this.renderToolbarView();\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        this.components.clear();\n        this.toolbarContainer.clear();\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\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        });\n        this.cdr.markForCheck();\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 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 = 13;\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 + defaultItemWidth;\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"]}
@@ -119,10 +119,10 @@ export class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
119
119
  }
120
120
  }
121
121
  TheToolbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheToolbarDropdownComponent, deps: [{ token: i0.ElementRef }, { token: i1.ThyPopover }, { token: i0.ViewContainerRef }, { token: i2.Overlay }], target: i0.ɵɵFactoryTarget.Component });
122
- TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode\"\n thyAction\n [thyActionIcon]=\"activeIcon\"\n [thyActionActive]=\"activeDropdown\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <thy-icon *ngIf=\"!toolbarItem.isHideDropdownActionIcon\" class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n class=\"d-flex justify-content-between text-secondary\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [ngStyle]=\"menu?.styles\"\n [thyDropdownMenuItemActive]=\"activeKeys.includes(menu.key)\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"itemMousedown($event, menu)\"\n >\n <div class=\"d-flex align-items-center\">\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </div>\n <div class=\"menu-item-right font-size-sm text-muted\" *ngIf=\"menu.shortcutKey\">{{ menu.shortcutKey }}</div>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: i5.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i6.ThyDropdownMenuDividerComponent, selector: "thy-dropdown-menu-divider" }, { kind: "directive", type: i6.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "directive", type: i6.ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }, { kind: "directive", type: i6.ThyDropdownMenuItemIconDirective, selector: "[thyDropdownMenuItemIcon]" }, { kind: "directive", type: i6.ThyDropdownMenuItemActiveDirective, selector: "[thyDropdownMenuItemActive]", inputs: ["thyDropdownMenuItemActive"] }] });
122
+ TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode\"\n thyAction\n [thyActionIcon]=\"activeIcon\"\n [thyActionActive]=\"activeDropdown\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <thy-icon *ngIf=\"!toolbarItem.isHideDropdownActionIcon\" class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n class=\"d-flex justify-content-between text-secondary\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [ngStyle]=\"menu?.styles\"\n [thyDropdownMenuItemActive]=\"activeKeys.includes(menu.key)\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"itemMousedown($event, menu)\"\n >\n <div class=\"d-flex align-items-center\">\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span class=\"text-body\" *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </div>\n <div class=\"menu-item-right font-size-sm text-muted\" *ngIf=\"menu.shortcutKey\">{{ menu.shortcutKey }}</div>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: i5.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i6.ThyDropdownMenuDividerComponent, selector: "thy-dropdown-menu-divider" }, { kind: "directive", type: i6.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "directive", type: i6.ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }, { kind: "directive", type: i6.ThyDropdownMenuItemIconDirective, selector: "[thyDropdownMenuItemIcon]" }, { kind: "directive", type: i6.ThyDropdownMenuItemActiveDirective, selector: "[thyDropdownMenuItemActive]", inputs: ["thyDropdownMenuItemActive"] }] });
123
123
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheToolbarDropdownComponent, decorators: [{
124
124
  type: Component,
125
- args: [{ selector: 'the-toolbar-dropdown', template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode\"\n thyAction\n [thyActionIcon]=\"activeIcon\"\n [thyActionActive]=\"activeDropdown\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <thy-icon *ngIf=\"!toolbarItem.isHideDropdownActionIcon\" class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n class=\"d-flex justify-content-between text-secondary\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [ngStyle]=\"menu?.styles\"\n [thyDropdownMenuItemActive]=\"activeKeys.includes(menu.key)\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"itemMousedown($event, menu)\"\n >\n <div class=\"d-flex align-items-center\">\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </div>\n <div class=\"menu-item-right font-size-sm text-muted\" *ngIf=\"menu.shortcutKey\">{{ menu.shortcutKey }}</div>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n" }]
125
+ args: [{ selector: 'the-toolbar-dropdown', template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode\"\n thyAction\n [thyActionIcon]=\"activeIcon\"\n [thyActionActive]=\"activeDropdown\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <thy-icon *ngIf=\"!toolbarItem.isHideDropdownActionIcon\" class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n thyTooltipPlacement=\"top\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n class=\"d-flex justify-content-between text-secondary\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [ngStyle]=\"menu?.styles\"\n [thyDropdownMenuItemActive]=\"activeKeys.includes(menu.key)\"\n (mousedown)=\"preventDefault($event)\"\n (click)=\"itemMousedown($event, menu)\"\n >\n <div class=\"d-flex align-items-center\">\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span class=\"text-body\" *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </div>\n <div class=\"menu-item-right font-size-sm text-muted\" *ngIf=\"menu.shortcutKey\">{{ menu.shortcutKey }}</div>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n" }]
126
126
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ThyPopover }, { type: i0.ViewContainerRef }, { type: i2.Overlay }]; }, propDecorators: { className: [{
127
127
  type: HostBinding,
128
128
  args: ['class']
@@ -138,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
138
138
  type: ViewChild,
139
139
  args: ['dropdownTemplate', { static: true }]
140
140
  }] } });
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.ts","../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAsB,KAAK,EAAe,SAAS,EAAoB,WAAW,EAAE,MAAM,eAAe,CAAC;AAI5H,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,2CAA2C,CAAC;;;;;;;;AAMnF,MAAM,OAAO,2BAA4B,SAAQ,sBAAsB;IAqCnE,YACW,UAAsB,EACrB,UAAsB,EACtB,gBAAkC,EAClC,OAAgB;QAExB,KAAK,EAAE,CAAC;QALD,eAAU,GAAV,UAAU,CAAY;QACrB,eAAU,GAAV,UAAU,CAAY;QACtB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,YAAO,GAAP,OAAO,CAAS;QAxCN,cAAS,GAAG,gCAAgC,CAAC;QAMnE,eAAU,GAAiB,EAAE,CAAC;QAE9B,iBAAY,GAAG,YAAY,CAAC;IAmC5B,CAAC;IA/BD,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC,WAAW,EAAE,CAAC;IACvI,CAAC;IAED,IAAI,UAAU;QACV,IAAI,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAE;YACpC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;SAChC;QACD,OAAO,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC;IACrC,CAAC;IAED,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,WAAW,CAAC,iBAAiB,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAC1E,CAAC;IAoBD,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACtB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC;SAClD;QAED,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE;YAC3C,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC;SAC7E;IACL,CAAC;IAED,eAAe,CAAC,MAAc;QAC1B,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAC9B,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;YAC3B,IAAI,IAAI,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,EAAE;gBACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAClC;SACJ;IACL,CAAC;IAED,cAAc,CAAC,KAAiB;QAC5B,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,IAAI,CAAC,MAAM,EAAE,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE;YACxC,OAAO;SACV;QACD,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,aAAa,CAAC,KAAiB,EAAE,IAAiB;QAC9C,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,iBAAiB,EAAE;YACrC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC9B;QAED,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;YAC/B,OAAO;SACV;QAED,IAAI,IAAI,EAAE,OAAO,EAAE;YACf,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC9B;IACL,CAAC;IAED,cAAc,CAAC,KAAY;QACvB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED,mBAAmB,CAAC,KAAiB;QACjC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAClE,MAAM,EAAE,KAAK,CAAC,aAA4B;YAC1C,UAAU,EAAE,CAAC,8BAA8B,EAAE,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC;YACnE,iBAAiB,EAAE,QAAQ;YAC3B,SAAS,EAAE,YAAY;YACvB,cAAc,EAAE,KAAK;YACrB,eAAe,EAAE,IAAI;YACrB,gBAAgB,EAAE,IAAI;YACtB,WAAW,EAAE,KAAK;YAClB,MAAM,EAAE,CAAC;YACT,QAAQ,EAAE,CAAC;YACX,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;SAC7D,CAAC,CAAC;QACH,IAAI,CAAC,kBAAkB,EAAE,aAAa,EAAE,CAAC,sBAAsB,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;IACnG,CAAC;IAED,oBAAoB;QAChB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,IAAI,CAAC,kBAAkB,EAAE,KAAK,EAAE,CAAC;SACpC;IACL,CAAC;IAED,sBAAsB;QAClB,MAAM,WAAW,GAAsB;YACnC,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,OAAO;YACjB,QAAQ,EAAE,QAAQ;YAClB,OAAO,EAAE,CAAC;YACV,OAAO,EAAE,CAAC,CAAC;SACd,CAAC;QACF,MAAM,cAAc,GAAsB;YACtC,GAAG,WAAW;YACd,OAAO,EAAE,QAAQ;YACjB,QAAQ,EAAE,KAAK;YACf,OAAO,EAAE,CAAC;SACb,CAAC;QACF,OAAO,IAAI,CAAC,OAAO;aACd,QAAQ,EAAE;aACV,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC;aACpC,sBAAsB,CAAC,KAAK,CAAC;aAC7B,iBAAiB,CAAC,KAAK,CAAC;aACxB,QAAQ,CAAC,KAAK,CAAC;aACf,aAAa,CAAC,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC,CAAC;IACtD,CAAC;;wHAhJQ,2BAA2B;4GAA3B,2BAA2B,8iBCZxC,mhEAiDA;2FDrCa,2BAA2B;kBAJvC,SAAS;+BACI,sBAAsB;+KAIV,SAAS;sBAA9B,WAAW;uBAAC,OAAO;gBAEX,mBAAmB;sBAA3B,KAAK;gBA0BN,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI/C,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI/C,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Component, OnInit, ElementRef, Input, TemplateRef, ViewChild, ViewContainerRef, HostBinding } from '@angular/core';\nimport { ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { DropdownMode } from '../../constants/toolbar';\nimport { ToolbarItem, ToolbarKey } from '../../interfaces/toolbar';\nimport { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';\n\n@Component({\n    selector: 'the-toolbar-dropdown',\n    templateUrl: './toolbar-dropdown.component.html'\n})\nexport class TheToolbarDropdownComponent extends TheBaseToolbarDropdown implements OnInit {\n    @HostBinding('class') className = 'the-toolbar-dropdown-container';\n\n    @Input() itemMousedownHandle: (item: ToolbarItem) => void;\n\n    editor: Editor;\n\n    activeKeys: ToolbarKey[] = [];\n\n    dropdownMode = DropdownMode;\n\n    public dropdownPopoverRef: ThyPopoverRef<any>;\n\n    get isOpen() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    get activeIcon(): string {\n        if (this.toolbarItem.dropdownFixedIcon) {\n            return this.toolbarItem.icon;\n        }\n        return this.activeMenuItem?.icon;\n    }\n\n    get activeDropdown(): boolean {\n        return this.toolbarItem.dropdownFixedIcon && !!this.activeKeys.length;\n    }\n\n    @ViewChild('iconModeTemplate', { static: true })\n    iconModeTemplate: TemplateRef<any>;\n\n    @ViewChild('textModeTemplate', { static: true })\n    textModeTemplate: TemplateRef<any>;\n\n    @ViewChild('dropdownTemplate', { static: true })\n    dropdownTemplate: TemplateRef<any>;\n\n    constructor(\n        public elementRef: ElementRef,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.activeMenuItem) {\n            this.activeMenuItem = this.defaultDropdownItem;\n        }\n\n        if (this.toolbarItem && this.toolbarItem?.key) {\n            this.elementRef.nativeElement?.classList?.add(`${this.toolbarItem?.key}`);\n        }\n    }\n\n    selectionChange(editor: Editor) {\n        super.selectionChange(editor);\n        for (const menu of this.menus) {\n            if (menu?.active && menu?.active(editor)) {\n                this.activeKeys.push(menu.key);\n            }\n        }\n    }\n\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled) {\n            return;\n        }\n        this.openDropdownPopover(event);\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        super.execute(event);\n\n        this.closeDropdownPopover();\n\n        if (!this.toolbarItem.dropdownFixedIcon) {\n            this.activeMenuItem = item;\n        }\n\n        if (this.itemMousedownHandle) {\n            this.itemMousedownHandle(item);\n            return;\n        }\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    preventDefault(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    openDropdownPopover(event: MouseEvent) {\n        this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {\n            origin: event.currentTarget as HTMLElement,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            originActiveClass: 'active',\n            placement: 'bottomLeft',\n            insideClosable: false,\n            outsideClosable: true,\n            backdropClosable: true,\n            hasBackdrop: false,\n            offset: 4,\n            minWidth: 0,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n        this.dropdownPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());\n    }\n\n    closeDropdownPopover() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef?.close();\n        }\n    }\n\n    createPositionStrategy() {\n        const topPosition: ConnectedPosition = {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetX: 0,\n            offsetY: -4\n        };\n        const bottomPosition: ConnectedPosition = {\n            ...topPosition,\n            originY: 'bottom',\n            overlayY: 'top',\n            offsetY: 4\n        };\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.elementRef)\n            .withFlexibleDimensions(false)\n            .withGrowAfterOpen(false)\n            .withPush(false)\n            .withPositions([bottomPosition, topPosition]);\n    }\n}\n","<a\n    *ngIf=\"mode === dropdownMode.icon\"\n    href=\"javascript:;\"\n    class=\"icon-mode\"\n    thyAction\n    [thyActionIcon]=\"activeIcon\"\n    [thyActionActive]=\"activeDropdown\"\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"preventDefault($event)\"\n    (click)=\"toggleDropdown($event)\"\n>\n    <thy-icon *ngIf=\"!toolbarItem.isHideDropdownActionIcon\" class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n    *ngIf=\"mode !== dropdownMode.icon\"\n    href=\"javascript:;\"\n    class=\"text-mode\"\n    thyAction\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"preventDefault($event)\"\n    (click)=\"toggleDropdown($event)\"\n>\n    <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n    <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n    <div class=\"thy-dropdown-menu\">\n        <ng-container *ngFor=\"let menu of menus\">\n            <a\n                *ngIf=\"menu.key !== 'split'\"\n                class=\"d-flex justify-content-between text-secondary\"\n                href=\"javascript:;\"\n                thyDropdownMenuItem\n                [ngStyle]=\"menu?.styles\"\n                [thyDropdownMenuItemActive]=\"activeKeys.includes(menu.key)\"\n                (mousedown)=\"preventDefault($event)\"\n                (click)=\"itemMousedown($event, menu)\"\n            >\n                <div class=\"d-flex align-items-center\">\n                    <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n                    <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n                </div>\n                <div class=\"menu-item-right font-size-sm text-muted\" *ngIf=\"menu.shortcutKey\">{{ menu.shortcutKey }}</div>\n            </a>\n            <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n        </ng-container>\n    </div>\n</ng-template>\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.ts","../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, TemplateRef, ViewChild, ViewContainerRef, HostBinding } from '@angular/core';\nimport { ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { DropdownMode } from '../../constants/toolbar';\nimport { ToolbarItem, ToolbarKey } from '../../interfaces/toolbar';\nimport { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';\n\n@Component({\n    selector: 'the-toolbar-dropdown',\n    templateUrl: './toolbar-dropdown.component.html'\n})\nexport class TheToolbarDropdownComponent extends TheBaseToolbarDropdown implements OnInit {\n    @HostBinding('class') className = 'the-toolbar-dropdown-container';\n\n    @Input() itemMousedownHandle: (item: ToolbarItem) => void;\n\n    editor: Editor;\n\n    activeKeys: ToolbarKey[] = [];\n\n    dropdownMode = DropdownMode;\n\n    public dropdownPopoverRef: ThyPopoverRef<any>;\n\n    get isOpen() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    get activeIcon(): string {\n        if (this.toolbarItem.dropdownFixedIcon) {\n            return this.toolbarItem.icon;\n        }\n        return this.activeMenuItem?.icon;\n    }\n\n    get activeDropdown(): boolean {\n        return this.toolbarItem.dropdownFixedIcon && !!this.activeKeys.length;\n    }\n\n    @ViewChild('iconModeTemplate', { static: true })\n    iconModeTemplate: TemplateRef<any>;\n\n    @ViewChild('textModeTemplate', { static: true })\n    textModeTemplate: TemplateRef<any>;\n\n    @ViewChild('dropdownTemplate', { static: true })\n    dropdownTemplate: TemplateRef<any>;\n\n    constructor(\n        public elementRef: ElementRef,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.activeMenuItem) {\n            this.activeMenuItem = this.defaultDropdownItem;\n        }\n\n        if (this.toolbarItem && this.toolbarItem?.key) {\n            this.elementRef.nativeElement?.classList?.add(`${this.toolbarItem?.key}`);\n        }\n    }\n\n    selectionChange(editor: Editor) {\n        super.selectionChange(editor);\n        for (const menu of this.menus) {\n            if (menu?.active && menu?.active(editor)) {\n                this.activeKeys.push(menu.key);\n            }\n        }\n    }\n\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled) {\n            return;\n        }\n        this.openDropdownPopover(event);\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        super.execute(event);\n\n        this.closeDropdownPopover();\n\n        if (!this.toolbarItem.dropdownFixedIcon) {\n            this.activeMenuItem = item;\n        }\n\n        if (this.itemMousedownHandle) {\n            this.itemMousedownHandle(item);\n            return;\n        }\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    preventDefault(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    openDropdownPopover(event: MouseEvent) {\n        this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {\n            origin: event.currentTarget as HTMLElement,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            originActiveClass: 'active',\n            placement: 'bottomLeft',\n            insideClosable: false,\n            outsideClosable: true,\n            backdropClosable: true,\n            hasBackdrop: false,\n            offset: 4,\n            minWidth: 0,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n        this.dropdownPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());\n    }\n\n    closeDropdownPopover() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef?.close();\n        }\n    }\n\n    createPositionStrategy() {\n        const topPosition: ConnectedPosition = {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetX: 0,\n            offsetY: -4\n        };\n        const bottomPosition: ConnectedPosition = {\n            ...topPosition,\n            originY: 'bottom',\n            overlayY: 'top',\n            offsetY: 4\n        };\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.elementRef)\n            .withFlexibleDimensions(false)\n            .withGrowAfterOpen(false)\n            .withPush(false)\n            .withPositions([bottomPosition, topPosition]);\n    }\n}\n","<a\n    *ngIf=\"mode === dropdownMode.icon\"\n    href=\"javascript:;\"\n    class=\"icon-mode\"\n    thyAction\n    [thyActionIcon]=\"activeIcon\"\n    [thyActionActive]=\"activeDropdown\"\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"preventDefault($event)\"\n    (click)=\"toggleDropdown($event)\"\n>\n    <thy-icon *ngIf=\"!toolbarItem.isHideDropdownActionIcon\" class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n    *ngIf=\"mode !== dropdownMode.icon\"\n    href=\"javascript:;\"\n    class=\"text-mode\"\n    thyAction\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"preventDefault($event)\"\n    (click)=\"toggleDropdown($event)\"\n>\n    <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n    <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n    <div class=\"thy-dropdown-menu\">\n        <ng-container *ngFor=\"let menu of menus\">\n            <a\n                *ngIf=\"menu.key !== 'split'\"\n                class=\"d-flex justify-content-between text-secondary\"\n                href=\"javascript:;\"\n                thyDropdownMenuItem\n                [ngStyle]=\"menu?.styles\"\n                [thyDropdownMenuItemActive]=\"activeKeys.includes(menu.key)\"\n                (mousedown)=\"preventDefault($event)\"\n                (click)=\"itemMousedown($event, menu)\"\n            >\n                <div class=\"d-flex align-items-center\">\n                    <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n                    <span class=\"text-body\" *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n                </div>\n                <div class=\"menu-item-right font-size-sm text-muted\" *ngIf=\"menu.shortcutKey\">{{ menu.shortcutKey }}</div>\n            </a>\n            <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n        </ng-container>\n    </div>\n</ng-template>\n"]}
@@ -30,6 +30,7 @@ export var PluginMenuIcons;
30
30
  PluginMenuIcons["code"] = "the-icon-code";
31
31
  PluginMenuIcons["table"] = "the-icon-table";
32
32
  PluginMenuIcons["hr"] = "the-icon-hr";
33
+ PluginMenuIcons["checkItem"] = "the-icon-check-item";
33
34
  })(PluginMenuIcons || (PluginMenuIcons = {}));
34
35
  export const PluginMenuSvgs = [
35
36
  {
@@ -267,6 +268,37 @@ export const PluginMenuSvgs = [
267
268
  </g>
268
269
  </g>
269
270
  </svg>`
271
+ },
272
+ {
273
+ key: PluginMenuIcons.checkItem,
274
+ svg: `<svg width="36px" height="36px" viewBox="0 0 36 36" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
275
+ <title>待办事项</title>
276
+ <g id="待办事项" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
277
+ <g id="icon备份-2">
278
+ <rect id="矩形" stroke="#EEEEEE" fill="#FFFFFF" x="0.5" y="0.5" width="35" height="35" rx="4"></rect>
279
+ <g id="编组-4" transform="translate(5.000000, 12.000000)">
280
+ <g id="编组-3" transform="translate(15.900000, 0.000000)" fill="#CACACA">
281
+ <path d="M0.6,5.58676508 L3.54334707,5.58676508 C3.87471792,5.58676508 4.14334707,5.85539423 4.14334707,6.18676508 C4.14334707,6.51813593 3.87471792,6.78676508 3.54334707,6.78676508 L0.6,6.78676508 C0.26862915,6.78676508 1.81902998e-12,6.51813593 1.8189894e-12,6.18676508 C1.81894882e-12,5.85539423 0.26862915,5.58676508 0.6,5.58676508 Z" id="矩形备份-74"></path>
282
+ <path d="M0.6,0 L6.33577755,0 C6.6671484,-9.15528894e-16 6.93577755,0.26862915 6.93577755,0.6 C6.93577755,0.93137085 6.6671484,1.2 6.33577755,1.2 L0.6,1.2 C0.26862915,1.2 4.05812251e-17,0.93137085 0,0.6 C-4.05812251e-17,0.26862915 0.26862915,1.7189414e-16 0.6,0 Z" id="矩形备份-75"></path>
283
+ <path d="M0.6,11.1735302 L6.33577755,11.1735302 C6.6671484,11.1735302 6.93577755,11.4421593 6.93577755,11.7735302 C6.93577755,12.104901 6.6671484,12.3735302 6.33577755,12.3735302 L0.6,12.3735302 C0.26862915,12.3735302 4.05812251e-17,12.104901 0,11.7735302 C-4.05812251e-17,11.4421593 0.26862915,11.1735302 0.6,11.1735302 Z" id="矩形备份-77"></path>
284
+ </g>
285
+ <g id="3.Data-Input-数据输入/-3.Checkbox-多选框-/-3.Select" transform="translate(0.000000, 0.000000)" stroke="#6698FF">
286
+ <path d="M10.500003,0.5 C10.7761467,0.5 11.0261426,0.611923561 11.2071022,0.792884987 C11.3880653,0.973849926 11.499988,1.22385308 11.499988,1.5 L11.499988,1.5 L11.499988,10.50003 C11.499988,10.7761733 11.3880629,11.0261769 11.2070985,11.2071431 C11.0261394,11.388104 10.7761453,11.50003 10.500003,11.50003 L10.500003,11.50003 L1.4999715,11.50003 C1.22385428,11.50003 0.973862046,11.3880904 0.792898366,11.2071233 C0.611938132,11.0261596 0.5,10.7761657 0.5,10.50003 L0.5,10.50003 L0.5,1.5 C0.5,1.22386076 0.611935724,0.973867183 0.79289468,0.792904788 C0.973858868,0.611937162 1.22385287,0.5 1.4999715,0.5 L1.4999715,0.5 Z" id="圆角矩形-12-拷贝-12" fill="#6698FF" opacity="0.300000012"></path>
287
+ <polyline id="路径" stroke-width="1.5" points="3.0000075 5.33991979 5.2500075 7.58991979 8.8425368 3.750015"></polyline>
288
+ </g>
289
+ </g>
290
+ </g>
291
+ </g>
292
+ </svg>`
270
293
  }
271
294
  ];
272
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.js","sourceRoot":"","sources":["../../../../packages/src/constants/plugin-menu.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAEpE,MAAM,CAAC,MAAM,iBAAiB,GAA8B;IACxD,GAAG,sBAAsB;IACzB,YAAY,CAAC,YAAY;IACzB,YAAY,CAAC,YAAY;IACzB,YAAY,CAAC,IAAI;IACjB,EAAE,SAAS,EAAE,IAAI,EAAE;IACnB,YAAY,CAAC,KAAK;IAClB,YAAY,CAAC,KAAK;IAClB,YAAY,CAAC,UAAU;IACvB,YAAY,CAAC,EAAE;IACf,YAAY,CAAC,IAAI;CACpB,CAAC;AAEF,MAAM,CAAN,IAAY,qBAGX;AAHD,WAAY,qBAAqB;IAC7B,0CAAiB,CAAA;IACjB,4CAAmB,CAAA;AACvB,CAAC,EAHW,qBAAqB,KAArB,qBAAqB,QAGhC;AAED,MAAM,CAAN,IAAY,eAaX;AAbD,WAAY,eAAe;IACvB,qDAAkC,CAAA;IAClC,qDAAkC,CAAA;IAClC,uDAAoC,CAAA;IACpC,sDAAmC,CAAA;IACnC,0DAAuC,CAAA;IACvC,0DAAuC,CAAA;IACvC,yCAAsB,CAAA;IACtB,2CAAwB,CAAA;IACxB,sDAAmC,CAAA;IACnC,yCAAsB,CAAA;IACtB,2CAAwB,CAAA;IACxB,qCAAkB,CAAA;AACtB,CAAC,EAbW,eAAe,KAAf,eAAe,QAa1B;AAED,MAAM,CAAC,MAAM,cAAc,GAAG;IAC1B;QACI,GAAG,EAAE,eAAe,CAAC,KAAK;QAC1B,GAAG,EAAE;;;;;;;;;;;;;OAaN;KACF;IACD;QACI,GAAG,EAAE,eAAe,CAAC,UAAU;QAC/B,GAAG,EAAE;;;;;;;;;;;;;;;;;;;;;;WAsBF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,IAAI;QACzB,GAAG,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;WAyBF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,KAAK;QAC1B,GAAG,EAAE;;;;;;;;;;;;;;WAcF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,EAAE;QACvB,GAAG,EAAE;;;;;;;;;;;;;;;;;;;;;;;WAuBF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,SAAS;QAC9B,GAAG,EAAE;;;;;;;;;;;WAWF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,SAAS;QAC9B,GAAG,EAAE;;;;;;;;;;;WAWF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,SAAS;QAC9B,GAAG,EAAE;;;;;;;;;;;WAWF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,SAAS;QAC9B,GAAG,EAAE;;;;;;;;;;;WAWF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,YAAY;QACjC,GAAG,EAAE;;;;;;;;;;;;;;;;;WAiBF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,YAAY;QACjC,GAAG,EAAE;;;;;;;;;;;;;;;WAeF;KACN;IACD;QACI,GAAG,EAAE,eAAe,CAAC,IAAI;QACzB,GAAG,EAAE;;;;;;;;;;;;;;;WAeF;KACN;CACJ,CAAC","sourcesContent":["import { ThePluginMenuItemConfig } from '../interfaces/plugins/plugin-menu';\nimport { ElementKinds, STANDARD_HEADING_TYPES } from './node-types';\n\nexport const DefaultPluginMenu: ThePluginMenuItemConfig[] = [\n    ...STANDARD_HEADING_TYPES,\n    ElementKinds.numberedList,\n    ElementKinds.bulletedList,\n    ElementKinds.link,\n    { groupName: '基础' },\n    ElementKinds.image,\n    ElementKinds.table,\n    ElementKinds.blockquote,\n    ElementKinds.hr,\n    ElementKinds.code\n];\n\nexport enum ThePluginMenuItemType {\n    icon = 'iconMenu',\n    group = 'groupMenu'\n}\n\nexport enum PluginMenuIcons {\n    heading_1 = `the-icon-heading-one`,\n    heading_2 = `the-icon-heading-two`,\n    heading_3 = `the-icon-heading-three`,\n    heading_4 = `the-icon-heading-four`,\n    numberedList = 'the-icon-numbered-list',\n    bulletedList = 'the-icon-bulleted-list',\n    link = 'the-icon-link',\n    image = `the-icon-image`,\n    blockquote = `the-icon-block-quote`,\n    code = `the-icon-code`,\n    table = `the-icon-table`,\n    hr = `the-icon-hr`\n}\n\nexport const PluginMenuSvgs = [\n    {\n        key: PluginMenuIcons.image,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n<title>图片</title>\n    <g id=\"图片\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"icon\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"矩形\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <g id=\"编组\" transform=\"translate(8.500000, 10.000000)\">\n                <path d=\"M0,1 C0,0.447715 0.447715,0 1,0 L18,0 C18.5523,0 19,0.447715 19,1 L19,15 C19,15.5523 18.5523,16 18,16 L1,16 C0.447715,16 0,15.5523 0,15 L0,1 Z\" id=\"路径\" fill=\"#EEEEEE\"></path>\n                <path d=\"M4.5,7 C5.60453333,7 6.5,6.10453333 6.5,5 C6.5,3.89546667 5.60453333,3 4.5,3 C3.39546667,3 2.5,3.89546667 2.5,5 C2.5,6.10453333 3.39546667,7 4.5,7 Z\" id=\"路径\" fill=\"#F6C659\"></path>\n                <path d=\"M5,9 L7.5,11 L10.5,7.5 L19,13 L19,15 C19,15.5523 18.5523,16 18,16 L1,16 C0.447715,16 0,15.5523 0,15 L0,13 L5,9 Z\" id=\"路径\" fill=\"#6698FF\"></path>\n                <path d=\"M5,9 L7.488,10.99 L3.165,16 L1,16 C0.447715,16 0,15.5523 0,15 L0,13 L5,9 Z\" id=\"形状结合\" fill=\"#CAD9F8\"></path>\n            </g>\n        </g>\n    </g>\n</svg>`\n    },\n    {\n        key: PluginMenuIcons.blockquote,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>引用</title>\n    <defs>\n        <rect id=\"path-1\" x=\"1\" y=\"1\" width=\"34\" height=\"34\" rx=\"4\"></rect>\n    </defs>\n    <g id=\"引用\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"矩形\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"蒙版\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <mask id=\"mask-2\" fill=\"white\">\n                <use xlink:href=\"#path-1\"></use>\n            </mask>\n            <use id=\"蒙版\" fill=\"#FFFFFF\" xlink:href=\"#path-1\"></use>\n            <g id=\"编组-34\" mask=\"url(#mask-2)\">\n                <g transform=\"translate(7.000000, 7.600000)\">\n                    <path d=\"M-9.3,9.9 L10.5,9.9 C10.8313708,9.9 11.1,10.1686292 11.1,10.5 C11.1,10.8313708 10.8313708,11.1 10.5,11.1 L-9.3,11.1 C-9.63137085,11.1 -9.9,10.8313708 -9.9,10.5 C-9.9,10.1686292 -9.63137085,9.9 -9.3,9.9 Z\" id=\"矩形备份-86\" fill=\"#AAAAAA\" transform=\"translate(0.600000, 10.500000) rotate(-270.000000) translate(-0.600000, -10.500000) \"></path>\n                    <path d=\"M12.0569495,0.107381518 C9.05340743,2.09055298 7.38481149,4.39881214 7.05114973,7.03213028 C6.53171396,11.1315969 10.097464,13.1381708 11.9041919,11.3352765 C13.7109198,9.53238214 12.6278961,7.24401116 11.3196447,6.61849713 C10.0113932,5.99294208 9.21135004,6.21080993 9.35090591,5.37489124 C9.49046177,4.53901356 11.3517118,2.22140491 12.9868965,1.14207129 C13.0953823,1.04722312 13.1366628,0.863185692 13.0322053,0.723558362 C12.9634843,0.631744678 12.8287146,0.451664378 12.6278961,0.18330516 C12.4522847,-0.0513630698 12.2840519,-0.042579465 12.0569495,0.107381518 Z M19.9642908,0.107381518 C16.9607886,2.09055298 15.2921807,4.39881214 14.9585069,7.03213028 C14.4390911,11.1315969 18.0048451,13.1381708 19.811573,11.3352765 C21.618301,9.53238214 20.5352773,7.24401116 19.2270258,6.61849713 C17.9187744,5.99294208 17.1186913,6.21080993 17.2582871,5.37489124 C17.3978429,4.53901356 19.259093,2.22140491 20.8942776,1.14207129 C21.0027635,1.04722312 21.0440439,0.863185692 20.9395466,0.723558362 C20.8708654,0.631744678 20.7360957,0.451664378 20.5352773,0.18330516 C20.3596658,-0.0513630698 20.191433,-0.042579465 19.9642908,0.107381518 Z\" id=\"形状结合\" fill=\"#CACACA\" transform=\"translate(14.000000, 6.000000) rotate(-180.000000) translate(-14.000000, -6.000000) \"></path>\n                    <path d=\"M6.6,20.4 L15.7517228,20.4 C16.0830937,20.4 16.3517228,20.6686292 16.3517228,21 C16.3517228,21.3313708 16.0830937,21.6 15.7517228,21.6 L6.6,21.6 C6.26862915,21.6 6,21.3313708 6,21 C6,20.6686292 6.26862915,20.4 6.6,20.4 Z\" id=\"矩形备份-88\" fill=\"#CACACA\"></path>\n                    <rect id=\"矩形备份-87\" fill=\"#CACACA\" x=\"6\" y=\"15.4\" width=\"16\" height=\"1.2\" rx=\"0.6\"></rect>\n                </g>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.code,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>代码块</title>\n    <defs>\n        <rect id=\"path-1\" x=\"1\" y=\"1\" width=\"34\" height=\"34\" rx=\"4\"></rect>\n    </defs>\n    <g id=\"代码块\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"icon\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"蒙版\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <mask id=\"mask-2\" fill=\"white\">\n                <use xlink:href=\"#path-1\"></use>\n            </mask>\n            <use id=\"蒙版\" fill=\"#FFFFFF\" xlink:href=\"#path-1\"></use>\n            <g id=\"编组-24\" mask=\"url(#mask-2)\">\n                <g transform=\"translate(6.000000, 6.000000)\">\n                    <rect id=\"矩形备份-60\" fill=\"#F5F5F5\" x=\"0\" y=\"0\" width=\"43\" height=\"24\" rx=\"2\"></rect>\n                    <path d=\"M2,0 L6,0 L6,0 L6,24 L2,24 C0.8954305,24 1.3527075e-16,23.1045695 0,22 L0,2 C-1.3527075e-16,0.8954305 0.8954305,2.02906125e-16 2,0 Z\" id=\"矩形备份-60\" fill=\"#EEEEEE\"></path>\n                    <path d=\"M2.6,4 L3.4,4 C3.73137085,4 4,4.26862915 4,4.6 C4,4.93137085 3.73137085,5.2 3.4,5.2 L2.6,5.2 C2.26862915,5.2 2,4.93137085 2,4.6 C2,4.26862915 2.26862915,4 2.6,4 Z M2.6,9 L3.4,9 C3.73137085,9 4,9.26862915 4,9.6 C4,9.93137085 3.73137085,10.2 3.4,10.2 L2.6,10.2 C2.26862915,10.2 2,9.93137085 2,9.6 C2,9.26862915 2.26862915,9 2.6,9 Z M2.6,14 L3.4,14 C3.73137085,14 4,14.2686292 4,14.6 C4,14.9313708 3.73137085,15.2 3.4,15.2 L2.6,15.2 C2.26862915,15.2 2,14.9313708 2,14.6 C2,14.2686292 2.26862915,14 2.6,14 Z M2.6,19 L3.4,19 C3.73137085,19 4,19.2686292 4,19.6 C4,19.9313708 3.73137085,20.2 3.4,20.2 L2.6,20.2 C2.26862915,20.2 2,19.9313708 2,19.6 C2,19.2686292 2.26862915,19 2.6,19 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n                    <path d=\"M10.6,4 L23.8215948,4 C24.1529656,4 24.4215948,4.26862915 24.4215948,4.6 C24.4215948,4.93137085 24.1529656,5.2 23.8215948,5.2 L10.6,5.2 C10.2686292,5.2 10,4.93137085 10,4.6 C10,4.26862915 10.2686292,4 10.6,4 Z\" id=\"矩形备份-61\" fill=\"#CACACA\"></path>\n                    <path d=\"M15.6,9 L23.9488547,9 C24.2802256,9 24.5488547,9.26862915 24.5488547,9.6 C24.5488547,9.93137085 24.2802256,10.2 23.9488547,10.2 L15.6,10.2 C15.2686292,10.2 15,9.93137085 15,9.6 C15,9.26862915 15.2686292,9 15.6,9 Z\" id=\"矩形备份-63\" fill=\"#FF7575\"></path>\n                    <path d=\"M10.6,14 L21.7142342,14 C22.0456051,14 22.3142342,14.2686292 22.3142342,14.6 C22.3142342,14.9313708 22.0456051,15.2 21.7142342,15.2 L10.6,15.2 C10.2686292,15.2 10,14.9313708 10,14.6 C10,14.2686292 10.2686292,14 10.6,14 Z\" id=\"矩形备份-65\" fill=\"#CACACA\"></path>\n                    <path d=\"M13.6,19 L29.1044747,19 C29.4358456,19 29.7044747,19.2686292 29.7044747,19.6 C29.7044747,19.9313708 29.4358456,20.2 29.1044747,20.2 L13.6,20.2 C13.2686292,20.2 13,19.9313708 13,19.6 C13,19.2686292 13.2686292,19 13.6,19 Z\" id=\"矩形备份-66\" fill=\"#6698FF\"></path>\n                </g>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.table,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>表格</title>\n    <g id=\"表格\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"icon\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"矩形\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <g id=\"编组-36\" transform=\"translate(6.800000, 8.800000)\">\n                <path d=\"M20.2,0 L2.2,0 C0.98497355,0 0,0.98497355 0,2.2 L0,16.2 C0,17.4150264 0.98497355,18.4 2.2,18.4 L20.2,18.4 C21.4150264,18.4 22.4,17.4150264 22.4,16.2 L22.4,2.2 C22.4,0.98497355 21.4150264,0 20.2,0 Z M20.2,1.2 C20.7522847,1.2 21.2,1.64771525 21.2,2.2 L21.2,16.2 C21.2,16.7522847 20.7522847,17.2 20.2,17.2 L2.2,17.2 C1.64771525,17.2 1.2,16.7522847 1.2,16.2 L1.2,2.2 C1.2,1.64771525 1.64771525,1.2 2.2,1.2 L20.2,1.2 Z\" id=\"矩形\" fill=\"#D8D8D8\" fill-rule=\"nonzero\"></path>\n                <path d=\"M2.2,1.2 L20.2,1.2 C20.7522847,1.2 21.2,1.64771525 21.2,2.2 L21.2,5.7 L21.2,5.7 L1.2,5.7 L1.2,2.2 C1.2,1.64771525 1.64771525,1.2 2.2,1.2 Z\" id=\"矩形\" fill=\"#EEEEEE\"></path>\n                <path d=\"M21.2,5.2 L21.2,6.4 L15.3,6.4 L15.3,11.2 L21.2,11.2 L21.2,12.4 L15.3,12.4 L15.3,17.3 L14.1,17.3 L14.1,12.4 L8.3,12.4 L8.3,17.3 L7.1,17.3 L7.1,12.4 L1.2,12.4 L1.2,11.2 L7.1,11.2 L7.1,6.4 L1.2,6.4 L1.2,5.2 L21.2,5.2 Z M14.1,6.4 L8.3,6.4 L8.3,11.2 L14.1,11.2 L14.1,6.4 Z\" id=\"形状结合\" fill=\"#D8D8D8\"></path>\n                <path d=\"M9.8,8.11197815 L12.6,8.11197815 C12.9313708,8.11197815 13.2,8.3806073 13.2,8.71197815 C13.2,9.043349 12.9313708,9.31197815 12.6,9.31197815 L9.8,9.31197815 C9.46862915,9.31197815 9.2,9.043349 9.2,8.71197815 C9.2,8.3806073 9.46862915,8.11197815 9.8,8.11197815 Z\" id=\"矩形\" fill=\"#6698FF\"></path>\n                <path d=\"M16.8,14.1134683 L19.6,14.1134683 C19.9313708,14.1134683 20.2,14.3820974 20.2,14.7134683 C20.2,15.0448391 19.9313708,15.3134683 19.6,15.3134683 L16.8,15.3134683 C16.4686292,15.3134683 16.2,15.0448391 16.2,14.7134683 C16.2,14.3820974 16.4686292,14.1134683 16.8,14.1134683 Z\" id=\"矩形备份-71\" fill=\"#FF7575\"></path>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.hr,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>分割线</title>\n    <defs>\n        <rect id=\"path-1\" x=\"1\" y=\"1\" width=\"34\" height=\"34\" rx=\"4\"></rect>\n    </defs>\n    <g id=\"分割线\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"矩形备份-60\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"蒙版\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <mask id=\"mask-2\" fill=\"white\">\n                <use xlink:href=\"#path-1\"></use>\n            </mask>\n            <use id=\"蒙版\" fill=\"#FFFFFF\" xlink:href=\"#path-1\"></use>\n            <g id=\"编组-33\" mask=\"url(#mask-2)\">\n                <g transform=\"translate(7.000000, 7.500000)\">\n                    <path d=\"M3.6,0 L17.5238673,0 C17.8552382,1.87571599e-15 18.1238673,0.26862915 18.1238673,0.6 C18.1238673,0.93137085 17.8552382,1.2 17.5238673,1.2 L3.6,1.2 C3.26862915,1.2 3,0.93137085 3,0.6 C3,0.26862915 3.26862915,1.7189414e-16 3.6,0 Z\" id=\"矩形备份-81\" fill=\"#CACACA\"></path>\n                    <path d=\"M6.47613265,15 L20.4,15 C20.7313708,15 21,15.2686292 21,15.6 C21,15.9313708 20.7313708,16.2 20.4,16.2 L6.47613265,16.2 C6.1447618,16.2 5.87613265,15.9313708 5.87613265,15.6 C5.87613265,15.2686292 6.1447618,15 6.47613265,15 Z\" id=\"矩形备份-84\" fill=\"#CACACA\"></path>\n                    <path d=\"M5.49677721,5 L14.6485,5 C14.9798709,5 15.2485,5.26862915 15.2485,5.6 C15.2485,5.93137085 14.9798709,6.2 14.6485,6.2 L5.49677721,6.2 C5.16540636,6.2 4.89677721,5.93137085 4.89677721,5.6 C4.89677721,5.26862915 5.16540636,5 5.49677721,5 Z\" id=\"矩形备份-82\" fill=\"#CACACA\"></path>\n                    <path d=\"M2.55871088,20 L11.7104337,20 C12.0418046,20 12.3104337,20.2686292 12.3104337,20.6 C12.3104337,20.9313708 12.0418046,21.2 11.7104337,21.2 L2.55871088,21.2 C2.22734003,21.2 1.95871088,20.9313708 1.95871088,20.6 C1.95871088,20.2686292 2.22734003,20 2.55871088,20 Z\" id=\"矩形备份-85\" fill=\"#CACACA\"></path>\n                    <path d=\"M0.6,10 L20.4,10 C20.7313708,10 21,10.2686292 21,10.6 C21,10.9313708 20.7313708,11.2 20.4,11.2 L0.6,11.2 C0.26862915,11.2 4.05812251e-17,10.9313708 0,10.6 C-4.05812251e-17,10.2686292 0.26862915,10 0.6,10 Z\" id=\"矩形备份-83\" fill=\"#AAAAAA\"></path>\n                </g>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_1,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H1</title>\n        <g id=\"H1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(9.000000, 7.000000)\" fill=\"#666666\">\n                    <path d=\"M7.6,0 C7.93137085,-6.08718376e-17 8.2,0.26862915 8.2,0.6 L8.2,11.4 C8.2,11.7313708 7.93137085,12 7.6,12 C7.26862915,12 7,11.7313708 7,11.4 L7,6.4 L1.2,6.4 L1.2,11.4 C1.2,11.7313708 0.93137085,12 0.6,12 C0.26862915,12 1.51603528e-16,11.7313708 0,11.4 L0,0.6 C7.04410774e-17,0.26862915 0.26862915,-1.61172767e-16 0.6,0 C0.93137085,-6.08718376e-17 1.2,0.26862915 1.2,0.6 L1.2,5.2 L7,5.2 L7,0.6 C7,0.26862915 7.26862915,-1.61172767e-16 7.6,0 Z M12.6,4.03849355 C12.9313708,4.03849355 13.2,4.3071227 13.2,4.63849355 L13.2,10.7994936 L14.3,10.8 C14.5761424,10.8 14.8,11.0238576 14.8,11.3 L14.8,11.5 C14.8,11.7761424 14.5761424,12 14.3,12 L10.8,12 C10.5238576,12 10.3,11.7761424 10.3,11.5 L10.3,11.3 C10.3,11.0238576 10.5238576,10.8 10.8,10.8 L12,10.7994936 L11.9992076,5.99749355 L11.4573367,6.503957 C11.2420362,6.70484511 10.9182139,6.71678064 10.6901851,6.54683893 L10.6095636,6.47459911 C10.6095239,6.47455657 10.6094842,6.47451403 10.6094445,6.47447147 C10.3834309,6.23210152 10.3966345,5.85241672 10.6389386,5.62633256 L12.1456416,4.22048943 C12.1994667,4.1702674 12.2600744,4.13185491 12.3242723,4.1051414 L12.4103536,4.06908195 C12.4699613,4.04923872 12.5337258,4.03849355 12.6,4.03849355 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_2,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H2</title>\n        <g id=\"H2\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(8.000000, 5.000000)\" fill=\"#666666\">\n                    <path d=\"M8.6,2 C8.93137085,2 9.2,2.26862915 9.2,2.6 L9.2,13.4 C9.2,13.7313708 8.93137085,14 8.6,14 C8.26862915,14 8,13.7313708 8,13.4 L7.999,8.4 L2.2,8.4 L2.2,13.4 C2.2,13.7313708 1.93137085,14 1.6,14 C1.26862915,14 1,13.7313708 1,13.4 L1,2.6 C1,2.26862915 1.26862915,2 1.6,2 C1.93137085,2 2.2,2.26862915 2.2,2.6 L2.2,7.2 L7.999,7.2 L8,2.6 C8,2.26862915 8.26862915,2 8.6,2 Z M10.6050397,12.9143577 C10.5088932,13.5872926 11.0315636,13.9150843 11.673969,13.8576252 L14.7346207,13.8600109 C15.0659915,13.8600109 15.3346207,13.5913818 15.3346207,13.2600109 C15.3346207,12.9286401 15.0659915,12.6600109 14.7346207,12.6600109 L11.8578688,12.6600109 C11.9286468,12.324783 12.0484495,12.1022143 12.3451123,11.7834278 C12.3790085,11.7470038 12.4146387,11.7109747 12.4520606,11.6753577 C12.4981091,11.6315301 12.5450179,11.590446 12.5935631,11.5512355 C12.734276,11.4375804 12.8707598,11.3503175 13.1225647,11.206769 C13.9119415,10.7567625 14.2357153,10.5238408 14.7581338,9.92598498 C15.7545688,8.78566459 15.3845816,6.90006903 13.8145208,6.29898616 C13.1088388,6.02882249 12.2294594,6.13691231 11.509755,6.55397744 C11.1947054,6.73654711 10.9257925,6.99181908 10.7050302,7.31345899 C10.5175098,7.5866672 10.5869735,7.96016156 10.8601817,8.147682 C11.1333899,8.33520244 11.5068842,8.26573878 11.6944047,7.99253057 C11.8168882,7.81407796 11.9552234,7.68276 12.1114244,7.59224233 C12.5322515,7.34837511 13.037157,7.28631413 13.3854792,7.41966599 C14.146101,7.71086283 14.3210515,8.60247738 13.8545136,9.13638345 C13.4412636,9.6093069 13.2103422,9.77543093 12.5282596,10.1642713 C12.2246758,10.3373378 12.0423445,10.4539139 11.8395486,10.6177142 C11.7659434,10.6771658 11.6945757,10.7396718 11.6247531,10.8061268 C11.5697738,10.8584544 11.5170831,10.911735 11.4666494,10.9659299 C11.1108509,11.3482621 10.877698,11.762253 10.7425697,12.192387 C10.6922909,12.3524319 10.6581826,12.5062255 10.6351917,12.6597188 C10.6238114,12.7356971 10.6061737,12.8994638 10.6050397,12.9143577 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_3,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H3</title>\n        <g id=\"H3\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(8.000000, 5.000000)\" fill=\"#666666\">\n                    <path d=\"M8.6,2 C8.93137085,2 9.2,2.26862915 9.2,2.6 L9.2,13.4 C9.2,13.7313708 8.93137085,14 8.6,14 C8.26862915,14 8,13.7313708 8,13.4 L7.999,8.4 L2.2,8.4 L2.2,13.4 C2.2,13.7313708 1.93137085,14 1.6,14 C1.26862915,14 1,13.7313708 1,13.4 L1,2.6 C1,2.26862915 1.26862915,2 1.6,2 C1.93137085,2 2.2,2.26862915 2.2,2.6 L2.2,7.2 L7.999,7.2 L8,2.6 C8,2.26862915 8.26862915,2 8.6,2 Z M14.8321775,7.18983161 C15.1357692,6.79527134 14.854493,6.22394171 14.356652,6.22394171 L11.0241938,6.22394171 C10.6928229,6.22394171 10.4241938,6.49257086 10.4241938,6.82394171 C10.4241938,7.15531256 10.6928229,7.42394171 11.0241938,7.42394171 L13.137929,7.42394171 L11.8506572,9.09693329 C11.7699456,9.20182941 11.7261828,9.33046927 11.7261828,9.46282318 L11.7261828,9.82922943 C11.7261828,10.1666497 12.0043217,10.4377176 12.3416301,10.4290305 C12.6787875,10.4203474 12.9830249,10.4540644 13.2547454,10.5294651 C13.7397835,10.6640601 14.0222167,11.2257408 13.8341992,11.8813236 C13.6970249,12.3596256 13.2389994,12.6238282 12.6183411,12.6238282 C12.0434265,12.6238282 11.4646434,12.41278 10.8719286,11.9820919 C10.6038559,11.7873006 10.2286305,11.8467069 10.0338391,12.1147796 C9.8390478,12.3828523 9.89845407,12.7580777 10.1665268,12.952869 C10.9617588,13.5307135 11.7826635,13.8238282 12.6183411,13.8238282 C13.7784713,13.8238282 14.6856352,13.2653796 14.9876983,12.2121406 C15.3629178,10.9038183 14.7001971,9.6852239 13.575613,9.37315895 C13.4583717,9.34062522 13.3380638,9.31356451 13.2147084,9.29196113 L14.8321775,7.18983161 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_4,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H4</title>\n        <g id=\"H4\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(8.000000, 5.000000)\" fill=\"#666666\">\n                    <path d=\"M8.6,2 C8.93137085,2 9.2,2.26862915 9.2,2.6 L9.2,13.4 C9.2,13.7313708 8.93137085,14 8.6,14 C8.26862915,14 8,13.7313708 8,13.4 L7.999,8.4 L2.2,8.4 L2.2,13.4 C2.2,13.7313708 1.93137085,14 1.6,14 C1.26862915,14 1,13.7313708 1,13.4 L1,2.6 C1,2.26862915 1.26862915,2 1.6,2 C1.93137085,2 2.2,2.26862915 2.2,2.6 L2.2,7.2 L7.999,7.2 L8,2.6 C8,2.26862915 8.26862915,2 8.6,2 Z M13.4093228,5.91341961 C13.7406441,5.91915017 14.0045876,6.19238469 13.998857,6.52370599 L13.998857,6.52370599 L13.9382755,9.99126303 L14.8179917,9.99134588 C15.1162255,9.99134588 15.3636385,10.2089355 15.4101387,10.4940228 L15.4179917,10.5913459 C15.4179917,10.9227167 15.1493626,11.1913459 14.8179917,11.1913459 L14.8179917,11.1913459 L13.9182755,11.191263 L13.8794422,13.4278503 C13.8742847,13.7260395 13.652449,13.9696526 13.3666002,14.0112157 L13.2691559,14.0173845 C12.9378346,14.0116539 12.6738911,13.7384194 12.6796217,13.4070981 L12.6796217,13.4070981 L12.7172755,11.191263 L10.5912754,11.1913459 C10.1454143,11.1913459 9.86643429,10.7287014 10.0448619,10.3426594 L10.0902034,10.2613052 L12.776267,6.18328918 C12.9048512,5.9880711 13.1278997,5.89246083 13.3452953,5.91706111 Z M12.7382755,9.99126303 L12.7662755,8.38026303 L11.7049365,9.99134588 L12.7382755,9.99126303 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.bulletedList,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>无序列表</title>\n        <g id=\"无序列表\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.icon图标/11.editor/-save备份-32\" transform=\"translate(8.000000, 9.000000)\">\n                    <circle id=\"椭圆形\" fill=\"#666666\" cx=\"1.5\" cy=\"1.5\" r=\"1.5\"></circle>\n                    <circle id=\"椭圆形备份\" fill=\"#666666\" cx=\"1.5\" cy=\"9\" r=\"1.5\"></circle>\n                    <circle id=\"椭圆形备份-2\" fill=\"#666666\" cx=\"1.5\" cy=\"16.5\" r=\"1.5\"></circle>\n                    <g id=\"编组-2\" transform=\"translate(7.000000, 1.000000)\" fill=\"#CACACA\">\n                        <path d=\"M0.59981695,7.55958265 L8.40018305,7.55958265 C8.7314528,7.55958265 9,7.82812984 9,8.1593996 C9,8.49066935 8.7314528,8.75921655 8.40018305,8.75921655 L0.59981695,8.75921655 C0.268547196,8.75921655 4.05688444e-17,8.49066935 0,8.1593996 C-4.05688444e-17,7.82812984 0.268547196,7.55958265 0.59981695,7.55958265 Z\" id=\"矩形备份-74\"></path>\n                        <path d=\"M0.59981695,0 L12.400183,0 C12.7314528,-2.44215884e-15 13,0.268547196 13,0.59981695 C13,0.931086705 12.7314528,1.1996339 12.400183,1.1996339 L0.59981695,1.1996339 C0.268547196,1.1996339 4.05688444e-17,0.931086705 0,0.59981695 C-4.05688444e-17,0.268547196 0.268547196,6.08532667e-17 0.59981695,0 Z\" id=\"矩形备份-75\"></path>\n                        <path d=\"M0.59981695,15 L12.400183,15 C12.7314528,15 13,15.2685472 13,15.599817 C13,15.9310867 12.7314528,16.1996339 12.400183,16.1996339 L0.59981695,16.1996339 C0.268547196,16.1996339 4.05688444e-17,15.9310867 0,15.599817 C-4.05688444e-17,15.2685472 0.268547196,15 0.59981695,15 Z\" id=\"矩形备份-77\"></path>\n                    </g>\n                </g>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.numberedList,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>有序列表</title>\n        <g id=\"有序列表\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.icon图标/11.editor/-save备份-32\" transform=\"translate(8.000000, 8.000000)\">\n                    <path d=\"M1.29125304,1.43706144 L1.29125304,4.74230276 L2.58250608,4.74230276 L2.58250608,0 L1.57819816,0 L0,1.00594301 L0.57389024,2.01188602 L1.29125304,1.43706144 Z M0.14347256,8.47866252 L1.00430792,9.19719324 C1.14778048,8.90978095 1.4347256,8.76607481 1.57819816,8.76607481 C1.72167072,8.76607481 1.72167072,8.76607481 1.86514328,8.90978095 C2.00861584,9.0534871 2.00861584,9.0534871 2.00861584,9.19719324 C2.00861584,9.34089938 2.00861584,9.48460553 1.86514328,9.62831167 C1.72167072,9.77201782 1.57819816,9.91572396 1.4347256,10.2031362 L0.14347256,11.6401977 L0.14347256,12.5024346 L3.29986888,12.5024346 L3.29986888,11.3527854 L1.86514328,11.3527854 L2.43903352,10.7779608 C2.8694512,10.3468424 3.15639632,10.0594301 3.15639632,9.77201782 C3.29986888,9.48460553 3.29986888,9.34089938 3.29986888,9.0534871 C3.29986888,8.62236866 3.15639632,8.33495637 2.8694512,8.04754408 C2.58250608,7.7601318 2.1520884,7.61642565 1.72167072,7.61642565 C1.00430792,7.61642565 0.43041768,7.90383794 0.14347256,8.47866252 Z M2.72597864,17.6758558 C3.15639632,17.3884435 3.29986888,17.1010312 3.29986888,16.5262066 C3.29986888,16.0950882 3.15639632,15.8076759 2.8694512,15.5202636 C2.58250608,15.2328513 2.1520884,15.2328513 1.72167072,15.2328513 C1.4347256,15.2328513 1.00430792,15.3765574 0.7173628,15.5202636 C0.43041768,15.6639697 0.28694512,15.951382 0.14347256,16.2387943 L1.14778048,16.8136189 C1.29125304,16.5262066 1.4347256,16.3825005 1.72167072,16.3825005 C1.86514328,16.3825005 2.00861584,16.3825005 2.00861584,16.5262066 C2.1520884,16.5262066 2.1520884,16.6699127 2.1520884,16.8136189 C2.1520884,16.957325 2.1520884,16.957325 2.00861584,17.1010312 C1.86514328,17.1010312 1.86514328,17.2447373 1.72167072,17.2447373 L1.29125304,17.2447373 L1.29125304,18.2506803 L1.57819816,18.2506803 C1.72167072,18.2506803 1.86514328,18.2506803 2.00861584,18.3943865 C2.1520884,18.5380926 2.1520884,18.5380926 2.1520884,18.6817988 C2.1520884,18.8255049 2.1520884,18.9692111 2.00861584,18.9692111 C1.86514328,19.1129172 1.86514328,19.1129172 1.72167072,19.1129172 C1.4347256,19.1129172 1.29125304,18.9692111 1.14778048,18.6817988 L1.687539e-14,18.9692111 C0.14347256,19.2566233 0.28694512,19.5440356 0.7173628,19.8314479 C1.00430792,19.9751541 1.4347256,20.1188602 1.86514328,20.1188602 C2.29556096,20.1188602 2.72597864,19.9751541 3.01292376,19.6877418 C3.29986888,19.4003295 3.44334144,19.1129172 3.44334144,18.6817988 C3.44334144,18.2506803 3.15639632,17.8195619 2.72597864,17.6758558 Z\" id=\"合并形状\" fill=\"#666666\" fill-rule=\"nonzero\"></path>\n                    <g id=\"编组-2\" transform=\"translate(7.000000, 2.000000)\" fill=\"#CACACA\">\n                        <path d=\"M0.59981695,7.55958265 L8.40018305,7.55958265 C8.7314528,7.55958265 9,7.82812984 9,8.1593996 C9,8.49066935 8.7314528,8.75921655 8.40018305,8.75921655 L0.59981695,8.75921655 C0.268547196,8.75921655 4.05688444e-17,8.49066935 0,8.1593996 C-4.05688444e-17,7.82812984 0.268547196,7.55958265 0.59981695,7.55958265 Z\" id=\"矩形备份-74\"></path>\n                        <path d=\"M0.59981695,0 L12.400183,0 C12.7314528,-2.44215884e-15 13,0.268547196 13,0.59981695 C13,0.931086705 12.7314528,1.1996339 12.400183,1.1996339 L0.59981695,1.1996339 C0.268547196,1.1996339 4.05688444e-17,0.931086705 0,0.59981695 C-4.05688444e-17,0.268547196 0.268547196,6.08532667e-17 0.59981695,0 Z\" id=\"矩形备份-75\"></path>\n                        <path d=\"M0.59981695,15 L12.400183,15 C12.7314528,15 13,15.2685472 13,15.599817 C13,15.9310867 12.7314528,16.1996339 12.400183,16.1996339 L0.59981695,16.1996339 C0.268547196,16.1996339 4.05688444e-17,15.9310867 0,15.599817 C-4.05688444e-17,15.2685472 0.268547196,15 0.59981695,15 Z\" id=\"矩形备份-77\"></path>\n                    </g>\n                </g>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.link,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>链接</title>\n        <g id=\"链接\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"编组-5\" transform=\"translate(5.000000, 10.000000)\">\n                    <path d=\"M18.6642225,7.87948239 L21.6075695,7.87948239 C21.9389404,7.87948239 22.2075695,8.14811154 22.2075695,8.47948239 C22.2075695,8.81085324 21.9389404,9.07948239 21.6075695,9.07948239 L18.6642225,9.07948239 C18.3328516,9.07948239 18.0642225,8.81085324 18.0642225,8.47948239 C18.0642225,8.14811154 18.3328516,7.87948239 18.6642225,7.87948239 Z\" id=\"矩形备份-76\" fill=\"#73D897\"></path>\n                    <path d=\"M18.6642225,2.29271731 L24.4,2.29271731 C24.7313708,2.29271731 25,2.56134646 25,2.89271731 C25,3.22408816 24.7313708,3.49271731 24.4,3.49271731 L18.6642225,3.49271731 C18.3328516,3.49271731 18.0642225,3.22408816 18.0642225,2.89271731 C18.0642225,2.56134646 18.3328516,2.29271731 18.6642225,2.29271731 Z\" id=\"矩形备份-89\" fill=\"#6698FF\"></path>\n                    <path d=\"M18.6642225,13.4662475 L24.4,13.4662475 C24.7313708,13.4662475 25,13.7348766 25,14.0662475 C25,14.3976183 24.7313708,14.6662475 24.4,14.6662475 L18.6642225,14.6662475 C18.3328516,14.6662475 18.0642225,14.3976183 18.0642225,14.0662475 C18.0642225,13.7348766 18.3328516,13.4662475 18.6642225,13.4662475 Z\" id=\"矩形备份-91\" fill=\"#FF7575\"></path>\n                    <g id=\"1.Base基础/1.icon图标/11.editor/link-insert\" transform=\"translate(-1.000000, -1.000000)\" fill=\"#DDDDDD\">\n                        <path d=\"M9.25269168,6.12928454 C11.4618307,6.12928454 13.2526917,7.92014554 13.2526917,10.1292845 L13.2526917,14.1292845 C13.2526917,16.3384235 11.4618307,18.1292845 9.25269168,18.1292845 C7.04355269,18.1292845 5.25269168,16.3384235 5.25269168,14.1292845 L5.25269168,13.1292845 L6.45269168,13.1292845 L6.45269168,14.1292845 C6.45269168,15.6756818 7.70629439,16.9292845 9.25269168,16.9292845 C10.799089,16.9292845 12.0526917,15.6756818 12.0526917,14.1292845 L12.0526917,10.1292845 C12.0526917,8.58288724 10.799089,7.32928454 9.25269168,7.32928454 L9.25269168,6.12928454 Z M9.25269168,0.129284535 C11.4618307,0.129284535 13.2526917,1.92014554 13.2526917,4.12928454 L13.2526917,5.12928454 L12.0526917,5.12928454 L12.0526917,4.12928454 C12.0526917,2.58288724 10.799089,1.32928454 9.25269168,1.32928454 C7.70629439,1.32928454 6.45269168,2.58288724 6.45269168,4.12928454 L6.45269168,8.12928454 C6.45269168,9.67568184 7.70629439,10.9292845 9.25269168,10.9292845 L9.25269168,12.1292845 C7.04355269,12.1292845 5.25269168,10.3384235 5.25269168,8.12928454 L5.25269168,4.12928454 C5.25269168,1.92014554 7.04355269,0.129284535 9.25269168,0.129284535 Z\" id=\"形状结合\" transform=\"translate(9.252692, 9.129285) rotate(46.000000) translate(-9.252692, -9.129285) \"></path>\n                    </g>\n                </g>\n            </g>\n        </g>\n    </svg>`\n    }\n];\n"]}
295
+ let THE_DEFAULT_MENU_ICONS_HAS_INITIALIZED = false;
296
+ export const initializeDefaultMenuIcons = (iconRegistry) => {
297
+ if (!THE_DEFAULT_MENU_ICONS_HAS_INITIALIZED) {
298
+ THE_DEFAULT_MENU_ICONS_HAS_INITIALIZED = true;
299
+ PluginMenuSvgs.forEach(menuItem => {
300
+ iconRegistry.addSvgIconLiteral(menuItem.key, menuItem.svg);
301
+ });
302
+ }
303
+ };
304
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.js","sourceRoot":"","sources":["../../../../packages/src/constants/plugin-menu.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThyIconRegistry } from 'ngx-tethys/icon';\nimport { ThePluginMenuItemConfig } from '../interfaces/plugins/plugin-menu';\nimport { ElementKinds, STANDARD_HEADING_TYPES } from './node-types';\n\nexport const DefaultPluginMenu: ThePluginMenuItemConfig[] = [\n    ...STANDARD_HEADING_TYPES,\n    ElementKinds.numberedList,\n    ElementKinds.bulletedList,\n    ElementKinds.link,\n    { groupName: '基础' },\n    ElementKinds.image,\n    ElementKinds.table,\n    ElementKinds.blockquote,\n    ElementKinds.hr,\n    ElementKinds.code\n];\n\nexport enum ThePluginMenuItemType {\n    icon = 'iconMenu',\n    group = 'groupMenu'\n}\n\nexport enum PluginMenuIcons {\n    heading_1 = `the-icon-heading-one`,\n    heading_2 = `the-icon-heading-two`,\n    heading_3 = `the-icon-heading-three`,\n    heading_4 = `the-icon-heading-four`,\n    numberedList = 'the-icon-numbered-list',\n    bulletedList = 'the-icon-bulleted-list',\n    link = 'the-icon-link',\n    image = `the-icon-image`,\n    blockquote = `the-icon-block-quote`,\n    code = `the-icon-code`,\n    table = `the-icon-table`,\n    hr = `the-icon-hr`,\n    checkItem = `the-icon-check-item`\n}\n\nexport const PluginMenuSvgs = [\n    {\n        key: PluginMenuIcons.image,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n<title>图片</title>\n    <g id=\"图片\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"icon\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"矩形\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <g id=\"编组\" transform=\"translate(8.500000, 10.000000)\">\n                <path d=\"M0,1 C0,0.447715 0.447715,0 1,0 L18,0 C18.5523,0 19,0.447715 19,1 L19,15 C19,15.5523 18.5523,16 18,16 L1,16 C0.447715,16 0,15.5523 0,15 L0,1 Z\" id=\"路径\" fill=\"#EEEEEE\"></path>\n                <path d=\"M4.5,7 C5.60453333,7 6.5,6.10453333 6.5,5 C6.5,3.89546667 5.60453333,3 4.5,3 C3.39546667,3 2.5,3.89546667 2.5,5 C2.5,6.10453333 3.39546667,7 4.5,7 Z\" id=\"路径\" fill=\"#F6C659\"></path>\n                <path d=\"M5,9 L7.5,11 L10.5,7.5 L19,13 L19,15 C19,15.5523 18.5523,16 18,16 L1,16 C0.447715,16 0,15.5523 0,15 L0,13 L5,9 Z\" id=\"路径\" fill=\"#6698FF\"></path>\n                <path d=\"M5,9 L7.488,10.99 L3.165,16 L1,16 C0.447715,16 0,15.5523 0,15 L0,13 L5,9 Z\" id=\"形状结合\" fill=\"#CAD9F8\"></path>\n            </g>\n        </g>\n    </g>\n</svg>`\n    },\n    {\n        key: PluginMenuIcons.blockquote,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>引用</title>\n    <defs>\n        <rect id=\"path-1\" x=\"1\" y=\"1\" width=\"34\" height=\"34\" rx=\"4\"></rect>\n    </defs>\n    <g id=\"引用\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"矩形\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"蒙版\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <mask id=\"mask-2\" fill=\"white\">\n                <use xlink:href=\"#path-1\"></use>\n            </mask>\n            <use id=\"蒙版\" fill=\"#FFFFFF\" xlink:href=\"#path-1\"></use>\n            <g id=\"编组-34\" mask=\"url(#mask-2)\">\n                <g transform=\"translate(7.000000, 7.600000)\">\n                    <path d=\"M-9.3,9.9 L10.5,9.9 C10.8313708,9.9 11.1,10.1686292 11.1,10.5 C11.1,10.8313708 10.8313708,11.1 10.5,11.1 L-9.3,11.1 C-9.63137085,11.1 -9.9,10.8313708 -9.9,10.5 C-9.9,10.1686292 -9.63137085,9.9 -9.3,9.9 Z\" id=\"矩形备份-86\" fill=\"#AAAAAA\" transform=\"translate(0.600000, 10.500000) rotate(-270.000000) translate(-0.600000, -10.500000) \"></path>\n                    <path d=\"M12.0569495,0.107381518 C9.05340743,2.09055298 7.38481149,4.39881214 7.05114973,7.03213028 C6.53171396,11.1315969 10.097464,13.1381708 11.9041919,11.3352765 C13.7109198,9.53238214 12.6278961,7.24401116 11.3196447,6.61849713 C10.0113932,5.99294208 9.21135004,6.21080993 9.35090591,5.37489124 C9.49046177,4.53901356 11.3517118,2.22140491 12.9868965,1.14207129 C13.0953823,1.04722312 13.1366628,0.863185692 13.0322053,0.723558362 C12.9634843,0.631744678 12.8287146,0.451664378 12.6278961,0.18330516 C12.4522847,-0.0513630698 12.2840519,-0.042579465 12.0569495,0.107381518 Z M19.9642908,0.107381518 C16.9607886,2.09055298 15.2921807,4.39881214 14.9585069,7.03213028 C14.4390911,11.1315969 18.0048451,13.1381708 19.811573,11.3352765 C21.618301,9.53238214 20.5352773,7.24401116 19.2270258,6.61849713 C17.9187744,5.99294208 17.1186913,6.21080993 17.2582871,5.37489124 C17.3978429,4.53901356 19.259093,2.22140491 20.8942776,1.14207129 C21.0027635,1.04722312 21.0440439,0.863185692 20.9395466,0.723558362 C20.8708654,0.631744678 20.7360957,0.451664378 20.5352773,0.18330516 C20.3596658,-0.0513630698 20.191433,-0.042579465 19.9642908,0.107381518 Z\" id=\"形状结合\" fill=\"#CACACA\" transform=\"translate(14.000000, 6.000000) rotate(-180.000000) translate(-14.000000, -6.000000) \"></path>\n                    <path d=\"M6.6,20.4 L15.7517228,20.4 C16.0830937,20.4 16.3517228,20.6686292 16.3517228,21 C16.3517228,21.3313708 16.0830937,21.6 15.7517228,21.6 L6.6,21.6 C6.26862915,21.6 6,21.3313708 6,21 C6,20.6686292 6.26862915,20.4 6.6,20.4 Z\" id=\"矩形备份-88\" fill=\"#CACACA\"></path>\n                    <rect id=\"矩形备份-87\" fill=\"#CACACA\" x=\"6\" y=\"15.4\" width=\"16\" height=\"1.2\" rx=\"0.6\"></rect>\n                </g>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.code,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>代码块</title>\n    <defs>\n        <rect id=\"path-1\" x=\"1\" y=\"1\" width=\"34\" height=\"34\" rx=\"4\"></rect>\n    </defs>\n    <g id=\"代码块\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"icon\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"蒙版\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <mask id=\"mask-2\" fill=\"white\">\n                <use xlink:href=\"#path-1\"></use>\n            </mask>\n            <use id=\"蒙版\" fill=\"#FFFFFF\" xlink:href=\"#path-1\"></use>\n            <g id=\"编组-24\" mask=\"url(#mask-2)\">\n                <g transform=\"translate(6.000000, 6.000000)\">\n                    <rect id=\"矩形备份-60\" fill=\"#F5F5F5\" x=\"0\" y=\"0\" width=\"43\" height=\"24\" rx=\"2\"></rect>\n                    <path d=\"M2,0 L6,0 L6,0 L6,24 L2,24 C0.8954305,24 1.3527075e-16,23.1045695 0,22 L0,2 C-1.3527075e-16,0.8954305 0.8954305,2.02906125e-16 2,0 Z\" id=\"矩形备份-60\" fill=\"#EEEEEE\"></path>\n                    <path d=\"M2.6,4 L3.4,4 C3.73137085,4 4,4.26862915 4,4.6 C4,4.93137085 3.73137085,5.2 3.4,5.2 L2.6,5.2 C2.26862915,5.2 2,4.93137085 2,4.6 C2,4.26862915 2.26862915,4 2.6,4 Z M2.6,9 L3.4,9 C3.73137085,9 4,9.26862915 4,9.6 C4,9.93137085 3.73137085,10.2 3.4,10.2 L2.6,10.2 C2.26862915,10.2 2,9.93137085 2,9.6 C2,9.26862915 2.26862915,9 2.6,9 Z M2.6,14 L3.4,14 C3.73137085,14 4,14.2686292 4,14.6 C4,14.9313708 3.73137085,15.2 3.4,15.2 L2.6,15.2 C2.26862915,15.2 2,14.9313708 2,14.6 C2,14.2686292 2.26862915,14 2.6,14 Z M2.6,19 L3.4,19 C3.73137085,19 4,19.2686292 4,19.6 C4,19.9313708 3.73137085,20.2 3.4,20.2 L2.6,20.2 C2.26862915,20.2 2,19.9313708 2,19.6 C2,19.2686292 2.26862915,19 2.6,19 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n                    <path d=\"M10.6,4 L23.8215948,4 C24.1529656,4 24.4215948,4.26862915 24.4215948,4.6 C24.4215948,4.93137085 24.1529656,5.2 23.8215948,5.2 L10.6,5.2 C10.2686292,5.2 10,4.93137085 10,4.6 C10,4.26862915 10.2686292,4 10.6,4 Z\" id=\"矩形备份-61\" fill=\"#CACACA\"></path>\n                    <path d=\"M15.6,9 L23.9488547,9 C24.2802256,9 24.5488547,9.26862915 24.5488547,9.6 C24.5488547,9.93137085 24.2802256,10.2 23.9488547,10.2 L15.6,10.2 C15.2686292,10.2 15,9.93137085 15,9.6 C15,9.26862915 15.2686292,9 15.6,9 Z\" id=\"矩形备份-63\" fill=\"#FF7575\"></path>\n                    <path d=\"M10.6,14 L21.7142342,14 C22.0456051,14 22.3142342,14.2686292 22.3142342,14.6 C22.3142342,14.9313708 22.0456051,15.2 21.7142342,15.2 L10.6,15.2 C10.2686292,15.2 10,14.9313708 10,14.6 C10,14.2686292 10.2686292,14 10.6,14 Z\" id=\"矩形备份-65\" fill=\"#CACACA\"></path>\n                    <path d=\"M13.6,19 L29.1044747,19 C29.4358456,19 29.7044747,19.2686292 29.7044747,19.6 C29.7044747,19.9313708 29.4358456,20.2 29.1044747,20.2 L13.6,20.2 C13.2686292,20.2 13,19.9313708 13,19.6 C13,19.2686292 13.2686292,19 13.6,19 Z\" id=\"矩形备份-66\" fill=\"#6698FF\"></path>\n                </g>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.table,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>表格</title>\n    <g id=\"表格\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"icon\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"矩形\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <g id=\"编组-36\" transform=\"translate(6.800000, 8.800000)\">\n                <path d=\"M20.2,0 L2.2,0 C0.98497355,0 0,0.98497355 0,2.2 L0,16.2 C0,17.4150264 0.98497355,18.4 2.2,18.4 L20.2,18.4 C21.4150264,18.4 22.4,17.4150264 22.4,16.2 L22.4,2.2 C22.4,0.98497355 21.4150264,0 20.2,0 Z M20.2,1.2 C20.7522847,1.2 21.2,1.64771525 21.2,2.2 L21.2,16.2 C21.2,16.7522847 20.7522847,17.2 20.2,17.2 L2.2,17.2 C1.64771525,17.2 1.2,16.7522847 1.2,16.2 L1.2,2.2 C1.2,1.64771525 1.64771525,1.2 2.2,1.2 L20.2,1.2 Z\" id=\"矩形\" fill=\"#D8D8D8\" fill-rule=\"nonzero\"></path>\n                <path d=\"M2.2,1.2 L20.2,1.2 C20.7522847,1.2 21.2,1.64771525 21.2,2.2 L21.2,5.7 L21.2,5.7 L1.2,5.7 L1.2,2.2 C1.2,1.64771525 1.64771525,1.2 2.2,1.2 Z\" id=\"矩形\" fill=\"#EEEEEE\"></path>\n                <path d=\"M21.2,5.2 L21.2,6.4 L15.3,6.4 L15.3,11.2 L21.2,11.2 L21.2,12.4 L15.3,12.4 L15.3,17.3 L14.1,17.3 L14.1,12.4 L8.3,12.4 L8.3,17.3 L7.1,17.3 L7.1,12.4 L1.2,12.4 L1.2,11.2 L7.1,11.2 L7.1,6.4 L1.2,6.4 L1.2,5.2 L21.2,5.2 Z M14.1,6.4 L8.3,6.4 L8.3,11.2 L14.1,11.2 L14.1,6.4 Z\" id=\"形状结合\" fill=\"#D8D8D8\"></path>\n                <path d=\"M9.8,8.11197815 L12.6,8.11197815 C12.9313708,8.11197815 13.2,8.3806073 13.2,8.71197815 C13.2,9.043349 12.9313708,9.31197815 12.6,9.31197815 L9.8,9.31197815 C9.46862915,9.31197815 9.2,9.043349 9.2,8.71197815 C9.2,8.3806073 9.46862915,8.11197815 9.8,8.11197815 Z\" id=\"矩形\" fill=\"#6698FF\"></path>\n                <path d=\"M16.8,14.1134683 L19.6,14.1134683 C19.9313708,14.1134683 20.2,14.3820974 20.2,14.7134683 C20.2,15.0448391 19.9313708,15.3134683 19.6,15.3134683 L16.8,15.3134683 C16.4686292,15.3134683 16.2,15.0448391 16.2,14.7134683 C16.2,14.3820974 16.4686292,14.1134683 16.8,14.1134683 Z\" id=\"矩形备份-71\" fill=\"#FF7575\"></path>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.hr,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n    <title>分割线</title>\n    <defs>\n        <rect id=\"path-1\" x=\"1\" y=\"1\" width=\"34\" height=\"34\" rx=\"4\"></rect>\n    </defs>\n    <g id=\"分割线\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n        <g id=\"矩形备份-60\">\n            <path d=\"M32,0 C34.209139,0 36,1.790861 36,4 L36,32 C36,34.209139 34.209139,36 32,36 L4,36 C1.790861,36 0,34.209139 0,32 L0,4 C0,1.790861 1.790861,0 4,0 L32,0 Z M32,1 L4,1 C2.40231912,1 1.09633912,2.24891996 1.00509269,3.82372721 L1,4 L1,32 C1,33.5976809 2.24891996,34.9036609 3.82372721,34.9949073 L4,35 L32,35 C33.5976809,35 34.9036609,33.75108 34.9949073,32.1762728 L35,32 L35,4 C35,2.40231912 33.75108,1.09633912 32.1762728,1.00509269 L32,1 Z\" id=\"蒙版\" fill=\"#EEEEEE\" fill-rule=\"nonzero\"></path>\n            <mask id=\"mask-2\" fill=\"white\">\n                <use xlink:href=\"#path-1\"></use>\n            </mask>\n            <use id=\"蒙版\" fill=\"#FFFFFF\" xlink:href=\"#path-1\"></use>\n            <g id=\"编组-33\" mask=\"url(#mask-2)\">\n                <g transform=\"translate(7.000000, 7.500000)\">\n                    <path d=\"M3.6,0 L17.5238673,0 C17.8552382,1.87571599e-15 18.1238673,0.26862915 18.1238673,0.6 C18.1238673,0.93137085 17.8552382,1.2 17.5238673,1.2 L3.6,1.2 C3.26862915,1.2 3,0.93137085 3,0.6 C3,0.26862915 3.26862915,1.7189414e-16 3.6,0 Z\" id=\"矩形备份-81\" fill=\"#CACACA\"></path>\n                    <path d=\"M6.47613265,15 L20.4,15 C20.7313708,15 21,15.2686292 21,15.6 C21,15.9313708 20.7313708,16.2 20.4,16.2 L6.47613265,16.2 C6.1447618,16.2 5.87613265,15.9313708 5.87613265,15.6 C5.87613265,15.2686292 6.1447618,15 6.47613265,15 Z\" id=\"矩形备份-84\" fill=\"#CACACA\"></path>\n                    <path d=\"M5.49677721,5 L14.6485,5 C14.9798709,5 15.2485,5.26862915 15.2485,5.6 C15.2485,5.93137085 14.9798709,6.2 14.6485,6.2 L5.49677721,6.2 C5.16540636,6.2 4.89677721,5.93137085 4.89677721,5.6 C4.89677721,5.26862915 5.16540636,5 5.49677721,5 Z\" id=\"矩形备份-82\" fill=\"#CACACA\"></path>\n                    <path d=\"M2.55871088,20 L11.7104337,20 C12.0418046,20 12.3104337,20.2686292 12.3104337,20.6 C12.3104337,20.9313708 12.0418046,21.2 11.7104337,21.2 L2.55871088,21.2 C2.22734003,21.2 1.95871088,20.9313708 1.95871088,20.6 C1.95871088,20.2686292 2.22734003,20 2.55871088,20 Z\" id=\"矩形备份-85\" fill=\"#CACACA\"></path>\n                    <path d=\"M0.6,10 L20.4,10 C20.7313708,10 21,10.2686292 21,10.6 C21,10.9313708 20.7313708,11.2 20.4,11.2 L0.6,11.2 C0.26862915,11.2 4.05812251e-17,10.9313708 0,10.6 C-4.05812251e-17,10.2686292 0.26862915,10 0.6,10 Z\" id=\"矩形备份-83\" fill=\"#AAAAAA\"></path>\n                </g>\n            </g>\n        </g>\n    </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_1,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H1</title>\n        <g id=\"H1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(9.000000, 7.000000)\" fill=\"#666666\">\n                    <path d=\"M7.6,0 C7.93137085,-6.08718376e-17 8.2,0.26862915 8.2,0.6 L8.2,11.4 C8.2,11.7313708 7.93137085,12 7.6,12 C7.26862915,12 7,11.7313708 7,11.4 L7,6.4 L1.2,6.4 L1.2,11.4 C1.2,11.7313708 0.93137085,12 0.6,12 C0.26862915,12 1.51603528e-16,11.7313708 0,11.4 L0,0.6 C7.04410774e-17,0.26862915 0.26862915,-1.61172767e-16 0.6,0 C0.93137085,-6.08718376e-17 1.2,0.26862915 1.2,0.6 L1.2,5.2 L7,5.2 L7,0.6 C7,0.26862915 7.26862915,-1.61172767e-16 7.6,0 Z M12.6,4.03849355 C12.9313708,4.03849355 13.2,4.3071227 13.2,4.63849355 L13.2,10.7994936 L14.3,10.8 C14.5761424,10.8 14.8,11.0238576 14.8,11.3 L14.8,11.5 C14.8,11.7761424 14.5761424,12 14.3,12 L10.8,12 C10.5238576,12 10.3,11.7761424 10.3,11.5 L10.3,11.3 C10.3,11.0238576 10.5238576,10.8 10.8,10.8 L12,10.7994936 L11.9992076,5.99749355 L11.4573367,6.503957 C11.2420362,6.70484511 10.9182139,6.71678064 10.6901851,6.54683893 L10.6095636,6.47459911 C10.6095239,6.47455657 10.6094842,6.47451403 10.6094445,6.47447147 C10.3834309,6.23210152 10.3966345,5.85241672 10.6389386,5.62633256 L12.1456416,4.22048943 C12.1994667,4.1702674 12.2600744,4.13185491 12.3242723,4.1051414 L12.4103536,4.06908195 C12.4699613,4.04923872 12.5337258,4.03849355 12.6,4.03849355 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_2,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H2</title>\n        <g id=\"H2\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(8.000000, 5.000000)\" fill=\"#666666\">\n                    <path d=\"M8.6,2 C8.93137085,2 9.2,2.26862915 9.2,2.6 L9.2,13.4 C9.2,13.7313708 8.93137085,14 8.6,14 C8.26862915,14 8,13.7313708 8,13.4 L7.999,8.4 L2.2,8.4 L2.2,13.4 C2.2,13.7313708 1.93137085,14 1.6,14 C1.26862915,14 1,13.7313708 1,13.4 L1,2.6 C1,2.26862915 1.26862915,2 1.6,2 C1.93137085,2 2.2,2.26862915 2.2,2.6 L2.2,7.2 L7.999,7.2 L8,2.6 C8,2.26862915 8.26862915,2 8.6,2 Z M10.6050397,12.9143577 C10.5088932,13.5872926 11.0315636,13.9150843 11.673969,13.8576252 L14.7346207,13.8600109 C15.0659915,13.8600109 15.3346207,13.5913818 15.3346207,13.2600109 C15.3346207,12.9286401 15.0659915,12.6600109 14.7346207,12.6600109 L11.8578688,12.6600109 C11.9286468,12.324783 12.0484495,12.1022143 12.3451123,11.7834278 C12.3790085,11.7470038 12.4146387,11.7109747 12.4520606,11.6753577 C12.4981091,11.6315301 12.5450179,11.590446 12.5935631,11.5512355 C12.734276,11.4375804 12.8707598,11.3503175 13.1225647,11.206769 C13.9119415,10.7567625 14.2357153,10.5238408 14.7581338,9.92598498 C15.7545688,8.78566459 15.3845816,6.90006903 13.8145208,6.29898616 C13.1088388,6.02882249 12.2294594,6.13691231 11.509755,6.55397744 C11.1947054,6.73654711 10.9257925,6.99181908 10.7050302,7.31345899 C10.5175098,7.5866672 10.5869735,7.96016156 10.8601817,8.147682 C11.1333899,8.33520244 11.5068842,8.26573878 11.6944047,7.99253057 C11.8168882,7.81407796 11.9552234,7.68276 12.1114244,7.59224233 C12.5322515,7.34837511 13.037157,7.28631413 13.3854792,7.41966599 C14.146101,7.71086283 14.3210515,8.60247738 13.8545136,9.13638345 C13.4412636,9.6093069 13.2103422,9.77543093 12.5282596,10.1642713 C12.2246758,10.3373378 12.0423445,10.4539139 11.8395486,10.6177142 C11.7659434,10.6771658 11.6945757,10.7396718 11.6247531,10.8061268 C11.5697738,10.8584544 11.5170831,10.911735 11.4666494,10.9659299 C11.1108509,11.3482621 10.877698,11.762253 10.7425697,12.192387 C10.6922909,12.3524319 10.6581826,12.5062255 10.6351917,12.6597188 C10.6238114,12.7356971 10.6061737,12.8994638 10.6050397,12.9143577 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_3,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H3</title>\n        <g id=\"H3\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(8.000000, 5.000000)\" fill=\"#666666\">\n                    <path d=\"M8.6,2 C8.93137085,2 9.2,2.26862915 9.2,2.6 L9.2,13.4 C9.2,13.7313708 8.93137085,14 8.6,14 C8.26862915,14 8,13.7313708 8,13.4 L7.999,8.4 L2.2,8.4 L2.2,13.4 C2.2,13.7313708 1.93137085,14 1.6,14 C1.26862915,14 1,13.7313708 1,13.4 L1,2.6 C1,2.26862915 1.26862915,2 1.6,2 C1.93137085,2 2.2,2.26862915 2.2,2.6 L2.2,7.2 L7.999,7.2 L8,2.6 C8,2.26862915 8.26862915,2 8.6,2 Z M14.8321775,7.18983161 C15.1357692,6.79527134 14.854493,6.22394171 14.356652,6.22394171 L11.0241938,6.22394171 C10.6928229,6.22394171 10.4241938,6.49257086 10.4241938,6.82394171 C10.4241938,7.15531256 10.6928229,7.42394171 11.0241938,7.42394171 L13.137929,7.42394171 L11.8506572,9.09693329 C11.7699456,9.20182941 11.7261828,9.33046927 11.7261828,9.46282318 L11.7261828,9.82922943 C11.7261828,10.1666497 12.0043217,10.4377176 12.3416301,10.4290305 C12.6787875,10.4203474 12.9830249,10.4540644 13.2547454,10.5294651 C13.7397835,10.6640601 14.0222167,11.2257408 13.8341992,11.8813236 C13.6970249,12.3596256 13.2389994,12.6238282 12.6183411,12.6238282 C12.0434265,12.6238282 11.4646434,12.41278 10.8719286,11.9820919 C10.6038559,11.7873006 10.2286305,11.8467069 10.0338391,12.1147796 C9.8390478,12.3828523 9.89845407,12.7580777 10.1665268,12.952869 C10.9617588,13.5307135 11.7826635,13.8238282 12.6183411,13.8238282 C13.7784713,13.8238282 14.6856352,13.2653796 14.9876983,12.2121406 C15.3629178,10.9038183 14.7001971,9.6852239 13.575613,9.37315895 C13.4583717,9.34062522 13.3380638,9.31356451 13.2147084,9.29196113 L14.8321775,7.18983161 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.heading_4,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>H4</title>\n        <g id=\"H4\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.Base基础/1.icon图标/11.editor/header-1\" transform=\"translate(8.000000, 5.000000)\" fill=\"#666666\">\n                    <path d=\"M8.6,2 C8.93137085,2 9.2,2.26862915 9.2,2.6 L9.2,13.4 C9.2,13.7313708 8.93137085,14 8.6,14 C8.26862915,14 8,13.7313708 8,13.4 L7.999,8.4 L2.2,8.4 L2.2,13.4 C2.2,13.7313708 1.93137085,14 1.6,14 C1.26862915,14 1,13.7313708 1,13.4 L1,2.6 C1,2.26862915 1.26862915,2 1.6,2 C1.93137085,2 2.2,2.26862915 2.2,2.6 L2.2,7.2 L7.999,7.2 L8,2.6 C8,2.26862915 8.26862915,2 8.6,2 Z M13.4093228,5.91341961 C13.7406441,5.91915017 14.0045876,6.19238469 13.998857,6.52370599 L13.998857,6.52370599 L13.9382755,9.99126303 L14.8179917,9.99134588 C15.1162255,9.99134588 15.3636385,10.2089355 15.4101387,10.4940228 L15.4179917,10.5913459 C15.4179917,10.9227167 15.1493626,11.1913459 14.8179917,11.1913459 L14.8179917,11.1913459 L13.9182755,11.191263 L13.8794422,13.4278503 C13.8742847,13.7260395 13.652449,13.9696526 13.3666002,14.0112157 L13.2691559,14.0173845 C12.9378346,14.0116539 12.6738911,13.7384194 12.6796217,13.4070981 L12.6796217,13.4070981 L12.7172755,11.191263 L10.5912754,11.1913459 C10.1454143,11.1913459 9.86643429,10.7287014 10.0448619,10.3426594 L10.0902034,10.2613052 L12.776267,6.18328918 C12.9048512,5.9880711 13.1278997,5.89246083 13.3452953,5.91706111 Z M12.7382755,9.99126303 L12.7662755,8.38026303 L11.7049365,9.99134588 L12.7382755,9.99126303 Z\" id=\"形状结合\"></path>\n                </g>\n                <path d=\"M8.6,28 L18.4,28 C18.7313708,28 19,28.2686292 19,28.6 C19,28.9313708 18.7313708,29.2 18.4,29.2 L8.6,29.2 C8.26862915,29.2 8,28.9313708 8,28.6 C8,28.2686292 8.26862915,28 8.6,28 Z M8.6,24 L27.4,24 C27.7313708,24 28,24.2686292 28,24.6 C28,24.9313708 27.7313708,25.2 27.4,25.2 L8.6,25.2 C8.26862915,25.2 8,24.9313708 8,24.6 C8,24.2686292 8.26862915,24 8.6,24 Z\" id=\"形状结合\" fill=\"#CACACA\"></path>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.bulletedList,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>无序列表</title>\n        <g id=\"无序列表\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.icon图标/11.editor/-save备份-32\" transform=\"translate(8.000000, 9.000000)\">\n                    <circle id=\"椭圆形\" fill=\"#666666\" cx=\"1.5\" cy=\"1.5\" r=\"1.5\"></circle>\n                    <circle id=\"椭圆形备份\" fill=\"#666666\" cx=\"1.5\" cy=\"9\" r=\"1.5\"></circle>\n                    <circle id=\"椭圆形备份-2\" fill=\"#666666\" cx=\"1.5\" cy=\"16.5\" r=\"1.5\"></circle>\n                    <g id=\"编组-2\" transform=\"translate(7.000000, 1.000000)\" fill=\"#CACACA\">\n                        <path d=\"M0.59981695,7.55958265 L8.40018305,7.55958265 C8.7314528,7.55958265 9,7.82812984 9,8.1593996 C9,8.49066935 8.7314528,8.75921655 8.40018305,8.75921655 L0.59981695,8.75921655 C0.268547196,8.75921655 4.05688444e-17,8.49066935 0,8.1593996 C-4.05688444e-17,7.82812984 0.268547196,7.55958265 0.59981695,7.55958265 Z\" id=\"矩形备份-74\"></path>\n                        <path d=\"M0.59981695,0 L12.400183,0 C12.7314528,-2.44215884e-15 13,0.268547196 13,0.59981695 C13,0.931086705 12.7314528,1.1996339 12.400183,1.1996339 L0.59981695,1.1996339 C0.268547196,1.1996339 4.05688444e-17,0.931086705 0,0.59981695 C-4.05688444e-17,0.268547196 0.268547196,6.08532667e-17 0.59981695,0 Z\" id=\"矩形备份-75\"></path>\n                        <path d=\"M0.59981695,15 L12.400183,15 C12.7314528,15 13,15.2685472 13,15.599817 C13,15.9310867 12.7314528,16.1996339 12.400183,16.1996339 L0.59981695,16.1996339 C0.268547196,16.1996339 4.05688444e-17,15.9310867 0,15.599817 C-4.05688444e-17,15.2685472 0.268547196,15 0.59981695,15 Z\" id=\"矩形备份-77\"></path>\n                    </g>\n                </g>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.numberedList,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>有序列表</title>\n        <g id=\"有序列表\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"1.icon图标/11.editor/-save备份-32\" transform=\"translate(8.000000, 8.000000)\">\n                    <path d=\"M1.29125304,1.43706144 L1.29125304,4.74230276 L2.58250608,4.74230276 L2.58250608,0 L1.57819816,0 L0,1.00594301 L0.57389024,2.01188602 L1.29125304,1.43706144 Z M0.14347256,8.47866252 L1.00430792,9.19719324 C1.14778048,8.90978095 1.4347256,8.76607481 1.57819816,8.76607481 C1.72167072,8.76607481 1.72167072,8.76607481 1.86514328,8.90978095 C2.00861584,9.0534871 2.00861584,9.0534871 2.00861584,9.19719324 C2.00861584,9.34089938 2.00861584,9.48460553 1.86514328,9.62831167 C1.72167072,9.77201782 1.57819816,9.91572396 1.4347256,10.2031362 L0.14347256,11.6401977 L0.14347256,12.5024346 L3.29986888,12.5024346 L3.29986888,11.3527854 L1.86514328,11.3527854 L2.43903352,10.7779608 C2.8694512,10.3468424 3.15639632,10.0594301 3.15639632,9.77201782 C3.29986888,9.48460553 3.29986888,9.34089938 3.29986888,9.0534871 C3.29986888,8.62236866 3.15639632,8.33495637 2.8694512,8.04754408 C2.58250608,7.7601318 2.1520884,7.61642565 1.72167072,7.61642565 C1.00430792,7.61642565 0.43041768,7.90383794 0.14347256,8.47866252 Z M2.72597864,17.6758558 C3.15639632,17.3884435 3.29986888,17.1010312 3.29986888,16.5262066 C3.29986888,16.0950882 3.15639632,15.8076759 2.8694512,15.5202636 C2.58250608,15.2328513 2.1520884,15.2328513 1.72167072,15.2328513 C1.4347256,15.2328513 1.00430792,15.3765574 0.7173628,15.5202636 C0.43041768,15.6639697 0.28694512,15.951382 0.14347256,16.2387943 L1.14778048,16.8136189 C1.29125304,16.5262066 1.4347256,16.3825005 1.72167072,16.3825005 C1.86514328,16.3825005 2.00861584,16.3825005 2.00861584,16.5262066 C2.1520884,16.5262066 2.1520884,16.6699127 2.1520884,16.8136189 C2.1520884,16.957325 2.1520884,16.957325 2.00861584,17.1010312 C1.86514328,17.1010312 1.86514328,17.2447373 1.72167072,17.2447373 L1.29125304,17.2447373 L1.29125304,18.2506803 L1.57819816,18.2506803 C1.72167072,18.2506803 1.86514328,18.2506803 2.00861584,18.3943865 C2.1520884,18.5380926 2.1520884,18.5380926 2.1520884,18.6817988 C2.1520884,18.8255049 2.1520884,18.9692111 2.00861584,18.9692111 C1.86514328,19.1129172 1.86514328,19.1129172 1.72167072,19.1129172 C1.4347256,19.1129172 1.29125304,18.9692111 1.14778048,18.6817988 L1.687539e-14,18.9692111 C0.14347256,19.2566233 0.28694512,19.5440356 0.7173628,19.8314479 C1.00430792,19.9751541 1.4347256,20.1188602 1.86514328,20.1188602 C2.29556096,20.1188602 2.72597864,19.9751541 3.01292376,19.6877418 C3.29986888,19.4003295 3.44334144,19.1129172 3.44334144,18.6817988 C3.44334144,18.2506803 3.15639632,17.8195619 2.72597864,17.6758558 Z\" id=\"合并形状\" fill=\"#666666\" fill-rule=\"nonzero\"></path>\n                    <g id=\"编组-2\" transform=\"translate(7.000000, 2.000000)\" fill=\"#CACACA\">\n                        <path d=\"M0.59981695,7.55958265 L8.40018305,7.55958265 C8.7314528,7.55958265 9,7.82812984 9,8.1593996 C9,8.49066935 8.7314528,8.75921655 8.40018305,8.75921655 L0.59981695,8.75921655 C0.268547196,8.75921655 4.05688444e-17,8.49066935 0,8.1593996 C-4.05688444e-17,7.82812984 0.268547196,7.55958265 0.59981695,7.55958265 Z\" id=\"矩形备份-74\"></path>\n                        <path d=\"M0.59981695,0 L12.400183,0 C12.7314528,-2.44215884e-15 13,0.268547196 13,0.59981695 C13,0.931086705 12.7314528,1.1996339 12.400183,1.1996339 L0.59981695,1.1996339 C0.268547196,1.1996339 4.05688444e-17,0.931086705 0,0.59981695 C-4.05688444e-17,0.268547196 0.268547196,6.08532667e-17 0.59981695,0 Z\" id=\"矩形备份-75\"></path>\n                        <path d=\"M0.59981695,15 L12.400183,15 C12.7314528,15 13,15.2685472 13,15.599817 C13,15.9310867 12.7314528,16.1996339 12.400183,16.1996339 L0.59981695,16.1996339 C0.268547196,16.1996339 4.05688444e-17,15.9310867 0,15.599817 C-4.05688444e-17,15.2685472 0.268547196,15 0.59981695,15 Z\" id=\"矩形备份-77\"></path>\n                    </g>\n                </g>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.link,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>链接</title>\n        <g id=\"链接\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"编组-5\" transform=\"translate(5.000000, 10.000000)\">\n                    <path d=\"M18.6642225,7.87948239 L21.6075695,7.87948239 C21.9389404,7.87948239 22.2075695,8.14811154 22.2075695,8.47948239 C22.2075695,8.81085324 21.9389404,9.07948239 21.6075695,9.07948239 L18.6642225,9.07948239 C18.3328516,9.07948239 18.0642225,8.81085324 18.0642225,8.47948239 C18.0642225,8.14811154 18.3328516,7.87948239 18.6642225,7.87948239 Z\" id=\"矩形备份-76\" fill=\"#73D897\"></path>\n                    <path d=\"M18.6642225,2.29271731 L24.4,2.29271731 C24.7313708,2.29271731 25,2.56134646 25,2.89271731 C25,3.22408816 24.7313708,3.49271731 24.4,3.49271731 L18.6642225,3.49271731 C18.3328516,3.49271731 18.0642225,3.22408816 18.0642225,2.89271731 C18.0642225,2.56134646 18.3328516,2.29271731 18.6642225,2.29271731 Z\" id=\"矩形备份-89\" fill=\"#6698FF\"></path>\n                    <path d=\"M18.6642225,13.4662475 L24.4,13.4662475 C24.7313708,13.4662475 25,13.7348766 25,14.0662475 C25,14.3976183 24.7313708,14.6662475 24.4,14.6662475 L18.6642225,14.6662475 C18.3328516,14.6662475 18.0642225,14.3976183 18.0642225,14.0662475 C18.0642225,13.7348766 18.3328516,13.4662475 18.6642225,13.4662475 Z\" id=\"矩形备份-91\" fill=\"#FF7575\"></path>\n                    <g id=\"1.Base基础/1.icon图标/11.editor/link-insert\" transform=\"translate(-1.000000, -1.000000)\" fill=\"#DDDDDD\">\n                        <path d=\"M9.25269168,6.12928454 C11.4618307,6.12928454 13.2526917,7.92014554 13.2526917,10.1292845 L13.2526917,14.1292845 C13.2526917,16.3384235 11.4618307,18.1292845 9.25269168,18.1292845 C7.04355269,18.1292845 5.25269168,16.3384235 5.25269168,14.1292845 L5.25269168,13.1292845 L6.45269168,13.1292845 L6.45269168,14.1292845 C6.45269168,15.6756818 7.70629439,16.9292845 9.25269168,16.9292845 C10.799089,16.9292845 12.0526917,15.6756818 12.0526917,14.1292845 L12.0526917,10.1292845 C12.0526917,8.58288724 10.799089,7.32928454 9.25269168,7.32928454 L9.25269168,6.12928454 Z M9.25269168,0.129284535 C11.4618307,0.129284535 13.2526917,1.92014554 13.2526917,4.12928454 L13.2526917,5.12928454 L12.0526917,5.12928454 L12.0526917,4.12928454 C12.0526917,2.58288724 10.799089,1.32928454 9.25269168,1.32928454 C7.70629439,1.32928454 6.45269168,2.58288724 6.45269168,4.12928454 L6.45269168,8.12928454 C6.45269168,9.67568184 7.70629439,10.9292845 9.25269168,10.9292845 L9.25269168,12.1292845 C7.04355269,12.1292845 5.25269168,10.3384235 5.25269168,8.12928454 L5.25269168,4.12928454 C5.25269168,1.92014554 7.04355269,0.129284535 9.25269168,0.129284535 Z\" id=\"形状结合\" transform=\"translate(9.252692, 9.129285) rotate(46.000000) translate(-9.252692, -9.129285) \"></path>\n                    </g>\n                </g>\n            </g>\n        </g>\n    </svg>`\n    },\n    {\n        key: PluginMenuIcons.checkItem,\n        svg: `<svg width=\"36px\" height=\"36px\" viewBox=\"0 0 36 36\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n        <title>待办事项</title>\n        <g id=\"待办事项\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n            <g id=\"icon备份-2\">\n                <rect id=\"矩形\" stroke=\"#EEEEEE\" fill=\"#FFFFFF\" x=\"0.5\" y=\"0.5\" width=\"35\" height=\"35\" rx=\"4\"></rect>\n                <g id=\"编组-4\" transform=\"translate(5.000000, 12.000000)\">\n                    <g id=\"编组-3\" transform=\"translate(15.900000, 0.000000)\" fill=\"#CACACA\">\n                        <path d=\"M0.6,5.58676508 L3.54334707,5.58676508 C3.87471792,5.58676508 4.14334707,5.85539423 4.14334707,6.18676508 C4.14334707,6.51813593 3.87471792,6.78676508 3.54334707,6.78676508 L0.6,6.78676508 C0.26862915,6.78676508 1.81902998e-12,6.51813593 1.8189894e-12,6.18676508 C1.81894882e-12,5.85539423 0.26862915,5.58676508 0.6,5.58676508 Z\" id=\"矩形备份-74\"></path>\n                        <path d=\"M0.6,0 L6.33577755,0 C6.6671484,-9.15528894e-16 6.93577755,0.26862915 6.93577755,0.6 C6.93577755,0.93137085 6.6671484,1.2 6.33577755,1.2 L0.6,1.2 C0.26862915,1.2 4.05812251e-17,0.93137085 0,0.6 C-4.05812251e-17,0.26862915 0.26862915,1.7189414e-16 0.6,0 Z\" id=\"矩形备份-75\"></path>\n                        <path d=\"M0.6,11.1735302 L6.33577755,11.1735302 C6.6671484,11.1735302 6.93577755,11.4421593 6.93577755,11.7735302 C6.93577755,12.104901 6.6671484,12.3735302 6.33577755,12.3735302 L0.6,12.3735302 C0.26862915,12.3735302 4.05812251e-17,12.104901 0,11.7735302 C-4.05812251e-17,11.4421593 0.26862915,11.1735302 0.6,11.1735302 Z\" id=\"矩形备份-77\"></path>\n                    </g>\n                    <g id=\"3.Data-Input-数据输入/-3.Checkbox-多选框-/-3.Select\" transform=\"translate(0.000000, 0.000000)\" stroke=\"#6698FF\">\n                        <path d=\"M10.500003,0.5 C10.7761467,0.5 11.0261426,0.611923561 11.2071022,0.792884987 C11.3880653,0.973849926 11.499988,1.22385308 11.499988,1.5 L11.499988,1.5 L11.499988,10.50003 C11.499988,10.7761733 11.3880629,11.0261769 11.2070985,11.2071431 C11.0261394,11.388104 10.7761453,11.50003 10.500003,11.50003 L10.500003,11.50003 L1.4999715,11.50003 C1.22385428,11.50003 0.973862046,11.3880904 0.792898366,11.2071233 C0.611938132,11.0261596 0.5,10.7761657 0.5,10.50003 L0.5,10.50003 L0.5,1.5 C0.5,1.22386076 0.611935724,0.973867183 0.79289468,0.792904788 C0.973858868,0.611937162 1.22385287,0.5 1.4999715,0.5 L1.4999715,0.5 Z\" id=\"圆角矩形-12-拷贝-12\" fill=\"#6698FF\" opacity=\"0.300000012\"></path>\n                        <polyline id=\"路径\" stroke-width=\"1.5\" points=\"3.0000075 5.33991979 5.2500075 7.58991979 8.8425368 3.750015\"></polyline>\n                    </g>\n                </g>\n            </g>\n        </g>\n    </svg>`\n    }\n];\n\nlet THE_DEFAULT_MENU_ICONS_HAS_INITIALIZED = false;\nexport const initializeDefaultMenuIcons = (iconRegistry: ThyIconRegistry) => {\n    if (!THE_DEFAULT_MENU_ICONS_HAS_INITIALIZED) {\n        THE_DEFAULT_MENU_ICONS_HAS_INITIALIZED = true;\n        PluginMenuSvgs.forEach(menuItem => {\n            iconRegistry.addSvgIconLiteral(menuItem.key, menuItem.svg);\n        });\n    }\n};\n"]}
@@ -28,6 +28,7 @@ export const DefaultGlobalToolbarDefinition = [
28
28
  ElementKinds.image,
29
29
  ElementKinds.table,
30
30
  ElementKinds.blockquote,
31
+ ElementKinds.hr,
31
32
  ElementKinds.code
32
33
  ];
33
34
  export const DefaultInlineToolbarDefinition = [
@@ -49,4 +50,4 @@ export const ToolbarMoreGroup = {
49
50
  key: 'more',
50
51
  icon: 'more'
51
52
  };
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb25zdGFudHMvdG9vbGJhci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXZELE9BQU8sRUFBRSxrQkFBa0IsRUFBMEIsTUFBTSx5QkFBeUIsQ0FBQztBQUdyRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLGNBQWMsQ0FBMEMseUJBQXlCLENBQUMsQ0FBQztBQUUzSCxNQUFNLENBQU4sSUFBWSxZQUdYO0FBSEQsV0FBWSxZQUFZO0lBQ3BCLGtDQUFrQixDQUFBO0lBQ2xCLGtDQUFrQixDQUFBO0FBQ3RCLENBQUMsRUFIVyxZQUFZLEtBQVosWUFBWSxRQUd2QjtBQUVELE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFpQjtJQUN4RCxZQUFZLENBQUMsV0FBVztJQUN4QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFNBQVMsQ0FBQyxJQUFJO0lBQ2QsU0FBUyxDQUFDLE1BQU07SUFDaEIsa0JBQWtCLENBQUMsS0FBSztJQUN4QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFNBQVMsQ0FBQyxLQUFLO0lBQ2YsU0FBUyxDQUFDLGVBQWU7SUFDekIsa0JBQWtCLENBQUMsS0FBSztJQUN4QixZQUFZLENBQUMsTUFBTTtJQUNuQixrQkFBa0IsQ0FBQyxTQUFTO0lBQzVCLGtCQUFrQixDQUFDLGFBQWE7SUFDaEMsa0JBQWtCLENBQUMsS0FBSztJQUN4QixZQUFZLENBQUMsWUFBWTtJQUN6QixZQUFZLENBQUMsWUFBWTtJQUN6QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFlBQVksQ0FBQyxJQUFJO0lBQ2pCLFlBQVksQ0FBQyxLQUFLO0lBQ2xCLFlBQVksQ0FBQyxLQUFLO0lBQ2xCLFlBQVksQ0FBQyxVQUFVO0lBQ3ZCLFlBQVksQ0FBQyxJQUFJO0NBQ3BCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBaUI7SUFDeEQsa0JBQWtCLENBQUMsS0FBSztJQUN4QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFNBQVMsQ0FBQyxJQUFJO0lBQ2QsU0FBUyxDQUFDLE1BQU07SUFDaEIsU0FBUyxDQUFDLFNBQVM7SUFDbkIsU0FBUyxDQUFDLE1BQU07SUFDaEIsWUFBWSxDQUFDLFVBQVU7SUFDdkIsU0FBUyxDQUFDLEtBQUs7SUFDZixTQUFTLENBQUMsZUFBZTtJQUN6QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLGtCQUFrQixDQUFDLFNBQVM7SUFDNUIsa0JBQWtCLENBQUMsS0FBSztJQUN4QixZQUFZLENBQUMsSUFBSTtDQUNwQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQWdCO0lBQ3pDLEdBQUcsRUFBRSxNQUFNO0lBQ1gsSUFBSSxFQUFFLE1BQU07Q0FDZixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJ3NsYXRlLWFuZ3VsYXInO1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEVsZW1lbnRLaW5kcywgTWFya1R5cGVzIH0gZnJvbSAnLi9ub2RlLXR5cGVzJztcbmltcG9ydCB7IFRvb2xiYXJJdGVtLCBUb29sYmFyS2V5IH0gZnJvbSAnLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBUb29sYmFyQWN0aW9uVHlwZXMsIFNUQU5EQVJEX0hFQURJTkdfVFlQRVMgfSBmcm9tICcuLi9jb25zdGFudHMvbm9kZS10eXBlcyc7XG5pbXBvcnQgdHlwZSB7IFRoZVRvb2xiYXJHcm91cENvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvdG9vbGJhci1ncm91cC90b29sYmFyLWdyb3VwLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBjb25zdCBUaGVUb29sYmFyR3JvdXBUb2tlbiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxDb21wb25lbnRUeXBlPFRoZVRvb2xiYXJHcm91cENvbXBvbmVudD4+KCd0aGUtdG9vbGJhci1ncm91cC10b2tlbicpO1xuXG5leHBvcnQgZW51bSBEcm9wZG93bk1vZGUge1xuICAgIGljb24gPSAnaWNvbi1tb2RlJyxcbiAgICB0ZXh0ID0gJ3RleHQtbW9kZSdcbn1cblxuZXhwb3J0IGNvbnN0IERlZmF1bHRHbG9iYWxUb29sYmFyRGVmaW5pdGlvbjogVG9vbGJhcktleVtdID0gW1xuICAgIEVsZW1lbnRLaW5kcy5oZWFkaW5nTGlzdCxcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMuc3BsaXQsXG4gICAgTWFya1R5cGVzLmJvbGQsXG4gICAgTWFya1R5cGVzLml0YWxpYyxcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMuZ3JvdXAsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnNwbGl0LFxuICAgIE1hcmtUeXBlcy5jb2xvcixcbiAgICBNYXJrVHlwZXMuYmFja2dyb3VuZENvbG9yLFxuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5zcGxpdCxcbiAgICBFbGVtZW50S2luZHMuaW5kZW50LFxuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5hbGlnblR5cGUsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnZlcnRpY2FsQWxpZ24sXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnNwbGl0LFxuICAgIEVsZW1lbnRLaW5kcy5udW1iZXJlZExpc3QsXG4gICAgRWxlbWVudEtpbmRzLmJ1bGxldGVkTGlzdCxcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMuc3BsaXQsXG4gICAgRWxlbWVudEtpbmRzLmxpbmssXG4gICAgRWxlbWVudEtpbmRzLmltYWdlLFxuICAgIEVsZW1lbnRLaW5kcy50YWJsZSxcbiAgICBFbGVtZW50S2luZHMuYmxvY2txdW90ZSxcbiAgICBFbGVtZW50S2luZHMuY29kZVxuXTtcblxuZXhwb3J0IGNvbnN0IERlZmF1bHRJbmxpbmVUb29sYmFyRGVmaW5pdGlvbjogVG9vbGJhcktleVtdID0gW1xuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5jbGVhbixcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMuc3BsaXQsXG4gICAgTWFya1R5cGVzLmJvbGQsXG4gICAgTWFya1R5cGVzLml0YWxpYyxcbiAgICBNYXJrVHlwZXMudW5kZXJsaW5lLFxuICAgIE1hcmtUeXBlcy5zdHJpa2UsXG4gICAgRWxlbWVudEtpbmRzLmlubGluZUNvZGUsXG4gICAgTWFya1R5cGVzLmNvbG9yLFxuICAgIE1hcmtUeXBlcy5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnNwbGl0LFxuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5hbGlnblR5cGUsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnNwbGl0LFxuICAgIEVsZW1lbnRLaW5kcy5saW5rXG5dO1xuXG5leHBvcnQgY29uc3QgVG9vbGJhck1vcmVHcm91cDogVG9vbGJhckl0ZW0gPSB7XG4gICAga2V5OiAnbW9yZScsXG4gICAgaWNvbjogJ21vcmUnXG59O1xuIl19
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb25zdGFudHMvdG9vbGJhci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXZELE9BQU8sRUFBRSxrQkFBa0IsRUFBMEIsTUFBTSx5QkFBeUIsQ0FBQztBQUdyRixNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLGNBQWMsQ0FBMEMseUJBQXlCLENBQUMsQ0FBQztBQUUzSCxNQUFNLENBQU4sSUFBWSxZQUdYO0FBSEQsV0FBWSxZQUFZO0lBQ3BCLGtDQUFrQixDQUFBO0lBQ2xCLGtDQUFrQixDQUFBO0FBQ3RCLENBQUMsRUFIVyxZQUFZLEtBQVosWUFBWSxRQUd2QjtBQUVELE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFpQjtJQUN4RCxZQUFZLENBQUMsV0FBVztJQUN4QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFNBQVMsQ0FBQyxJQUFJO0lBQ2QsU0FBUyxDQUFDLE1BQU07SUFDaEIsa0JBQWtCLENBQUMsS0FBSztJQUN4QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFNBQVMsQ0FBQyxLQUFLO0lBQ2YsU0FBUyxDQUFDLGVBQWU7SUFDekIsa0JBQWtCLENBQUMsS0FBSztJQUN4QixZQUFZLENBQUMsTUFBTTtJQUNuQixrQkFBa0IsQ0FBQyxTQUFTO0lBQzVCLGtCQUFrQixDQUFDLGFBQWE7SUFDaEMsa0JBQWtCLENBQUMsS0FBSztJQUN4QixZQUFZLENBQUMsWUFBWTtJQUN6QixZQUFZLENBQUMsWUFBWTtJQUN6QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFlBQVksQ0FBQyxJQUFJO0lBQ2pCLFlBQVksQ0FBQyxLQUFLO0lBQ2xCLFlBQVksQ0FBQyxLQUFLO0lBQ2xCLFlBQVksQ0FBQyxVQUFVO0lBQ3ZCLFlBQVksQ0FBQyxFQUFFO0lBQ2YsWUFBWSxDQUFDLElBQUk7Q0FDcEIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFpQjtJQUN4RCxrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLGtCQUFrQixDQUFDLEtBQUs7SUFDeEIsU0FBUyxDQUFDLElBQUk7SUFDZCxTQUFTLENBQUMsTUFBTTtJQUNoQixTQUFTLENBQUMsU0FBUztJQUNuQixTQUFTLENBQUMsTUFBTTtJQUNoQixZQUFZLENBQUMsVUFBVTtJQUN2QixTQUFTLENBQUMsS0FBSztJQUNmLFNBQVMsQ0FBQyxlQUFlO0lBQ3pCLGtCQUFrQixDQUFDLEtBQUs7SUFDeEIsa0JBQWtCLENBQUMsU0FBUztJQUM1QixrQkFBa0IsQ0FBQyxLQUFLO0lBQ3hCLFlBQVksQ0FBQyxJQUFJO0NBQ3BCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBZ0I7SUFDekMsR0FBRyxFQUFFLE1BQU07SUFDWCxJQUFJLEVBQUUsTUFBTTtDQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRUeXBlIH0gZnJvbSAnc2xhdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRWxlbWVudEtpbmRzLCBNYXJrVHlwZXMgfSBmcm9tICcuL25vZGUtdHlwZXMnO1xuaW1wb3J0IHsgVG9vbGJhckl0ZW0sIFRvb2xiYXJLZXkgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IFRvb2xiYXJBY3Rpb25UeXBlcywgU1RBTkRBUkRfSEVBRElOR19UWVBFUyB9IGZyb20gJy4uL2NvbnN0YW50cy9ub2RlLXR5cGVzJztcbmltcG9ydCB0eXBlIHsgVGhlVG9vbGJhckdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cy90b29sYmFyLWdyb3VwL3Rvb2xiYXItZ3JvdXAuY29tcG9uZW50JztcblxuZXhwb3J0IGNvbnN0IFRoZVRvb2xiYXJHcm91cFRva2VuID0gbmV3IEluamVjdGlvblRva2VuPENvbXBvbmVudFR5cGU8VGhlVG9vbGJhckdyb3VwQ29tcG9uZW50Pj4oJ3RoZS10b29sYmFyLWdyb3VwLXRva2VuJyk7XG5cbmV4cG9ydCBlbnVtIERyb3Bkb3duTW9kZSB7XG4gICAgaWNvbiA9ICdpY29uLW1vZGUnLFxuICAgIHRleHQgPSAndGV4dC1tb2RlJ1xufVxuXG5leHBvcnQgY29uc3QgRGVmYXVsdEdsb2JhbFRvb2xiYXJEZWZpbml0aW9uOiBUb29sYmFyS2V5W10gPSBbXG4gICAgRWxlbWVudEtpbmRzLmhlYWRpbmdMaXN0LFxuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5zcGxpdCxcbiAgICBNYXJrVHlwZXMuYm9sZCxcbiAgICBNYXJrVHlwZXMuaXRhbGljLFxuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5ncm91cCxcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMuc3BsaXQsXG4gICAgTWFya1R5cGVzLmNvbG9yLFxuICAgIE1hcmtUeXBlcy5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnNwbGl0LFxuICAgIEVsZW1lbnRLaW5kcy5pbmRlbnQsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLmFsaWduVHlwZSxcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMudmVydGljYWxBbGlnbixcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMuc3BsaXQsXG4gICAgRWxlbWVudEtpbmRzLm51bWJlcmVkTGlzdCxcbiAgICBFbGVtZW50S2luZHMuYnVsbGV0ZWRMaXN0LFxuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5zcGxpdCxcbiAgICBFbGVtZW50S2luZHMubGluayxcbiAgICBFbGVtZW50S2luZHMuaW1hZ2UsXG4gICAgRWxlbWVudEtpbmRzLnRhYmxlLFxuICAgIEVsZW1lbnRLaW5kcy5ibG9ja3F1b3RlLFxuICAgIEVsZW1lbnRLaW5kcy5ocixcbiAgICBFbGVtZW50S2luZHMuY29kZVxuXTtcblxuZXhwb3J0IGNvbnN0IERlZmF1bHRJbmxpbmVUb29sYmFyRGVmaW5pdGlvbjogVG9vbGJhcktleVtdID0gW1xuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5jbGVhbixcbiAgICBUb29sYmFyQWN0aW9uVHlwZXMuc3BsaXQsXG4gICAgTWFya1R5cGVzLmJvbGQsXG4gICAgTWFya1R5cGVzLml0YWxpYyxcbiAgICBNYXJrVHlwZXMudW5kZXJsaW5lLFxuICAgIE1hcmtUeXBlcy5zdHJpa2UsXG4gICAgRWxlbWVudEtpbmRzLmlubGluZUNvZGUsXG4gICAgTWFya1R5cGVzLmNvbG9yLFxuICAgIE1hcmtUeXBlcy5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnNwbGl0LFxuICAgIFRvb2xiYXJBY3Rpb25UeXBlcy5hbGlnblR5cGUsXG4gICAgVG9vbGJhckFjdGlvblR5cGVzLnNwbGl0LFxuICAgIEVsZW1lbnRLaW5kcy5saW5rXG5dO1xuXG5leHBvcnQgY29uc3QgVG9vbGJhck1vcmVHcm91cDogVG9vbGJhckl0ZW0gPSB7XG4gICAga2V5OiAnbW9yZScsXG4gICAgaWNvbjogJ21vcmUnXG59O1xuIl19