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.
Files changed (41) hide show
  1. package/CHANGELOG.md +29 -0
  2. package/color-picker/color-picker.component.d.ts +30 -6
  3. package/esm2020/color-picker/color-picker.component.mjs +121 -19
  4. package/esm2020/dialog/header/dialog-header.component.mjs +3 -3
  5. package/esm2020/layout/sidebar.component.mjs +10 -3
  6. package/esm2020/popover/header/popover-header.component.mjs +3 -3
  7. package/esm2020/slide/slide-header/slide-header.component.mjs +3 -3
  8. package/esm2020/tree/tree-node.component.mjs +9 -7
  9. package/esm2020/version.mjs +2 -2
  10. package/fesm2015/ngx-tethys-color-picker.mjs +119 -18
  11. package/fesm2015/ngx-tethys-color-picker.mjs.map +1 -1
  12. package/fesm2015/ngx-tethys-dialog.mjs +2 -2
  13. package/fesm2015/ngx-tethys-dialog.mjs.map +1 -1
  14. package/fesm2015/ngx-tethys-layout.mjs +9 -2
  15. package/fesm2015/ngx-tethys-layout.mjs.map +1 -1
  16. package/fesm2015/ngx-tethys-popover.mjs +2 -2
  17. package/fesm2015/ngx-tethys-popover.mjs.map +1 -1
  18. package/fesm2015/ngx-tethys-slide.mjs +2 -2
  19. package/fesm2015/ngx-tethys-slide.mjs.map +1 -1
  20. package/fesm2015/ngx-tethys-tree.mjs +8 -6
  21. package/fesm2015/ngx-tethys-tree.mjs.map +1 -1
  22. package/fesm2015/ngx-tethys.mjs +1 -1
  23. package/fesm2015/ngx-tethys.mjs.map +1 -1
  24. package/fesm2020/ngx-tethys-color-picker.mjs +117 -17
  25. package/fesm2020/ngx-tethys-color-picker.mjs.map +1 -1
  26. package/fesm2020/ngx-tethys-dialog.mjs +2 -2
  27. package/fesm2020/ngx-tethys-dialog.mjs.map +1 -1
  28. package/fesm2020/ngx-tethys-layout.mjs +9 -2
  29. package/fesm2020/ngx-tethys-layout.mjs.map +1 -1
  30. package/fesm2020/ngx-tethys-popover.mjs +2 -2
  31. package/fesm2020/ngx-tethys-popover.mjs.map +1 -1
  32. package/fesm2020/ngx-tethys-slide.mjs +2 -2
  33. package/fesm2020/ngx-tethys-slide.mjs.map +1 -1
  34. package/fesm2020/ngx-tethys-tree.mjs +8 -6
  35. package/fesm2020/ngx-tethys-tree.mjs.map +1 -1
  36. package/fesm2020/ngx-tethys.mjs +1 -1
  37. package/fesm2020/ngx-tethys.mjs.map +1 -1
  38. package/layout/sidebar.component.d.ts +2 -0
  39. package/package.json +1 -1
  40. package/schematics/version.d.ts +1 -1
  41. 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
- private elementRef;
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(event: Event): void;
50
- hide(): void;
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.zone.runOutsideAngular(() => {
56
- fromEvent(this.elementRef.nativeElement, 'click')
57
- .pipe(takeUntil(this.destroy$))
58
- .subscribe(event => {
59
- this.zone.run(() => this.togglePanel(event));
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(event) {
108
+ togglePanel() {
109
+ this.closePanel = false;
64
110
  this.popoverRef = this.thyPopover.open(ThyColorPickerPanelComponent, {
65
- origin: event.currentTarget,
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
- hide() {
105
- this.popoverRef?.getOverlayRef()?.hasAttached() && this.popoverRef.close();
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-bold\" (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"] }] });
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-bold\" (click)=\"close($event)\"></a>\n</ng-template>\n" }]
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,{"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":"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","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-bold\" (click)=\"close($event)\"></a>\n</ng-template>\n"]}
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":"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","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"]}