@worktile/theia 3.0.6 → 3.0.7

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.
@@ -131,6 +131,7 @@ export class TheTableToolbarComponent {
131
131
  tableStore: this.tableStore,
132
132
  editor: this.editor
133
133
  },
134
+ minWidth: 0,
134
135
  insideClosable: false,
135
136
  hasBackdrop: false,
136
137
  placement: 'bottomLeft',
@@ -158,4 +159,4 @@ export var DeleteIcon;
158
159
  DeleteIcon[DeleteIcon["table-delete-columns"] = 1] = "table-delete-columns";
159
160
  DeleteIcon[DeleteIcon["trash"] = 2] = "trash";
160
161
  })(DeleteIcon || (DeleteIcon = {}));
161
- //# 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 { setCellMenuInvisibility } from '../../utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../../table.types';\nimport { TableEditor } from '../../table.editor';\nimport { TheTableOptionsComponent } from './table-options.component';\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: string;\n\n    iconName: string;\n\n    @Input() tableStore: TableStore;\n\n    @Input() isActiveSelect: boolean;\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            invisibility: 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            invisibility: 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 isShowSplitLine() {\n        return this.cellMenuList.filter(item => !item.invisibility).length > 1;\n    }\n\n    constructor(\n        private ngZone: NgZone,\n        private colorSelectService: TheColorSelectService,\n        private thyPopover: ThyPopover,\n        private popoverRef: ThyPopoverRef<TheTableToolbarComponent>\n    ) {}\n\n    ngOnInit() {\n        this.deleteIcon = DeleteIcon[this.getDeleteIcon()];\n        this.getIconName(this.deleteIcon);\n        setCellMenuInvisibility(this.editor, this.cellMenuList, this.tableStore.selectedCells, this.isActiveSelect);\n        this.selectedColor = this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    ngOnDestroy() {\n        this.colorSelectService.closeColorSelect();\n    }\n\n    getIconName(key: string) {\n        switch (key) {\n            case 'trash':\n                this.iconName = '删除表格';\n                break;\n            case 'table-delete-columns':\n                this.iconName = '删除整列';\n                break;\n            case 'table-delete-rows':\n                this.iconName = '删除整行';\n                break;\n        }\n    }\n\n    getDeleteIcon() {\n        if (this.tableStore.isSelectedTable) {\n            return DeleteIcon.trash;\n        }\n        if (this.tableStore.selectedRowsIndex.length > 0) {\n            return DeleteIcon['table-delete-rows'];\n        }\n        if (this.tableStore.selectedColumnsIndex.length > 0) {\n            return DeleteIcon['table-delete-columns'];\n        }\n        return null;\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-icon-nav-link');\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            );\n        });\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            insideClosable: false,\n            hasBackdrop: false,\n            placement: 'bottomLeft',\n            originActiveClass: 'table-options-active',\n            panelClass: 'table-options-pannel'\n        });\n    }\n}\n\nexport enum DeleteIcon {\n    'table-delete-rows',\n    'table-delete-columns',\n    'trash'\n}\n","<thy-icon-nav>\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a href=\"javascript:;\" thyIconNavLink *ngIf=\"!item.invisibility\" [thyTooltip]=\"item.name\" (mousedown)=\"item.actionHandle()\">\n            <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n        </a>\n    </ng-container>\n    <nav-split-line *ngIf=\"!isActiveSelect && isShowSplitLine\"></nav-split-line>\n    <a href=\"javascript:;\" thyIconNavLink thyTooltip=\"单元格背景\" (mousedown)=\"openSelectColor($event)\">\n        <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n    </a>\n    <nav-split-line *ngIf=\"tableStore.isSelectedTable\"></nav-split-line>\n    <button\n        thyButton=\"default\"\n        *ngIf=\"tableStore.isSelectedTable\"\n        class=\"mr-2\"\n        thySize=\"md\"\n        class=\"table-options\"\n        (mousedown)=\"openTableOptionMenu($event)\"\n    >\n        <span>表格选项</span>\n        <thy-icon thyIconName=\"caret-down\"></thy-icon>\n    </button>\n    <nav-split-line *ngIf=\"deleteIcon\"></nav-split-line>\n    <a\n        *ngIf=\"deleteIcon\"\n        href=\"javascript:;\"\n        thyIconNavLink\n        [thyTooltip]=\"iconName\"\n        class=\"danger\"\n        [thyIconNavLinkIcon]=\"deleteIcon\"\n        (mousedown)=\"onDelete($event)\"\n        (mouseenter)=\"onEnterDelete($event)\"\n        (mouseleave)=\"onLeaveDelete($event)\"\n    ></a>\n</thy-icon-nav>\n"]}
162
+ //# 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 { setCellMenuInvisibility } from '../../utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../../table.types';\nimport { TableEditor } from '../../table.editor';\nimport { TheTableOptionsComponent } from './table-options.component';\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: string;\n\n    iconName: string;\n\n    @Input() tableStore: TableStore;\n\n    @Input() isActiveSelect: boolean;\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            invisibility: 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            invisibility: 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 isShowSplitLine() {\n        return this.cellMenuList.filter(item => !item.invisibility).length > 1;\n    }\n\n    constructor(\n        private ngZone: NgZone,\n        private colorSelectService: TheColorSelectService,\n        private thyPopover: ThyPopover,\n        private popoverRef: ThyPopoverRef<TheTableToolbarComponent>\n    ) {}\n\n    ngOnInit() {\n        this.deleteIcon = DeleteIcon[this.getDeleteIcon()];\n        this.getIconName(this.deleteIcon);\n        setCellMenuInvisibility(this.editor, this.cellMenuList, this.tableStore.selectedCells, this.isActiveSelect);\n        this.selectedColor = this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    ngOnDestroy() {\n        this.colorSelectService.closeColorSelect();\n    }\n\n    getIconName(key: string) {\n        switch (key) {\n            case 'trash':\n                this.iconName = '删除表格';\n                break;\n            case 'table-delete-columns':\n                this.iconName = '删除整列';\n                break;\n            case 'table-delete-rows':\n                this.iconName = '删除整行';\n                break;\n        }\n    }\n\n    getDeleteIcon() {\n        if (this.tableStore.isSelectedTable) {\n            return DeleteIcon.trash;\n        }\n        if (this.tableStore.selectedRowsIndex.length > 0) {\n            return DeleteIcon['table-delete-rows'];\n        }\n        if (this.tableStore.selectedColumnsIndex.length > 0) {\n            return DeleteIcon['table-delete-columns'];\n        }\n        return null;\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-icon-nav-link');\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            );\n        });\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: false,\n            hasBackdrop: false,\n            placement: 'bottomLeft',\n            originActiveClass: 'table-options-active',\n            panelClass: 'table-options-pannel'\n        });\n    }\n}\n\nexport enum DeleteIcon {\n    'table-delete-rows',\n    'table-delete-columns',\n    'trash'\n}\n","<thy-icon-nav>\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a href=\"javascript:;\" thyIconNavLink *ngIf=\"!item.invisibility\" [thyTooltip]=\"item.name\" (mousedown)=\"item.actionHandle()\">\n            <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n        </a>\n    </ng-container>\n    <nav-split-line *ngIf=\"!isActiveSelect && isShowSplitLine\"></nav-split-line>\n    <a href=\"javascript:;\" thyIconNavLink thyTooltip=\"单元格背景\" (mousedown)=\"openSelectColor($event)\">\n        <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n    </a>\n    <nav-split-line *ngIf=\"tableStore.isSelectedTable\"></nav-split-line>\n    <button\n        thyButton=\"default\"\n        *ngIf=\"tableStore.isSelectedTable\"\n        class=\"mr-2\"\n        thySize=\"md\"\n        class=\"table-options\"\n        (mousedown)=\"openTableOptionMenu($event)\"\n    >\n        <span>表格选项</span>\n        <thy-icon thyIconName=\"caret-down\"></thy-icon>\n    </button>\n    <nav-split-line *ngIf=\"deleteIcon\"></nav-split-line>\n    <a\n        *ngIf=\"deleteIcon\"\n        href=\"javascript:;\"\n        thyIconNavLink\n        [thyTooltip]=\"iconName\"\n        class=\"danger\"\n        [thyIconNavLinkIcon]=\"deleteIcon\"\n        (mousedown)=\"onDelete($event)\"\n        (mouseenter)=\"onEnterDelete($event)\"\n        (mouseleave)=\"onLeaveDelete($event)\"\n    ></a>\n</thy-icon-nav>\n"]}
@@ -46,6 +46,7 @@ export class TableService {
46
46
  offset: this.offset,
47
47
  hasBackdrop: this.hasBackdrop,
48
48
  insideClosable: this.insideClosable,
49
+ minWidth: 0,
49
50
  panelClass: 'the-temp-table-toolbar-wrap',
50
51
  scrollStrategy: this.overlay.scrollStrategies.reposition(),
51
52
  manualClosure: true
@@ -99,4 +100,4 @@ TableService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version
99
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TableService, decorators: [{
100
101
  type: Injectable
101
102
  }], ctorParameters: function () { return [{ type: i1.ThyPopover }, { type: i2.Overlay }, { type: i3.TableStore }, { type: i4.TheTableContextMenuService }, { type: i0.NgZone }, { type: i5.TheContextService }]; } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.service.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/table/table.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { ThyPlacement } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { TheTableToolbarComponent } from './components/toolbar/table-toolbar.component';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { TableStore } from './table.store';\nimport { TheTableContextMenuService } from '../../services/table-contextmenu.service';\nimport { TheContextService } from '../../services/context.service';\nimport { fromEvent, merge } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { isVirtualKey } from './utils/is-virtual-key';\n\n@Injectable()\nexport class TableService {\n    backdropClosable = false;\n\n    hasBackdrop = false;\n\n    insideClosable = false;\n\n    placement: ThyPlacement = 'topLeft';\n\n    offset = 8;\n\n    toolbarRef: ThyPopoverRef<any>;\n\n    get isOpened() {\n        return this.toolbarRef && this.toolbarRef.componentInstance;\n    }\n\n    constructor(\n        private thyPopover: ThyPopover,\n        private overlay: Overlay,\n        private tableStore: TableStore,\n        private theTableContextMenuService: TheTableContextMenuService,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    openToolbar(origin: HTMLElement, isActiveSelect?: boolean) {\n        this.theTableContextMenuService.closeContextMenu();\n\n        if (this.isOpened) {\n            if (this.toolbarRef.containerInstance.config.origin === origin) {\n                return;\n            }\n            this.toolbarRef.close();\n        }\n        this.toolbarRef = this.thyPopover.open(TheTableToolbarComponent, {\n            initialState: {\n                tableStore: this.tableStore,\n                isActiveSelect\n            },\n            viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n            origin: this.getOrigin(origin),\n            backdropClosable: this.backdropClosable,\n            placement: this.placement,\n            offset: this.offset,\n            hasBackdrop: this.hasBackdrop,\n            insideClosable: this.insideClosable,\n            panelClass: 'the-temp-table-toolbar-wrap',\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            manualClosure: true\n        });\n        this._listenCellClearEvent();\n    }\n\n    getOrigin(origin: HTMLElement): HTMLElement {\n        if (origin instanceof HTMLTableCellElement && origin.tagName !== 'TH') {\n            const { selectedRowsIndex, selectedColumnsIndex, focusCellPath, isSelectedTable, focusCellElement } = this.tableStore;\n            const [row, col] = focusCellPath.slice(-2);\n            const tableElement = focusCellElement.closest('.the-temp-table-container') as HTMLElement;\n            if (isSelectedTable && col === 0 && row === 0) {\n                return tableElement.querySelector('.the-temp-table-corner-controls');\n            }\n            if (selectedColumnsIndex.length > 0 && row === 0) {\n                return tableElement.querySelectorAll('.the-temp-table-col-controls')[col] as HTMLElement;\n            }\n            if (selectedRowsIndex.length > 0 && col === 0) {\n                return tableElement.querySelectorAll('.the-temp-table-row-controls-button-wrap')[row] as HTMLElement;\n            }\n        }\n        return origin;\n    }\n\n    closeToolbar() {\n        if (this.isOpened) {\n            this.ngZone.run(() => {\n                this.toolbarRef.close();\n            });\n            return this.toolbarRef.afterClosed();\n        }\n    }\n\n    _listenCellClearEvent() {\n        const onMouseObservable = merge(\n            fromEvent<MouseEvent>(document, 'mousedown').pipe(filter((e: MouseEvent) => e.button !== 2)),\n            fromEvent<KeyboardEvent>(document, 'keydown').pipe(\n                filter((e: KeyboardEvent) => {\n                    return !isVirtualKey(e);\n                })\n            )\n        )\n            .pipe(take(1))\n            .subscribe((e: MouseEvent) => {\n                if (this.tableStore.selectedCells && this.tableStore.selectedCells.length > 0) {\n                    if (e.type === 'keydown') {\n                        this.tableStore.clearSelectedCellsContent();\n                    }\n                    this.tableStore.clearSelectedCells();\n                    this.closeToolbar();\n                    onMouseObservable.unsubscribe();\n                }\n            });\n    }\n}\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.service.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/table/table.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { ThyPlacement } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { TheTableToolbarComponent } from './components/toolbar/table-toolbar.component';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { TableStore } from './table.store';\nimport { TheTableContextMenuService } from '../../services/table-contextmenu.service';\nimport { TheContextService } from '../../services/context.service';\nimport { fromEvent, merge } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { isVirtualKey } from './utils/is-virtual-key';\n\n@Injectable()\nexport class TableService {\n    backdropClosable = false;\n\n    hasBackdrop = false;\n\n    insideClosable = false;\n\n    placement: ThyPlacement = 'topLeft';\n\n    offset = 8;\n\n    toolbarRef: ThyPopoverRef<any>;\n\n    get isOpened() {\n        return this.toolbarRef && this.toolbarRef.componentInstance;\n    }\n\n    constructor(\n        private thyPopover: ThyPopover,\n        private overlay: Overlay,\n        private tableStore: TableStore,\n        private theTableContextMenuService: TheTableContextMenuService,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    openToolbar(origin: HTMLElement, isActiveSelect?: boolean) {\n        this.theTableContextMenuService.closeContextMenu();\n\n        if (this.isOpened) {\n            if (this.toolbarRef.containerInstance.config.origin === origin) {\n                return;\n            }\n            this.toolbarRef.close();\n        }\n        this.toolbarRef = this.thyPopover.open(TheTableToolbarComponent, {\n            initialState: {\n                tableStore: this.tableStore,\n                isActiveSelect\n            },\n            viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n            origin: this.getOrigin(origin),\n            backdropClosable: this.backdropClosable,\n            placement: this.placement,\n            offset: this.offset,\n            hasBackdrop: this.hasBackdrop,\n            insideClosable: this.insideClosable,\n            minWidth: 0,\n            panelClass: 'the-temp-table-toolbar-wrap',\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            manualClosure: true\n        });\n        this._listenCellClearEvent();\n    }\n\n    getOrigin(origin: HTMLElement): HTMLElement {\n        if (origin instanceof HTMLTableCellElement && origin.tagName !== 'TH') {\n            const { selectedRowsIndex, selectedColumnsIndex, focusCellPath, isSelectedTable, focusCellElement } = this.tableStore;\n            const [row, col] = focusCellPath.slice(-2);\n            const tableElement = focusCellElement.closest('.the-temp-table-container') as HTMLElement;\n            if (isSelectedTable && col === 0 && row === 0) {\n                return tableElement.querySelector('.the-temp-table-corner-controls');\n            }\n            if (selectedColumnsIndex.length > 0 && row === 0) {\n                return tableElement.querySelectorAll('.the-temp-table-col-controls')[col] as HTMLElement;\n            }\n            if (selectedRowsIndex.length > 0 && col === 0) {\n                return tableElement.querySelectorAll('.the-temp-table-row-controls-button-wrap')[row] as HTMLElement;\n            }\n        }\n        return origin;\n    }\n\n    closeToolbar() {\n        if (this.isOpened) {\n            this.ngZone.run(() => {\n                this.toolbarRef.close();\n            });\n            return this.toolbarRef.afterClosed();\n        }\n    }\n\n    _listenCellClearEvent() {\n        const onMouseObservable = merge(\n            fromEvent<MouseEvent>(document, 'mousedown').pipe(filter((e: MouseEvent) => e.button !== 2)),\n            fromEvent<KeyboardEvent>(document, 'keydown').pipe(\n                filter((e: KeyboardEvent) => {\n                    return !isVirtualKey(e);\n                })\n            )\n        )\n            .pipe(take(1))\n            .subscribe((e: MouseEvent) => {\n                if (this.tableStore.selectedCells && this.tableStore.selectedCells.length > 0) {\n                    if (e.type === 'keydown') {\n                        this.tableStore.clearSelectedCellsContent();\n                    }\n                    this.tableStore.clearSelectedCells();\n                    this.closeToolbar();\n                    onMouseObservable.unsubscribe();\n                }\n            });\n    }\n}\n"]}
@@ -35,6 +35,7 @@ export class TheTableToolbarItemComponent extends TheBaseToolbarItem {
35
35
  editor: this.editor,
36
36
  optionsParam
37
37
  },
38
+ minWidth: 0,
38
39
  backdropClosable: false,
39
40
  hasBackdrop: false,
40
41
  insideClosable: false,
@@ -82,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
82
83
  }
83
84
  }]
