@worktile/theia 14.3.17 → 14.3.18

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.
@@ -85,18 +85,6 @@ export class TheTableToolbarComponent {
85
85
  setDeleteIcon() {
86
86
  const { selectedCells, selectedRowsIndex, selectedColumnsIndex, createTablePosition } = this.tableStore;
87
87
  const pos = createTablePosition();
88
- // 满足已选中整行或者整列
89
- const isSelectedWholeRowOrColumnCell = selectedRowsIndex.length * pos.getWidth() === selectedCells.length ||
90
- selectedColumnsIndex.length * pos.getHeight() === selectedCells.length;
91
- if (!isSelectedWholeRowOrColumnCell) {
92
- this.deleteIcon = null;
93
- this.iconName = null;
94
- return;
95
- }
96
- if (this.tableStore.isSelectedTable) {
97
- this.deleteIcon = DeleteIcon.trash;
98
- this.iconName = '删除表格';
99
- }
100
88
  if (this.tableStore.selectedRowsIndex.length > 0) {
101
89
  this.deleteIcon = DeleteIcon['table-delete-rows'];
102
90
  this.iconName = '删除整行';
@@ -105,6 +93,17 @@ export class TheTableToolbarComponent {
105
93
  this.deleteIcon = DeleteIcon['table-delete-columns'];
106
94
  this.iconName = '删除整列';
107
95
  }
96
+ if (this.tableStore.isSelectedTable) {
97
+ this.deleteIcon = DeleteIcon.trash;
98
+ this.iconName = '删除表格';
99
+ }
100
+ // 满足已选中整行或者整列
101
+ const isSelectedWholeRowOrColumnCell = selectedRowsIndex.length * pos.getWidth() === selectedCells.length ||
102
+ selectedColumnsIndex.length * pos.getHeight() === selectedCells.length;
103
+ if (!isSelectedWholeRowOrColumnCell) {
104
+ this.deleteIcon = null;
105
+ this.iconName = null;
106
+ }
108
107
  }
109
108
  onDelete(event) {
110
109
  event.preventDefault();
@@ -198,4 +197,4 @@ export var DeleteIcon;
198
197
  DeleteIcon["table-delete-columns"] = "table-delete-columns";
199
198
  DeleteIcon["trash"] = "trash";
200
199
  })(DeleteIcon || (DeleteIcon = {}));
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.ts","../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, NgZone, OnDestroy } from '@angular/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { TableStore } from '../../table.store';\nimport { ColorType, BackgroundColors, TableHeaderBackgroundColor, SpecialBackgroundColor } from '../../../../constants/color-select';\nimport { TheColorSelectService } from '../../../../services/color-select.service';\nimport { splitCell } from '../../utils/split-cell';\nimport { setCellMenuVisibility } from '../../utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../../table.types';\nimport { TableEditor } from '../../table.editor';\nimport { TheTableOptionsComponent } from './table-options.component';\nimport { PluginKeys, TheEditor } from '../../../../interfaces';\nimport { getPluginOptions } from '../../../../core';\nimport { TableElement } from '../../../..//custom-types';\nimport { isRectangularInTableCells } from '../../utils/is-selection-in-table';\nimport * as TheTransforms from '../../../../transforms';\nimport * as TheQueries from '../../../../queries';\nimport { Subscription } from 'rxjs';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\nimport { copyNode } from '../../../../utils';\n\n@Component({\n    selector: 'the-table-toolbar',\n    templateUrl: 'table-toolbar.component.html'\n})\nexport class TheTableToolbarComponent implements OnInit, OnDestroy {\n    selectedColor: string;\n\n    deleteIcon: DeleteIcon;\n\n    iconName: string;\n\n    isRectangle: boolean;\n\n    isColumnEqual: boolean;\n\n    tableChangeSubscriber: Subscription;\n\n    @Input() tableStore: TableStore;\n\n    @Input() tableElement: TableElement;\n\n    get editor(): Editor {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    cellMenuList: MenuEntity[] = [\n        {\n            key: 'merge-cells',\n            name: '合并单元格',\n            visibility: false,\n            icon: 'table-merge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                this.tableStore.mergeCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        },\n        {\n            key: 'split-cells',\n            name: '拆分单元格',\n            visibility: false,\n            icon: 'table-unmerge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                splitCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        }\n    ];\n\n    get hasDivider() {\n        return this.cellMenuList.filter(item => item.visibility).length > 1;\n    }\n\n    get tableOptions() {\n        return getPluginOptions(this.editor, PluginKeys.table);\n    }\n\n    constructor(\n        private ngZone: NgZone,\n        private colorSelectService: TheColorSelectService,\n        private thyPopover: ThyPopover,\n        private popoverRef: ThyPopoverRef<TheTableToolbarComponent>,\n        private thyNotifyService: ThyNotifyService\n    ) {}\n\n    ngOnInit() {\n        this.isColumnEqual = this.tableElement?.columns?.every(col => this.tableElement.columns[0].width === col.width) ?? true;\n        const { selectedCells, isSelectedTable } = this.tableStore;\n        const tableInfo = { selectedCells, isSelectedTable };\n        this.isRectangle = isRectangularInTableCells(this.editor, selectedCells);\n        this.setDeleteIcon();\n        setCellMenuVisibility(this.editor, this.cellMenuList, tableInfo);\n        this.selectedColor = this.tableStore.getSelectedCellBackgroundColor();\n\n        const path = TheEditor.findPath(this.editor, this.tableElement);\n        this.tableChangeSubscriber = this.tableStore.tableChange().subscribe(() => {\n            const columns = (TheQueries.getNode(this.editor, path) as TableElement).columns;\n            this.isColumnEqual = columns?.every(col => columns[0].width === col.width) ?? true;\n        });\n    }\n\n    ngOnDestroy() {\n        this.tableChangeSubscriber?.unsubscribe();\n        this.colorSelectService.closeColorSelect();\n    }\n\n    setDeleteIcon() {\n        const { selectedCells, selectedRowsIndex, selectedColumnsIndex, createTablePosition } = this.tableStore;\n        const pos = createTablePosition();\n        // 满足已选中整行或者整列\n        const isSelectedWholeRowOrColumnCell =\n            selectedRowsIndex.length * pos.getWidth() === selectedCells.length ||\n            selectedColumnsIndex.length * pos.getHeight() === selectedCells.length;\n        if (!isSelectedWholeRowOrColumnCell) {\n            this.deleteIcon = null;\n            this.iconName = null;\n            return;\n        }\n        if (this.tableStore.isSelectedTable) {\n            this.deleteIcon = DeleteIcon.trash;\n            this.iconName = '删除表格';\n        }\n        if (this.tableStore.selectedRowsIndex.length > 0) {\n            this.deleteIcon = DeleteIcon['table-delete-rows'];\n            this.iconName = '删除整行';\n        }\n        if (this.tableStore.selectedColumnsIndex.length > 0) {\n            this.deleteIcon = DeleteIcon['table-delete-columns'];\n            this.iconName = '删除整列';\n        }\n    }\n\n    onDelete(event: MouseEvent) {\n        event.preventDefault();\n        this.tableStore.removeColumnOrRows();\n        this.tableStore.clearDangerousCells();\n        this.tableStore.clearSelectedCells();\n        this.popoverRef.close();\n    }\n\n    onEnterDelete(event: MouseEvent) {\n        this.tableStore.setDangerousCells();\n    }\n\n    onLeaveDelete(event: MouseEvent) {\n        this.tableStore.clearDangerousCells();\n    }\n\n    openSelectColor(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        const element = (event.target as HTMLElement).closest('.thy-action');\n        const isHeader = TableEditor.isActiveHeader(this.editor);\n        this.ngZone.run(() => {\n            this.colorSelectService.toggleColorSelect(\n                element as HTMLElement,\n                this.selectedColor,\n                BackgroundColors,\n                {\n                    perRowColorNumbers: 7,\n                    rowOptions: { 1: '#bbb', 2: '#bbb' },\n                    specialColor: isHeader ? TableHeaderBackgroundColor : SpecialBackgroundColor\n                },\n                (newColor: ColorType) => {\n                    if ((newColor === TableHeaderBackgroundColor && isHeader) || (newColor === SpecialBackgroundColor && !isHeader)) {\n                        this.tableStore.setSelectedCellsBackgroundColor(null);\n                    } else {\n                        this.tableStore.setSelectedCellsBackgroundColor(newColor);\n                    }\n                    this.selectedColor = newColor;\n                },\n                'bottomLeft',\n                4\n            );\n        });\n    }\n\n    setFullscreen(event: MouseEvent) {\n        this.tableOptions.setFullscreen(this.editor, event, this.tableElement);\n    }\n\n    mousedown(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    onCopy(e: Event) {\n        e?.preventDefault();\n\n        copyNode(this.editor, this.tableElement, this.thyNotifyService);\n    }\n\n    setEquallyColumnHandle(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const columns = this.tableElement.columns;\n        const sumWidth = columns.reduce((previousValue, currentValue) => {\n            return previousValue + currentValue.width;\n        }, 0);\n        const equalColumns = columns.map(() => {\n            return { width: sumWidth / columns.length };\n        });\n\n        TheTransforms.setNode(this.editor, { columns: equalColumns }, this.tableElement);\n    }\n\n    openTableOptionMenu(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.thyPopover.open(TheTableOptionsComponent, {\n            origin: event.currentTarget as HTMLElement,\n            initialState: {\n                tableStore: this.tableStore,\n                editor: this.editor\n            },\n            minWidth: 0,\n            insideClosable: true,\n            outsideClosable: true,\n            hasBackdrop: false,\n            placement: 'bottomLeft',\n            originActiveClass: 'active',\n            panelClass: 'table-options-pannel'\n        });\n    }\n}\n\nexport enum DeleteIcon {\n    'table-delete-rows' = 'table-delete-rows',\n    'table-delete-columns' = 'table-delete-columns',\n    'trash' = 'trash'\n}\n","<thy-actions thySize=\"xxs\">\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a\n            *ngIf=\"item.visibility\"\n            href=\"javascript:;\"\n            thyAction\n            [thyActionIcon]=\"item.icon\"\n            [thyTooltip]=\"item.name\"\n            (mousedown)=\"item.actionHandle()\"\n        ></a>\n    </ng-container>\n    <thy-divider *ngIf=\"hasDivider\" class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"> </thy-divider>\n    <a href=\"javascript:;\" thyAction thyTooltip=\"单元格背景\" (mousedown)=\"openSelectColor($event)\">\n        <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n    </a>\n    <a\n        href=\"javascript:;\"\n        *ngIf=\"tableStore.isSelectedTable && !isColumnEqual\"\n        thyAction\n        thyTooltip=\"列等宽\"\n        (mousedown)=\"setEquallyColumnHandle($event)\"\n    >\n        <thy-icon thyIconName=\"table-column-equal-width\"></thy-icon>\n    </a>\n    <a\n        href=\"javascript:;\"\n        *ngIf=\"tableStore.isSelectedTable && tableOptions?.showFullscreen\"\n        thyAction\n        thyTooltip=\"全屏\"\n        (mousedown)=\"setFullscreen($event)\"\n    >\n        <thy-icon thyIconName=\"arrows-alt\"></thy-icon>\n    </a>\n    <a\n        *ngIf=\"tableStore.isSelectedTable && !tableStore?.isFullscreen\"\n        class=\"fullscreen-hidden\"\n        href=\"javascript:;\"\n        thyAction\n        thyActionIcon=\"copy\"\n        thyTooltip=\"复制\"\n        (mousedown)=\"onCopy($event)\"\n    ></a>\n    <ng-container *ngIf=\"tableStore.isSelectedTable\">\n        <thy-divider class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n        <a href=\"javascript:;\" class=\"link-with-down\" thyAction (mousedown)=\"mousedown($event)\" (click)=\"openTableOptionMenu($event)\">\n            <span>表格选项</span>\n            <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n        </a>\n    </ng-container>\n    <ng-container *ngIf=\"tableStore?.isFullscreen ? deleteIcon && !tableStore.isSelectedTable : deleteIcon\">\n        <thy-divider class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n        <a\n            href=\"javascript:;\"\n            thyAction\n            thyType=\"danger\"\n            [thyActionIcon]=\"deleteIcon\"\n            [thyTooltip]=\"iconName\"\n            (mousedown)=\"onDelete($event)\"\n            (mouseenter)=\"onEnterDelete($event)\"\n            (mouseleave)=\"onLeaveDelete($event)\"\n        ></a>\n    </ng-container>\n</thy-actions>\n"]}
200
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.ts","../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAqB,MAAM,eAAe,CAAC;AAI5E,OAAO,EAAa,gBAAgB,EAAE,0BAA0B,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAErI,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAE/E,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAC;AAC9E,OAAO,KAAK,aAAa,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,UAAU,MAAM,qBAAqB,CAAC;AAGlD,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;;AAM7C,MAAM,OAAO,wBAAwB;IA0DjC,YACY,MAAc,EACd,kBAAyC,EACzC,UAAsB,EACtB,UAAmD,EACnD,gBAAkC;QAJlC,WAAM,GAAN,MAAM,CAAQ;QACd,uBAAkB,GAAlB,kBAAkB,CAAuB;QACzC,eAAU,GAAV,UAAU,CAAY;QACtB,eAAU,GAAV,UAAU,CAAyC;QACnD,qBAAgB,GAAhB,gBAAgB,CAAkB;QA1C9C,iBAAY,GAAiB;YACzB;gBACI,GAAG,EAAE,aAAa;gBAClB,IAAI,EAAE,OAAO;gBACb,UAAU,EAAE,KAAK;gBACjB,IAAI,EAAE,mBAAmB;gBACzB,YAAY,EAAE,GAAG,EAAE;oBACf,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACvC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;gBACzC,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,aAAa;gBAClB,IAAI,EAAE,OAAO;gBACb,UAAU,EAAE,KAAK;gBACjB,IAAI,EAAE,qBAAqB;gBAC3B,YAAY,EAAE,GAAG,EAAE;oBACf,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACvB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;gBACzC,CAAC;aACJ;SACJ,CAAC;IAgBC,CAAC;IA/CJ,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IACrD,CAAC;IA+BD,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IACxE,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;IAC3D,CAAC;IAUD,QAAQ;QACJ,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC;QACxH,MAAM,EAAE,aAAa,EAAE,eAAe,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC;QAC3D,MAAM,SAAS,GAAG,EAAE,aAAa,EAAE,eAAe,EAAE,CAAC;QACrD,IAAI,CAAC,WAAW,GAAG,yBAAyB,CAAC,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;QACzE,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,qBAAqB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC;QACjE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,EAAE,CAAC;QAEtE,MAAM,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAChE,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACtE,MAAM,OAAO,GAAI,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAkB,CAAC,OAAO,CAAC;YAChF,IAAI,CAAC,aAAa,GAAG,OAAO,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC;QACvF,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;QAC1C,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;IAC/C,CAAC;IAED,aAAa;QACT,MAAM,EAAE,aAAa,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC;QACxG,MAAM,GAAG,GAAG,mBAAmB,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,mBAAmB,CAAC,CAAC;YAClD,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;SAC1B;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE;YACjD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,sBAAsB,CAAC,CAAC;YACrD,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;SAC1B;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE;YACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,KAAK,CAAC;YACnC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;SAC1B;QACD,cAAc;QACd,MAAM,8BAA8B,GAChC,iBAAiB,CAAC,MAAM,GAAG,GAAG,CAAC,QAAQ,EAAE,KAAK,aAAa,CAAC,MAAM;YAClE,oBAAoB,CAAC,MAAM,GAAG,GAAG,CAAC,SAAS,EAAE,KAAK,aAAa,CAAC,MAAM,CAAC;QAC3E,IAAI,CAAC,8BAA8B,EAAE;YACjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;IACL,CAAC;IAED,QAAQ,CAAC,KAAiB;QACtB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;QACrC,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;QACrC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;IAED,aAAa,CAAC,KAAiB;QAC3B,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;IACxC,CAAC;IAED,aAAa,CAAC,KAAiB;QAC3B,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;IAC1C,CAAC;IAED,eAAe,CAAC,KAAiB;QAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,OAAO,GAAI,KAAK,CAAC,MAAsB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACrE,MAAM,QAAQ,GAAG,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;YACjB,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CACrC,OAAsB,EACtB,IAAI,CAAC,aAAa,EAClB,gBAAgB,EAChB;gBACI,kBAAkB,EAAE,CAAC;gBACrB,UAAU,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE;gBACpC,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,sBAAsB;aAC/E,EACD,CAAC,QAAmB,EAAE,EAAE;gBACpB,IAAI,CAAC,QAAQ,KAAK,0BAA0B,IAAI,QAAQ,CAAC,IAAI,CAAC,QAAQ,KAAK,sBAAsB,IAAI,CAAC,QAAQ,CAAC,EAAE;oBAC7G,IAAI,CAAC,UAAU,CAAC,+BAA+B,CAAC,IAAI,CAAC,CAAC;iBACzD;qBAAM;oBACH,IAAI,CAAC,UAAU,CAAC,+BAA+B,CAAC,QAAQ,CAAC,CAAC;iBAC7D;gBACD,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;YAClC,CAAC,EACD,YAAY,EACZ,CAAC,CACJ,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;IAED,aAAa,CAAC,KAAiB;QAC3B,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAC3E,CAAC;IAED,SAAS,CAAC,KAAiB;QACvB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,CAAQ;QACX,CAAC,EAAE,cAAc,EAAE,CAAC;QAEpB,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACpE,CAAC;IAED,sBAAsB,CAAC,KAAiB;QACpC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;QAC1C,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,aAAa,EAAE,YAAY,EAAE,EAAE;YAC5D,OAAO,aAAa,GAAG,YAAY,CAAC,KAAK,CAAC;QAC9C,CAAC,EAAE,CAAC,CAAC,CAAC;QACN,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE;YAClC,OAAO,EAAE,KAAK,EAAE,QAAQ,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IACrF,CAAC;IAED,mBAAmB,CAAC,KAAY;QAC5B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,wBAAwB,EAAE;YAC3C,MAAM,EAAE,KAAK,CAAC,aAA4B;YAC1C,YAAY,EAAE;gBACV,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,MAAM,EAAE,IAAI,CAAC,MAAM;aACtB;YACD,QAAQ,EAAE,CAAC;YACX,cAAc,EAAE,IAAI;YACpB,eAAe,EAAE,IAAI;YACrB,WAAW,EAAE,KAAK;YAClB,SAAS,EAAE,YAAY;YACvB,iBAAiB,EAAE,QAAQ;YAC3B,UAAU,EAAE,sBAAsB;SACrC,CAAC,CAAC;IACP,CAAC;;sHA5MQ,wBAAwB;0GAAxB,wBAAwB,6HCzBrC,6pFA+DA;4FDtCa,wBAAwB;kBAJpC,SAAS;+BACI,mBAAmB;qNAgBpB,UAAU;sBAAlB,KAAK;gBAEG,YAAY;sBAApB,KAAK;;AAgMV,MAAM,CAAN,IAAY,UAIX;AAJD,WAAY,UAAU;IAClB,qDAAyC,CAAA;IACzC,2DAA+C,CAAA;IAC/C,6BAAiB,CAAA;AACrB,CAAC,EAJW,UAAU,KAAV,UAAU,QAIrB","sourcesContent":["import { Component, OnInit, Input, NgZone, OnDestroy } from '@angular/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { TableStore } from '../../table.store';\nimport { ColorType, BackgroundColors, TableHeaderBackgroundColor, SpecialBackgroundColor } from '../../../../constants/color-select';\nimport { TheColorSelectService } from '../../../../services/color-select.service';\nimport { splitCell } from '../../utils/split-cell';\nimport { setCellMenuVisibility } from '../../utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../../table.types';\nimport { TableEditor } from '../../table.editor';\nimport { TheTableOptionsComponent } from './table-options.component';\nimport { PluginKeys, TheEditor } from '../../../../interfaces';\nimport { getPluginOptions } from '../../../../core';\nimport { TableElement } from '../../../..//custom-types';\nimport { isRectangularInTableCells } from '../../utils/is-selection-in-table';\nimport * as TheTransforms from '../../../../transforms';\nimport * as TheQueries from '../../../../queries';\nimport { Subscription } from 'rxjs';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\nimport { copyNode } from '../../../../utils';\n\n@Component({\n    selector: 'the-table-toolbar',\n    templateUrl: 'table-toolbar.component.html'\n})\nexport class TheTableToolbarComponent implements OnInit, OnDestroy {\n    selectedColor: string;\n\n    deleteIcon: DeleteIcon;\n\n    iconName: string;\n\n    isRectangle: boolean;\n\n    isColumnEqual: boolean;\n\n    tableChangeSubscriber: Subscription;\n\n    @Input() tableStore: TableStore;\n\n    @Input() tableElement: TableElement;\n\n    get editor(): Editor {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    cellMenuList: MenuEntity[] = [\n        {\n            key: 'merge-cells',\n            name: '合并单元格',\n            visibility: false,\n            icon: 'table-merge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                this.tableStore.mergeCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        },\n        {\n            key: 'split-cells',\n            name: '拆分单元格',\n            visibility: false,\n            icon: 'table-unmerge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                splitCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        }\n    ];\n\n    get hasDivider() {\n        return this.cellMenuList.filter(item => item.visibility).length > 1;\n    }\n\n    get tableOptions() {\n        return getPluginOptions(this.editor, PluginKeys.table);\n    }\n\n    constructor(\n        private ngZone: NgZone,\n        private colorSelectService: TheColorSelectService,\n        private thyPopover: ThyPopover,\n        private popoverRef: ThyPopoverRef<TheTableToolbarComponent>,\n        private thyNotifyService: ThyNotifyService\n    ) {}\n\n    ngOnInit() {\n        this.isColumnEqual = this.tableElement?.columns?.every(col => this.tableElement.columns[0].width === col.width) ?? true;\n        const { selectedCells, isSelectedTable } = this.tableStore;\n        const tableInfo = { selectedCells, isSelectedTable };\n        this.isRectangle = isRectangularInTableCells(this.editor, selectedCells);\n        this.setDeleteIcon();\n        setCellMenuVisibility(this.editor, this.cellMenuList, tableInfo);\n        this.selectedColor = this.tableStore.getSelectedCellBackgroundColor();\n\n        const path = TheEditor.findPath(this.editor, this.tableElement);\n        this.tableChangeSubscriber = this.tableStore.tableChange().subscribe(() => {\n            const columns = (TheQueries.getNode(this.editor, path) as TableElement).columns;\n            this.isColumnEqual = columns?.every(col => columns[0].width === col.width) ?? true;\n        });\n    }\n\n    ngOnDestroy() {\n        this.tableChangeSubscriber?.unsubscribe();\n        this.colorSelectService.closeColorSelect();\n    }\n\n    setDeleteIcon() {\n        const { selectedCells, selectedRowsIndex, selectedColumnsIndex, createTablePosition } = this.tableStore;\n        const pos = createTablePosition();\n        if (this.tableStore.selectedRowsIndex.length > 0) {\n            this.deleteIcon = DeleteIcon['table-delete-rows'];\n            this.iconName = '删除整行';\n        }\n        if (this.tableStore.selectedColumnsIndex.length > 0) {\n            this.deleteIcon = DeleteIcon['table-delete-columns'];\n            this.iconName = '删除整列';\n        }\n        if (this.tableStore.isSelectedTable) {\n            this.deleteIcon = DeleteIcon.trash;\n            this.iconName = '删除表格';\n        }\n        // 满足已选中整行或者整列\n        const isSelectedWholeRowOrColumnCell =\n            selectedRowsIndex.length * pos.getWidth() === selectedCells.length ||\n            selectedColumnsIndex.length * pos.getHeight() === selectedCells.length;\n        if (!isSelectedWholeRowOrColumnCell) {\n            this.deleteIcon = null;\n            this.iconName = null;\n        }\n    }\n\n    onDelete(event: MouseEvent) {\n        event.preventDefault();\n        this.tableStore.removeColumnOrRows();\n        this.tableStore.clearDangerousCells();\n        this.tableStore.clearSelectedCells();\n        this.popoverRef.close();\n    }\n\n    onEnterDelete(event: MouseEvent) {\n        this.tableStore.setDangerousCells();\n    }\n\n    onLeaveDelete(event: MouseEvent) {\n        this.tableStore.clearDangerousCells();\n    }\n\n    openSelectColor(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        const element = (event.target as HTMLElement).closest('.thy-action');\n        const isHeader = TableEditor.isActiveHeader(this.editor);\n        this.ngZone.run(() => {\n            this.colorSelectService.toggleColorSelect(\n                element as HTMLElement,\n                this.selectedColor,\n                BackgroundColors,\n                {\n                    perRowColorNumbers: 7,\n                    rowOptions: { 1: '#bbb', 2: '#bbb' },\n                    specialColor: isHeader ? TableHeaderBackgroundColor : SpecialBackgroundColor\n                },\n                (newColor: ColorType) => {\n                    if ((newColor === TableHeaderBackgroundColor && isHeader) || (newColor === SpecialBackgroundColor && !isHeader)) {\n                        this.tableStore.setSelectedCellsBackgroundColor(null);\n                    } else {\n                        this.tableStore.setSelectedCellsBackgroundColor(newColor);\n                    }\n                    this.selectedColor = newColor;\n                },\n                'bottomLeft',\n                4\n            );\n        });\n    }\n\n    setFullscreen(event: MouseEvent) {\n        this.tableOptions.setFullscreen(this.editor, event, this.tableElement);\n    }\n\n    mousedown(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    onCopy(e: Event) {\n        e?.preventDefault();\n\n        copyNode(this.editor, this.tableElement, this.thyNotifyService);\n    }\n\n    setEquallyColumnHandle(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        const columns = this.tableElement.columns;\n        const sumWidth = columns.reduce((previousValue, currentValue) => {\n            return previousValue + currentValue.width;\n        }, 0);\n        const equalColumns = columns.map(() => {\n            return { width: sumWidth / columns.length };\n        });\n\n        TheTransforms.setNode(this.editor, { columns: equalColumns }, this.tableElement);\n    }\n\n    openTableOptionMenu(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.thyPopover.open(TheTableOptionsComponent, {\n            origin: event.currentTarget as HTMLElement,\n            initialState: {\n                tableStore: this.tableStore,\n                editor: this.editor\n            },\n            minWidth: 0,\n            insideClosable: true,\n            outsideClosable: true,\n            hasBackdrop: false,\n            placement: 'bottomLeft',\n            originActiveClass: 'active',\n            panelClass: 'table-options-pannel'\n        });\n    }\n}\n\nexport enum DeleteIcon {\n    'table-delete-rows' = 'table-delete-rows',\n    'table-delete-columns' = 'table-delete-columns',\n    'trash' = 'trash'\n}\n","<thy-actions thySize=\"xxs\">\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a\n            *ngIf=\"item.visibility\"\n            href=\"javascript:;\"\n            thyAction\n            [thyActionIcon]=\"item.icon\"\n            [thyTooltip]=\"item.name\"\n            (mousedown)=\"item.actionHandle()\"\n        ></a>\n    </ng-container>\n    <thy-divider *ngIf=\"hasDivider\" class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"> </thy-divider>\n    <a href=\"javascript:;\" thyAction thyTooltip=\"单元格背景\" (mousedown)=\"openSelectColor($event)\">\n        <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n    </a>\n    <a\n        href=\"javascript:;\"\n        *ngIf=\"tableStore.isSelectedTable && !isColumnEqual\"\n        thyAction\n        thyTooltip=\"列等宽\"\n        (mousedown)=\"setEquallyColumnHandle($event)\"\n    >\n        <thy-icon thyIconName=\"table-column-equal-width\"></thy-icon>\n    </a>\n    <a\n        href=\"javascript:;\"\n        *ngIf=\"tableStore.isSelectedTable && tableOptions?.showFullscreen\"\n        thyAction\n        thyTooltip=\"全屏\"\n        (mousedown)=\"setFullscreen($event)\"\n    >\n        <thy-icon thyIconName=\"arrows-alt\"></thy-icon>\n    </a>\n    <a\n        *ngIf=\"tableStore.isSelectedTable && !tableStore?.isFullscreen\"\n        class=\"fullscreen-hidden\"\n        href=\"javascript:;\"\n        thyAction\n        thyActionIcon=\"copy\"\n        thyTooltip=\"复制\"\n        (mousedown)=\"onCopy($event)\"\n    ></a>\n    <ng-container *ngIf=\"tableStore.isSelectedTable\">\n        <thy-divider class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n        <a href=\"javascript:;\" class=\"link-with-down\" thyAction (mousedown)=\"mousedown($event)\" (click)=\"openTableOptionMenu($event)\">\n            <span>表格选项</span>\n            <thy-icon class=\"font-size-sm text-desc ml-1\" thyIconName=\"caret-down\"></thy-icon>\n        </a>\n    </ng-container>\n    <ng-container *ngIf=\"tableStore?.isFullscreen ? deleteIcon && !tableStore.isSelectedTable : deleteIcon\">\n        <thy-divider class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n        <a\n            href=\"javascript:;\"\n            thyAction\n            thyType=\"danger\"\n            [thyActionIcon]=\"deleteIcon\"\n            [thyTooltip]=\"iconName\"\n            (mousedown)=\"onDelete($event)\"\n            (mouseenter)=\"onEnterDelete($event)\"\n            (mouseleave)=\"onLeaveDelete($event)\"\n        ></a>\n    </ng-container>\n</thy-actions>\n"]}
@@ -38,12 +38,18 @@ getCell) {
38
38
  });
