@worktile/theia 17.2.2 → 17.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/column-resize/column-resize.directive.d.ts +5 -3
- package/components/column-resize/column-resize.scss +0 -7
- package/components/column-resize/overlay-handle.component.d.ts +4 -6
- package/components/column-resize/resizing.store.d.ts +0 -8
- package/components/inline-toolbar/inline-toolbar.component.d.ts +1 -1
- package/components/toolbar/toolbar.component.d.ts +0 -1
- package/constants/node-types.d.ts +0 -1
- package/core/utils/plugin-menu.d.ts +8 -0
- package/editor.component.d.ts +1 -1
- package/esm2022/components/column-resize/column-resize.directive.mjs +28 -9
- package/esm2022/components/column-resize/overlay-handle.component.mjs +12 -16
- package/esm2022/components/column-resize/resizing.store.mjs +3 -66
- package/esm2022/components/inline-toolbar/inline-toolbar.component.mjs +13 -22
- package/esm2022/components/plugin-menu/plugin-menu.component.mjs +6 -5
- package/esm2022/components/toolbar/toolbar.component.mjs +2 -7
- package/esm2022/constants/default.mjs +2 -2
- package/esm2022/constants/node-types.mjs +1 -2
- package/esm2022/core/utils/plugin-menu.mjs +34 -1
- package/esm2022/editor.component.mjs +13 -5
- package/esm2022/interfaces/plugins/plugin-menu.mjs +2 -2
- package/esm2022/interfaces/plugins/plugins.mjs +1 -1
- package/esm2022/plugins/common/block-card.plugin.mjs +12 -2
- package/esm2022/plugins/image/image.component.mjs +2 -2
- package/esm2022/plugins/image/image.editor.mjs +2 -3
- package/esm2022/plugins/image/image.plugin.mjs +2 -2
- package/esm2022/plugins/inline-code/inline-code.plugin.mjs +3 -2
- package/esm2022/plugins/link/link.plugin.mjs +4 -3
- package/esm2022/plugins/quick-insert/quick-insert.editor.mjs +4 -2
- package/esm2022/plugins/table/components/insert-mark/insert-mark.component.mjs +41 -17
- package/esm2022/plugins/table/components/row/row.component.mjs +2 -2
- package/esm2022/plugins/table/components/table.component.mjs +22 -26
- package/esm2022/plugins/table/components/td/td.component.mjs +47 -125
- package/esm2022/plugins/table/table.editor.mjs +2 -2
- package/esm2022/plugins/table/table.types.mjs +1 -1
- package/esm2022/plugins/table/utils/get-grid-columns.mjs +2 -2
- package/esm2022/plugins/table/utils/table-viewport.mjs +41 -0
- package/esm2022/plugins/vertical-align/toolbar-item.component.mjs +3 -5
- package/esm2022/queries/anchor-block-entry.mjs +3 -3
- package/esm2022/queries/anchor-block.mjs +3 -3
- package/esm2022/queries/get-block-card-cursor.mjs +6 -2
- package/esm2022/queries/is-block-card-cursor.mjs +7 -2
- package/esm2022/utils/index.mjs +2 -2
- package/esm2022/utils/scrolling.mjs +43 -0
- package/fesm2022/worktile-theia.mjs +294 -314
- package/fesm2022/worktile-theia.mjs.map +1 -1
- package/interfaces/editor.d.ts +2 -2
- package/interfaces/plugins/plugins.d.ts +2 -1
- package/package.json +1 -1
- package/plugins/table/components/insert-mark/insert-mark.component.d.ts +12 -4
- package/plugins/table/components/table.component.d.ts +1 -2
- package/plugins/table/components/table.component.scss +4 -18
- package/plugins/table/components/td/td.component.d.ts +9 -10
- package/plugins/table/table.types.d.ts +2 -2
- package/plugins/table/utils/table-viewport.d.ts +8 -0
- package/plugins/vertical-align/toolbar-item.component.d.ts +2 -3
- package/queries/anchor-block-entry.d.ts +2 -2
- package/queries/anchor-block.d.ts +2 -2
- package/queries/get-block-card-cursor.d.ts +2 -2
- package/queries/is-block-card-cursor.d.ts +2 -2
- package/styles/editor.scss +7 -0
- package/utils/index.d.ts +1 -1
- package/utils/{scroll-into-view.d.ts → scrolling.d.ts} +1 -0
- package/esm2022/utils/scroll-into-view.mjs +0 -38
|
@@ -82,7 +82,7 @@ export const createImagePlugin = createPluginFactory({
|
|
|
82
82
|
],
|
|
83
83
|
options: {
|
|
84
84
|
allowParentTypes: [ElementKinds.listItem, ElementKinds.tableCell, ElementKinds.blockquote],
|
|
85
|
-
imageTypes: ['image/png', 'image/jpeg', 'image/gif', 'image/bmp']
|
|
85
|
+
imageTypes: ['image/png', 'image/jpeg', 'image/gif', 'image/bmp', 'image/svg+xml']
|
|
86
86
|
}
|
|
87
87
|
});
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.plugin.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/image/image.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Element } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { ElementKinds } from '../../constants';\nimport { PluginMenuIcons, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport { createPluginFactory, getPluginOptions } from '../../core';\nimport { ImagePluginOptions, PluginKeys } from '../../interfaces';\nimport { TheImage } from './image.component';\nimport { ImageEditor } from './image.editor';\n\nexport const withImage = <T extends Editor>(editor: T): T => {\n    const { insertData, isVoid, renderElement, isBlockCard, mousedown } = editor;\n\n    editor.isVoid = (element: Element) => {\n        return element.type === ElementKinds.image || isVoid(element);\n    };\n\n    editor.insertData = (data: DataTransfer) => {\n        if (data.files.length) {\n            const imageFiles: File[] = [];\n            const imageTypes = getPluginOptions<ImagePluginOptions>(editor, PluginKeys.image)?.imageTypes;\n            for (const file of data.files as FileList) {\n                if (imageTypes.includes(file.type)) {\n                    imageFiles.push(file);\n                }\n            }\n            if (imageFiles.length) {\n                return ImageEditor.insertImages(editor, imageFiles);\n            }\n        }\n        insertData(data);\n    };\n\n    editor.renderElement = (element: Element) => {\n        if (element.type === ElementKinds.image) {\n            return TheImage;\n        }\n        return renderElement(element);\n    };\n\n    editor.mousedown = (event: MouseEvent) => {\n        const hitElement = event.target as HTMLElement;\n        if (hitElement.classList.contains('the-image-container')) {\n            const imageElement = hitElement.closest('the-image');\n            const blockCardEntry = AngularEditor.toSlateCardEntry(editor, imageElement);\n            if (blockCardEntry && (blockCardEntry[0] as Element).type === ElementKinds.image) {\n                event.preventDefault();\n                const innerImage = hitElement.querySelector('.thy-image');\n                const { x, width } = innerImage.getBoundingClientRect();\n                const centerX = x + width / 2;\n                AngularEditor.moveBlockCard(editor, blockCardEntry[0], { direction: event.x < centerX ? 'left' : 'right' });\n                return;\n            }\n        }\n        mousedown(event);\n    };\n\n    editor.isBlockCard = (element: Element) => {\n        if (element && element.type === ElementKinds.image) {\n            return true;\n        }\n        return isBlockCard(element);\n    };\n\n    return editor;\n};\n\nexport const createImagePlugin = createPluginFactory<ImagePluginOptions>({\n    key: PluginKeys.image,\n    withOverrides: withImage,\n    toolbarItems: [\n        {\n            key: ElementKinds.image,\n            icon: 'image',\n            name: '图片',\n            execute: editor => ImageEditor.openUpload(editor),\n            active: editor => ImageEditor.isActive(editor)\n        }\n    ],\n    menuItems: [\n        {\n            key: ElementKinds.image,\n            keywords: 'tp,tupian,image,photo,picture,图片',\n            execute: editor => ImageEditor.openUpload(editor),\n            active: editor => ImageEditor.isActive(editor),\n            name: '图片',\n            menuIcon: PluginMenuIcons.image,\n            description: '支持 jpg、jpeg 等格式图像',\n            type: ThePluginMenuItemType.group,\n            displayKey: '/tp'\n        }\n    ],\n    options: {\n        allowParentTypes: [ElementKinds.listItem, ElementKinds.tableCell, ElementKinds.blockquote],\n        imageTypes: ['image/png', 'image/jpeg', 'image/gif', 'image/bmp', 'image/svg+xml']\n    }\n});\n"]}
|
|
@@ -3,9 +3,9 @@ import { DISABLED_OPERATE_TYPES, ElementKinds, ZERO_WIDTH_CHAR } from '../../con
|
|
|
3
3
|
import { createPluginFactory } from '../../core';
|
|
4
4
|
import { PluginKeys } from '../../interfaces';
|
|
5
5
|
import { CONTROL_KEY } from '../../utils';
|
|
6
|
+
import { withRemoveEmptyNodes } from '../normalizers/remove-empty-nodes';
|
|
6
7
|
import { TheInlineCode } from './inline-code.component';
|
|
7
8
|
import { InlineCodeEditor } from './inline-code.editor';
|
|
8
|
-
import { withRemoveEmptyNodes } from '../normalizers/remove-empty-nodes';
|
|
9
9
|
export const withInlineCode = (editor) => {
|
|
10
10
|
const { isInline, renderElement, insertText } = editor;
|
|
11
11
|
editor.isInline = (element) => {
|
|
@@ -60,7 +60,8 @@ export const createInlineCodePlugin = createPluginFactory({
|
|
|
60
60
|
}
|
|
61
61
|
],
|
|
62
62
|
options: {
|
|
63
|
+
isInline: true,
|
|
63
64
|
disabledOperateTypes: [ElementKinds.image, ...DISABLED_OPERATE_TYPES]
|
|
64
65
|
}
|
|
65
66
|
});
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5saW5lLWNvZGUucGx1Z2luLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3BsdWdpbnMvaW5saW5lLWNvZGUvaW5saW5lLWNvZGUucGx1Z2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sT0FBTyxDQUFDO0FBQzNDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDeEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRWpELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV4RCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsQ0FBbUIsTUFBUyxFQUFLLEVBQUU7SUFDN0QsTUFBTSxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBRXZELE1BQU0sQ0FBQyxRQUFRLEdBQUcsQ0FBQyxPQUEwQixFQUFFLEVBQUU7UUFDN0MsT0FBTyxPQUFPLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQy9FLENBQUMsQ0FBQztJQUVGLE1BQU0sQ0FBQyxhQUFhLEdBQUcsQ0FBQyxPQUEwQixFQUFFLEVBQUU7UUFDbEQsSUFBSSxPQUFPLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUMzQyxPQUFPLGFBQWEsQ0FBQztRQUN6QixDQUFDO1FBQ0QsT0FBTyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbEMsQ0FBQyxDQUFDO0lBRUYsTUFBTSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsRUFBRTtRQUN2QixJQUFJLElBQUksSUFBSSxnQkFBZ0IsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ3RELElBQUksU0FBUyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7WUFDakMsTUFBTSxlQUFlLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDNUUsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ2pCLElBQUksZUFBZSxJQUFJLGVBQWUsRUFBRSxDQUFDO2dCQUNyQyxNQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7Z0JBQzdELElBQUksS0FBSyxHQUFHO29CQUNSLE1BQU0sRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsTUFBTSxDQUFDO29CQUMvQyxLQUFLLEVBQUUsU0FBUyxDQUFDLE1BQU07aUJBQzFCLENBQUM7Z0JBQ0YsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsTUFBTSxFQUFFLGNBQWMsQ0FBQyxFQUFFLENBQUM7b0JBQzNELEtBQUssR0FBRzt3QkFDSixNQUFNLEVBQUUsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNO3dCQUMvQixLQUFLLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLFNBQVMsQ0FBQztxQkFDaEQsQ0FBQztnQkFDTixDQUFDO2dCQUNELFVBQVUsQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFO29CQUN0QixFQUFFLEVBQUUsS0FBSztpQkFDWixDQUFDLENBQUM7WUFDUCxDQUFDO1FBQ0wsQ0FBQzthQUFNLENBQUM7WUFDSixVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDckIsQ0FBQztJQUNMLENBQUMsQ0FBQztJQUVGLE1BQU0sR0FBRyxvQkFBb0IsQ0FBQyxFQUFFLElBQUksRUFBRSxZQUFZLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN6RSxPQUFPLE1BQU0sQ0FBQztBQUNsQixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxtQkFBbUIsQ0FBQztJQUN0RCxHQUFHLEVBQUUsVUFBVSxDQUFDLFVBQVU7SUFDMUIsYUFBYSxFQUFFLGNBQWM7SUFDN0IsWUFBWSxFQUFFO1FBQ1Y7WUFDSSxHQUFHLEVBQUUsWUFBWSxDQUFDLFVBQVU7WUFDNUIsSUFBSSxFQUFFLE1BQU07WUFDWixJQUFJLEVBQUUsTUFBTTtZQUNaLFdBQVcsRUFBRSxHQUFHLFdBQVcsSUFBSTtZQUMvQixPQUFPLEVBQUUsTUFBTSxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUM7WUFDNUQsTUFBTSxFQUFFLE1BQU0sQ0FBQyxFQUFFLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDO1NBQ2hFO0tBQ0o7SUFDRCxPQUFPLEVBQUU7UUFDTCxRQUFRLEVBQUUsSUFBSTtRQUNkLG9CQUFvQixFQUFFLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxHQUFHLHNCQUFzQixDQUFDO0tBQ3hFO0NBQ0osQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWRpdG9yLCBUcmFuc2Zvcm1zIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgRElTQUJMRURfT1BFUkFURV9UWVBFUywgRWxlbWVudEtpbmRzLCBaRVJPX1dJRFRIX0NIQVIgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgY3JlYXRlUGx1Z2luRmFjdG9yeSB9IGZyb20gJy4uLy4uL2NvcmUnO1xuaW1wb3J0IHsgSW5saW5lQ29kZUVsZW1lbnQgfSBmcm9tICcuLi8uLi9jdXN0b20tdHlwZXMnO1xuaW1wb3J0IHsgUGx1Z2luS2V5cyB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQ09OVFJPTF9LRVkgfSBmcm9tICcuLi8uLi91dGlscyc7XG5pbXBvcnQgeyB3aXRoUmVtb3ZlRW1wdHlOb2RlcyB9IGZyb20gJy4uL25vcm1hbGl6ZXJzL3JlbW92ZS1lbXB0eS1ub2Rlcyc7XG5pbXBvcnQgeyBUaGVJbmxpbmVDb2RlIH0gZnJvbSAnLi9pbmxpbmUtY29kZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5saW5lQ29kZUVkaXRvciB9IGZyb20gJy4vaW5saW5lLWNvZGUuZWRpdG9yJztcblxuZXhwb3J0IGNvbnN0IHdpdGhJbmxpbmVDb2RlID0gPFQgZXh0ZW5kcyBFZGl0b3I+KGVkaXRvcjogVCk6IFQgPT4ge1xuICAgIGNvbnN0IHsgaXNJbmxpbmUsIHJlbmRlckVsZW1lbnQsIGluc2VydFRleHQgfSA9IGVkaXRvcjtcblxuICAgIGVkaXRvci5pc0lubGluZSA9IChlbGVtZW50OiBJbmxpbmVDb2RlRWxlbWVudCkgPT4ge1xuICAgICAgICByZXR1cm4gZWxlbWVudC50eXBlID09PSBFbGVtZW50S2luZHMuaW5saW5lQ29kZSA/IHRydWUgOiBpc0lubGluZShlbGVtZW50KTtcbiAgICB9O1xuXG4gICAgZWRpdG9yLnJlbmRlckVsZW1lbnQgPSAoZWxlbWVudDogSW5saW5lQ29kZUVsZW1lbnQpID0+IHtcbiAgICAgICAgaWYgKGVsZW1lbnQudHlwZSA9PT0gRWxlbWVudEtpbmRzLmlubGluZUNvZGUpIHtcbiAgICAgICAgICAgIHJldHVybiBUaGVJbmxpbmVDb2RlO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiByZW5kZXJFbGVtZW50KGVsZW1lbnQpO1xuICAgIH07XG5cbiAgICBlZGl0b3IuaW5zZXJ0VGV4dCA9IHRleHQgPT4ge1xuICAgICAgICBpZiAodGV4dCAmJiBJbmxpbmVDb2RlRWRpdG9yLmlzSW5saW5lQ29kZUFjdGl2ZShlZGl0b3IpKSB7XG4gICAgICAgICAgICBsZXQgc2VsZWN0aW9uID0gZWRpdG9yLnNlbGVjdGlvbjtcbiAgICAgICAgICAgIGNvbnN0IGN1cnJlbnROb2RlVGV4dCA9IEVkaXRvci5zdHJpbmcoZWRpdG9yLCBlZGl0b3Iuc2VsZWN0aW9uLmFuY2hvci5wYXRoKTtcbiAgICAgICAgICAgIGluc2VydFRleHQodGV4dCk7XG4gICAgICAgICAgICBpZiAoY3VycmVudE5vZGVUZXh0ID09IFpFUk9fV0lEVEhfQ0hBUikge1xuICAgICAgICAgICAgICAgIGNvbnN0IGlubGluZUNvZGVQYXRoID0gRWRpdG9yLnBhdGgoZWRpdG9yLCBlZGl0b3Iuc2VsZWN0aW9uKTtcbiAgICAgICAgICAgICAgICBsZXQgcmFuZ2UgPSB7XG4gICAgICAgICAgICAgICAgICAgIGFuY2hvcjogRWRpdG9yLmJlZm9yZShlZGl0b3IsIHNlbGVjdGlvbi5hbmNob3IpLFxuICAgICAgICAgICAgICAgICAgICBmb2N1czogc2VsZWN0aW9uLmFuY2hvclxuICAgICAgICAgICAgICAgIH07XG4gICAgICAgICAgICAgICAgaWYgKEVkaXRvci5pc1N0YXJ0KGVkaXRvciwgc2VsZWN0aW9uLmFuY2hvciwgaW5saW5lQ29kZVBhdGgpKSB7XG4gICAgICAgICAgICAgICAgICAgIHJhbmdlID0ge1xuICAgICAgICAgICAgICAgICAgICAgICAgYW5jaG9yOiBlZGl0b3Iuc2VsZWN0aW9uLmFuY2hvcixcbiAgICAgICAgICAgICAgICAgICAgICAgIGZvY3VzOiBFZGl0b3IuYWZ0ZXIoZWRpdG9yLCBlZGl0b3Iuc2VsZWN0aW9uKVxuICAgICAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBUcmFuc2Zvcm1zLmRlbGV0ZShlZGl0b3IsIHtcbiAgICAgICAgICAgICAgICAgICAgYXQ6IHJhbmdlXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBpbnNlcnRUZXh0KHRleHQpO1xuICAgICAgICB9XG4gICAgfTtcblxuICAgIGVkaXRvciA9IHdpdGhSZW1vdmVFbXB0eU5vZGVzKHsgdHlwZTogRWxlbWVudEtpbmRzLmlubGluZUNvZGUgfSkoZWRpdG9yKTtcbiAgICByZXR1cm4gZWRpdG9yO1xufTtcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUlubGluZUNvZGVQbHVnaW4gPSBjcmVhdGVQbHVnaW5GYWN0b3J5KHtcbiAgICBrZXk6IFBsdWdpbktleXMuaW5saW5lQ29kZSxcbiAgICB3aXRoT3ZlcnJpZGVzOiB3aXRoSW5saW5lQ29kZSxcbiAgICB0b29sYmFySXRlbXM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAga2V5OiBFbGVtZW50S2luZHMuaW5saW5lQ29kZSxcbiAgICAgICAgICAgIGljb246ICdjb2RlJyxcbiAgICAgICAgICAgIG5hbWU6ICfooYzlhoXku6PnoIEnLFxuICAgICAgICAgICAgc2hvcnRjdXRLZXk6IGAke0NPTlRST0xfS0VZfStFYCxcbiAgICAgICAgICAgIGV4ZWN1dGU6IGVkaXRvciA9PiBJbmxpbmVDb2RlRWRpdG9yLnRvZ2dsZUlubGluZUNvZGUoZWRpdG9yKSxcbiAgICAgICAgICAgIGFjdGl2ZTogZWRpdG9yID0+IElubGluZUNvZGVFZGl0b3IuaXNJbmxpbmVDb2RlQWN0aXZlKGVkaXRvcilcbiAgICAgICAgfVxuICAgIF0sXG4gICAgb3B0aW9uczoge1xuICAgICAgICBpc0lubGluZTogdHJ1ZSxcbiAgICAgICAgZGlzYWJsZWRPcGVyYXRlVHlwZXM6IFtFbGVtZW50S2luZHMuaW1hZ2UsIC4uLkRJU0FCTEVEX09QRVJBVEVfVFlQRVNdXG4gICAgfVxufSk7XG4iXX0=
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import isUrl from 'is-url';
|
|
2
2
|
import { Transforms } from 'slate';
|
|
3
|
+
import { CLIPBOARD_FORMAT_KEY, DISABLED_OPERATE_TYPES, ElementKinds, PluginMenuIcons, ThePluginMenuItemType } from '../../constants';
|
|
3
4
|
import { createPluginFactory } from '../../core';
|
|
4
|
-
import { ElementKinds, CLIPBOARD_FORMAT_KEY, DISABLED_OPERATE_TYPES, ThePluginMenuItemType, PluginMenuIcons } from '../../constants';
|
|
5
5
|
import { PluginKeys } from '../../interfaces';
|
|
6
6
|
import { withRemoveEmptyNodes } from '../normalizers/remove-empty-nodes';
|
|
7
|
-
import { LinkEditor } from './link.editor';
|
|
8
7
|
import { TheLink } from './link.component';
|
|
8
|
+
import { LinkEditor } from './link.editor';
|
|
9
9
|
export const withLink = (editor) => {
|
|
10
10
|
const { insertData, insertText, isInline, renderElement } = editor;
|
|
11
11
|
editor.isInline = (element) => {
|
|
@@ -67,7 +67,8 @@ export const createLinkPlugin = createPluginFactory({
|
|
|
67
67
|
}
|
|
68
68
|
],
|
|
69
69
|
options: {
|
|
70
|
+
isInline: true,
|
|
70
71
|
disabledOperateTypes: [ElementKinds.image, ...DISABLED_OPERATE_TYPES]
|
|
71
72
|
}
|
|
72
73
|
});
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluay5wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvcGx1Z2lucy9saW5rL2xpbmsucGx1Z2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxNQUFNLFFBQVEsQ0FBQztBQUMzQixPQUFPLEVBQW1CLFVBQVUsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUNwRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsc0JBQXNCLEVBQUUsWUFBWSxFQUFFLGVBQWUsRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3JJLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUNqRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDOUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDekUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHLENBQW1CLE1BQVMsRUFBSyxFQUFFO0lBQ3ZELE1BQU0sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFbkUsTUFBTSxDQUFDLFFBQVEsR0FBRyxDQUFDLE9BQWdCLEVBQUUsRUFBRTtRQUNuQyxPQUFPLE9BQU8sQ0FBQyxJQUFJLEtBQUssWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDekUsQ0FBQyxDQUFDO0lBRUYsTUFBTSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsRUFBRTtRQUN2QixJQUFJLElBQUksSUFBSSxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUs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LENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBpc1VybCBmcm9tICdpcy11cmwnO1xuaW1wb3J0IHsgRWRpdG9yLCBFbGVtZW50LCBUcmFuc2Zvcm1zIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgQ0xJUEJPQVJEX0ZPUk1BVF9LRVksIERJU0FCTEVEX09QRVJBVEVfVFlQRVMsIEVsZW1lbnRLaW5kcywgUGx1Z2luTWVudUljb25zLCBUaGVQbHVnaW5NZW51SXRlbVR5cGUgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgY3JlYXRlUGx1Z2luRmFjdG9yeSB9IGZyb20gJy4uLy4uL2NvcmUnO1xuaW1wb3J0IHsgUGx1Z2luS2V5cyB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgd2l0aFJlbW92ZUVtcHR5Tm9kZXMgfSBmcm9tICcuLi9ub3JtYWxpemVycy9yZW1vdmUtZW1wdHktbm9kZXMnO1xuaW1wb3J0IHsgVGhlTGluayB9IGZyb20gJy4vbGluay5jb21wb25lbnQnO1xuaW1wb3J0IHsgTGlua0VkaXRvciB9IGZyb20gJy4vbGluay5lZGl0b3InO1xuXG5leHBvcnQgY29uc3Qgd2l0aExpbmsgPSA8VCBleHRlbmRzIEVkaXRvcj4oZWRpdG9yOiBUKTogVCA9PiB7XG4gICAgY29uc3QgeyBpbnNlcnREYXRhLCBpbnNlcnRUZXh0LCBpc0lubGluZSwgcmVuZGVyRWxlbWVudCB9ID0gZWRpdG9yO1xuXG4gICAgZWRpdG9yLmlzSW5saW5lID0gKGVsZW1lbnQ6IEVsZW1lbnQpID0+IHtcbiAgICAgICAgcmV0dXJuIGVsZW1lbnQudHlwZSA9PT0gRWxlbWVudEtpbmRzLmxpbmsgPyB0cnVlIDogaXNJbmxpbmUoZWxlbWVudCk7XG4gICAgfTtcblxuICAgIGVkaXRvci5pbnNlcnRUZXh0ID0gdGV4dCA9PiB7XG4gICAgICAgIGlmICh0ZXh0ICYmIGlzVXJsKHRleHQpKSB7XG4gICAgICAgICAgICBMaW5rRWRpdG9yLndyYXBMaW5rKGVkaXRvciwgdGV4dCwgdGV4dCk7XG4gICAgICAgICAgICBUcmFuc2Zvcm1zLm1vdmUoZWRpdG9yLCB7IGRpc3RhbmNlOiAxLCB1bml0OiAnb2Zmc2V0JyB9KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGluc2VydFRleHQodGV4dCk7XG4gICAgICAgIH1cbiAgICB9O1xuXG4gICAgZWRpdG9yLmluc2VydERhdGEgPSBkYXRhID0+IHtcbiAgICAgICAgY29uc3QgdGV4dCA9IGRhdGEuZ2V0RGF0YSgndGV4dC9wbGFpbicpO1xuICAgICAgICBjb25zdCBmcmFnbWVudCA9IGRhdGEuZ2V0RGF0YShgYXBwbGljYXRpb24vJHtDTElQQk9BUkRfRk9STUFUX0tFWX1gKTtcblxuICAgICAgICBpZiAodGV4dCAmJiBpc1VybCh0ZXh0KSAmJiAhZnJhZ21lbnQpIHtcbiAgICAgICAgICAgIExpbmtFZGl0b3Iud3JhcExpbmsoZWRpdG9yLCB0ZXh0LCB0ZXh0KTtcbiAgICAgICAgICAgIFRyYW5zZm9ybXMubW92ZShlZGl0b3IsIHsgZGlzdGFuY2U6IDEsIHVuaXQ6ICdvZmZzZXQnIH0pO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgaW5zZXJ0RGF0YShkYXRhKTtcbiAgICAgICAgfVxuICAgIH07XG5cbiAgICBlZGl0b3IucmVuZGVyRWxlbWVudCA9IChlbGVtZW50OiBFbGVtZW50KSA9PiB7XG4gICAgICAgIGlmIChlbGVtZW50LnR5cGUgPT09IEVsZW1lbnRLaW5kcy5saW5rKSB7XG4gICAgICAgICAgICByZXR1cm4gVGhlTGluaztcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcmVuZGVyRWxlbWVudChlbGVtZW50KTtcbiAgICB9O1xuXG4gICAgZWRpdG9yID0gd2l0aFJlbW92ZUVtcHR5Tm9kZXMoeyB0eXBlOiBFbGVtZW50S2luZHMubGluayB9KShlZGl0b3IpO1xuXG4gICAgcmV0dXJuIGVkaXRvcjtcbn07XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVMaW5rUGx1Z2luID0gY3JlYXRlUGx1Z2luRmFjdG9yeSh7XG4gICAga2V5OiBQbHVnaW5LZXlzLmxpbmssXG4gICAgd2l0aE92ZXJyaWRlczogd2l0aExpbmssXG4gICAgdG9vbGJhckl0ZW1zOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGtleTogRWxlbWVudEtpbmRzLmxpbmssXG4gICAgICAgICAgICBpY29uOiAnbGluay1pbnNlcnQnLFxuICAgICAgICAgICAgbmFtZTogJ+mTvuaOpScsXG4gICAgICAgICAgICBleGVjdXRlOiBlZGl0b3IgPT4gTGlua0VkaXRvci5pbnNlcnRMaW5rKGVkaXRvciksXG4gICAgICAgICAgICBhY3RpdmU6IGVkaXRvciA9PiBMaW5rRWRpdG9yLmlzQWN0aXZlKGVkaXRvcilcbiAgICAgICAgfVxuICAgIF0sXG4gICAgbWVudUl0ZW1zOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIGtleTogRWxlbWVudEtpbmRzLmxpbmssXG4gICAgICAgICAgICBrZXl3b3JkczogJ2xqLGxpYW5qaWUsbGluayzpk77mjqUnLFxuICAgICAgICAgICAgZGVzY3JpcHRpb246ICfmlK/mjIHmj5LlhaXpk77mjqUnLFxuICAgICAgICAgICAgZXhlY3V0ZTogZWRpdG9yID0+IExpbmtFZGl0b3IuaW5zZXJ0TGluayhlZGl0b3IpLFxuICAgICAgICAgICAgYWN0aXZlOiBlZGl0b3IgPT4gTGlua0VkaXRvci5pc0FjdGl2ZShlZGl0b3IpLFxuICAgICAgICAgICAgdHlwZTogVGhlUGx1Z2luTWVudUl0ZW1UeXBlLmljb24sXG4gICAgICAgICAgICBuYW1lOiAn6ZO+5o6lJyxcbiAgICAgICAgICAgIGRpc3BsYXlLZXk6ICcvbGonLFxuICAgICAgICAgICAgaWNvbjogJ2xpbmstaW5zZXJ0JyxcbiAgICAgICAgICAgIG1lbnVJY29uOiBQbHVnaW5NZW51SWNvbnMubGlua1xuICAgICAgICB9XG4gICAgXSxcbiAgICBvcHRpb25zOiB7XG4gICAgICAgIGlzSW5saW5lOiB0cnVlLFxuICAgICAgICBkaXNhYmxlZE9wZXJhdGVUeXBlczogW0VsZW1lbnRLaW5kcy5pbWFnZSwgLi4uRElTQUJMRURfT1BFUkFURV9UWVBFU11cbiAgICB9XG59KTtcbiJdfQ==
|
|
@@ -3,6 +3,7 @@ import { ViewContainerRef } from '@angular/core';
|
|
|
3
3
|
import { ThyPopover } from 'ngx-tethys/popover';
|
|
4
4
|
import { AngularEditor } from 'slate-angular';
|
|
5
5
|
import { ThePluginMenuComponent } from '../../components/plugin-menu/plugin-menu.component';
|
|
6
|
+
import { buildQuickInsertMenus } from '../../core';
|
|
6
7
|
import { getBlockAbove } from '../../queries/get-block-above';
|
|
7
8
|
import { THE_PLUGIN_MENU_REF } from '../../utils/weak-maps';
|
|
8
9
|
export const QuickInsertEditor = {
|
|
@@ -16,10 +17,11 @@ export const QuickInsertEditor = {
|
|
|
16
17
|
const overlay = editor.injector.get(Overlay);
|
|
17
18
|
const viewContainerRef = editor.injector.get(ViewContainerRef);
|
|
18
19
|
const thyPopover = editor.injector.get(ThyPopover);
|
|
20
|
+
const pluginMenus = buildQuickInsertMenus(editor, editor?.options?.menu);
|
|
19
21
|
const pluginMenuRef = thyPopover.open(ThePluginMenuComponent, {
|
|
20
22
|
initialState: {
|
|
21
23
|
editor,
|
|
22
|
-
thePluginMenu:
|
|
24
|
+
thePluginMenu: pluginMenus
|
|
23
25
|
},
|
|
24
26
|
origin,
|
|
25
27
|
viewContainerRef: viewContainerRef,
|
|
@@ -65,4 +67,4 @@ export const QuickInsertEditor = {
|
|
|
65
67
|
return !!pluginMenuRef;
|
|
66
68
|
}
|
|
67
69
|
};
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVpY2staW5zZXJ0LmVkaXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL3F1aWNrLWluc2VydC9xdWljay1pbnNlcnQuZWRpdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLFVBQVUsRUFBaUIsTUFBTSxvQkFBb0IsQ0FBQztBQUUvRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzVGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUNuRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDOUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFNUQsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUc7SUFDN0IsUUFBUSxDQUFDLE1BQWM7UUFDbkIsSUFBSSxpQkFBaUIsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUN6QyxPQUFPO1FBQ1gsQ0FBQztRQUNELE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDdEMsTUFBTSxRQUFRLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDeEQsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQywwQkFBMEIsQ0FBZ0IsQ0FBQztRQUNqRixNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM3QyxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDL0QsTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDbkQsTUFBTSxXQUFXLEdBQUcscUJBQXFCLENBQUMsTUFBTSxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFFekUsTUFBTSxhQUFhLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsRUFBRTtZQUMxRCxZQUFZLEVBQUU7Z0JBQ1YsTUFBTTtnQkFDTixhQUFhLEVBQUUsV0FBVzthQUM3QjtZQUNELE1BQU07WUFDTixnQkFBZ0IsRUFBRSxnQkFBZ0I7WUFDbEMsZ0JBQWdCLEVBQUUsSUFBSTtZQUN0QixTQUFTLEVBQUUsWUFBWTtZQUN2QixNQUFNLEVBQUUsQ0FBQztZQUNULFdBQVcsRUFBRSxLQUFLO1lBQ2xCLGVBQWUsRUFBRSxJQUFJO1lBQ3JCLGFBQWEsRUFBRSxJQUFJO1lBQ25CLFFBQVEsRUFBRSxDQUFDO1lBQ1gsY0FBYyxFQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxVQUFVLEVBQUU7U0FDeEQsQ0FBQyxDQUFDO1FBQ0gsaUJBQWlCLENBQUMsbUJBQW1CLENBQUMsTUFBTSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQzdELGFBQWEsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3ZDLGlCQUFpQixDQUFDLG1CQUFtQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN4RCxDQUFDLENBQUMsQ0FBQztRQUNILGFBQWEsQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDbkQsT0FBTyxhQUFhLENBQUM7SUFDekIsQ0FBQztJQUNELGNBQWMsQ0FBQyxNQUFjLEVBQUUsUUFBZ0I7UUFDM0MsTUFBTSxhQUFhLEdBQUcsbUJBQW1CLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3RELElBQUksYUFBYSxFQUFFLENBQUM7WUFDaEIsYUFBYSxDQUFDLGlCQUFpQixDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUM3RCxDQUFDO0lBQ0wsQ0FBQztJQUNELG1CQUFtQixDQUFDLE1BQWMsRUFBRSxhQUF3QztRQUN4RSxJQUFJLGFBQWEsRUFBRSxDQUFDO1lBQ2hCLG1CQUFtQixDQUFDLEdBQUcsQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFDLENBQUM7UUFDbkQsQ0FBQzthQUFNLENBQUM7WUFDSixtQkFBbUIsQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQzFDLENBQUM7SUFDTCxDQUFDO0lBQ0QsU0FBUyxDQUFDLE1BQWM7UUFDcEIsTUFBTSxhQUFhLEdBQUcsbUJBQW1CLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3RELElBQUksYUFBYSxFQUFFLENBQUM7WUFDaEIsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3RCLGlCQUFpQixDQUFDLG1CQUFtQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN4RCxDQUFDO0lBQ0wsQ0FBQztJQUNELFlBQVksQ0FBQyxNQUFjO1FBQ3ZCLE1BQU0sYUFBYSxHQUFHLG1CQUFtQixDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN0RCxPQUFPLENBQUMsQ0FBQyxhQUFhLENBQUM7SUFDM0IsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGh5UG9wb3ZlciwgVGh5UG9wb3ZlclJlZiB9IGZyb20gJ25neC10ZXRoeXMvcG9wb3Zlcic7XG5pbXBvcnQgeyBFZGl0b3IgfSBmcm9tICdzbGF0ZSc7XG5pbXBvcnQgeyBBbmd1bGFyRWRpdG9yIH0gZnJvbSAnc2xhdGUtYW5ndWxhcic7XG5pbXBvcnQgeyBUaGVQbHVnaW5NZW51Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9wbHVnaW4tbWVudS9wbHVnaW4tbWVudS5jb21wb25lbnQnO1xuaW1wb3J0IHsgYnVpbGRRdWlja0luc2VydE1lbnVzIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5pbXBvcnQgeyBnZXRCbG9ja0Fib3ZlIH0gZnJvbSAnLi4vLi4vcXVlcmllcy9nZXQtYmxvY2stYWJvdmUnO1xuaW1wb3J0IHsgVEhFX1BMVUdJTl9NRU5VX1JFRiB9IGZyb20gJy4uLy4uL3V0aWxzL3dlYWstbWFwcyc7XG5cbmV4cG9ydCBjb25zdCBRdWlja0luc2VydEVkaXRvciA9IHtcbiAgICBvcGVuTWVudShlZGl0b3I6IEVkaXRvcikge1xuICAgICAgICBpZiAoUXVpY2tJbnNlcnRFZGl0b3IuaXNPcGVuZWRNZW51KGVkaXRvcikpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBbYmxvY2tdID0gZ2V0QmxvY2tBYm92ZShlZGl0b3IpO1xuICAgICAgICBjb25zdCByb290Tm9kZSA9IEFuZ3VsYXJFZGl0b3IudG9ET01Ob2RlKGVkaXRvciwgYmxvY2spO1xuICAgICAgICBjb25zdCBvcmlnaW4gPSByb290Tm9kZS5xdWVyeVNlbGVjdG9yKCdbZGF0YS1zbGF0ZS1sZWFmPVwidHJ1ZVwiXScpIGFzIEhUTUxFbGVtZW50O1xuICAgICAgICBjb25zdCBvdmVybGF5ID0gZWRpdG9yLmluamVjdG9yLmdldChPdmVybGF5KTtcbiAgICAgICAgY29uc3Qgdmlld0NvbnRhaW5lclJlZiA9IGVkaXRvci5pbmplY3Rvci5nZXQoVmlld0NvbnRhaW5lclJlZik7XG4gICAgICAgIGNvbnN0IHRoeVBvcG92ZXIgPSBlZGl0b3IuaW5qZWN0b3IuZ2V0KFRoeVBvcG92ZXIpO1xuICAgICAgICBjb25zdCBwbHVnaW5NZW51cyA9IGJ1aWxkUXVpY2tJbnNlcnRNZW51cyhlZGl0b3IsIGVkaXRvcj8ub3B0aW9ucz8ubWVudSk7XG5cbiAgICAgICAgY29uc3QgcGx1Z2luTWVudVJlZiA9IHRoeVBvcG92ZXIub3BlbihUaGVQbHVnaW5NZW51Q29tcG9uZW50LCB7XG4gICAgICAgICAgICBpbml0aWFsU3RhdGU6IHtcbiAgICAgICAgICAgICAgICBlZGl0b3IsXG4gICAgICAgICAgICAgICAgdGhlUGx1Z2luTWVudTogcGx1Z2luTWVudXNcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBvcmlnaW4sXG4gICAgICAgICAgICB2aWV3Q29udGFpbmVyUmVmOiB2aWV3Q29udGFpbmVyUmVmLFxuICAgICAgICAgICAgYmFja2Ryb3BDbG9zYWJsZTogdHJ1ZSxcbiAgICAgICAgICAgIHBsYWNlbWVudDogJ2JvdHRvbUxlZnQnLFxuICAgICAgICAgICAgb2Zmc2V0OiA0LFxuICAgICAgICAgICAgaGFzQmFja2Ryb3A6IGZhbHNlLFxuICAgICAgICAgICAgb3V0c2lkZUNsb3NhYmxlOiB0cnVlLFxuICAgICAgICAgICAgbWFudWFsQ2xvc3VyZTogdHJ1ZSxcbiAgICAgICAgICAgIG1pbldpZHRoOiAwLFxuICAgICAgICAgICAgc2Nyb2xsU3RyYXRlZ3k6IG92ZXJsYXkuc2Nyb2xsU3RyYXRlZ2llcy5yZXBvc2l0aW9uKClcbiAgICAgICAgfSk7XG4gICAgICAgIFF1aWNrSW5zZXJ0RWRpdG9yLnVwZGF0ZVBsdWdpbk1lbnVSZWYoZWRpdG9yLCBwbHVnaW5NZW51UmVmKTtcbiAgICAgICAgcGx1Z2luTWVudVJlZi5hZnRlckNsb3NlZCgpLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgICBRdWlja0luc2VydEVkaXRvci51cGRhdGVQbHVnaW5NZW51UmVmKGVkaXRvciwgbnVsbCk7XG4gICAgICAgIH0pO1xuICAgICAgICBwbHVnaW5NZW51UmVmLmNvbXBvbmVudEluc3RhbmNlLmNkci5tYXJrRm9yQ2hlY2soKTtcbiAgICAgICAgcmV0dXJuIHBsdWdpbk1lbnVSZWY7XG4gICAgfSxcbiAgICB1cGRhdGVLZXl3b3JkcyhlZGl0b3I6IEVkaXRvciwga2V5d29yZHM6IHN0cmluZykge1xuICAgICAgICBjb25zdCBwbHVnaW5NZW51UmVmID0gVEhFX1BMVUdJTl9NRU5VX1JFRi5nZXQoZWRpdG9yKTtcbiAgICAgICAgaWYgKHBsdWdpbk1lbnVSZWYpIHtcbiAgICAgICAgICAgIHBsdWdpbk1lbnVSZWYuY29tcG9uZW50SW5zdGFuY2UudXBkYXRlS2V5d29yZHMoa2V5d29yZHMpO1xuICAgICAgICB9XG4gICAgfSxcbiAgICB1cGRhdGVQbHVnaW5NZW51UmVmKGVkaXRvcjogRWRpdG9yLCBwbHVnaW5NZW51UmVmOiBUaHlQb3BvdmVyUmVmPGFueT4gfCBudWxsKSB7XG4gICAgICAgIGlmIChwbHVnaW5NZW51UmVmKSB7XG4gICAgICAgICAgICBUSEVfUExVR0lOX01FTlVfUkVGLnNldChlZGl0b3IsIHBsdWdpbk1lbnVSZWYpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgVEhFX1BMVUdJTl9NRU5VX1JFRi5zZXQoZWRpdG9yLCBudWxsKTtcbiAgICAgICAgfVxuICAgIH0sXG4gICAgY2xvc2VNZW51KGVkaXRvcjogRWRpdG9yKSB7XG4gICAgICAgIGNvbnN0IHBsdWdpbk1lbnVSZWYgPSBUSEVfUExVR0lOX01FTlVfUkVGLmdldChlZGl0b3IpO1xuICAgICAgICBpZiAocGx1Z2luTWVudVJlZikge1xuICAgICAgICAgICAgcGx1Z2luTWVudVJlZi5jbG9zZSgpO1xuICAgICAgICAgICAgUXVpY2tJbnNlcnRFZGl0b3IudXBkYXRlUGx1Z2luTWVudVJlZihlZGl0b3IsIG51bGwpO1xuICAgICAgICB9XG4gICAgfSxcbiAgICBpc09wZW5lZE1lbnUoZWRpdG9yOiBFZGl0b3IpIHtcbiAgICAgICAgY29uc3QgcGx1Z2luTWVudVJlZiA9IFRIRV9QTFVHSU5fTUVOVV9SRUYuZ2V0KGVkaXRvcik7XG4gICAgICAgIHJldHVybiAhIXBsdWdpbk1lbnVSZWY7XG4gICAgfVxufTtcbiJdfQ==
|
|
@@ -1,21 +1,23 @@
|
|
|
1
1
|
import { NgClass, NgIf, NgStyle } from '@angular/common';
|
|
2
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
3
3
|
import { ThyTooltipDirective } from 'ngx-tethys/tooltip';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
5
|
import { takeUntil } from 'rxjs/operators';
|
|
6
6
|
import { Range } from 'slate';
|
|
7
|
-
import { ELEMENT_TO_COMPONENT } from 'slate-angular';
|
|
8
7
|
import { TableEditor } from '../../table.editor';
|
|
9
8
|
import { TOP_CELL_CLASS } from '../../table.types';
|
|
10
9
|
import { createTablePosition } from '../../utils/create-table-position';
|
|
10
|
+
import { getTableViewportRect } from '../../utils/table-viewport';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
export class TheInsertMark {
|
|
13
13
|
get editor() {
|
|
14
14
|
return this.tableStore && this.tableStore.editor;
|
|
15
15
|
}
|
|
16
|
-
constructor(cdr, renderer2) {
|
|
16
|
+
constructor(cdr, renderer2, elementRef) {
|
|
17
17
|
this.cdr = cdr;
|
|
18
18
|
this.renderer2 = renderer2;
|
|
19
|
+
this.elementRef = elementRef;
|
|
20
|
+
this.insertLineStyle = {};
|
|
19
21
|
this.destroy$ = new Subject();
|
|
20
22
|
this.tooltipContent = '';
|
|
21
23
|
this.disabled = false;
|
|
@@ -52,7 +54,7 @@ export class TheInsertMark {
|
|
|
52
54
|
return;
|
|
53
55
|
}
|
|
54
56
|
this.dotWrapperHovered = true;
|
|
55
|
-
this.
|
|
57
|
+
this.insertLineStyle = this.getInsertLineStyle();
|
|
56
58
|
this.parentElement && this.renderer2.addClass(this.parentElement, TOP_CELL_CLASS);
|
|
57
59
|
this.cdr.detectChanges();
|
|
58
60
|
}
|
|
@@ -65,35 +67,54 @@ export class TheInsertMark {
|
|
|
65
67
|
this.parentElement && this.renderer2.removeClass(this.parentElement, TOP_CELL_CLASS);
|
|
66
68
|
this.cdr.detectChanges();
|
|
67
69
|
}
|
|
68
|
-
|
|
70
|
+
getInsertLineStyle() {
|
|
69
71
|
const { selection } = this.editor;
|
|
70
72
|
if (selection && Range.isCollapsed(selection)) {
|
|
71
73
|
const { table } = createTablePosition(this.editor, selection.anchor.path);
|
|
72
74
|
if (!table) {
|
|
73
75
|
return;
|
|
74
76
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
let
|
|
77
|
+
let width = 0;
|
|
78
|
+
let height = 0;
|
|
79
|
+
let left = 0;
|
|
80
|
+
let top = 0;
|
|
81
|
+
const insertMarkSize = 19;
|
|
82
|
+
const insertMarkBoundingClientRect = this.insertWrapper.nativeElement.getBoundingClientRect();
|
|
83
|
+
const tableViewportRect = getTableViewportRect(this.editor, table);
|
|
79
84
|
if (this.type === 'row') {
|
|
80
|
-
|
|
85
|
+
width = tableViewportRect.right - insertMarkBoundingClientRect.right;
|
|
86
|
+
height = 1;
|
|
87
|
+
left = insertMarkBoundingClientRect.left + insertMarkSize;
|
|
88
|
+
top = insertMarkBoundingClientRect.top + insertMarkSize / 2;
|
|
81
89
|
}
|
|
82
90
|
else {
|
|
83
|
-
|
|
91
|
+
width = 1;
|
|
92
|
+
height = tableViewportRect.bottom - insertMarkBoundingClientRect.bottom;
|
|
93
|
+
left = insertMarkBoundingClientRect.left + insertMarkSize / 2;
|
|
94
|
+
top = insertMarkBoundingClientRect.top + insertMarkSize;
|
|
95
|
+
if (this.isLastColumn()) {
|
|
96
|
+
left = insertMarkBoundingClientRect.right;
|
|
97
|
+
}
|
|
84
98
|
}
|
|
85
|
-
return
|
|
99
|
+
return { height: `${height}px`, width: `${width}px`, left: `${left}px`, top: `${top}px` };
|
|
86
100
|
}
|
|
87
101
|
}
|
|
88
|
-
|
|
89
|
-
|
|
102
|
+
isLastColumn() {
|
|
103
|
+
const tablePosition = createTablePosition(this.editor);
|
|
104
|
+
if (!tablePosition?.table) {
|
|
105
|
+
return false;
|
|
106
|
+
}
|
|
107
|
+
return this.type === 'column' && this.at === tablePosition.getWidth();
|
|
108
|
+
}
|
|
109
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheInsertMark, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
110
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: TheInsertMark, isStandalone: true, selector: "the-table-insert-mark", inputs: { type: "type", at: "at", tableStore: "tableStore", parentElement: "parentElement" }, host: { classAttribute: "the-table-insert-mark" }, viewQueries: [{ propertyName: "insertWrapper", first: true, predicate: ["insertWrapper"], descendants: true }], ngImport: i0, template: "<div\n #insertWrapper\n [thyTooltip]=\"!disabled && tooltipContent\"\n class=\"the-table-controls-insert-wrapper\"\n [ngClass]=\"{ disabled: disabled }\"\n contenteditable=\"false\"\n (pointerdown)=\"preventDefault($event)\"\n (pointerup)=\"insert($event)\"\n (click)=\"preventDefault($event)\"\n (mouseup)=\"preventDefault($event)\"\n (mouseenter)=\"onMouseEnter($event)\"\n (mouseleave)=\"onMouseLeave($event)\"\n>\n <div\n class=\"the-table-controls-insert-line\"\n *ngIf=\"dotWrapperHovered\"\n [ngStyle]=\"insertLineStyle\"\n ></div>\n</div>\n", dependencies: [{ kind: "directive", type: ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
90
111
|
}
|
|
91
112
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheInsertMark, decorators: [{
|
|
92
113
|
type: Component,
|
|
93
114
|
args: [{ selector: 'the-table-insert-mark', host: {
|
|
94
115
|
class: 'the-table-insert-mark'
|
|
95
|
-
}, standalone: true, imports: [ThyTooltipDirective, NgClass, NgIf, NgStyle], template: "<div\n [thyTooltip]=\"!disabled && tooltipContent\"\n class=\"the-table-controls-insert-wrapper\"\n [ngClass]=\"{ disabled: disabled }\"\n contenteditable=\"false\"\n (pointerdown)=\"preventDefault($event)\"\n (pointerup)=\"insert($event)\"\n (click)=\"preventDefault($event)\"\n (mouseup)=\"preventDefault($event)\"\n (mouseenter)=\"onMouseEnter($event)\"\n (mouseleave)=\"onMouseLeave($event)\"\n>\n <div\n class=\"the-table-controls-insert-line\"\n *ngIf=\"dotWrapperHovered\"\n [
|
|
96
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }], propDecorators: { type: [{
|
|
116
|
+
}, standalone: true, imports: [ThyTooltipDirective, NgClass, NgIf, NgStyle], template: "<div\n #insertWrapper\n [thyTooltip]=\"!disabled && tooltipContent\"\n class=\"the-table-controls-insert-wrapper\"\n [ngClass]=\"{ disabled: disabled }\"\n contenteditable=\"false\"\n (pointerdown)=\"preventDefault($event)\"\n (pointerup)=\"insert($event)\"\n (click)=\"preventDefault($event)\"\n (mouseup)=\"preventDefault($event)\"\n (mouseenter)=\"onMouseEnter($event)\"\n (mouseleave)=\"onMouseLeave($event)\"\n>\n <div\n class=\"the-table-controls-insert-line\"\n *ngIf=\"dotWrapperHovered\"\n [ngStyle]=\"insertLineStyle\"\n ></div>\n</div>\n" }]
|
|
117
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { type: [{
|
|
97
118
|
type: Input
|
|
98
119
|
}], at: [{
|
|
99
120
|
type: Input
|
|
@@ -101,5 +122,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
101
122
|
type: Input
|
|
102
123
|
}], parentElement: [{
|
|
103
124
|
type: Input
|
|
125
|
+
}], insertWrapper: [{
|
|
126
|
+
type: ViewChild,
|
|
127
|
+
args: ['insertWrapper']
|
|
104
128
|
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"insert-mark.component.js","sourceRoot":"","sources":["../../../../../../../packages/src/plugins/table/components/insert-mark/insert-mark.component.ts","../../../../../../../packages/src/plugins/table/components/insert-mark/insert-mark.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, NgStyle } from '@angular/common';\nimport { ChangeDetectorRef, Component, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\nimport { ThyTooltipDirective } from 'ngx-tethys/tooltip';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { Editor, Range } from 'slate';\nimport { ELEMENT_TO_COMPONENT } from 'slate-angular';\nimport { TableEditor } from '../../table.editor';\nimport { TableStore } from '../../table.store';\nimport { TOP_CELL_CLASS } from '../../table.types';\nimport { createTablePosition } from '../../utils/create-table-position';\nimport { TheTable } from '../table.component';\n\n@Component({\n    selector: 'the-table-insert-mark',\n    templateUrl: './insert-mark.component.html',\n    host: {\n        class: 'the-table-insert-mark'\n    },\n    standalone: true,\n    imports: [ThyTooltipDirective, NgClass, NgIf, NgStyle]\n})\nexport class TheInsertMark implements OnInit, OnDestroy {\n    @Input() type: 'row' | 'column';\n\n    @Input() at: number;\n\n    @Input() tableStore: TableStore;\n\n    @Input() parentElement: HTMLElement;\n\n    public insertLength: string;\n\n    public dotWrapperHovered: boolean;\n\n    destroy$ = new Subject<void>();\n\n    tooltipContent = '';\n\n    disabled = false;\n\n    get editor(): Editor {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        public renderer2: Renderer2\n    ) {}\n\n    ngOnInit() {\n        this.tooltipContent = this.type === 'row' ? '插入行' : '插入列';\n\n        this.tableStore\n            .selectedCellsChange()\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(selectedCellPositions => {\n                this.disabled = !!selectedCellPositions.length;\n            });\n    }\n\n    ngOnDestroy() {\n        this.destroy$?.next();\n        this.destroy$?.complete();\n    }\n\n    preventDefault(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    insert(event: MouseEvent) {\n        this.preventDefault(event);\n        if (this.disabled) {\n            return;\n        }\n        const fun = this.type === 'row' ? TableEditor.insertRow : TableEditor.insertColumn;\n        fun(this.editor, 1, this.at);\n        this.tableStore.changeCells();\n    }\n\n    onMouseEnter(event: MouseEvent) {\n        this.preventDefault(event);\n        if (this.disabled) {\n            return;\n        }\n        this.dotWrapperHovered = true;\n        this.insertLength = this.getLength();\n        this.parentElement && this.renderer2.addClass(this.parentElement, TOP_CELL_CLASS);\n        this.cdr.detectChanges();\n    }\n\n    onMouseLeave(event: MouseEvent) {\n        this.preventDefault(event);\n        if (this.disabled) {\n            return;\n        }\n        this.dotWrapperHovered = false;\n        this.parentElement && this.renderer2.removeClass(this.parentElement, TOP_CELL_CLASS);\n        this.cdr.detectChanges();\n    }\n\n    getLength() {\n        const { selection } = this.editor;\n        if (selection && Range.isCollapsed(selection)) {\n            const { table } = createTablePosition(this.editor, selection.anchor.path);\n            if (!table) {\n                return;\n            }\n            const tableComponent = ELEMENT_TO_COMPONENT.get(table) as TheTable;\n            const tableWrapper = tableComponent.tableWrapper.nativeElement as HTMLElement;\n            const tableElement = tableComponent.theTableElement.nativeElement as HTMLElement;\n            let result = 0;\n            if (this.type === 'row') {\n                result = tableWrapper.offsetWidth;\n            } else {\n                result = tableElement.offsetHeight - 1;\n            }\n            return result + 'px';\n        }\n    }\n}\n","<div\n  [thyTooltip]=\"!disabled && tooltipContent\"\n  class=\"the-table-controls-insert-wrapper\"\n  [ngClass]=\"{ disabled: disabled }\"\n  contenteditable=\"false\"\n  (pointerdown)=\"preventDefault($event)\"\n  (pointerup)=\"insert($event)\"\n  (click)=\"preventDefault($event)\"\n  (mouseup)=\"preventDefault($event)\"\n  (mouseenter)=\"onMouseEnter($event)\"\n  (mouseleave)=\"onMouseLeave($event)\"\n>\n  <div\n    class=\"the-table-controls-insert-line\"\n    *ngIf=\"dotWrapperHovered\"\n    [attr.data-dot-type]=\"type\"\n    [ngStyle]=\"{ height: type === 'column' && insertLength, width: type === 'row' && insertLength }\"\n  ></div>\n</div>\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"insert-mark.component.js","sourceRoot":"","sources":["../../../../../../../packages/src/plugins/table/components/insert-mark/insert-mark.component.ts","../../../../../../../packages/src/plugins/table/components/insert-mark/insert-mark.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAqB,SAAS,EAAc,KAAK,EAAgC,SAAS,EAAE,MAAM,eAAe,CAAC;AACzH,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAU,KAAK,EAAE,MAAM,OAAO,CAAC;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;;AAWlE,MAAM,OAAO,aAAa;IAqBtB,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IACrD,CAAC;IAED,YACY,GAAsB,EACvB,SAAoB,EACpB,UAAmC;QAFlC,QAAG,GAAH,GAAG,CAAmB;QACvB,cAAS,GAAT,SAAS,CAAW;QACpB,eAAU,GAAV,UAAU,CAAyB;QAjB9C,oBAAe,GAAG,EAAE,CAAC;QAIrB,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAE/B,mBAAc,GAAG,EAAE,CAAC;QAEpB,aAAQ,GAAG,KAAK,CAAC;IAUd,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QAE1D,IAAI,CAAC,UAAU;aACV,mBAAmB,EAAE;aACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,qBAAqB,CAAC,EAAE;YAC/B,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,qBAAqB,CAAC,MAAM,CAAC;QACnD,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,cAAc,CAAC,KAAiB;QAC5B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,KAAiB;QACpB,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO;QACX,CAAC;QACD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,YAAY,CAAC;QACnF,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;QAC7B,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;IAED,YAAY,CAAC,KAAiB;QAC1B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO;QACX,CAAC;QACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACjD,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC;QAClF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,YAAY,CAAC,KAAiB;QAC1B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO;QACX,CAAC;QACD,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC;QACrF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,kBAAkB;QACd,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAClC,IAAI,SAAS,IAAI,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC;YAC5C,MAAM,EAAE,KAAK,EAAE,GAAG,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YAC1E,IAAI,CAAC,KAAK,EAAE,CAAC;gBACT,OAAO;YACX,CAAC;YACD,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,IAAI,MAAM,GAAG,CAAC,CAAC;YACf,IAAI,IAAI,GAAG,CAAC,CAAC;YACb,IAAI,GAAG,GAAG,CAAC,CAAC;YACZ,MAAM,cAAc,GAAG,EAAE,CAAC;YAC1B,MAAM,4BAA4B,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAC9F,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;YACnE,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;gBACtB,KAAK,GAAG,iBAAiB,CAAC,KAAK,GAAG,4BAA4B,CAAC,KAAK,CAAC;gBACrE,MAAM,GAAG,CAAC,CAAC;gBACX,IAAI,GAAG,4BAA4B,CAAC,IAAI,GAAG,cAAc,CAAC;gBAC1D,GAAG,GAAG,4BAA4B,CAAC,GAAG,GAAG,cAAc,GAAG,CAAC,CAAC;YAChE,CAAC;iBAAM,CAAC;gBACJ,KAAK,GAAG,CAAC,CAAC;gBACV,MAAM,GAAG,iBAAiB,CAAC,MAAM,GAAG,4BAA4B,CAAC,MAAM,CAAC;gBACxE,IAAI,GAAG,4BAA4B,CAAC,IAAI,GAAG,cAAc,GAAG,CAAC,CAAC;gBAC9D,GAAG,GAAG,4BAA4B,CAAC,GAAG,GAAG,cAAc,CAAC;gBACxD,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;oBACtB,IAAI,GAAG,4BAA4B,CAAC,KAAK,CAAC;gBAC9C,CAAC;YACL,CAAC;YACD,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,IAAI,EAAE,KAAK,EAAE,GAAG,KAAK,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE,CAAC;QAC9F,CAAC;IACL,CAAC;IAED,YAAY;QACR,MAAM,aAAa,GAAG,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvD,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC;YACxB,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,EAAE,KAAK,aAAa,CAAC,QAAQ,EAAE,CAAC;IAC1E,CAAC;8GAzHQ,aAAa;kGAAb,aAAa,kVCrB1B,4jBAmBA,4CDAc,mBAAmB,8TAAE,OAAO,oFAAE,IAAI,6FAAE,OAAO;;2FAE5C,aAAa;kBATzB,SAAS;+BACI,uBAAuB,QAE3B;wBACF,KAAK,EAAE,uBAAuB;qBACjC,cACW,IAAI,WACP,CAAC,mBAAmB,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC;uIAG7C,IAAI;sBAAZ,KAAK;gBAEG,EAAE;sBAAV,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEsB,aAAa;sBAAxC,SAAS;uBAAC,eAAe","sourcesContent":["import { NgClass, NgIf, NgStyle } from '@angular/common';\nimport { ChangeDetectorRef, Component, ElementRef, Input, OnDestroy, OnInit, Renderer2, ViewChild } from '@angular/core';\nimport { ThyTooltipDirective } from 'ngx-tethys/tooltip';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { Editor, Range } from 'slate';\nimport { TableEditor } from '../../table.editor';\nimport { TableStore } from '../../table.store';\nimport { TOP_CELL_CLASS } from '../../table.types';\nimport { createTablePosition } from '../../utils/create-table-position';\nimport { getTableViewportRect } from '../../utils/table-viewport';\n\n@Component({\n    selector: 'the-table-insert-mark',\n    templateUrl: './insert-mark.component.html',\n    host: {\n        class: 'the-table-insert-mark'\n    },\n    standalone: true,\n    imports: [ThyTooltipDirective, NgClass, NgIf, NgStyle]\n})\nexport class TheInsertMark implements OnInit, OnDestroy {\n    @Input() type: 'row' | 'column';\n\n    @Input() at: number;\n\n    @Input() tableStore: TableStore;\n\n    @Input() parentElement: HTMLElement;\n\n    @ViewChild('insertWrapper') insertWrapper: ElementRef<HTMLElement>;\n\n    insertLineStyle = {};\n\n    public dotWrapperHovered: boolean;\n\n    destroy$ = new Subject<void>();\n\n    tooltipContent = '';\n\n    disabled = false;\n\n    get editor(): Editor {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        public renderer2: Renderer2,\n        public elementRef: ElementRef<HTMLElement>\n    ) {}\n\n    ngOnInit() {\n        this.tooltipContent = this.type === 'row' ? '插入行' : '插入列';\n\n        this.tableStore\n            .selectedCellsChange()\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(selectedCellPositions => {\n                this.disabled = !!selectedCellPositions.length;\n            });\n    }\n\n    ngOnDestroy() {\n        this.destroy$?.next();\n        this.destroy$?.complete();\n    }\n\n    preventDefault(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    insert(event: MouseEvent) {\n        this.preventDefault(event);\n        if (this.disabled) {\n            return;\n        }\n        const fun = this.type === 'row' ? TableEditor.insertRow : TableEditor.insertColumn;\n        fun(this.editor, 1, this.at);\n        this.tableStore.changeCells();\n    }\n\n    onMouseEnter(event: MouseEvent) {\n        this.preventDefault(event);\n        if (this.disabled) {\n            return;\n        }\n        this.dotWrapperHovered = true;\n        this.insertLineStyle = this.getInsertLineStyle();\n        this.parentElement && this.renderer2.addClass(this.parentElement, TOP_CELL_CLASS);\n        this.cdr.detectChanges();\n    }\n\n    onMouseLeave(event: MouseEvent) {\n        this.preventDefault(event);\n        if (this.disabled) {\n            return;\n        }\n        this.dotWrapperHovered = false;\n        this.parentElement && this.renderer2.removeClass(this.parentElement, TOP_CELL_CLASS);\n        this.cdr.detectChanges();\n    }\n\n    getInsertLineStyle() {\n        const { selection } = this.editor;\n        if (selection && Range.isCollapsed(selection)) {\n            const { table } = createTablePosition(this.editor, selection.anchor.path);\n            if (!table) {\n                return;\n            }\n            let width = 0;\n            let height = 0;\n            let left = 0;\n            let top = 0;\n            const insertMarkSize = 19;\n            const insertMarkBoundingClientRect = this.insertWrapper.nativeElement.getBoundingClientRect();\n            const tableViewportRect = getTableViewportRect(this.editor, table);\n            if (this.type === 'row') {\n                width = tableViewportRect.right - insertMarkBoundingClientRect.right;\n                height = 1;\n                left = insertMarkBoundingClientRect.left + insertMarkSize;\n                top = insertMarkBoundingClientRect.top + insertMarkSize / 2;\n            } else {\n                width = 1;\n                height = tableViewportRect.bottom - insertMarkBoundingClientRect.bottom;\n                left = insertMarkBoundingClientRect.left + insertMarkSize / 2;\n                top = insertMarkBoundingClientRect.top + insertMarkSize;\n                if (this.isLastColumn()) {\n                    left = insertMarkBoundingClientRect.right;\n                }\n            }\n            return { height: `${height}px`, width: `${width}px`, left: `${left}px`, top: `${top}px` };\n        }\n    }\n\n    isLastColumn() {\n        const tablePosition = createTablePosition(this.editor);\n        if (!tablePosition?.table) {\n            return false;\n        }\n        return this.type === 'column' && this.at === tablePosition.getWidth();\n    }\n}\n","<div\n  #insertWrapper\n  [thyTooltip]=\"!disabled && tooltipContent\"\n  class=\"the-table-controls-insert-wrapper\"\n  [ngClass]=\"{ disabled: disabled }\"\n  contenteditable=\"false\"\n  (pointerdown)=\"preventDefault($event)\"\n  (pointerup)=\"insert($event)\"\n  (click)=\"preventDefault($event)\"\n  (mouseup)=\"preventDefault($event)\"\n  (mouseenter)=\"onMouseEnter($event)\"\n  (mouseleave)=\"onMouseLeave($event)\"\n>\n  <div\n    class=\"the-table-controls-insert-line\"\n    *ngIf=\"dotWrapperHovered\"\n    [ngStyle]=\"insertLineStyle\"\n  ></div>\n</div>\n"]}
|
|
@@ -40,7 +40,7 @@ export class TheTableRow extends TheBaseElement {
|
|
|
40
40
|
this.updateNumberedColumnPosition();
|
|
41
41
|
}
|
|
42
42
|
setHeight() {
|
|
43
|
-
if (this.element
|
|
43
|
+
if (this.element?.height) {
|
|
44
44
|
this.height = this.element.height + 'px';
|
|
45
45
|
}
|
|
46
46
|
}
|
|
@@ -92,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
92
92
|
type: ViewChild,
|
|
93
93
|
args: ['numberedColumn']
|
|
94
94
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row.component.js","sourceRoot":"","sources":["../../../../../../../packages/src/plugins/table/components/row/row.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { AfterViewInit, ChangeDetectorRef, Component, ElementRef, HostBinding, OnInit, Renderer2, ViewChild } from '@angular/core';\nimport { AfterContextChange } from 'slate-angular';\nimport { ThePreventDefaultDirective } from '../../../../components/action/prevent-default';\nimport { TableElement, TableRowElement } from '../../../../custom-types';\nimport { TheEditor } from '../../../../interfaces/editor';\nimport { TheBaseElement } from '../../../../interfaces/view-base';\nimport { getTableByRow } from '../../utils';\nimport { hasHeaderRow } from '../../utils/is-header-row';\n\n@Component({\n    selector: 'tr[theTableRow]',\n    template: `\n        <td #numberedColumn *ngIf=\"readonly && numberedColumn\" class=\"the-table-number-column align-middle\" thePreventDefault>\n            {{ rowNumber }}\n        </td>\n    `,\n    standalone: true,\n    imports: [NgIf, ThePreventDefaultDirective]\n})\nexport class TheTableRow extends TheBaseElement<TableRowElement> implements OnInit, AfterViewInit, AfterContextChange {\n    @HostBinding('style.height') height: string;\n\n    numberedColumn = false;\n\n    rowNumber: number | string = '';\n\n    @ViewChild('numberedColumn')\n    numberedColumnRef: ElementRef<HTMLElement>;\n\n    constructor(\n        public elementRef: ElementRef<HTMLElement>,\n        public cdr: ChangeDetectorRef,\n        private renderer: Renderer2\n    ) {\n        super(elementRef, cdr);\n    }\n\n    onContextChange() {\n        super.onContextChange();\n        if (this.initialized) {\n            this.setHeight();\n            const path = TheEditor.findPath(this.editor, this.element);\n            const rowIndex = path[path.length - 1];\n            this.setStickyRowClass(rowIndex);\n            this.setNumberColumn(rowIndex);\n        }\n    }\n\n    afterContextChange() {\n        this.updateNumberedColumnPosition();\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.setHeight();\n        const path = TheEditor.findPath(this.editor, this.element);\n        const rowIndex = path[path.length - 1];\n        this.setNumberColumn(rowIndex);\n        this.setStickyRowClass(rowIndex);\n    }\n\n    ngAfterViewInit(): void {\n        this.updateNumberedColumnPosition();\n    }\n\n    setHeight() {\n        if (this.element?.height) {\n            this.height = this.element.height + 'px';\n        }\n    }\n\n    setStickyRowClass(rowIndex: number) {\n        if (rowIndex === 0) {\n            this.renderer.addClass(this.elementRef.nativeElement, 'the-sticky-row');\n        } else {\n            this.renderer.removeClass(this.elementRef.nativeElement, 'the-sticky-row');\n        }\n    }\n\n    setNumberColumn(rowIndex: number) {\n        const table = getTableByRow(this.editor, this.element) as TableElement;\n        const headerRow = hasHeaderRow(table);\n        this.numberedColumn = table?.options?.numberedColumn;\n        this.rowNumber = headerRow && rowIndex === 0 ? '' : headerRow ? rowIndex : rowIndex + 1;\n    }\n\n    updateNumberedColumnPosition() {\n        if (this.numberedColumnRef) {\n            const isFirstChild = this.elementRef.nativeElement.firstElementChild === this.numberedColumnRef.nativeElement;\n            if (!isFirstChild) {\n                this.elementRef.nativeElement.prepend(this.numberedColumnRef.nativeElement);\n            }\n        }\n    }\n}\n"]}
|