84
85
  }], ctorParameters: function () { return [{ type: i1.ThyPopover }, { type: i2.Overlay }]; } });
85
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL3RhYmxlL3Rvb2xiYXItaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUMvRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQzs7Ozs7OztBQXNCL0YsTUFBTSxPQUFPLDRCQUE2QixTQUFRLGtCQUFrQjtJQU9oRSxZQUFvQixVQUFzQixFQUFVLE9BQWdCO1FBQ2hFLEtBQUssRUFBRSxDQUFDO1FBRFEsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUFVLFlBQU8sR0FBUCxPQUFPLENBQVM7SUFFcEUsQ0FBQztJQU5ELElBQUksaUJBQWlCO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLGlCQUFpQixDQUFDO0lBQ3hFLENBQUM7SUFNRCxPQUFPLENBQUMsS0FBaUI7O1FBQ3JCLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFckIsSUFBSSxNQUFBLElBQUksQ0FBQyxNQUFNLDBDQUFFLFFBQVEsRUFBRTtZQUN2QixPQUFPO1NBQ1Y7UUFDRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQWlCLEVBQUUsWUFBMkI7UUFDNUQsSUFBSSxJQUFJLENBQUMsaUJBQWlCLEVBQUU7WUFDeEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUM1QixPQUFPO1NBQ1Y7UUFDRCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLHVCQUF1QixFQUFFO1lBQ2hFLE1BQU0sRUFBRSxLQUFLLENBQUMsYUFBNEI7WUFDMUMsWUFBWSxFQUFFO2dCQUNWLE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTTtnQkFDbkIsWUFBWTthQUNmO1lBQ0QsZ0JBQWdCLEVBQUUsS0FBSztZQUN2QixXQUFXLEVBQUUsS0FBSztZQUNsQixjQUFjLEVBQUUsS0FBSztZQUNyQixTQUFTLEVBQUUsWUFBWTtZQUN2QixNQUFNLEVBQUUsRUFBRTtZQUNWLFVBQVUsRUFBRSwyQkFBMkI7WUFDdkMsY0FBYyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxFQUFFO1NBQzdELENBQUMsQ0FBQztRQUNILE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUMvQixDQUFDOzswSEF4Q1EsNEJBQTRCOzhHQUE1Qiw0QkFBNEIsaUpBakIzQjs7Ozs7Ozs7Ozs7O0tBWVQ7NEZBS1EsNEJBQTRCO2tCQW5CeEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsd0JBQXdCO29CQUNsQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7OztLQVlUO29CQUNELElBQUksRUFBRTt3QkFDRixLQUFLLEVBQUUsZ0NBQWdDO3FCQUMxQztpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXkgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoeVBvcG92ZXIsIFRoeVBvcG92ZXJSZWYgfSBmcm9tICduZ3gtdGV0aHlzJztcbmltcG9ydCB7IFRoZUJhc2VUb29sYmFySXRlbSB9IGZyb20gJy4uLy4uL2NvcmUvdG9vbGJhci1pdGVtL2Jhc2UtdG9vbGJhci1pdGVtJztcbmltcG9ydCB7IFRoZVRhYmxlU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy90YWJsZS1zZWxlY3QvdGFibGUtc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUYWJsZU9wdGlvbnMgfSBmcm9tICcuL3RhYmxlLnR5cGVzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd0aGUtdGFibGUtdG9vbGJhci1pdGVtJyxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8YVxuICAgICAgICAgICAgdGh5SWNvbk5hdkxpbmtcbiAgICAgICAgICAgIGNsYXNzPVwibGluay13aXRoLWRvd25cIlxuICAgICAgICAgICAgW3RoeVRvb2x0aXBdPVwidG9vbGJhckl0ZW0/Lm5hbWVcIlxuICAgICAgICAgICAgdGh5VG9vbHRpcFBsYWNlbWVudD1cInRvcFwiXG4gICAgICAgICAgICBbdGh5SWNvbk5hdkxpbmtBY3RpdmVdPVwiYWN0aXZlXCJcbiAgICAgICAgICAgIChtb3VzZWRvd24pPVwiZXhlY3V0ZSgkZXZlbnQpXCJcbiAgICAgICAgPlxuICAgICAgICAgICAgPHRoeS1pY29uIFt0aHlJY29uTmFtZV09XCJ0b29sYmFySXRlbS5pY29uXCI+PC90aHktaWNvbj5cbiAgICAgICAgICAgIDx0aHktaWNvbiBjbGFzcz1cImxpbmstZG93bi1pY29uIGZvbnQtc2l6ZS1zbSB0ZXh0LWRlc2MgdGFibGUtZG93bi1pY29uXCIgdGh5SWNvbk5hbWU9XCJjYXJldC1kb3duXCI+IDwvdGh5LWljb24+XG4gICAgICAgIDwvYT5cbiAgICBgLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgY2xhc3M6ICd0aGUtdG9vbGJhci1kcm9wZG93bi1jb250YWluZXInXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBUaGVUYWJsZVRvb2xiYXJJdGVtQ29tcG9uZW50IGV4dGVuZHMgVGhlQmFzZVRvb2xiYXJJdGVtIHtcbiAgICB0YWJsZVNlbGVjdFJlZjogVGh5UG9wb3ZlclJlZjxUaGVUYWJsZVNlbGVjdENvbXBvbmVudD47XG5cbiAgICBnZXQgaXNPcGVuVGFibGVTZWxlY3QoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnRhYmxlU2VsZWN0UmVmICYmIHRoaXMudGFibGVTZWxlY3RSZWYuY29tcG9uZW50SW5zdGFuY2U7XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSB0aHlQb3BvdmVyOiBUaHlQb3BvdmVyLCBwcml2YXRlIG92ZXJsYXk6IE92ZXJsYXkpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBleGVjdXRlKGV2ZW50OiBNb3VzZUV2ZW50KSB7XG4gICAgICAgIHN1cGVyLmV4ZWN1dGUoZXZlbnQpO1xuXG4gICAgICAgIGlmICh0aGlzLmVkaXRvcj8uZGlzYWJsZWQpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnRvZ2dsZVRhYmxlU2VsZWN0KGV2ZW50KTtcbiAgICB9XG5cbiAgICB0b2dnbGVUYWJsZVNlbGVjdChldmVudDogTW91c2VFdmVudCwgb3B0aW9uc1BhcmFtPzogVGFibGVPcHRpb25zKSB7XG4gICAgICAgIGlmICh0aGlzLmlzT3BlblRhYmxlU2VsZWN0KSB7XG4gICAgICAgICAgICB0aGlzLnRhYmxlU2VsZWN0UmVmLmNsb3NlKCk7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy50YWJsZVNlbGVjdFJlZiA9IHRoaXMudGh5UG9wb3Zlci5vcGVuKFRoZVRhYmxlU2VsZWN0Q29tcG9uZW50LCB7XG4gICAgICAgICAgICBvcmlnaW46IGV2ZW50LmN1cnJlbnRUYXJnZXQgYXMgSFRNTEVsZW1lbnQsXG4gICAgICAgICAgICBpbml0aWFsU3RhdGU6IHtcbiAgICAgICAgICAgICAgICBlZGl0b3I6IHRoaXMuZWRpdG9yLFxuICAgICAgICAgICAgICAgIG9wdGlvbnNQYXJhbVxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIGJhY2tkcm9wQ2xvc2FibGU6IGZhbHNlLFxuICAgICAgICAgICAgaGFzQmFja2Ryb3A6IGZhbHNlLFxuICAgICAgICAgICAgaW5zaWRlQ2xvc2FibGU6IGZhbHNlLFxuICAgICAgICAgICAgcGxhY2VtZW50OiAnYm90dG9tTGVmdCcsXG4gICAgICAgICAgICBvZmZzZXQ6IDEwLFxuICAgICAgICAgICAgcGFuZWxDbGFzczogJ3RoZS10YWJsZS1zZWxlY3Rvci1wYW5uZWwnLFxuICAgICAgICAgICAgc2Nyb2xsU3RyYXRlZ3k6IHRoaXMub3ZlcmxheS5zY3JvbGxTdHJhdGVnaWVzLnJlcG9zaXRpb24oKVxuICAgICAgICB9KTtcbiAgICAgICAgcmV0dXJuIHRoaXMudGFibGVTZWxlY3RSZWY7XG4gICAgfVxufVxuIl19
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL3RhYmxlL3Rvb2xiYXItaXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUMvRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQzs7Ozs7OztBQXNCL0YsTUFBTSxPQUFPLDRCQUE2QixTQUFRLGtCQUFrQjtJQU9oRSxZQUFvQixVQUFzQixFQUFVLE9BQWdCO1FBQ2hFLEtBQUssRUFBRSxDQUFDO1FBRFEsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUFVLFlBQU8sR0FBUCxPQUFPLENBQVM7SUFFcEUsQ0FBQztJQU5ELElBQUksaUJBQWlCO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLGlCQUFpQixDQUFDO0lBQ3hFLENBQUM7SUFNRCxPQUFPLENBQUMsS0FBaUI7O1FBQ3JCLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFckIsSUFBSSxNQUFBLElBQUksQ0FBQyxNQUFNLDBDQUFFLFFBQVEsRUFBRTtZQUN2QixPQUFPO1NBQ1Y7UUFDRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQWlCLEVBQUUsWUFBMkI7UUFDNUQsSUFBSSxJQUFJLENBQUMsaUJBQWlCLEVBQUU7WUFDeEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUM1QixPQUFPO1NBQ1Y7UUFDRCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLHVCQUF1QixFQUFFO1lBQ2hFLE1BQU0sRUFBRSxLQUFLLENBQUMsYUFBNEI7WUFDMUMsWUFBWSxFQUFFO2dCQUNWLE1BQU0sRUFBRSxJQUFJLENBQUMsTUFBTTtnQkFDbkIsWUFBWTthQUNmO1lBQ0QsUUFBUSxFQUFFLENBQUM7WUFDWCxnQkFBZ0IsRUFBRSxLQUFLO1lBQ3ZCLFdBQVcsRUFBRSxLQUFLO1lBQ2xCLGNBQWMsRUFBRSxLQUFLO1lBQ3JCLFNBQVMsRUFBRSxZQUFZO1lBQ3ZCLE1BQU0sRUFBRSxFQUFFO1lBQ1YsVUFBVSxFQUFFLDJCQUEyQjtZQUN2QyxjQUFjLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxVQUFVLEVBQUU7U0FDN0QsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQy9CLENBQUM7OzBIQXpDUSw0QkFBNEI7OEdBQTVCLDRCQUE0QixpSkFqQjNCOzs7Ozs7Ozs7Ozs7S0FZVDs0RkFLUSw0QkFBNEI7a0JBbkJ4QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7O0tBWVQ7b0JBQ0QsSUFBSSxFQUFFO3dCQUNGLEtBQUssRUFBRSxnQ0FBZ0M7cUJBQzFDO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGh5UG9wb3ZlciwgVGh5UG9wb3ZlclJlZiB9IGZyb20gJ25neC10ZXRoeXMnO1xuaW1wb3J0IHsgVGhlQmFzZVRvb2xiYXJJdGVtIH0gZnJvbSAnLi4vLi4vY29yZS90b29sYmFyLWl0ZW0vYmFzZS10b29sYmFyLWl0ZW0nO1xuaW1wb3J0IHsgVGhlVGFibGVTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL3RhYmxlLXNlbGVjdC90YWJsZS1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IFRhYmxlT3B0aW9ucyB9IGZyb20gJy4vdGFibGUudHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RoZS10YWJsZS10b29sYmFyLWl0ZW0nLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxhXG4gICAgICAgICAgICB0aHlJY29uTmF2TGlua1xuICAgICAgICAgICAgY2xhc3M9XCJsaW5rLXdpdGgtZG93blwiXG4gICAgICAgICAgICBbdGh5VG9vbHRpcF09XCJ0b29sYmFySXRlbT8ubmFtZVwiXG4gICAgICAgICAgICB0aHlUb29sdGlwUGxhY2VtZW50PVwidG9wXCJcbiAgICAgICAgICAgIFt0aHlJY29uTmF2TGlua0FjdGl2ZV09XCJhY3RpdmVcIlxuICAgICAgICAgICAgKG1vdXNlZG93bik9XCJleGVjdXRlKCRldmVudClcIlxuICAgICAgICA+XG4gICAgICAgICAgICA8dGh5LWljb24gW3RoeUljb25OYW1lXT1cInRvb2xiYXJJdGVtLmljb25cIj48L3RoeS1pY29uPlxuICAgICAgICAgICAgPHRoeS1pY29uIGNsYXNzPVwibGluay1kb3duLWljb24gZm9udC1zaXplLXNtIHRleHQtZGVzYyB0YWJsZS1kb3duLWljb25cIiB0aHlJY29uTmFtZT1cImNhcmV0LWRvd25cIj4gPC90aHktaWNvbj5cbiAgICAgICAgPC9hPlxuICAgIGAsXG4gICAgaG9zdDoge1xuICAgICAgICBjbGFzczogJ3RoZS10b29sYmFyLWRyb3Bkb3duLWNvbnRhaW5lcidcbiAgICB9XG59KVxuZXhwb3J0IGNsYXNzIFRoZVRhYmxlVG9vbGJhckl0ZW1Db21wb25lbnQgZXh0ZW5kcyBUaGVCYXNlVG9vbGJhckl0ZW0ge1xuICAgIHRhYmxlU2VsZWN0UmVmOiBUaHlQb3BvdmVyUmVmPFRoZVRhYmxlU2VsZWN0Q29tcG9uZW50PjtcblxuICAgIGdldCBpc09wZW5UYWJsZVNlbGVjdCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMudGFibGVTZWxlY3RSZWYgJiYgdGhpcy50YWJsZVNlbGVjdFJlZi5jb21wb25lbnRJbnN0YW5jZTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRoeVBvcG92ZXI6IFRoeVBvcG92ZXIsIHByaXZhdGUgb3ZlcmxheTogT3ZlcmxheSkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIGV4ZWN1dGUoZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICAgICAgc3VwZXIuZXhlY3V0ZShldmVudCk7XG5cbiAgICAgICAgaWYgKHRoaXMuZWRpdG9yPy5kaXNhYmxlZCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMudG9nZ2xlVGFibGVTZWxlY3QoZXZlbnQpO1xuICAgIH1cblxuICAgIHRvZ2dsZVRhYmxlU2VsZWN0KGV2ZW50OiBNb3VzZUV2ZW50LCBvcHRpb25zUGFyYW0/OiBUYWJsZU9wdGlvbnMpIHtcbiAgICAgICAgaWYgKHRoaXMuaXNPcGVuVGFibGVTZWxlY3QpIHtcbiAgICAgICAgICAgIHRoaXMudGFibGVTZWxlY3RSZWYuY2xvc2UoKTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnRhYmxlU2VsZWN0UmVmID0gdGhpcy50aHlQb3BvdmVyLm9wZW4oVGhlVGFibGVTZWxlY3RDb21wb25lbnQsIHtcbiAgICAgICAgICAgIG9yaWdpbjogZXZlbnQuY3VycmVudFRhcmdldCBhcyBIVE1MRWxlbWVudCxcbiAgICAgICAgICAgIGluaXRpYWxTdGF0ZToge1xuICAgICAgICAgICAgICAgIGVkaXRvcjogdGhpcy5lZGl0b3IsXG4gICAgICAgICAgICAgICAgb3B0aW9uc1BhcmFtXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgbWluV2lkdGg6IDAsXG4gICAgICAgICAgICBiYWNrZHJvcENsb3NhYmxlOiBmYWxzZSxcbiAgICAgICAgICAgIGhhc0JhY2tkcm9wOiBmYWxzZSxcbiAgICAgICAgICAgIGluc2lkZUNsb3NhYmxlOiBmYWxzZSxcbiAgICAgICAgICAgIHBsYWNlbWVudDogJ2JvdHRvbUxlZnQnLFxuICAgICAgICAgICAgb2Zmc2V0OiAxMCxcbiAgICAgICAgICAgIHBhbmVsQ2xhc3M6ICd0aGUtdGFibGUtc2VsZWN0b3ItcGFubmVsJyxcbiAgICAgICAgICAgIHNjcm9sbFN0cmF0ZWd5OiB0aGlzLm92ZXJsYXkuc2Nyb2xsU3RyYXRlZ2llcy5yZXBvc2l0aW9uKClcbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiB0aGlzLnRhYmxlU2VsZWN0UmVmO1xuICAgIH1cbn1cbiJdfQ==
@@ -55,6 +55,7 @@ export class TheVerticalToolbarItemComponent extends TheBaseToolbarDropdown {
55
55
  panelClass: ['the-toolbar-dropdown-popover', (_a = this.toolbarItem) === null || _a === void 0 ? void 0 : _a.key],
56
56
  placement: 'bottomLeft',
57
57
  offset: 10,
58
+ minWidth: 0,
58
59
  viewContainerRef: this.viewContainerRef,
59
60
  insideClosable: false,
60
61
  backdropClosable: false,
@@ -86,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
86
87
  type: HostListener,
87
88
  args: ['document: mousedown', ['$event']]
88
89
  }] } });
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-item.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/vertical-align/toolbar-item.component.ts","../../../../../packages/src/plugins/vertical-align/toolbar-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostListener, OnInit, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys';\nimport { Editor } from 'slate';\nimport { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';\nimport { ToolbarItem } from '../../interfaces';\n\n@Component({\n    selector: 'the-toolbar-vertical-align-item',\n    templateUrl: './toolbar-item.component.html',\n    host: {\n        class: 'the-toolbar-dropdown-container verticalAlign',\n        '[class.hide]': '!active'\n    }\n})\nexport class TheVerticalToolbarItemComponent extends TheBaseToolbarDropdown implements OnInit {\n    isHide = true;\n    dropdownPopoverRef: ThyPopoverRef<any>;\n\n    @ViewChild('VerticalAlignItems', { read: TemplateRef, static: true })\n    template: TemplateRef<any>;\n\n    get isOpened() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement)) {\n            this.close();\n        }\n    }\n\n    constructor(public elementRef: ElementRef, private thyPopover: ThyPopover, private viewContainerRef: ViewContainerRef) {\n        super();\n    }\n\n    ngOnInit(): void {}\n\n    menusActive(editor: Editor) {\n        return this.menus.find(i => {\n            if (this.editor?.selection && i?.active) {\n                return i?.active(editor);\n            }\n        });\n    }\n\n    execute(event: MouseEvent) {\n        super.execute(event);\n        if (this.editor?.readOnly || this.editor?.disabled) {\n            return;\n        }\n        this.openPopover();\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        this.close();\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    openPopover() {\n        this.dropdownPopoverRef = this.thyPopover.open(this.template, {\n            origin: this.elementRef,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            placement: 'bottomLeft',\n            offset: 10,\n            viewContainerRef: this.viewContainerRef,\n            insideClosable: false,\n            backdropClosable: false,\n            hasBackdrop: false\n        });\n    }\n\n    close() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef.close();\n        }\n    }\n}\n","<a\n    thyIconNavLink\n    class=\"icon-mode link-with-down\"\n    [thyTooltip]=\"toolbarItem?.name\"\n    [thyIconNavLinkActive]=\"isOpened\"\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"execute($event)\"\n>\n    <thy-icon [thyIconName]=\"activeMenuItem?.icon\"></thy-icon>\n    <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #VerticalAlignItems>\n    <thy-action-menu class=\"dropdown\">\n        <ng-container *ngFor=\"let menu of toolbarItem?.includes\">\n            <a\n                thyActionMenuItem\n                href=\"javascript:;\"\n                [thyActionMenuItemActive]=\"menu.key === activeMenuItem?.key\"\n                (mousedown)=\"itemMousedown($event, menu)\"\n            >\n                <span *ngIf=\"menu.icon\" thyActionMenuItemIcon>\n                    <thy-icon [thyIconName]=\"menu?.icon\"></thy-icon>\n                </span>\n                <span thyActionMenuItemName>{{ menu.name }}</span>\n            </a>\n        </ng-container>\n    </thy-action-menu>\n</ng-template>\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-item.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/vertical-align/toolbar-item.component.ts","../../../../../packages/src/plugins/vertical-align/toolbar-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostListener, OnInit, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys';\nimport { Editor } from 'slate';\nimport { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';\nimport { ToolbarItem } from '../../interfaces';\n\n@Component({\n    selector: 'the-toolbar-vertical-align-item',\n    templateUrl: './toolbar-item.component.html',\n    host: {\n        class: 'the-toolbar-dropdown-container verticalAlign',\n        '[class.hide]': '!active'\n    }\n})\nexport class TheVerticalToolbarItemComponent extends TheBaseToolbarDropdown implements OnInit {\n    isHide = true;\n    dropdownPopoverRef: ThyPopoverRef<any>;\n\n    @ViewChild('VerticalAlignItems', { read: TemplateRef, static: true })\n    template: TemplateRef<any>;\n\n    get isOpened() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement)) {\n            this.close();\n        }\n    }\n\n    constructor(public elementRef: ElementRef, private thyPopover: ThyPopover, private viewContainerRef: ViewContainerRef) {\n        super();\n    }\n\n    ngOnInit(): void {}\n\n    menusActive(editor: Editor) {\n        return this.menus.find(i => {\n            if (this.editor?.selection && i?.active) {\n                return i?.active(editor);\n            }\n        });\n    }\n\n    execute(event: MouseEvent) {\n        super.execute(event);\n        if (this.editor?.readOnly || this.editor?.disabled) {\n            return;\n        }\n        this.openPopover();\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        this.close();\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    openPopover() {\n        this.dropdownPopoverRef = this.thyPopover.open(this.template, {\n            origin: this.elementRef,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            placement: 'bottomLeft',\n            offset: 10,\n            minWidth: 0,\n            viewContainerRef: this.viewContainerRef,\n            insideClosable: false,\n            backdropClosable: false,\n            hasBackdrop: false\n        });\n    }\n\n    close() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef.close();\n        }\n    }\n}\n","<a\n    thyIconNavLink\n    class=\"icon-mode link-with-down\"\n    [thyTooltip]=\"toolbarItem?.name\"\n    [thyIconNavLinkActive]=\"isOpened\"\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"execute($event)\"\n>\n    <thy-icon [thyIconName]=\"activeMenuItem?.icon\"></thy-icon>\n    <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #VerticalAlignItems>\n    <thy-action-menu class=\"dropdown\">\n        <ng-container *ngFor=\"let menu of toolbarItem?.includes\">\n            <a\n                thyActionMenuItem\n                href=\"javascript:;\"\n                [thyActionMenuItemActive]=\"menu.key === activeMenuItem?.key\"\n                (mousedown)=\"itemMousedown($event, menu)\"\n            >\n                <span *ngIf=\"menu.icon\" thyActionMenuItemIcon>\n                    <thy-icon [thyIconName]=\"menu?.icon\"></thy-icon>\n                </span>\n                <span thyActionMenuItemName>{{ menu.name }}</span>\n            </a>\n        </ng-container>\n    </thy-action-menu>\n</ng-template>\n"]}
@@ -26,6 +26,7 @@ export class TheColorSelectService {
26
26
  option
27
27
  },
