ngx-tethys 15.2.5 → 15.2.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.
- package/CHANGELOG.md +29 -0
- package/color-picker/color-picker.component.d.ts +30 -6
- package/esm2020/color-picker/color-picker.component.mjs +121 -19
- package/esm2020/dialog/header/dialog-header.component.mjs +3 -3
- package/esm2020/layout/sidebar.component.mjs +10 -3
- package/esm2020/popover/header/popover-header.component.mjs +3 -3
- package/esm2020/slide/slide-header/slide-header.component.mjs +3 -3
- package/esm2020/tree/tree-node.component.mjs +9 -7
- package/esm2020/version.mjs +2 -2
- package/fesm2015/ngx-tethys-color-picker.mjs +119 -18
- package/fesm2015/ngx-tethys-color-picker.mjs.map +1 -1
- package/fesm2015/ngx-tethys-dialog.mjs +2 -2
- package/fesm2015/ngx-tethys-dialog.mjs.map +1 -1
- package/fesm2015/ngx-tethys-layout.mjs +9 -2
- package/fesm2015/ngx-tethys-layout.mjs.map +1 -1
- package/fesm2015/ngx-tethys-popover.mjs +2 -2
- package/fesm2015/ngx-tethys-popover.mjs.map +1 -1
- package/fesm2015/ngx-tethys-slide.mjs +2 -2
- package/fesm2015/ngx-tethys-slide.mjs.map +1 -1
- package/fesm2015/ngx-tethys-tree.mjs +8 -6
- package/fesm2015/ngx-tethys-tree.mjs.map +1 -1
- package/fesm2015/ngx-tethys.mjs +1 -1
- package/fesm2015/ngx-tethys.mjs.map +1 -1
- package/fesm2020/ngx-tethys-color-picker.mjs +117 -17
- package/fesm2020/ngx-tethys-color-picker.mjs.map +1 -1
- package/fesm2020/ngx-tethys-dialog.mjs +2 -2
- package/fesm2020/ngx-tethys-dialog.mjs.map +1 -1
- package/fesm2020/ngx-tethys-layout.mjs +9 -2
- package/fesm2020/ngx-tethys-layout.mjs.map +1 -1
- package/fesm2020/ngx-tethys-popover.mjs +2 -2
- package/fesm2020/ngx-tethys-popover.mjs.map +1 -1
- package/fesm2020/ngx-tethys-slide.mjs +2 -2
- package/fesm2020/ngx-tethys-slide.mjs.map +1 -1
- package/fesm2020/ngx-tethys-tree.mjs +8 -6
- package/fesm2020/ngx-tethys-tree.mjs.map +1 -1
- package/fesm2020/ngx-tethys.mjs +1 -1
- package/fesm2020/ngx-tethys.mjs.map +1 -1
- package/layout/sidebar.component.d.ts +2 -0
- package/package.json +1 -1
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,35 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [15.2.7](https://github.com/atinc/ngx-tethys/compare/15.2.4...15.2.7) (2023-05-04)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* **date-picker:** compatibility null values at updateHourMinute ([#2633](https://github.com/atinc/ngx-tethys/issues/2633)) ([1207c47](https://github.com/atinc/ngx-tethys/commit/1207c473f98c18d8a30dc4d2e00b002b86aeb246))
|
|
11
|
+
* **layout:** collapse dom appears when the mouse hovers over the sidebar #INFR-5569 ([#2616](https://github.com/atinc/ngx-tethys/issues/2616)) ([e9b925d](https://github.com/atinc/ngx-tethys/commit/e9b925dce96175ac8f2b6eb1a48503391f877fc3)), closes [#INFR-5569](https://github.com/atinc/ngx-tethys/issues/INFR-5569) [#INFR-5569](https://github.com/atinc/ngx-tethys/issues/INFR-5569)
|
|
12
|
+
* **layout:** fix can't operate layout content ([#2635](https://github.com/atinc/ngx-tethys/issues/2635)) ([0c7ce6f](https://github.com/atinc/ngx-tethys/commit/0c7ce6f506db35fec9f523b2b3f5087df8810d64))
|
|
13
|
+
* **tree:** fix the problem of clicking to disable the parent node #INFR-7545 ([#2639](https://github.com/atinc/ngx-tethys/issues/2639)) ([4936aba](https://github.com/atinc/ngx-tethys/commit/4936aba4890c891f5792bf46d6df86802e095e3a)), closes [#INFR-7545](https://github.com/atinc/ngx-tethys/issues/INFR-7545)
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
### Features
|
|
17
|
+
|
|
18
|
+
* **color-picker:** support hover trigger #INFR-7525 ([#2642](https://github.com/atinc/ngx-tethys/issues/2642)) ([78b5c7a](https://github.com/atinc/ngx-tethys/commit/78b5c7ac34e5fc897cbdac40579c12aeee25d991)), closes [#INFR-7525](https://github.com/atinc/ngx-tethys/issues/INFR-7525)
|
|
19
|
+
* **color-picker:** support thyPlacement params #INFR-7526 ([#2637](https://github.com/atinc/ngx-tethys/issues/2637)) ([366f742](https://github.com/atinc/ngx-tethys/commit/366f742859fd39c4f61ff04c2715aae96632a05b)), closes [#INFR-7526](https://github.com/atinc/ngx-tethys/issues/INFR-7526)
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
## [15.2.6](https://github.com/atinc/ngx-tethys/compare/15.2.4...15.2.6) (2023-04-26)
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
### Bug Fixes
|
|
27
|
+
|
|
28
|
+
* **date-picker:** compatibility null values at updateHourMinute ([#2633](https://github.com/atinc/ngx-tethys/issues/2633)) ([1207c47](https://github.com/atinc/ngx-tethys/commit/1207c473f98c18d8a30dc4d2e00b002b86aeb246))
|
|
29
|
+
* **layout:** collapse dom appears when the mouse hovers over the sidebar #INFR-5569 ([#2616](https://github.com/atinc/ngx-tethys/issues/2616)) ([e9b925d](https://github.com/atinc/ngx-tethys/commit/e9b925dce96175ac8f2b6eb1a48503391f877fc3)), closes [#INFR-5569](https://github.com/atinc/ngx-tethys/issues/INFR-5569) [#INFR-5569](https://github.com/atinc/ngx-tethys/issues/INFR-5569)
|
|
30
|
+
* **layout:** fix can't operate layout content ([#2635](https://github.com/atinc/ngx-tethys/issues/2635)) ([0c7ce6f](https://github.com/atinc/ngx-tethys/commit/0c7ce6f506db35fec9f523b2b3f5087df8810d64))
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
|
|
5
34
|
## [15.2.5](https://github.com/atinc/ngx-tethys/compare/15.2.4...15.2.5) (2023-04-26)
|
|
6
35
|
|
|
7
36
|
|
|
@@ -1,14 +1,17 @@
|
|
|
1
|
+
import { FocusMonitor } from '@angular/cdk/a11y';
|
|
2
|
+
import { Platform } from '@angular/cdk/platform';
|
|
1
3
|
import { ElementRef, EventEmitter, NgZone, OnDestroy, OnInit } from '@angular/core';
|
|
4
|
+
import { ThyOverlayDirectiveBase, ThyPlacement, ThyOverlayTrigger } from 'ngx-tethys/core';
|
|
2
5
|
import { ThyPopover } from 'ngx-tethys/popover';
|
|
3
6
|
import * as i0 from "@angular/core";
|
|
4
7
|
/**
|
|
5
8
|
* 颜色选择组件
|
|
6
9
|
* @name thyColorPicker
|
|
7
10
|
*/
|
|
8
|
-
export declare class ThyColorPickerDirective implements OnInit, OnDestroy {
|
|
11
|
+
export declare class ThyColorPickerDirective extends ThyOverlayDirectiveBase implements OnInit, OnDestroy {
|
|
9
12
|
private thyPopover;
|
|
10
13
|
private zone;
|
|
11
|
-
|
|
14
|
+
protected elementRef: ElementRef<HTMLElement>;
|
|
12
15
|
/**
|
|
13
16
|
* 弹框偏移量。
|
|
14
17
|
* @type number
|
|
@@ -30,6 +33,11 @@ export declare class ThyColorPickerDirective implements OnInit, OnDestroy {
|
|
|
30
33
|
* 预设的快捷选择颜色。
|
|
31
34
|
*/
|
|
32
35
|
thyPresetColors: string[];
|
|
36
|
+
/**
|
|
37
|
+
* 颜色面板弹出位置 'top' | 'topLeft' | 'topRight' | 'bottom' | 'bottomLeft' | 'bottomRight' | 'left' | 'leftTop' | 'leftBottom' | 'right' | 'rightTop' | 'rightBottom'
|
|
38
|
+
* @type ThyPlacement
|
|
39
|
+
*/
|
|
40
|
+
thyPlacement: ThyPlacement;
|
|
33
41
|
/**
|
|
34
42
|
* panel 展开后触发
|
|
35
43
|
*/
|
|
@@ -38,21 +46,37 @@ export declare class ThyColorPickerDirective implements OnInit, OnDestroy {
|
|
|
38
46
|
* panel 关闭后触发
|
|
39
47
|
*/
|
|
40
48
|
thyPanelClose: EventEmitter<void>;
|
|
49
|
+
/**
|
|
50
|
+
* 弹出悬浮层的触发方式
|
|
51
|
+
* @type 'hover' | 'click'
|
|
52
|
+
* @default click
|
|
53
|
+
*/
|
|
54
|
+
set thyTrigger(trigger: ThyOverlayTrigger);
|
|
55
|
+
/**
|
|
56
|
+
* 显示延迟时间
|
|
57
|
+
*/
|
|
58
|
+
set thyShowDelay(value: number);
|
|
59
|
+
/**
|
|
60
|
+
* 隐藏延迟时间
|
|
61
|
+
*/
|
|
62
|
+
set thyHideDelay(value: number);
|
|
41
63
|
private onChangeFn;
|
|
42
64
|
private onTouchFn;
|
|
43
65
|
color: string;
|
|
44
66
|
private popoverRef;
|
|
67
|
+
private closePanel;
|
|
45
68
|
private destroy$;
|
|
46
69
|
get backgroundColor(): string;
|
|
47
|
-
constructor(thyPopover: ThyPopover, zone: NgZone, elementRef: ElementRef<HTMLElement
|
|
70
|
+
constructor(thyPopover: ThyPopover, zone: NgZone, elementRef: ElementRef<HTMLElement>, platform: Platform, focusMonitor: FocusMonitor);
|
|
48
71
|
ngOnInit(): void;
|
|
49
|
-
togglePanel(
|
|
50
|
-
|
|
72
|
+
togglePanel(): import("@angular/cdk/overlay").OverlayRef;
|
|
73
|
+
show(delay?: number): void;
|
|
74
|
+
hide(delay?: number): void;
|
|
51
75
|
writeValue(value: string): void;
|
|
52
76
|
registerOnChange(fn: any): void;
|
|
53
77
|
registerOnTouched(fn: any): void;
|
|
54
78
|
onModelChange(value: string): void;
|
|
55
79
|
ngOnDestroy(): void;
|
|
56
80
|
static ɵfac: i0.ɵɵFactoryDeclaration<ThyColorPickerDirective, never>;
|
|
57
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<ThyColorPickerDirective, "[thyColorPicker]", never, { "thyOffset": "thyOffset"; "thyHasBackdrop": "thyHasBackdrop"; "thyDefaultColor": "thyDefaultColor"; "thyTransparentColorSelectable": "thyTransparentColorSelectable"; "thyPresetColors": "thyPresetColors"; }, { "thyPanelOpen": "thyPanelOpen"; "thyPanelClose": "thyPanelClose"; }, never, never, true, never>;
|
|
81
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<ThyColorPickerDirective, "[thyColorPicker]", never, { "thyOffset": "thyOffset"; "thyHasBackdrop": "thyHasBackdrop"; "thyDefaultColor": "thyDefaultColor"; "thyTransparentColorSelectable": "thyTransparentColorSelectable"; "thyPresetColors": "thyPresetColors"; "thyPlacement": "thyPlacement"; "thyTrigger": "thyTrigger"; "thyShowDelay": "thyShowDelay"; "thyHideDelay": "thyHideDelay"; }, { "thyPanelOpen": "thyPanelOpen"; "thyPanelClose": "thyPanelClose"; }, never, never, true, never>;
|
|
58
82
|
}
|
|
@@ -1,24 +1,49 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
+
import { FocusMonitor } from '@angular/cdk/a11y';
|
|
3
|
+
import { Platform } from '@angular/cdk/platform';
|
|
2
4
|
import { Directive, ElementRef, EventEmitter, forwardRef, Input, NgZone, Output } from '@angular/core';
|
|
3
5
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
-
import { InputBoolean, InputNumber } from 'ngx-tethys/core';
|
|
6
|
+
import { InputBoolean, InputNumber, ThyOverlayDirectiveBase } from 'ngx-tethys/core';
|
|
5
7
|
import { ThyPopover } from 'ngx-tethys/popover';
|
|
6
8
|
import { fromEvent, Subject } from 'rxjs';
|
|
7
|
-
import { takeUntil } from 'rxjs/operators';
|
|
8
9
|
import { ThyColorPickerPanelComponent } from './color-picker-panel.component';
|
|
9
10
|
import { DEFAULT_COLORS } from './constant';
|
|
10
11
|
import ThyColor from './helpers/color.class';
|
|
12
|
+
import { takeUntil } from 'rxjs/operators';
|
|
11
13
|
import * as i0 from "@angular/core";
|
|
12
14
|
import * as i1 from "ngx-tethys/popover";
|
|
15
|
+
import * as i2 from "@angular/cdk/platform";
|
|
16
|
+
import * as i3 from "@angular/cdk/a11y";
|
|
13
17
|
/**
|
|
14
18
|
* 颜色选择组件
|
|
15
19
|
* @name thyColorPicker
|
|
16
20
|
*/
|
|
17
|
-
export class ThyColorPickerDirective {
|
|
21
|
+
export class ThyColorPickerDirective extends ThyOverlayDirectiveBase {
|
|
22
|
+
/**
|
|
23
|
+
* 弹出悬浮层的触发方式
|
|
24
|
+
* @type 'hover' | 'click'
|
|
25
|
+
* @default click
|
|
26
|
+
*/
|
|
27
|
+
set thyTrigger(trigger) {
|
|
28
|
+
this.trigger = trigger;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* 显示延迟时间
|
|
32
|
+
*/
|
|
33
|
+
set thyShowDelay(value) {
|
|
34
|
+
this.showDelay = value;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* 隐藏延迟时间
|
|
38
|
+
*/
|
|
39
|
+
set thyHideDelay(value) {
|
|
40
|
+
this.hideDelay = value;
|
|
41
|
+
}
|
|
18
42
|
get backgroundColor() {
|
|
19
43
|
return this.color;
|
|
20
44
|
}
|
|
21
|
-
constructor(thyPopover, zone, elementRef) {
|
|
45
|
+
constructor(thyPopover, zone, elementRef, platform, focusMonitor) {
|
|
46
|
+
super(elementRef, platform, focusMonitor, zone, true);
|
|
22
47
|
this.thyPopover = thyPopover;
|
|
23
48
|
this.zone = zone;
|
|
24
49
|
this.elementRef = elementRef;
|
|
@@ -39,6 +64,11 @@ export class ThyColorPickerDirective {
|
|
|
39
64
|
* 预设的快捷选择颜色。
|
|
40
65
|
*/
|
|
41
66
|
this.thyPresetColors = DEFAULT_COLORS;
|
|
67
|
+
/**
|
|
68
|
+
* 颜色面板弹出位置 'top' | 'topLeft' | 'topRight' | 'bottom' | 'bottomLeft' | 'bottomRight' | 'left' | 'leftTop' | 'leftBottom' | 'right' | 'rightTop' | 'rightBottom'
|
|
69
|
+
* @type ThyPlacement
|
|
70
|
+
*/
|
|
71
|
+
this.thyPlacement = 'bottom';
|
|
42
72
|
/**
|
|
43
73
|
* panel 展开后触发
|
|
44
74
|
*/
|
|
@@ -49,32 +79,56 @@ export class ThyColorPickerDirective {
|
|
|
49
79
|
this.thyPanelClose = new EventEmitter();
|
|
50
80
|
this.onChangeFn = () => { };
|
|
51
81
|
this.onTouchFn = () => { };
|
|
82
|
+
this.closePanel = true;
|
|
52
83
|
this.destroy$ = new Subject();
|
|
53
84
|
}
|
|
54
85
|
ngOnInit() {
|
|
55
|
-
this.
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
86
|
+
this.initialize();
|
|
87
|
+
if (this.trigger === 'hover') {
|
|
88
|
+
this.ngZone.runOutsideAngular(() => {
|
|
89
|
+
return fromEvent(document, 'mousemove')
|
|
90
|
+
.pipe(takeUntil(this.destroy$))
|
|
91
|
+
.subscribe(event => {
|
|
92
|
+
if (this.popoverRef?.getOverlayRef()?.hasAttached()) {
|
|
93
|
+
if (this.elementRef.nativeElement.contains(event.target) ||
|
|
94
|
+
event.target.closest('.thy-color-picker-custom-panel') ||
|
|
95
|
+
!!event.target.querySelector('.thy-color-picker-custom-panel') ||
|
|
96
|
+
this.popoverRef.getOverlayRef()?.hostElement?.contains(event.target)) {
|
|
97
|
+
this.closePanel = false;
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
this.closePanel = true;
|
|
101
|
+
this.popoverRef.close();
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
});
|
|
60
105
|
});
|
|
61
|
-
}
|
|
106
|
+
}
|
|
62
107
|
}
|
|
63
|
-
togglePanel(
|
|
108
|
+
togglePanel() {
|
|
109
|
+
this.closePanel = false;
|
|
64
110
|
this.popoverRef = this.thyPopover.open(ThyColorPickerPanelComponent, {
|
|
65
|
-
origin:
|
|
111
|
+
origin: this.elementRef.nativeElement,
|
|
66
112
|
offset: this.thyOffset,
|
|
67
113
|
manualClosure: true,
|
|
68
114
|
width: '286px',
|
|
115
|
+
placement: this.thyPlacement,
|
|
69
116
|
originActiveClass: 'thy-default-picker-active',
|
|
70
117
|
hasBackdrop: this.thyHasBackdrop,
|
|
71
118
|
outsideClosable: false,
|
|
119
|
+
canClose: () => {
|
|
120
|
+
if (this.trigger === 'hover') {
|
|
121
|
+
return this.closePanel;
|
|
122
|
+
}
|
|
123
|
+
return true;
|
|
124
|
+
},
|
|
72
125
|
initialState: {
|
|
73
126
|
color: new ThyColor(this.color).toHexString(true),
|
|
74
127
|
defaultColor: this.thyDefaultColor,
|
|
75
128
|
transparentColorSelectable: this.thyTransparentColorSelectable,
|
|
76
129
|
defaultColors: this.thyPresetColors,
|
|
77
130
|
colorChange: (value) => {
|
|
131
|
+
this.closePanel = true;
|
|
78
132
|
this.onModelChange(value);
|
|
79
133
|
}
|
|
80
134
|
}
|
|
@@ -100,9 +154,36 @@ export class ThyColorPickerDirective {
|
|
|
100
154
|
}
|
|
101
155
|
});
|
|
102
156
|
}
|
|
157
|
+
return this.popoverRef.getOverlayRef();
|
|
103
158
|
}
|
|
104
|
-
|
|
105
|
-
this.
|
|
159
|
+
show(delay = this.showDelay) {
|
|
160
|
+
if (this.hideTimeoutId) {
|
|
161
|
+
clearTimeout(this.hideTimeoutId);
|
|
162
|
+
this.hideTimeoutId = null;
|
|
163
|
+
}
|
|
164
|
+
if (this.disabled || (this.overlayRef && this.overlayRef.hasAttached())) {
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
if (this.trigger !== 'hover') {
|
|
168
|
+
delay = 0;
|
|
169
|
+
}
|
|
170
|
+
this.showTimeoutId = setTimeout(() => {
|
|
171
|
+
const overlayRef = this.togglePanel();
|
|
172
|
+
this.overlayRef = overlayRef;
|
|
173
|
+
this.showTimeoutId = null;
|
|
174
|
+
}, delay);
|
|
175
|
+
}
|
|
176
|
+
hide(delay = this.hideDelay) {
|
|
177
|
+
if (this.showTimeoutId) {
|
|
178
|
+
clearTimeout(this.showTimeoutId);
|
|
179
|
+
this.showTimeoutId = null;
|
|
180
|
+
}
|
|
181
|
+
this.hideTimeoutId = setTimeout(() => {
|
|
182
|
+
if (this.popoverRef) {
|
|
183
|
+
this.popoverRef?.getOverlayRef()?.hasAttached() && this.popoverRef.close();
|
|
184
|
+
}
|
|
185
|
+
this.hideTimeoutId = null;
|
|
186
|
+
}, delay);
|
|
106
187
|
}
|
|
107
188
|
writeValue(value) {
|
|
108
189
|
this.color = value;
|
|
@@ -121,17 +202,18 @@ export class ThyColorPickerDirective {
|
|
|
121
202
|
this.destroy$.next();
|
|
122
203
|
this.destroy$.complete();
|
|
123
204
|
this.hide();
|
|
205
|
+
this.dispose();
|
|
124
206
|
this.popoverRef = null;
|
|
125
207
|
}
|
|
126
208
|
}
|
|
127
|
-
ThyColorPickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ThyColorPickerDirective, deps: [{ token: i1.ThyPopover }, { token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
128
|
-
ThyColorPickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.2", type: ThyColorPickerDirective, isStandalone: true, selector: "[thyColorPicker]", inputs: { thyOffset: "thyOffset", thyHasBackdrop: "thyHasBackdrop", thyDefaultColor: "thyDefaultColor", thyTransparentColorSelectable: "thyTransparentColorSelectable", thyPresetColors: "thyPresetColors" }, outputs: { thyPanelOpen: "thyPanelOpen", thyPanelClose: "thyPanelClose" }, providers: [
|
|
209
|
+
ThyColorPickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ThyColorPickerDirective, deps: [{ token: i1.ThyPopover }, { token: i0.NgZone }, { token: i0.ElementRef }, { token: i2.Platform }, { token: i3.FocusMonitor }], target: i0.ɵɵFactoryTarget.Directive });
|
|
210
|
+
ThyColorPickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.2", type: ThyColorPickerDirective, isStandalone: true, selector: "[thyColorPicker]", inputs: { thyOffset: "thyOffset", thyHasBackdrop: "thyHasBackdrop", thyDefaultColor: "thyDefaultColor", thyTransparentColorSelectable: "thyTransparentColorSelectable", thyPresetColors: "thyPresetColors", thyPlacement: "thyPlacement", thyTrigger: "thyTrigger", thyShowDelay: "thyShowDelay", thyHideDelay: "thyHideDelay" }, outputs: { thyPanelOpen: "thyPanelOpen", thyPanelClose: "thyPanelClose" }, providers: [
|
|
129
211
|
{
|
|
130
212
|
provide: NG_VALUE_ACCESSOR,
|
|
131
213
|
multi: true,
|
|
132
214
|
useExisting: forwardRef(() => ThyColorPickerDirective)
|
|
133
215
|
}
|
|
134
|
-
], ngImport: i0 });
|
|
216
|
+
], usesInheritance: true, ngImport: i0 });
|
|
135
217
|
__decorate([
|
|
136
218
|
InputNumber(),
|
|
137
219
|
__metadata("design:type", Number)
|
|
@@ -144,6 +226,16 @@ __decorate([
|
|
|
144
226
|
InputBoolean(),
|
|
145
227
|
__metadata("design:type", Boolean)
|
|
146
228
|
], ThyColorPickerDirective.prototype, "thyTransparentColorSelectable", void 0);
|
|
229
|
+
__decorate([
|
|
230
|
+
InputNumber(),
|
|
231
|
+
__metadata("design:type", Number),
|
|
232
|
+
__metadata("design:paramtypes", [Number])
|
|
233
|
+
], ThyColorPickerDirective.prototype, "thyShowDelay", null);
|
|
234
|
+
__decorate([
|
|
235
|
+
InputNumber(),
|
|
236
|
+
__metadata("design:type", Number),
|
|
237
|
+
__metadata("design:paramtypes", [Number])
|
|
238
|
+
], ThyColorPickerDirective.prototype, "thyHideDelay", null);
|
|
147
239
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ThyColorPickerDirective, decorators: [{
|
|
148
240
|
type: Directive,
|
|
149
241
|
args: [{
|
|
@@ -157,7 +249,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
|
|
|
157
249
|
],
|
|
158
250
|
standalone: true
|
|
159
251
|
}]
|
|
160
|
-
}], ctorParameters: function () { return [{ type: i1.ThyPopover }, { type: i0.NgZone }, { type: i0.ElementRef }]; }, propDecorators: { thyOffset: [{
|
|
252
|
+
}], ctorParameters: function () { return [{ type: i1.ThyPopover }, { type: i0.NgZone }, { type: i0.ElementRef }, { type: i2.Platform }, { type: i3.FocusMonitor }]; }, propDecorators: { thyOffset: [{
|
|
161
253
|
type: Input
|
|
162
254
|
}], thyHasBackdrop: [{
|
|
163
255
|
type: Input
|
|
@@ -167,9 +259,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
|
|
|
167
259
|
type: Input
|
|
168
260
|
}], thyPresetColors: [{
|
|
169
261
|
type: Input
|
|
262
|
+
}], thyPlacement: [{
|
|
263
|
+
type: Input
|
|
170
264
|
}], thyPanelOpen: [{
|
|
171
265
|
type: Output
|
|
172
266
|
}], thyPanelClose: [{
|
|
173
267
|
type: Output
|
|
268
|
+
}], thyTrigger: [{
|
|
269
|
+
type: Input
|
|
270
|
+
}], thyShowDelay: [{
|
|
271
|
+
type: Input,
|
|
272
|
+
args: ['thyShowDelay']
|
|
273
|
+
}], thyHideDelay: [{
|
|
274
|
+
type: Input,
|
|
275
|
+
args: ['thyHideDelay']
|
|
174
276
|
}] } });
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../src/color-picker/color-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, forwardRef, Input, NgZone, OnDestroy, OnInit, Output } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { InputBoolean, InputNumber } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { ThyColorPickerPanelComponent } from './color-picker-panel.component';\nimport { DEFAULT_COLORS } from './constant';\nimport ThyColor from './helpers/color.class';\n\n/**\n * 颜色选择组件\n * @name thyColorPicker\n */\n@Directive({\n    selector: '[thyColorPicker]',\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            multi: true,\n            useExisting: forwardRef(() => ThyColorPickerDirective)\n        }\n    ],\n    standalone: true\n})\nexport class ThyColorPickerDirective implements OnInit, OnDestroy {\n    /**\n     * 弹框偏移量。\n     * @type  number\n     */\n    @Input() @InputNumber() thyOffset: number = 0;\n\n    /**\n     * 颜色选择面板是否有幕布。\n     */\n    @Input() @InputBoolean() thyHasBackdrop: boolean = true;\n\n    /**\n     * 设置颜色选择面板的默认颜色选项值。\n     */\n    @Input() thyDefaultColor: string;\n\n    /**\n     * 是否显示'无填充色'选项。\n     */\n    @Input() @InputBoolean() thyTransparentColorSelectable: boolean = true;\n\n    /**\n     * 预设的快捷选择颜色。\n     */\n    @Input() thyPresetColors: string[] = DEFAULT_COLORS;\n\n    /**\n     * panel 展开后触发\n     */\n    @Output() thyPanelOpen: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * panel 关闭后触发\n     */\n    @Output() thyPanelClose: EventEmitter<void> = new EventEmitter<void>();\n\n    private onChangeFn: (value: number | string) => void = () => {};\n\n    private onTouchFn: () => void = () => {};\n\n    color: string;\n\n    private popoverRef: ThyPopoverRef<ThyColorPickerPanelComponent>;\n\n    private destroy$ = new Subject<void>();\n\n    public get backgroundColor(): string {\n        return this.color;\n    }\n\n    constructor(private thyPopover: ThyPopover, private zone: NgZone, private elementRef: ElementRef<HTMLElement>) {}\n\n    ngOnInit(): void {\n        this.zone.runOutsideAngular(() => {\n            fromEvent<Event>(this.elementRef.nativeElement, 'click')\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(event => {\n                    this.zone.run(() => this.togglePanel(event));\n                });\n        });\n    }\n\n    togglePanel(event: Event) {\n        this.popoverRef = this.thyPopover.open(ThyColorPickerPanelComponent, {\n            origin: event.currentTarget as HTMLElement,\n            offset: this.thyOffset,\n            manualClosure: true,\n            width: '286px',\n            originActiveClass: 'thy-default-picker-active',\n            hasBackdrop: this.thyHasBackdrop,\n            outsideClosable: false,\n            initialState: {\n                color: new ThyColor(this.color).toHexString(true),\n                defaultColor: this.thyDefaultColor,\n                transparentColorSelectable: this.thyTransparentColorSelectable,\n                defaultColors: this.thyPresetColors,\n                colorChange: (value: string) => {\n                    this.onModelChange(value);\n                }\n            }\n        });\n        if (this.popoverRef) {\n            this.popoverRef.afterOpened().subscribe(() => {\n                this.thyPanelOpen.emit();\n            });\n            this.popoverRef.afterClosed().subscribe(() => {\n                this.thyPanelClose.emit();\n            });\n        }\n        if (this.popoverRef && !this.thyHasBackdrop) {\n            this.popoverRef\n                .getOverlayRef()\n                .outsidePointerEvents()\n                .subscribe(event => {\n                    if ((event.target as HTMLElement).closest('.thy-color-picker-custom-panel')) {\n                        return;\n                    }\n                    if (!this.popoverRef.getOverlayRef().hostElement.contains(event.target as HTMLElement)) {\n                        this.popoverRef.close();\n                    }\n                });\n        }\n    }\n\n    hide() {\n        this.popoverRef?.getOverlayRef()?.hasAttached() && this.popoverRef.close();\n    }\n\n    writeValue(value: string): void {\n        this.color = value;\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchFn = fn;\n    }\n\n    onModelChange(value: string): void {\n        this.color = value;\n        this.onChangeFn(value);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        this.hide();\n        this.popoverRef = null;\n    }\n}\n"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../src/color-picker/color-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport { Platform } from '@angular/cdk/platform';\nimport { Directive, ElementRef, EventEmitter, forwardRef, Input, NgZone, OnDestroy, OnInit, Output } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { InputBoolean, InputNumber, ThyOverlayDirectiveBase, ThyPlacement, ThyOverlayTrigger } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { fromEvent, Subject } from 'rxjs';\nimport { ThyColorPickerPanelComponent } from './color-picker-panel.component';\nimport { DEFAULT_COLORS } from './constant';\nimport ThyColor from './helpers/color.class';\nimport { takeUntil } from 'rxjs/operators';\n\n/**\n * 颜色选择组件\n * @name thyColorPicker\n */\n@Directive({\n    selector: '[thyColorPicker]',\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            multi: true,\n            useExisting: forwardRef(() => ThyColorPickerDirective)\n        }\n    ],\n    standalone: true\n})\nexport class ThyColorPickerDirective extends ThyOverlayDirectiveBase implements OnInit, OnDestroy {\n    /**\n     * 弹框偏移量。\n     * @type  number\n     */\n    @Input() @InputNumber() thyOffset: number = 0;\n\n    /**\n     * 颜色选择面板是否有幕布。\n     */\n    @Input() @InputBoolean() thyHasBackdrop: boolean = true;\n\n    /**\n     * 设置颜色选择面板的默认颜色选项值。\n     */\n    @Input() thyDefaultColor: string;\n\n    /**\n     * 是否显示'无填充色'选项。\n     */\n    @Input() @InputBoolean() thyTransparentColorSelectable: boolean = true;\n\n    /**\n     * 预设的快捷选择颜色。\n     */\n    @Input() thyPresetColors: string[] = DEFAULT_COLORS;\n\n    /**\n     * 颜色面板弹出位置 'top' | 'topLeft' | 'topRight' | 'bottom' | 'bottomLeft' | 'bottomRight' | 'left' | 'leftTop' | 'leftBottom' | 'right' | 'rightTop' | 'rightBottom'\n     * @type ThyPlacement\n     */\n    @Input() thyPlacement: ThyPlacement = 'bottom';\n\n    /**\n     * panel 展开后触发\n     */\n    @Output() thyPanelOpen: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * panel 关闭后触发\n     */\n    @Output() thyPanelClose: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * 弹出悬浮层的触发方式\n     * @type 'hover' | 'click'\n     * @default click\n     */\n    @Input() set thyTrigger(trigger: ThyOverlayTrigger) {\n        this.trigger = trigger;\n    }\n\n    /**\n     * 显示延迟时间\n     */\n    @Input('thyShowDelay')\n    @InputNumber()\n    set thyShowDelay(value: number) {\n        this.showDelay = value;\n    }\n\n    /**\n     * 隐藏延迟时间\n     */\n    @Input('thyHideDelay')\n    @InputNumber()\n    set thyHideDelay(value: number) {\n        this.hideDelay = value;\n    }\n\n    private onChangeFn: (value: number | string) => void = () => {};\n\n    private onTouchFn: () => void = () => {};\n\n    color: string;\n\n    private popoverRef: ThyPopoverRef<ThyColorPickerPanelComponent>;\n\n    private closePanel = true;\n\n    private destroy$ = new Subject<void>();\n\n    public get backgroundColor(): string {\n        return this.color;\n    }\n\n    constructor(\n        private thyPopover: ThyPopover,\n        private zone: NgZone,\n        protected elementRef: ElementRef<HTMLElement>,\n        platform: Platform,\n        focusMonitor: FocusMonitor\n    ) {\n        super(elementRef, platform, focusMonitor, zone, true);\n    }\n\n    ngOnInit(): void {\n        this.initialize();\n        if (this.trigger === 'hover') {\n            this.ngZone.runOutsideAngular(() => {\n                return fromEvent(document, 'mousemove')\n                    .pipe(takeUntil(this.destroy$))\n                    .subscribe(event => {\n                        if (this.popoverRef?.getOverlayRef()?.hasAttached()) {\n                            if (\n                                this.elementRef.nativeElement.contains(event.target as HTMLElement) ||\n                                (event.target as HTMLElement).closest('.thy-color-picker-custom-panel') ||\n                                !!(event.target as HTMLElement).querySelector('.thy-color-picker-custom-panel') ||\n                                this.popoverRef.getOverlayRef()?.hostElement?.contains(event.target as HTMLElement)\n                            ) {\n                                this.closePanel = false;\n                            } else {\n                                this.closePanel = true;\n                                this.popoverRef.close();\n                            }\n                        }\n                    });\n            });\n        }\n    }\n\n    togglePanel() {\n        this.closePanel = false;\n        this.popoverRef = this.thyPopover.open(ThyColorPickerPanelComponent, {\n            origin: this.elementRef.nativeElement as HTMLElement,\n            offset: this.thyOffset,\n            manualClosure: true,\n            width: '286px',\n            placement: this.thyPlacement,\n            originActiveClass: 'thy-default-picker-active',\n            hasBackdrop: this.thyHasBackdrop,\n            outsideClosable: false,\n            canClose: () => {\n                if (this.trigger === 'hover') {\n                    return this.closePanel;\n                }\n                return true;\n            },\n            initialState: {\n                color: new ThyColor(this.color).toHexString(true),\n                defaultColor: this.thyDefaultColor,\n                transparentColorSelectable: this.thyTransparentColorSelectable,\n                defaultColors: this.thyPresetColors,\n                colorChange: (value: string) => {\n                    this.closePanel = true;\n                    this.onModelChange(value);\n                }\n            }\n        });\n        if (this.popoverRef) {\n            this.popoverRef.afterOpened().subscribe(() => {\n                this.thyPanelOpen.emit();\n            });\n            this.popoverRef.afterClosed().subscribe(() => {\n                this.thyPanelClose.emit();\n            });\n        }\n        if (this.popoverRef && !this.thyHasBackdrop) {\n            this.popoverRef\n                .getOverlayRef()\n                .outsidePointerEvents()\n                .subscribe(event => {\n                    if ((event.target as HTMLElement).closest('.thy-color-picker-custom-panel')) {\n                        return;\n                    }\n                    if (!this.popoverRef.getOverlayRef().hostElement.contains(event.target as HTMLElement)) {\n                        this.popoverRef.close();\n                    }\n                });\n        }\n        return this.popoverRef.getOverlayRef();\n    }\n\n    show(delay: number = this.showDelay): void {\n        if (this.hideTimeoutId) {\n            clearTimeout(this.hideTimeoutId);\n            this.hideTimeoutId = null;\n        }\n\n        if (this.disabled || (this.overlayRef && this.overlayRef.hasAttached())) {\n            return;\n        }\n        if (this.trigger !== 'hover') {\n            delay = 0;\n        }\n\n        this.showTimeoutId = setTimeout(() => {\n            const overlayRef = this.togglePanel();\n            this.overlayRef = overlayRef;\n            this.showTimeoutId = null;\n        }, delay);\n    }\n\n    hide(delay: number = this.hideDelay) {\n        if (this.showTimeoutId) {\n            clearTimeout(this.showTimeoutId);\n            this.showTimeoutId = null;\n        }\n\n        this.hideTimeoutId = setTimeout(() => {\n            if (this.popoverRef) {\n                this.popoverRef?.getOverlayRef()?.hasAttached() && this.popoverRef.close();\n            }\n            this.hideTimeoutId = null;\n        }, delay);\n    }\n\n    writeValue(value: string): void {\n        this.color = value;\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchFn = fn;\n    }\n\n    onModelChange(value: string): void {\n        this.color = value;\n        this.onChangeFn(value);\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n        this.hide();\n        this.dispose();\n        this.popoverRef = null;\n    }\n}\n"]}
|
|
@@ -62,7 +62,7 @@ export class DialogHeaderComponent {
|
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
64
|
DialogHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: DialogHeaderComponent, deps: [{ token: i0.ElementRef }, { token: i1.ThyDialog }, { token: i2.ThyTranslate }, { token: i3.ThyDialogContainerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
65
|
-
DialogHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.2", type: DialogHeaderComponent, isStandalone: true, selector: "thy-dialog-header", inputs: { thyTitle: "thyTitle", thySize: "thySize", thyDivided: "thyDivided", thyTitleTranslationKey: "thyTitleTranslationKey", thyIcon: "thyIcon" }, outputs: { thyOnClose: "thyOnClose" }, host: { properties: { "class.thy-dialog-header-lg": "thySize === 'lg'", "class.thy-dialog-header-divided": "thyDivided" }, classAttribute: "dialog-header thy-dialog-header" }, queries: [{ propertyName: "headerTemplate", first: true, predicate: ["dialogHeader"], descendants: true }], exportAs: ["thyDialogHeader"], ngImport: i0, template: "<ng-container *ngIf=\"headerTemplate; else defaultHeader\">\n <template [ngTemplateOutlet]=\"headerTemplate\"></template>\n</ng-container>\n<ng-template #defaultHeader>\n <h3 class=\"dialog-title\"><thy-icon [thyIconName]=\"thyIcon\"></thy-icon>{{ thyTitle }}</h3>\n <a href=\"javascript:;\" class=\"mr-n2\" thyAction thyActionIcon=\"close
|
|
65
|
+
DialogHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.2", type: DialogHeaderComponent, isStandalone: true, selector: "thy-dialog-header", inputs: { thyTitle: "thyTitle", thySize: "thySize", thyDivided: "thyDivided", thyTitleTranslationKey: "thyTitleTranslationKey", thyIcon: "thyIcon" }, outputs: { thyOnClose: "thyOnClose" }, host: { properties: { "class.thy-dialog-header-lg": "thySize === 'lg'", "class.thy-dialog-header-divided": "thyDivided" }, classAttribute: "dialog-header thy-dialog-header" }, queries: [{ propertyName: "headerTemplate", first: true, predicate: ["dialogHeader"], descendants: true }], exportAs: ["thyDialogHeader"], ngImport: i0, template: "<ng-container *ngIf=\"headerTemplate; else defaultHeader\">\n <template [ngTemplateOutlet]=\"headerTemplate\"></template>\n</ng-container>\n<ng-template #defaultHeader>\n <h3 class=\"dialog-title\"><thy-icon [thyIconName]=\"thyIcon\"></thy-icon>{{ thyTitle }}</h3>\n <a href=\"javascript:;\" class=\"mr-n2\" thyAction thyActionIcon=\"close\" (click)=\"close($event)\"></a>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }] });
|
|
66
66
|
__decorate([
|
|
67
67
|
InputBoolean(),
|
|
68
68
|
__metadata("design:type", Boolean)
|
|
@@ -73,7 +73,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
|
|
|
73
73
|
class: 'dialog-header thy-dialog-header',
|
|
74
74
|
'[class.thy-dialog-header-lg]': `thySize === 'lg'`,
|
|
75
75
|
'[class.thy-dialog-header-divided]': `thyDivided`
|
|
76
|
-
}, standalone: true, imports: [NgIf, NgTemplateOutlet, ThyIconComponent, ThyActionComponent], template: "<ng-container *ngIf=\"headerTemplate; else defaultHeader\">\n <template [ngTemplateOutlet]=\"headerTemplate\"></template>\n</ng-container>\n<ng-template #defaultHeader>\n <h3 class=\"dialog-title\"><thy-icon [thyIconName]=\"thyIcon\"></thy-icon>{{ thyTitle }}</h3>\n <a href=\"javascript:;\" class=\"mr-n2\" thyAction thyActionIcon=\"close
|
|
76
|
+
}, standalone: true, imports: [NgIf, NgTemplateOutlet, ThyIconComponent, ThyActionComponent], template: "<ng-container *ngIf=\"headerTemplate; else defaultHeader\">\n <template [ngTemplateOutlet]=\"headerTemplate\"></template>\n</ng-container>\n<ng-template #defaultHeader>\n <h3 class=\"dialog-title\"><thy-icon [thyIconName]=\"thyIcon\"></thy-icon>{{ thyTitle }}</h3>\n <a href=\"javascript:;\" class=\"mr-n2\" thyAction thyActionIcon=\"close\" (click)=\"close($event)\"></a>\n</ng-template>\n" }]
|
|
77
77
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ThyDialog }, { type: i2.ThyTranslate }, { type: i3.ThyDialogContainerComponent, decorators: [{
|
|
78
78
|
type: Optional
|
|
79
79
|
}] }]; }, propDecorators: { headerTemplate: [{
|
|
@@ -92,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
|
|
|
92
92
|
}], thyOnClose: [{
|
|
93
93
|
type: Output
|
|
94
94
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-header.component.js","sourceRoot":"","sources":["../../../../../src/dialog/header/dialog-header.component.ts","../../../../../src/dialog/header/dialog-header.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAU,QAAQ,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChI,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;;;;;AAEzD;;;;GAIG;AAcH,MAAM,OAAO,qBAAqB;IA0B9B;;OAEG;IACH,IACI,sBAAsB,CAAC,GAAW;QAClC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;SAC/C;IACL,CAAC;IAYD,YACY,UAAsB,EACtB,MAAiB,EACjB,SAAuB,EACX,eAA4C;QAHxD,eAAU,GAAV,UAAU,CAAY;QACtB,WAAM,GAAN,MAAM,CAAW;QACjB,cAAS,GAAT,SAAS,CAAc;QACX,oBAAe,GAAf,eAAe,CAA6B;QATpE;;WAEG;QACO,eAAU,GAAwB,IAAI,YAAY,EAAS,CAAC;IAOnE,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACvB,iFAAiF;YACjF,kGAAkG;YAClG,kGAAkG;YAClG,oFAAoF;YACpF,mCAAmC;YACnC,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAA8B,CAAC;YAC3G,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC;SACzE;QAED,mFAAmF;QACnF,8EAA8E;QAC9E,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACxB,IAAI,IAAI,CAAC,eAAe,EAAE;gBACtB,IAAI,CAAC,eAAe,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC;aACvD;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,KAAa;QACf,IAAI,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC/B;aAAM;YACH,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;SACvB;IACL,CAAC;;kHA/EQ,qBAAqB;sGAArB,qBAAqB,qkBC3BlC,2YAOA,4CDkBc,IAAI,6FAAE,gBAAgB,oJAAE,gBAAgB,sMAAE,kBAAkB;AA0BtE;IAAU,YAAY,EAAE;;yDAAqB;2FAxBpC,qBAAqB;kBAbjC,SAAS;+BACI,mBAAmB,YAGnB,iBAAiB,QACrB;wBACF,KAAK,EAAE,iCAAiC;wBACxC,8BAA8B,EAAE,kBAAkB;wBAClD,mCAAmC,EAAE,YAAY;qBACpD,cACW,IAAI,WACP,CAAC,IAAI,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,kBAAkB,CAAC;;0BAoDlE,QAAQ;4CA5CN,cAAc;sBADpB,YAAY;uBAAC,cAAc;gBAMnB,QAAQ;sBAAhB,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBAMmB,UAAU;sBAAlC,KAAK;gBAMF,sBAAsB;sBADzB,KAAK;gBAUG,OAAO;sBAAf,KAAK;gBAKI,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter, ContentChild, TemplateRef, OnInit, Optional, ElementRef } from '@angular/core';\nimport { ThyDialog } from '../dialog.service';\nimport { ThyDialogContainerComponent } from '../dialog-container.component';\nimport { InputBoolean, ThyTranslate } from 'ngx-tethys/core';\nimport { ThyInternalDialogRef } from '../dialog-ref';\nimport { ThyActionComponent } from 'ngx-tethys/action';\nimport { ThyIconComponent } from 'ngx-tethys/icon';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\n\n/**\n * 模态框头部组件\n * @name thy-dialog-header\n * @order 40\n */\n@Component({\n    selector: 'thy-dialog-header',\n    templateUrl: './dialog-header.component.html',\n    // changeDetection: ChangeDetectionStrategy.OnPush,\n    exportAs: 'thyDialogHeader',\n    host: {\n        class: 'dialog-header thy-dialog-header',\n        '[class.thy-dialog-header-lg]': `thySize === 'lg'`,\n        '[class.thy-dialog-header-divided]': `thyDivided`\n    },\n    standalone: true,\n    imports: [NgIf, NgTemplateOutlet, ThyIconComponent, ThyActionComponent]\n})\nexport class DialogHeaderComponent implements OnInit {\n    /**\n     * 自定义头部模板\n     * @type TemplateRef\n     */\n    @ContentChild('dialogHeader')\n    public headerTemplate: TemplateRef<any>;\n\n    /**\n     * 标题\n     */\n    @Input() thyTitle: string;\n\n    /**\n     * 大小，只有大的详情页场景会使用 lg, 左右 padding 缩小至 20px\n     * @type lg | md\n     * @default md\n     */\n    @Input() thySize: 'lg' | 'md';\n\n    /**\n     * 是否显示分割线\n     * @default false\n     */\n    @Input() @InputBoolean() thyDivided: boolean;\n\n    /**\n     * 标题的多语言 Key\n     */\n    @Input()\n    set thyTitleTranslationKey(key: string) {\n        if (key && !this.thyTitle) {\n            this.thyTitle = this.translate.instant(key);\n        }\n    }\n\n    /**\n     * 头部图标\n     */\n    @Input() thyIcon: string;\n\n    /**\n     * 关闭事件\n     */\n    @Output() thyOnClose: EventEmitter<Event> = new EventEmitter<Event>();\n\n    constructor(\n        private elementRef: ElementRef,\n        private dialog: ThyDialog,\n        private translate: ThyTranslate,\n        @Optional() private dialogContainer: ThyDialogContainerComponent\n    ) {}\n\n    ngOnInit() {\n        if (!this.dialogContainer) {\n            // When this directive is included in a dialog via TemplateRef (rather than being\n            // in a Component), the ThyDialogContainerComponent isn't available via injection because embedded\n            // views cannot be given a custom injector. Instead, we look up the ThyDialogContainerComponent by\n            // ID. This must occur in `onInit`, as the ID binding for the dialog container won't\n            // be resolved at constructor time.\n            const dialogRef = this.dialog.getClosestDialog(this.elementRef.nativeElement) as ThyInternalDialogRef<any>;\n            this.dialogContainer = dialogRef ? dialogRef.containerInstance : null;\n        }\n\n        // change in next microtask avoid throw ExpressionChangedAfterItHasBeenCheckedError\n        // because sub component change parent's HostBinding property (ariaLabelledBy)\n        Promise.resolve().then(() => {\n            if (this.dialogContainer) {\n                this.dialogContainer.ariaLabelledBy = this.thyTitle;\n            }\n        });\n    }\n\n    close(event?: Event) {\n        if (this.thyOnClose.observers.length > 0) {\n            this.thyOnClose.emit(event);\n        } else {\n            this.dialog.close();\n        }\n    }\n}\n","<ng-container *ngIf=\"headerTemplate; else defaultHeader\">\n  <template [ngTemplateOutlet]=\"headerTemplate\"></template>\n</ng-container>\n<ng-template #defaultHeader>\n  <h3 class=\"dialog-title\"><thy-icon [thyIconName]=\"thyIcon\"></thy-icon>{{ thyTitle }}</h3>\n  <a href=\"javascript:;\" class=\"mr-n2\" thyAction thyActionIcon=\"close\" (click)=\"close($event)\"></a>\n</ng-template>\n"]}
|