39
39
  });
40
40
  }
41
+ const theTableWrapper = AngularEditor.toDOMNode(editor, table).querySelector('.the-table-wrapper');
42
+ const scrollWidth = theTableWrapper.scrollWidth;
43
+ const clientWidth = theTableWrapper.clientWidth;
44
+ const columnLength = table?.children[0].children.length;
45
+ const columnWidth = clientWidth / (columnLength + 1);
41
46
  if (table?.columns) {
42
- const theTableWrapper = AngularEditor.toDOMNode(editor, table).querySelector('.the-table-wrapper');
43
- const scrollWidth = theTableWrapper.scrollWidth;
44
- const clientWidth = theTableWrapper.clientWidth;
45
47
  Transforms.setNodes(editor, { columns: addColumns(table, table.columns.length + 1, insertColumnIndex, scrollWidth > clientWidth) }, { at: tableEntry[1] });
46
48
  }
49
+ else if (columnWidth < opts.minWidthPx) {
50
+ const columns = Array(columnLength + 1).fill({ width: opts.minWidthPx });
51
+ Transforms.setNodes(editor, { columns }, { at: tableEntry[1] });
52
+ }
47
53
  });
48
54
  }
49
55
  /**
@@ -59,4 +65,4 @@ export function insertColumnAtRow(opts, editor, count = 1, tableEntry, rowIndex,
59
65
  }
60
66
  });
61
67
  }
62
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"insert-column.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/table/transforms/insert-column.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transforms, Editor, NodeEntry } from 'slate';\nimport { TablePosition, createCell } from '../utils';\nimport { calcSpanForColumn } from '../utils/calc-span';\nimport { addColumns } from '../utils/add-columns';\nimport { TableOptions } from '../table.types';\nimport { TableCellElement, TableElement } from '../../../custom-types';\nimport { AngularEditor } from 'slate-angular';\n\n/**\n * Insert a new column in current table\n */\nexport function insertColumn(\n    opts: TableOptions,\n    editor: Editor,\n    count = 1,\n    at?: number, // Column index\n    getCell?: (column: number, row: number) => TableCellElement\n) {\n    const { selection } = editor;\n    const {\n        anchor: { path }\n    } = selection;\n\n    const tablePosition = TablePosition.create(opts, editor, path);\n    let table = tablePosition.table;\n    let tableEntry = tablePosition.tableEntry;\n\n    const insertColumnIndex = typeof at === 'undefined' ? tablePosition.getColumnIndex() + 1 : at;\n\n    // Insert the new cell\n\n    Editor.withoutNormalizing(editor, () => {\n        const colspan = calcSpanForColumn(table, insertColumnIndex);\n        for (let i = 0; i < count; i++) {\n            table.children.forEach((row, rowIndex) => {\n                const isInside = colspan[rowIndex];\n                const newCell = getCell ? getCell(insertColumnIndex, rowIndex) : createCell(opts);\n                if (isInside) {\n                    newCell.hidden = true;\n                    const dirtyCell = row.children.find(\n                        (cell: TableCellElement, columnIndex: number) =>\n                            !cell.hidden &&\n                            columnIndex < insertColumnIndex &&\n                            cell.colspan &&\n                            cell.colspan + columnIndex > insertColumnIndex\n                    ) as TableCellElement;\n                    if (dirtyCell) {\n                        Transforms.setNodes(\n                            editor,\n                            { colspan: dirtyCell.colspan + 1 },\n                            {\n                                at: tablePosition.tableEntry[1].concat(rowIndex).concat(row.children.indexOf(dirtyCell))\n                            }\n                        );\n                    }\n                }\n                Transforms.insertNodes(editor, [newCell], {\n                    at: tablePosition.tableEntry[1].concat(rowIndex).concat(insertColumnIndex)\n                });\n            });\n        }\n        if (table?.columns) {\n            const theTableWrapper = AngularEditor.toDOMNode(editor, table).querySelector('.the-table-wrapper');\n\n            const scrollWidth = theTableWrapper.scrollWidth;\n            const clientWidth = theTableWrapper.clientWidth;\n            Transforms.setNodes(\n                editor,\n                { columns: addColumns(table, table.columns.length + 1, insertColumnIndex, scrollWidth > clientWidth) },\n                { at: tableEntry[1] }\n            );\n        }\n    });\n}\n\n/**\n * Insert new column in the row\n */\nexport function insertColumnAtRow(\n    opts: TableOptions,\n    editor: Editor,\n    count = 1,\n    tableEntry: NodeEntry<TableElement>,\n    rowIndex: number,\n    columnIndex: number,\n    getCell?: (column: number, row: number) => TableCellElement\n) {\n    Editor.withoutNormalizing(editor, () => {\n        for (let i = 0; i < count; i++) {\n            const newCell = getCell ? getCell(columnIndex, rowIndex) : createCell(opts);\n            Transforms.insertNodes(editor, [newCell], {\n                at: tableEntry[1].concat([rowIndex, columnIndex])\n            });\n        }\n    });\n}\n"]}
68
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"insert-column.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/table/transforms/insert-column.ts"],"names":[],"mappings":"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","sourcesContent":["import { Transforms, Editor, NodeEntry } from 'slate';\nimport { TablePosition, createCell } from '../utils';\nimport { calcSpanForColumn } from '../utils/calc-span';\nimport { addColumns } from '../utils/add-columns';\nimport { TableOptions } from '../table.types';\nimport { TableCellElement, TableElement } from '../../../custom-types';\nimport { AngularEditor } from 'slate-angular';\n\n/**\n * Insert a new column in current table\n */\nexport function insertColumn(\n    opts: TableOptions,\n    editor: Editor,\n    count = 1,\n    at?: number, // Column index\n    getCell?: (column: number, row: number) => TableCellElement\n) {\n    const { selection } = editor;\n    const {\n        anchor: { path }\n    } = selection;\n\n    const tablePosition = TablePosition.create(opts, editor, path);\n    let table = tablePosition.table;\n    let tableEntry = tablePosition.tableEntry;\n\n    const insertColumnIndex = typeof at === 'undefined' ? tablePosition.getColumnIndex() + 1 : at;\n\n    // Insert the new cell\n\n    Editor.withoutNormalizing(editor, () => {\n        const colspan = calcSpanForColumn(table, insertColumnIndex);\n        for (let i = 0; i < count; i++) {\n            table.children.forEach((row, rowIndex) => {\n                const isInside = colspan[rowIndex];\n                const newCell = getCell ? getCell(insertColumnIndex, rowIndex) : createCell(opts);\n                if (isInside) {\n                    newCell.hidden = true;\n                    const dirtyCell = row.children.find(\n                        (cell: TableCellElement, columnIndex: number) =>\n                            !cell.hidden &&\n                            columnIndex < insertColumnIndex &&\n                            cell.colspan &&\n                            cell.colspan + columnIndex > insertColumnIndex\n                    ) as TableCellElement;\n                    if (dirtyCell) {\n                        Transforms.setNodes(\n                            editor,\n                            { colspan: dirtyCell.colspan + 1 },\n                            {\n                                at: tablePosition.tableEntry[1].concat(rowIndex).concat(row.children.indexOf(dirtyCell))\n                            }\n                        );\n                    }\n                }\n                Transforms.insertNodes(editor, [newCell], {\n                    at: tablePosition.tableEntry[1].concat(rowIndex).concat(insertColumnIndex)\n                });\n            });\n        }\n\n        const theTableWrapper = AngularEditor.toDOMNode(editor, table).querySelector('.the-table-wrapper');\n        const scrollWidth = theTableWrapper.scrollWidth;\n        const clientWidth = theTableWrapper.clientWidth;\n        const columnLength = table?.children[0].children.length;\n        const columnWidth = clientWidth / (columnLength + 1);\n\n        if (table?.columns) {\n            Transforms.setNodes(\n                editor,\n                { columns: addColumns(table, table.columns.length + 1, insertColumnIndex, scrollWidth > clientWidth) },\n                { at: tableEntry[1] }\n            );\n        } else if (columnWidth < opts.minWidthPx) {\n            const columns = Array(columnLength + 1).fill({ width: opts.minWidthPx });\n            Transforms.setNodes(editor, { columns }, { at: tableEntry[1] });\n        }\n    });\n}\n\n/**\n * Insert new column in the row\n */\nexport function insertColumnAtRow(\n    opts: TableOptions,\n    editor: Editor,\n    count = 1,\n    tableEntry: NodeEntry<TableElement>,\n    rowIndex: number,\n    columnIndex: number,\n    getCell?: (column: number, row: number) => TableCellElement\n) {\n    Editor.withoutNormalizing(editor, () => {\n        for (let i = 0; i < count; i++) {\n            const newCell = getCell ? getCell(columnIndex, rowIndex) : createCell(opts);\n            Transforms.insertNodes(editor, [newCell], {\n                at: tableEntry[1].concat([rowIndex, columnIndex])\n            });\n        }\n    });\n}\n"]}
@@ -4187,12 +4187,18 @@ getCell) {
4187
4187
  });