28
28
  origin,
29
+ minWidth: 0,
29
30
  backdropClosable: this.backdropClosable,
30
31
  placement: placement || this.placement,
31
32
  offset: offset !== null ? offset : this.offset,
@@ -46,4 +47,4 @@ TheColorSelectService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0"
46
47
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheColorSelectService, decorators: [{
47
48
  type: Injectable
48
49
  }], ctorParameters: function () { return [{ type: i1.ThyPopover }]; } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3Itc2VsZWN0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvc2VydmljZXMvY29sb3Itc2VsZWN0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUczQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBSTVGLE1BQU0sT0FBTyxxQkFBcUI7SUFpQjlCLFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7UUFoQjFDLHFCQUFnQixHQUFHLEtBQUssQ0FBQztRQUV6QixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUVwQixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUV2QixjQUFTLEdBQWlCLFlBQVksQ0FBQztRQUV2QyxXQUFNLEdBQUcsRUFBRSxDQUFDO0lBUWlDLENBQUM7SUFKOUMsSUFBSSxpQkFBaUI7UUFDakIsT0FBTyxJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsaUJBQWlCLENBQUM7SUFDeEUsQ0FBQztJQUlELGlCQUFpQixDQUNiLE1BQW1CLEVBQ25CLGFBQXdCLEVBQ3hCLE1BQWdCLEVBQ2hCLE1BQXlCLEVBQ3pCLFlBQXdDLEVBQ3hDLFNBQXdCLEVBQ3hCLE1BQWU7UUFFZixJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUN4QixJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQy9CO1FBQ0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyx1QkFBdUIsRUFBRTtZQUNoRSxZQUFZLEVBQUU7Z0JBQ1YsYUFBYTtnQkFDYixZQUFZO2dCQUNaLE1BQU07Z0JBQ04sTUFBTTthQUNUO1lBQ0QsTUFBTTtZQUNOLGdCQUFnQixFQUFFLElBQUksQ0FBQyxnQkFBZ0I7WUFDdkMsU0FBUyxFQUFFLFNBQVMsSUFBSSxJQUFJLENBQUMsU0FBUztZQUN0QyxNQUFNLEVBQUUsTUFBTSxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTTtZQUM5QyxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDN0IsY0FBYyxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQ25DLFVBQVUsRUFBRSx3QkFBd0I7U0FDdkMsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQy9CLENBQUM7SUFFRCxnQkFBZ0I7UUFDWixJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUN4QixJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQy9CO0lBQ0wsQ0FBQzs7bUhBckRRLHFCQUFxQjt1SEFBckIscUJBQXFCOzRGQUFyQixxQkFBcUI7a0JBRGpDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlQbGFjZW1lbnQgfSBmcm9tICduZ3gtdGV0aHlzL2NvcmUnO1xuaW1wb3J0IHsgVGh5UG9wb3ZlciwgVGh5UG9wb3ZlclJlZiB9IGZyb20gJ25neC10ZXRoeXMvcG9wb3Zlcic7XG5pbXBvcnQgeyBUaGVDb2xvclNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvY29sb3Itc2VsZWN0L2NvbG9yLXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29sb3JUeXBlLCBDb2xvclNlbGVjdE9wdGlvbiB9IGZyb20gJy4uL2NvbnN0YW50cy9jb2xvci1zZWxlY3QnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgVGhlQ29sb3JTZWxlY3RTZXJ2aWNlIHtcbiAgICBiYWNrZHJvcENsb3NhYmxlID0gZmFsc2U7XG5cbiAgICBoYXNCYWNrZHJvcCA9IGZhbHNlO1xuXG4gICAgaW5zaWRlQ2xvc2FibGUgPSBmYWxzZTtcblxuICAgIHBsYWNlbWVudDogVGh5UGxhY2VtZW50ID0gJ2JvdHRvbUxlZnQnO1xuXG4gICAgb2Zmc2V0ID0gMTA7XG5cbiAgICBjb2xvclNlbGVjdFJlZjogVGh5UG9wb3ZlclJlZjxUaGVDb2xvclNlbGVjdENvbXBvbmVudD47XG5cbiAgICBnZXQgaXNPcGVuQ29sb3JTZWxlY3QoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbG9yU2VsZWN0UmVmICYmIHRoaXMuY29sb3JTZWxlY3RSZWYuY29tcG9uZW50SW5zdGFuY2U7XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSB0aHlQb3BvdmVyOiBUaHlQb3BvdmVyKSB7fVxuXG4gICAgdG9nZ2xlQ29sb3JTZWxlY3QoXG4gICAgICAgIG9yaWdpbjogSFRNTEVsZW1lbnQsXG4gICAgICAgIHNlbGVjdGVkQ29sb3I6IENvbG9yVHlwZSxcbiAgICAgICAgY29sb3JzOiBzdHJpbmdbXSxcbiAgICAgICAgb3B0aW9uOiBDb2xvclNlbGVjdE9wdGlvbixcbiAgICAgICAgc2VsZWN0QWN0aW9uOiAoY29sb3I6IENvbG9yVHlwZSkgPT4gdm9pZCxcbiAgICAgICAgcGxhY2VtZW50PzogVGh5UGxhY2VtZW50LFxuICAgICAgICBvZmZzZXQ/OiBudW1iZXJcbiAgICApIHtcbiAgICAgICAgaWYgKHRoaXMuaXNPcGVuQ29sb3JTZWxlY3QpIHtcbiAgICAgICAgICAgIHRoaXMuY29sb3JTZWxlY3RSZWYuY2xvc2UoKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmNvbG9yU2VsZWN0UmVmID0gdGhpcy50aHlQb3BvdmVyLm9wZW4oVGhlQ29sb3JTZWxlY3RDb21wb25lbnQsIHtcbiAgICAgICAgICAgIGluaXRpYWxTdGF0ZToge1xuICAgICAgICAgICAgICAgIHNlbGVjdGVkQ29sb3IsXG4gICAgICAgICAgICAgICAgc2VsZWN0QWN0aW9uLFxuICAgICAgICAgICAgICAgIGNvbG9ycyxcbiAgICAgICAgICAgICAgICBvcHRpb25cbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBvcmlnaW4sXG4gICAgICAgICAgICBiYWNrZHJvcENsb3NhYmxlOiB0aGlzLmJhY2tkcm9wQ2xvc2FibGUsXG4gICAgICAgICAgICBwbGFjZW1lbnQ6IHBsYWNlbWVudCB8fCB0aGlzLnBsYWNlbWVudCxcbiAgICAgICAgICAgIG9mZnNldDogb2Zmc2V0ICE9PSBudWxsID8gb2Zmc2V0IDogdGhpcy5vZmZzZXQsXG4gICAgICAgICAgICBoYXNCYWNrZHJvcDogdGhpcy5oYXNCYWNrZHJvcCxcbiAgICAgICAgICAgIGluc2lkZUNsb3NhYmxlOiB0aGlzLmluc2lkZUNsb3NhYmxlLFxuICAgICAgICAgICAgcGFuZWxDbGFzczogJ2NvbG9yLXNlbGVjdC1jb250YWluZXInXG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gdGhpcy5jb2xvclNlbGVjdFJlZjtcbiAgICB9XG5cbiAgICBjbG9zZUNvbG9yU2VsZWN0KCkge1xuICAgICAgICBpZiAodGhpcy5pc09wZW5Db2xvclNlbGVjdCkge1xuICAgICAgICAgICAgdGhpcy5jb2xvclNlbGVjdFJlZi5jbG9zZSgpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3Itc2VsZWN0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvc2VydmljZXMvY29sb3Itc2VsZWN0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUczQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBSTVGLE1BQU0sT0FBTyxxQkFBcUI7SUFpQjlCLFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7UUFoQjFDLHFCQUFnQixHQUFHLEtBQUssQ0FBQztRQUV6QixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUVwQixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUV2QixjQUFTLEdBQWlCLFlBQVksQ0FBQztRQUV2QyxXQUFNLEdBQUcsRUFBRSxDQUFDO0lBUWlDLENBQUM7SUFKOUMsSUFBSSxpQkFBaUI7UUFDakIsT0FBTyxJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsaUJBQWlCLENBQUM7SUFDeEUsQ0FBQztJQUlELGlCQUFpQixDQUNiLE1BQW1CLEVBQ25CLGFBQXdCLEVBQ3hCLE1BQWdCLEVBQ2hCLE1BQXlCLEVBQ3pCLFlBQXdDLEVBQ3hDLFNBQXdCLEVBQ3hCLE1BQWU7UUFFZixJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUN4QixJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQy9CO1FBQ0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyx1QkFBdUIsRUFBRTtZQUNoRSxZQUFZLEVBQUU7Z0JBQ1YsYUFBYTtnQkFDYixZQUFZO2dCQUNaLE1BQU07Z0JBQ04sTUFBTTthQUNUO1lBQ0QsTUFBTTtZQUNOLFFBQVEsRUFBRSxDQUFDO1lBQ1gsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLGdCQUFnQjtZQUN2QyxTQUFTLEVBQUUsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTO1lBQ3RDLE1BQU0sRUFBRSxNQUFNLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNO1lBQzlDLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVztZQUM3QixjQUFjLEVBQUUsSUFBSSxDQUFDLGNBQWM7WUFDbkMsVUFBVSxFQUFFLHdCQUF3QjtTQUN2QyxDQUFDLENBQUM7UUFDSCxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDL0IsQ0FBQztJQUVELGdCQUFnQjtRQUNaLElBQUksSUFBSSxDQUFDLGlCQUFpQixFQUFFO1lBQ3hCLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDL0I7SUFDTCxDQUFDOzttSEF0RFEscUJBQXFCO3VIQUFyQixxQkFBcUI7NEZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoeVBsYWNlbWVudCB9IGZyb20gJ25neC10ZXRoeXMvY29yZSc7XG5pbXBvcnQgeyBUaHlQb3BvdmVyLCBUaHlQb3BvdmVyUmVmIH0gZnJvbSAnbmd4LXRldGh5cy9wb3BvdmVyJztcbmltcG9ydCB7IFRoZUNvbG9yU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cy9jb2xvci1zZWxlY3QvY29sb3Itc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb2xvclR5cGUsIENvbG9yU2VsZWN0T3B0aW9uIH0gZnJvbSAnLi4vY29uc3RhbnRzL2NvbG9yLXNlbGVjdCc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUaGVDb2xvclNlbGVjdFNlcnZpY2Uge1xuICAgIGJhY2tkcm9wQ2xvc2FibGUgPSBmYWxzZTtcblxuICAgIGhhc0JhY2tkcm9wID0gZmFsc2U7XG5cbiAgICBpbnNpZGVDbG9zYWJsZSA9IGZhbHNlO1xuXG4gICAgcGxhY2VtZW50OiBUaHlQbGFjZW1lbnQgPSAnYm90dG9tTGVmdCc7XG5cbiAgICBvZmZzZXQgPSAxMDtcblxuICAgIGNvbG9yU2VsZWN0UmVmOiBUaHlQb3BvdmVyUmVmPFRoZUNvbG9yU2VsZWN0Q29tcG9uZW50PjtcblxuICAgIGdldCBpc09wZW5Db2xvclNlbGVjdCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29sb3JTZWxlY3RSZWYgJiYgdGhpcy5jb2xvclNlbGVjdFJlZi5jb21wb25lbnRJbnN0YW5jZTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRoeVBvcG92ZXI6IFRoeVBvcG92ZXIpIHt9XG5cbiAgICB0b2dnbGVDb2xvclNlbGVjdChcbiAgICAgICAgb3JpZ2luOiBIVE1MRWxlbWVudCxcbiAgICAgICAgc2VsZWN0ZWRDb2xvcjogQ29sb3JUeXBlLFxuICAgICAgICBjb2xvcnM6IHN0cmluZ1tdLFxuICAgICAgICBvcHRpb246IENvbG9yU2VsZWN0T3B0aW9uLFxuICAgICAgICBzZWxlY3RBY3Rpb246IChjb2xvcjogQ29sb3JUeXBlKSA9PiB2b2lkLFxuICAgICAgICBwbGFjZW1lbnQ/OiBUaHlQbGFjZW1lbnQsXG4gICAgICAgIG9mZnNldD86IG51bWJlclxuICAgICkge1xuICAgICAgICBpZiAodGhpcy5pc09wZW5Db2xvclNlbGVjdCkge1xuICAgICAgICAgICAgdGhpcy5jb2xvclNlbGVjdFJlZi5jbG9zZSgpO1xuICAgICAgICB9XG4gICAgICAgIHRoaXMuY29sb3JTZWxlY3RSZWYgPSB0aGlzLnRoeVBvcG92ZXIub3BlbihUaGVDb2xvclNlbGVjdENvbXBvbmVudCwge1xuICAgICAgICAgICAgaW5pdGlhbFN0YXRlOiB7XG4gICAgICAgICAgICAgICAgc2VsZWN0ZWRDb2xvcixcbiAgICAgICAgICAgICAgICBzZWxlY3RBY3Rpb24sXG4gICAgICAgICAgICAgICAgY29sb3JzLFxuICAgICAgICAgICAgICAgIG9wdGlvblxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIG9yaWdpbixcbiAgICAgICAgICAgIG1pbldpZHRoOiAwLFxuICAgICAgICAgICAgYmFja2Ryb3BDbG9zYWJsZTogdGhpcy5iYWNrZHJvcENsb3NhYmxlLFxuICAgICAgICAgICAgcGxhY2VtZW50OiBwbGFjZW1lbnQgfHwgdGhpcy5wbGFjZW1lbnQsXG4gICAgICAgICAgICBvZmZzZXQ6IG9mZnNldCAhPT0gbnVsbCA/IG9mZnNldCA6IHRoaXMub2Zmc2V0LFxuICAgICAgICAgICAgaGFzQmFja2Ryb3A6IHRoaXMuaGFzQmFja2Ryb3AsXG4gICAgICAgICAgICBpbnNpZGVDbG9zYWJsZTogdGhpcy5pbnNpZGVDbG9zYWJsZSxcbiAgICAgICAgICAgIHBhbmVsQ2xhc3M6ICdjb2xvci1zZWxlY3QtY29udGFpbmVyJ1xuICAgICAgICB9KTtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29sb3JTZWxlY3RSZWY7XG4gICAgfVxuXG4gICAgY2xvc2VDb2xvclNlbGVjdCgpIHtcbiAgICAgICAgaWYgKHRoaXMuaXNPcGVuQ29sb3JTZWxlY3QpIHtcbiAgICAgICAgICAgIHRoaXMuY29sb3JTZWxlY3RSZWYuY2xvc2UoKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
