ngx-tethys 17.0.2 → 17.0.4

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 (99) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/autocomplete/autocomplete.component.d.ts +2 -5
  3. package/cascader/cascader.component.d.ts +9 -1
  4. package/cascader/cascader.service.d.ts +3 -0
  5. package/drag-drop/drag.directive.d.ts +1 -4
  6. package/drag-drop/drop-container.directive.d.ts +4 -5
  7. package/dropdown/dropdown-submenu.component.d.ts +3 -6
  8. package/esm2022/autocomplete/autocomplete.component.mjs +7 -14
  9. package/esm2022/button/button-group.component.mjs +2 -2
  10. package/esm2022/cascader/cascader.component.mjs +27 -5
  11. package/esm2022/cascader/cascader.service.mjs +33 -3
  12. package/esm2022/core/behaviors/disabled.mjs +2 -2
  13. package/esm2022/date-picker/abstract-picker.directive.mjs +3 -3
  14. package/esm2022/date-picker/base-picker.component.mjs +3 -2
  15. package/esm2022/drag-drop/drag.directive.mjs +3 -7
  16. package/esm2022/drag-drop/drop-container.directive.mjs +9 -7
  17. package/esm2022/dropdown/dropdown-submenu.component.mjs +7 -12
  18. package/esm2022/form/form.directive.mjs +3 -2
  19. package/esm2022/grid/thy-grid-item.component.mjs +7 -11
  20. package/esm2022/image/preview/image-preview.component.mjs +9 -13
  21. package/esm2022/input/input-count.component.mjs +9 -10
  22. package/esm2022/input/input-group.component.mjs +9 -9
  23. package/esm2022/nav/nav-item.directive.mjs +7 -13
  24. package/esm2022/nav/nav.component.mjs +8 -13
  25. package/esm2022/radio/button/radio-button.component.mjs +2 -2
  26. package/esm2022/radio/group/radio-group.component.mjs +6 -1
  27. package/esm2022/radio/radio.component.mjs +2 -2
  28. package/esm2022/resizable/resizable.directive.mjs +11 -14
  29. package/esm2022/resizable/resize-handle.component.mjs +8 -13
  30. package/esm2022/shared/directives/thy-drag-drop.directive.mjs +8 -8
  31. package/esm2022/space/space.component.mjs +7 -9
  32. package/esm2022/table/table-column.component.mjs +3 -2
  33. package/esm2022/table/table.component.mjs +11 -12
  34. package/esm2022/tabs/tabs.component.mjs +8 -10
  35. package/esm2022/time-picker/time-picker.utils.mjs +8 -8
  36. package/esm2022/util/helpers/helpers.mjs +10 -1
  37. package/esm2022/version.mjs +2 -2
  38. package/esm2022/watermark/watermark.directive.mjs +9 -14
  39. package/fesm2022/ngx-tethys-autocomplete.mjs +8 -14
  40. package/fesm2022/ngx-tethys-autocomplete.mjs.map +1 -1
  41. package/fesm2022/ngx-tethys-button.mjs +2 -1
  42. package/fesm2022/ngx-tethys-button.mjs.map +1 -1
  43. package/fesm2022/ngx-tethys-cascader.mjs +58 -6
  44. package/fesm2022/ngx-tethys-cascader.mjs.map +1 -1
  45. package/fesm2022/ngx-tethys-core.mjs +2 -2
  46. package/fesm2022/ngx-tethys-core.mjs.map +1 -1
  47. package/fesm2022/ngx-tethys-date-picker.mjs +2 -2
  48. package/fesm2022/ngx-tethys-date-picker.mjs.map +1 -1
  49. package/fesm2022/ngx-tethys-drag-drop.mjs +9 -10
  50. package/fesm2022/ngx-tethys-drag-drop.mjs.map +1 -1
  51. package/fesm2022/ngx-tethys-dropdown.mjs +8 -11
  52. package/fesm2022/ngx-tethys-dropdown.mjs.map +1 -1
  53. package/fesm2022/ngx-tethys-form.mjs +2 -1
  54. package/fesm2022/ngx-tethys-form.mjs.map +1 -1
  55. package/fesm2022/ngx-tethys-grid.mjs +6 -10
  56. package/fesm2022/ngx-tethys-grid.mjs.map +1 -1
  57. package/fesm2022/ngx-tethys-image.mjs +10 -12
  58. package/fesm2022/ngx-tethys-image.mjs.map +1 -1
  59. package/fesm2022/ngx-tethys-input.mjs +13 -14
  60. package/fesm2022/ngx-tethys-input.mjs.map +1 -1
  61. package/fesm2022/ngx-tethys-nav.mjs +11 -21
  62. package/fesm2022/ngx-tethys-nav.mjs.map +1 -1
  63. package/fesm2022/ngx-tethys-radio.mjs +6 -1
  64. package/fesm2022/ngx-tethys-radio.mjs.map +1 -1
  65. package/fesm2022/ngx-tethys-resizable.mjs +15 -22
  66. package/fesm2022/ngx-tethys-resizable.mjs.map +1 -1
  67. package/fesm2022/ngx-tethys-shared.mjs +8 -7
  68. package/fesm2022/ngx-tethys-shared.mjs.map +1 -1
  69. package/fesm2022/ngx-tethys-space.mjs +7 -8
  70. package/fesm2022/ngx-tethys-space.mjs.map +1 -1
  71. package/fesm2022/ngx-tethys-table.mjs +12 -12
  72. package/fesm2022/ngx-tethys-table.mjs.map +1 -1
  73. package/fesm2022/ngx-tethys-tabs.mjs +7 -9
  74. package/fesm2022/ngx-tethys-tabs.mjs.map +1 -1
  75. package/fesm2022/ngx-tethys-time-picker.mjs +8 -7
  76. package/fesm2022/ngx-tethys-time-picker.mjs.map +1 -1
  77. package/fesm2022/ngx-tethys-util.mjs +9 -0
  78. package/fesm2022/ngx-tethys-util.mjs.map +1 -1
  79. package/fesm2022/ngx-tethys-watermark.mjs +8 -13
  80. package/fesm2022/ngx-tethys-watermark.mjs.map +1 -1
  81. package/fesm2022/ngx-tethys.mjs +1 -1
  82. package/fesm2022/ngx-tethys.mjs.map +1 -1
  83. package/grid/thy-grid-item.component.d.ts +3 -6
  84. package/image/preview/image-preview.component.d.ts +3 -6
  85. package/input/input-count.component.d.ts +2 -4
  86. package/input/input-group.component.d.ts +3 -4
  87. package/nav/nav-item.directive.d.ts +3 -6
  88. package/nav/nav.component.d.ts +3 -6
  89. package/package.json +1 -1
  90. package/resizable/resizable.directive.d.ts +2 -4
  91. package/resizable/resize-handle.component.d.ts +3 -6
  92. package/schematics/version.d.ts +1 -1
  93. package/schematics/version.js +1 -1
  94. package/shared/directives/thy-drag-drop.directive.d.ts +2 -4
  95. package/space/space.component.d.ts +2 -4
  96. package/table/table.component.d.ts +3 -3
  97. package/tabs/tabs.component.d.ts +2 -4
  98. package/util/helpers/helpers.d.ts +12 -0
  99. package/watermark/watermark.directive.d.ts +3 -6
