@worktile/theia 14.2.0 → 14.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/components/plugin-menu/plugin-menu.component.mjs +3 -3
- package/esm2020/interfaces/editor.mjs +1 -1
- package/esm2020/plugins/todo-item/todo-item.plugin.mjs +15 -2
- package/fesm2015/worktile-theia.mjs +15 -2
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +15 -2
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/interfaces/editor.d.ts +2 -2
- package/package.json +1 -1
|
@@ -45,9 +45,9 @@ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
|
|
|
45
45
|
}
|
|
46
46
|
ngOnInit() {
|
|
47
47
|
this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);
|
|
48
|
-
let currentMenu = DefaultPluginMenu;
|
|
48
|
+
let currentMenu = this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;
|
|
49
49
|
const menuItemsMap = buildPluginMenuItemMap(this.editor);
|
|
50
|
-
this.pluginMenu =
|
|
50
|
+
this.pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);
|
|
51
51
|
this.buildMenus();
|
|
52
52
|
}
|
|
53
53
|
buildMenus() {
|
|
@@ -99,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
99
99
|
}], editor: [{
|
|
100
100
|
type: Input
|
|
101
101
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/plugin-menu/plugin-menu.component.ts","../../../../../packages/src/components/plugin-menu/plugin-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ElementRef, ChangeDetectorRef, HostBinding } from '@angular/core';\nimport { mixinUnsubscribe, MixinBase } from 'ngx-tethys/core';\nimport { Editor, Node, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig } from '../../interfaces/plugins/plugin-menu';\nimport { getPluginOptions } from '../../core';\nimport { QuickInsertPluginOptions } from '../../plugins/quick-insert/quick-insert.plugin';\nimport { PluginKeys } from '../../interfaces';\nimport { QuickInsertEditor } from '../../plugins/public-api';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html'\n})\nexport class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    editorElement: HTMLElement;\n\n    ThePluginMenu = ThePluginMenu;\n\n    pluginMenu: ThePluginMenu;\n\n    groupMenu: ThePluginMenu = [];\n\n    iconMenu: ThePluginMenu = [];\n\n    ThePluginMenuItemType = ThePluginMenuItemType;\n\n    keyWords: string;\n\n    thyMessage = '暂无数据';\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '266px'\n    };\n\n    @HostBinding('class') containerClassName = `the-plugin-menu-container`;\n\n    @Input() editor: Editor;\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef) {\n        super();\n    }\n\n    ngOnInit() {\n        this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);\n        let currentMenu = DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this.pluginMenu = this.editor.options.menu ? this.editor.options.menu : buildPluginMenu(menuItemsMap, currentMenu);\n        this.buildMenus();\n    }\n\n    buildMenus() {\n        if (this.keyWords) {\n            this.iconMenu = [];\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.keywords && item?.keywords.includes(this.keyWords);\n            });\n\n            if (this.groupMenu.length > 0) {\n                this.groupMenu.unshift(this.searchGroup);\n            }\n        } else {\n            this.iconMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type === ThePluginMenuItemType.icon;\n            });\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type !== ThePluginMenuItemType.icon;\n            });\n        }\n\n        this.cdr.detectChanges();\n    }\n\n    executeItem(event: MouseEvent, menuItem: ThePluginMenuItem) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.removeKeywords();\n        const toolbarItem: any = this.pluginMenu.find((item: ThePluginMenuItem) => item.key === menuItem.key);\n        if (toolbarItem.execute) {\n            toolbarItem.execute(this.editor);\n        }\n        QuickInsertEditor.closeMenu(this.editor);\n    }\n\n    removeKeywords = () => {\n        const hotkey = getPluginOptions<QuickInsertPluginOptions>(this.editor, PluginKeys.quickInsert)?.hotkey;\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && node.text.includes(hotkey)) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n    <div class=\"icon-menu d-flex px-5 py-1\">\n        <ng-container *ngFor=\"let item of iconMenu\">\n            <a\n                *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n                href=\"javascript:;\"\n                class=\"mt-2\"\n                thyAction\n                [thyActionIcon]=\"item.icon\"\n                [thyTooltip]=\"item.name\"\n                (mousedown)=\"executeItem($event, item)\"\n            ></a>\n        </ng-container>\n    </div>\n\n    <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n    <ng-container *ngFor=\"let item of groupMenu\">\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n            <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n            </div>\n        </ng-container>\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n            <div\n                [thyDropdown]=\"expand\"\n                thyTrigger=\"hover\"\n                thyDropdownMenuItem\n                [thyPopoverOptions]=\"expandPopoverOptions\"\n                class=\"insert-menu-item mb-1 py-0\"\n                (mousedown)=\"executeItem($event, item)\"\n            >\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n                <div *ngIf=\"item?.isExpanded\">\n                    <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                </div>\n            </div>\n            <thy-dropdown-menu class=\"expand-menu\" #expand>\n                <div class=\"the-plugin-menu-container\">\n                    <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n                        <div class=\"menu-icon mr-2\">\n                            <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n                        </div>\n                        <div class=\"menu-content d-flex align-items-center\">\n                            <div class=\"menu-item-title w-100\">\n                                <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n                                {{ child.name }}\n                            </div>\n                            <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n                        </div>\n                    </div>\n                </div>\n                <table-select\n                    *ngIf=\"item.key === 'table'\"\n                    class=\"plugin-menu-table the-table-selector-panel\"\n                    [editor]=\"editor\"\n                    [beforeInsert]=\"removeKeywords\"\n                ></table-select>\n            </thy-dropdown-menu>\n        </ng-container>\n\n        <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n            <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n        </ng-container>\n    </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n    <div class=\"empty d-flex align-items-center justify-content-center\">\n        <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n    </div>\n</ng-template>\n"]}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/plugin-menu/plugin-menu.component.ts","../../../../../packages/src/components/plugin-menu/plugin-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ElementRef, ChangeDetectorRef, HostBinding } from '@angular/core';\nimport { mixinUnsubscribe, MixinBase } from 'ngx-tethys/core';\nimport { Editor, Node, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig } from '../../interfaces/plugins/plugin-menu';\nimport { getPluginOptions } from '../../core';\nimport { QuickInsertPluginOptions } from '../../plugins/quick-insert/quick-insert.plugin';\nimport { PluginKeys } from '../../interfaces';\nimport { QuickInsertEditor } from '../../plugins/public-api';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html'\n})\nexport class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    editorElement: HTMLElement;\n\n    ThePluginMenu = ThePluginMenu;\n\n    pluginMenu: ThePluginMenu;\n\n    groupMenu: ThePluginMenu = [];\n\n    iconMenu: ThePluginMenu = [];\n\n    ThePluginMenuItemType = ThePluginMenuItemType;\n\n    keyWords: string;\n\n    thyMessage = '暂无数据';\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '266px'\n    };\n\n    @HostBinding('class') containerClassName = `the-plugin-menu-container`;\n\n    @Input() editor: Editor;\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef) {\n        super();\n    }\n\n    ngOnInit() {\n        this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);\n        let currentMenu =  this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this.pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\n        this.buildMenus();\n    }\n\n    buildMenus() {\n        if (this.keyWords) {\n            this.iconMenu = [];\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.keywords && item?.keywords.includes(this.keyWords);\n            });\n\n            if (this.groupMenu.length > 0) {\n                this.groupMenu.unshift(this.searchGroup);\n            }\n        } else {\n            this.iconMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type === ThePluginMenuItemType.icon;\n            });\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type !== ThePluginMenuItemType.icon;\n            });\n        }\n\n        this.cdr.detectChanges();\n    }\n\n    executeItem(event: MouseEvent, menuItem: ThePluginMenuItem) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.removeKeywords();\n        const toolbarItem: any = this.pluginMenu.find((item: ThePluginMenuItem) => item.key === menuItem.key);\n        if (toolbarItem.execute) {\n            toolbarItem.execute(this.editor);\n        }\n        QuickInsertEditor.closeMenu(this.editor);\n    }\n\n    removeKeywords = () => {\n        const hotkey = getPluginOptions<QuickInsertPluginOptions>(this.editor, PluginKeys.quickInsert)?.hotkey;\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && node.text.includes(hotkey)) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n    <div class=\"icon-menu d-flex px-5 py-1\">\n        <ng-container *ngFor=\"let item of iconMenu\">\n            <a\n                *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n                href=\"javascript:;\"\n                class=\"mt-2\"\n                thyAction\n                [thyActionIcon]=\"item.icon\"\n                [thyTooltip]=\"item.name\"\n                (mousedown)=\"executeItem($event, item)\"\n            ></a>\n        </ng-container>\n    </div>\n\n    <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n    <ng-container *ngFor=\"let item of groupMenu\">\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n            <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n            </div>\n        </ng-container>\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n            <div\n                [thyDropdown]=\"expand\"\n                thyTrigger=\"hover\"\n                thyDropdownMenuItem\n                [thyPopoverOptions]=\"expandPopoverOptions\"\n                class=\"insert-menu-item mb-1 py-0\"\n                (mousedown)=\"executeItem($event, item)\"\n            >\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n                <div *ngIf=\"item?.isExpanded\">\n                    <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                </div>\n            </div>\n            <thy-dropdown-menu class=\"expand-menu\" #expand>\n                <div class=\"the-plugin-menu-container\">\n                    <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n                        <div class=\"menu-icon mr-2\">\n                            <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n                        </div>\n                        <div class=\"menu-content d-flex align-items-center\">\n                            <div class=\"menu-item-title w-100\">\n                                <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n                                {{ child.name }}\n                            </div>\n                            <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n                        </div>\n                    </div>\n                </div>\n                <table-select\n                    *ngIf=\"item.key === 'table'\"\n                    class=\"plugin-menu-table the-table-selector-panel\"\n                    [editor]=\"editor\"\n                    [beforeInsert]=\"removeKeywords\"\n                ></table-select>\n            </thy-dropdown-menu>\n        </ng-container>\n\n        <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n            <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n        </ng-container>\n    </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n    <div class=\"empty d-flex align-items-center justify-content-center\">\n        <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n    </div>\n</ng-template>\n"]}
|
|
@@ -22,4 +22,4 @@ export const THE_MODE_PROVIDER = {
|
|
|
22
22
|
mode: TheMode.default
|
|
23
23
|
}
|
|
24
24
|
};
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2ludGVyZmFjZXMvZWRpdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsT0FBTyxFQUFFLGFBQWEsRUFBOEIsTUFBTSxlQUFlLENBQUM7QUF3QjFFLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRztJQUNyQixHQUFHLGFBQWE7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBTixJQUFZLFdBR1g7QUFIRCxXQUFZLFdBQVc7SUFDbkIsNEJBQWEsQ0FBQTtJQUNiLDRCQUFhLENBQUE7QUFDakIsQ0FBQyxFQUhXLFdBQVcsS0FBWCxXQUFXLFFBR3RCO0FBRUQsTUFBTSxDQUFOLElBQVksT0FHWDtBQUhELFdBQVksT0FBTztJQUNmLDhCQUFtQixDQUFBO0lBQ25CLDBCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUhXLE9BQU8sS0FBUCxPQUFPLFFBR2xCO0FBSUQsTUFBTSxPQUFPLGFBQWE7Q0FFekI7QUFFRCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsSUFBSSxjQUFjLENBQWdCLFVBQVUsQ0FBQyxDQUFDO0FBRTVFLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHO0lBQzdCLE9BQU8sRUFBRSxjQUFjO0lBQ3ZCLFFBQVEsRUFBRTtRQUNOLElBQUksRUFBRSxPQUFPLENBQUMsT0FBTztLQUN4QjtDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQW5jZXN0b3IsIFJhbmdlLCBQYXRoLCBQb2ludCwgTm9kZSwgU3BhbiwgTm9kZUVudHJ5LCBFZGl0b3IsIEVsZW1lbnQsIFRleHQgfSBmcm9tICdzbGF0ZSc7XG5pbXBvcnQgeyBBbmd1bGFyRWRpdG9yLCBTbGF0ZVBsYWNlaG9sZGVyLCBWaWV3VHlwZSB9IGZyb20gJ3NsYXRlLWFuZ3VsYXInO1xuaW1wb3J0IHsgSGlzdG9yeUVkaXRvciB9IGZyb20gJ3NsYXRlLWhpc3RvcnknO1xuaW1wb3J0IHsgRWxlbWVudE9wdGlvbnNJbmZvIH0gZnJvbSAnLi92YWxpZC1jaGlsZHJlbi10eXBlcyc7XG5pbXBvcnQgeyBQcmVkaWNhdGUgfSBmcm9tICcuLi91dGlscy9tYXRjaCc7XG5pbXBvcnQgeyBUb29sYmFyT3B0aW9uIH0gZnJvbSAnLi90b29sYmFyJztcbmltcG9ydCB7IEN1c3RvbUVsZW1lbnRLaW5kcyB9IGZyb20gJy4uL2N1c3RvbS10eXBlcyc7XG5pbXBvcnQgeyBGb250U2l6ZXMgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgVGhlUGx1Z2luIH0gZnJvbSAnLi9wbHVnaW5zJztcbmltcG9ydCB7IE92ZXJyaWRlQnlLZXksIE5lc3RlZFN0cnVjdHVyZUJ5S2V5IH0gZnJvbSAnLi91dGlsaXR5JztcbmltcG9ydCB7IFRoZVBsdWdpbk1lbnUsIFRoZVBsdWdpbk1lbnVJdGVtQ29uZmlnIH0gZnJvbSAnLi9wbHVnaW5zL3BsdWdpbi1tZW51JztcblxuZXhwb3J0IGludGVyZmFjZSBUaGVFZGl0b3IgZXh0ZW5kcyBBbmd1bGFyRWRpdG9yLCBIaXN0b3J5RWRpdG9yIHtcbiAgICBba2V5OiBzdHJpbmddOiBhbnk7XG4gICAgb3B0aW9uczogVGhlT3B0aW9ucztcbiAgICBwbHVnaW5zOiBUaGVQbHVnaW5bXTtcbiAgICBkaXNhYmxlZDogYm9vbGVhbjtcbiAgICBwbHVnaW5zQnlLZXk6IE92ZXJyaWRlQnlLZXk7XG4gICAgbmVzdGVkU3RydWN0dXJlQnlLZXk6IE5lc3RlZFN0cnVjdHVyZUJ5S2V5O1xuICAgIGV4dHJhRWxlbWVudE9wdGlvbnM6IEVsZW1lbnRPcHRpb25zSW5mb1tdO1xuICAgIHJlbmRlckVsZW1lbnQ6IChlbGVtZW50OiBFbGVtZW50KSA9PiBWaWV3VHlwZTtcbiAgICByZW5kZXJMZWFmOiAodGV4dDogVGV4dCkgPT4gVmlld1R5cGU7XG4gICAgaXNDb250YWluZXI6IChlbGVtZW50OiBFbGVtZW50KSA9PiBib29sZWFuO1xufVxuXG5leHBvcnQgY29uc3QgVGhlRWRpdG9yID0ge1xuICAgIC4uLkFuZ3VsYXJFZGl0b3Jcbn07XG5cbmV4cG9ydCBlbnVtIFRoZURhdGFNb2RlIHtcbiAgICBqc29uID0gJ2pzb24nLFxuICAgIGh0bWwgPSAnaHRtbCdcbn1cblxuZXhwb3J0IGVudW0gVGhlTW9kZSB7XG4gICAgZGVmYXVsdCA9ICdkZWZhdWx0JyxcbiAgICBwcmludCA9ICdwcmludCdcbn1cblxuZXhwb3J0IHR5cGUgVGhlTW9kZVR5cGUgPSBUaGVNb2RlIHwgc3RyaW5nO1xuXG5leHBvcnQgY2xhc3MgVGhlTW9kZUNvbmZpZyB7XG4gICAgbW9kZTogVGhlTW9kZVR5cGU7XG59XG5cbmV4cG9ydCBjb25zdCBUSEVfTU9ERV9UT0tFTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUaGVNb2RlQ29uZmlnPigndGhlLW1vZGUnKTtcblxuZXhwb3J0IGNvbnN0IFRIRV9NT0RFX1BST1ZJREVSID0ge1xuICAgIHByb3ZpZGU6IFRIRV9NT0RFX1RPS0VOLFxuICAgIHVzZVZhbHVlOiB7XG4gICAgICAgIG1vZGU6IFRoZU1vZGUuZGVmYXVsdFxuICAgIH1cbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGhlT3B0aW9ucyB7XG4gICAgbW9kZT86IFRoZURhdGFNb2RlO1xuICAgIHJlYWRvbmx5PzogYm9vbGVhbjtcbiAgICBkaXNhYmxlZD86IGJvb2xlYW47XG4gICAgYXV0b0ZvY3VzPzogYm9vbGVhbjtcbiAgICBwbGFjZWhvbGRlcj86IHN0cmluZztcbiAgICBwbGFjZWhvbGRlckRlY29yYXRlPzogKGVkaXRvcjogRWRpdG9yKSA9PiBTbGF0ZVBsYWNlaG9sZGVyW107XG4gICAgaW5saW5lVG9vbGJhclZpc2libGU/OiBib29sZWFuO1xuICAgIHNjcm9sbENvbnRhaW5lcj86IHN0cmluZztcbiAgICBtYXhIZWlnaHQ/OiBudW1iZXI7XG4gICAgZm9udFNpemU/OiBGb250U2l6ZXM7XG4gICAgcmljaE1lZGlhPzogYm9vbGVhbjtcbiAgICB0b29sYmFyPzogVG9vbGJhck9wdGlvbjtcbiAgICBtZW51PzogVGhlUGx1Z2luTWVudUl0ZW1Db25maWdbXTtcbiAgICBkaXNhYmxlUGx1Z2lucz86IHN0cmluZ1tdO1xuICAgIGV4dHJhRWxlbWVudE9wdGlvbnM/OiBFbGVtZW50T3B0aW9uc0luZm9bXTtcbn1cblxuZXhwb3J0IHR5cGUgTm9kZU1hdGNoPFQgPSBOb2RlPiA9IFByZWRpY2F0ZTxUPjtcblxuZXhwb3J0IGludGVyZmFjZSBNYXRjaE9wdGlvbnM8VCA9IE5vZGU+IHtcbiAgICBtYXRjaD86IE5vZGVNYXRjaDxUPjtcbiAgICBibG9jaz86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5kZW50T3B0aW9ucyB7XG4gICAgaW5kZW50VHlwZXM/OiBDdXN0b21FbGVtZW50S2luZHNbXTtcbiAgICBkaXNhYmxlZEluZGVudFR5cGVzPzogQ3VzdG9tRWxlbWVudEtpbmRzW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRWRpdG9yQWJvdmVPcHRpb25zPFQgPSBBbmNlc3Rvcj4gZXh0ZW5kcyBNYXRjaE9wdGlvbnM8VD4ge1xuICAgIGF0PzogUmFuZ2UgfCBQYXRoIHwgUG9pbnQ7XG4gICAgbW9kZT86ICdoaWdoZXN0JyB8ICdsb3dlc3QnO1xuICAgIHZvaWRzPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFZGl0b3JOb2Rlc09wdGlvbnMge1xuICAgIGF0PzogUmFuZ2UgfCBQYXRoIHwgUG9pbnQgfCBTcGFuO1xuICAgIG1hdGNoPzogKG5vZGU6IE5vZGUpID0+IGJvb2xlYW47XG4gICAgbW9kZT86ICdoaWdoZXN0JyB8ICdsb3dlc3QnIHwgJ2FsbCc7XG4gICAgdW5pdmVyc2FsPzogYm9vbGVhbjtcbiAgICByZXZlcnNlPzogYm9vbGVhbjtcbiAgICB2b2lkcz86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV3JhcE9wdGlvbnMge1xuICAgIGF0PzogUGF0aCB8IFBvaW50IHwgUmFuZ2U7XG4gICAgbWF0Y2g/OiAobm9kZTogTm9kZSkgPT4gYm9vbGVhbjtcbiAgICBtb2RlPzogJ2hpZ2hlc3QnIHwgJ2xvd2VzdCcgfCAnYWxsJztcbiAgICBzcGxpdD86IGJvb2xlYW47XG4gICAgdm9pZHM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVkaXRvclBhcmVudE9wdGlvbnMge1xuICAgIGRlcHRoPzogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICAgIGVkZ2U/OiAnc3RhcnQnIHwgJ2VuZCcgfCB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUXVlcnlPcHRpb25zIHtcbiAgICAvLyBDb25kaXRpb24gb24gdGhlIG5vZGUgdG8gYmUgdmFsaWQuXG4gICAgZmlsdGVyPzogKGVudHJ5OiBOb2RlRW50cnk8Tm9kZT4pID0+IGJvb2xlYW47XG4gICAgLy8gTGlzdCBvZiB0eXBlcyB0aGF0IGFyZSB2YWxpZC4gSWYgZW1wdHkgb3IgdW5kZWZpbmVkIC0gYWxsb3cgYWxsLlxuICAgIGFsbG93Pzogc3RyaW5nW107XG4gICAgLy8gTGlzdCBvZiB0eXBlcyB0aGF0IGFyZSBpbnZhbGlkLlxuICAgIGV4Y2x1ZGU/OiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEb21FdmVudERhdGFJbmZvIHtcbiAgICBpbnB1dFR5cGU/OiBzdHJpbmc7XG4gICAga2V5Pzogc3RyaW5nO1xuICAgIHRleHQ/OiBzdHJpbmc7XG4gICAganNvbj86IE5vZGVbXTtcbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Transforms, Range, Editor, Element } from 'slate';
|
|
2
2
|
import { createPluginFactory } from '../../core';
|
|
3
3
|
import { PluginKeys } from '../../interfaces';
|
|
4
|
-
import { ElementKinds } from '../../constants';
|
|
4
|
+
import { ElementKinds, PluginMenuIcons, ThePluginMenuItemType } from '../../constants';
|
|
5
5
|
import { TheTodoItemComponent } from './todo-item.component';
|
|
6
6
|
import { TodoItemEditor } from './todo-item.editor';
|
|
7
7
|
import * as TheQueries from '../../queries';
|
|
@@ -71,9 +71,22 @@ export const createTodoItemPlugin = createPluginFactory({
|
|
|
71
71
|
active: editor => TodoItemEditor.isActive(editor)
|
|
72
72
|
}
|
|
73
73
|
],
|
|
74
|
+
menuItems: [
|
|
75
|
+
{
|
|
76
|
+
key: ElementKinds.checkItem,
|
|
77
|
+
keywords: 'dbsx,daibanshixiang,todolist,待办事项',
|
|
78
|
+
execute: editor => TodoItemEditor.insertTodoItem(editor),
|
|
79
|
+
active: editor => TodoItemEditor.isActive(editor),
|
|
80
|
+
type: ThePluginMenuItemType.icon,
|
|
81
|
+
name: '待办事项',
|
|
82
|
+
displayKey: '/dbsx',
|
|
83
|
+
icon: 'list-check',
|
|
84
|
+
menuIcon: PluginMenuIcons.numberedList
|
|
85
|
+
}
|
|
86
|
+
],
|
|
74
87
|
options: {
|
|
75
88
|
allowParentTypes: [ElementKinds.tableCell, ElementKinds.blockquote],
|
|
76
89
|
editableWithReadonly: false
|
|
77
90
|
}
|
|
78
91
|
});
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"todo-item.plugin.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/todo-item/todo-item.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transforms, Range, Editor, Element, Descendant } from 'slate';\nimport { createPluginFactory } from '../../core';\nimport { PluginKeys } from '../../interfaces';\nimport { ElementKinds } from '../../constants';\nimport { TheTodoItemComponent } from './todo-item.component';\nimport { TodoItemEditor } from './todo-item.editor';\nimport * as TheQueries from '../../queries';\n\nexport interface TodoItemPluginOptions {\n    editableWithReadonly?: boolean;\n}\n\nexport const withTodoItem = <T extends Editor>(editor: T): T => {\n    const { insertBreak, deleteBackward, renderElement } = editor;\n\n    editor.insertBreak = () => {\n        const { selection } = editor;\n\n        if (selection && Range.isCollapsed(selection)) {\n            const [match] = Editor.nodes(editor, {\n                match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n            });\n\n            if (match) {\n                const [, path] = match;\n                const block = TheQueries.anchorBlock(editor);\n\n                if (block && Editor.isStart(editor, selection.anchor, path) && Editor.isEmpty(editor, block)) {\n                    Transforms.setNodes(\n                        editor,\n                        {\n                            type: ElementKinds.default,\n                            checked: undefined\n                        } as Partial<Descendant>,\n                        {\n                            match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n                        }\n                    );\n                    return;\n                }\n            }\n        }\n        insertBreak();\n\n        const anchorBlock = TheQueries.anchorBlock(editor);\n        if (anchorBlock && anchorBlock.type === ElementKinds.checkItem) {\n            Transforms.setNodes(editor, { checked: false });\n        }\n    };\n\n    editor.deleteBackward = unit => {\n        const { selection } = editor;\n\n        if (selection && Range.isCollapsed(selection)) {\n            const [match] = Editor.nodes(editor, {\n                match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n            });\n\n            if (match) {\n                const [, path] = match;\n\n                if (Editor.isStart(editor, selection.anchor, path)) {\n                    Transforms.setNodes(editor, { type: ElementKinds.default, checked: undefined } as Partial<Descendant>, {\n                        match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n                    });\n                    return;\n                }\n            }\n        }\n        deleteBackward(unit);\n    };\n\n    editor.renderElement = (element: Element) => {\n        if (element.type === ElementKinds.checkItem) {\n            return TheTodoItemComponent;\n        }\n        return renderElement(element);\n    };\n\n    return editor;\n};\n\nexport const createTodoItemPlugin = createPluginFactory<TodoItemPluginOptions>({\n    key: PluginKeys.checkItem,\n    withOverrides: withTodoItem,\n    toolbarItems: [\n        {\n            key: ElementKinds.checkItem,\n            icon: 'list-check',\n            name: '待办事项',\n            execute: editor => TodoItemEditor.insertTodoItem(editor),\n            active: editor => TodoItemEditor.isActive(editor)\n        }\n    ],\n    options: {\n        allowParentTypes: [ElementKinds.tableCell, ElementKinds.blockquote],\n        editableWithReadonly: false\n    }\n});\n"]}
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"todo-item.plugin.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/todo-item/todo-item.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transforms, Range, Editor, Element, Descendant } from 'slate';\nimport { createPluginFactory } from '../../core';\nimport { PluginKeys } from '../../interfaces';\nimport { ElementKinds, PluginMenuIcons, ThePluginMenuItemType } from '../../constants';\nimport { TheTodoItemComponent } from './todo-item.component';\nimport { TodoItemEditor } from './todo-item.editor';\nimport * as TheQueries from '../../queries';\n\nexport interface TodoItemPluginOptions {\n    editableWithReadonly?: boolean;\n}\n\nexport const withTodoItem = <T extends Editor>(editor: T): T => {\n    const { insertBreak, deleteBackward, renderElement } = editor;\n\n    editor.insertBreak = () => {\n        const { selection } = editor;\n\n        if (selection && Range.isCollapsed(selection)) {\n            const [match] = Editor.nodes(editor, {\n                match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n            });\n\n            if (match) {\n                const [, path] = match;\n                const block = TheQueries.anchorBlock(editor);\n\n                if (block && Editor.isStart(editor, selection.anchor, path) && Editor.isEmpty(editor, block)) {\n                    Transforms.setNodes(\n                        editor,\n                        {\n                            type: ElementKinds.default,\n                            checked: undefined\n                        } as Partial<Descendant>,\n                        {\n                            match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n                        }\n                    );\n                    return;\n                }\n            }\n        }\n        insertBreak();\n\n        const anchorBlock = TheQueries.anchorBlock(editor);\n        if (anchorBlock && anchorBlock.type === ElementKinds.checkItem) {\n            Transforms.setNodes(editor, { checked: false });\n        }\n    };\n\n    editor.deleteBackward = unit => {\n        const { selection } = editor;\n        if (selection && Range.isCollapsed(selection)) {\n            const [match] = Editor.nodes(editor, {\n                match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n            });\n\n            if (match) {\n                const [, path] = match;\n\n                if (Editor.isStart(editor, selection.anchor, path)) {\n                    Transforms.setNodes(editor, { type: ElementKinds.default, checked: undefined } as Partial<Descendant>, {\n                        match: n => Element.isElement(n) && n.type === ElementKinds.checkItem\n                    });\n                    return;\n                }\n            }\n        }\n        deleteBackward(unit);\n    };\n\n    editor.renderElement = (element: Element) => {\n        if (element.type === ElementKinds.checkItem) {\n            return TheTodoItemComponent;\n        }\n        return renderElement(element);\n    };\n\n    return editor;\n};\n\nexport const createTodoItemPlugin = createPluginFactory<TodoItemPluginOptions>({\n    key: PluginKeys.checkItem,\n    withOverrides: withTodoItem,\n    toolbarItems: [\n        {\n            key: ElementKinds.checkItem,\n            icon: 'list-check',\n            name: '待办事项',\n            execute: editor => TodoItemEditor.insertTodoItem(editor),\n            active: editor => TodoItemEditor.isActive(editor)\n        }\n    ],\n    menuItems: [\n        {\n            key: ElementKinds.checkItem,\n            keywords: 'dbsx,daibanshixiang,todolist,待办事项',\n            execute: editor => TodoItemEditor.insertTodoItem(editor),\n            active: editor => TodoItemEditor.isActive(editor),\n            type: ThePluginMenuItemType.icon,\n            name: '待办事项',\n            displayKey: '/dbsx',\n            icon: 'list-check',\n            menuIcon: PluginMenuIcons.numberedList\n        }\n    ],\n    options: {\n        allowParentTypes: [ElementKinds.tableCell, ElementKinds.blockquote],\n        editableWithReadonly: false\n    }\n});\n"]}
|
|
@@ -9783,9 +9783,9 @@ class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
|
|
|
9783
9783
|
}
|
|
9784
9784
|
ngOnInit() {
|
|
9785
9785
|
this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);
|
|
9786
|
-
let currentMenu = DefaultPluginMenu;
|
|
9786
|
+
let currentMenu = this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;
|
|
9787
9787
|
const menuItemsMap = buildPluginMenuItemMap(this.editor);
|
|
9788
|
-
this.pluginMenu =
|
|
9788
|
+
this.pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);
|
|
9789
9789
|
this.buildMenus();
|
|
9790
9790
|
}
|
|
9791
9791
|
buildMenus() {
|
|
@@ -13671,6 +13671,19 @@ const createTodoItemPlugin = createPluginFactory({
|
|
|
13671
13671
|
active: editor => TodoItemEditor.isActive(editor)
|
|
13672
13672
|
}
|
|
13673
13673
|
],
|
|
13674
|
+
menuItems: [
|
|
13675
|
+
{
|
|
13676
|
+
key: ElementKinds.checkItem,
|
|
13677
|
+
keywords: 'dbsx,daibanshixiang,todolist,待办事项',
|
|
13678
|
+
execute: editor => TodoItemEditor.insertTodoItem(editor),
|
|
13679
|
+
active: editor => TodoItemEditor.isActive(editor),
|
|
13680
|
+
type: ThePluginMenuItemType.icon,
|
|
13681
|
+
name: '待办事项',
|
|
13682
|
+
displayKey: '/dbsx',
|
|
13683
|
+
icon: 'list-check',
|
|
13684
|
+
menuIcon: PluginMenuIcons.numberedList
|
|
13685
|
+
}
|
|
13686
|
+
],
|
|
13674
13687
|
options: {
|
|
13675
13688
|
allowParentTypes: [ElementKinds.tableCell, ElementKinds.blockquote],
|
|
13676
13689
|
editableWithReadonly: false
|