@@ -163,6 +163,7 @@ export class TheTableContextMenuService {
163
163
  y: event.y
164
164
  },
165
165
  hasBackdrop: false,
166
+ minWidth: 0,
166
167
  placement: 'bottomLeft',
167
168
  viewContainerRef: this.theContextService.getOptions().viewContainerRef,
168
169
  manualClosure: true,
@@ -186,4 +187,4 @@ TheTableContextMenuService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12
186
187
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableContextMenuService, decorators: [{
187
188
  type: Injectable
188
189
  }], ctorParameters: function () { return [{ type: i1.TheColorSelectService }, { type: i2.TableStore }, { type: i3.ThyPopover }, { type: i0.NgZone }, { type: i4.TheContextService }]; } });
189
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-contextmenu.service.js","sourceRoot":"","sources":["../../../../packages/src/services/table-contextmenu.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { BackgroundColors, ColorType, SpecialBackgroundColor, TableHeaderBackgroundColor } from '../constants/color-select';\nimport { TableStore } from '../plugins/table/table.store';\nimport { TheColorSelectService } from './color-select.service';\nimport { TableEditor } from '../plugins/table/table.editor';\nimport { ThyPopoverRef, ThyPopover } from 'ngx-tethys/popover';\nimport { TheContextMenuComponent } from '../components/contextmenu/contextmenu.component';\nimport { TheContextService } from './context.service';\nimport { splitCell } from '../plugins/table/utils/split-cell';\nimport { setCellMenuInvisibility } from '../plugins/table/utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../plugins/table/table.types';\n\n@Injectable()\nexport class TheTableContextMenuService {\n    menuRef: ThyPopoverRef<TheContextMenuComponent>;\n\n    get isOpened() {\n        return this.menuRef && this.menuRef.componentInstance;\n    }\n\n    get editor() {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    get backgroundColor() {\n        return this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    constructor(\n        private colorSelectService: TheColorSelectService,\n        private tableStore: TableStore,\n        private thyPopover: ThyPopover,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    menuEntities: MenuEntity[] = [\n        {\n            key: 'background-color',\n            icon: 'background-tt',\n            divider: true,\n            name: '单元格背景',\n            extendIcon: 'angle-right',\n            actionHandle: () => {},\n            activeHandle: (event: MouseEvent) => {\n                if (this.colorSelectService.isOpenColorSelect) {\n                    return;\n                }\n                const isHeader = TableEditor.isActiveHeader(this.editor);\n                this.colorSelectService.toggleColorSelect(\n                    event.target as HTMLElement,\n                    this.backgroundColor,\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.tableStore.selectFirstCell();\n                    },\n                    'rightTop',\n                    0\n                );\n            },\n            deactiveHandle: (event: MouseEvent) => {\n                if (event.relatedTarget instanceof HTMLElement) {\n                    if (event.relatedTarget.classList.contains('color-container')) {\n                        return;\n                    }\n                }\n                if (this.colorSelectService.isOpenColorSelect) {\n                    this.colorSelectService.closeColorSelect();\n                }\n            }\n        },\n        {\n            key: 'clear-selection',\n            icon: 'sweep',\n            divider: true,\n            name: '清空选中区域',\n            actionHandle: () => {\n                this.tableStore.clearSelectedCellsContent();\n                this.tableStore.selectFirstCell();\n            }\n        },\n        {\n            key: 'merge-cells',\n            icon: 'table-merge-cells',\n            name: '合并单元格',\n            actionHandle: () => {\n                this.tableStore.mergeCell(this.editor);\n            }\n        },\n        {\n            key: 'split-cells',\n            icon: 'table-unmerge-cells',\n            name: '拆分单元格',\n            divider: true,\n            actionHandle: () => {\n                splitCell(this.editor);\n            }\n        },\n        {\n            key: 'delete-selection-rows',\n            icon: 'table-delete-rows',\n            name: '删除所在行',\n            actionHandle: () => {\n                this.tableStore.removeDangerousRows();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousRows();\n            }\n        },\n        {\n            key: 'delete-selection-columns',\n            icon: 'table-delete-columns',\n            divider: true,\n            name: '删除所在列',\n            actionHandle: () => {\n                this.tableStore.removeDangerousColumns();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousColumns();\n            }\n        },\n        {\n            key: 'delete-table',\n            icon: 'trash',\n            name: '删除表格',\n            actionHandle: () => {\n                TableEditor.removeTable(this.editor);\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousTable();\n            }\n        }\n    ];\n\n    openMenuList(event: MouseEvent) {\n        this.ngZone.run(() => {\n            setCellMenuInvisibility(this.editor, this.menuEntities, this.tableStore.selectedCells);\n            this.menuEntities.forEach(item => {\n                if (item.key === 'background-color') {\n                    item.backgroundColor = this.tableStore.getSelectedCellBackgroundColor();\n                }\n            });\n            this.menuRef = this.thyPopover.open(TheContextMenuComponent, {\n                origin: event.target as HTMLElement,\n                initialState: {\n                    menuEntities: this.menuEntities,\n                    actionHandle: (entity: MenuEntity) => {\n                        entity.actionHandle(entity);\n                    },\n                    activeHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.activeHandle) {\n                            entity.activeHandle(menuEvent);\n                        }\n                    },\n                    deactiveHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.key.indexOf('delete') >= 0) {\n                            this.tableStore.clearDangerousCells();\n                        }\n                        if (entity.deactiveHandle) {\n                            entity.deactiveHandle(menuEvent);\n                        }\n                    }\n                },\n                originPosition: {\n                    x: event.x + 30,\n                    y: event.y\n                },\n                hasBackdrop: false,\n                placement: 'bottomLeft',\n                viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n                manualClosure: true,\n                insideClosable: false,\n                backdropClosable: false\n            });\n            this.menuRef.afterClosed().subscribe(() => {\n                this.tableStore.clearSelectedCells();\n            });\n        });\n    }\n\n    closeContextMenu() {\n        if (this.isOpened) {\n            this.menuRef.close();\n            return this.menuRef.afterClosed();\n        }\n    }\n}\n"]}
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-contextmenu.service.js","sourceRoot":"","sources":["../../../../packages/src/services/table-contextmenu.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { BackgroundColors, ColorType, SpecialBackgroundColor, TableHeaderBackgroundColor } from '../constants/color-select';\nimport { TableStore } from '../plugins/table/table.store';\nimport { TheColorSelectService } from './color-select.service';\nimport { TableEditor } from '../plugins/table/table.editor';\nimport { ThyPopoverRef, ThyPopover } from 'ngx-tethys/popover';\nimport { TheContextMenuComponent } from '../components/contextmenu/contextmenu.component';\nimport { TheContextService } from './context.service';\nimport { splitCell } from '../plugins/table/utils/split-cell';\nimport { setCellMenuInvisibility } from '../plugins/table/utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../plugins/table/table.types';\n\n@Injectable()\nexport class TheTableContextMenuService {\n    menuRef: ThyPopoverRef<TheContextMenuComponent>;\n\n    get isOpened() {\n        return this.menuRef && this.menuRef.componentInstance;\n    }\n\n    get editor() {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    get backgroundColor() {\n        return this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    constructor(\n        private colorSelectService: TheColorSelectService,\n        private tableStore: TableStore,\n        private thyPopover: ThyPopover,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    menuEntities: MenuEntity[] = [\n        {\n            key: 'background-color',\n            icon: 'background-tt',\n            divider: true,\n            name: '单元格背景',\n            extendIcon: 'angle-right',\n            actionHandle: () => {},\n            activeHandle: (event: MouseEvent) => {\n                if (this.colorSelectService.isOpenColorSelect) {\n                    return;\n                }\n                const isHeader = TableEditor.isActiveHeader(this.editor);\n                this.colorSelectService.toggleColorSelect(\n                    event.target as HTMLElement,\n                    this.backgroundColor,\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.tableStore.selectFirstCell();\n                    },\n                    'rightTop',\n                    0\n                );\n            },\n            deactiveHandle: (event: MouseEvent) => {\n                if (event.relatedTarget instanceof HTMLElement) {\n                    if (event.relatedTarget.classList.contains('color-container')) {\n                        return;\n                    }\n                }\n                if (this.colorSelectService.isOpenColorSelect) {\n                    this.colorSelectService.closeColorSelect();\n                }\n            }\n        },\n        {\n            key: 'clear-selection',\n            icon: 'sweep',\n            divider: true,\n            name: '清空选中区域',\n            actionHandle: () => {\n                this.tableStore.clearSelectedCellsContent();\n                this.tableStore.selectFirstCell();\n            }\n        },\n        {\n            key: 'merge-cells',\n            icon: 'table-merge-cells',\n            name: '合并单元格',\n            actionHandle: () => {\n                this.tableStore.mergeCell(this.editor);\n            }\n        },\n        {\n            key: 'split-cells',\n            icon: 'table-unmerge-cells',\n            name: '拆分单元格',\n            divider: true,\n            actionHandle: () => {\n                splitCell(this.editor);\n            }\n        },\n        {\n            key: 'delete-selection-rows',\n            icon: 'table-delete-rows',\n            name: '删除所在行',\n            actionHandle: () => {\n                this.tableStore.removeDangerousRows();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousRows();\n            }\n        },\n        {\n            key: 'delete-selection-columns',\n            icon: 'table-delete-columns',\n            divider: true,\n            name: '删除所在列',\n            actionHandle: () => {\n                this.tableStore.removeDangerousColumns();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousColumns();\n            }\n        },\n        {\n            key: 'delete-table',\n            icon: 'trash',\n            name: '删除表格',\n            actionHandle: () => {\n                TableEditor.removeTable(this.editor);\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousTable();\n            }\n        }\n    ];\n\n    openMenuList(event: MouseEvent) {\n        this.ngZone.run(() => {\n            setCellMenuInvisibility(this.editor, this.menuEntities, this.tableStore.selectedCells);\n            this.menuEntities.forEach(item => {\n                if (item.key === 'background-color') {\n                    item.backgroundColor = this.tableStore.getSelectedCellBackgroundColor();\n                }\n            });\n            this.menuRef = this.thyPopover.open(TheContextMenuComponent, {\n                origin: event.target as HTMLElement,\n                initialState: {\n                    menuEntities: this.menuEntities,\n                    actionHandle: (entity: MenuEntity) => {\n                        entity.actionHandle(entity);\n                    },\n                    activeHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.activeHandle) {\n                            entity.activeHandle(menuEvent);\n                        }\n                    },\n                    deactiveHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.key.indexOf('delete') >= 0) {\n                            this.tableStore.clearDangerousCells();\n                        }\n                        if (entity.deactiveHandle) {\n                            entity.deactiveHandle(menuEvent);\n                        }\n                    }\n                },\n                originPosition: {\n                    x: event.x + 30,\n                    y: event.y\n                },\n                hasBackdrop: false,\n                minWidth: 0,\n                placement: 'bottomLeft',\n                viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n                manualClosure: true,\n                insideClosable: false,\n                backdropClosable: false\n            });\n            this.menuRef.afterClosed().subscribe(() => {\n                this.tableStore.clearSelectedCells();\n            });\n        });\n    }\n\n    closeContextMenu() {\n        if (this.isOpened) {\n            this.menuRef.close();\n            return this.menuRef.afterClosed();\n        }\n    }\n}\n"]}
@@ -754,6 +754,7 @@ class TheColorSelectService {
754
754
  option
755
755
  },