4188
4188
  });
4189
4189
  }
4190
+ const theTableWrapper = AngularEditor.toDOMNode(editor, table).querySelector('.the-table-wrapper');
4191
+ const scrollWidth = theTableWrapper.scrollWidth;
4192
+ const clientWidth = theTableWrapper.clientWidth;
4193
+ const columnLength = table === null || table === void 0 ? void 0 : table.children[0].children.length;
4194
+ const columnWidth = clientWidth / (columnLength + 1);
4190
4195
  if (table === null || table === void 0 ? void 0 : table.columns) {
4191
- const theTableWrapper = AngularEditor.toDOMNode(editor, table).querySelector('.the-table-wrapper');
4192
- const scrollWidth = theTableWrapper.scrollWidth;
4193
- const clientWidth = theTableWrapper.clientWidth;
4194
4196
  Transforms.setNodes(editor, { columns: addColumns(table, table.columns.length + 1, insertColumnIndex, scrollWidth > clientWidth) }, { at: tableEntry[1] });
4195
4197
  }
4198
+ else if (columnWidth < opts.minWidthPx) {
4199
+ const columns = Array(columnLength + 1).fill({ width: opts.minWidthPx });
4200
+ Transforms.setNodes(editor, { columns }, { at: tableEntry[1] });
4201
+ }
4196
4202
  });
