ngx-tethys 13.2.7 → 13.2.8

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 (51) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/copy/copy.directive.d.ts +16 -2
  3. package/esm2020/copy/copy.directive.mjs +13 -2
  4. package/esm2020/mention/suggestions/suggestions.component.mjs +3 -3
  5. package/esm2020/nav/nav-item.directive.mjs +3 -3
  6. package/esm2020/property/properties.component.mjs +3 -11
  7. package/esm2020/property/property-item.component.mjs +1 -1
  8. package/esm2020/tree-select/tree-select.component.mjs +1 -14
  9. package/esm2020/version.mjs +2 -2
  10. package/esm2020/watermark/watermark.directive.mjs +2 -2
  11. package/fesm2015/ngx-tethys-copy.mjs +12 -1
  12. package/fesm2015/ngx-tethys-copy.mjs.map +1 -1
  13. package/fesm2015/ngx-tethys-mention.mjs +2 -2
  14. package/fesm2015/ngx-tethys-mention.mjs.map +1 -1
  15. package/fesm2015/ngx-tethys-nav.mjs +2 -2
  16. package/fesm2015/ngx-tethys-nav.mjs.map +1 -1
  17. package/fesm2015/ngx-tethys-property.mjs +2 -10
  18. package/fesm2015/ngx-tethys-property.mjs.map +1 -1
  19. package/fesm2015/ngx-tethys-tree-select.mjs +0 -13
  20. package/fesm2015/ngx-tethys-tree-select.mjs.map +1 -1
  21. package/fesm2015/ngx-tethys-watermark.mjs +1 -1
  22. package/fesm2015/ngx-tethys-watermark.mjs.map +1 -1
  23. package/fesm2015/ngx-tethys.mjs +1 -1
  24. package/fesm2015/ngx-tethys.mjs.map +1 -1
  25. package/fesm2020/ngx-tethys-copy.mjs +12 -1
  26. package/fesm2020/ngx-tethys-copy.mjs.map +1 -1
  27. package/fesm2020/ngx-tethys-mention.mjs +2 -2
  28. package/fesm2020/ngx-tethys-mention.mjs.map +1 -1
  29. package/fesm2020/ngx-tethys-nav.mjs +2 -2
  30. package/fesm2020/ngx-tethys-nav.mjs.map +1 -1
  31. package/fesm2020/ngx-tethys-property.mjs +2 -10
  32. package/fesm2020/ngx-tethys-property.mjs.map +1 -1
  33. package/fesm2020/ngx-tethys-tree-select.mjs +0 -13
  34. package/fesm2020/ngx-tethys-tree-select.mjs.map +1 -1
  35. package/fesm2020/ngx-tethys-watermark.mjs +1 -1
  36. package/fesm2020/ngx-tethys-watermark.mjs.map +1 -1
  37. package/fesm2020/ngx-tethys.mjs +1 -1
  38. package/fesm2020/ngx-tethys.mjs.map +1 -1
  39. package/label/styles/label.scss +1 -1
  40. package/nav/styles/mixin.scss +2 -1
  41. package/nav/styles/nav.scss +3 -2
  42. package/package.json +1 -1
  43. package/property/property-item.component.d.ts +0 -1
  44. package/schematics/version.d.ts +1 -1
  45. package/schematics/version.js +1 -1
  46. package/shared/option/styles/select-dropdown.scss +1 -1
  47. package/shared/select/select-control/select-control.scss +3 -0
  48. package/shared/select/styles/select.mixin.scss +8 -5
  49. package/styles/variables.scss +1 -2
  50. package/tree-select/styles/tree-select.scss +1 -1
  51. package/tree-select/tree-select.component.d.ts +0 -1