@@ -1,21 +1,18 @@
1
- import { Directive, ElementRef, Renderer2, NgZone, Input, Output, EventEmitter, ChangeDetectorRef, booleanAttribute, numberAttribute } from '@angular/core';
2
- import { MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';
1
+ import { Directive, ElementRef, Renderer2, NgZone, Input, Output, EventEmitter, ChangeDetectorRef, inject, DestroyRef, booleanAttribute, numberAttribute } from '@angular/core';
3
2
  import { ThyResizableService } from './resizable.service';
4
3
  import { Platform } from '@angular/cdk/platform';
5
- import { takeUntil } from 'rxjs/operators';
4
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
5
  import { getEventWithPoint, ensureInBounds, setCompatibleStyle } from './utils';
7
6
  import { fromEvent } from 'rxjs';
8
7
  import * as i0 from "@angular/core";
9
8
  import * as i1 from "@angular/cdk/platform";
10
9
  import * as i2 from "./resizable.service";
11
- const _MixinBase = mixinUnsubscribe(MixinBase);
12
10
  /**
13
11
  * 调整尺寸
14
12
  * @name thyResizable
15
13
  */
16
- export class ThyResizableDirective extends _MixinBase {
14
+ export class ThyResizableDirective {
17
15
  constructor(elementRef, renderer, platform, ngZone, thyResizableService, changeDetectorRef) {
18
- super();
19
16
  this.elementRef = elementRef;
20
17
  this.renderer = renderer;
21
18
  this.platform = platform;
@@ -76,7 +73,8 @@ export class ThyResizableDirective extends _MixinBase {
76
73
  this.sizeCache = null;
77
74
  this.ghostElement = null;
78
75
  this.currentHandleEvent = null;
79
- this.thyResizableService.handleMouseDownOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(event => {
76
+ this.destroyRef = inject(DestroyRef);
77
+ this.thyResizableService.handleMouseDownOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(event => {
80
78
  if (this.thyDisabled) {
81
79
  return;
82
80
  }
@@ -92,7 +90,7 @@ export class ThyResizableDirective extends _MixinBase {
92
90
  }
93
91
  this.nativeElementRect = this.nativeElement.getBoundingClientRect();
94
92
  });
95
- this.thyResizableService.documentMouseUpOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(event => {
93
+ this.thyResizableService.documentMouseUpOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(event => {
96
94
  if (this.resizing) {
97
95
  this.ngZone.run(() => {
98
96
  this.resizing = false;
@@ -102,7 +100,7 @@ export class ThyResizableDirective extends _MixinBase {
102
100
  this.endResize(event);
103
101
  }
104
102
  });
105
- this.thyResizableService.documentMouseMoveOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(event => {
103
+ this.thyResizableService.documentMouseMoveOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(event => {
106
104
  if (this.resizing) {
107
105
  this.resize(event);
108
106
  }
@@ -115,12 +113,12 @@ export class ThyResizableDirective extends _MixinBase {
115
113
  this.nativeElement = this.elementRef.nativeElement;
116
114
  this.ngZone.runOutsideAngular(() => {
117
115
  fromEvent(this.nativeElement, 'mouseenter')
118
- .pipe(takeUntil(this.ngUnsubscribe$))
116
+ .pipe(takeUntilDestroyed(this.destroyRef))
119
117
  .subscribe(() => {
120
118
  this.thyResizableService.mouseEnteredOutsideAngular$.next(true);
121
119
  });
122
120
  fromEvent(this.nativeElement, 'mouseleave')
123
- .pipe(takeUntil(this.ngUnsubscribe$))
121
+ .pipe(takeUntilDestroyed(this.destroyRef))
124
122
  .subscribe(() => {
125
123
  this.thyResizableService.mouseEnteredOutsideAngular$.next(false);
126
124
  });
@@ -308,10 +306,9 @@ export class ThyResizableDirective extends _MixinBase {
308
306
  ngOnDestroy() {
309
307
  this.ghostElement = null;
310
308
  this.sizeCache = null;
311
- super.ngOnDestroy();
312
309
  }
313
310
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyResizableDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.Platform }, { token: i0.NgZone }, { token: i2.ThyResizableService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
314
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.2.3", type: ThyResizableDirective, isStandalone: true, selector: "[thyResizable]", inputs: { thyBounds: "thyBounds", thyMaxHeight: ["thyMaxHeight", "thyMaxHeight", numberAttribute], thyMaxWidth: ["thyMaxWidth", "thyMaxWidth", numberAttribute], thyMinHeight: ["thyMinHeight", "thyMinHeight", numberAttribute], thyMinWidth: ["thyMinWidth", "thyMinWidth", numberAttribute], thyGridColumnCount: ["thyGridColumnCount", "thyGridColumnCount", numberAttribute], thyMaxColumn: ["thyMaxColumn", "thyMaxColumn", numberAttribute], thyMinColumn: ["thyMinColumn", "thyMinColumn", numberAttribute], thyLockAspectRatio: ["thyLockAspectRatio", "thyLockAspectRatio", booleanAttribute], thyPreview: ["thyPreview", "thyPreview", booleanAttribute], thyDisabled: ["thyDisabled", "thyDisabled", booleanAttribute] }, outputs: { thyResize: "thyResize", thyResizeStart: "thyResizeStart", thyResizeEnd: "thyResizeEnd" }, host: { properties: { "class.thy-resizable-resizing": "resizing", "class.thy-resizable-disabled": "thyDisabled" }, classAttribute: "thy-resizable" }, providers: [ThyResizableService], usesInheritance: true, ngImport: i0 }); }
311
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.2.3", type: ThyResizableDirective, isStandalone: true, selector: "[thyResizable]", inputs: { thyBounds: "thyBounds", thyMaxHeight: ["thyMaxHeight", "thyMaxHeight", numberAttribute], thyMaxWidth: ["thyMaxWidth", "thyMaxWidth", numberAttribute], thyMinHeight: ["thyMinHeight", "thyMinHeight", numberAttribute], thyMinWidth: ["thyMinWidth", "thyMinWidth", numberAttribute], thyGridColumnCount: ["thyGridColumnCount", "thyGridColumnCount", numberAttribute], thyMaxColumn: ["thyMaxColumn", "thyMaxColumn", numberAttribute], thyMinColumn: ["thyMinColumn", "thyMinColumn", numberAttribute], thyLockAspectRatio: ["thyLockAspectRatio", "thyLockAspectRatio", booleanAttribute], thyPreview: ["thyPreview", "thyPreview", booleanAttribute], thyDisabled: ["thyDisabled", "thyDisabled", booleanAttribute] }, outputs: { thyResize: "thyResize", thyResizeStart: "thyResizeStart", thyResizeEnd: "thyResizeEnd" }, host: { properties: { "class.thy-resizable-resizing": "resizing", "class.thy-resizable-disabled": "thyDisabled" }, classAttribute: "thy-resizable" }, providers: [ThyResizableService], ngImport: i0 }); }
315
312
  }
316
313
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyResizableDirective, decorators: [{
317
314
  type: Directive,
@@ -364,4 +361,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
364
361
  }], thyResizeEnd: [{
365
362
  type: Output
366
363
  }] } });
367
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../../src/resizable/resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    AfterViewInit,\n    OnDestroy,\n    ElementRef,\n    Renderer2,\n    NgZone,\n    Input,\n    Output,\n    EventEmitter,\n    ChangeDetectorRef,\n    booleanAttribute,\n    numberAttribute\n} from '@angular/core';\nimport { Constructor, ThyUnsubscribe, MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';\nimport { ThyResizableService } from './resizable.service';\nimport { Platform } from '@angular/cdk/platform';\nimport { takeUntil } from 'rxjs/operators';\nimport { ThyResizeHandleMouseDownEvent } from './resize-handle.component';\nimport { ThyResizeEvent } from './interface';\nimport { getEventWithPoint, ensureInBounds, setCompatibleStyle } from './utils';\nimport { fromEvent } from 'rxjs';\n\nconst _MixinBase: Constructor<ThyUnsubscribe> & typeof MixinBase = mixinUnsubscribe(MixinBase);\n\n/**\n * 调整尺寸\n * @name thyResizable\n */\n@Directive({\n    selector: '[thyResizable]',\n    providers: [ThyResizableService],\n    host: {\n        class: 'thy-resizable',\n        '[class.thy-resizable-resizing]': 'resizing',\n        '[class.thy-resizable-disabled]': 'thyDisabled'\n    },\n    standalone: true\n})\nexport class ThyResizableDirective extends _MixinBase implements AfterViewInit, OnDestroy {\n    /**\n     * 调整尺寸的边界\n     * @default parent\n     * @type 'window' | 'parent' | ElementRef<HTMLElement>\n     */\n    @Input() thyBounds: 'window' | 'parent' | ElementRef<HTMLElement> = 'parent';\n\n    /**\n     * 最大高度(超过边界部分忽略)\n     */\n    @Input({ transform: numberAttribute }) thyMaxHeight?: number;\n\n    /**\n     * 最大宽度(超过边界部分忽略)\n     */\n    @Input({ transform: numberAttribute }) thyMaxWidth?: number;\n\n    /**\n     * 最小高度\n     */\n    @Input({ transform: numberAttribute }) thyMinHeight: number = 40;\n\n    /**\n     * 最小宽度\n     */\n    @Input({ transform: numberAttribute }) thyMinWidth: number = 40;\n\n    /**\n     * 栅格列数(-1 为不栅格)\n     */\n    @Input({ transform: numberAttribute }) thyGridColumnCount: number = -1;\n\n    /**\n     * 栅格最大列数\n     */\n    @Input({ transform: numberAttribute }) thyMaxColumn: number = -1;\n\n    /**\n     * 栅格最小列数\n     */\n    @Input({ transform: numberAttribute }) thyMinColumn: number = -1;\n\n    /**\n     * 锁定宽高比\n     */\n    @Input({ transform: booleanAttribute }) thyLockAspectRatio: boolean = false;\n\n    /**\n     * 是否预览模式\n     */\n    @Input({ transform: booleanAttribute }) thyPreview: boolean = false;\n\n    /**\n     * 是否禁用调整大小\n     */\n    @Input({ transform: booleanAttribute }) thyDisabled: boolean = false;\n\n    /**\n     * 调整尺寸时的事件\n     */\n    @Output() readonly thyResize = new EventEmitter<ThyResizeEvent>();\n\n    /**\n     * 开始调整尺寸时的事件\n     */\n    @Output() readonly thyResizeStart = new EventEmitter<ThyResizeEvent>();\n\n    /**\n     * 结束调整尺寸时的事件\n     */\n    @Output() readonly thyResizeEnd = new EventEmitter<ThyResizeEvent>();\n\n    resizing = false;\n    private nativeElement!: HTMLElement;\n    private nativeElementRect!: ClientRect | DOMRect;\n    private sizeCache: ThyResizeEvent | null = null;\n    private ghostElement: HTMLDivElement | null = null;\n    private currentHandleEvent: ThyResizeHandleMouseDownEvent | null = null;\n\n    constructor(\n        private elementRef: ElementRef<HTMLElement>,\n        private renderer: Renderer2,\n        private platform: Platform,\n        private ngZone: NgZone,\n        private thyResizableService: ThyResizableService,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {\n        super();\n        this.thyResizableService.handleMouseDownOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(event => {\n            if (this.thyDisabled) {\n                return;\n            }\n            this.resizing = true;\n            const { mouseEvent } = event;\n            this.thyResizableService.startResizing(mouseEvent);\n            this.currentHandleEvent = event;\n            this.setCursor();\n            // Re-enter the Angular zone and run the change detection only if there're any `thyResizeStart` listeners,\n            // e.g.: `<div thyResizable (thyResizeStart)=\"...\"></div>`.\n            if (this.thyResizeStart.observers.length) {\n                this.ngZone.run(() => this.thyResizeStart.emit({ mouseEvent }));\n            }\n            this.nativeElementRect = this.nativeElement.getBoundingClientRect();\n        });\n\n        this.thyResizableService.documentMouseUpOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(event => {\n            if (this.resizing) {\n                this.ngZone.run(() => {\n                    this.resizing = false;\n                    this.changeDetectorRef.markForCheck();\n                });\n                this.thyResizableService.documentMouseUpOutsideAngular$.next(event);\n                this.endResize(event);\n            }\n        });\n\n        this.thyResizableService.documentMouseMoveOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(event => {\n            if (this.resizing) {\n                this.resize(event);\n            }\n        });\n    }\n\n    ngAfterViewInit(): void {\n        if (!this.platform.isBrowser) {\n            return;\n        }\n        this.nativeElement = this.elementRef.nativeElement;\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(this.nativeElement, 'mouseenter')\n                .pipe(takeUntil(this.ngUnsubscribe$))\n                .subscribe(() => {\n                    this.thyResizableService.mouseEnteredOutsideAngular$.next(true);\n                });\n\n            fromEvent(this.nativeElement, 'mouseleave')\n                .pipe(takeUntil(this.ngUnsubscribe$))\n                .subscribe(() => {\n                    this.thyResizableService.mouseEnteredOutsideAngular$.next(false);\n                });\n        });\n    }\n\n    setCursor(): void {\n        switch (this.currentHandleEvent!.direction) {\n            case 'left':\n            case 'right':\n                this.renderer.setStyle(document.body, 'cursor', 'ew-resize');\n                break;\n            case 'top':\n            case 'bottom':\n                this.renderer.setStyle(document.body, 'cursor', 'ns-resize');\n                break;\n            case 'topLeft':\n            case 'bottomRight':\n                this.renderer.setStyle(document.body, 'cursor', 'nwse-resize');\n                break;\n            case 'topRight':\n            case 'bottomLeft':\n                this.renderer.setStyle(document.body, 'cursor', 'nesw-resize');\n                break;\n        }\n        setCompatibleStyle(document.body, 'user-select', 'none');\n    }\n\n    endResize(event: MouseEvent | TouchEvent): void {\n        this.renderer.setStyle(document.body, 'cursor', '');\n        setCompatibleStyle(document.body, 'user-select', '');\n        this.removeGhostElement();\n        const size = this.sizeCache\n            ? { ...this.sizeCache }\n            : {\n                  width: this.nativeElementRect.width,\n                  height: this.nativeElementRect.height\n              };\n        // Re-enter the Angular zone and run the change detection only if there're any `thyResizeEnd` listeners,\n        // e.g.: `<div thyResizable (thyResizeEnd)=\"...\"></div>`.\n        if (this.thyResizeEnd.observers.length) {\n            this.ngZone.run(() => {\n                this.thyResizeEnd.emit({\n                    ...size,\n                    mouseEvent: event\n                });\n            });\n        }\n        this.sizeCache = null;\n        this.currentHandleEvent = null;\n    }\n\n    resize(event: MouseEvent | TouchEvent): void {\n        const nativeElementRect = this.nativeElementRect;\n        const resizeEvent = getEventWithPoint(event);\n        const handleEvent = getEventWithPoint(this.currentHandleEvent!.mouseEvent);\n        let width = nativeElementRect.width;\n        let height = nativeElementRect.height;\n        const ratio = this.thyLockAspectRatio ? width / height : -1;\n        switch (this.currentHandleEvent!.direction) {\n            case 'bottomRight':\n                width = resizeEvent.clientX - nativeElementRect.left;\n                height = resizeEvent.clientY - nativeElementRect.top;\n                break;\n            case 'bottomLeft':\n                width = nativeElementRect.width + (handleEvent.clientX - resizeEvent.clientX);\n                height = resizeEvent.clientY - nativeElementRect.top;\n                break;\n            case 'topRight':\n                width = resizeEvent.clientX - nativeElementRect.left;\n                height = nativeElementRect.height + (handleEvent.clientY - resizeEvent.clientY);\n                break;\n            case 'topLeft':\n                width = nativeElementRect.width + (handleEvent.clientX - resizeEvent.clientX);\n                height = nativeElementRect.height + (handleEvent.clientY - resizeEvent.clientY);\n                break;\n            case 'top':\n                height = nativeElementRect.height + (handleEvent.clientY - resizeEvent.clientY);\n                break;\n            case 'right':\n                width = resizeEvent.clientX - nativeElementRect.left;\n                break;\n            case 'bottom':\n                height = resizeEvent.clientY - nativeElementRect.top;\n                break;\n            case 'left':\n                width = nativeElementRect.width + (handleEvent.clientX - resizeEvent.clientX);\n        }\n        const size = this.calcSize(width, height, ratio);\n        this.sizeCache = { ...size };\n        // Re-enter the Angular zone and run the change detection only if there're any `thyResize` listeners,\n        // e.g.: `<div thyResizable (thyResize)=\"...\"></div>`.\n        if (this.thyResize.observers.length) {\n            this.ngZone.run(() => {\n                this.thyResize.emit({\n                    ...size,\n                    mouseEvent: event\n                });\n            });\n        }\n\n        if (this.thyPreview) {\n            this.previewResize(size);\n        }\n    }\n\n    calcSize(width: number, height: number, ratio: number): ThyResizeEvent {\n        let newWidth: number;\n        let newHeight: number;\n        let maxWidth: number;\n        let maxHeight: number;\n        let col = 0;\n        let spanWidth = 0;\n        let minWidth = this.thyMinWidth;\n        let boundWidth = Infinity;\n        let boundHeight = Infinity;\n        if (this.thyBounds === 'parent') {\n            const parent = this.renderer.parentNode(this.nativeElement);\n            if (parent instanceof HTMLElement) {\n                const parentRect = parent.getBoundingClientRect();\n                boundWidth = parentRect.width;\n                boundHeight = parentRect.height;\n            }\n        } else if (this.thyBounds === 'window') {\n            if (typeof window !== 'undefined') {\n                boundWidth = window.innerWidth;\n                boundHeight = window.innerHeight;\n            }\n        } else if (this.thyBounds && this.thyBounds.nativeElement && this.thyBounds.nativeElement instanceof HTMLElement) {\n            const boundsRect = this.thyBounds.nativeElement.getBoundingClientRect();\n            boundWidth = boundsRect.width;\n            boundHeight = boundsRect.height;\n        }\n\n        maxWidth = ensureInBounds(this.thyMaxWidth!, boundWidth);\n        maxHeight = ensureInBounds(this.thyMaxHeight!, boundHeight);\n\n        if (this.thyGridColumnCount !== -1) {\n            spanWidth = maxWidth / this.thyGridColumnCount;\n            minWidth = this.thyMinColumn !== -1 ? spanWidth * this.thyMinColumn : minWidth;\n            maxWidth = this.thyMaxColumn !== -1 ? spanWidth * this.thyMaxColumn : maxWidth;\n        }\n\n        if (ratio !== -1) {\n            if (/(left|right)/i.test(this.currentHandleEvent!.direction)) {\n                newWidth = Math.min(Math.max(width, minWidth), maxWidth);\n                newHeight = Math.min(Math.max(newWidth / ratio, this.thyMinHeight), maxHeight);\n                if (newHeight >= maxHeight || newHeight <= this.thyMinHeight) {\n                    newWidth = Math.min(Math.max(newHeight * ratio, minWidth), maxWidth);\n                }\n            } else {\n                newHeight = Math.min(Math.max(height, this.thyMinHeight), maxHeight);\n                newWidth = Math.min(Math.max(newHeight * ratio, minWidth), maxWidth);\n                if (newWidth >= maxWidth || newWidth <= minWidth) {\n                    newHeight = Math.min(Math.max(newWidth / ratio, this.thyMinHeight), maxHeight);\n                }\n            }\n        } else {\n            newWidth = Math.min(Math.max(width, minWidth), maxWidth);\n            newHeight = Math.min(Math.max(height, this.thyMinHeight), maxHeight);\n        }\n\n        if (this.thyGridColumnCount !== -1) {\n            col = Math.round(newWidth / spanWidth);\n            newWidth = col * spanWidth;\n        }\n\n        return {\n            col,\n            width: newWidth,\n            height: newHeight\n        };\n    }\n\n    previewResize({ width, height }: ThyResizeEvent): void {\n        this.createGhostElement();\n        this.renderer.setStyle(this.ghostElement, 'width', `${width}px`);\n        this.renderer.setStyle(this.ghostElement, 'height', `${height}px`);\n    }\n\n    createGhostElement(): void {\n        if (!this.ghostElement) {\n            this.ghostElement = this.renderer.createElement('div');\n            this.renderer.setAttribute(this.ghostElement, 'class', 'thy-resizable-preview');\n        }\n        this.renderer.appendChild(this.nativeElement, this.ghostElement);\n    }\n\n    removeGhostElement(): void {\n        if (this.ghostElement) {\n            this.renderer.removeChild(this.nativeElement, this.ghostElement);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.ghostElement = null;\n        this.sizeCache = null;\n        super.ngOnDestroy();\n    }\n}\n"]}
364
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../../src/resizable/resizable.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAGT,UAAU,EACV,SAAS,EACT,MAAM,EACN,KAAK,EACL,MAAM,EACN,YAAY,EACZ,iBAAiB,EACjB,MAAM,EACN,UAAU,EACV,gBAAgB,EAChB,eAAe,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAGhE,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAChF,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;AAEjC;;;GAGG;AAWH,MAAM,OAAO,qBAAqB;IAiF9B,YACY,UAAmC,EACnC,QAAmB,EACnB,QAAkB,EAClB,MAAc,EACd,mBAAwC,EACxC,iBAAoC;QALpC,eAAU,GAAV,UAAU,CAAyB;QACnC,aAAQ,GAAR,QAAQ,CAAW;QACnB,aAAQ,GAAR,QAAQ,CAAU;QAClB,WAAM,GAAN,MAAM,CAAQ;QACd,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAtFhD;;;;WAIG;QACM,cAAS,GAAkD,QAAQ,CAAC;QAY7E;;WAEG;QACoC,iBAAY,GAAW,EAAE,CAAC;QAEjE;;WAEG;QACoC,gBAAW,GAAW,EAAE,CAAC;QAEhE;;WAEG;QACoC,uBAAkB,GAAW,CAAC,CAAC,CAAC;QAEvE;;WAEG;QACoC,iBAAY,GAAW,CAAC,CAAC,CAAC;QAEjE;;WAEG;QACoC,iBAAY,GAAW,CAAC,CAAC,CAAC;QAEjE;;WAEG;QACqC,uBAAkB,GAAY,KAAK,CAAC;QAE5E;;WAEG;QACqC,eAAU,GAAY,KAAK,CAAC;QAEpE;;WAEG;QACqC,gBAAW,GAAY,KAAK,CAAC;QAErE;;WAEG;QACgB,cAAS,GAAG,IAAI,YAAY,EAAkB,CAAC;QAElE;;WAEG;QACgB,mBAAc,GAAG,IAAI,YAAY,EAAkB,CAAC;QAEvE;;WAEG;QACgB,iBAAY,GAAG,IAAI,YAAY,EAAkB,CAAC;QAErE,aAAQ,GAAG,KAAK,CAAC;QAGT,cAAS,GAA0B,IAAI,CAAC;QACxC,iBAAY,GAA0B,IAAI,CAAC;QAC3C,uBAAkB,GAAyC,IAAI,CAAC;QACvD,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAU7C,IAAI,CAAC,mBAAmB,CAAC,8BAA8B,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAChH,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,OAAO;YACX,CAAC;YACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,MAAM,EAAE,UAAU,EAAE,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;YACnD,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAChC,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,0GAA0G;YAC1G,2DAA2D;YAC3D,IAAI,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;gBACvC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;YACpE,CAAC;YACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;QACxE,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,CAAC,8BAA8B,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAChH,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;oBACjB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;oBACtB,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;gBAC1C,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,mBAAmB,CAAC,8BAA8B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACpE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,CAAC,gCAAgC,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAClH,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACvB,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACX,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;YAC3B,OAAO;QACX,CAAC;QACD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACnD,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC/B,SAAS,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC;iBACtC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACzC,SAAS,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,mBAAmB,CAAC,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACpE,CAAC,CAAC,CAAC;YAEP,SAAS,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC;iBACtC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBACzC,SAAS,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,mBAAmB,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrE,CAAC,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC;IAED,SAAS;QACL,QAAQ,IAAI,CAAC,kBAAmB,CAAC,SAAS,EAAE,CAAC;YACzC,KAAK,MAAM,CAAC;YACZ,KAAK,OAAO;gBACR,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;gBAC7D,MAAM;YACV,KAAK,KAAK,CAAC;YACX,KAAK,QAAQ;gBACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;gBAC7D,MAAM;YACV,KAAK,SAAS,CAAC;YACf,KAAK,aAAa;gBACd,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;gBAC/D,MAAM;YACV,KAAK,UAAU,CAAC;YAChB,KAAK,YAAY;gBACb,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE,aAAa,CAAC,CAAC;gBAC/D,MAAM;QACd,CAAC;QACD,kBAAkB,CAAC,QAAQ,CAAC,IAAI,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;IAC7D,CAAC;IAED,SAAS,CAAC,KAA8B;QACpC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC;QACpD,kBAAkB,CAAC,QAAQ,CAAC,IAAI,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS;YACvB,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,SAAS,EAAE;YACvB,CAAC,CAAC;gBACI,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK;gBACnC,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,MAAM;aACxC,CAAC;QACR,wGAAwG;QACxG,yDAAyD;QACzD,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;YACrC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;gBACjB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;oBACnB,GAAG,IAAI;oBACP,UAAU,EAAE,KAAK;iBACpB,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACP,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;IACnC,CAAC;IAED,MAAM,CAAC,KAA8B;QACjC,MAAM,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC;QACjD,MAAM,WAAW,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,WAAW,GAAG,iBAAiB,CAAC,IAAI,CAAC,kBAAmB,CAAC,UAAU,CAAC,CAAC;QAC3E,IAAI,KAAK,GAAG,iBAAiB,CAAC,KAAK,CAAC;QACpC,IAAI,MAAM,GAAG,iBAAiB,CAAC,MAAM,CAAC;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,QAAQ,IAAI,CAAC,kBAAmB,CAAC,SAAS,EAAE,CAAC;YACzC,KAAK,aAAa;gBACd,KAAK,GAAG,WAAW,CAAC,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC;gBACrD,MAAM,GAAG,WAAW,CAAC,OAAO,GAAG,iBAAiB,CAAC,GAAG,CAAC;gBACrD,MAAM;YACV,KAAK,YAAY;gBACb,KAAK,GAAG,iBAAiB,CAAC,KAAK,GAAG,CAAC,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;gBAC9E,MAAM,GAAG,WAAW,CAAC,OAAO,GAAG,iBAAiB,CAAC,GAAG,CAAC;gBACrD,MAAM;YACV,KAAK,UAAU;gBACX,KAAK,GAAG,WAAW,CAAC,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC;gBACrD,MAAM,GAAG,iBAAiB,CAAC,MAAM,GAAG,CAAC,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;gBAChF,MAAM;YACV,KAAK,SAAS;gBACV,KAAK,GAAG,iBAAiB,CAAC,KAAK,GAAG,CAAC,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;gBAC9E,MAAM,GAAG,iBAAiB,CAAC,MAAM,GAAG,CAAC,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;gBAChF,MAAM;YACV,KAAK,KAAK;gBACN,MAAM,GAAG,iBAAiB,CAAC,MAAM,GAAG,CAAC,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;gBAChF,MAAM;YACV,KAAK,OAAO;gBACR,KAAK,GAAG,WAAW,CAAC,OAAO,GAAG,iBAAiB,CAAC,IAAI,CAAC;gBACrD,MAAM;YACV,KAAK,QAAQ;gBACT,MAAM,GAAG,WAAW,CAAC,OAAO,GAAG,iBAAiB,CAAC,GAAG,CAAC;gBACrD,MAAM;YACV,KAAK,MAAM;gBACP,KAAK,GAAG,iBAAiB,CAAC,KAAK,GAAG,CAAC,WAAW,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;QACtF,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;QACjD,IAAI,CAAC,SAAS,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC;QAC7B,qGAAqG;QACrG,sDAAsD;QACtD,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC;YAClC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;gBACjB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;oBAChB,GAAG,IAAI;oBACP,UAAU,EAAE,KAAK;iBACpB,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACP,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;IACL,CAAC;IAED,QAAQ,CAAC,KAAa,EAAE,MAAc,EAAE,KAAa;QACjD,IAAI,QAAgB,CAAC;QACrB,IAAI,SAAiB,CAAC;QACtB,IAAI,QAAgB,CAAC;QACrB,IAAI,SAAiB,CAAC;QACtB,IAAI,GAAG,GAAG,CAAC,CAAC;QACZ,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC;QAChC,IAAI,UAAU,GAAG,QAAQ,CAAC;QAC1B,IAAI,WAAW,GAAG,QAAQ,CAAC;QAC3B,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE,CAAC;YAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC5D,IAAI,MAAM,YAAY,WAAW,EAAE,CAAC;gBAChC,MAAM,UAAU,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAC;gBAClD,UAAU,GAAG,UAAU,CAAC,KAAK,CAAC;gBAC9B,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC;YACpC,CAAC;QACL,CAAC;aAAM,IAAI,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE,CAAC;YACrC,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;gBAChC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;gBAC/B,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC;YACrC,CAAC;QACL,CAAC;aAAM,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,YAAY,WAAW,EAAE,CAAC;YAC/G,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YACxE,UAAU,GAAG,UAAU,CAAC,KAAK,CAAC;YAC9B,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC;QACpC,CAAC;QAED,QAAQ,GAAG,cAAc,CAAC,IAAI,CAAC,WAAY,EAAE,UAAU,CAAC,CAAC;QACzD,SAAS,GAAG,cAAc,CAAC,IAAI,CAAC,YAAa,EAAE,WAAW,CAAC,CAAC;QAE5D,IAAI,IAAI,CAAC,kBAAkB,KAAK,CAAC,CAAC,EAAE,CAAC;YACjC,SAAS,GAAG,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC;YAC/C,QAAQ,GAAG,IAAI,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC;YAC/E,QAAQ,GAAG,IAAI,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC;QACnF,CAAC;QAED,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;YACf,IAAI,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAmB,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC3D,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACzD,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,GAAG,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,CAAC;gBAC/E,IAAI,SAAS,IAAI,SAAS,IAAI,SAAS,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBAC3D,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,KAAK,EAAE,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACzE,CAAC;YACL,CAAC;iBAAM,CAAC;gBACJ,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,CAAC;gBACrE,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,KAAK,EAAE,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;gBACrE,IAAI,QAAQ,IAAI,QAAQ,IAAI,QAAQ,IAAI,QAAQ,EAAE,CAAC;oBAC/C,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,GAAG,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,CAAC;gBACnF,CAAC;YACL,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;YACzD,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,CAAC;QACzE,CAAC;QAED,IAAI,IAAI,CAAC,kBAAkB,KAAK,CAAC,CAAC,EAAE,CAAC;YACjC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC;YACvC,QAAQ,GAAG,GAAG,GAAG,SAAS,CAAC;QAC/B,CAAC;QAED,OAAO;YACH,GAAG;YACH,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,SAAS;SACpB,CAAC;IACN,CAAC;IAED,aAAa,CAAC,EAAE,KAAK,EAAE,MAAM,EAAkB;QAC3C,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC,CAAC;QACjE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,CAAC,CAAC;IACvE,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACvD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,uBAAuB,CAAC,CAAC;QACpF,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IACrE,CAAC;IAED,kBAAkB;QACd,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACrE,CAAC;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IAC1B,CAAC;8GA/UQ,qBAAqB;kGAArB,qBAAqB,mIAWV,eAAe,+CAKf,eAAe,kDAKf,eAAe,+CAKf,eAAe,oEAKf,eAAe,kDAKf,eAAe,kDAKf,eAAe,oEAKf,gBAAgB,4CAKhB,gBAAgB,+CAKhB,gBAAgB,2QAhEzB,CAAC,mBAAmB,CAAC;;2FAQvB,qBAAqB;kBAVjC,SAAS;mBAAC;oBACP,QAAQ,EAAE,gBAAgB;oBAC1B,SAAS,EAAE,CAAC,mBAAmB,CAAC;oBAChC,IAAI,EAAE;wBACF,KAAK,EAAE,eAAe;wBACtB,gCAAgC,EAAE,UAAU;wBAC5C,gCAAgC,EAAE,aAAa;qBAClD;oBACD,UAAU,EAAE,IAAI;iBACnB;qNAOY,SAAS;sBAAjB,KAAK;gBAKiC,YAAY;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAKE,WAAW;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAKE,YAAY;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAKE,WAAW;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAKE,kBAAkB;sBAAxD,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAKE,YAAY;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAKE,YAAY;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAKG,kBAAkB;sBAAzD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAKE,UAAU;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAKE,WAAW;sBAAlD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAKnB,SAAS;sBAA3B,MAAM;gBAKY,cAAc;sBAAhC,MAAM;gBAKY,YAAY;sBAA9B,MAAM","sourcesContent":["import {\n    Directive,\n    AfterViewInit,\n    OnDestroy,\n    ElementRef,\n    Renderer2,\n    NgZone,\n    Input,\n    Output,\n    EventEmitter,\n    ChangeDetectorRef,\n    inject,\n    DestroyRef,\n    booleanAttribute,\n    numberAttribute\n} from '@angular/core';\nimport { ThyResizableService } from './resizable.service';\nimport { Platform } from '@angular/cdk/platform';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ThyResizeHandleMouseDownEvent } from './resize-handle.component';\nimport { ThyResizeEvent } from './interface';\nimport { getEventWithPoint, ensureInBounds, setCompatibleStyle } from './utils';\nimport { fromEvent } from 'rxjs';\n\n/**\n * 调整尺寸\n * @name thyResizable\n */\n@Directive({\n    selector: '[thyResizable]',\n    providers: [ThyResizableService],\n    host: {\n        class: 'thy-resizable',\n        '[class.thy-resizable-resizing]': 'resizing',\n        '[class.thy-resizable-disabled]': 'thyDisabled'\n    },\n    standalone: true\n})\nexport class ThyResizableDirective implements AfterViewInit, OnDestroy {\n    /**\n     * 调整尺寸的边界\n     * @default parent\n     * @type 'window' | 'parent' | ElementRef<HTMLElement>\n     */\n    @Input() thyBounds: 'window' | 'parent' | ElementRef<HTMLElement> = 'parent';\n\n    /**\n     * 最大高度(超过边界部分忽略)\n     */\n    @Input({ transform: numberAttribute }) thyMaxHeight?: number;\n\n    /**\n     * 最大宽度(超过边界部分忽略)\n     */\n    @Input({ transform: numberAttribute }) thyMaxWidth?: number;\n\n    /**\n     * 最小高度\n     */\n    @Input({ transform: numberAttribute }) thyMinHeight: number = 40;\n\n    /**\n     * 最小宽度\n     */\n    @Input({ transform: numberAttribute }) thyMinWidth: number = 40;\n\n    /**\n     * 栅格列数(-1 为不栅格)\n     */\n    @Input({ transform: numberAttribute }) thyGridColumnCount: number = -1;\n\n    /**\n     * 栅格最大列数\n     */\n    @Input({ transform: numberAttribute }) thyMaxColumn: number = -1;\n\n    /**\n     * 栅格最小列数\n     */\n    @Input({ transform: numberAttribute }) thyMinColumn: number = -1;\n\n    /**\n     * 锁定宽高比\n     */\n    @Input({ transform: booleanAttribute }) thyLockAspectRatio: boolean = false;\n\n    /**\n     * 是否预览模式\n     */\n    @Input({ transform: booleanAttribute }) thyPreview: boolean = false;\n\n    /**\n     * 是否禁用调整大小\n     */\n    @Input({ transform: booleanAttribute }) thyDisabled: boolean = false;\n\n    /**\n     * 调整尺寸时的事件\n     */\n    @Output() readonly thyResize = new EventEmitter<ThyResizeEvent>();\n\n    /**\n     * 开始调整尺寸时的事件\n     */\n    @Output() readonly thyResizeStart = new EventEmitter<ThyResizeEvent>();\n\n    /**\n     * 结束调整尺寸时的事件\n     */\n    @Output() readonly thyResizeEnd = new EventEmitter<ThyResizeEvent>();\n\n    resizing = false;\n    private nativeElement!: HTMLElement;\n    private nativeElementRect!: ClientRect | DOMRect;\n    private sizeCache: ThyResizeEvent | null = null;\n    private ghostElement: HTMLDivElement | null = null;\n    private currentHandleEvent: ThyResizeHandleMouseDownEvent | null = null;\n    private readonly destroyRef = inject(DestroyRef);\n\n    constructor(\n        private elementRef: ElementRef<HTMLElement>,\n        private renderer: Renderer2,\n        private platform: Platform,\n        private ngZone: NgZone,\n        private thyResizableService: ThyResizableService,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {\n        this.thyResizableService.handleMouseDownOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(event => {\n            if (this.thyDisabled) {\n                return;\n            }\n            this.resizing = true;\n            const { mouseEvent } = event;\n            this.thyResizableService.startResizing(mouseEvent);\n            this.currentHandleEvent = event;\n            this.setCursor();\n            // Re-enter the Angular zone and run the change detection only if there're any `thyResizeStart` listeners,\n            // e.g.: `<div thyResizable (thyResizeStart)=\"...\"></div>`.\n            if (this.thyResizeStart.observers.length) {\n                this.ngZone.run(() => this.thyResizeStart.emit({ mouseEvent }));\n            }\n            this.nativeElementRect = this.nativeElement.getBoundingClientRect();\n        });\n\n        this.thyResizableService.documentMouseUpOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(event => {\n            if (this.resizing) {\n                this.ngZone.run(() => {\n                    this.resizing = false;\n                    this.changeDetectorRef.markForCheck();\n                });\n                this.thyResizableService.documentMouseUpOutsideAngular$.next(event);\n                this.endResize(event);\n            }\n        });\n\n        this.thyResizableService.documentMouseMoveOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(event => {\n            if (this.resizing) {\n                this.resize(event);\n            }\n        });\n    }\n\n    ngAfterViewInit(): void {\n        if (!this.platform.isBrowser) {\n            return;\n        }\n        this.nativeElement = this.elementRef.nativeElement;\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(this.nativeElement, 'mouseenter')\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe(() => {\n                    this.thyResizableService.mouseEnteredOutsideAngular$.next(true);\n                });\n\n            fromEvent(this.nativeElement, 'mouseleave')\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe(() => {\n                    this.thyResizableService.mouseEnteredOutsideAngular$.next(false);\n                });\n        });\n    }\n\n    setCursor(): void {\n        switch (this.currentHandleEvent!.direction) {\n            case 'left':\n            case 'right':\n                this.renderer.setStyle(document.body, 'cursor', 'ew-resize');\n                break;\n            case 'top':\n            case 'bottom':\n                this.renderer.setStyle(document.body, 'cursor', 'ns-resize');\n                break;\n            case 'topLeft':\n            case 'bottomRight':\n                this.renderer.setStyle(document.body, 'cursor', 'nwse-resize');\n                break;\n            case 'topRight':\n            case 'bottomLeft':\n                this.renderer.setStyle(document.body, 'cursor', 'nesw-resize');\n                break;\n        }\n        setCompatibleStyle(document.body, 'user-select', 'none');\n    }\n\n    endResize(event: MouseEvent | TouchEvent): void {\n        this.renderer.setStyle(document.body, 'cursor', '');\n        setCompatibleStyle(document.body, 'user-select', '');\n        this.removeGhostElement();\n        const size = this.sizeCache\n            ? { ...this.sizeCache }\n            : {\n                  width: this.nativeElementRect.width,\n                  height: this.nativeElementRect.height\n              };\n        // Re-enter the Angular zone and run the change detection only if there're any `thyResizeEnd` listeners,\n        // e.g.: `<div thyResizable (thyResizeEnd)=\"...\"></div>`.\n        if (this.thyResizeEnd.observers.length) {\n            this.ngZone.run(() => {\n                this.thyResizeEnd.emit({\n                    ...size,\n                    mouseEvent: event\n                });\n            });\n        }\n        this.sizeCache = null;\n        this.currentHandleEvent = null;\n    }\n\n    resize(event: MouseEvent | TouchEvent): void {\n        const nativeElementRect = this.nativeElementRect;\n        const resizeEvent = getEventWithPoint(event);\n        const handleEvent = getEventWithPoint(this.currentHandleEvent!.mouseEvent);\n        let width = nativeElementRect.width;\n        let height = nativeElementRect.height;\n        const ratio = this.thyLockAspectRatio ? width / height : -1;\n        switch (this.currentHandleEvent!.direction) {\n            case 'bottomRight':\n                width = resizeEvent.clientX - nativeElementRect.left;\n                height = resizeEvent.clientY - nativeElementRect.top;\n                break;\n            case 'bottomLeft':\n                width = nativeElementRect.width + (handleEvent.clientX - resizeEvent.clientX);\n                height = resizeEvent.clientY - nativeElementRect.top;\n                break;\n            case 'topRight':\n                width = resizeEvent.clientX - nativeElementRect.left;\n                height = nativeElementRect.height + (handleEvent.clientY - resizeEvent.clientY);\n                break;\n            case 'topLeft':\n                width = nativeElementRect.width + (handleEvent.clientX - resizeEvent.clientX);\n                height = nativeElementRect.height + (handleEvent.clientY - resizeEvent.clientY);\n                break;\n            case 'top':\n                height = nativeElementRect.height + (handleEvent.clientY - resizeEvent.clientY);\n                break;\n            case 'right':\n                width = resizeEvent.clientX - nativeElementRect.left;\n                break;\n            case 'bottom':\n                height = resizeEvent.clientY - nativeElementRect.top;\n                break;\n            case 'left':\n                width = nativeElementRect.width + (handleEvent.clientX - resizeEvent.clientX);\n        }\n        const size = this.calcSize(width, height, ratio);\n        this.sizeCache = { ...size };\n        // Re-enter the Angular zone and run the change detection only if there're any `thyResize` listeners,\n        // e.g.: `<div thyResizable (thyResize)=\"...\"></div>`.\n        if (this.thyResize.observers.length) {\n            this.ngZone.run(() => {\n                this.thyResize.emit({\n                    ...size,\n                    mouseEvent: event\n                });\n            });\n        }\n\n        if (this.thyPreview) {\n            this.previewResize(size);\n        }\n    }\n\n    calcSize(width: number, height: number, ratio: number): ThyResizeEvent {\n        let newWidth: number;\n        let newHeight: number;\n        let maxWidth: number;\n        let maxHeight: number;\n        let col = 0;\n        let spanWidth = 0;\n        let minWidth = this.thyMinWidth;\n        let boundWidth = Infinity;\n        let boundHeight = Infinity;\n        if (this.thyBounds === 'parent') {\n            const parent = this.renderer.parentNode(this.nativeElement);\n            if (parent instanceof HTMLElement) {\n                const parentRect = parent.getBoundingClientRect();\n                boundWidth = parentRect.width;\n                boundHeight = parentRect.height;\n            }\n        } else if (this.thyBounds === 'window') {\n            if (typeof window !== 'undefined') {\n                boundWidth = window.innerWidth;\n                boundHeight = window.innerHeight;\n            }\n        } else if (this.thyBounds && this.thyBounds.nativeElement && this.thyBounds.nativeElement instanceof HTMLElement) {\n            const boundsRect = this.thyBounds.nativeElement.getBoundingClientRect();\n            boundWidth = boundsRect.width;\n            boundHeight = boundsRect.height;\n        }\n\n        maxWidth = ensureInBounds(this.thyMaxWidth!, boundWidth);\n        maxHeight = ensureInBounds(this.thyMaxHeight!, boundHeight);\n\n        if (this.thyGridColumnCount !== -1) {\n            spanWidth = maxWidth / this.thyGridColumnCount;\n            minWidth = this.thyMinColumn !== -1 ? spanWidth * this.thyMinColumn : minWidth;\n            maxWidth = this.thyMaxColumn !== -1 ? spanWidth * this.thyMaxColumn : maxWidth;\n        }\n\n        if (ratio !== -1) {\n            if (/(left|right)/i.test(this.currentHandleEvent!.direction)) {\n                newWidth = Math.min(Math.max(width, minWidth), maxWidth);\n                newHeight = Math.min(Math.max(newWidth / ratio, this.thyMinHeight), maxHeight);\n                if (newHeight >= maxHeight || newHeight <= this.thyMinHeight) {\n                    newWidth = Math.min(Math.max(newHeight * ratio, minWidth), maxWidth);\n                }\n            } else {\n                newHeight = Math.min(Math.max(height, this.thyMinHeight), maxHeight);\n                newWidth = Math.min(Math.max(newHeight * ratio, minWidth), maxWidth);\n                if (newWidth >= maxWidth || newWidth <= minWidth) {\n                    newHeight = Math.min(Math.max(newWidth / ratio, this.thyMinHeight), maxHeight);\n                }\n            }\n        } else {\n            newWidth = Math.min(Math.max(width, minWidth), maxWidth);\n            newHeight = Math.min(Math.max(height, this.thyMinHeight), maxHeight);\n        }\n\n        if (this.thyGridColumnCount !== -1) {\n            col = Math.round(newWidth / spanWidth);\n            newWidth = col * spanWidth;\n        }\n\n        return {\n            col,\n            width: newWidth,\n            height: newHeight\n        };\n    }\n\n    previewResize({ width, height }: ThyResizeEvent): void {\n        this.createGhostElement();\n        this.renderer.setStyle(this.ghostElement, 'width', `${width}px`);\n        this.renderer.setStyle(this.ghostElement, 'height', `${height}px`);\n    }\n\n    createGhostElement(): void {\n        if (!this.ghostElement) {\n            this.ghostElement = this.renderer.createElement('div');\n            this.renderer.setAttribute(this.ghostElement, 'class', 'thy-resizable-preview');\n        }\n        this.renderer.appendChild(this.nativeElement, this.ghostElement);\n    }\n\n    removeGhostElement(): void {\n        if (this.ghostElement) {\n            this.renderer.removeChild(this.nativeElement, this.ghostElement);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.ghostElement = null;\n        this.sizeCache = null;\n    }\n}\n"]}
@@ -1,8 +1,7 @@
1
- import { Component, ChangeDetectionStrategy, Input, Output, NgZone, EventEmitter, ElementRef, booleanAttribute } from '@angular/core';
1
+ import { Component, ChangeDetectionStrategy, Input, Output, NgZone, EventEmitter, ElementRef, inject, DestroyRef, booleanAttribute } from '@angular/core';
2
2
  import { normalizePassiveListenerOptions } from '@angular/cdk/platform';
3
3
  import { ThyResizableService } from './resizable.service';
4
- import { takeUntil } from 'rxjs/operators';
5
- import { MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';
4
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
5
  import { fromEvent, merge } from 'rxjs';
7
6
  import { useHostRenderer } from '@tethys/cdk/dom';
8
7
  import { NgIf } from '@angular/common';
@@ -14,15 +13,13 @@ export class ThyResizeHandleMouseDownEvent {
14
13
  this.mouseEvent = mouseEvent;
15
14
  }
16
15
  }
17
- const _MixinBase = mixinUnsubscribe(MixinBase);
18
16
  const passiveEventListenerOptions = normalizePassiveListenerOptions({ passive: true });
19
17
  /**
20
18
  * 定义调整手柄及方向
21
19
  * @name thy-resize-handle
22
20
  */
23
- export class ThyResizeHandle extends _MixinBase {
21
+ export class ThyResizeHandle {
24
22
  constructor(ngZone, thyResizableService, host) {
25
- super();
26
23
  this.ngZone = ngZone;
27
24
  this.thyResizableService = thyResizableService;
28
25
  this.host = host;
@@ -40,9 +37,10 @@ export class ThyResizeHandle extends _MixinBase {
40
37
  */
41
38
  this.thyMouseDown = new EventEmitter();
42
39
  this.hostRenderer = useHostRenderer();
40
+ this.destroyRef = inject(DestroyRef);
43
41
  }
44
42
  ngOnInit() {
45
- this.thyResizableService.mouseEnteredOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(entered => {
43
+ this.thyResizableService.mouseEnteredOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(entered => {
46
44
  if (entered) {
47
45
  this.hostRenderer.addClass('thy-resizable-handle-box-hover');
48
46
  }
@@ -55,17 +53,14 @@ export class ThyResizeHandle extends _MixinBase {
55
53
  // The element `touchstart` listener is not passive by default
56
54
  // We never call `preventDefault()` on it, so we're safe making it passive too.
57
55
  merge(fromEvent(this.host.nativeElement, 'mousedown', passiveEventListenerOptions), fromEvent(this.host.nativeElement, 'touchstart', passiveEventListenerOptions))
58
- .pipe(takeUntil(this.ngUnsubscribe$))
56
+ .pipe(takeUntilDestroyed(this.destroyRef))
59
57
  .subscribe((event) => {
60
58
  this.thyResizableService.handleMouseDownOutsideAngular$.next(new ThyResizeHandleMouseDownEvent(this.thyDirection, event));
61
59
  });
62
60
  });
63
61
  }
64
- ngOnDestroy() {
65
- super.ngOnDestroy();
66
- }
67
62
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyResizeHandle, deps: [{ token: i0.NgZone }, { token: i1.ThyResizableService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
68
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyResizeHandle, isStandalone: true, selector: "thy-resize-handle, [thy-resize-handle]", inputs: { thyDirection: "thyDirection", thyLine: ["thyLine", "thyLine", booleanAttribute] }, outputs: { thyMouseDown: "thyMouseDown" }, host: { properties: { "class.thy-resizable-handle-top": "thyDirection === 'top'", "class.thy-resizable-handle-right": "thyDirection === 'right'", "class.thy-resizable-handle-bottom": "thyDirection === 'bottom'", "class.thy-resizable-handle-left": "thyDirection === 'left'", "class.thy-resizable-handle-topRight": "thyDirection === 'topRight'", "class.thy-resizable-handle-bottomRight": "thyDirection === 'bottomRight'", "class.thy-resizable-handle-bottomLeft": "thyDirection === 'bottomLeft'", "class.thy-resizable-handle-topLeft": "thyDirection === 'topLeft'", "class.thy-resizable-handle-box-hover": "entered" }, classAttribute: "thy-resizable-handle" }, exportAs: ["thyResizeHandle"], usesInheritance: true, ngImport: i0, template: `
63
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThyResizeHandle, isStandalone: true, selector: "thy-resize-handle, [thy-resize-handle]", inputs: { thyDirection: "thyDirection", thyLine: ["thyLine", "thyLine", booleanAttribute] }, outputs: { thyMouseDown: "thyMouseDown" }, host: { properties: { "class.thy-resizable-handle-top": "thyDirection === 'top'", "class.thy-resizable-handle-right": "thyDirection === 'right'", "class.thy-resizable-handle-bottom": "thyDirection === 'bottom'", "class.thy-resizable-handle-left": "thyDirection === 'left'", "class.thy-resizable-handle-topRight": "thyDirection === 'topRight'", "class.thy-resizable-handle-bottomRight": "thyDirection === 'bottomRight'", "class.thy-resizable-handle-bottomLeft": "thyDirection === 'bottomLeft'", "class.thy-resizable-handle-topLeft": "thyDirection === 'topLeft'", "class.thy-resizable-handle-box-hover": "entered" }, classAttribute: "thy-resizable-handle" }, exportAs: ["thyResizeHandle"], ngImport: i0, template: `
69
64
  <ng-content></ng-content>
70
65
  <div *ngIf="thyLine" class="thy-resizable-handle-line"></div>
71
66
  `, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
@@ -103,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
103
98
  }], thyMouseDown: [{
104
99
  type: Output
105
100
  }] } });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-handle.component.js","sourceRoot":"","sources":["../../../../src/resizable/resize-handle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    OnInit,\n    OnDestroy,\n    Component,\n    ChangeDetectionStrategy,\n    Input,\n    Output,\n    NgZone,\n    EventEmitter,\n    ElementRef,\n    booleanAttribute\n} from '@angular/core';\nimport { normalizePassiveListenerOptions } from '@angular/cdk/platform';\nimport { ThyResizeDirection } from './interface';\nimport { ThyResizableService } from './resizable.service';\nimport { takeUntil } from 'rxjs/operators';\nimport { Constructor, ThyUnsubscribe, MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';\nimport { fromEvent, merge } from 'rxjs';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport { NgIf } from '@angular/common';\n\nexport class ThyResizeHandleMouseDownEvent {\n    constructor(public direction: ThyResizeDirection, public mouseEvent: MouseEvent | TouchEvent) {}\n}\n\nconst _MixinBase: Constructor<ThyUnsubscribe> & typeof MixinBase = mixinUnsubscribe(MixinBase);\n\nconst passiveEventListenerOptions = <AddEventListenerOptions>normalizePassiveListenerOptions({ passive: true });\n\n/**\n * 定义调整手柄及方向\n * @name thy-resize-handle\n */\n@Component({\n    selector: 'thy-resize-handle, [thy-resize-handle]',\n    exportAs: 'thyResizeHandle',\n    template: `\n        <ng-content></ng-content>\n        <div *ngIf=\"thyLine\" class=\"thy-resizable-handle-line\"></div>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-resizable-handle',\n        '[class.thy-resizable-handle-top]': `thyDirection === 'top'`,\n        '[class.thy-resizable-handle-right]': `thyDirection === 'right'`,\n        '[class.thy-resizable-handle-bottom]': `thyDirection === 'bottom'`,\n        '[class.thy-resizable-handle-left]': `thyDirection === 'left'`,\n        '[class.thy-resizable-handle-topRight]': `thyDirection === 'topRight'`,\n        '[class.thy-resizable-handle-bottomRight]': `thyDirection === 'bottomRight'`,\n        '[class.thy-resizable-handle-bottomLeft]': `thyDirection === 'bottomLeft'`,\n        '[class.thy-resizable-handle-topLeft]': `thyDirection === 'topLeft'`,\n        '[class.thy-resizable-handle-box-hover]': 'entered'\n    },\n    standalone: true,\n    imports: [NgIf]\n})\nexport class ThyResizeHandle extends _MixinBase implements OnInit, OnDestroy {\n    /**\n     * 调整方向\n     * @type top | right | bottom | left | topRight | bottomRight | bottomLeft | topLeft\n     */\n    @Input() thyDirection: ThyResizeDirection = 'bottomRight';\n\n    /**\n     * 是否展示拖拽线\n     */\n    @Input({ transform: booleanAttribute }) thyLine = false;\n\n    /**\n     * MouseDown 回调事件\n     */\n    @Output() readonly thyMouseDown = new EventEmitter<ThyResizeHandleMouseDownEvent>();\n\n    private hostRenderer = useHostRenderer();\n\n    constructor(private ngZone: NgZone, private thyResizableService: ThyResizableService, private host: ElementRef<HTMLElement>) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.thyResizableService.mouseEnteredOutsideAngular$.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(entered => {\n            if (entered) {\n                this.hostRenderer.addClass('thy-resizable-handle-box-hover');\n            } else {\n                this.hostRenderer.removeClass('thy-resizable-handle-box-hover');\n            }\n        });\n        this.ngZone.runOutsideAngular(() => {\n            // Note: since Chrome 56 defaults document level `touchstart` listener to passive.\n            // The element `touchstart` listener is not passive by default\n            // We never call `preventDefault()` on it, so we're safe making it passive too.\n            merge(\n                fromEvent<MouseEvent>(this.host.nativeElement, 'mousedown', passiveEventListenerOptions),\n                fromEvent<TouchEvent>(this.host.nativeElement, 'touchstart', passiveEventListenerOptions)\n            )\n                .pipe(takeUntil(this.ngUnsubscribe$))\n                .subscribe((event: MouseEvent | TouchEvent) => {\n                    this.thyResizableService.handleMouseDownOutsideAngular$.next(\n                        new ThyResizeHandleMouseDownEvent(this.thyDirection, event)\n                    );\n                });\n        });\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n}\n"]}
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resize-handle.component.js","sourceRoot":"","sources":["../../../../src/resizable/resize-handle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    OnInit,\n    Component,\n    ChangeDetectionStrategy,\n    Input,\n    Output,\n    NgZone,\n    EventEmitter,\n    ElementRef,\n    inject,\n    DestroyRef,\n    booleanAttribute\n} from '@angular/core';\nimport { normalizePassiveListenerOptions } from '@angular/cdk/platform';\nimport { ThyResizeDirection } from './interface';\nimport { ThyResizableService } from './resizable.service';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { fromEvent, merge } from 'rxjs';\nimport { useHostRenderer } from '@tethys/cdk/dom';\nimport { NgIf } from '@angular/common';\n\nexport class ThyResizeHandleMouseDownEvent {\n    constructor(public direction: ThyResizeDirection, public mouseEvent: MouseEvent | TouchEvent) {}\n}\n\nconst passiveEventListenerOptions = <AddEventListenerOptions>normalizePassiveListenerOptions({ passive: true });\n\n/**\n * 定义调整手柄及方向\n * @name thy-resize-handle\n */\n@Component({\n    selector: 'thy-resize-handle, [thy-resize-handle]',\n    exportAs: 'thyResizeHandle',\n    template: `\n        <ng-content></ng-content>\n        <div *ngIf=\"thyLine\" class=\"thy-resizable-handle-line\"></div>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-resizable-handle',\n        '[class.thy-resizable-handle-top]': `thyDirection === 'top'`,\n        '[class.thy-resizable-handle-right]': `thyDirection === 'right'`,\n        '[class.thy-resizable-handle-bottom]': `thyDirection === 'bottom'`,\n        '[class.thy-resizable-handle-left]': `thyDirection === 'left'`,\n        '[class.thy-resizable-handle-topRight]': `thyDirection === 'topRight'`,\n        '[class.thy-resizable-handle-bottomRight]': `thyDirection === 'bottomRight'`,\n        '[class.thy-resizable-handle-bottomLeft]': `thyDirection === 'bottomLeft'`,\n        '[class.thy-resizable-handle-topLeft]': `thyDirection === 'topLeft'`,\n        '[class.thy-resizable-handle-box-hover]': 'entered'\n    },\n    standalone: true,\n    imports: [NgIf]\n})\nexport class ThyResizeHandle implements OnInit {\n    /**\n     * 调整方向\n     * @type top | right | bottom | left | topRight | bottomRight | bottomLeft | topLeft\n     */\n    @Input() thyDirection: ThyResizeDirection = 'bottomRight';\n\n    /**\n     * 是否展示拖拽线\n     */\n    @Input({ transform: booleanAttribute }) thyLine = false;\n\n    /**\n     * MouseDown 回调事件\n     */\n    @Output() readonly thyMouseDown = new EventEmitter<ThyResizeHandleMouseDownEvent>();\n\n    private hostRenderer = useHostRenderer();\n\n    private readonly destroyRef = inject(DestroyRef);\n\n    constructor(private ngZone: NgZone, private thyResizableService: ThyResizableService, private host: ElementRef<HTMLElement>) {}\n\n    ngOnInit(): void {\n        this.thyResizableService.mouseEnteredOutsideAngular$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(entered => {\n            if (entered) {\n                this.hostRenderer.addClass('thy-resizable-handle-box-hover');\n            } else {\n                this.hostRenderer.removeClass('thy-resizable-handle-box-hover');\n            }\n        });\n        this.ngZone.runOutsideAngular(() => {\n            // Note: since Chrome 56 defaults document level `touchstart` listener to passive.\n            // The element `touchstart` listener is not passive by default\n            // We never call `preventDefault()` on it, so we're safe making it passive too.\n            merge(\n                fromEvent<MouseEvent>(this.host.nativeElement, 'mousedown', passiveEventListenerOptions),\n                fromEvent<TouchEvent>(this.host.nativeElement, 'touchstart', passiveEventListenerOptions)\n            )\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe((event: MouseEvent | TouchEvent) => {\n                    this.thyResizableService.handleMouseDownOutsideAngular$.next(\n                        new ThyResizeHandleMouseDownEvent(this.thyDirection, event)\n                    );\n                });\n        });\n    }\n}\n"]}
@@ -1,21 +1,20 @@
1
1
  import { Directive, ContentChildren, QueryList } from '@angular/core';
2
2
  import { CdkDrag } from '@angular/cdk/drag-drop';
3
3
  import { merge, Subject } from 'rxjs';
4
- import { MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';
5
4
  import { takeUntil, startWith } from 'rxjs/operators';
6
5
  import * as i0 from "@angular/core";
7
- const _MixinBase = mixinUnsubscribe(MixinBase);
8
6
  /**
9
7
  * @private
10
8
  */
11
- export class ThyDragDropDirective extends _MixinBase {
9
+ export class ThyDragDropDirective {
12
10
  constructor() {
13
- super();
11
+ this.ngUnsubscribe$ = new Subject();
14
12
  }
15
13
  ngAfterContentInit() {
16
14
  if (this.draggables) {
17
15
  this.draggables.changes.pipe(startWith(this.draggables)).subscribe(() => {
18
- super.ngOnDestroy();
16
+ this.ngUnsubscribe$.next();
17
+ this.ngUnsubscribe$.complete();
19
18
  this.ngUnsubscribe$ = new Subject();
20
19
  merge(...this.draggables.toArray().map(dragRef => {
21
20
  return dragRef.started;
@@ -33,10 +32,11 @@ export class ThyDragDropDirective extends _MixinBase {
33
32
  }
34
33
  }
35
34
  ngOnDestroy() {
36
- super.ngOnDestroy();
35
+ this.ngUnsubscribe$.next();
36
+ this.ngUnsubscribe$.complete();
37
37
  }
38
38
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyDragDropDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
39
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.3", type: ThyDragDropDirective, isStandalone: true, selector: "[thyDragDrop]", queries: [{ propertyName: "draggables", predicate: CdkDrag, descendants: true }], usesInheritance: true, ngImport: i0 }); }
39
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.3", type: ThyDragDropDirective, isStandalone: true, selector: "[thyDragDrop]", queries: [{ propertyName: "draggables", predicate: CdkDrag, descendants: true }], ngImport: i0 }); }
40
40
  }
41
41
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThyDragDropDirective, decorators: [{
42
42
  type: Directive,
@@ -48,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
48
48
  type: ContentChildren,
49
49
  args: [CdkDrag, { descendants: true }]
50
50
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh5LWRyYWctZHJvcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvc2hhcmVkL2RpcmVjdGl2ZXMvdGh5LWRyYWctZHJvcC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBb0IsZUFBZSxFQUFFLFNBQVMsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUNuRyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDakQsT0FBTyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFlLFNBQVMsRUFBRSxnQkFBZ0IsRUFBa0IsTUFBTSxpQkFBaUIsQ0FBQztBQUMzRixPQUFPLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQUV0RCxNQUFNLFVBQVUsR0FBbUQsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFL0Y7O0dBRUc7QUFLSCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsVUFBVTtJQUdoRDtRQUNJLEtBQUssRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUVELGtCQUFrQjtRQUNkLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ2xCLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDcEUsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO2dCQUNwQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7Z0JBQ3BDLEtBQUssQ0FDRCxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUFFO29CQUN2QyxPQUFPLE9BQU8sQ0FBQyxPQUFPLENBQUM7Z0JBQzNCLENBQUMsQ0FBQyxDQUNMO3FCQUNJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO3FCQUNwQyxTQUFTLENBQUMsR0FBRyxFQUFFO29CQUNaLFFBQVEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO2dCQUNyRCxDQUFDLENBQUMsQ0FBQztnQkFFUCxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztxQkFDL0QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7cUJBQ3BDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7b0JBQ1osUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUM7Z0JBQ3hELENBQUMsQ0FBQyxDQUFDO1lBQ1gsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDUCxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDeEIsQ0FBQzs4R0FqQ1Esb0JBQW9CO2tHQUFwQixvQkFBb0Isb0dBQ1osT0FBTzs7MkZBRGYsb0JBQW9CO2tCQUpoQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxlQUFlO29CQUN6QixVQUFVLEVBQUUsSUFBSTtpQkFDbkI7d0RBRW9ELFVBQVU7c0JBQTFELGVBQWU7dUJBQUMsT0FBTyxFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgQWZ0ZXJDb250ZW50SW5pdCwgQ29udGVudENoaWxkcmVuLCBRdWVyeUxpc3QsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2RrRHJhZyB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kcmFnLWRyb3AnO1xuaW1wb3J0IHsgbWVyZ2UsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IENvbnN0cnVjdG9yLCBNaXhpbkJhc2UsIG1peGluVW5zdWJzY3JpYmUsIFRoeVVuc3Vic2NyaWJlIH0gZnJvbSAnbmd4LXRldGh5cy9jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbCwgc3RhcnRXaXRoIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5jb25zdCBfTWl4aW5CYXNlOiBDb25zdHJ1Y3RvcjxUaHlVbnN1YnNjcmliZT4gJiB0eXBlb2YgTWl4aW5CYXNlID0gbWl4aW5VbnN1YnNjcmliZShNaXhpbkJhc2UpO1xuXG4vKipcbiAqIEBwcml2YXRlXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3RoeURyYWdEcm9wXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnRHJvcERpcmVjdGl2ZSBleHRlbmRzIF9NaXhpbkJhc2UgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0LCBPbkRlc3Ryb3kge1xuICAgIEBDb250ZW50Q2hpbGRyZW4oQ2RrRHJhZywgeyBkZXNjZW5kYW50czogdHJ1ZSB9KSBkcmFnZ2FibGVzOiBRdWVyeUxpc3Q8Q2RrRHJhZz47XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBuZ0FmdGVyQ29udGVudEluaXQoKSB7XG4gICAgICAgIGlmICh0aGlzLmRyYWdnYWJsZXMpIHtcbiAgICAgICAgICAgIHRoaXMuZHJhZ2dhYmxlcy5jaGFuZ2VzLnBpcGUoc3RhcnRXaXRoKHRoaXMuZHJhZ2dhYmxlcykpLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgICAgICAgc3VwZXIubmdPbkRlc3Ryb3koKTtcbiAgICAgICAgICAgICAgICB0aGlzLm5nVW5zdWJzY3JpYmUkID0gbmV3IFN1YmplY3QoKTtcbiAgICAgICAgICAgICAgICBtZXJnZShcbiAgICAgICAgICAgICAgICAgICAgLi4udGhpcy5kcmFnZ2FibGVzLnRvQXJyYXkoKS5tYXAoZHJhZ1JlZiA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gZHJhZ1JlZi5zdGFydGVkO1xuICAgICAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMubmdVbnN1YnNjcmliZSQpKVxuICAgICAgICAgICAgICAgICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGRvY3VtZW50LmJvZHkuY2xhc3NMaXN0LmFkZCgndGh5LWRyYWdnaW5nLWJvZHknKTtcbiAgICAgICAgICAgICAgICAgICAgfSk7XG5cbiAgICAgICAgICAgICAgICBtZXJnZSguLi50aGlzLmRyYWdnYWJsZXMudG9BcnJheSgpLm1hcChkcmFnUmVmID0+IGRyYWdSZWYucmVsZWFzZWQpKVxuICAgICAgICAgICAgICAgICAgICAucGlwZSh0YWtlVW50aWwodGhpcy5uZ1Vuc3Vic2NyaWJlJCkpXG4gICAgICAgICAgICAgICAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZG9jdW1lbnQuYm9keS5jbGFzc0xpc3QucmVtb3ZlKCd0aHktZHJhZ2dpbmctYm9keScpO1xuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKSB7XG4gICAgICAgIHN1cGVyLm5nT25EZXN0cm95KCk7XG4gICAgfVxufVxuIl19
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh5LWRyYWctZHJvcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvc2hhcmVkL2RpcmVjdGl2ZXMvdGh5LWRyYWctZHJvcC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBb0IsZUFBZSxFQUFFLFNBQVMsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUNuRyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDakQsT0FBTyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFFdEQ7O0dBRUc7QUFLSCxNQUFNLE9BQU8sb0JBQW9CO0lBSzdCO1FBRlEsbUJBQWMsR0FBRyxJQUFJLE9BQU8sRUFBRSxDQUFDO0lBRXhCLENBQUM7SUFFaEIsa0JBQWtCO1FBQ2QsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDbEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNwRSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUMzQixJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUUvQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7Z0JBQ3BDLEtBQUssQ0FDRCxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxFQUFFO29CQUN2QyxPQUFPLE9BQU8sQ0FBQyxPQUFPLENBQUM7Z0JBQzNCLENBQUMsQ0FBQyxDQUNMO3FCQUNJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO3FCQUNwQyxTQUFTLENBQUMsR0FBRyxFQUFFO29CQUNaLFFBQVEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO2dCQUNyRCxDQUFDLENBQUMsQ0FBQztnQkFFUCxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztxQkFDL0QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7cUJBQ3BDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7b0JBQ1osUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUM7Z0JBQ3hELENBQUMsQ0FBQyxDQUFDO1lBQ1gsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbkMsQ0FBQzs4R0FwQ1Esb0JBQW9CO2tHQUFwQixvQkFBb0Isb0dBQ1osT0FBTzs7MkZBRGYsb0JBQW9CO2tCQUpoQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxlQUFlO29CQUN6QixVQUFVLEVBQUUsSUFBSTtpQkFDbkI7d0RBRW9ELFVBQVU7c0JBQTFELGVBQWU7dUJBQUMsT0FBTyxFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgQWZ0ZXJDb250ZW50SW5pdCwgQ29udGVudENoaWxkcmVuLCBRdWVyeUxpc3QsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2RrRHJhZyB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kcmFnLWRyb3AnO1xuaW1wb3J0IHsgbWVyZ2UsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IHRha2VVbnRpbCwgc3RhcnRXaXRoIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG4vKipcbiAqIEBwcml2YXRlXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3RoeURyYWdEcm9wXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnRHJvcERpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQsIE9uRGVzdHJveSB7XG4gICAgQENvbnRlbnRDaGlsZHJlbihDZGtEcmFnLCB7IGRlc2NlbmRhbnRzOiB0cnVlIH0pIGRyYWdnYWJsZXM6IFF1ZXJ5TGlzdDxDZGtEcmFnPjtcblxuICAgIHByaXZhdGUgbmdVbnN1YnNjcmliZSQgPSBuZXcgU3ViamVjdCgpO1xuXG4gICAgY29uc3RydWN0b3IoKSB7fVxuXG4gICAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xuICAgICAgICBpZiAodGhpcy5kcmFnZ2FibGVzKSB7XG4gICAgICAgICAgICB0aGlzLmRyYWdnYWJsZXMuY2hhbmdlcy5waXBlKHN0YXJ0V2l0aCh0aGlzLmRyYWdnYWJsZXMpKS5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMubmdVbnN1YnNjcmliZSQubmV4dCgpO1xuICAgICAgICAgICAgICAgIHRoaXMubmdVbnN1YnNjcmliZSQuY29tcGxldGUoKTtcblxuICAgICAgICAgICAgICAgIHRoaXMubmdVbnN1YnNjcmliZSQgPSBuZXcgU3ViamVjdCgpO1xuICAgICAgICAgICAgICAgIG1lcmdlKFxuICAgICAgICAgICAgICAgICAgICAuLi50aGlzLmRyYWdnYWJsZXMudG9BcnJheSgpLm1hcChkcmFnUmVmID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBkcmFnUmVmLnN0YXJ0ZWQ7XG4gICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAgICAgICAucGlwZSh0YWtlVW50aWwodGhpcy5uZ1Vuc3Vic2NyaWJlJCkpXG4gICAgICAgICAgICAgICAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgZG9jdW1lbnQuYm9keS5jbGFzc0xpc3QuYWRkKCd0aHktZHJhZ2dpbmctYm9keScpO1xuICAgICAgICAgICAgICAgICAgICB9KTtcblxuICAgICAgICAgICAgICAgIG1lcmdlKC4uLnRoaXMuZHJhZ2dhYmxlcy50b0FycmF5KCkubWFwKGRyYWdSZWYgPT4gZHJhZ1JlZi5yZWxlYXNlZCkpXG4gICAgICAgICAgICAgICAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLm5nVW5zdWJzY3JpYmUkKSlcbiAgICAgICAgICAgICAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBkb2N1bWVudC5ib2R5LmNsYXNzTGlzdC5yZW1vdmUoJ3RoeS1kcmFnZ2luZy1ib2R5Jyk7XG4gICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZ1Vuc3Vic2NyaWJlJC5uZXh0KCk7XG4gICAgICAgIHRoaXMubmdVbnN1YnNjcmliZSQuY29tcGxldGUoKTtcbiAgICB9XG59XG4iXX0=
@@ -1,7 +1,6 @@
1
- import { MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';
2
1
  import { useHostRenderer } from '@tethys/cdk/dom';
3
- import { takeUntil } from 'rxjs/operators';
4
- import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, Directive, HostBinding, Input, QueryList, TemplateRef } from '@angular/core';
2
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
+ import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, DestroyRef, Directive, HostBinding, inject, Input, QueryList, TemplateRef } from '@angular/core';
5
4
  import { getNumericSize } from 'ngx-tethys/core';
6
5
  import { NgFor, NgTemplateOutlet } from '@angular/common';
7
6
  import * as i0 from "@angular/core";
@@ -27,13 +26,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
27
26
  }]
28
27
  }], ctorParameters: () => [] });
29
28
  const DEFAULT_SIZE = 'md';
30
- const _MixinBase = mixinUnsubscribe(MixinBase);
31
29
  /**
32
30
  * 间距组件
33
31
  * @name thy-space
34
32
  * @order 10
35
33
  */
36
- export class ThySpace extends _MixinBase {
34
+ export class ThySpace {
37
35
  /**
38
36
  * 大小,支持 `zero` | `xxs` | `xs` | `sm` | `md` | `lg` | `xlg` 和自定义数字大小
39
37
  * @type string | number
@@ -49,8 +47,8 @@ export class ThySpace extends _MixinBase {
49
47
  this.hostRenderer.updateClass(align ? [`align-items-${align}`] : []);
50
48
  }
51
49
  constructor(cdr) {
52
- super();
53
50
  this.cdr = cdr;
51
+ this.destroyRef = inject(DestroyRef);
54
52
  this.space = getNumericSize(DEFAULT_SIZE);
55
53
  this.hostRenderer = useHostRenderer();
56
54
  /**
@@ -60,12 +58,12 @@ export class ThySpace extends _MixinBase {
60
58
  }
61
59
  ngOnInit() { }
62
60
  ngAfterContentInit() {
63
- this.items.changes.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(() => {
61
+ this.items.changes.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
64
62
  this.cdr.markForCheck();
65
63
  });
66
64
  }
67
65
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThySpace, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
68
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThySpace, isStandalone: true, selector: "thy-space", inputs: { thySize: "thySize", thyVertical: ["thyVertical", "thyVertical", booleanAttribute], thyAlign: "thyAlign" }, host: { properties: { "class.thy-space-vertical": "this.thyVertical" }, classAttribute: "thy-space" }, queries: [{ propertyName: "items", predicate: ThySpaceItemDirective, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n\n<ng-template ngFor let-item let-last=\"last\" let-index=\"index\" [ngForOf]=\"items\">\n <div class=\"thy-space-item\" [style.margin-right.px]=\"last ? null : space\">\n <ng-container [ngTemplateOutlet]=\"item\"></ng-container>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
66
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.2.3", type: ThySpace, isStandalone: true, selector: "thy-space", inputs: { thySize: "thySize", thyVertical: ["thyVertical", "thyVertical", booleanAttribute], thyAlign: "thyAlign" }, host: { properties: { "class.thy-space-vertical": "this.thyVertical" }, classAttribute: "thy-space" }, queries: [{ propertyName: "items", predicate: ThySpaceItemDirective, read: TemplateRef }], ngImport: i0, template: "<ng-content></ng-content>\n\n<ng-template ngFor let-item let-last=\"last\" let-index=\"index\" [ngForOf]=\"items\">\n <div class=\"thy-space-item\" [style.margin-right.px]=\"last ? null : space\">\n <ng-container [ngTemplateOutlet]=\"item\"></ng-container>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
69
67
  }
70
68
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: ThySpace, decorators: [{
71
69
  type: Component,
@@ -86,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
86
84
  type: ContentChildren,
87
85
  args: [ThySpaceItemDirective, { read: TemplateRef }]
88
86
  }] } });
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BhY2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3NwYWNlL3NwYWNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3NyYy9zcGFjZS9zcGFjZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWUsU0FBUyxFQUFFLGdCQUFnQixFQUFrQixNQUFNLGlCQUFpQixDQUFDO0FBQzNGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNsRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFM0MsT0FBTyxFQUVILGdCQUFnQixFQUNoQix1QkFBdUIsRUFDdkIsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxlQUFlLEVBQ2YsU0FBUyxFQUNULFdBQVcsRUFDWCxLQUFLLEVBRUwsU0FBUyxFQUNULFdBQVcsRUFDZCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQWtCLGNBQWMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFFMUQ7Ozs7R0FJRztBQVFILE1BQU0sT0FBTyxxQkFBcUI7SUFDOUIsZ0JBQWUsQ0FBQztJQUVoQixRQUFRLEtBQVUsQ0FBQzs4R0FIVixxQkFBcUI7a0dBQXJCLHFCQUFxQjs7MkZBQXJCLHFCQUFxQjtrQkFQakMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixJQUFJLEVBQUU7d0JBQ0YsS0FBSyxFQUFFLGdCQUFnQjtxQkFDMUI7b0JBQ0QsVUFBVSxFQUFFLElBQUk7aUJBQ25COztBQU9ELE1BQU0sWUFBWSxHQUFtQixJQUFJLENBQUM7QUFFMUMsTUFBTSxVQUFVLEdBQW1ELGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRS9GOzs7O0dBSUc7QUFXSCxNQUFNLE9BQU8sUUFBUyxTQUFRLFVBQVU7SUFLcEM7OztPQUdHO0lBQ0gsSUFBYSxPQUFPLENBQUMsSUFBb0I7UUFDckMsSUFBSSxDQUFDLEtBQUssR0FBRyxjQUFjLENBQUMsSUFBSSxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFTRCx5Q0FBeUM7SUFDekM7O09BRUc7SUFDSCxJQUNJLFFBQVEsQ0FBQyxLQUFhO1FBQ3RCLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxlQUFlLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFJRCxZQUFvQixHQUFzQjtRQUN0QyxLQUFLLEVBQUUsQ0FBQztRQURRLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBOUJuQyxVQUFLLEdBQVcsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRTVDLGlCQUFZLEdBQUcsZUFBZSxFQUFFLENBQUM7UUFVekM7O1dBRUc7UUFHSCxnQkFBVyxHQUFZLEtBQUssQ0FBQztJQWU3QixDQUFDO0lBRUQsUUFBUSxLQUFVLENBQUM7SUFFbkIsa0JBQWtCO1FBQ2QsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ25FLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDNUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDOzhHQXpDUSxRQUFRO2tHQUFSLFFBQVEsdUhBaUJHLGdCQUFnQixnTEFZbkIscUJBQXFCLFFBQVUsV0FBVyxvREN2Ri9ELGtTQU9BLDRDRGlEYyxLQUFLLG1IQUFFLGdCQUFnQjs7MkZBRXhCLFFBQVE7a0JBVnBCLFNBQVM7K0JBQ0ksV0FBVyxtQkFFSix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNGLEtBQUssRUFBRSxXQUFXO3FCQUNyQixjQUNXLElBQUksV0FDUCxDQUFDLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQztzRkFXckIsT0FBTztzQkFBbkIsS0FBSztnQkFTTixXQUFXO3NCQUZWLFdBQVc7dUJBQUMsMEJBQTBCOztzQkFDdEMsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFRbEMsUUFBUTtzQkFEWCxLQUFLO2dCQUt5RCxLQUFLO3NCQUFuRSxlQUFlO3VCQUFDLHFCQUFxQixFQUFFLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnN0cnVjdG9yLCBNaXhpbkJhc2UsIG1peGluVW5zdWJzY3JpYmUsIFRoeVVuc3Vic2NyaWJlIH0gZnJvbSAnbmd4LXRldGh5cy9jb3JlJztcbmltcG9ydCB7IHVzZUhvc3RSZW5kZXJlciB9IGZyb20gJ0B0ZXRoeXMvY2RrL2RvbSc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7XG4gICAgQWZ0ZXJDb250ZW50SW5pdCxcbiAgICBib29sZWFuQXR0cmlidXRlLFxuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENoYW5nZURldGVjdG9yUmVmLFxuICAgIENvbXBvbmVudCxcbiAgICBDb250ZW50Q2hpbGRyZW4sXG4gICAgRGlyZWN0aXZlLFxuICAgIEhvc3RCaW5kaW5nLFxuICAgIElucHV0LFxuICAgIE9uSW5pdCxcbiAgICBRdWVyeUxpc3QsXG4gICAgVGVtcGxhdGVSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlTcGFjaW5nU2l6ZSwgZ2V0TnVtZXJpY1NpemUgfSBmcm9tICduZ3gtdGV0aHlzL2NvcmUnO1xuaW1wb3J0IHsgTmdGb3IsIE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG4vKipcbiAqIOmXtOi3nee7hOS7tumhue+8jOS9v+eUqOe7k+aehOaAp+aMh+S7pCAqdGh5U3BhY2VJdGVtIOS8oOWFpeaooeadv1xuICogQG5hbWUgdGh5U3BhY2VJdGVtXG4gKiBAb3JkZXIgMjBcbiAqL1xuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbdGh5U3BhY2VJdGVtXScsXG4gICAgaG9zdDoge1xuICAgICAgICBjbGFzczogJ3RoeS1zcGFjZS1pdGVtJ1xuICAgIH0sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBUaHlTcGFjZUl0ZW1EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIGNvbnN0cnVjdG9yKCkge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge31cbn1cblxuY29uc3QgREVGQVVMVF9TSVpFOiBUaHlTcGFjaW5nU2l6ZSA9ICdtZCc7XG5cbmNvbnN0IF9NaXhpbkJhc2U6IENvbnN0cnVjdG9yPFRoeVVuc3Vic2NyaWJlPiAmIHR5cGVvZiBNaXhpbkJhc2UgPSBtaXhpblVuc3Vic2NyaWJlKE1peGluQmFzZSk7XG5cbi8qKlxuICog6Ze06Led57uE5Lu2XG4gKiBAbmFtZSB0aHktc3BhY2VcbiAqIEBvcmRlciAxMFxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RoeS1zcGFjZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NwYWNlLmNvbXBvbmVudC5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAndGh5LXNwYWNlJ1xuICAgIH0sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTmdGb3IsIE5nVGVtcGxhdGVPdXRsZXRdXG59KVxuZXhwb3J0IGNsYXNzIFRoeVNwYWNlIGV4dGVuZHMgX01peGluQmFzZSBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJDb250ZW50SW5pdCB7XG4gICAgcHVibGljIHNwYWNlOiBudW1iZXIgPSBnZXROdW1lcmljU2l6ZShERUZBVUxUX1NJWkUpO1xuXG4gICAgcHJpdmF0ZSBob3N0UmVuZGVyZXIgPSB1c2VIb3N0UmVuZGVyZXIoKTtcblxuICAgIC8qKlxuICAgICAqIOWkp+Wwj++8jOaUr+aMgSBgemVyb2AgfCBgeHhzYCB8IGB4c2AgfCBgc21gIHwgYG1kYCB8IGBsZ2AgfCBgeGxnYCDlkozoh6rlrprkuYnmlbDlrZflpKflsI9cbiAgICAgKiBAdHlwZSBzdHJpbmcgfCBudW1iZXJcbiAgICAgKi9cbiAgICBASW5wdXQoKSBzZXQgdGh5U2l6ZShzaXplOiBUaHlTcGFjaW5nU2l6ZSkge1xuICAgICAgICB0aGlzLnNwYWNlID0gZ2V0TnVtZXJpY1NpemUoc2l6ZSwgREVGQVVMVF9TSVpFKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiDpl7Tot53lnoLnm7TmlrnlkJHvvIzpu5jorqTmmK/msLTlubPmlrnlkJFcbiAgICAgKi9cbiAgICBASG9zdEJpbmRpbmcoYGNsYXNzLnRoeS1zcGFjZS12ZXJ0aWNhbGApXG4gICAgQElucHV0KHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pXG4gICAgdGh5VmVydGljYWw6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAgIC8vIEBDbGFzc0JpbmRpbmcoYGFsaWduLWl0ZW1zLXt7dmFsdWV9fWApXG4gICAgLyoqXG4gICAgICog5a+56b2Q5pa55byP77yM5Y+v6YCJ5oupIGBzdGFydGAgfCBgZW5kYCB8IGBiYXNlbGluZWAgfCBgY2VudGVyYFxuICAgICAqL1xuICAgIEBJbnB1dCgpXG4gICAgc2V0IHRoeUFsaWduKGFsaWduOiBzdHJpbmcpIHtcbiAgICAgICAgdGhpcy5ob3N0UmVuZGVyZXIudXBkYXRlQ2xhc3MoYWxpZ24gPyBbYGFsaWduLWl0ZW1zLSR7YWxpZ259YF0gOiBbXSk7XG4gICAgfVxuXG4gICAgQENvbnRlbnRDaGlsZHJlbihUaHlTcGFjZUl0ZW1EaXJlY3RpdmUsIHsgcmVhZDogVGVtcGxhdGVSZWYgfSkgaXRlbXMhOiBRdWVyeUxpc3Q8VGVtcGxhdGVSZWY8SFRNTEVsZW1lbnQ+PjtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge31cblxuICAgIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pdGVtcy5jaGFuZ2VzLnBpcGUodGFrZVVudGlsKHRoaXMubmdVbnN1YnNjcmliZSQpKS5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cblxuPG5nLXRlbXBsYXRlIG5nRm9yIGxldC1pdGVtIGxldC1sYXN0PVwibGFzdFwiIGxldC1pbmRleD1cImluZGV4XCIgW25nRm9yT2ZdPVwiaXRlbXNcIj5cbiAgPGRpdiBjbGFzcz1cInRoeS1zcGFjZS1pdGVtXCIgW3N0eWxlLm1hcmdpbi1yaWdodC5weF09XCJsYXN0ID8gbnVsbCA6IHNwYWNlXCI+XG4gICAgPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJpdGVtXCI+PC9uZy1jb250YWluZXI+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BhY2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3NwYWNlL3NwYWNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3NyYy9zcGFjZS9zcGFjZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFFaEUsT0FBTyxFQUVILGdCQUFnQixFQUNoQix1QkFBdUIsRUFDdkIsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxlQUFlLEVBQ2YsVUFBVSxFQUNWLFNBQVMsRUFDVCxXQUFXLEVBQ1gsTUFBTSxFQUNOLEtBQUssRUFFTCxTQUFTLEVBQ1QsV0FBVyxFQUNkLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBa0IsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDakUsT0FBTyxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUUxRDs7OztHQUlHO0FBUUgsTUFBTSxPQUFPLHFCQUFxQjtJQUM5QixnQkFBZSxDQUFDO0lBRWhCLFFBQVEsS0FBVSxDQUFDOzhHQUhWLHFCQUFxQjtrR0FBckIscUJBQXFCOzsyRkFBckIscUJBQXFCO2tCQVBqQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLElBQUksRUFBRTt3QkFDRixLQUFLLEVBQUUsZ0JBQWdCO3FCQUMxQjtvQkFDRCxVQUFVLEVBQUUsSUFBSTtpQkFDbkI7O0FBT0QsTUFBTSxZQUFZLEdBQW1CLElBQUksQ0FBQztBQUUxQzs7OztHQUlHO0FBV0gsTUFBTSxPQUFPLFFBQVE7SUFPakI7OztPQUdHO0lBQ0gsSUFBYSxPQUFPLENBQUMsSUFBb0I7UUFDckMsSUFBSSxDQUFDLEtBQUssR0FBRyxjQUFjLENBQUMsSUFBSSxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFTRCx5Q0FBeUM7SUFDekM7O09BRUc7SUFDSCxJQUNJLFFBQVEsQ0FBQyxLQUFhO1FBQ3RCLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxlQUFlLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFJRCxZQUFvQixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQWhDekIsZUFBVSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUUxQyxVQUFLLEdBQVcsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRTVDLGlCQUFZLEdBQUcsZUFBZSxFQUFFLENBQUM7UUFVekM7O1dBRUc7UUFHSCxnQkFBVyxHQUFZLEtBQUssQ0FBQztJQWFnQixDQUFDO0lBRTlDLFFBQVEsS0FBVSxDQUFDO0lBRW5CLGtCQUFrQjtRQUNkLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3hFLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDNUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDOzhHQXpDUSxRQUFRO2tHQUFSLFFBQVEsdUhBbUJHLGdCQUFnQixnTEFZbkIscUJBQXFCLFFBQVUsV0FBVyw2QkN4Ri9ELGtTQU9BLDRDRGdEYyxLQUFLLG1IQUFFLGdCQUFnQjs7MkZBRXhCLFFBQVE7a0JBVnBCLFNBQVM7K0JBQ0ksV0FBVyxtQkFFSix1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNGLEtBQUssRUFBRSxXQUFXO3FCQUNyQixjQUNXLElBQUksV0FDUCxDQUFDLEtBQUssRUFBRSxnQkFBZ0IsQ0FBQztzRkFhckIsT0FBTztzQkFBbkIsS0FBSztnQkFTTixXQUFXO3NCQUZWLFdBQVc7dUJBQUMsMEJBQTBCOztzQkFDdEMsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFRbEMsUUFBUTtzQkFEWCxLQUFLO2dCQUt5RCxLQUFLO3NCQUFuRSxlQUFlO3VCQUFDLHFCQUFxQixFQUFFLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUhvc3RSZW5kZXJlciB9IGZyb20gJ0B0ZXRoeXMvY2RrL2RvbSc7XG5pbXBvcnQgeyB0YWtlVW50aWxEZXN0cm95ZWQgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5cbmltcG9ydCB7XG4gICAgQWZ0ZXJDb250ZW50SW5pdCxcbiAgICBib29sZWFuQXR0cmlidXRlLFxuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENoYW5nZURldGVjdG9yUmVmLFxuICAgIENvbXBvbmVudCxcbiAgICBDb250ZW50Q2hpbGRyZW4sXG4gICAgRGVzdHJveVJlZixcbiAgICBEaXJlY3RpdmUsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgaW5qZWN0LFxuICAgIElucHV0LFxuICAgIE9uSW5pdCxcbiAgICBRdWVyeUxpc3QsXG4gICAgVGVtcGxhdGVSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlTcGFjaW5nU2l6ZSwgZ2V0TnVtZXJpY1NpemUgfSBmcm9tICduZ3gtdGV0aHlzL2NvcmUnO1xuaW1wb3J0IHsgTmdGb3IsIE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG4vKipcbiAqIOmXtOi3nee7hOS7tumhue+8jOS9v+eUqOe7k+aehOaAp+aMh+S7pCAqdGh5U3BhY2VJdGVtIOS8oOWFpeaooeadv1xuICogQG5hbWUgdGh5U3BhY2VJdGVtXG4gKiBAb3JkZXIgMjBcbiAqL1xuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbdGh5U3BhY2VJdGVtXScsXG4gICAgaG9zdDoge1xuICAgICAgICBjbGFzczogJ3RoeS1zcGFjZS1pdGVtJ1xuICAgIH0sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBUaHlTcGFjZUl0ZW1EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIGNvbnN0cnVjdG9yKCkge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge31cbn1cblxuY29uc3QgREVGQVVMVF9TSVpFOiBUaHlTcGFjaW5nU2l6ZSA9ICdtZCc7XG5cbi8qKlxuICog6Ze06Led57uE5Lu2XG4gKiBAbmFtZSB0aHktc3BhY2VcbiAqIEBvcmRlciAxMFxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RoeS1zcGFjZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NwYWNlLmNvbXBvbmVudC5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAndGh5LXNwYWNlJ1xuICAgIH0sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTmdGb3IsIE5nVGVtcGxhdGVPdXRsZXRdXG59KVxuZXhwb3J0IGNsYXNzIFRoeVNwYWNlIGltcGxlbWVudHMgT25Jbml0LCBBZnRlckNvbnRlbnRJbml0IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRlc3Ryb3lSZWYgPSBpbmplY3QoRGVzdHJveVJlZik7XG5cbiAgICBwdWJsaWMgc3BhY2U6IG51bWJlciA9IGdldE51bWVyaWNTaXplKERFRkFVTFRfU0laRSk7XG5cbiAgICBwcml2YXRlIGhvc3RSZW5kZXJlciA9IHVzZUhvc3RSZW5kZXJlcigpO1xuXG4gICAgLyoqXG4gICAgICog5aSn5bCP77yM5pSv5oyBIGB6ZXJvYCB8IGB4eHNgIHwgYHhzYCB8IGBzbWAgfCBgbWRgIHwgYGxnYCB8IGB4bGdgIOWSjOiHquWumuS5ieaVsOWtl+Wkp+Wwj1xuICAgICAqIEB0eXBlIHN0cmluZyB8IG51bWJlclxuICAgICAqL1xuICAgIEBJbnB1dCgpIHNldCB0aHlTaXplKHNpemU6IFRoeVNwYWNpbmdTaXplKSB7XG4gICAgICAgIHRoaXMuc3BhY2UgPSBnZXROdW1lcmljU2l6ZShzaXplLCBERUZBVUxUX1NJWkUpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIOmXtOi3neWeguebtOaWueWQke+8jOm7mOiupOaYr+awtOW5s+aWueWQkVxuICAgICAqL1xuICAgIEBIb3N0QmluZGluZyhgY2xhc3MudGh5LXNwYWNlLXZlcnRpY2FsYClcbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgICB0aHlWZXJ0aWNhbDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gICAgLy8gQENsYXNzQmluZGluZyhgYWxpZ24taXRlbXMte3t2YWx1ZX19YClcbiAgICAvKipcbiAgICAgKiDlr7npvZDmlrnlvI/vvIzlj6/pgInmi6kgYHN0YXJ0YCB8IGBlbmRgIHwgYGJhc2VsaW5lYCB8IGBjZW50ZXJgXG4gICAgICovXG4gICAgQElucHV0KClcbiAgICBzZXQgdGh5QWxpZ24oYWxpZ246IHN0cmluZykge1xuICAgICAgICB0aGlzLmhvc3RSZW5kZXJlci51cGRhdGVDbGFzcyhhbGlnbiA/IFtgYWxpZ24taXRlbXMtJHthbGlnbn1gXSA6IFtdKTtcbiAgICB9XG5cbiAgICBAQ29udGVudENoaWxkcmVuKFRoeVNwYWNlSXRlbURpcmVjdGl2ZSwgeyByZWFkOiBUZW1wbGF0ZVJlZiB9KSBpdGVtcyE6IFF1ZXJ5TGlzdDxUZW1wbGF0ZVJlZjxIVE1MRWxlbWVudD4+O1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7fVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7fVxuXG4gICAgbmdBZnRlckNvbnRlbnRJbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLml0ZW1zLmNoYW5nZXMucGlwZSh0YWtlVW50aWxEZXN0cm95ZWQodGhpcy5kZXN0cm95UmVmKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgIHRoaXMuY2RyLm1hcmtGb3JDaGVjaygpO1xuICAgICAgICB9KTtcbiAgICB9XG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG5cbjxuZy10ZW1wbGF0ZSBuZ0ZvciBsZXQtaXRlbSBsZXQtbGFzdD1cImxhc3RcIiBsZXQtaW5kZXg9XCJpbmRleFwiIFtuZ0Zvck9mXT1cIml0ZW1zXCI+XG4gIDxkaXYgY2xhc3M9XCJ0aHktc3BhY2UtaXRlbVwiIFtzdHlsZS5tYXJnaW4tcmlnaHQucHhdPVwibGFzdCA/IG51bGwgOiBzcGFjZVwiPlxuICAgIDxuZy1jb250YWluZXIgW25nVGVtcGxhdGVPdXRsZXRdPVwiaXRlbVwiPjwvbmctY29udGFpbmVyPlxuICA8L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
@@ -1,5 +1,6 @@
1
+ import { coerceCssPixelValue } from '@angular/cdk/coercion';
1
2
  import { Component, ContentChild, ElementRef, EventEmitter, Inject, InjectionToken, Input, Optional, Output, TemplateRef, ViewEncapsulation, booleanAttribute } from '@angular/core';
2
- import { coerceCssPixelValue, isArray, isObject } from 'ngx-tethys/util';
3
+ import { isArray, isObject } from 'ngx-tethys/util';
3
4
  import { ThyTableSortDirection } from './table.interface';
4
5
  import * as i0 from "@angular/core";
5
6
  /**
@@ -201,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
201
202
  type: ContentChild,
202
203
  args: [TemplateRef, { static: true }]
203
204
  }] } });
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column.component.js","sourceRoot":"","sources":["../../../../src/table/table-column.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { _isNumberValue } from '@angular/cdk/coercion';\nimport {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    InjectionToken,\n    Input,\n    OnInit,\n    Optional,\n    Output,\n    TemplateRef,\n    ViewEncapsulation,\n    booleanAttribute\n} from '@angular/core';\nimport { coerceCssPixelValue, isArray, isObject } from 'ngx-tethys/util';\nimport { ThyTableSortDirection, ThyTableSortEvent } from './table.interface';\n\nexport interface IThyTableColumnParentComponent {\n    rowKey: string;\n    updateColumnSelections(key: string, selections: any): void;\n}\n\n/**\n * Injection token used to provide the parent component to options.\n */\nexport const THY_TABLE_COLUMN_PARENT_COMPONENT = new InjectionToken<IThyTableColumnParentComponent>('THY_TABLE_COLUMN_PARENT_COMPONENT');\n\nexport type FixedDirection = 'left' | 'right';\n\n/**\n * 表格列组件\n * @name thy-table-column\n * @order 20\n */\n@Component({\n    selector: 'thy-table-column',\n    template: '<ng-content></ng-content>',\n    encapsulation: ViewEncapsulation.None,\n    standalone: true\n})\nexport class ThyTableColumnComponent implements OnInit {\n    /**\n     * 设置数据属性 Key，读取数组中对象的当前 Key 值\n     * @type string\n     */\n    @Input('thyModelKey') model = '';\n\n    /**\n     * 设置列名，显示在表头\n     * @type string\n     */\n    @Input('thyTitle') title = '';\n\n    /**\n     * 设置列的特殊类型，序列号、选择框、单选框、切换按钮\n     * @type string\n     */\n    @Input('thyType') type = '';\n\n    public width: string = '';\n\n    /**\n     * 设置列的宽度\n     */\n    @Input()\n    set thyWidth(value: string | number) {\n        this.width = coerceCssPixelValue(value);\n    }\n\n    public minWidth: string = '';\n\n    /**\n     * 设置列的最小宽度\n     */\n    @Input()\n    set thyMinWidth(value: string | number) {\n        this.minWidth = coerceCssPixelValue(value);\n    }\n\n    /**\n     * 设置列的样式\n     */\n    @Input('thyClassName') className = '';\n\n    /**\n     * 设置列头部的 Class，即 th 元素上的样式\n     * @type string\n     */\n    @Input('thyHeaderClassName') headerClassName = '';\n\n    /**\n     * 设置自定义类型的禁用状态\n     * @type boolean\n     */\n    @Input({ alias: 'thyDisabled', transform: booleanAttribute }) disabled = false;\n\n    /**\n     * thyType 为 checkbox 或者 radio 类型时选中的数据 ，支持单个对象，单个 Id，同时支持多个 Id，多个对象\n     */\n    @Input('thySelections')\n    set selections(value: any) {\n        if (value) {\n            this._selections = isArray(value) ? value : [value];\n            this._selections = this._selections.map((item: string | number | object) => {\n                return isObject(item) ? item[this.parent.rowKey] : item;\n            });\n            if (!this._firstChange) {\n                this.parent.updateColumnSelections(this.key, this._selections);\n            }\n        }\n    }\n\n    get selections() {\n        return this._selections;\n    }\n    /**\n     * 设置数据为空的时候显示的文本\n     * @type string\n     */\n    @Input('thyDefaultText') defaultText = '';\n\n    /**\n     * 设置 Tree 模式下折叠展开按钮展示列，不传默认第一列\n     */\n    @Input({ alias: 'thyExpand', transform: booleanAttribute }) expand = false;\n\n    public sortable: boolean;\n\n    /**\n     * 是否开启列排序功能（开启时 thyModelKey 为 必传）\n     * @default false\n     */\n    @Input({ transform: booleanAttribute })\n    set thySortable(value: boolean) {\n        if (value) {\n            if (this.model) {\n                this.sortable = true;\n            } else {\n                throw new Error(`thyModelKey is required when sortable`);\n            }\n        } else {\n            this.sortable = false;\n        }\n    }\n\n    /**\n     * 默认列排序顺序\n     * @type 'asc' | 'desc' | ''\n     */\n    @Input('thySortDirection') sortDirection = ThyTableSortDirection.default;\n\n    /**\n     * 设置固定列\n     */\n    @Input('thyFixed') fixed: FixedDirection;\n\n    /**\n     * 当前列是否是操作列，设置为 true 时会追加 thy-operation-links 样式类，文字居中\n     * @default false\n     */\n    @Input({ alias: 'thyOperational', transform: booleanAttribute }) operational: boolean;\n\n    /**\n     * 当前列是否是次要列，设置为 true 时会追加 thy-table-column-secondary 样式类，文字颜色为 $gray-600\n     * @default false\n     */\n    @Input({ alias: 'thySecondary', transform: booleanAttribute }) secondary: boolean;\n\n    /**\n     * 列排序修改事件\n     */\n    @Output('thySortChange') sortChange: EventEmitter<ThyTableSortEvent> = new EventEmitter<ThyTableSortEvent>();\n\n    @ContentChild('header', { static: true }) headerTemplateRef: TemplateRef<any>;\n\n    @ContentChild('cell', { static: true }) cellTemplateRef: TemplateRef<any>;\n\n    @ContentChild(TemplateRef, { static: true })\n    set templateRef(value: TemplateRef<any>) {\n        if (value) {\n            if (!this.headerTemplateRef && !this.cellTemplateRef) {\n                this.cellTemplateRef = value;\n            }\n        }\n    }\n\n    public key?: string;\n\n    public left: number;\n\n    public right: number;\n\n    private _selections: any;\n\n    private _firstChange = true;\n\n    constructor(\n        private el: ElementRef,\n        @Optional()\n        @Inject(THY_TABLE_COLUMN_PARENT_COMPONENT)\n        public parent: IThyTableColumnParentComponent\n    ) {}\n\n    ngOnInit() {\n        this.key = this._generateKey();\n        this._firstChange = false;\n    }\n\n    private _generateKey() {\n        return '[$$column]' + Math.random().toString(16).slice(2, 10);\n    }\n}\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column.component.js","sourceRoot":"","sources":["../../../../src/table/table-column.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { _isNumberValue, coerceCssPixelValue } from '@angular/cdk/coercion';\nimport {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    Inject,\n    InjectionToken,\n    Input,\n    OnInit,\n    Optional,\n    Output,\n    TemplateRef,\n    ViewEncapsulation,\n    booleanAttribute\n} from '@angular/core';\nimport { isArray, isObject } from 'ngx-tethys/util';\nimport { ThyTableSortDirection, ThyTableSortEvent } from './table.interface';\n\nexport interface IThyTableColumnParentComponent {\n    rowKey: string;\n    updateColumnSelections(key: string, selections: any): void;\n}\n\n/**\n * Injection token used to provide the parent component to options.\n */\nexport const THY_TABLE_COLUMN_PARENT_COMPONENT = new InjectionToken<IThyTableColumnParentComponent>('THY_TABLE_COLUMN_PARENT_COMPONENT');\n\nexport type FixedDirection = 'left' | 'right';\n\n/**\n * 表格列组件\n * @name thy-table-column\n * @order 20\n */\n@Component({\n    selector: 'thy-table-column',\n    template: '<ng-content></ng-content>',\n    encapsulation: ViewEncapsulation.None,\n    standalone: true\n})\nexport class ThyTableColumnComponent implements OnInit {\n    /**\n     * 设置数据属性 Key，读取数组中对象的当前 Key 值\n     * @type string\n     */\n    @Input('thyModelKey') model = '';\n\n    /**\n     * 设置列名，显示在表头\n     * @type string\n     */\n    @Input('thyTitle') title = '';\n\n    /**\n     * 设置列的特殊类型，序列号、选择框、单选框、切换按钮\n     * @type string\n     */\n    @Input('thyType') type = '';\n\n    public width: string = '';\n\n    /**\n     * 设置列的宽度\n     */\n    @Input()\n    set thyWidth(value: string | number) {\n        this.width = coerceCssPixelValue(value);\n    }\n\n    public minWidth: string = '';\n\n    /**\n     * 设置列的最小宽度\n     */\n    @Input()\n    set thyMinWidth(value: string | number) {\n        this.minWidth = coerceCssPixelValue(value);\n    }\n\n    /**\n     * 设置列的样式\n     */\n    @Input('thyClassName') className = '';\n\n    /**\n     * 设置列头部的 Class，即 th 元素上的样式\n     * @type string\n     */\n    @Input('thyHeaderClassName') headerClassName = '';\n\n    /**\n     * 设置自定义类型的禁用状态\n     * @type boolean\n     */\n    @Input({ alias: 'thyDisabled', transform: booleanAttribute }) disabled = false;\n\n    /**\n     * thyType 为 checkbox 或者 radio 类型时选中的数据 ，支持单个对象，单个 Id，同时支持多个 Id，多个对象\n     */\n    @Input('thySelections')\n    set selections(value: any) {\n        if (value) {\n            this._selections = isArray(value) ? value : [value];\n            this._selections = this._selections.map((item: string | number | object) => {\n                return isObject(item) ? item[this.parent.rowKey] : item;\n            });\n            if (!this._firstChange) {\n                this.parent.updateColumnSelections(this.key, this._selections);\n            }\n        }\n    }\n\n    get selections() {\n        return this._selections;\n    }\n    /**\n     * 设置数据为空的时候显示的文本\n     * @type string\n     */\n    @Input('thyDefaultText') defaultText = '';\n\n    /**\n     * 设置 Tree 模式下折叠展开按钮展示列，不传默认第一列\n     */\n    @Input({ alias: 'thyExpand', transform: booleanAttribute }) expand = false;\n\n    public sortable: boolean;\n\n    /**\n     * 是否开启列排序功能（开启时 thyModelKey 为 必传）\n     * @default false\n     */\n    @Input({ transform: booleanAttribute })\n    set thySortable(value: boolean) {\n        if (value) {\n            if (this.model) {\n                this.sortable = true;\n            } else {\n                throw new Error(`thyModelKey is required when sortable`);\n            }\n        } else {\n            this.sortable = false;\n        }\n    }\n\n    /**\n     * 默认列排序顺序\n     * @type 'asc' | 'desc' | ''\n     */\n    @Input('thySortDirection') sortDirection = ThyTableSortDirection.default;\n\n    /**\n     * 设置固定列\n     */\n    @Input('thyFixed') fixed: FixedDirection;\n\n    /**\n     * 当前列是否是操作列，设置为 true 时会追加 thy-operation-links 样式类，文字居中\n     * @default false\n     */\n    @Input({ alias: 'thyOperational', transform: booleanAttribute }) operational: boolean;\n\n    /**\n     * 当前列是否是次要列，设置为 true 时会追加 thy-table-column-secondary 样式类，文字颜色为 $gray-600\n     * @default false\n     */\n    @Input({ alias: 'thySecondary', transform: booleanAttribute }) secondary: boolean;\n\n    /**\n     * 列排序修改事件\n     */\n    @Output('thySortChange') sortChange: EventEmitter<ThyTableSortEvent> = new EventEmitter<ThyTableSortEvent>();\n\n    @ContentChild('header', { static: true }) headerTemplateRef: TemplateRef<any>;\n\n    @ContentChild('cell', { static: true }) cellTemplateRef: TemplateRef<any>;\n\n    @ContentChild(TemplateRef, { static: true })\n    set templateRef(value: TemplateRef<any>) {\n        if (value) {\n            if (!this.headerTemplateRef && !this.cellTemplateRef) {\n                this.cellTemplateRef = value;\n            }\n        }\n    }\n\n    public key?: string;\n\n    public left: number;\n\n    public right: number;\n\n    private _selections: any;\n\n    private _firstChange = true;\n\n    constructor(\n        private el: ElementRef,\n        @Optional()\n        @Inject(THY_TABLE_COLUMN_PARENT_COMPONENT)\n        public parent: IThyTableColumnParentComponent\n    ) {}\n\n    ngOnInit() {\n        this.key = this._generateKey();\n        this._firstChange = false;\n    }\n\n    private _generateKey() {\n        return '[$$column]' + Math.random().toString(16).slice(2, 10);\n    }\n}\n"]}