@worktile/theia 13.0.6 → 13.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/toolbar/toolbar.component.scss +3 -1
- package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +3 -3
- package/components/toolbar-dropdown/toolbar-dropdown.component.scss +14 -0
- package/esm2020/components/toolbar-dropdown/toolbar-dropdown.component.mjs +19 -22
- package/esm2020/plugins/table/components/toolbar/table-toolbar.component.mjs +2 -2
- package/esm2020/services/color-select.service.mjs +3 -2
- package/fesm2015/worktile-theia.mjs +21 -23
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +20 -22
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/package.json +1 -1
- package/plugins/font-size/toolbar-item.component.scss +1 -1
- package/plugins/table/components/table.component.scss +0 -4
|
@@ -36,8 +36,10 @@
|
|
|
36
36
|
@include mixins.the-toolbar-active();
|
|
37
37
|
}
|
|
38
38
|
.the-global-toolbar {
|
|
39
|
+
.the-toolbar-item,
|
|
40
|
+
.the-toolbar-dropdown-container,
|
|
39
41
|
.thy-action {
|
|
40
|
-
&:not(:hover):not(.active) {
|
|
42
|
+
&:not(:hover):not(.active):not(.thy-popover-origin-active) {
|
|
41
43
|
color: variables.$gray-700;
|
|
42
44
|
}
|
|
43
45
|
}
|
|
@@ -11,21 +11,21 @@ export declare class TheToolbarDropdownComponent extends TheBaseToolbarDropdown
|
|
|
11
11
|
private thyPopover;
|
|
12
12
|
private viewContainerRef;
|
|
13
13
|
private overlay;
|
|
14
|
+
className: string;
|
|
14
15
|
itemMousedownHandle: (item: ToolbarItem) => void;
|
|
15
16
|
editor: Editor;
|
|
16
|
-
template: TemplateRef<any>;
|
|
17
17
|
dropdownMode: typeof DropdownMode;
|
|
18
18
|
dropdownPopoverRef: ThyPopoverRef<any>;
|
|
19
19
|
get isOpen(): boolean;
|
|
20
20
|
iconModeTemplate: TemplateRef<any>;
|
|
21
21
|
textModeTemplate: TemplateRef<any>;
|
|
22
22
|
dropdownTemplate: TemplateRef<any>;
|
|
23
|
-
toggleDropdown(event: MouseEvent): void;
|
|
24
23
|
handleDocumentMouseDown(event: MouseEvent): void;
|
|
25
24
|
constructor(elementRef: ElementRef, thyPopover: ThyPopover, viewContainerRef: ViewContainerRef, overlay: Overlay);
|
|
26
25
|
ngOnInit(): void;
|
|
26
|
+
toggleDropdown(event: MouseEvent): void;
|
|
27
27
|
itemMousedown(event: MouseEvent, item: ToolbarItem): void;
|
|
28
|
-
openDropdownPopover(): void;
|
|
28
|
+
openDropdownPopover(event: MouseEvent): void;
|
|
29
29
|
closeDropdownPopover(): void;
|
|
30
30
|
createPositionStrategy(): import("@angular/cdk/overlay").FlexibleConnectedPositionStrategy;
|
|
31
31
|
static ɵfac: i0.ɵɵFactoryDeclaration<TheToolbarDropdownComponent, never>;
|
|
@@ -48,6 +48,20 @@
|
|
|
48
48
|
min-width: 200px;
|
|
49
49
|
}
|
|
50
50
|
|
|
51
|
+
.thy-dropdown-menu {
|
|
52
|
+
display: flex;
|
|
53
|
+
flex-direction: column;
|
|
54
|
+
width: 200px;
|
|
55
|
+
max-height: 300px;
|
|
56
|
+
overflow-y: auto;
|
|
57
|
+
background-color: variables.$white;
|
|
58
|
+
z-index: 100;
|
|
59
|
+
|
|
60
|
+
.dropdown-menu-item {
|
|
61
|
+
color: variables.$gray-700;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
51
65
|
&.heading-list {
|
|
52
66
|
.dropdown-menu-item:not(:first-child) {
|
|
53
67
|
padding-top: 0;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, HostListener, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, Input, HostListener, ViewChild, HostBinding } from '@angular/core';
|
|
2
2
|
import { DropdownMode } from '../../constants/toolbar';
|
|
3
3
|
import { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -16,27 +16,18 @@ export class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
16
16
|
this.thyPopover = thyPopover;
|
|
17
17
|
this.viewContainerRef = viewContainerRef;
|
|
18
18
|
this.overlay = overlay;
|
|
19
|
+
this.className = 'the-toolbar-dropdown-container';
|
|
19
20
|
this.dropdownMode = DropdownMode;
|
|
20
21
|
}
|
|
21
22
|
get isOpen() {
|
|
22
23
|
return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();
|
|
23
24
|
}
|
|
24
|
-
toggleDropdown(event) {
|
|
25
|
-
super.execute(event);
|
|
26
|
-
if (this.editor?.disabled || this.disabled) {
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
this.openDropdownPopover();
|
|
30
|
-
}
|
|
31
25
|
handleDocumentMouseDown(event) {
|
|
32
26
|
if (!this.elementRef.nativeElement.contains(event.target)) {
|
|
33
27
|
this.closeDropdownPopover();
|
|
34
28
|
}
|
|
35
29
|
}
|
|
36
30
|
ngOnInit() {
|
|
37
|
-
if (!this.template) {
|
|
38
|
-
this.template = this.mode === this.dropdownMode.icon ? this.iconModeTemplate : this.textModeTemplate;
|
|
39
|
-
}
|
|
40
31
|
if (!this.activeMenuItem) {
|
|
41
32
|
this.activeMenuItem = this.defaultDropdownItem;
|
|
42
33
|
}
|
|
@@ -44,6 +35,13 @@ export class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
44
35
|
this.elementRef.nativeElement.classList.add(`${this.toolbarItem?.key}`);
|
|
45
36
|
}
|
|
46
37
|
}
|
|
38
|
+
toggleDropdown(event) {
|
|
39
|
+
super.execute(event);
|
|
40
|
+
if (this.editor?.disabled || this.disabled) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
this.openDropdownPopover(event);
|
|
44
|
+
}
|
|
47
45
|
itemMousedown(event, item) {
|
|
48
46
|
super.execute(event);
|
|
49
47
|
this.closeDropdownPopover();
|
|
@@ -58,10 +56,11 @@ export class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
58
56
|
item?.execute(this.editor);
|
|
59
57
|
}
|
|
60
58
|
}
|
|
61
|
-
openDropdownPopover() {
|
|
59
|
+
openDropdownPopover(event) {
|
|
62
60
|
this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {
|
|
63
|
-
origin:
|
|
61
|
+
origin: event.currentTarget,
|
|
64
62
|
panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],
|
|
63
|
+
originActiveClass: 'active',
|
|
65
64
|
placement: 'bottomLeft',
|
|
66
65
|
insideClosable: false,
|
|
67
66
|
backdropClosable: true,
|
|
@@ -102,13 +101,14 @@ export class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
102
101
|
}
|
|
103
102
|
}
|
|
104
103
|
TheToolbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TheToolbarDropdownComponent, deps: [{ token: i0.ElementRef }, { token: i1.ThyPopover }, { token: i0.ViewContainerRef }, { token: i2.Overlay }], target: i0.ɵɵFactoryTarget.Component });
|
|
105
|
-
TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "
|
|
104
|
+
TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "document: mousedown": "handleDocumentMouseDown($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode link-with-down\"\n thyAction\n [thyActionIcon]=\"activeMenuItem?.icon\"\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [thyDropdownMenuItemActive]=\"menu.key === activeMenuItem?.key && !toolbarItem?.dropdownFixedIcon\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n", components: [{ type: i3.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i5.ThyDropdownMenuDividerComponent, selector: "thy-dropdown-menu-divider" }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { type: i5.ThyDropdownMenuItemActiveDirective, selector: "[thyDropdownMenuItemActive]", inputs: ["thyDropdownMenuItemActive"] }, { type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.ThyDropdownMenuItemIconDirective, selector: "[thyDropdownMenuItemIcon]" }, { type: i5.ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }] });
|
|
106
105
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TheToolbarDropdownComponent, decorators: [{
|
|
107
106
|
type: Component,
|
|
108
|
-
args: [{ selector: 'the-toolbar-dropdown',
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
107
|
+
args: [{ selector: 'the-toolbar-dropdown', template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode link-with-down\"\n thyAction\n [thyActionIcon]=\"activeMenuItem?.icon\"\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [thyDropdownMenuItemActive]=\"menu.key === activeMenuItem?.key && !toolbarItem?.dropdownFixedIcon\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n" }]
|
|
108
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ThyPopover }, { type: i0.ViewContainerRef }, { type: i2.Overlay }]; }, propDecorators: { className: [{
|
|
109
|
+
type: HostBinding,
|
|
110
|
+
args: ['class']
|
|
111
|
+
}], itemMousedownHandle: [{
|
|
112
112
|
type: Input
|
|
113
113
|
}], iconModeTemplate: [{
|
|
114
114
|
type: ViewChild,
|
|
@@ -119,11 +119,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
119
119
|
}], dropdownTemplate: [{
|
|
120
120
|
type: ViewChild,
|
|
121
121
|
args: ['dropdownTemplate', { static: true }]
|
|
122
|
-
}], toggleDropdown: [{
|
|
123
|
-
type: HostListener,
|
|
124
|
-
args: ['mousedown', ['$event']]
|
|
125
122
|
}], handleDocumentMouseDown: [{
|
|
126
123
|
type: HostListener,
|
|
127
124
|
args: ['document: mousedown', ['$event']]
|
|
128
125
|
}] } });
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.ts","../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener, TemplateRef, ViewChild, ViewContainerRef, HostBinding } from '@angular/core';\nimport { ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { DropdownMode } from '../../constants/toolbar';\nimport { ToolbarItem } from '../../interfaces/toolbar';\nimport { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';\nimport { ThyDropdownMenuComponent } from 'ngx-tethys/dropdown';\n\n@Component({\n    selector: 'the-toolbar-dropdown',\n    templateUrl: './toolbar-dropdown.component.html',\n    host: {\n        class: 'the-toolbar-dropdown-container'\n    }\n})\nexport class TheToolbarDropdownComponent extends TheBaseToolbarDropdown implements OnInit {\n    @Input() itemMousedownHandle: (item: ToolbarItem) => void;\n\n    editor: Editor;\n    template: TemplateRef<any>;\n    dropdownMode = DropdownMode;\n    dropdownPopoverRef: ThyPopoverRef<any>;\n\n    get isOpen() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    @ViewChild('iconModeTemplate', { static: true })\n    iconModeTemplate: TemplateRef<any>;\n\n    @ViewChild('textModeTemplate', { static: true })\n    textModeTemplate: TemplateRef<any>;\n\n    @ViewChild('dropdownTemplate', { static: true })\n    dropdownTemplate: TemplateRef<any>;\n\n    @HostListener('mousedown', ['$event'])\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled) {\n            return;\n        }\n        this.openDropdownPopover();\n    }\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement)) {\n            this.closeDropdownPopover();\n        }\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.template) {\n            this.template = this.mode === this.dropdownMode.icon ? this.iconModeTemplate : this.textModeTemplate;\n        }\n\n        if (!this.activeMenuItem) {\n            this.activeMenuItem = this.defaultDropdownItem;\n        }\n\n        if (this.toolbarItem) {\n            this.elementRef.nativeElement.classList.add(`${this.toolbarItem?.key}`);\n        }\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        super.execute(event);\n\n        this.closeDropdownPopover();\n\n        if (!this.toolbarItem.dropdownFixedIcon) {\n            this.activeMenuItem = item;\n        }\n\n        if (this.itemMousedownHandle) {\n            this.itemMousedownHandle(item);\n            return;\n        }\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    openDropdownPopover() {\n        this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {\n            origin: this.elementRef,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            placement: 'bottomLeft',\n            insideClosable: false,\n            backdropClosable: true,\n            hasBackdrop: false,\n            offset: 10,\n            minWidth: 0,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n        this.dropdownPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());\n    }\n\n    closeDropdownPopover() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef?.close();\n        }\n    }\n\n    createPositionStrategy() {\n        const topPosition: ConnectedPosition = {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetX: 0,\n            offsetY: -15\n        };\n        const bottomPosition: ConnectedPosition = {\n            ...topPosition,\n            overlayY: 'top',\n            offsetY: 42\n        };\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.elementRef)\n            .withFlexibleDimensions(false)\n            .withGrowAfterOpen(false)\n            .withPush(false)\n            .withPositions([bottomPosition, topPosition]);\n    }\n}\n","<ng-template [ngTemplateOutlet]=\"template\"></ng-template>\n\n<ng-template #iconModeTemplate>\n    <a\n        href=\"javascript:;\"\n        class=\"icon-mode link-with-down\"\n        thyAction\n        [thyActionIcon]=\"activeMenuItem?.icon\"\n        [thyTooltip]=\"activeMenuItem?.name\"\n        thyTooltipPlacement=\"top\"\n    >\n        <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n    </a>\n</ng-template>\n\n<ng-template #textModeTemplate>\n    <a href=\"javascript:;\" class=\"text-mode\" thyAction [thyTooltip]=\"activeMenuItem?.name\" thyTooltipPlacement=\"top\">\n        <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n        <thy-icon class=\"font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n    </a>\n</ng-template>\n\n<ng-template #dropdownTemplate>\n    <div class=\"thy-dropdown-menu\">\n        <ng-container *ngFor=\"let menu of menus\">\n            <a\n                *ngIf=\"menu.key !== 'split'\"\n                href=\"javascript:;\"\n                thyDropdownMenuItem\n                [thyDropdownMenuItemActive]=\"menu.key === activeMenuItem?.key && !toolbarItem?.dropdownFixedIcon\"\n                (mousedown)=\"itemMousedown($event, menu)\"\n                [ngStyle]=\"menu?.styles\"\n            >\n                <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n                <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n            </a>\n            <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n        </ng-container>\n    </div>\n</ng-template>\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.ts","../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener, TemplateRef, ViewChild, ViewContainerRef, HostBinding } from '@angular/core';\nimport { ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { DropdownMode } from '../../constants/toolbar';\nimport { ToolbarItem } from '../../interfaces/toolbar';\nimport { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';\n\n@Component({\n    selector: 'the-toolbar-dropdown',\n    templateUrl: './toolbar-dropdown.component.html'\n})\nexport class TheToolbarDropdownComponent extends TheBaseToolbarDropdown implements OnInit {\n    @HostBinding('class') className = 'the-toolbar-dropdown-container';\n\n    @Input() itemMousedownHandle: (item: ToolbarItem) => void;\n\n    editor: Editor;\n    dropdownMode = DropdownMode;\n    dropdownPopoverRef: ThyPopoverRef<any>;\n\n    get isOpen() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    @ViewChild('iconModeTemplate', { static: true })\n    iconModeTemplate: TemplateRef<any>;\n\n    @ViewChild('textModeTemplate', { static: true })\n    textModeTemplate: TemplateRef<any>;\n\n    @ViewChild('dropdownTemplate', { static: true })\n    dropdownTemplate: TemplateRef<any>;\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement)) {\n            this.closeDropdownPopover();\n        }\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.activeMenuItem) {\n            this.activeMenuItem = this.defaultDropdownItem;\n        }\n\n        if (this.toolbarItem) {\n            this.elementRef.nativeElement.classList.add(`${this.toolbarItem?.key}`);\n        }\n    }\n\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled) {\n            return;\n        }\n        this.openDropdownPopover(event);\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        super.execute(event);\n\n        this.closeDropdownPopover();\n\n        if (!this.toolbarItem.dropdownFixedIcon) {\n            this.activeMenuItem = item;\n        }\n\n        if (this.itemMousedownHandle) {\n            this.itemMousedownHandle(item);\n            return;\n        }\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    openDropdownPopover(event: MouseEvent) {\n        this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {\n            origin: event.currentTarget as HTMLElement,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            originActiveClass: 'active',\n            placement: 'bottomLeft',\n            insideClosable: false,\n            backdropClosable: true,\n            hasBackdrop: false,\n            offset: 10,\n            minWidth: 0,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n        this.dropdownPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());\n    }\n\n    closeDropdownPopover() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef?.close();\n        }\n    }\n\n    createPositionStrategy() {\n        const topPosition: ConnectedPosition = {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetX: 0,\n            offsetY: -15\n        };\n        const bottomPosition: ConnectedPosition = {\n            ...topPosition,\n            overlayY: 'top',\n            offsetY: 42\n        };\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.elementRef)\n            .withFlexibleDimensions(false)\n            .withGrowAfterOpen(false)\n            .withPush(false)\n            .withPositions([bottomPosition, topPosition]);\n    }\n}\n","<a\n    *ngIf=\"mode === dropdownMode.icon\"\n    href=\"javascript:;\"\n    class=\"icon-mode link-with-down\"\n    thyAction\n    [thyActionIcon]=\"activeMenuItem?.icon\"\n    [thyTooltip]=\"activeMenuItem?.name\"\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"toggleDropdown($event)\"\n>\n    <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n    *ngIf=\"mode !== dropdownMode.icon\"\n    href=\"javascript:;\"\n    class=\"text-mode\"\n    thyAction\n    [thyTooltip]=\"activeMenuItem?.name\"\n    thyTooltipPlacement=\"top\"\n    (mousedown)=\"toggleDropdown($event)\"\n>\n    <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n    <thy-icon class=\"font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n    <div class=\"thy-dropdown-menu\">\n        <ng-container *ngFor=\"let menu of menus\">\n            <a\n                *ngIf=\"menu.key !== 'split'\"\n                href=\"javascript:;\"\n                thyDropdownMenuItem\n                [thyDropdownMenuItemActive]=\"menu.key === activeMenuItem?.key && !toolbarItem?.dropdownFixedIcon\"\n                (mousedown)=\"itemMousedown($event, menu)\"\n                [ngStyle]=\"menu?.styles\"\n            >\n                <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n                <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n            </a>\n            <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n        </ng-container>\n    </div>\n</ng-template>\n"]}
|
|
@@ -134,7 +134,7 @@ export class TheTableToolbarComponent {
|
|
|
134
134
|
insideClosable: false,
|
|
135
135
|
hasBackdrop: false,
|
|
136
136
|
placement: 'bottomLeft',
|
|
137
|
-
originActiveClass: '
|
|
137
|
+
originActiveClass: 'active',
|
|
138
138
|
panelClass: 'table-options-pannel'
|
|
139
139
|
});
|
|
140
140
|
}
|
|
@@ -155,4 +155,4 @@ export var DeleteIcon;
|
|
|
155
155
|
DeleteIcon[DeleteIcon["table-delete-columns"] = 1] = "table-delete-columns";
|
|
156
156
|
DeleteIcon[DeleteIcon["trash"] = 2] = "trash";
|
|
157
157
|
})(DeleteIcon || (DeleteIcon = {}));
|
|
158
|
-
//# 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-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            );\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-actions thySize=\"xxs\">\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a\n            *ngIf=\"!item.invisibility\"\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=\"!isActiveSelect && isShowSplitLine\" class=\"mx-2 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\n    <ng-container *ngIf=\"tableStore.isSelectedTable\">\n        <thy-divider class=\"mx-2 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n        <a href=\"javascript:;\" class=\"link-with-down\" thyAction (mousedown)=\"openTableOptionMenu($event)\">\n            <span>表格选项</span>\n            <thy-icon thyIconName=\"caret-down\"></thy-icon>\n        </a>\n    </ng-container>\n\n    <thy-divider *ngIf=\"deleteIcon\" class=\"mx-2 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n    <a\n        *ngIf=\"deleteIcon\"\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</thy-actions>\n"]}
|
|
158
|
+
//# 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-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            );\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: '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-actions thySize=\"xxs\">\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a\n            *ngIf=\"!item.invisibility\"\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=\"!isActiveSelect && isShowSplitLine\" class=\"mx-2 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\n    <ng-container *ngIf=\"tableStore.isSelectedTable\">\n        <thy-divider class=\"mx-2 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n        <a href=\"javascript:;\" class=\"link-with-down\" thyAction (mousedown)=\"openTableOptionMenu($event)\">\n            <span>表格选项</span>\n            <thy-icon thyIconName=\"caret-down\"></thy-icon>\n        </a>\n    </ng-container>\n\n    <thy-divider *ngIf=\"deleteIcon\" class=\"mx-2 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n    <a\n        *ngIf=\"deleteIcon\"\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</thy-actions>\n"]}
|
|
@@ -32,7 +32,8 @@ export class TheColorSelectService {
|
|
|
32
32
|
offset: offset !== null ? offset : this.offset,
|
|
33
33
|
hasBackdrop: this.hasBackdrop,
|
|
34
34
|
insideClosable: this.insideClosable,
|
|
35
|
-
panelClass: 'color-select-container'
|
|
35
|
+
panelClass: 'color-select-container',
|
|
36
|
+
originActiveClass: 'active'
|
|
36
37
|
});
|
|
37
38
|
return this.colorSelectRef;
|
|
38
39
|
}
|
|
@@ -47,4 +48,4 @@ TheColorSelectService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0"
|
|
|
47
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TheColorSelectService, decorators: [{
|
|
48
49
|
type: Injectable
|
|
49
50
|
}], ctorParameters: function () { return [{ type: i1.ThyPopover }]; } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3Itc2VsZWN0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvc2VydmljZXMvY29sb3Itc2VsZWN0LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUczQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBSTVGLE1BQU0sT0FBTyxxQkFBcUI7SUFpQjlCLFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7UUFoQjFDLHFCQUFnQixHQUFHLEtBQUssQ0FBQztRQUV6QixnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUVwQixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQUV2QixjQUFTLEdBQWlCLFlBQVksQ0FBQztRQUV2QyxXQUFNLEdBQUcsRUFBRSxDQUFDO0lBUWlDLENBQUM7SUFKOUMsSUFBSSxpQkFBaUI7UUFDakIsT0FBTyxJQUFJLENBQUMsY0FBYyxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsaUJBQWlCLENBQUM7SUFDeEUsQ0FBQztJQUlELGlCQUFpQixDQUNiLE1BQW1CLEVBQ25CLGFBQXdCLEVBQ3hCLE1BQWdCLEVBQ2hCLE1BQXlCLEVBQ3pCLFlBQXdDLEVBQ3hDLFNBQXdCLEVBQ3hCLE1BQWU7UUFFZixJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUN4QixJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQy9CO1FBQ0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyx1QkFBdUIsRUFBRTtZQUNoRSxZQUFZLEVBQUU7Z0JBQ1YsYUFBYTtnQkFDYixZQUFZO2dCQUNaLE1BQU07Z0JBQ04sTUFBTTthQUNUO1lBQ0QsTUFBTTtZQUNOLFFBQVEsRUFBRSxDQUFDO1lBQ1gsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLGdCQUFnQjtZQUN2QyxTQUFTLEVBQUUsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTO1lBQ3RDLE1BQU0sRUFBRSxNQUFNLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNO1lBQzlDLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVztZQUM3QixjQUFjLEVBQUUsSUFBSSxDQUFDLGNBQWM7WUFDbkMsVUFBVSxFQUFFLHdCQUF3QjtZQUNwQyxpQkFBaUIsRUFBRSxRQUFRO1NBQzlCLENBQUMsQ0FBQztRQUNILE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUMvQixDQUFDO0lBRUQsZ0JBQWdCO1FBQ1osSUFBSSxJQUFJLENBQUMsaUJBQWlCLEVBQUU7WUFDeEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUMvQjtJQUNMLENBQUM7O21IQXZEUSxxQkFBcUI7dUhBQXJCLHFCQUFxQjs0RkFBckIscUJBQXFCO2tCQURqQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGh5UGxhY2VtZW50IH0gZnJvbSAnbmd4LXRldGh5cy9jb3JlJztcbmltcG9ydCB7IFRoeVBvcG92ZXIsIFRoeVBvcG92ZXJSZWYgfSBmcm9tICduZ3gtdGV0aHlzL3BvcG92ZXInO1xuaW1wb3J0IHsgVGhlQ29sb3JTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2NvbG9yLXNlbGVjdC9jb2xvci1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IENvbG9yVHlwZSwgQ29sb3JTZWxlY3RPcHRpb24gfSBmcm9tICcuLi9jb25zdGFudHMvY29sb3Itc2VsZWN0JztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFRoZUNvbG9yU2VsZWN0U2VydmljZSB7XG4gICAgYmFja2Ryb3BDbG9zYWJsZSA9IGZhbHNlO1xuXG4gICAgaGFzQmFja2Ryb3AgPSBmYWxzZTtcblxuICAgIGluc2lkZUNsb3NhYmxlID0gZmFsc2U7XG5cbiAgICBwbGFjZW1lbnQ6IFRoeVBsYWNlbWVudCA9ICdib3R0b21MZWZ0JztcblxuICAgIG9mZnNldCA9IDEwO1xuXG4gICAgY29sb3JTZWxlY3RSZWY6IFRoeVBvcG92ZXJSZWY8VGhlQ29sb3JTZWxlY3RDb21wb25lbnQ+O1xuXG4gICAgZ2V0IGlzT3BlbkNvbG9yU2VsZWN0KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5jb2xvclNlbGVjdFJlZiAmJiB0aGlzLmNvbG9yU2VsZWN0UmVmLmNvbXBvbmVudEluc3RhbmNlO1xuICAgIH1cblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgdGh5UG9wb3ZlcjogVGh5UG9wb3Zlcikge31cblxuICAgIHRvZ2dsZUNvbG9yU2VsZWN0KFxuICAgICAgICBvcmlnaW46IEhUTUxFbGVtZW50LFxuICAgICAgICBzZWxlY3RlZENvbG9yOiBDb2xvclR5cGUsXG4gICAgICAgIGNvbG9yczogc3RyaW5nW10sXG4gICAgICAgIG9wdGlvbjogQ29sb3JTZWxlY3RPcHRpb24sXG4gICAgICAgIHNlbGVjdEFjdGlvbjogKGNvbG9yOiBDb2xvclR5cGUpID0+IHZvaWQsXG4gICAgICAgIHBsYWNlbWVudD86IFRoeVBsYWNlbWVudCxcbiAgICAgICAgb2Zmc2V0PzogbnVtYmVyXG4gICAgKSB7XG4gICAgICAgIGlmICh0aGlzLmlzT3BlbkNvbG9yU2VsZWN0KSB7XG4gICAgICAgICAgICB0aGlzLmNvbG9yU2VsZWN0UmVmLmNsb3NlKCk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5jb2xvclNlbGVjdFJlZiA9IHRoaXMudGh5UG9wb3Zlci5vcGVuKFRoZUNvbG9yU2VsZWN0Q29tcG9uZW50LCB7XG4gICAgICAgICAgICBpbml0aWFsU3RhdGU6IHtcbiAgICAgICAgICAgICAgICBzZWxlY3RlZENvbG9yLFxuICAgICAgICAgICAgICAgIHNlbGVjdEFjdGlvbixcbiAgICAgICAgICAgICAgICBjb2xvcnMsXG4gICAgICAgICAgICAgICAgb3B0aW9uXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgb3JpZ2luLFxuICAgICAgICAgICAgbWluV2lkdGg6IDAsXG4gICAgICAgICAgICBiYWNrZHJvcENsb3NhYmxlOiB0aGlzLmJhY2tkcm9wQ2xvc2FibGUsXG4gICAgICAgICAgICBwbGFjZW1lbnQ6IHBsYWNlbWVudCB8fCB0aGlzLnBsYWNlbWVudCxcbiAgICAgICAgICAgIG9mZnNldDogb2Zmc2V0ICE9PSBudWxsID8gb2Zmc2V0IDogdGhpcy5vZmZzZXQsXG4gICAgICAgICAgICBoYXNCYWNrZHJvcDogdGhpcy5oYXNCYWNrZHJvcCxcbiAgICAgICAgICAgIGluc2lkZUNsb3NhYmxlOiB0aGlzLmluc2lkZUNsb3NhYmxlLFxuICAgICAgICAgICAgcGFuZWxDbGFzczogJ2NvbG9yLXNlbGVjdC1jb250YWluZXInLFxuICAgICAgICAgICAgb3JpZ2luQWN0aXZlQ2xhc3M6ICdhY3RpdmUnXG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gdGhpcy5jb2xvclNlbGVjdFJlZjtcbiAgICB9XG5cbiAgICBjbG9zZUNvbG9yU2VsZWN0KCkge1xuICAgICAgICBpZiAodGhpcy5pc09wZW5Db2xvclNlbGVjdCkge1xuICAgICAgICAgICAgdGhpcy5jb2xvclNlbGVjdFJlZi5jbG9zZSgpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -761,7 +761,8 @@ class TheColorSelectService {
|
|
|
761
761
|
offset: offset !== null ? offset : this.offset,
|
|
762
762
|
hasBackdrop: this.hasBackdrop,
|
|
763
763
|
insideClosable: this.insideClosable,
|
|
764
|
-
panelClass: 'color-select-container'
|
|
764
|
+
panelClass: 'color-select-container',
|
|
765
|
+
originActiveClass: 'active'
|
|
765
766
|
});
|
|
766
767
|
return this.colorSelectRef;
|
|
767
768
|
}
|
|
@@ -6904,19 +6905,12 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
6904
6905
|
this.thyPopover = thyPopover;
|
|
6905
6906
|
this.viewContainerRef = viewContainerRef;
|
|
6906
6907
|
this.overlay = overlay;
|
|
6908
|
+
this.className = 'the-toolbar-dropdown-container';
|
|
6907
6909
|
this.dropdownMode = DropdownMode;
|
|
6908
6910
|
}
|
|
6909
6911
|
get isOpen() {
|
|
6910
6912
|
return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();
|
|
6911
6913
|
}
|
|
6912
|
-
toggleDropdown(event) {
|
|
6913
|
-
var _a;
|
|
6914
|
-
super.execute(event);
|
|
6915
|
-
if (((_a = this.editor) === null || _a === void 0 ? void 0 : _a.disabled) || this.disabled) {
|
|
6916
|
-
return;
|
|
6917
|
-
}
|
|
6918
|
-
this.openDropdownPopover();
|
|
6919
|
-
}
|
|
6920
6914
|
handleDocumentMouseDown(event) {
|
|
6921
6915
|
if (!this.elementRef.nativeElement.contains(event.target)) {
|
|
6922
6916
|
this.closeDropdownPopover();
|
|
@@ -6924,9 +6918,6 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
6924
6918
|
}
|
|
6925
6919
|
ngOnInit() {
|
|
6926
6920
|
var _a;
|
|
6927
|
-
if (!this.template) {
|
|
6928
|
-
this.template = this.mode === this.dropdownMode.icon ? this.iconModeTemplate : this.textModeTemplate;
|
|
6929
|
-
}
|
|
6930
6921
|
if (!this.activeMenuItem) {
|
|
6931
6922
|
this.activeMenuItem = this.defaultDropdownItem;
|
|
6932
6923
|
}
|
|
@@ -6934,6 +6925,14 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
6934
6925
|
this.elementRef.nativeElement.classList.add(`${(_a = this.toolbarItem) === null || _a === void 0 ? void 0 : _a.key}`);
|
|
6935
6926
|
}
|
|
6936
6927
|
}
|
|
6928
|
+
toggleDropdown(event) {
|
|
6929
|
+
var _a;
|
|
6930
|
+
super.execute(event);
|
|
6931
|
+
if (((_a = this.editor) === null || _a === void 0 ? void 0 : _a.disabled) || this.disabled) {
|
|
6932
|
+
return;
|
|
6933
|
+
}
|
|
6934
|
+
this.openDropdownPopover(event);
|
|
6935
|
+
}
|
|
6937
6936
|
itemMousedown(event, item) {
|
|
6938
6937
|
super.execute(event);
|
|
6939
6938
|
this.closeDropdownPopover();
|
|
@@ -6948,11 +6947,12 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
6948
6947
|
item === null || item === void 0 ? void 0 : item.execute(this.editor);
|
|
6949
6948
|
}
|
|
6950
6949
|
}
|
|
6951
|
-
openDropdownPopover() {
|
|
6950
|
+
openDropdownPopover(event) {
|
|
6952
6951
|
var _a, _b;
|
|
6953
6952
|
this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {
|
|
6954
|
-
origin:
|
|
6953
|
+
origin: event.currentTarget,
|
|
6955
6954
|
panelClass: ['the-toolbar-dropdown-popover', (_a = this.toolbarItem) === null || _a === void 0 ? void 0 : _a.key],
|
|
6955
|
+
originActiveClass: 'active',
|
|
6956
6956
|
placement: 'bottomLeft',
|
|
6957
6957
|
insideClosable: false,
|
|
6958
6958
|
backdropClosable: true,
|
|
@@ -6990,13 +6990,14 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
|
|
|
6990
6990
|
}
|
|
6991
6991
|
}
|
|
6992
6992
|
TheToolbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TheToolbarDropdownComponent, deps: [{ token: i0.ElementRef }, { token: i1$1.ThyPopover }, { token: i0.ViewContainerRef }, { token: i2$1.Overlay }], target: i0.ɵɵFactoryTarget.Component });
|
|
6993
|
-
TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "
|
|
6993
|
+
TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "document: mousedown": "handleDocumentMouseDown($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode link-with-down\"\n thyAction\n [thyActionIcon]=\"activeMenuItem?.icon\"\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [thyDropdownMenuItemActive]=\"menu.key === activeMenuItem?.key && !toolbarItem?.dropdownFixedIcon\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n", components: [{ type: i3$1.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { type: i2.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i5$2.ThyDropdownMenuDividerComponent, selector: "thy-dropdown-menu-divider" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4$2.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5$2.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { type: i5$2.ThyDropdownMenuItemActiveDirective, selector: "[thyDropdownMenuItemActive]", inputs: ["thyDropdownMenuItemActive"] }, { type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5$2.ThyDropdownMenuItemIconDirective, selector: "[thyDropdownMenuItemIcon]" }, { type: i5$2.ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }] });
|
|
6994
6994
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: TheToolbarDropdownComponent, decorators: [{
|
|
6995
6995
|
type: Component,
|
|
6996
|
-
args: [{ selector: 'the-toolbar-dropdown',
|
|
6997
|
-
|
|
6998
|
-
|
|
6999
|
-
|
|
6996
|
+
args: [{ selector: 'the-toolbar-dropdown', template: "<a\n *ngIf=\"mode === dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"icon-mode link-with-down\"\n thyAction\n [thyActionIcon]=\"activeMenuItem?.icon\"\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n<a\n *ngIf=\"mode !== dropdownMode.icon\"\n href=\"javascript:;\"\n class=\"text-mode\"\n thyAction\n [thyTooltip]=\"activeMenuItem?.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"toggleDropdown($event)\"\n>\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n href=\"javascript:;\"\n thyDropdownMenuItem\n [thyDropdownMenuItemActive]=\"menu.key === activeMenuItem?.key && !toolbarItem?.dropdownFixedIcon\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <thy-icon *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyDropdownMenuItemIcon [thyIconName]=\"menu.icon\"></thy-icon>\n <span *ngIf=\"menu.name\" thyDropdownMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-dropdown-menu-divider *ngIf=\"menu.key === 'split'\"></thy-dropdown-menu-divider>\n </ng-container>\n </div>\n</ng-template>\n" }]
|
|
6997
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1$1.ThyPopover }, { type: i0.ViewContainerRef }, { type: i2$1.Overlay }]; }, propDecorators: { className: [{
|
|
6998
|
+
type: HostBinding,
|
|
6999
|
+
args: ['class']
|
|
7000
|
+
}], itemMousedownHandle: [{
|
|
7000
7001
|
type: Input
|
|
7001
7002
|
}], iconModeTemplate: [{
|
|
7002
7003
|
type: ViewChild,
|
|
@@ -7007,9 +7008,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
7007
7008
|
}], dropdownTemplate: [{
|
|
7008
7009
|
type: ViewChild,
|
|
7009
7010
|
args: ['dropdownTemplate', { static: true }]
|
|
7010
|
-
}], toggleDropdown: [{
|
|
7011
|
-
type: HostListener,
|
|
7012
|
-
args: ['mousedown', ['$event']]
|
|
7013
7011
|
}], handleDocumentMouseDown: [{
|
|
7014
7012
|
type: HostListener,
|
|
7015
7013
|
args: ['document: mousedown', ['$event']]
|
|
@@ -8646,7 +8644,7 @@ class TheTableToolbarComponent {
|
|
|
8646
8644
|
insideClosable: false,
|
|
8647
8645
|
hasBackdrop: false,
|
|
8648
8646
|
placement: 'bottomLeft',
|
|
8649
|
-
originActiveClass: '
|
|
8647
|
+
originActiveClass: 'active',
|
|
8650
8648
|
panelClass: 'table-options-pannel'
|
|
8651
8649
|
});
|
|
8652
8650
|
}
|