package/CHANGELOG.md CHANGED
@@ -2,6 +2,26 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ ## [13.2.8](https://github.com/atinc/ngx-tethys/compare/13.2.7...13.2.8) (2022-08-31)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * **label:** fix label border-radius #INFR-4486 ([#2148](https://github.com/atinc/ngx-tethys/issues/2148)) ([4ab201e](https://github.com/atinc/ngx-tethys/commit/4ab201efce101847c5def7d337bf6402cd584281)), closes [#INFR-4486](https://github.com/atinc/ngx-tethys/issues/INFR-4486)
11
+ * **nav:** replace nav component active-class 'active' to 'nav-active' #INFR-4482 ([#2143](https://github.com/atinc/ngx-tethys/issues/2143)) ([f333f24](https://github.com/atinc/ngx-tethys/commit/f333f2410a880f31ea2b559f877fd4e9df1972b2)), closes [#INFR-4482](https://github.com/atinc/ngx-tethys/issues/INFR-4482) [#INFR-4482](https://github.com/atinc/ngx-tethys/issues/INFR-4482) [#INFR-4482](https://github.com/atinc/ngx-tethys/issues/INFR-4482) [#INFR-4482](https://github.com/atinc/ngx-tethys/issues/INFR-4482)
12
+ * **property:** remove auto fill item span logic #INFR-4471 ([b2a9c75](https://github.com/atinc/ngx-tethys/commit/b2a9c750fd77bf45e3b3d1667749cfd378e70123)), closes [#INFR-4471](https://github.com/atinc/ngx-tethys/issues/INFR-4471)
13
+ * **select:** center thy-tag ([#2145](https://github.com/atinc/ngx-tethys/issues/2145)) ([de34ae7](https://github.com/atinc/ngx-tethys/commit/de34ae74c122da4e851a9d4bff5c9a64cecf8cf6))
14
+ * **select:** fix select-control height when empty and center placeholder ([#2150](https://github.com/atinc/ngx-tethys/issues/2150)) ([a650e57](https://github.com/atinc/ngx-tethys/commit/a650e57a024bcbf10f24e0753ea47edbd8f9403b))
15
+ * **watermark:** adjust the refresh condition #INFR-4478 ([e667d73](https://github.com/atinc/ngx-tethys/commit/e667d73b53ce8a8958f170d8611018ffdecfc0b3)), closes [#INFR-4478](https://github.com/atinc/ngx-tethys/issues/INFR-4478)
16
+
17
+
18
+ ### Features
19
+
20
+ * **mention:** add show suggestions limit #INFR-176 ([#2140](https://github.com/atinc/ngx-tethys/issues/2140)) ([d68bcb9](https://github.com/atinc/ngx-tethys/commit/d68bcb927ba94c084da11354eceaf03104b0c98d)), closes [#INFR-176](https://github.com/atinc/ngx-tethys/issues/INFR-176)
21
+ * **select:** change select and tree-select border-radius to dropdown… ([#2147](https://github.com/atinc/ngx-tethys/issues/2147)) ([7bf0eae](https://github.com/atinc/ngx-tethys/commit/7bf0eae93be348df3df3450408f31c92f56895d2))
22
+
23
+
24
+
5
25
  ## [13.2.7](https://github.com/atinc/ngx-tethys/compare/13.2.6...13.2.7) (2022-08-26)
6
26
 
7
27
 
@@ -12,15 +12,29 @@ export declare class ThyCopyDirective implements OnInit, OnDestroy {
12
12
  private elementRef;
13
13
  private viewContainerRef;
14
14
  private notifyService;
15
+ /**
16
+ * 默认为点击标签,可传复制目标标签
17
+ */
15
18
  thyCopy: EventEmitter<ThyCopyEvent>;
19
+ /**
20
+ * 复制成功时的文案
21
+ */
16
22
  thyCopySuccessText: string;
23
+ /**
24
+ * 提示文案
25
+ */
17
26
  thyCopyTips: string;
18
27
  /**
19
- * 偏移量
20
- * @default 4
28
+ * 偏移量
21
29
  */
22
30
  thyCopyTipsOffset: number;
31
+ /**
32
+ * 当为 string 时,复制的是传入的内容;当为 ElementRef | HTMLElement 时,复制的是 dom 节点的 value 或者 textContent
33
+ */
23
34
  thyCopyContent: string | ElementRef | HTMLElement;
35
+ /**
36
+ * 是否展示通知
37
+ */
24
38
  thyShowNotify: boolean;
25
39
  constructor(document: any, tooltipService: TooltipService, elementRef: ElementRef<HTMLElement>, viewContainerRef: ViewContainerRef, notifyService: ThyNotifyService);
26
40
  ngOnInit(): void;
@@ -15,10 +15,21 @@ export class ThyCopyDirective {
15
15
  this.elementRef = elementRef;
16
16
  this.viewContainerRef = viewContainerRef;
17
17
  this.notifyService = notifyService;
18
- // 默认为点击标签,可传复制目标标签
18
+ /**
19
+ * 默认为点击标签,可传复制目标标签
20
+ */
19
21
  this.thyCopy = new EventEmitter();
22
+ /**
23
+ * 复制成功时的文案
24
+ */
20
25
  this.thyCopySuccessText = '复制成功';
26
+ /**
27
+ * 提示文案
28
+ */
21
29
  this.thyCopyTips = '点击复制';
30
+ /**
31
+ * 是否展示通知
32
+ */
22
33
  this.thyShowNotify = true;
23
34
  }
24
35
  ngOnInit() {
@@ -92,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
92
103
  type: HostListener,
93
104
  args: ['click', ['$event']]
94
105
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29weS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29weS9jb3B5LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFDSCxTQUFTLEVBQ1QsVUFBVSxFQUNWLFlBQVksRUFDWixZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFHTCxNQUFNLEVBQ04sZ0JBQWdCLEVBQ25CLE1BQU0sZUFBZSxDQUFDOzs7O0FBV3ZCLE1BQU0sT0FBTyxnQkFBZ0I7SUFrQnpCLFlBQzhCLFFBQWEsRUFDaEMsY0FBOEIsRUFDN0IsVUFBbUMsRUFDbkMsZ0JBQWtDLEVBQ2xDLGFBQStCO1FBSmIsYUFBUSxHQUFSLFFBQVEsQ0FBSztRQUNoQyxtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDN0IsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFDbkMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUNsQyxrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7UUF0QjNDLG1CQUFtQjtRQUNULFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBZ0IsQ0FBQztRQUU1Qyx1QkFBa0IsR0FBRyxNQUFNLENBQUM7UUFFNUIsZ0JBQVcsR0FBRyxNQUFNLENBQUM7UUFVTCxrQkFBYSxHQUFHLElBQUksQ0FBQztJQVEzQyxDQUFDO0lBRUosUUFBUTtRQUNKLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQzVFLElBQUksQ0FBQyxjQUFjLENBQUMsbUJBQW1CLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUMvRixJQUFJLENBQUMsY0FBYyxDQUFDLG1CQUFtQixDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDbkYsQ0FBQztJQUVPLFVBQVUsQ0FBQyxLQUFZO1FBQzNCLElBQUksT0FBTyxJQUFJLENBQUMsY0FBYyxLQUFLLFFBQVEsRUFBRTtZQUN6QyxPQUFPLElBQUksQ0FBQyxjQUFjLENBQUM7U0FDOUI7YUFBTTtZQUNILE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUM7WUFDdkYsT0FBTyxNQUFNLENBQUMsS0FBSyxJQUFJLE1BQU0sQ0FBQyxXQUFXLENBQUM7U0FDN0M7SUFDTCxDQUFDO0lBRU0sT0FBTyxDQUFDLEtBQVk7UUFDdkIsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDekQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3pDLFFBQVEsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4QyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDbEIsSUFBSTtZQUNBLFFBQVEsQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztZQUMxQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUM5QyxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUU7Z0JBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO2FBQ3ZEO1NBQ0o7UUFBQyxPQUFPLEdBQUcsRUFBRTtZQUNWLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1lBQy9DLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRTtnQkFDcEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7YUFDcEM7U0FDSjtnQkFBUztZQUNOLFFBQVEsQ0FBQyxNQUFNLEVBQUUsQ0FBQztTQUNyQjtJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNqQyxDQUFDOzs2R0FoRVEsZ0JBQWdCLGtCQW1CYixRQUFRO2lHQW5CWCxnQkFBZ0Isc1RBRmQsQ0FBQyxjQUFjLENBQUM7QUFrQkY7SUFBZixZQUFZLEVBQUU7O3VEQUFzQjsyRkFoQnJDLGdCQUFnQjtrQkFKNUIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsV0FBVztvQkFDckIsU0FBUyxFQUFFLENBQUMsY0FBYyxDQUFDO2lCQUM5Qjs7MEJBb0JRLE1BQU07MkJBQUMsUUFBUTtnS0FqQlYsT0FBTztzQkFBaEIsTUFBTTtnQkFFRSxrQkFBa0I7c0JBQTFCLEtBQUs7Z0JBRUcsV0FBVztzQkFBbkIsS0FBSztnQkFNRyxpQkFBaUI7c0JBQXpCLEtBQUs7Z0JBRUcsY0FBYztzQkFBdEIsS0FBSztnQkFFbUIsYUFBYTtzQkFBckMsS0FBSztnQkF5QkMsT0FBTztzQkFEYixZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElucHV0Qm9vbGVhbiB9IGZyb20gJ25neC10ZXRoeXMvY29yZSc7XG5pbXBvcnQgeyBUaHlOb3RpZnlTZXJ2aWNlIH0gZnJvbSAnbmd4LXRldGh5cy9ub3RpZnknO1xuaW1wb3J0IHsgVG9vbHRpcFNlcnZpY2UgfSBmcm9tICduZ3gtdGV0aHlzL3Rvb2x0aXAnO1xuXG5pbXBvcnQgeyBjb2VyY2VFbGVtZW50IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gICAgRGlyZWN0aXZlLFxuICAgIEVsZW1lbnRSZWYsXG4gICAgRXZlbnRFbWl0dGVyLFxuICAgIEhvc3RMaXN0ZW5lcixcbiAgICBJbmplY3QsXG4gICAgSW5wdXQsXG4gICAgT25EZXN0cm95LFxuICAgIE9uSW5pdCxcbiAgICBPdXRwdXQsXG4gICAgVmlld0NvbnRhaW5lclJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBUaHlDb3B5RXZlbnQge1xuICAgIGlzU3VjY2VzczogYm9vbGVhbjtcbiAgICBldmVudDogRXZlbnQ7XG59XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3RoeUNvcHldJyxcbiAgICBwcm92aWRlcnM6IFtUb29sdGlwU2VydmljZV1cbn0pXG5leHBvcnQgY2xhc3MgVGh5Q29weURpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICAvLyDpu5jorqTkuLrngrnlh7vmoIfnrb7vvIzlj6/kvKDlpI3liLbnm67moIfmoIfnrb5cbiAgICBAT3V0cHV0KCkgdGh5Q29weSA9IG5ldyBFdmVudEVtaXR0ZXI8VGh5Q29weUV2ZW50PigpO1xuXG4gICAgQElucHV0KCkgdGh5Q29weVN1Y2Nlc3NUZXh0ID0gJ+WkjeWItuaIkOWKnyc7XG5cbiAgICBASW5wdXQoKSB0aHlDb3B5VGlwcyA9ICfngrnlh7vlpI3liLYnO1xuXG4gICAgLyoqXG4gICAgICogIOWBj+enu+mHj1xuICAgICAqIEBkZWZhdWx0IDRcbiAgICAgKi9cbiAgICBASW5wdXQoKSB0aHlDb3B5VGlwc09mZnNldDogbnVtYmVyO1xuXG4gICAgQElucHV0KCkgdGh5Q29weUNvbnRlbnQ6IHN0cmluZyB8IEVsZW1lbnRSZWYgfCBIVE1MRWxlbWVudDtcblxuICAgIEBJbnB1dCgpIEBJbnB1dEJvb2xlYW4oKSB0aHlTaG93Tm90aWZ5ID0gdHJ1ZTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KERPQ1VNRU5UKSBwcml2YXRlIGRvY3VtZW50OiBhbnksXG4gICAgICAgIHB1YmxpYyB0b29sdGlwU2VydmljZTogVG9vbHRpcFNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICAgICAgIHByaXZhdGUgdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgICAgcHJpdmF0ZSBub3RpZnlTZXJ2aWNlOiBUaHlOb3RpZnlTZXJ2aWNlXG4gICAgKSB7fVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMudG9vbHRpcFNlcnZpY2UuYXR0YWNoKHRoaXMuZWxlbWVudFJlZiwgdGhpcy52aWV3Q29udGFpbmVyUmVmLCAnaG92ZXInKTtcbiAgICAgICAgdGhpcy50b29sdGlwU2VydmljZS50aHlUb29sdGlwRGlyZWN0aXZlLmNvbnRlbnQgPSB0aGlzLnRoeUNvcHlUaXBzID8gdGhpcy50aHlDb3B5VGlwcyA6ICfngrnlh7vlpI3liLYnO1xuICAgICAgICB0aGlzLnRvb2x0aXBTZXJ2aWNlLnRoeVRvb2x0aXBEaXJlY3RpdmUudG9vbHRpcE9mZnNldCA9IHRoaXMudGh5Q29weVRpcHNPZmZzZXQ7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXRDb250ZW50KGV2ZW50OiBFdmVudCkge1xuICAgICAgICBpZiAodHlwZW9mIHRoaXMudGh5Q29weUNvbnRlbnQgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy50aHlDb3B5Q29udGVudDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGNvbnN0IHRhcmdldCA9IHRoaXMudGh5Q29weUNvbnRlbnQgPyBjb2VyY2VFbGVtZW50KHRoaXMudGh5Q29weUNvbnRlbnQpIDogZXZlbnQudGFyZ2V0O1xuICAgICAgICAgICAgcmV0dXJuIHRhcmdldC52YWx1ZSB8fCB0YXJnZXQudGV4dENvbnRlbnQ7XG4gICAgICAgIH1cbiAgICB9XG4gICAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKVxuICAgIHB1YmxpYyBvbkNsaWNrKGV2ZW50OiBFdmVudCkge1xuICAgICAgICBjb25zdCB0ZXh0YXJlYSA9IHRoaXMuZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgndGV4dGFyZWEnKTtcbiAgICAgICAgdGhpcy5kb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKHRleHRhcmVhKTtcbiAgICAgICAgdGV4dGFyZWEudmFsdWUgPSB0aGlzLmdldENvbnRlbnQoZXZlbnQpO1xuICAgICAgICB0ZXh0YXJlYS5zZWxlY3QoKTtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGRvY3VtZW50LmV4ZWNDb21tYW5kKCdjb3B5JywgZmFsc2UsIG51bGwpO1xuICAgICAgICAgICAgdGhpcy50aHlDb3B5LmVtaXQoeyBpc1N1Y2Nlc3M6IHRydWUsIGV2ZW50IH0pO1xuICAgICAgICAgICAgaWYgKHRoaXMudGh5U2hvd05vdGlmeSkge1xuICAgICAgICAgICAgICAgIHRoaXMubm90aWZ5U2VydmljZS5zdWNjZXNzKHRoaXMudGh5Q29weVN1Y2Nlc3NUZXh0KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgICAgICB0aGlzLnRoeUNvcHkuZW1pdCh7IGlzU3VjY2VzczogZmFsc2UsIGV2ZW50IH0pO1xuICAgICAgICAgICAgaWYgKHRoaXMudGh5U2hvd05vdGlmeSkge1xuICAgICAgICAgICAgICAgIHRoaXMubm90aWZ5U2VydmljZS5lcnJvcign5aSN5Yi25aSx6LSlJyk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gZmluYWxseSB7XG4gICAgICAgICAgICB0ZXh0YXJlYS5yZW1vdmUoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCkge1xuICAgICAgICB0aGlzLnRvb2x0aXBTZXJ2aWNlLmRldGFjaCgpO1xuICAgIH1cbn1cbiJdfQ==
106
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29weS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29weS9jb3B5LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFDSCxTQUFTLEVBQ1QsVUFBVSxFQUNWLFlBQVksRUFDWixZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFHTCxNQUFNLEVBQ04sZ0JBQWdCLEVBQ25CLE1BQU0sZUFBZSxDQUFDOzs7O0FBV3ZCLE1BQU0sT0FBTyxnQkFBZ0I7SUErQnpCLFlBQzhCLFFBQWEsRUFDaEMsY0FBOEIsRUFDN0IsVUFBbUMsRUFDbkMsZ0JBQWtDLEVBQ2xDLGFBQStCO1FBSmIsYUFBUSxHQUFSLFFBQVEsQ0FBSztRQUNoQyxtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDN0IsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFDbkMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUNsQyxrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7UUFuQzNDOztXQUVHO1FBQ08sWUFBTyxHQUFHLElBQUksWUFBWSxFQUFnQixDQUFDO1FBRXJEOztXQUVHO1FBQ00sdUJBQWtCLEdBQUcsTUFBTSxDQUFDO1FBRXJDOztXQUVHO1FBQ00sZ0JBQVcsR0FBRyxNQUFNLENBQUM7UUFZOUI7O1dBRUc7UUFDc0Isa0JBQWEsR0FBRyxJQUFJLENBQUM7SUFRM0MsQ0FBQztJQUVKLFFBQVE7UUFDSixJQUFJLENBQUMsY0FB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eyBJbnB1dEJvb2xlYW4gfSBmcm9tICduZ3gtdGV0aHlzL2NvcmUnO1xuaW1wb3J0IHsgVGh5Tm90aWZ5U2VydmljZSB9IGZyb20gJ25neC10ZXRoeXMvbm90aWZ5JztcbmltcG9ydCB7IFRvb2x0aXBTZXJ2aWNlIH0gZnJvbSAnbmd4LXRldGh5cy90b29sdGlwJztcblxuaW1wb3J0IHsgY29lcmNlRWxlbWVudCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBET0NVTUVOVCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICAgIERpcmVjdGl2ZSxcbiAgICBFbGVtZW50UmVmLFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBIb3N0TGlzdGVuZXIsXG4gICAgSW5qZWN0LFxuICAgIElucHV0LFxuICAgIE9uRGVzdHJveSxcbiAgICBPbkluaXQsXG4gICAgT3V0cHV0LFxuICAgIFZpZXdDb250YWluZXJSZWZcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGh5Q29weUV2ZW50IHtcbiAgICBpc1N1Y2Nlc3M6IGJvb2xlYW47XG4gICAgZXZlbnQ6IEV2ZW50O1xufVxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t0aHlDb3B5XScsXG4gICAgcHJvdmlkZXJzOiBbVG9vbHRpcFNlcnZpY2VdXG59KVxuZXhwb3J0IGNsYXNzIFRoeUNvcHlEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gICAgLyoqXG4gICAgICog6buY6K6k5Li654K55Ye75qCH562+77yM5Y+v5Lyg5aSN5Yi255uu5qCH5qCH562+XG4gICAgICovXG4gICAgQE91dHB1dCgpIHRoeUNvcHkgPSBuZXcgRXZlbnRFbWl0dGVyPFRoeUNvcHlFdmVudD4oKTtcblxuICAgIC8qKlxuICAgICAqIOWkjeWItuaIkOWKn+aXtueahOaWh+ahiFxuICAgICAqL1xuICAgIEBJbnB1dCgpIHRoeUNvcHlTdWNjZXNzVGV4dCA9ICflpI3liLbmiJDlip8nO1xuXG4gICAgLyoqXG4gICAgICog5o+Q56S65paH5qGIXG4gICAgICovXG4gICAgQElucHV0KCkgdGh5Q29weVRpcHMgPSAn54K55Ye75aSN5Yi2JztcblxuICAgIC8qKlxuICAgICAqIOWBj+enu+mHj1xuICAgICAqL1xuICAgIEBJbnB1dCgpIHRoeUNvcHlUaXBzT2Zmc2V0OiBudW1iZXI7XG5cbiAgICAvKipcbiAgICAgKiDlvZPkuLogc3RyaW5nIOaXtu+8jOWkjeWItueahOaYr+S8oOWFpeeahOWGheWuue+8m+W9k+S4uiBFbGVtZW50UmVmIHwgSFRNTEVsZW1lbnQg5pe277yM5aSN5Yi255qE5pivIGRvbSDoioLngrnnmoQgdmFsdWUg5oiW6ICFIHRleHRDb250ZW50XG4gICAgICovXG4gICAgQElucHV0KCkgdGh5Q29weUNvbnRlbnQ6IHN0cmluZyB8IEVsZW1lbnRSZWYgfCBIVE1MRWxlbWVudDtcblxuICAgIC8qKlxuICAgICAqIOaYr+WQpuWxleekuumAmuefpVxuICAgICAqL1xuICAgIEBJbnB1dCgpIEBJbnB1dEJvb2xlYW4oKSB0aHlTaG93Tm90aWZ5ID0gdHJ1ZTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KERPQ1VNRU5UKSBwcml2YXRlIGRvY3VtZW50OiBhbnksXG4gICAgICAgIHB1YmxpYyB0b29sdGlwU2VydmljZTogVG9vbHRpcFNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICAgICAgIHByaXZhdGUgdmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgICAgcHJpdmF0ZSBub3RpZnlTZXJ2aWNlOiBUaHlOb3RpZnlTZXJ2aWNlXG4gICAgKSB7fVxuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMudG9vbHRpcFNlcnZpY2UuYXR0YWNoKHRoaXMuZWxlbWVudFJlZiwgdGhpcy52aWV3Q29udGFpbmVyUmVmLCAnaG92ZXInKTtcbiAgICAgICAgdGhpcy50b29sdGlwU2VydmljZS50aHlUb29sdGlwRGlyZWN0aXZlLmNvbnRlbnQgPSB0aGlzLnRoeUNvcHlUaXBzID8gdGhpcy50aHlDb3B5VGlwcyA6ICfngrnlh7vlpI3liLYnO1xuICAgICAgICB0aGlzLnRvb2x0aXBTZXJ2aWNlLnRoeVRvb2x0aXBEaXJlY3RpdmUudG9vbHRpcE9mZnNldCA9IHRoaXMudGh5Q29weVRpcHNPZmZzZXQ7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXRDb250ZW50KGV2ZW50OiBFdmVudCkge1xuICAgICAgICBpZiAodHlwZW9mIHRoaXMudGh5Q29weUNvbnRlbnQgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy50aHlDb3B5Q29udGVudDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGNvbnN0IHRhcmdldCA9IHRoaXMudGh5Q29weUNvbnRlbnQgPyBjb2VyY2VFbGVtZW50KHRoaXMudGh5Q29weUNvbnRlbnQpIDogZXZlbnQudGFyZ2V0O1xuICAgICAgICAgICAgcmV0dXJuIHRhcmdldC52YWx1ZSB8fCB0YXJnZXQudGV4dENvbnRlbnQ7XG4gICAgICAgIH1cbiAgICB9XG4gICAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKVxuICAgIHB1YmxpYyBvbkNsaWNrKGV2ZW50OiBFdmVudCkge1xuICAgICAgICBjb25zdCB0ZXh0YXJlYSA9IHRoaXMuZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgndGV4dGFyZWEnKTtcbiAgICAgICAgdGhpcy5kb2N1bWVudC5ib2R5LmFwcGVuZENoaWxkKHRleHRhcmVhKTtcbiAgICAgICAgdGV4dGFyZWEudmFsdWUgPSB0aGlzLmdldENvbnRlbnQoZXZlbnQpO1xuICAgICAgICB0ZXh0YXJlYS5zZWxlY3QoKTtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGRvY3VtZW50LmV4ZWNDb21tYW5kKCdjb3B5JywgZmFsc2UsIG51bGwpO1xuICAgICAgICAgICAgdGhpcy50aHlDb3B5LmVtaXQoeyBpc1N1Y2Nlc3M6IHRydWUsIGV2ZW50IH0pO1xuICAgICAgICAgICAgaWYgKHRoaXMudGh5U2hvd05vdGlmeSkge1xuICAgICAgICAgICAgICAgIHRoaXMubm90aWZ5U2VydmljZS5zdWNjZXNzKHRoaXMudGh5Q29weVN1Y2Nlc3NUZXh0KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgICAgICB0aGlzLnRoeUNvcHkuZW1pdCh7IGlzU3VjY2VzczogZmFsc2UsIGV2ZW50IH0pO1xuICAgICAgICAgICAgaWYgKHRoaXMudGh5U2hvd05vdGlmeSkge1xuICAgICAgICAgICAgICAgIHRoaXMubm90aWZ5U2VydmljZS5lcnJvcign5aSN5Yi25aSx6LSlJyk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gZmluYWxseSB7XG4gICAgICAgICAgICB0ZXh0YXJlYS5yZW1vdmUoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCkge1xuICAgICAgICB0aGlzLnRvb2x0aXBTZXJ2aWNlLmRldGFjaCgpO1xuICAgIH1cbn1cbiJdfQ==
@@ -68,12 +68,12 @@ export class ThyMentionSuggestionsComponent {
68
68
  }
69
69
  }
70
70
  ThyMentionSuggestionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyMentionSuggestionsComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component });
71
- ThyMentionSuggestionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyMentionSuggestionsComponent, selector: "thy-mention-suggestions", host: { properties: { "class.thy-mention-suggestions": "this.suggestionsClass" } }, ngImport: i0, template: "<ng-container *ngIf=\"mention.suggestionsTemplateRef; else default\">\n <ng-container [ngTemplateOutlet]=\"mention.suggestionsTemplateRef\" [ngTemplateOutletContext]=\"{ data: data }\"></ng-container>\n</ng-container>\n<ng-template #default>\n <thy-loading [thyDone]=\"loadingDone\"></thy-loading>\n <ng-container *ngIf=\"loadingDone\">\n <thy-selection-list\n *ngIf=\"data?.length > 0; else empty\"\n thyBindKeyEventContainer=\"body\"\n thyMultiple=\"false\"\n thyAutoActiveFirstItem=\"true\"\n thySpaceKeyEnabled=\"false\"\n [thyScrollContainer]=\"elementRef\"\n (thySelectionChange)=\"selectionChange($event)\"\n >\n <thy-list-option *ngFor=\"let item of data\" [thyValue]=\"item\">\n <ng-container *ngIf=\"mention?.displayTemplateRef; else default\">\n <ng-template *ngTemplateOutlet=\"mention?.displayTemplateRef; context: { $implicit: item }\"></ng-template>\n </ng-container>\n <ng-template #default>\n {{ item['name'] || '' }}\n </ng-template>\n </thy-list-option>\n </thy-selection-list>\n </ng-container>\n <ng-template #empty>\n <div class=\"text-desc p-3\">\n {{ mention?.emptyText }}\n </div>\n </ng-template>\n</ng-template>\n", components: [{ type: i2.ThyLoadingComponent, selector: "thy-loading", inputs: ["thyDone", "thyTip", "thyIsMask"] }, { type: i3.ThySelectionListComponent, selector: "thy-selection-list,[thy-selection-list]", inputs: ["thyMultiple", "thyBindKeyEventContainer", "thyScrollContainer", "thyBeforeKeydown", "thyUniqueKey", "thyCompareWith", "thyLayout", "thyAutoActiveFirstItem", "thySize", "thySpaceKeyEnabled"], outputs: ["thySelectionChange"] }, { type: i4.ThyListOptionComponent, selector: "thy-list-option,[thy-list-option]", inputs: ["id", "thyValue", "thyDisabled"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
71
+ ThyMentionSuggestionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyMentionSuggestionsComponent, selector: "thy-mention-suggestions", host: { properties: { "class.thy-mention-suggestions": "this.suggestionsClass" } }, ngImport: i0, template: "<ng-container *ngIf=\"mention.suggestionsTemplateRef; else default\">\n <ng-container [ngTemplateOutlet]=\"mention.suggestionsTemplateRef\" [ngTemplateOutletContext]=\"{ data: data }\"></ng-container>\n</ng-container>\n<ng-template #default>\n <thy-loading [thyDone]=\"loadingDone\"></thy-loading>\n <ng-container *ngIf=\"loadingDone\">\n <thy-selection-list\n *ngIf=\"data?.length > 0; else empty\"\n thyBindKeyEventContainer=\"body\"\n thyMultiple=\"false\"\n thyAutoActiveFirstItem=\"true\"\n thySpaceKeyEnabled=\"false\"\n [thyScrollContainer]=\"elementRef\"\n (thySelectionChange)=\"selectionChange($event)\"\n >\n <thy-list-option *ngFor=\"let item of data | slice: 0:mention.limit\" [thyValue]=\"item\">\n <ng-container *ngIf=\"mention?.displayTemplateRef; else default\">\n <ng-template *ngTemplateOutlet=\"mention?.displayTemplateRef; context: { $implicit: item }\"></ng-template>\n </ng-container>\n <ng-template #default>\n {{ item['name'] || '' }}\n </ng-template>\n </thy-list-option>\n </thy-selection-list>\n </ng-container>\n <ng-template #empty>\n <div class=\"text-desc p-3\">\n {{ mention?.emptyText }}\n </div>\n </ng-template>\n</ng-template>\n", components: [{ type: i2.ThyLoadingComponent, selector: "thy-loading", inputs: ["thyDone", "thyTip", "thyIsMask"] }, { type: i3.ThySelectionListComponent, selector: "thy-selection-list,[thy-selection-list]", inputs: ["thyMultiple", "thyBindKeyEventContainer", "thyScrollContainer", "thyBeforeKeydown", "thyUniqueKey", "thyCompareWith", "thyLayout", "thyAutoActiveFirstItem", "thySize", "thySpaceKeyEnabled"], outputs: ["thySelectionChange"] }, { type: i4.ThyListOptionComponent, selector: "thy-list-option,[thy-list-option]", inputs: ["id", "thyValue", "thyDisabled"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "slice": i5.SlicePipe } });
72
72
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyMentionSuggestionsComponent, decorators: [{
73
73
  type: Component,
74
- args: [{ selector: 'thy-mention-suggestions', template: "<ng-container *ngIf=\"mention.suggestionsTemplateRef; else default\">\n <ng-container [ngTemplateOutlet]=\"mention.suggestionsTemplateRef\" [ngTemplateOutletContext]=\"{ data: data }\"></ng-container>\n</ng-container>\n<ng-template #default>\n <thy-loading [thyDone]=\"loadingDone\"></thy-loading>\n <ng-container *ngIf=\"loadingDone\">\n <thy-selection-list\n *ngIf=\"data?.length > 0; else empty\"\n thyBindKeyEventContainer=\"body\"\n thyMultiple=\"false\"\n thyAutoActiveFirstItem=\"true\"\n thySpaceKeyEnabled=\"false\"\n [thyScrollContainer]=\"elementRef\"\n (thySelectionChange)=\"selectionChange($event)\"\n >\n <thy-list-option *ngFor=\"let item of data\" [thyValue]=\"item\">\n <ng-container *ngIf=\"mention?.displayTemplateRef; else default\">\n <ng-template *ngTemplateOutlet=\"mention?.displayTemplateRef; context: { $implicit: item }\"></ng-template>\n </ng-container>\n <ng-template #default>\n {{ item['name'] || '' }}\n </ng-template>\n </thy-list-option>\n </thy-selection-list>\n </ng-container>\n <ng-template #empty>\n <div class=\"text-desc p-3\">\n {{ mention?.emptyText }}\n </div>\n </ng-template>\n</ng-template>\n" }]
74
+ args: [{ selector: 'thy-mention-suggestions', template: "<ng-container *ngIf=\"mention.suggestionsTemplateRef; else default\">\n <ng-container [ngTemplateOutlet]=\"mention.suggestionsTemplateRef\" [ngTemplateOutletContext]=\"{ data: data }\"></ng-container>\n</ng-container>\n<ng-template #default>\n <thy-loading [thyDone]=\"loadingDone\"></thy-loading>\n <ng-container *ngIf=\"loadingDone\">\n <thy-selection-list\n *ngIf=\"data?.length > 0; else empty\"\n thyBindKeyEventContainer=\"body\"\n thyMultiple=\"false\"\n thyAutoActiveFirstItem=\"true\"\n thySpaceKeyEnabled=\"false\"\n [thyScrollContainer]=\"elementRef\"\n (thySelectionChange)=\"selectionChange($event)\"\n >\n <thy-list-option *ngFor=\"let item of data | slice: 0:mention.limit\" [thyValue]=\"item\">\n <ng-container *ngIf=\"mention?.displayTemplateRef; else default\">\n <ng-template *ngTemplateOutlet=\"mention?.displayTemplateRef; context: { $implicit: item }\"></ng-template>\n </ng-container>\n <ng-template #default>\n {{ item['name'] || '' }}\n </ng-template>\n </thy-list-option>\n </thy-selection-list>\n </ng-container>\n <ng-template #empty>\n <div class=\"text-desc p-3\">\n {{ mention?.emptyText }}\n </div>\n </ng-template>\n</ng-template>\n" }]
75
75
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.ThyPopoverRef }]; }, propDecorators: { suggestionsClass: [{
76
76
  type: HostBinding,
77
77
  args: ['class.thy-mention-suggestions']
78
78
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"suggestions.component.js","sourceRoot":"","sources":["../../../../../src/mention/suggestions/suggestions.component.ts","../../../../../src/mention/suggestions/suggestions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThySelectionListChange } from 'ngx-tethys/list';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Observable, of, Subject } from 'rxjs';\nimport { catchError, debounceTime, switchMap, take } from 'rxjs/operators';\n\nimport { Component, ElementRef, HostBinding, NgZone, OnDestroy, OnInit } from '@angular/core';\n\nimport { SeekQueryResult } from '../adapter/adapter';\nimport { Mention, MentionDefaultDataItem, MentionSuggestionSelectEvent } from '../interfaces';\n\n@Component({\n    selector: 'thy-mention-suggestions',\n    templateUrl: './suggestions.component.html'\n})\nexport class ThyMentionSuggestionsComponent<TItem = MentionDefaultDataItem> implements OnInit, OnDestroy {\n    data: TItem[];\n\n    mention: Mention<TItem>;\n\n    suggestionSelect$ = new Subject<MentionSuggestionSelectEvent>();\n\n    debounce = 150;\n\n    loadingDone = true;\n\n    private search$ = new Subject<SeekQueryResult>();\n\n    @HostBinding('class.thy-mention-suggestions') suggestionsClass = true;\n\n    constructor(public elementRef: ElementRef<HTMLElement>, private ngZone: NgZone, private popoverRef: ThyPopoverRef<any>) {\n        this.search$\n            .pipe(\n                switchMap(query => {\n                    const data = this.mention.search(query.term, this.mention.data);\n                    if (data instanceof Observable) {\n                        this.loadingDone = false;\n                        return (data as Observable<TItem[]>).pipe(debounceTime(this.debounce));\n                    } else {\n                        return of(data as TItem[]);\n                    }\n                }),\n                catchError(() => {\n                    this.loadingDone = false;\n                    return [];\n                })\n            )\n            .subscribe(data => {\n                this.loadingDone = true;\n                this.data = data || [];\n\n                if (this.popoverRef) {\n                    if (this.mention.autoClose && this.data.length === 0) {\n                        this.popoverRef.close();\n                    }\n                    this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                        this.popoverRef.updatePosition();\n                    });\n                }\n            });\n    }\n\n    ngOnInit(): void {\n        if (this.mention.popoverClass) {\n            this.elementRef.nativeElement.classList.add(this.mention.popoverClass);\n        }\n    }\n\n    search(query: SeekQueryResult) {\n        this.search$.next(query);\n    }\n\n    select(item: TItem, event: Event) {\n        this.suggestionSelect$.next({\n            event,\n            item\n        });\n    }\n\n    selectionChange(event: ThySelectionListChange<TItem>) {\n        this.select(event.value, event.event);\n    }\n\n    ngOnDestroy() {\n        this.search$.next();\n        this.search$.complete();\n    }\n}\n","<ng-container *ngIf=\"mention.suggestionsTemplateRef; else default\">\n  <ng-container [ngTemplateOutlet]=\"mention.suggestionsTemplateRef\" [ngTemplateOutletContext]=\"{ data: data }\"></ng-container>\n</ng-container>\n<ng-template #default>\n  <thy-loading [thyDone]=\"loadingDone\"></thy-loading>\n  <ng-container *ngIf=\"loadingDone\">\n    <thy-selection-list\n      *ngIf=\"data?.length > 0; else empty\"\n      thyBindKeyEventContainer=\"body\"\n      thyMultiple=\"false\"\n      thyAutoActiveFirstItem=\"true\"\n      thySpaceKeyEnabled=\"false\"\n      [thyScrollContainer]=\"elementRef\"\n      (thySelectionChange)=\"selectionChange($event)\"\n    >\n      <thy-list-option *ngFor=\"let item of data\" [thyValue]=\"item\">\n        <ng-container *ngIf=\"mention?.displayTemplateRef; else default\">\n          <ng-template *ngTemplateOutlet=\"mention?.displayTemplateRef; context: { $implicit: item }\"></ng-template>\n        </ng-container>\n        <ng-template #default>\n          {{ item['name'] || '' }}\n        </ng-template>\n      </thy-list-option>\n    </thy-selection-list>\n  </ng-container>\n  <ng-template #empty>\n    <div class=\"text-desc p-3\">\n      {{ mention?.emptyText }}\n    </div>\n  </ng-template>\n</ng-template>\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"suggestions.component.js","sourceRoot":"","sources":["../../../../../src/mention/suggestions/suggestions.component.ts","../../../../../src/mention/suggestions/suggestions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ThySelectionListChange } from 'ngx-tethys/list';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Observable, of, Subject } from 'rxjs';\nimport { catchError, debounceTime, switchMap, take } from 'rxjs/operators';\n\nimport { Component, ElementRef, HostBinding, NgZone, OnDestroy, OnInit } from '@angular/core';\n\nimport { SeekQueryResult } from '../adapter/adapter';\nimport { Mention, MentionDefaultDataItem, MentionSuggestionSelectEvent } from '../interfaces';\n\n@Component({\n    selector: 'thy-mention-suggestions',\n    templateUrl: './suggestions.component.html'\n})\nexport class ThyMentionSuggestionsComponent<TItem = MentionDefaultDataItem> implements OnInit, OnDestroy {\n    data: TItem[];\n\n    mention: Mention<TItem>;\n\n    suggestionSelect$ = new Subject<MentionSuggestionSelectEvent>();\n\n    debounce = 150;\n\n    loadingDone = true;\n\n    private search$ = new Subject<SeekQueryResult>();\n\n    @HostBinding('class.thy-mention-suggestions') suggestionsClass = true;\n\n    constructor(public elementRef: ElementRef<HTMLElement>, private ngZone: NgZone, private popoverRef: ThyPopoverRef<any>) {\n        this.search$\n            .pipe(\n                switchMap(query => {\n                    const data = this.mention.search(query.term, this.mention.data);\n                    if (data instanceof Observable) {\n                        this.loadingDone = false;\n                        return (data as Observable<TItem[]>).pipe(debounceTime(this.debounce));\n                    } else {\n                        return of(data as TItem[]);\n                    }\n                }),\n                catchError(() => {\n                    this.loadingDone = false;\n                    return [];\n                })\n            )\n            .subscribe(data => {\n                this.loadingDone = true;\n                this.data = data || [];\n\n                if (this.popoverRef) {\n                    if (this.mention.autoClose && this.data.length === 0) {\n                        this.popoverRef.close();\n                    }\n                    this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                        this.popoverRef.updatePosition();\n                    });\n                }\n            });\n    }\n\n    ngOnInit(): void {\n        if (this.mention.popoverClass) {\n            this.elementRef.nativeElement.classList.add(this.mention.popoverClass);\n        }\n    }\n\n    search(query: SeekQueryResult) {\n        this.search$.next(query);\n    }\n\n    select(item: TItem, event: Event) {\n        this.suggestionSelect$.next({\n            event,\n            item\n        });\n    }\n\n    selectionChange(event: ThySelectionListChange<TItem>) {\n        this.select(event.value, event.event);\n    }\n\n    ngOnDestroy() {\n        this.search$.next();\n        this.search$.complete();\n    }\n}\n","<ng-container *ngIf=\"mention.suggestionsTemplateRef; else default\">\n  <ng-container [ngTemplateOutlet]=\"mention.suggestionsTemplateRef\" [ngTemplateOutletContext]=\"{ data: data }\"></ng-container>\n</ng-container>\n<ng-template #default>\n  <thy-loading [thyDone]=\"loadingDone\"></thy-loading>\n  <ng-container *ngIf=\"loadingDone\">\n    <thy-selection-list\n      *ngIf=\"data?.length > 0; else empty\"\n      thyBindKeyEventContainer=\"body\"\n      thyMultiple=\"false\"\n      thyAutoActiveFirstItem=\"true\"\n      thySpaceKeyEnabled=\"false\"\n      [thyScrollContainer]=\"elementRef\"\n      (thySelectionChange)=\"selectionChange($event)\"\n    >\n      <thy-list-option *ngFor=\"let item of data | slice: 0:mention.limit\" [thyValue]=\"item\">\n        <ng-container *ngIf=\"mention?.displayTemplateRef; else default\">\n          <ng-template *ngTemplateOutlet=\"mention?.displayTemplateRef; context: { $implicit: item }\"></ng-template>\n        </ng-container>\n        <ng-template #default>\n          {{ item['name'] || '' }}\n        </ng-template>\n      </thy-list-option>\n    </thy-selection-list>\n  </ng-container>\n  <ng-template #empty>\n    <div class=\"text-desc p-3\">\n      {{ mention?.emptyText }}\n    </div>\n  </ng-template>\n</ng-template>\n"]}
@@ -62,7 +62,7 @@ export class ThyNavItemDirective extends _MixinBase {
62
62
  }
63
63
  }
64
64
  ThyNavItemDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyNavItemDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.RouterLinkActive, optional: true }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
65
- ThyNavItemDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: ThyNavItemDirective, selector: "[thyNavLink],[thyNavItem]", inputs: { thyNavItemActive: "thyNavItemActive", thyNavLinkActive: "thyNavLinkActive", thyNavItemDisabled: "thyNavItemDisabled" }, host: { properties: { "class.active": "thyNavItemActive || thyNavLinkActive", "class.disabled": "thyNavItemDisabled" }, classAttribute: "thy-nav-item" }, queries: [{ propertyName: "links", predicate: ThyNavItemDirective, descendants: true }, { propertyName: "routers", predicate: RouterLinkActive, descendants: true }], usesInheritance: true, ngImport: i0 });
65
+ ThyNavItemDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: ThyNavItemDirective, selector: "[thyNavLink],[thyNavItem]", inputs: { thyNavItemActive: "thyNavItemActive", thyNavLinkActive: "thyNavLinkActive", thyNavItemDisabled: "thyNavItemDisabled" }, host: { properties: { "class.nav-active": "thyNavItemActive || thyNavLinkActive", "class.disabled": "thyNavItemDisabled" }, classAttribute: "thy-nav-item" }, queries: [{ propertyName: "links", predicate: ThyNavItemDirective, descendants: true }, { propertyName: "routers", predicate: RouterLinkActive, descendants: true }], usesInheritance: true, ngImport: i0 });
66
66
  __decorate([
67
67
  InputBoolean(),
68
68
  __metadata("design:type", Boolean)
@@ -81,7 +81,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
81
81
  selector: '[thyNavLink],[thyNavItem]',
82
82
  host: {
83
83
  class: 'thy-nav-item',
84
- '[class.active]': 'thyNavItemActive || thyNavLinkActive',
84
+ '[class.nav-active]': 'thyNavItemActive || thyNavLinkActive',
85
85
  '[class.disabled]': 'thyNavItemDisabled'
86
86
  }
87
87
  }]