756
756
  origin,
757
+ minWidth: 0,
757
758
  backdropClosable: this.backdropClosable,
758
759
  placement: placement || this.placement,
759
760
  offset: offset !== null ? offset : this.offset,
@@ -2459,6 +2460,7 @@ const withDeserializeMd = (editor) => {
2459
2460
  viewContainerRef,
2460
2461
  placement,
2461
2462
  offset: -100,
2463
+ minWidth: 0,
2462
2464
  hasBackdrop: false,
2463
2465
  backdropClosable: false,
2464
2466
  closeOnNavigation: false,
@@ -3016,6 +3018,7 @@ class TheImageComponent extends TheBaseElementComponent {
3016
3018
  backdropClosable: true,
3017
3019
  hasBackdrop: false,
3018
3020
  offset: 10,
3021
+ minWidth: 0,
3019
3022
  viewContainerRef: this.viewContainerRef,
3020
3023
  scrollStrategy: this.overlay.scrollStrategies.reposition()
3021
3024
  });
@@ -6955,6 +6958,7 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
6955
6958
  backdropClosable: true,
6956
6959
  hasBackdrop: false,
6957
6960
  offset: 10,
6961
+ minWidth: 0,
6958
6962
  viewContainerRef: this.viewContainerRef,
6959
6963
  scrollStrategy: this.overlay.scrollStrategies.reposition()