4197
4203
  }
4198
4204
  /**
@@ -12191,18 +12197,6 @@ class TheTableToolbarComponent {
12191
12197
  setDeleteIcon() {
12192
12198
  const { selectedCells, selectedRowsIndex, selectedColumnsIndex, createTablePosition } = this.tableStore;
12193
12199
  const pos = createTablePosition();
12194
- // 满足已选中整行或者整列
12195
- const isSelectedWholeRowOrColumnCell = selectedRowsIndex.length * pos.getWidth() === selectedCells.length ||
12196
- selectedColumnsIndex.length * pos.getHeight() === selectedCells.length;
12197
- if (!isSelectedWholeRowOrColumnCell) {
12198
- this.deleteIcon = null;
12199
- this.iconName = null;
12200
- return;
12201
- }
12202
- if (this.tableStore.isSelectedTable) {
12203
- this.deleteIcon = DeleteIcon.trash;
12204
- this.iconName = '删除表格';
12205
- }
12206
12200
  if (this.tableStore.selectedRowsIndex.length > 0) {
12207
12201
  this.deleteIcon = DeleteIcon['table-delete-rows'];
12208
12202
  this.iconName = '删除整行';
@@ -12211,6 +12205,17 @@ class TheTableToolbarComponent {
12211
12205
  this.deleteIcon = DeleteIcon['table-delete-columns'];
12212
12206
  this.iconName = '删除整列';
12213
12207
  }
12208
+ if (this.tableStore.isSelectedTable) {
12209
+ this.deleteIcon = DeleteIcon.trash;
12210
+ this.iconName = '删除表格';
12211
+ }
12212
+ // 满足已选中整行或者整列
12213
+ const isSelectedWholeRowOrColumnCell = selectedRowsIndex.length * pos.getWidth() === selectedCells.length ||
12214
+ selectedColumnsIndex.length * pos.getHeight() === selectedCells.length;
12215
+ if (!isSelectedWholeRowOrColumnCell) {
12216
+ this.deleteIcon = null;
12217
+ this.iconName = null;
12218
+ }
12214
12219
  }
12215
12220
  onDelete(event) {
12216
12221
  event.preventDefault();