@@ -100,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
100
100
  type: ContentChildren,
101
101
  args: [RouterLinkActive, { descendants: true }]
102
102
  }] } });
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-item.directive.js","sourceRoot":"","sources":["../../../../src/nav/nav-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Constructor, InputBoolean, MixinBase, mixinUnsubscribe, ThyUnsubscribe } from 'ngx-tethys/core';\nimport { takeUntil } from 'rxjs/operators';\n\nimport {\n    AfterViewInit,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    Optional,\n    QueryList,\n    Renderer2\n} from '@angular/core';\nimport { RouterLinkActive } from '@angular/router';\n\nexport type ThyNavLink = '' | 'active';\n\nconst _MixinBase: Constructor<ThyUnsubscribe> & typeof MixinBase = mixinUnsubscribe(MixinBase);\n\n/**\n * 导航项\n * @name thyNavItem\n */\n@Directive({\n    selector: '[thyNavLink],[thyNavItem]',\n    host: {\n        class: 'thy-nav-item',\n        '[class.active]': 'thyNavItemActive || thyNavLinkActive',\n        '[class.disabled]': 'thyNavItemDisabled'\n    }\n})\nexport class ThyNavItemDirective extends _MixinBase implements AfterViewInit, OnDestroy {\n    /**\n     * 是否激活状态\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    thyNavItemActive: boolean;\n\n    /**\n     * 已经废弃，请使用 thyNavItemActive\n     * @deprecated please use thyNavItemActive\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    thyNavLinkActive: boolean;\n\n    /**\n     * 是否禁用\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    thyNavItemDisabled: boolean;\n\n    /**\n     * @private\n     */\n    @ContentChildren(ThyNavItemDirective, { descendants: true }) links: QueryList<ThyNavItemDirective>;\n\n    /**\n     * @private\n     */\n    @ContentChildren(RouterLinkActive, { descendants: true }) routers: QueryList<RouterLinkActive>;\n\n    // @HostBinding('attr.href') navLinkHref = 'javascript:;';\n\n    public offset: {\n        width: number;\n        height: number;\n        left: number;\n        top: number;\n    } = {\n        width: 0,\n        height: 0,\n        left: 0,\n        top: 0\n    };\n\n    public content: HTMLElement;\n\n    public isActive: boolean;\n\n    constructor(\n        public elementRef: ElementRef,\n        private renderer: Renderer2,\n        @Optional() private routerLinkActive: RouterLinkActive,\n        private ngZone: NgZone\n    ) {\n        super();\n    }\n\n    ngAfterViewInit() {\n        this.setOffset();\n\n        this.content = this.elementRef.nativeElement.outerHTML;\n\n        this.ngZone.onStable.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(() => {\n            this.isActive = this.linkIsActive();\n        });\n    }\n\n    setOffset() {\n        this.offset = {\n            width: this.elementRef.nativeElement.offsetWidth,\n            height: this.elementRef.nativeElement.offsetHeight,\n            left: this.elementRef.nativeElement.offsetLeft,\n            top: this.elementRef.nativeElement.offsetTop\n        };\n    }\n\n    linkIsActive() {\n        return (\n            this.thyNavItemActive ||\n            this.thyNavLinkActive ||\n            (this.routerLinkActive && this.routerLinkActive.isActive) ||\n            this.routers.some(router => router.isActive) ||\n            this.links.some(item => item.thyNavItemActive) ||\n            this.links.some(item => item.thyNavLinkActive)\n        );\n    }\n\n    setNavLinkHidden(value: boolean) {\n        if (value) {\n            this.renderer.addClass(this.elementRef.nativeElement, 'thy-nav-item-hidden');\n        } else {\n            this.renderer.removeClass(this.elementRef.nativeElement, 'thy-nav-item-hidden');\n        }\n    }\n\n    ngOnDestroy() {\n        this.ngUnsubscribe$.next();\n        this.ngUnsubscribe$.complete();\n    }\n}\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-item.directive.js","sourceRoot":"","sources":["../../../../src/nav/nav-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Constructor, InputBoolean, MixinBase, mixinUnsubscribe, ThyUnsubscribe } from 'ngx-tethys/core';\nimport { takeUntil } from 'rxjs/operators';\n\nimport {\n    AfterViewInit,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    Optional,\n    QueryList,\n    Renderer2\n} from '@angular/core';\nimport { RouterLinkActive } from '@angular/router';\n\nexport type ThyNavLink = '' | 'active';\n\nconst _MixinBase: Constructor<ThyUnsubscribe> & typeof MixinBase = mixinUnsubscribe(MixinBase);\n\n/**\n * 导航项\n * @name thyNavItem\n */\n@Directive({\n    selector: '[thyNavLink],[thyNavItem]',\n    host: {\n        class: 'thy-nav-item',\n        '[class.nav-active]': 'thyNavItemActive || thyNavLinkActive',\n        '[class.disabled]': 'thyNavItemDisabled'\n    }\n})\nexport class ThyNavItemDirective extends _MixinBase implements AfterViewInit, OnDestroy {\n    /**\n     * 是否激活状态\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    thyNavItemActive: boolean;\n\n    /**\n     * 已经废弃，请使用 thyNavItemActive\n     * @deprecated please use thyNavItemActive\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    thyNavLinkActive: boolean;\n\n    /**\n     * 是否禁用\n     * @default false\n     */\n    @Input()\n    @InputBoolean()\n    thyNavItemDisabled: boolean;\n\n    /**\n     * @private\n     */\n    @ContentChildren(ThyNavItemDirective, { descendants: true }) links: QueryList<ThyNavItemDirective>;\n\n    /**\n     * @private\n     */\n    @ContentChildren(RouterLinkActive, { descendants: true }) routers: QueryList<RouterLinkActive>;\n\n    // @HostBinding('attr.href') navLinkHref = 'javascript:;';\n\n    public offset: {\n        width: number;\n        height: number;\n        left: number;\n        top: number;\n    } = {\n        width: 0,\n        height: 0,\n        left: 0,\n        top: 0\n    };\n\n    public content: HTMLElement;\n\n    public isActive: boolean;\n\n    constructor(\n        public elementRef: ElementRef,\n        private renderer: Renderer2,\n        @Optional() private routerLinkActive: RouterLinkActive,\n        private ngZone: NgZone\n    ) {\n        super();\n    }\n\n    ngAfterViewInit() {\n        this.setOffset();\n\n        this.content = this.elementRef.nativeElement.outerHTML;\n\n        this.ngZone.onStable.pipe(takeUntil(this.ngUnsubscribe$)).subscribe(() => {\n            this.isActive = this.linkIsActive();\n        });\n    }\n\n    setOffset() {\n        this.offset = {\n            width: this.elementRef.nativeElement.offsetWidth,\n            height: this.elementRef.nativeElement.offsetHeight,\n            left: this.elementRef.nativeElement.offsetLeft,\n            top: this.elementRef.nativeElement.offsetTop\n        };\n    }\n\n    linkIsActive() {\n        return (\n            this.thyNavItemActive ||\n            this.thyNavLinkActive ||\n            (this.routerLinkActive && this.routerLinkActive.isActive) ||\n            this.routers.some(router => router.isActive) ||\n            this.links.some(item => item.thyNavItemActive) ||\n            this.links.some(item => item.thyNavLinkActive)\n        );\n    }\n\n    setNavLinkHidden(value: boolean) {\n        if (value) {\n            this.renderer.addClass(this.elementRef.nativeElement, 'thy-nav-item-hidden');\n        } else {\n            this.renderer.removeClass(this.elementRef.nativeElement, 'thy-nav-item-hidden');\n        }\n    }\n\n    ngOnDestroy() {\n        this.ngUnsubscribe$.next();\n        this.ngUnsubscribe$.complete();\n    }\n}\n"]}
@@ -79,14 +79,6 @@ export class ThyPropertiesComponent {
79
79
  rows.push([item]);
80
80
  }
81
81
  });