6960
6964
  });
@@ -7567,6 +7571,7 @@ class TheBaseLinkComponent extends TheBaseElementComponent {
7567
7571
  origin: dom,
7568
7572
  placement: 'bottomLeft',
7569
7573
  offset: 8,
7574
+ minWidth: 0,
7570
7575
  hasBackdrop: false,
7571
7576
  outsideClosable: true,
7572
7577
  viewContainerRef: this.viewContainerRef,
@@ -7586,6 +7591,7 @@ class TheBaseLinkComponent extends TheBaseElementComponent {
7586
7591
  link,
7587
7592
  originSelection: this.editor.selection
7588
7593
  },
7594
+ minWidth: 0,
7589
7595
  origin: this.elementRef.nativeElement,
7590
7596
  backdropClosable: true,
7591
7597
  placement: 'bottomLeft',
@@ -8648,6 +8654,7 @@ class TheTableToolbarComponent {
8648
8654
  tableStore: this.tableStore,
8649
8655
  editor: this.editor
8650
8656
  },
8657
+ minWidth: 0,
8651
8658
  insideClosable: false,
8652
8659
  hasBackdrop: false,
8653
8660
  placement: 'bottomLeft',
@@ -8900,6 +8907,7 @@ class TheTableContextMenuService {
8900
8907
  y: event.y
8901
8908
  },
8902
8909
  hasBackdrop: false,
8910
+ minWidth: 0,
8903
8911
  placement: 'bottomLeft',
8904
8912
  viewContainerRef: this.theContextService.getOptions().viewContainerRef,
8905
8913
  manualClosure: true,
@@ -8961,6 +8969,7 @@ class TableService {
8961
8969
  offset: this.offset,
8962
8970
  hasBackdrop: this.hasBackdrop,
8963
8971
  insideClosable: this.insideClosable,
8972
+ minWidth: 0,
8964
8973
  panelClass: 'the-temp-table-toolbar-wrap',
8965
8974
  scrollStrategy: this.overlay.scrollStrategies.reposition(),
8966
8975
  manualClosure: true
@@ -10845,6 +10854,7 @@ class TheTableToolbarItemComponent extends TheBaseToolbarItem {
10845
10854
  editor: this.editor,
10846
10855
  optionsParam
10847
10856
  },
10857
+ minWidth: 0,
10848
10858
  backdropClosable: false,
10849
10859
  hasBackdrop: false,
10850
10860
  insideClosable: false,
@@ -11540,6 +11550,7 @@ const QuickInsertEditor = {
11540
11550
  offset: 4,
11541
11551
  hasBackdrop: false,
11542
11552
  insideClosable: true,
11553
+ minWidth: 0,
11543
11554
  panelClass: 'the-quick-toolbar-container',
11544
11555
  scrollStrategy: overlay.scrollStrategies.reposition(),
11545
11556
  manualClosure: true
@@ -12051,6 +12062,7 @@ class TheVerticalToolbarItemComponent extends TheBaseToolbarDropdown {
12051
12062
  panelClass: ['the-toolbar-dropdown-popover', (_a = this.toolbarItem) === null || _a === void 0 ? void 0 : _a.key],
12052
12063
  placement: 'bottomLeft',
12053
12064
  offset: 10,
12065
+ minWidth: 0,
12054
12066
  viewContainerRef: this.viewContainerRef,
12055
12067
  insideClosable: false,
12056
12068
  backdropClosable: false,
@@ -12325,6 +12337,7 @@ class TheColorToolbarItemComponent extends TheBaseToolbarItem {
12325
12337
  backdropClosable: false,
12326
12338
  placement: 'bottomLeft',
12327
12339
  offset: 10,
12340
+ minWidth: 0,
12328
12341
  hasBackdrop: false,
12329
12342
  insideClosable: false,
12330
12343
  panelClass: 'color-select-container'
@@ -13533,6 +13546,7 @@ class TheToolbarGroupComponent {
13533
13546
  this.groupPopoverRef = this.thyPopover.open(this.groupTemplate, {
13534
13547
  panelClass: 'the-toolbar-group-container',
13535
13548
  offset: 10,
13549
+ minWidth: 0,
13536
13550
  placement: 'bottomRight',
13537
13551
  origin: event.currentTarget,
13538
13552
  viewContainerRef: this.viewContainerRef,