82
- // 循环处理所有行,若行数据的总 span 小于设置的 column 值,则补充行内最后一个 item 的 span 值进行填充
83
- rows.forEach(rowItems => {
84
- const totalSpan = rowItems.reduce((result, item) => result + item.thySpan, 0);
85
- if (totalSpan < this.thyColumn) {
86
- const lastItem = rowItems[rowItems.length - 1];
87
- lastItem.computedSpan = lastItem.thySpan + (this.thyColumn - totalSpan);
88
- }
89
- });
90
82
  this.rows = rows;
91
83
  }
92
84
  bindTriggerEvent() {
@@ -105,7 +97,7 @@ export class ThyPropertiesComponent {
105
97
  }
106
98
  }
107
99
  ThyPropertiesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyPropertiesComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
108
- ThyPropertiesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyPropertiesComponent, selector: "thy-properties", inputs: { thyLayout: "thyLayout", thyColumn: "thyColumn", thyEditTrigger: "thyEditTrigger" }, host: { properties: { "class.thy-properties-vertical": "thyLayout === \"vertical\"", "class.thy-properties-horizontal": "thyLayout === \"horizontal\"", "class.thy-properties-edit-trigger-hover": "thyEditTrigger === \"hover\"" }, classAttribute: "thy-properties" }, queries: [{ propertyName: "items", predicate: ThyPropertyItemComponent }], viewQueries: [{ propertyName: "itemElements", predicate: ["item"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"thyLayout === 'horizontal'\">\n <table>\n <tbody>\n <tr *ngFor=\"let row of rows; let i = index\">\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <div *ngIf=\"item\" class=\"thy-properties-item-container\">\n <ng-template [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n <ng-template [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-template>\n </div>\n </td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n</ng-container>\n\n<ng-container *ngIf=\"thyLayout === 'vertical'\">\n <table>\n <tbody>\n <ng-container *ngFor=\"let row of rows; let i = index\">\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n</ng-container>\n\n<ng-template #itemLabel let-item=\"item\">\n <span class=\"thy-properties-item-label\">\n <span *ngIf=\"item.thyLabelText\" thyFlexibleText [thyTooltipContent]=\"item.thyLabelText\">{{ item.thyLabelText }}</span>\n <ng-container *ngIf=\"item.label\">\n <ng-template [ngTemplateOutlet]=\"item.label\"></ng-template>\n </ng-container>\n </span>\n</ng-template>\n\n<ng-template #itemContent let-item=\"item\">\n <div\n #item\n class=\"thy-properties-item-content\"\n [class.thy-properties-item-content-editable]=\"item.thyEditable\"\n [class.thy-properties-item-content-editing]=\"item.editing\"\n >\n <div class=\"thy-properties-item-content-text\">\n <ng-template *ngIf=\"item.content\" [ngTemplateOutlet]=\"item.content\"></ng-template>\n </div>\n <div class=\"thy-properties-item-content-editor\" *ngIf=\"item.thyEditable\">\n <ng-template *ngIf=\"item.editor\" [ngTemplateOutlet]=\"item.editor\"></ng-template>\n </div>\n </div>\n</ng-template>\n", components: [{ type: i1.ThyFlexibleTextComponent, selector: "thy-flexible-text,[thyFlexibleText]", inputs: ["thyTooltipTrigger", "thyContainerClass", "thyTooltipContent", "thyTooltipPlacement"], exportAs: ["thyFlexibleText"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
100
+ ThyPropertiesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyPropertiesComponent, selector: "thy-properties", inputs: { thyLayout: "thyLayout", thyColumn: "thyColumn", thyEditTrigger: "thyEditTrigger" }, host: { properties: { "class.thy-properties-vertical": "thyLayout === \"vertical\"", "class.thy-properties-horizontal": "thyLayout === \"horizontal\"", "class.thy-properties-edit-trigger-hover": "thyEditTrigger === \"hover\"" }, classAttribute: "thy-properties" }, queries: [{ propertyName: "items", predicate: ThyPropertyItemComponent }], viewQueries: [{ propertyName: "itemElements", predicate: ["item"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"thyLayout === 'horizontal'\">\n <table>\n <tbody>\n <tr *ngFor=\"let row of rows; let i = index\">\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <div *ngIf=\"item\" class=\"thy-properties-item-container\">\n <ng-template [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n <ng-template [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-template>\n </div>\n </td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n</ng-container>\n\n<ng-container *ngIf=\"thyLayout === 'vertical'\">\n <table>\n <tbody>\n <ng-container *ngFor=\"let row of rows; let i = index\">\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n</ng-container>\n\n<ng-template #itemLabel let-item=\"item\">\n <span class=\"thy-properties-item-label\">\n <span *ngIf=\"item.thyLabelText\" thyFlexibleText [thyTooltipContent]=\"item.thyLabelText\">{{ item.thyLabelText }}</span>\n <ng-container *ngIf=\"item.label\">\n <ng-template [ngTemplateOutlet]=\"item.label\"></ng-template>\n </ng-container>\n </span>\n</ng-template>\n\n<ng-template #itemContent let-item=\"item\">\n <div\n #item\n class=\"thy-properties-item-content\"\n [class.thy-properties-item-content-editable]=\"item.thyEditable\"\n [class.thy-properties-item-content-editing]=\"item.editing\"\n >\n <div class=\"thy-properties-item-content-text\">\n <ng-template *ngIf=\"item.content\" [ngTemplateOutlet]=\"item.content\"></ng-template>\n </div>\n <div class=\"thy-properties-item-content-editor\" *ngIf=\"item.thyEditable\">\n <ng-template *ngIf=\"item.editor\" [ngTemplateOutlet]=\"item.editor\"></ng-template>\n </div>\n </div>\n</ng-template>\n", components: [{ type: i1.ThyFlexibleTextComponent, selector: "thy-flexible-text,[thyFlexibleText]", inputs: ["thyTooltipTrigger", "thyContainerClass", "thyTooltipContent", "thyTooltipPlacement"], exportAs: ["thyFlexibleText"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
109
101
  __decorate([
110
102
  InputNumber(),
111
103
  __metadata("design:type", Number)
@@ -117,7 +109,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
117
109
  '[class.thy-properties-vertical]': 'thyLayout === "vertical"',
118
110
  '[class.thy-properties-horizontal]': 'thyLayout === "horizontal"',
119
111
  '[class.thy-properties-edit-trigger-hover]': 'thyEditTrigger === "hover"'
120
- }, template: "<ng-container *ngIf=\"thyLayout === 'horizontal'\">\n <table>\n <tbody>\n <tr *ngFor=\"let row of rows; let i = index\">\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <div *ngIf=\"item\" class=\"thy-properties-item-container\">\n <ng-template [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n <ng-template [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-template>\n </div>\n </td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n</ng-container>\n\n<ng-container *ngIf=\"thyLayout === 'vertical'\">\n <table>\n <tbody>\n <ng-container *ngFor=\"let row of rows; let i = index\">\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n</ng-container>\n\n<ng-template #itemLabel let-item=\"item\">\n <span class=\"thy-properties-item-label\">\n <span *ngIf=\"item.thyLabelText\" thyFlexibleText [thyTooltipContent]=\"item.thyLabelText\">{{ item.thyLabelText }}</span>\n <ng-container *ngIf=\"item.label\">\n <ng-template [ngTemplateOutlet]=\"item.label\"></ng-template>\n </ng-container>\n </span>\n</ng-template>\n\n<ng-template #itemContent let-item=\"item\">\n <div\n #item\n class=\"thy-properties-item-content\"\n [class.thy-properties-item-content-editable]=\"item.thyEditable\"\n [class.thy-properties-item-content-editing]=\"item.editing\"\n >\n <div class=\"thy-properties-item-content-text\">\n <ng-template *ngIf=\"item.content\" [ngTemplateOutlet]=\"item.content\"></ng-template>\n </div>\n <div class=\"thy-properties-item-content-editor\" *ngIf=\"item.thyEditable\">\n <ng-template *ngIf=\"item.editor\" [ngTemplateOutlet]=\"item.editor\"></ng-template>\n </div>\n </div>\n</ng-template>\n" }]
112
+ }, template: "<ng-container *ngIf=\"thyLayout === 'horizontal'\">\n <table>\n <tbody>\n <tr *ngFor=\"let row of rows; let i = index\">\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <div *ngIf=\"item\" class=\"thy-properties-item-container\">\n <ng-template [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n <ng-template [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-template>\n </div>\n </td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n</ng-container>\n\n<ng-container *ngIf=\"thyLayout === 'vertical'\">\n <table>\n <tbody>\n <ng-container *ngFor=\"let row of rows; let i = index\">\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n <tr>\n <ng-container *ngFor=\"let item of rows[i]\">\n <td [attr.colspan]=\"item.thySpan\">\n <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n</ng-container>\n\n<ng-template #itemLabel let-item=\"item\">\n <span class=\"thy-properties-item-label\">\n <span *ngIf=\"item.thyLabelText\" thyFlexibleText [thyTooltipContent]=\"item.thyLabelText\">{{ item.thyLabelText }}</span>\n <ng-container *ngIf=\"item.label\">\n <ng-template [ngTemplateOutlet]=\"item.label\"></ng-template>\n </ng-container>\n </span>\n</ng-template>\n\n<ng-template #itemContent let-item=\"item\">\n <div\n #item\n class=\"thy-properties-item-content\"\n [class.thy-properties-item-content-editable]=\"item.thyEditable\"\n [class.thy-properties-item-content-editing]=\"item.editing\"\n >\n <div class=\"thy-properties-item-content-text\">\n <ng-template *ngIf=\"item.content\" [ngTemplateOutlet]=\"item.content\"></ng-template>\n </div>\n <div class=\"thy-properties-item-content-editor\" *ngIf=\"item.thyEditable\">\n <ng-template *ngIf=\"item.editor\" [ngTemplateOutlet]=\"item.editor\"></ng-template>\n </div>\n </div>\n</ng-template>\n" }]
121
113
  }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { thyLayout: [{
122
114
  type: Input
123
115
  }], thyColumn: [{
@@ -131,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
131
123
  type: ViewChildren,
132
124
  args: ['item', { read: ElementRef }]
133
125
  }] } });
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"properties.component.js","sourceRoot":"","sources":["../../../../src/property/properties.component.ts","../../../../src/property/properties.component.html"],"names":[],"mappings":"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","sourcesContent":["import { InputNumber } from 'ngx-tethys/core';\nimport { merge, Subject } from 'rxjs';\nimport { filter, startWith, takeUntil } from 'rxjs/operators';\n\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    SimpleChanges,\n    ViewChildren\n} from '@angular/core';\n\nimport { ThyPropertyItemComponent } from './property-item.component';\n\n/**\n * 属性列表组件\n * @name thy-properties\n */\n@Component({\n    selector: 'thy-properties',\n    templateUrl: './properties.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-properties',\n        '[class.thy-properties-vertical]': 'thyLayout === \"vertical\"',\n        '[class.thy-properties-horizontal]': 'thyLayout === \"horizontal\"',\n        '[class.thy-properties-edit-trigger-hover]': 'thyEditTrigger === \"hover\"'\n    }\n})\nexport class ThyPropertiesComponent implements OnInit, AfterViewInit, AfterContentInit, OnChanges, OnDestroy {\n    /**\n     * 展示布局\n     * @type \"horizontal\" | \"vertical\"\n     * @default horizontal\n     */\n    @Input() thyLayout: 'horizontal' | 'vertical' = 'horizontal';\n\n    /**\n     * 设置一行的可以 property-item 的数量\n     * @type  number\n     * @default 1\n     */\n    @Input() @InputNumber() thyColumn: number = 1;\n\n    /**\n     * 设置编辑状态触发方法\n     * @type 'hover' | 'click'\n     * @default hover\n     */\n    @Input() thyEditTrigger: 'hover' | 'click' = 'hover';\n\n    /**\n     * @private\n     */\n    @ContentChildren(ThyPropertyItemComponent) items!: QueryList<ThyPropertyItemComponent>;\n\n    /**\n     * @private\n     */\n    @ViewChildren('item', { read: ElementRef }) itemElements: QueryList<ElementRef<HTMLElement>>;\n\n    rows: ThyPropertyItemComponent[][] = [];\n\n    private destroy$ = new Subject();\n\n    private editTrigger$ = new Subject();\n\n    constructor(private ngZone: NgZone, private cdr: ChangeDetectorRef) {}\n\n    ngOnInit() {}\n\n    ngAfterContentInit(): void {\n        this.items.changes.pipe(startWith(this.items), takeUntil(this.destroy$)).subscribe(() => {\n            this.splitItems();\n            this.cdr.markForCheck();\n        });\n\n        merge(...this.items.map(item => item.changes$))\n            .pipe(\n                filter(changes => changes.thySpan && !changes.thySpan.firstChange),\n                takeUntil(merge(this.items.changes, this.destroy$))\n            )\n            .subscribe(() => {\n                this.splitItems();\n                this.cdr.markForCheck();\n            });\n    }\n\n    ngAfterViewInit(): void {\n        this.itemElements.changes.pipe(startWith(this.itemElements), takeUntil(this.destroy$)).subscribe(event => {\n            this.bindTriggerEvent();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.thyEditTrigger && !changes.thyEditTrigger.firstChange) {\n            this.editTrigger$.next();\n            this.bindTriggerEvent();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private splitItems(): void {\n        const items = this.items.toArray();\n        const rows: ThyPropertyItemComponent[][] = [[]];\n        items.forEach(item => {\n            const lastRowItems = rows[rows.length - 1];\n            const totalSpan = lastRowItems.reduce((result, item) => result + item.thySpan, 0);\n            // 计算最后一行剩余 span 空间是否容纳下当前 item 的 span，如果容纳不下则新增一行\n            if (item.thySpan <= this.thyColumn - totalSpan) {\n                lastRowItems.push(item);\n            } else {\n                rows.push([item]);\n            }\n        });\n        // 循环处理所有行，若行数据的总 span 小于设置的 column 值，则补充行内最后一个 item 的 span 值进行填充\n        rows.forEach(rowItems => {\n            const totalSpan = rowItems.reduce((result, item) => result + item.thySpan, 0);\n            if (totalSpan < this.thyColumn) {\n                const lastItem = rowItems[rowItems.length - 1];\n                lastItem.computedSpan = lastItem.thySpan + (this.thyColumn - totalSpan);\n            }\n        });\n        this.rows = rows;\n    }\n\n    private bindTriggerEvent() {\n        this.ngZone.runOutsideAngular(() => {\n            const eventDestroy$ = merge(this.itemElements.changes, this.editTrigger$, this.destroy$);\n\n            this.itemElements.forEach((element, index) => {\n                const itemComponent = this.items.get(index);\n                if (itemComponent.thyEditable) {\n                    return itemComponent\n                        .editorClick(element.nativeElement)\n                        .pipe(takeUntil(eventDestroy$))\n                        .subscribe();\n                }\n            });\n        });\n    }\n}\n","<ng-container *ngIf=\"thyLayout === 'horizontal'\">\n  <table>\n    <tbody>\n      <tr *ngFor=\"let row of rows; let i = index\">\n        <ng-container *ngFor=\"let item of rows[i]\">\n          <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n            <div *ngIf=\"item\" class=\"thy-properties-item-container\">\n              <ng-template [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n              <ng-template [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-template>\n            </div>\n          </td>\n        </ng-container>\n      </tr>\n    </tbody>\n  </table>\n</ng-container>\n\n<ng-container *ngIf=\"thyLayout === 'vertical'\">\n  <table>\n    <tbody>\n      <ng-container *ngFor=\"let row of rows; let i = index\">\n        <tr>\n          <ng-container *ngFor=\"let item of rows[i]\">\n            <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n              <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n            </td>\n          </ng-container>\n        </tr>\n        <tr>\n          <ng-container *ngFor=\"let item of rows[i]\">\n            <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n              <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n            </td>\n          </ng-container>\n        </tr>\n      </ng-container>\n    </tbody>\n  </table>\n</ng-container>\n\n<ng-template #itemLabel let-item=\"item\">\n  <span class=\"thy-properties-item-label\">\n    <span *ngIf=\"item.thyLabelText\" thyFlexibleText [thyTooltipContent]=\"item.thyLabelText\">{{ item.thyLabelText }}</span>\n    <ng-container *ngIf=\"item.label\">\n      <ng-template [ngTemplateOutlet]=\"item.label\"></ng-template>\n    </ng-container>\n  </span>\n</ng-template>\n\n<ng-template #itemContent let-item=\"item\">\n  <div\n    #item\n    class=\"thy-properties-item-content\"\n    [class.thy-properties-item-content-editable]=\"item.thyEditable\"\n    [class.thy-properties-item-content-editing]=\"item.editing\"\n  >\n    <div class=\"thy-properties-item-content-text\">\n      <ng-template *ngIf=\"item.content\" [ngTemplateOutlet]=\"item.content\"></ng-template>\n    </div>\n    <div class=\"thy-properties-item-content-editor\" *ngIf=\"item.thyEditable\">\n      <ng-template *ngIf=\"item.editor\" [ngTemplateOutlet]=\"item.editor\"></ng-template>\n    </div>\n  </div>\n</ng-template>\n"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"properties.component.js","sourceRoot":"","sources":["../../../../src/property/properties.component.ts","../../../../src/property/properties.component.html"],"names":[],"mappings":"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","sourcesContent":["import { InputNumber } from 'ngx-tethys/core';\nimport { merge, Subject } from 'rxjs';\nimport { filter, startWith, takeUntil } from 'rxjs/operators';\n\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    SimpleChanges,\n    ViewChildren\n} from '@angular/core';\n\nimport { ThyPropertyItemComponent } from './property-item.component';\n\n/**\n * 属性列表组件\n * @name thy-properties\n */\n@Component({\n    selector: 'thy-properties',\n    templateUrl: './properties.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'thy-properties',\n        '[class.thy-properties-vertical]': 'thyLayout === \"vertical\"',\n        '[class.thy-properties-horizontal]': 'thyLayout === \"horizontal\"',\n        '[class.thy-properties-edit-trigger-hover]': 'thyEditTrigger === \"hover\"'\n    }\n})\nexport class ThyPropertiesComponent implements OnInit, AfterViewInit, AfterContentInit, OnChanges, OnDestroy {\n    /**\n     * 展示布局\n     * @type \"horizontal\" | \"vertical\"\n     * @default horizontal\n     */\n    @Input() thyLayout: 'horizontal' | 'vertical' = 'horizontal';\n\n    /**\n     * 设置一行的可以 property-item 的数量\n     * @type  number\n     * @default 1\n     */\n    @Input() @InputNumber() thyColumn: number = 1;\n\n    /**\n     * 设置编辑状态触发方法\n     * @type 'hover' | 'click'\n     * @default hover\n     */\n    @Input() thyEditTrigger: 'hover' | 'click' = 'hover';\n\n    /**\n     * @private\n     */\n    @ContentChildren(ThyPropertyItemComponent) items!: QueryList<ThyPropertyItemComponent>;\n\n    /**\n     * @private\n     */\n    @ViewChildren('item', { read: ElementRef }) itemElements: QueryList<ElementRef<HTMLElement>>;\n\n    rows: ThyPropertyItemComponent[][] = [];\n\n    private destroy$ = new Subject();\n\n    private editTrigger$ = new Subject();\n\n    constructor(private ngZone: NgZone, private cdr: ChangeDetectorRef) {}\n\n    ngOnInit() {}\n\n    ngAfterContentInit(): void {\n        this.items.changes.pipe(startWith(this.items), takeUntil(this.destroy$)).subscribe(() => {\n            this.splitItems();\n            this.cdr.markForCheck();\n        });\n\n        merge(...this.items.map(item => item.changes$))\n            .pipe(\n                filter(changes => changes.thySpan && !changes.thySpan.firstChange),\n                takeUntil(merge(this.items.changes, this.destroy$))\n            )\n            .subscribe(() => {\n                this.splitItems();\n                this.cdr.markForCheck();\n            });\n    }\n\n    ngAfterViewInit(): void {\n        this.itemElements.changes.pipe(startWith(this.itemElements), takeUntil(this.destroy$)).subscribe(event => {\n            this.bindTriggerEvent();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.thyEditTrigger && !changes.thyEditTrigger.firstChange) {\n            this.editTrigger$.next();\n            this.bindTriggerEvent();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private splitItems(): void {\n        const items = this.items.toArray();\n        const rows: ThyPropertyItemComponent[][] = [[]];\n        items.forEach(item => {\n            const lastRowItems = rows[rows.length - 1];\n            const totalSpan = lastRowItems.reduce((result, item) => result + item.thySpan, 0);\n            // 计算最后一行剩余 span 空间是否容纳下当前 item 的 span，如果容纳不下则新增一行\n            if (item.thySpan <= this.thyColumn - totalSpan) {\n                lastRowItems.push(item);\n            } else {\n                rows.push([item]);\n            }\n        });\n        this.rows = rows;\n    }\n\n    private bindTriggerEvent() {\n        this.ngZone.runOutsideAngular(() => {\n            const eventDestroy$ = merge(this.itemElements.changes, this.editTrigger$, this.destroy$);\n\n            this.itemElements.forEach((element, index) => {\n                const itemComponent = this.items.get(index);\n                if (itemComponent.thyEditable) {\n                    return itemComponent\n                        .editorClick(element.nativeElement)\n                        .pipe(takeUntil(eventDestroy$))\n                        .subscribe();\n                }\n            });\n        });\n    }\n}\n","<ng-container *ngIf=\"thyLayout === 'horizontal'\">\n  <table>\n    <tbody>\n      <tr *ngFor=\"let row of rows; let i = index\">\n        <ng-container *ngFor=\"let item of rows[i]\">\n          <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n            <div *ngIf=\"item\" class=\"thy-properties-item-container\">\n              <ng-template [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n              <ng-template [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-template>\n            </div>\n          </td>\n        </ng-container>\n      </tr>\n    </tbody>\n  </table>\n</ng-container>\n\n<ng-container *ngIf=\"thyLayout === 'vertical'\">\n  <table>\n    <tbody>\n      <ng-container *ngFor=\"let row of rows; let i = index\">\n        <tr>\n          <ng-container *ngFor=\"let item of rows[i]\">\n            <td [attr.colspan]=\"item.computedSpan || item.thySpan\">\n              <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemLabel\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n            </td>\n          </ng-container>\n        </tr>\n        <tr>\n          <ng-container *ngFor=\"let item of rows[i]\">\n            <td [attr.colspan]=\"item.thySpan\">\n              <ng-template *ngIf=\"item\" [ngTemplateOutlet]=\"itemContent\" [ngTemplateOutletContext]=\"{ item: item }\"> </ng-template>\n            </td>\n          </ng-container>\n        </tr>\n      </ng-container>\n    </tbody>\n  </table>\n</ng-container>\n\n<ng-template #itemLabel let-item=\"item\">\n  <span class=\"thy-properties-item-label\">\n    <span *ngIf=\"item.thyLabelText\" thyFlexibleText [thyTooltipContent]=\"item.thyLabelText\">{{ item.thyLabelText }}</span>\n    <ng-container *ngIf=\"item.label\">\n      <ng-template [ngTemplateOutlet]=\"item.label\"></ng-template>\n    </ng-container>\n  </span>\n</ng-template>\n\n<ng-template #itemContent let-item=\"item\">\n  <div\n    #item\n    class=\"thy-properties-item-content\"\n    [class.thy-properties-item-content-editable]=\"item.thyEditable\"\n    [class.thy-properties-item-content-editing]=\"item.editing\"\n  >\n    <div class=\"thy-properties-item-content-text\">\n      <ng-template *ngIf=\"item.content\" [ngTemplateOutlet]=\"item.content\"></ng-template>\n    </div>\n    <div class=\"thy-properties-item-content-editor\" *ngIf=\"item.thyEditable\">\n      <ng-template *ngIf=\"item.editor\" [ngTemplateOutlet]=\"item.editor\"></ng-template>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -131,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
131
131
  type: ViewChild,
132
132
  args: [TemplateRef, { static: true }]
133
133
  }] } });
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-item.component.js","sourceRoot":"","sources":["../../../../src/property/property-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InputBoolean, InputNumber, ThyClickDispatcher } from 'ngx-tethys/core';\nimport { fromEvent, Subject } from 'rxjs';\nimport { filter, skip, take, takeUntil, tap } from 'rxjs/operators';\n\nimport { OverlayOutsideClickDispatcher } from '@angular/cdk/overlay';\nimport { OverlayReference } from '@angular/cdk/overlay/overlay-reference';\nimport {\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges,\n    SkipSelf,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\n/**\n * 属性组件\n * @name thy-property-item\n */\n@Component({\n    selector: 'thy-property-item',\n    template: `\n        <ng-template>\n            <ng-content></ng-content>\n        </ng-template>\n    `\n})\nexport class ThyPropertyItemComponent implements OnInit, OnChanges, OnDestroy {\n    /**\n     * 属性名称\n     * @type sting\n     * @default thyLabelText\n     */\n    @Input() thyLabelText: string;\n\n    /**\n     * 设置属性是否是可编辑的\n     * @type sting\n     * @default false\n     */\n    @Input() @InputBoolean() thyEditable: boolean;\n\n    /**\n     * 设置跨列的数量\n     * @type sting\n     * @default 1\n     */\n    @Input() @InputNumber() thySpan: number = 1;\n\n    /**\n     * 属性名称自定义模板\n     * @type TemplateRef\n     */\n    @ContentChild('label', { static: true }) label!: TemplateRef<void>;\n\n    /**\n     * 属性内容编辑模板，只有在 thyEditable 为 true 时生效\n     * @type TemplateRef\n     */\n    @ContentChild('editor', { static: true }) editor!: TemplateRef<void>;\n\n    /**\n     * @private\n     */\n    @ViewChild(TemplateRef, { static: true }) content!: TemplateRef<void>;\n\n    editing: boolean;\n\n    // 适配布局时通过计算动态设置的 span 值\n    computedSpan: number;\n\n    changes$ = new Subject<SimpleChanges>();\n\n    private destroy$ = new Subject();\n\n    private originOverlays: OverlayReference[] = [];\n\n    constructor(\n        @SkipSelf() protected parentCdr: ChangeDetectorRef,\n        private thyClickDispatcher: ThyClickDispatcher,\n        private ngZone: NgZone,\n        private overlayOutsideClickDispatcher: OverlayOutsideClickDispatcher\n    ) {\n        this.originOverlays = [...this.overlayOutsideClickDispatcher._attachedOverlays];\n    }\n\n    ngOnInit() {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.changes$.next(changes);\n    }\n\n    setEditing(editing: boolean) {\n        this.ngZone.run(() => {\n            this.editing = editing;\n            this.parentCdr.markForCheck();\n        });\n    }\n\n    /**\n     * @deprecated please use setEditing(editing: boolean)\n     */\n    setKeepEditing(keep: boolean) {\n        this.setEditing(keep);\n    }\n\n    private hasOverlay() {\n        return this.overlayOutsideClickDispatcher._attachedOverlays.length > this.originOverlays.length;\n    }\n\n    private subscribeOverlayClick() {\n        const newOpenedOverlays = this.overlayOutsideClickDispatcher._attachedOverlays.slice(this.originOverlays.length);\n\n        this.thyClickDispatcher\n            .clicked(0)\n            .pipe(\n                skip(1),\n                filter(event => {\n                    return (\n                        newOpenedOverlays.findIndex(overlay => {\n                            return overlay.overlayElement.contains(event.target as HTMLElement);\n                        }) < 0\n                    );\n                }),\n                take(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.setEditing(false);\n            });\n    }\n\n    private subscribeDocumentClick(editorElement: HTMLElement) {\n        this.thyClickDispatcher\n            .clicked(0)\n            .pipe(\n                filter(event => {\n                    return !editorElement.contains(event.target as HTMLElement);\n                }),\n                take(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.setEditing(false);\n            });\n    }\n\n    private bindEditorBlurEvent(editorElement: HTMLElement) {\n        if (this.hasOverlay()) {\n            this.subscribeOverlayClick();\n        } else {\n            this.subscribeDocumentClick(editorElement);\n        }\n    }\n\n    editorClick(editorElement: HTMLElement) {\n        return fromEvent(editorElement, 'click').pipe(\n            tap(() => {\n                this.setEditing(true);\n                this.bindEditorBlurEvent(editorElement);\n            })\n        );\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n"]}
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-item.component.js","sourceRoot":"","sources":["../../../../src/property/property-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { InputBoolean, InputNumber, ThyClickDispatcher } from 'ngx-tethys/core';\nimport { fromEvent, Subject } from 'rxjs';\nimport { filter, skip, take, takeUntil, tap } from 'rxjs/operators';\n\nimport { OverlayOutsideClickDispatcher } from '@angular/cdk/overlay';\nimport { OverlayReference } from '@angular/cdk/overlay/overlay-reference';\nimport {\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges,\n    SkipSelf,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\n/**\n * 属性组件\n * @name thy-property-item\n */\n@Component({\n    selector: 'thy-property-item',\n    template: `\n        <ng-template>\n            <ng-content></ng-content>\n        </ng-template>\n    `\n})\nexport class ThyPropertyItemComponent implements OnInit, OnChanges, OnDestroy {\n    /**\n     * 属性名称\n     * @type sting\n     * @default thyLabelText\n     */\n    @Input() thyLabelText: string;\n\n    /**\n     * 设置属性是否是可编辑的\n     * @type sting\n     * @default false\n     */\n    @Input() @InputBoolean() thyEditable: boolean;\n\n    /**\n     * 设置跨列的数量\n     * @type sting\n     * @default 1\n     */\n    @Input() @InputNumber() thySpan: number = 1;\n\n    /**\n     * 属性名称自定义模板\n     * @type TemplateRef\n     */\n    @ContentChild('label', { static: true }) label!: TemplateRef<void>;\n\n    /**\n     * 属性内容编辑模板，只有在 thyEditable 为 true 时生效\n     * @type TemplateRef\n     */\n    @ContentChild('editor', { static: true }) editor!: TemplateRef<void>;\n\n    /**\n     * @private\n     */\n    @ViewChild(TemplateRef, { static: true }) content!: TemplateRef<void>;\n\n    editing: boolean;\n\n    changes$ = new Subject<SimpleChanges>();\n\n    private destroy$ = new Subject();\n\n    private originOverlays: OverlayReference[] = [];\n\n    constructor(\n        @SkipSelf() protected parentCdr: ChangeDetectorRef,\n        private thyClickDispatcher: ThyClickDispatcher,\n        private ngZone: NgZone,\n        private overlayOutsideClickDispatcher: OverlayOutsideClickDispatcher\n    ) {\n        this.originOverlays = [...this.overlayOutsideClickDispatcher._attachedOverlays];\n    }\n\n    ngOnInit() {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.changes$.next(changes);\n    }\n\n    setEditing(editing: boolean) {\n        this.ngZone.run(() => {\n            this.editing = editing;\n            this.parentCdr.markForCheck();\n        });\n    }\n\n    /**\n     * @deprecated please use setEditing(editing: boolean)\n     */\n    setKeepEditing(keep: boolean) {\n        this.setEditing(keep);\n    }\n\n    private hasOverlay() {\n        return this.overlayOutsideClickDispatcher._attachedOverlays.length > this.originOverlays.length;\n    }\n\n    private subscribeOverlayClick() {\n        const newOpenedOverlays = this.overlayOutsideClickDispatcher._attachedOverlays.slice(this.originOverlays.length);\n\n        this.thyClickDispatcher\n            .clicked(0)\n            .pipe(\n                skip(1),\n                filter(event => {\n                    return (\n                        newOpenedOverlays.findIndex(overlay => {\n                            return overlay.overlayElement.contains(event.target as HTMLElement);\n                        }) < 0\n                    );\n                }),\n                take(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.setEditing(false);\n            });\n    }\n\n    private subscribeDocumentClick(editorElement: HTMLElement) {\n        this.thyClickDispatcher\n            .clicked(0)\n            .pipe(\n                filter(event => {\n                    return !editorElement.contains(event.target as HTMLElement);\n                }),\n                take(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe(() => {\n                this.setEditing(false);\n            });\n    }\n\n    private bindEditorBlurEvent(editorElement: HTMLElement) {\n        if (this.hasOverlay()) {\n            this.subscribeOverlayClick();\n        } else {\n            this.subscribeDocumentClick(editorElement);\n        }\n    }\n\n    editorClick(editorElement: HTMLElement) {\n        return fromEvent(editorElement, 'click').pipe(\n            tap(() => {\n                this.setEditing(true);\n                this.bindEditorBlurEvent(editorElement);\n            })\n        );\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n"]}