@alauda/ui 6.4.6-beta.5 → 6.4.6-beta.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 (101) hide show
  1. package/alauda-ui.d.ts +3 -0
  2. package/button/button.types.d.ts +9 -0
  3. package/esm2020/accordion/accordion-item/accordion-item.component.mjs +3 -1
  4. package/esm2020/alauda-ui.mjs +4 -1
  5. package/esm2020/anchor/anchor.component.mjs +2 -1
  6. package/esm2020/back-top/back-top.component.mjs +4 -2
  7. package/esm2020/button/button.component.mjs +2 -1
  8. package/esm2020/button/button.types.mjs +10 -1
  9. package/esm2020/date-picker/calendar/constant.mjs +2 -1
  10. package/esm2020/date-picker/calendar/header/component.mjs +5 -1
  11. package/esm2020/date-picker/calendar/panel/picker-panel.mjs +5 -1
  12. package/esm2020/date-picker/calendar/range-picker-panel/component.mjs +3 -1
  13. package/esm2020/date-picker/calendar/util.mjs +2 -1
  14. package/esm2020/dialog/dialog-content/dialog-content.component.mjs +2 -1
  15. package/esm2020/dialog/dialog.service.mjs +2 -1
  16. package/esm2020/drawer/component/drawer.component.mjs +4 -1
  17. package/esm2020/drawer/component/helper-directives.mjs +5 -1
  18. package/esm2020/form/common-form.mjs +8 -1
  19. package/esm2020/icon/icon-register.service.mjs +2 -1
  20. package/esm2020/input/autosize.directive.mjs +7 -2
  21. package/esm2020/input/input.component.mjs +5 -1
  22. package/esm2020/input/tags-input/tags-input.component.mjs +7 -2
  23. package/esm2020/message/message.config.mjs +6 -1
  24. package/esm2020/notification/notification.component.mjs +5 -1
  25. package/esm2020/paginator/paginator-intl.mjs +12 -1
  26. package/esm2020/paginator/paginator.component.mjs +9 -1
  27. package/esm2020/radio/radio-button/radio-button.component.mjs +2 -1
  28. package/esm2020/radio/radio-group/radio-group.component.mjs +4 -1
  29. package/esm2020/radio/radio.component.mjs +2 -1
  30. package/esm2020/scrolling/fixed-size-table-virtual-scroll-strategy.mjs +3 -1
  31. package/esm2020/scrolling/fixed-size-table-virtual-scroll.directive.mjs +3 -1
  32. package/esm2020/scrolling/fixed-size-virtual-scroll.directive.mjs +2 -1
  33. package/esm2020/select/base-select.mjs +5 -2
  34. package/esm2020/select/multi-select/multi-select.component.mjs +8 -4
  35. package/esm2020/select/select.component.mjs +2 -1
  36. package/esm2020/select/validators.mjs +6 -2
  37. package/esm2020/sort/sort-errors.mjs +5 -1
  38. package/esm2020/sort/sort-header.component.mjs +5 -1
  39. package/esm2020/sort/sort.directive.mjs +2 -1
  40. package/esm2020/steps/steps.component.mjs +5 -1
  41. package/esm2020/table/table-cell-def.directive.mjs +5 -1
  42. package/esm2020/table/table-cell.directive.mjs +3 -1
  43. package/esm2020/table/table-column-def.directive.mjs +7 -1
  44. package/esm2020/table/table-header-cell-def.directive.mjs +5 -1
  45. package/esm2020/table/table-header-cell.directive.mjs +3 -1
  46. package/esm2020/table/table-header-row-def.directive.mjs +5 -1
  47. package/esm2020/table/table-header-row.component.mjs +2 -1
  48. package/esm2020/table/table-row-def.directive.mjs +6 -1
  49. package/esm2020/table/table-row.component.mjs +2 -1
  50. package/esm2020/table/table-scroll.directive.mjs +2 -1
  51. package/esm2020/table/table.component.mjs +4 -1
  52. package/esm2020/tabs/tab-body.component.mjs +19 -1
  53. package/esm2020/tabs/tab-context.service.mjs +4 -1
  54. package/esm2020/tabs/tab-group.component.mjs +46 -1
  55. package/esm2020/tabs/tab-header-active-indicator.component.mjs +10 -1
  56. package/esm2020/tabs/tab-header.component.mjs +106 -3
  57. package/esm2020/tabs/tab.component.mjs +15 -1
  58. package/esm2020/tabs/tabs.types.mjs +4 -1
  59. package/esm2020/tag/tag.component.mjs +2 -1
  60. package/esm2020/time-picker/panel/panel.component.mjs +3 -1
  61. package/esm2020/tooltip/tooltip-intl.mjs +7 -1
  62. package/esm2020/tree-select/tree-select.component.mjs +2 -1
  63. package/esm2020/types.mjs +4 -1
  64. package/esm2020/utils/bem.mjs +2 -1
  65. package/esm2020/utils/coercion.mjs +5 -1
  66. package/fesm2015/alauda-ui.mjs +377 -10
  67. package/fesm2015/alauda-ui.mjs.map +1 -1
  68. package/fesm2020/alauda-ui.mjs +377 -10
  69. package/fesm2020/alauda-ui.mjs.map +1 -1
  70. package/form/common-form.d.ts +7 -0
  71. package/input/autosize.directive.d.ts +3 -0
  72. package/input/input.component.d.ts +3 -0
  73. package/message/message.config.d.ts +20 -0
  74. package/notification/notification.component.d.ts +4 -0
  75. package/package.json +2 -3
  76. package/paginator/paginator-intl.d.ts +9 -0
  77. package/paginator/paginator.component.d.ts +14 -0
  78. package/radio/radio-group/radio-group.component.d.ts +3 -0
  79. package/select/base-select.d.ts +3 -0
  80. package/select/multi-select/multi-select.component.d.ts +1 -0
  81. package/sort/sort-errors.d.ts +4 -0
  82. package/steps/steps.component.d.ts +3 -0
  83. package/steps/types.d.ts +3 -0
  84. package/table/table-cell-def.directive.d.ts +4 -0
  85. package/table/table-cell.directive.d.ts +1 -0
  86. package/table/table-column-def.directive.d.ts +4 -0
  87. package/table/table-header-cell-def.directive.d.ts +4 -0
  88. package/table/table-header-cell.directive.d.ts +1 -0
  89. package/table/table-header-row-def.directive.d.ts +4 -0
  90. package/table/table-header-row.component.d.ts +1 -0
  91. package/table/table-row-def.directive.d.ts +5 -0
  92. package/table/table-row.component.d.ts +1 -0
  93. package/tabs/tab-body.component.d.ts +16 -0
  94. package/tabs/tab-context.service.d.ts +3 -0
  95. package/tabs/tab-group.component.d.ts +28 -0
  96. package/tabs/tab-header-active-indicator.component.d.ts +9 -0
  97. package/tabs/tab-header.component.d.ts +83 -0
  98. package/tabs/tab.component.d.ts +18 -0
  99. package/tabs/tabs.types.d.ts +3 -0
  100. package/tooltip/tooltip-intl.d.ts +4 -0
  101. package/types.d.ts +3 -0
package/alauda-ui.d.ts CHANGED
@@ -1,2 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
1
4
  /// <amd-module name="@alauda/ui" />
2
5
  export * from './index';
@@ -7,8 +7,17 @@ export declare const ButtonType: {
7
7
  readonly Danger: "danger";
8
8
  readonly Text: "text";
9
9
  readonly Inline: "inline";
10
+ /**
11
+ * represents default internally, @link https://github.com/angular/vscode-ng-language-service/issues/1147
12
+ */
10
13
  readonly Empty: "";
14
+ /**
15
+ * @deprecated use `ButtonType.Danger` instead
16
+ */
11
17
  readonly Error: "danger";
18
+ /**
19
+ * @deprecated use `ButtonType.Default` instead
20
+ */
12
21
  readonly Info: "default";
13
22
  };
14
23
  export declare type ButtonType = ValueOf<typeof ButtonType>;
@@ -28,12 +28,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
28
28
  }]
29
29
  }] });
30
30
  export class AccordionItemComponent extends CdkAccordionItem {
31
+ // eslint-disable-next-line @typescript-eslint/no-useless-constructor
31
32
  constructor(accordion, cdr, uniqueSelectionDispatcher) {
32
33
  super(accordion, cdr, uniqueSelectionDispatcher);
33
34
  this.background = true;
34
35
  }
35
36
  ngAfterContentInit() {
36
37
  if (this._lazyContentTpl) {
38
+ // Render the content as soon as the accordion becomes open.
37
39
  this.opened
38
40
  .pipe(startWith(null), filter(() => !!this.expanded), take(1))
39
41
  .subscribe(() => {
@@ -68,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
68
70
  static: true,
69
71
  }]
70
72
  }] } });
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY29yZGlvbi9hY2NvcmRpb24taXRlbS9hY2NvcmRpb24taXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvYWNjb3JkaW9uL2FjY29yZGlvbi1pdGVtL2FjY29yZGlvbi1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxPQUFPLEVBQ1AsS0FBSyxFQUNMLEtBQUssRUFDTCxVQUFVLEVBQ1YsT0FBTyxHQUNSLE1BQU0scUJBQXFCLENBQUM7QUFDN0IsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFMUQsT0FBTyxFQUVMLHVCQUF1QixFQUV2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLFNBQVMsRUFDVCxLQUFLLEVBQ0wsV0FBVyxFQUNYLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7OztBQU8vQyxNQUFNLE9BQU8sNEJBQTRCOzt5SEFBNUIsNEJBQTRCOzZHQUE1Qiw0QkFBNEI7MkZBQTVCLDRCQUE0QjtrQkFIeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsMEJBQTBCO2lCQUNyQzs7QUFLRCxNQUFNLE9BQU8sNkJBQTZCOzswSEFBN0IsNkJBQTZCOzhHQUE3Qiw2QkFBNkI7MkZBQTdCLDZCQUE2QjtrQkFIekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO2lCQUNsQzs7QUFrQkQsTUFBTSxPQUFPLHNCQUNYLFNBQVEsZ0JBQWdCO0lBZXhCLFlBQ0UsU0FBNkIsRUFDN0IsR0FBc0IsRUFDdEIseUJBQW9EO1FBRXBELEtBQUssQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFLHlCQUF5QixDQUFDLENBQUM7UUFoQm5ELGVBQVUsR0FBRyxJQUFJLENBQUM7SUFpQmxCLENBQUM7SUFFRCxrQkFBa0I7UUFDaEIsSUFBSSxJQUFJLENBQUMsZUFBZSxFQUFFO1lBRXhCLElBQUksQ0FBQyxNQUFNO2lCQUNSLElBQUksQ0FDSCxTQUFTLENBQUMsSUFBWSxDQUFDLEVBQ3ZCLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUM3QixJQUFJLENBQUMsQ0FBQyxDQUFDLENBQ1I7aUJBQ0EsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDZCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7WUFDN0MsQ0FBQyxDQUFDLENBQUM7U0FDTjtJQUNILENBQUM7O21IQXJDVSxzQkFBc0I7dUdBQXRCLHNCQUFzQiw2SUFPbkIsNkJBQTZCLDJCQUNuQyxXQUFXLGtFQ3hEckIscThCQWlDQSw0Z0ZEYWlCLENBQUMsc0JBQXNCLENBQUMsY0FQM0I7UUFDVixPQUFPLENBQUMsUUFBUSxFQUFFO1lBQ2hCLEtBQUssQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDaEMsS0FBSyxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztZQUN6QyxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUFDO1NBQzVELENBQUM7S0FDSDsyRkFHVSxzQkFBc0I7a0JBaEJsQyxTQUFTOytCQUNFLG9CQUFvQixtQkFHYix1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJLHVCQUNoQixLQUFLLGNBQ2Q7d0JBQ1YsT0FBTyxDQUFDLFFBQVEsRUFBRTs0QkFDaEIsS0FBSyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQzs0QkFDaEMsS0FBSyxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQzs0QkFDekMsVUFBVSxDQUFDLGdCQUFnQixFQUFFLENBQUMsT0FBTyxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQzt5QkFDNUQsQ0FBQztxQkFDSCxpQkFDYyx3QkFBd0I7aUxBT3ZDLFVBQVU7c0JBRFQsS0FBSztnQkFPTixlQUFlO3NCQUpkLFlBQVk7dUJBQUMsNkJBQTZCLEVBQUU7d0JBQzNDLElBQUksRUFBRSxXQUFXO3dCQUNqQixNQUFNLEVBQUUsSUFBSTtxQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGFuaW1hdGUsXG4gIHN0YXRlLFxuICBzdHlsZSxcbiAgdHJhbnNpdGlvbixcbiAgdHJpZ2dlcixcbn0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBDZGtBY2NvcmRpb25JdGVtIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2FjY29yZGlvbic7XG5pbXBvcnQgeyBVbmlxdWVTZWxlY3Rpb25EaXNwYXRjaGVyIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7XG4gIEFmdGVyQ29udGVudEluaXQsXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBDb250ZW50Q2hpbGQsXG4gIERpcmVjdGl2ZSxcbiAgSW5wdXQsXG4gIFRlbXBsYXRlUmVmLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBmaWx0ZXIsIHN0YXJ0V2l0aCwgdGFrZSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBBY2NvcmRpb25Db21wb25lbnQgfSBmcm9tICcuLi9hY2NvcmRpb24uY29tcG9uZW50JztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2F1aUFjY29yZGlvbkl0ZW1IZWFkZXJdJyxcbn0pXG5leHBvcnQgY2xhc3MgQWNjb3JkaW9uSXRlbUhlYWRlckRpcmVjdGl2ZSB7fVxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2F1aUFjY29yZGlvbkNvbnRlbnRdJyxcbn0pXG5leHBvcnQgY2xhc3MgQWNjb3JkaW9uSXRlbUNvbnRlbnREaXJlY3RpdmUge31cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F1aS1hY2NvcmRpb24taXRlbScsXG4gIHRlbXBsYXRlVXJsOiAnYWNjb3JkaW9uLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnYWNjb3JkaW9uLWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxuICBhbmltYXRpb25zOiBbXG4gICAgdHJpZ2dlcignZXhwYW5kJywgW1xuICAgICAgc3RhdGUoJyonLCBzdHlsZSh7IGhlaWdodDogMCB9KSksXG4gICAgICBzdGF0ZSgnZXhwYW5kZWQnLCBzdHlsZSh7IGhlaWdodDogJyonIH0pKSxcbiAgICAgIHRyYW5zaXRpb24oJyogPD0+IGV4cGFuZGVkJywgW2FuaW1hdGUoJzAuMXMgZWFzZS1pbi1vdXQnKV0pLFxuICAgIF0pLFxuICBdLFxuICB2aWV3UHJvdmlkZXJzOiBbQWNjb3JkaW9uSXRlbUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEFjY29yZGlvbkl0ZW1Db21wb25lbnRcbiAgZXh0ZW5kcyBDZGtBY2NvcmRpb25JdGVtXG4gIGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdFxue1xuICBASW5wdXQoKVxuICBiYWNrZ3JvdW5kID0gdHJ1ZTtcblxuICBAQ29udGVudENoaWxkKEFjY29yZGlvbkl0ZW1Db250ZW50RGlyZWN0aXZlLCB7XG4gICAgcmVhZDogVGVtcGxhdGVSZWYsXG4gICAgc3RhdGljOiB0cnVlLFxuICB9KVxuICBfbGF6eUNvbnRlbnRUcGw6IFRlbXBsYXRlUmVmPHVua25vd24+O1xuXG4gIGxhenlDb250ZW50VHBsOiBUZW1wbGF0ZVJlZjx1bmtub3duPjtcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVzZWxlc3MtY29uc3RydWN0b3JcbiAgY29uc3RydWN0b3IoXG4gICAgYWNjb3JkaW9uOiBBY2NvcmRpb25Db21wb25lbnQsXG4gICAgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICB1bmlxdWVTZWxlY3Rpb25EaXNwYXRjaGVyOiBVbmlxdWVTZWxlY3Rpb25EaXNwYXRjaGVyLFxuICApIHtcbiAgICBzdXBlcihhY2NvcmRpb24sIGNkciwgdW5pcXVlU2VsZWN0aW9uRGlzcGF0Y2hlcik7XG4gIH1cblxuICBuZ0FmdGVyQ29udGVudEluaXQoKSB7XG4gICAgaWYgKHRoaXMuX2xhenlDb250ZW50VHBsKSB7XG4gICAgICAvLyBSZW5kZXIgdGhlIGNvbnRlbnQgYXMgc29vbiBhcyB0aGUgYWNjb3JkaW9uIGJlY29tZXMgb3Blbi5cbiAgICAgIHRoaXMub3BlbmVkXG4gICAgICAgIC5waXBlKFxuICAgICAgICAgIHN0YXJ0V2l0aChudWxsIGFzIHZvaWQpLFxuICAgICAgICAgIGZpbHRlcigoKSA9PiAhIXRoaXMuZXhwYW5kZWQpLFxuICAgICAgICAgIHRha2UoMSksXG4gICAgICAgIClcbiAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgdGhpcy5sYXp5Q29udGVudFRwbCA9IHRoaXMuX2xhenlDb250ZW50VHBsO1xuICAgICAgICB9KTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJhdWktYWNjb3JkaW9uLWl0ZW1cIj5cbiAgPGRpdiBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbV9faGVhZGVyXCI+XG4gICAgPGJ1dHRvblxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbV9fZXhwYW5kLWJ1dHRvblwiXG4gICAgICBbY2xhc3MuaXNFeHBhbmRlZF09XCJleHBhbmRlZFwiXG4gICAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgICAgKGNsaWNrKT1cInRvZ2dsZSgpXCJcbiAgICA+XG4gICAgICA8YXVpLWljb24gaWNvbj1cImFuZ2xlX3JpZ2h0XCI+PC9hdWktaWNvbj5cbiAgICA8L2J1dHRvbj5cbiAgICA8ZGl2XG4gICAgICBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbV9faGVhZGVyLWNvbnRlbnRcIlxuICAgICAgW2NsYXNzLmF1aS1hY2NvcmRpb24taXRlbV9faGVhZGVyLWNvbnRlbnQtLWV4cGFuZGVkXT1cImV4cGFuZGVkXCJcbiAgICA+XG4gICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbYXVpQWNjb3JkaW9uSXRlbUhlYWRlcl1cIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuICA8ZGl2XG4gICAgKm5nSWY9XCJleHBhbmRlZFwiXG4gICAgY2xhc3M9XCJhdWktYWNjb3JkaW9uLWl0ZW1fX2JvZHlcIlxuICAgIFtpZF09XCJpZFwiXG4gICAgW0BleHBhbmRdPVwiZXhwYW5kZWQgPyAnZXhwYW5kZWQnIDogJ2NvbGxhcHNlZCdcIlxuICA+XG4gICAgPGRpdlxuICAgICAgY2xhc3M9XCJhdWktYWNjb3JkaW9uLWl0ZW1fX2NvbnRlbnRcIlxuICAgICAgW2NsYXNzLmhhc0JhY2tncm91bmRdPVwiYmFja2dyb3VuZFwiXG4gICAgPlxuICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImxhenlDb250ZW50VHBsXCI+PC9uZy10ZW1wbGF0ZT5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FjY29yZGlvbi9hY2NvcmRpb24taXRlbS9hY2NvcmRpb24taXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvYWNjb3JkaW9uL2FjY29yZGlvbi1pdGVtL2FjY29yZGlvbi1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxPQUFPLEVBQ1AsS0FBSyxFQUNMLEtBQUssRUFDTCxVQUFVLEVBQ1YsT0FBTyxHQUNSLE1BQU0scUJBQXFCLENBQUM7QUFDN0IsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFMUQsT0FBTyxFQUVMLHVCQUF1QixFQUV2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLFNBQVMsRUFDVCxLQUFLLEVBQ0wsV0FBVyxFQUNYLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxJQUFJLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7OztBQU8vQyxNQUFNLE9BQU8sNEJBQTRCOzt5SEFBNUIsNEJBQTRCOzZHQUE1Qiw0QkFBNEI7MkZBQTVCLDRCQUE0QjtrQkFIeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsMEJBQTBCO2lCQUNyQzs7QUFLRCxNQUFNLE9BQU8sNkJBQTZCOzswSEFBN0IsNkJBQTZCOzhHQUE3Qiw2QkFBNkI7MkZBQTdCLDZCQUE2QjtrQkFIekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO2lCQUNsQzs7QUFrQkQsTUFBTSxPQUFPLHNCQUNYLFNBQVEsZ0JBQWdCO0lBY3hCLHFFQUFxRTtJQUNyRSxZQUNFLFNBQTZCLEVBQzdCLEdBQXNCLEVBQ3RCLHlCQUFvRDtRQUVwRCxLQUFLLENBQUMsU0FBUyxFQUFFLEdBQUcsRUFBRSx5QkFBeUIsQ0FBQyxDQUFDO1FBaEJuRCxlQUFVLEdBQUcsSUFBSSxDQUFDO0lBaUJsQixDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUN4Qiw0REFBNEQ7WUFDNUQsSUFBSSxDQUFDLE1BQU07aUJBQ1IsSUFBSSxDQUNILFNBQVMsQ0FBQyxJQUFZLENBQUMsRUFDdkIsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQzdCLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FDUjtpQkFDQSxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUM3QyxDQUFDLENBQUMsQ0FBQztTQUNOO0lBQ0gsQ0FBQzs7bUhBckNVLHNCQUFzQjt1R0FBdEIsc0JBQXNCLDZJQU9uQiw2QkFBNkIsMkJBQ25DLFdBQVcsa0VDeERyQixxOEJBaUNBLDRnRkRhaUIsQ0FBQyxzQkFBc0IsQ0FBQyxjQVAzQjtRQUNWLE9BQU8sQ0FBQyxRQUFRLEVBQUU7WUFDaEIsS0FBSyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNoQyxLQUFLLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ3pDLFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUM7U0FDNUQsQ0FBQztLQUNIOzJGQUdVLHNCQUFzQjtrQkFoQmxDLFNBQVM7K0JBQ0Usb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU0saUJBQ2hDLGlCQUFpQixDQUFDLElBQUksdUJBQ2hCLEtBQUssY0FDZDt3QkFDVixPQUFPLENBQUMsUUFBUSxFQUFFOzRCQUNoQixLQUFLLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDOzRCQUNoQyxLQUFLLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDOzRCQUN6QyxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUFDO3lCQUM1RCxDQUFDO3FCQUNILGlCQUNjLHdCQUF3QjtpTEFPdkMsVUFBVTtzQkFEVCxLQUFLO2dCQU9OLGVBQWU7c0JBSmQsWUFBWTt1QkFBQyw2QkFBNkIsRUFBRTt3QkFDM0MsSUFBSSxFQUFFLFdBQVc7d0JBQ2pCLE1BQU0sRUFBRSxJQUFJO3FCQUNiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgYW5pbWF0ZSxcbiAgc3RhdGUsXG4gIHN0eWxlLFxuICB0cmFuc2l0aW9uLFxuICB0cmlnZ2VyLFxufSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcbmltcG9ydCB7IENka0FjY29yZGlvbkl0ZW0gfSBmcm9tICdAYW5ndWxhci9jZGsvYWNjb3JkaW9uJztcbmltcG9ydCB7IFVuaXF1ZVNlbGVjdGlvbkRpc3BhdGNoZXIgfSBmcm9tICdAYW5ndWxhci9jZGsvY29sbGVjdGlvbnMnO1xuaW1wb3J0IHtcbiAgQWZ0ZXJDb250ZW50SW5pdCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZCxcbiAgRGlyZWN0aXZlLFxuICBJbnB1dCxcbiAgVGVtcGxhdGVSZWYsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpbHRlciwgc3RhcnRXaXRoLCB0YWtlIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IEFjY29yZGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL2FjY29yZGlvbi5jb21wb25lbnQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpQWNjb3JkaW9uSXRlbUhlYWRlcl0nLFxufSlcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25JdGVtSGVhZGVyRGlyZWN0aXZlIHt9XG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpQWNjb3JkaW9uQ29udGVudF0nLFxufSlcbmV4cG9ydCBjbGFzcyBBY2NvcmRpb25JdGVtQ29udGVudERpcmVjdGl2ZSB7fVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWFjY29yZGlvbi1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICdhY2NvcmRpb24taXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWydhY2NvcmRpb24taXRlbS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgcHJlc2VydmVXaGl0ZXNwYWNlczogZmFsc2UsXG4gIGFuaW1hdGlvbnM6IFtcbiAgICB0cmlnZ2VyKCdleHBhbmQnLCBbXG4gICAgICBzdGF0ZSgnKicsIHN0eWxlKHsgaGVpZ2h0OiAwIH0pKSxcbiAgICAgIHN0YXRlKCdleHBhbmRlZCcsIHN0eWxlKHsgaGVpZ2h0OiAnKicgfSkpLFxuICAgICAgdHJhbnNpdGlvbignKiA8PT4gZXhwYW5kZWQnLCBbYW5pbWF0ZSgnMC4xcyBlYXNlLWluLW91dCcpXSksXG4gICAgXSksXG4gIF0sXG4gIHZpZXdQcm92aWRlcnM6IFtBY2NvcmRpb25JdGVtQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgQWNjb3JkaW9uSXRlbUNvbXBvbmVudFxuICBleHRlbmRzIENka0FjY29yZGlvbkl0ZW1cbiAgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0XG57XG4gIEBJbnB1dCgpXG4gIGJhY2tncm91bmQgPSB0cnVlO1xuXG4gIEBDb250ZW50Q2hpbGQoQWNjb3JkaW9uSXRlbUNvbnRlbnREaXJlY3RpdmUsIHtcbiAgICByZWFkOiBUZW1wbGF0ZVJlZixcbiAgICBzdGF0aWM6IHRydWUsXG4gIH0pXG4gIF9sYXp5Q29udGVudFRwbDogVGVtcGxhdGVSZWY8dW5rbm93bj47XG5cbiAgbGF6eUNvbnRlbnRUcGw6IFRlbXBsYXRlUmVmPHVua25vd24+O1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdXNlbGVzcy1jb25zdHJ1Y3RvclxuICBjb25zdHJ1Y3RvcihcbiAgICBhY2NvcmRpb246IEFjY29yZGlvbkNvbXBvbmVudCxcbiAgICBjZHI6IENoYW5nZURldGVjdG9yUmVmLFxuICAgIHVuaXF1ZVNlbGVjdGlvbkRpc3BhdGNoZXI6IFVuaXF1ZVNlbGVjdGlvbkRpc3BhdGNoZXIsXG4gICkge1xuICAgIHN1cGVyKGFjY29yZGlvbiwgY2RyLCB1bmlxdWVTZWxlY3Rpb25EaXNwYXRjaGVyKTtcbiAgfVxuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcbiAgICBpZiAodGhpcy5fbGF6eUNvbnRlbnRUcGwpIHtcbiAgICAgIC8vIFJlbmRlciB0aGUgY29udGVudCBhcyBzb29uIGFzIHRoZSBhY2NvcmRpb24gYmVjb21lcyBvcGVuLlxuICAgICAgdGhpcy5vcGVuZWRcbiAgICAgICAgLnBpcGUoXG4gICAgICAgICAgc3RhcnRXaXRoKG51bGwgYXMgdm9pZCksXG4gICAgICAgICAgZmlsdGVyKCgpID0+ICEhdGhpcy5leHBhbmRlZCksXG4gICAgICAgICAgdGFrZSgxKSxcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICB0aGlzLmxhenlDb250ZW50VHBsID0gdGhpcy5fbGF6eUNvbnRlbnRUcGw7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbVwiPlxuICA8ZGl2IGNsYXNzPVwiYXVpLWFjY29yZGlvbi1pdGVtX19oZWFkZXJcIj5cbiAgICA8YnV0dG9uXG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIGNsYXNzPVwiYXVpLWFjY29yZGlvbi1pdGVtX19leHBhbmQtYnV0dG9uXCJcbiAgICAgIFtjbGFzcy5pc0V4cGFuZGVkXT1cImV4cGFuZGVkXCJcbiAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgICAoY2xpY2spPVwidG9nZ2xlKClcIlxuICAgID5cbiAgICAgIDxhdWktaWNvbiBpY29uPVwiYW5nbGVfcmlnaHRcIj48L2F1aS1pY29uPlxuICAgIDwvYnV0dG9uPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwiYXVpLWFjY29yZGlvbi1pdGVtX19oZWFkZXItY29udGVudFwiXG4gICAgICBbY2xhc3MuYXVpLWFjY29yZGlvbi1pdGVtX19oZWFkZXItY29udGVudC0tZXhwYW5kZWRdPVwiZXhwYW5kZWRcIlxuICAgID5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlthdWlBY2NvcmRpb25JdGVtSGVhZGVyXVwiPjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXZcbiAgICAqbmdJZj1cImV4cGFuZGVkXCJcbiAgICBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbV9fYm9keVwiXG4gICAgW2lkXT1cImlkXCJcbiAgICBbQGV4cGFuZF09XCJleHBhbmRlZCA/ICdleHBhbmRlZCcgOiAnY29sbGFwc2VkJ1wiXG4gID5cbiAgICA8ZGl2XG4gICAgICBjbGFzcz1cImF1aS1hY2NvcmRpb24taXRlbV9fY29udGVudFwiXG4gICAgICBbY2xhc3MuaGFzQmFja2dyb3VuZF09XCJiYWNrZ3JvdW5kXCJcbiAgICA+XG4gICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICA8bmctdGVtcGxhdGUgW25nVGVtcGxhdGVPdXRsZXRdPVwibGF6eUNvbnRlbnRUcGxcIj48L25nLXRlbXBsYXRlPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
@@ -1,2 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
1
4
  export * from './index';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxhdWRhLXVpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FsYXVkYS11aS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxhdWRhLXVpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FsYXVkYS11aS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -24,6 +24,7 @@ export class AnchorTreeComponent extends AnchorDirectiveChild {
24
24
  watchLabelsChange() {
25
25
  this.depose$$.next();
26
26
  const cdr = this.injector.get(ChangeDetectorRef);
27
+ // FIXME: Is there any better way to achieve this?
27
28
  combineLatest(this.treeItems.map(({ labelChange }) => labelChange).filter(Boolean))
28
29
  .pipe(debounceTime(0), takeUntil(this.depose$$))
29
30
  .subscribe(() => cdr.markForCheck());
@@ -134,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
134
135
  }], activeId: [{
135
136
  type: Input
136
137
  }] } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../src/anchor/anchor.component.ts","../../../src/anchor/anchor-tree.component.html","../../../src/anchor/anchor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  EMPTY,\n  Subject,\n  combineLatest,\n  fromEvent,\n  of,\n  debounceTime,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs';\n\nimport { buildBem, isTemplateRef, last } from '../utils';\n\nimport { AnchorDirectiveChild } from './anchor.directive';\nimport { AnchorItem, AnchorTreeItem } from './types';\nimport { getAnchorTreeItems } from './utils';\n\nconst bem = buildBem('aui-anchor');\n\n@Component({\n  selector: 'aui-anchor-tree',\n  templateUrl: 'anchor-tree.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorTreeComponent\n  extends AnchorDirectiveChild\n  implements OnDestroy\n{\n  @Input()\n  set treeItems(treeItems) {\n    this._treeItems = treeItems;\n    this.watchLabelsChange();\n  }\n\n  get treeItems() {\n    return this._treeItems;\n  }\n\n  private _treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  @Output()\n  activeIdChange = new EventEmitter<string>();\n\n  bem = bem;\n\n  isTemplateRef = isTemplateRef;\n\n  private readonly depose$$ = new Subject<void>();\n\n  watchLabelsChange() {\n    this.depose$$.next();\n    const cdr = this.injector.get(ChangeDetectorRef);\n    // FIXME: Is there any better way to achieve this?\n    combineLatest(\n      this.treeItems.map(({ labelChange }) => labelChange).filter(Boolean),\n    )\n      .pipe(debounceTime(0), takeUntil(this.depose$$))\n      .subscribe(() => cdr.markForCheck());\n  }\n\n  ngOnDestroy() {\n    this.depose$$.next();\n    this.depose$$.complete();\n  }\n\n  isActive(item: AnchorTreeItem): boolean {\n    return (\n      item.id === this.activeId ||\n      item.children?.some(subItem => this.isActive(subItem))\n    );\n  }\n\n  onItemClick(e: Event, item: AnchorTreeItem) {\n    e.preventDefault();\n\n    if (this.parent.injectId) {\n      const selector = '#' + item.id;\n\n      if (location.hash === selector) {\n        return;\n      }\n\n      history.pushState(\n        null,\n        null,\n        location.pathname + location.search + selector,\n      );\n    }\n\n    item.target.scrollIntoView({ behavior: 'smooth' });\n\n    this.activeIdChange.emit(item.id);\n  }\n\n  trackById(_index: number, item: AnchorTreeItem) {\n    return item.id;\n  }\n}\n\n@Component({\n  selector: 'aui-anchor',\n  templateUrl: 'anchor.component.html',\n  styleUrls: ['anchor.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorComponent\n  extends AnchorDirectiveChild\n  implements AfterViewInit, OnDestroy\n{\n  @Input()\n  get items() {\n    return this._items;\n  }\n\n  set items(items) {\n    this._items = items;\n    this.treeItems = getAnchorTreeItems(items);\n    const anchorId =\n      (this.parent.injectId && location.hash.slice(1)) || this.activeId;\n    const activeItem =\n      (anchorId && items.find(({ id }) => id === anchorId)) || items[0];\n    if (activeItem) {\n      if (this.parent.injectId && this.parent.scrollableEl !== window) {\n        activeItem.target.scrollIntoView();\n      }\n      this.activeId = activeItem.id;\n    }\n  }\n\n  private _items: AnchorItem[];\n\n  @Input()\n  treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  bem = bem;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  constructor(\n    protected override injector: Injector,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    super(injector);\n  }\n\n  ngAfterViewInit() {\n    const { injectId, containerEl, scrollableEl } = this.parent;\n    const pageContentEl = containerEl.closest('.aui-page__content');\n    const paddingTop = pageContentEl\n      ? +getComputedStyle(pageContentEl).paddingTop.slice(0, -2)\n      : 0;\n    fromEvent(scrollableEl, 'scroll')\n      .pipe(\n        debounceTime(100),\n        switchMap(() => {\n          const { scrollTop } =\n            scrollableEl === window\n              ? document.documentElement\n              : (scrollableEl as HTMLElement);\n          const activedItem =\n            this.items.find(\n              ({ target }) =>\n                target.offsetTop +\n                  target.offsetHeight / 2 +\n                  ((scrollableEl === window &&\n                    (target.offsetParent as HTMLElement)?.offsetTop) ||\n                    0) >\n                scrollTop + paddingTop,\n            ) || last(this.items);\n          return activedItem ? of(activedItem) : EMPTY;\n        }),\n        tap(activedItem => {\n          if (activedItem.id) {\n            this.activeId = activedItem.id;\n            this.cdr.markForCheck();\n          }\n        }),\n        debounceTime(100),\n        tap(activedItem => {\n          if (injectId && activedItem.id) {\n            history.replaceState(\n              null,\n              null,\n              location.pathname + location.search + '#' + activedItem.id,\n            );\n          }\n        }),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n}\n","<div\n  [class]=\"bem.element('item')\"\n  [class.active]=\"isActive(item)\"\n  *ngFor=\"let item of treeItems; trackBy: trackById\"\n>\n  <a\n    *ngIf=\"item.label as label\"\n    [href]=\"parent.injectId ? '#' + item.id : undefined\"\n    (click)=\"onItemClick($event, item)\"\n  >\n    <ng-container *ngIf=\"isTemplateRef(label); else plain\">\n      <ng-container\n        *ngTemplateOutlet=\"label; context: item.labelContext\"\n      ></ng-container>\n    </ng-container>\n    <ng-template #plain>\n      {{ item.label }}\n    </ng-template>\n  </a>\n  <aui-anchor-tree\n    *ngIf=\"item.children?.length\"\n    [treeItems]=\"item.children\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n","<div [class]=\"bem.block()\">\n  <aui-anchor-tree\n    [treeItems]=\"treeItems\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../src/anchor/anchor.component.ts","../../../src/anchor/anchor-tree.component.html","../../../src/anchor/anchor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  EMPTY,\n  Subject,\n  combineLatest,\n  fromEvent,\n  of,\n  debounceTime,\n  switchMap,\n  takeUntil,\n  tap,\n} from 'rxjs';\n\nimport { buildBem, isTemplateRef, last } from '../utils';\n\nimport { AnchorDirectiveChild } from './anchor.directive';\nimport { AnchorItem, AnchorTreeItem } from './types';\nimport { getAnchorTreeItems } from './utils';\n\nconst bem = buildBem('aui-anchor');\n\n@Component({\n  selector: 'aui-anchor-tree',\n  templateUrl: 'anchor-tree.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorTreeComponent\n  extends AnchorDirectiveChild\n  implements OnDestroy\n{\n  @Input()\n  set treeItems(treeItems) {\n    this._treeItems = treeItems;\n    this.watchLabelsChange();\n  }\n\n  get treeItems() {\n    return this._treeItems;\n  }\n\n  private _treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  @Output()\n  activeIdChange = new EventEmitter<string>();\n\n  bem = bem;\n\n  isTemplateRef = isTemplateRef;\n\n  private readonly depose$$ = new Subject<void>();\n\n  watchLabelsChange() {\n    this.depose$$.next();\n    const cdr = this.injector.get(ChangeDetectorRef);\n    // FIXME: Is there any better way to achieve this?\n    combineLatest(\n      this.treeItems.map(({ labelChange }) => labelChange).filter(Boolean),\n    )\n      .pipe(debounceTime(0), takeUntil(this.depose$$))\n      .subscribe(() => cdr.markForCheck());\n  }\n\n  ngOnDestroy() {\n    this.depose$$.next();\n    this.depose$$.complete();\n  }\n\n  isActive(item: AnchorTreeItem): boolean {\n    return (\n      item.id === this.activeId ||\n      item.children?.some(subItem => this.isActive(subItem))\n    );\n  }\n\n  onItemClick(e: Event, item: AnchorTreeItem) {\n    e.preventDefault();\n\n    if (this.parent.injectId) {\n      const selector = '#' + item.id;\n\n      if (location.hash === selector) {\n        return;\n      }\n\n      history.pushState(\n        null,\n        null,\n        location.pathname + location.search + selector,\n      );\n    }\n\n    item.target.scrollIntoView({ behavior: 'smooth' });\n\n    this.activeIdChange.emit(item.id);\n  }\n\n  trackById(_index: number, item: AnchorTreeItem) {\n    return item.id;\n  }\n}\n\n@Component({\n  selector: 'aui-anchor',\n  templateUrl: 'anchor.component.html',\n  styleUrls: ['anchor.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnchorComponent\n  extends AnchorDirectiveChild\n  implements AfterViewInit, OnDestroy\n{\n  @Input()\n  get items() {\n    return this._items;\n  }\n\n  set items(items) {\n    this._items = items;\n    this.treeItems = getAnchorTreeItems(items);\n    const anchorId =\n      (this.parent.injectId && location.hash.slice(1)) || this.activeId;\n    const activeItem =\n      (anchorId && items.find(({ id }) => id === anchorId)) || items[0];\n    if (activeItem) {\n      if (this.parent.injectId && this.parent.scrollableEl !== window) {\n        activeItem.target.scrollIntoView();\n      }\n      this.activeId = activeItem.id;\n    }\n  }\n\n  private _items: AnchorItem[];\n\n  @Input()\n  treeItems: AnchorTreeItem[];\n\n  @Input()\n  activeId: string;\n\n  bem = bem;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  constructor(\n    protected override injector: Injector,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    super(injector);\n  }\n\n  ngAfterViewInit() {\n    const { injectId, containerEl, scrollableEl } = this.parent;\n    const pageContentEl = containerEl.closest('.aui-page__content');\n    const paddingTop = pageContentEl\n      ? +getComputedStyle(pageContentEl).paddingTop.slice(0, -2)\n      : 0;\n    fromEvent(scrollableEl, 'scroll')\n      .pipe(\n        debounceTime(100),\n        switchMap(() => {\n          const { scrollTop } =\n            scrollableEl === window\n              ? document.documentElement\n              : (scrollableEl as HTMLElement);\n          const activedItem =\n            this.items.find(\n              ({ target }) =>\n                target.offsetTop +\n                  target.offsetHeight / 2 +\n                  ((scrollableEl === window &&\n                    (target.offsetParent as HTMLElement)?.offsetTop) ||\n                    0) >\n                scrollTop + paddingTop,\n            ) || last(this.items);\n          return activedItem ? of(activedItem) : EMPTY;\n        }),\n        tap(activedItem => {\n          if (activedItem.id) {\n            this.activeId = activedItem.id;\n            this.cdr.markForCheck();\n          }\n        }),\n        debounceTime(100),\n        tap(activedItem => {\n          if (injectId && activedItem.id) {\n            history.replaceState(\n              null,\n              null,\n              location.pathname + location.search + '#' + activedItem.id,\n            );\n          }\n        }),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe();\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n}\n","<div\n  [class]=\"bem.element('item')\"\n  [class.active]=\"isActive(item)\"\n  *ngFor=\"let item of treeItems; trackBy: trackById\"\n>\n  <a\n    *ngIf=\"item.label as label\"\n    [href]=\"parent.injectId ? '#' + item.id : undefined\"\n    (click)=\"onItemClick($event, item)\"\n  >\n    <ng-container *ngIf=\"isTemplateRef(label); else plain\">\n      <ng-container\n        *ngTemplateOutlet=\"label; context: item.labelContext\"\n      ></ng-container>\n    </ng-container>\n    <ng-template #plain>\n      {{ item.label }}\n    </ng-template>\n  </a>\n  <aui-anchor-tree\n    *ngIf=\"item.children?.length\"\n    [treeItems]=\"item.children\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n","<div [class]=\"bem.block()\">\n  <aui-anchor-tree\n    [treeItems]=\"treeItems\"\n    [(activeId)]=\"activeId\"\n  ></aui-anchor-tree>\n</div>\n"]}
@@ -12,7 +12,9 @@ export class BackTopComponent {
12
12
  this.target$$ = new BehaviorSubject(this.target);
13
13
  this.visibilityHeight$$ = new BehaviorSubject(this.visibilityHeight);
14
14
  this.isDisplayed$ = combineLatest([
15
- this.target$$.asObservable().pipe(map(target => this.getTarget(target)), switchMap(target => fromEvent(target, 'scroll').pipe(throttleTime(50, undefined, { leading: true, trailing: true }), map(() => this.getTargetScrollTop(target))))),
15
+ this.target$$.asObservable().pipe(map(target => this.getTarget(target)), switchMap(target => fromEvent(target, 'scroll').pipe(
16
+ // use default scheduler
17
+ throttleTime(50, undefined, { leading: true, trailing: true }), map(() => this.getTargetScrollTop(target))))),
16
18
  this.visibilityHeight$$,
17
19
  ]).pipe(map(([scrollTop, visibilityHeight]) => scrollTop >= visibilityHeight), distinctUntilChanged());
18
20
  }
@@ -62,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
62
64
  }], click: [{
63
65
  type: Output
64
66
  }] } });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFjay10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JhY2stdG9wL2JhY2stdG9wLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9iYWNrLXRvcC9iYWNrLXRvcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLFFBQVEsRUFDUixNQUFNLEVBQ04saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxlQUFlLEVBQ2YsYUFBYSxFQUNiLFNBQVMsRUFDVCxvQkFBb0IsRUFDcEIsR0FBRyxFQUNILFNBQVMsRUFDVCxZQUFZLEdBQ2IsTUFBTSxNQUFNLENBQUM7Ozs7O0FBWWQsTUFBTSxPQUFPLGdCQUFnQjtJQWlDM0IsWUFBeUMsYUFBNEI7UUFBNUIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFYckUsVUFBSyxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFFMUIsc0JBQWlCLEdBQUcsR0FBRyxDQUFDO1FBQ2YsYUFBUSxHQUFHLElBQUksZUFBZSxDQUFhLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4RCx1QkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FDdkQsSUFBSSxDQUFDLGdCQUFnQixDQUN0QixDQUFDO1FBT0YsaUJBQVksR0FBRyxhQUFhLENBQUM7WUFDM0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxJQUFJLENBQy9CLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsRUFDckMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQ2pCLFNBQVMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUU5QixZQUFZLENBQUMsRUFBRSxFQUFFLFNBQVMsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDLEVBQzlELEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FDM0MsQ0FDRixDQUNGO1lBQ0QsSUFBSSxDQUFDLGtCQUFrQjtTQUN4QixDQUFDLENBQUMsSUFBSSxDQUNMLEdBQUcsQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUFFLGdCQUFnQixDQUFDLEVBQUUsRUFBRSxDQUFDLFNBQVMsSUFBSSxnQkFBZ0IsQ0FBQyxFQUNyRSxvQkFBb0IsRUFBRSxDQUN2QixDQUFDO0lBakJzRSxDQUFDO0lBaEN6RSxJQUNJLGdCQUFnQixDQUFDLEdBQVc7UUFDOUIsSUFBSSxDQUFDLGlCQUFpQixHQUFHLEdBQUcsQ0FBQztRQUM3QixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFJLGdCQUFnQjtRQUNsQixPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQztJQUNoQyxDQUFDO0lBRUQsSUFDSSxNQUFNLENBQUMsR0FBZTtRQUN4QixJQUFJLENBQUMsT0FBTyxHQUFHLEdBQUcsQ0FBQztRQUNuQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBSSxNQUFNO1FBQ1IsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3RCLENBQUM7SUFpQ0Qsa0JBQWtCLENBQUMsTUFBd0I7UUFDekMsSUFBSSxNQUFNLEtBQUssTUFBTSxFQUFFO1lBQ3JCLE9BQU8sUUFBUSxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUM7U0FDM0M7UUFDRCxPQUFRLE1BQXNCLENBQUMsU0FBUyxDQUFDO0lBQzNDLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBWTtRQUN0QixJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDNUQsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUFrQjtRQUMxQixNQUFNLFlBQVksR0FDaEIsQ0FBQyxPQUFPLE1BQU0sS0FBSyxRQUFRLElBQUksUUFBUSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM5RCxJQUFJLENBQUMsYUFBYSxFQUFFLGFBQWEsRUFBRSxDQUFDLGFBQWE7WUFDakQsTUFBTSxDQUFDO1FBQ1QsSUFBSSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUM7UUFDbEMsT0FBTyxZQUFZLENBQUM7SUFDdEIsQ0FBQzs7NkdBdkVVLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLHFKQzlCN0IsK01BVUE7MkZEb0JhLGdCQUFnQjtrQkFSNUIsU0FBUzsrQkFDRSxjQUFjLGlCQUdULGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sdUJBQzFCLEtBQUs7OzBCQW1DYixRQUFROzRDQS9CakIsZ0JBQWdCO3NCQURuQixLQUFLO2dCQVdGLE1BQU07c0JBRFQsS0FBSztnQkFXTixLQUFLO3NCQURKLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtTY3JvbGxhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT3B0aW9uYWwsXG4gIE91dHB1dCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQmVoYXZpb3JTdWJqZWN0LFxuICBjb21iaW5lTGF0ZXN0LFxuICBmcm9tRXZlbnQsXG4gIGRpc3RpbmN0VW50aWxDaGFuZ2VkLFxuICBtYXAsXG4gIHN3aXRjaE1hcCxcbiAgdGhyb3R0bGVUaW1lLFxufSBmcm9tICdyeGpzJztcblxudHlwZSBUYXJnZXRUeXBlID0gRWxlbWVudCB8IFdpbmRvdyB8IHN0cmluZztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWJhY2stdG9wJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2JhY2stdG9wLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmFjay10b3AuY29tcG9uZW50LnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBCYWNrVG9wQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgc2V0IHZpc2liaWxpdHlIZWlnaHQodmFsOiBudW1iZXIpIHtcbiAgICB0aGlzLl92aXNpYmlsaXR5SGVpZ2h0ID0gdmFsO1xuICAgIHRoaXMudmlzaWJpbGl0eUhlaWdodCQkLm5leHQodmFsKTtcbiAgfVxuXG4gIGdldCB2aXNpYmlsaXR5SGVpZ2h0KCkge1xuICAgIHJldHVybiB0aGlzLl92aXNpYmlsaXR5SGVpZ2h0O1xuICB9XG5cbiAgQElucHV0KClcbiAgc2V0IHRhcmdldCh2YWw6IFRhcmdldFR5cGUpIHtcbiAgICB0aGlzLl90YXJnZXQgPSB2YWw7XG4gICAgdGhpcy50YXJnZXQkJC5uZXh0KHZhbCk7XG4gIH1cblxuICBnZXQgdGFyZ2V0KCkge1xuICAgIHJldHVybiB0aGlzLl90YXJnZXQ7XG4gIH1cblxuICBAT3V0cHV0KClcbiAgY2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPEV2ZW50PigpO1xuXG4gIHByaXZhdGUgX3Zpc2liaWxpdHlIZWlnaHQgPSA0MDA7XG4gIHByaXZhdGUgcmVhZG9ubHkgdGFyZ2V0JCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFRhcmdldFR5cGU+KHRoaXMudGFyZ2V0KTtcbiAgcHJpdmF0ZSByZWFkb25seSB2aXNpYmlsaXR5SGVpZ2h0JCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PG51bWJlcj4oXG4gICAgdGhpcy52aXNpYmlsaXR5SGVpZ2h0LFxuICApO1xuXG4gIHByaXZhdGUgX3RhcmdldDogVGFyZ2V0VHlwZTtcbiAgcHJpdmF0ZSBfc2Nyb2xsVGFyZ2V0OiBFbGVtZW50IHwgV2luZG93O1xuXG4gIGNvbnN0cnVjdG9yKEBPcHRpb25hbCgpIHByaXZhdGUgcmVhZG9ubHkgY2RrU2Nyb2xsYWJsZTogQ2RrU2Nyb2xsYWJsZSkge31cblxuICBpc0Rpc3BsYXllZCQgPSBjb21iaW5lTGF0ZXN0KFtcbiAgICB0aGlzLnRhcmdldCQkLmFzT2JzZXJ2YWJsZSgpLnBpcGUoXG4gICAgICBtYXAodGFyZ2V0ID0+IHRoaXMuZ2V0VGFyZ2V0KHRhcmdldCkpLFxuICAgICAgc3dpdGNoTWFwKHRhcmdldCA9PlxuICAgICAgICBmcm9tRXZlbnQodGFyZ2V0LCAnc2Nyb2xsJykucGlwZShcbiAgICAgICAgICAvLyB1c2UgZGVmYXVsdCBzY2hlZHVsZXJcbiAgICAgICAgICB0aHJvdHRsZVRpbWUoNTAsIHVuZGVmaW5lZCwgeyBsZWFkaW5nOiB0cnVlLCB0cmFpbGluZzogdHJ1ZSB9KSxcbiAgICAgICAgICBtYXAoKCkgPT4gdGhpcy5nZXRUYXJnZXRTY3JvbGxUb3AodGFyZ2V0KSksXG4gICAgICAgICksXG4gICAgICApLFxuICAgICksXG4gICAgdGhpcy52aXNpYmlsaXR5SGVpZ2h0JCQsXG4gIF0pLnBpcGUoXG4gICAgbWFwKChbc2Nyb2xsVG9wLCB2aXNpYmlsaXR5SGVpZ2h0XSkgPT4gc2Nyb2xsVG9wID49IHZpc2liaWxpdHlIZWlnaHQpLFxuICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksXG4gICk7XG5cbiAgZ2V0VGFyZ2V0U2Nyb2xsVG9wKHRhcmdldDogRWxlbWVudCB8IFdpbmRvdykge1xuICAgIGlmICh0YXJnZXQgPT09IHdpbmRvdykge1xuICAgICAgcmV0dXJuIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zY3JvbGxUb3A7XG4gICAgfVxuICAgIHJldHVybiAodGFyZ2V0IGFzIEhUTUxFbGVtZW50KS5zY3JvbGxUb3A7XG4gIH1cblxuICBoYW5kbGVDbGljayhldmVudDogRXZlbnQpIHtcbiAgICB0aGlzLl9zY3JvbGxUYXJnZXQuc2Nyb2xsVG8oeyB0b3A6IDAsIGJlaGF2aW9yOiAnc21vb3RoJyB9KTtcbiAgICB0aGlzLmNsaWNrLmVtaXQoZXZlbnQpO1xuICB9XG5cbiAgZ2V0VGFyZ2V0KHRhcmdldDogVGFyZ2V0VHlwZSk6IEVsZW1lbnQgfCBXaW5kb3cge1xuICAgIGNvbnN0IHNjcm9sbFRhcmdldCA9XG4gICAgICAodHlwZW9mIHRhcmdldCA9PT0gJ3N0cmluZycgJiYgZG9jdW1lbnQucXVlcnlTZWxlY3Rvcih0YXJnZXQpKSB8fFxuICAgICAgdGhpcy5jZGtTY3JvbGxhYmxlPy5nZXRFbGVtZW50UmVmKCkubmF0aXZlRWxlbWVudCB8fFxuICAgICAgd2luZG93O1xuICAgIHRoaXMuX3Njcm9sbFRhcmdldCA9IHNjcm9sbFRhcmdldDtcbiAgICByZXR1cm4gc2Nyb2xsVGFyZ2V0O1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiYXVpLWJhY2stdG9wXCJcbiAgKGNsaWNrKT1cImhhbmRsZUNsaWNrKCRldmVudClcIlxuICBbY2xhc3Muc2hvd109XCJpc0Rpc3BsYXllZCQgfCBhc3luY1wiXG4+XG4gIDxhdWktaWNvblxuICAgIGljb249XCJiYWNrX3RvcFwiXG4gICAgY2xhc3M9XCJhdWktYmFjay10b3BfX2ljb25cIlxuICA+PC9hdWktaWNvbj5cbjwvZGl2PlxuIl19
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFjay10b3AuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JhY2stdG9wL2JhY2stdG9wLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9iYWNrLXRvcC9iYWNrLXRvcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLFFBQVEsRUFDUixNQUFNLEVBQ04saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxlQUFlLEVBQ2YsYUFBYSxFQUNiLFNBQVMsRUFDVCxvQkFBb0IsRUFDcEIsR0FBRyxFQUNILFNBQVMsRUFDVCxZQUFZLEdBQ2IsTUFBTSxNQUFNLENBQUM7Ozs7O0FBWWQsTUFBTSxPQUFPLGdCQUFnQjtJQWlDM0IsWUFBeUMsYUFBNEI7UUFBNUIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFYckUsVUFBSyxHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7UUFFMUIsc0JBQWlCLEdBQUcsR0FBRyxDQUFDO1FBQ2YsYUFBUSxHQUFHLElBQUksZUFBZSxDQUFhLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4RCx1QkFBa0IsR0FBRyxJQUFJLGVBQWUsQ0FDdkQsSUFBSSxDQUFDLGdCQUFnQixDQUN0QixDQUFDO1FBT0YsaUJBQVksR0FBRyxhQUFhLENBQUM7WUFDM0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxJQUFJLENBQy9CLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsRUFDckMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQ2pCLFNBQVMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUMsSUFBSTtZQUM5Qix3QkFBd0I7WUFDeEIsWUFBWSxDQUFDLEVBQUUsRUFBRSxTQUFTLEVBQUUsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUM5RCxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQzNDLENBQ0YsQ0FDRjtZQUNELElBQUksQ0FBQyxrQkFBa0I7U0FDeEIsQ0FBQyxDQUFDLElBQUksQ0FDTCxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxTQUFTLElBQUksZ0JBQWdCLENBQUMsRUFDckUsb0JBQW9CLEVBQUUsQ0FDdkIsQ0FBQztJQWpCc0UsQ0FBQztJQWhDekUsSUFDSSxnQkFBZ0IsQ0FBQyxHQUFXO1FBQzlCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxHQUFHLENBQUM7UUFDN0IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDbEIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQ0ksTUFBTSxDQUFDLEdBQWU7UUFDeEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7UUFDbkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQUksTUFBTTtRQUNSLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBaUNELGtCQUFrQixDQUFDLE1BQXdCO1FBQ3pDLElBQUksTUFBTSxLQUFLLE1BQU0sRUFBRTtZQUNyQixPQUFPLFFBQVEsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDO1NBQzNDO1FBQ0QsT0FBUSxNQUFzQixDQUFDLFNBQVMsQ0FBQztJQUMzQyxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVk7UUFDdEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQzVELElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFFRCxTQUFTLENBQUMsTUFBa0I7UUFDMUIsTUFBTSxZQUFZLEdBQ2hCLENBQUMsT0FBTyxNQUFNLEtBQUssUUFBUSxJQUFJLFFBQVEsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDOUQsSUFBSSxDQUFDLGFBQWEsRUFBRSxhQUFhLEVBQUUsQ0FBQyxhQUFhO1lBQ2pELE1BQU0sQ0FBQztRQUNULElBQUksQ0FBQyxhQUFhLEdBQUcsWUFBWSxDQUFDO1FBQ2xDLE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7OzZHQXZFVSxnQkFBZ0I7aUdBQWhCLGdCQUFnQixxSkM5QjdCLCtNQVVBOzJGRG9CYSxnQkFBZ0I7a0JBUjVCLFNBQVM7K0JBQ0UsY0FBYyxpQkFHVCxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLHVCQUMxQixLQUFLOzswQkFtQ2IsUUFBUTs0Q0EvQmpCLGdCQUFnQjtzQkFEbkIsS0FBSztnQkFXRixNQUFNO3NCQURULEtBQUs7Z0JBV04sS0FBSztzQkFESixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2RrU2Nyb2xsYWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9wdGlvbmFsLFxuICBPdXRwdXQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIEJlaGF2aW9yU3ViamVjdCxcbiAgY29tYmluZUxhdGVzdCxcbiAgZnJvbUV2ZW50LFxuICBkaXN0aW5jdFVudGlsQ2hhbmdlZCxcbiAgbWFwLFxuICBzd2l0Y2hNYXAsXG4gIHRocm90dGxlVGltZSxcbn0gZnJvbSAncnhqcyc7XG5cbnR5cGUgVGFyZ2V0VHlwZSA9IEVsZW1lbnQgfCBXaW5kb3cgfCBzdHJpbmc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F1aS1iYWNrLXRvcCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9iYWNrLXRvcC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2JhY2stdG9wLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbn0pXG5leHBvcnQgY2xhc3MgQmFja1RvcENvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIHNldCB2aXNpYmlsaXR5SGVpZ2h0KHZhbDogbnVtYmVyKSB7XG4gICAgdGhpcy5fdmlzaWJpbGl0eUhlaWdodCA9IHZhbDtcbiAgICB0aGlzLnZpc2liaWxpdHlIZWlnaHQkJC5uZXh0KHZhbCk7XG4gIH1cblxuICBnZXQgdmlzaWJpbGl0eUhlaWdodCgpIHtcbiAgICByZXR1cm4gdGhpcy5fdmlzaWJpbGl0eUhlaWdodDtcbiAgfVxuXG4gIEBJbnB1dCgpXG4gIHNldCB0YXJnZXQodmFsOiBUYXJnZXRUeXBlKSB7XG4gICAgdGhpcy5fdGFyZ2V0ID0gdmFsO1xuICAgIHRoaXMudGFyZ2V0JCQubmV4dCh2YWwpO1xuICB9XG5cbiAgZ2V0IHRhcmdldCgpIHtcbiAgICByZXR1cm4gdGhpcy5fdGFyZ2V0O1xuICB9XG5cbiAgQE91dHB1dCgpXG4gIGNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcblxuICBwcml2YXRlIF92aXNpYmlsaXR5SGVpZ2h0ID0gNDAwO1xuICBwcml2YXRlIHJlYWRvbmx5IHRhcmdldCQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxUYXJnZXRUeXBlPih0aGlzLnRhcmdldCk7XG4gIHByaXZhdGUgcmVhZG9ubHkgdmlzaWJpbGl0eUhlaWdodCQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxudW1iZXI+KFxuICAgIHRoaXMudmlzaWJpbGl0eUhlaWdodCxcbiAgKTtcblxuICBwcml2YXRlIF90YXJnZXQ6IFRhcmdldFR5cGU7XG4gIHByaXZhdGUgX3Njcm9sbFRhcmdldDogRWxlbWVudCB8IFdpbmRvdztcblxuICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBwcml2YXRlIHJlYWRvbmx5IGNka1Njcm9sbGFibGU6IENka1Njcm9sbGFibGUpIHt9XG5cbiAgaXNEaXNwbGF5ZWQkID0gY29tYmluZUxhdGVzdChbXG4gICAgdGhpcy50YXJnZXQkJC5hc09ic2VydmFibGUoKS5waXBlKFxuICAgICAgbWFwKHRhcmdldCA9PiB0aGlzLmdldFRhcmdldCh0YXJnZXQpKSxcbiAgICAgIHN3aXRjaE1hcCh0YXJnZXQgPT5cbiAgICAgICAgZnJvbUV2ZW50KHRhcmdldCwgJ3Njcm9sbCcpLnBpcGUoXG4gICAgICAgICAgLy8gdXNlIGRlZmF1bHQgc2NoZWR1bGVyXG4gICAgICAgICAgdGhyb3R0bGVUaW1lKDUwLCB1bmRlZmluZWQsIHsgbGVhZGluZzogdHJ1ZSwgdHJhaWxpbmc6IHRydWUgfSksXG4gICAgICAgICAgbWFwKCgpID0+IHRoaXMuZ2V0VGFyZ2V0U2Nyb2xsVG9wKHRhcmdldCkpLFxuICAgICAgICApLFxuICAgICAgKSxcbiAgICApLFxuICAgIHRoaXMudmlzaWJpbGl0eUhlaWdodCQkLFxuICBdKS5waXBlKFxuICAgIG1hcCgoW3Njcm9sbFRvcCwgdmlzaWJpbGl0eUhlaWdodF0pID0+IHNjcm9sbFRvcCA+PSB2aXNpYmlsaXR5SGVpZ2h0KSxcbiAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpLFxuICApO1xuXG4gIGdldFRhcmdldFNjcm9sbFRvcCh0YXJnZXQ6IEVsZW1lbnQgfCBXaW5kb3cpIHtcbiAgICBpZiAodGFyZ2V0ID09PSB3aW5kb3cpIHtcbiAgICAgIHJldHVybiBkb2N1bWVudC5kb2N1bWVudEVsZW1lbnQuc2Nyb2xsVG9wO1xuICAgIH1cbiAgICByZXR1cm4gKHRhcmdldCBhcyBIVE1MRWxlbWVudCkuc2Nyb2xsVG9wO1xuICB9XG5cbiAgaGFuZGxlQ2xpY2soZXZlbnQ6IEV2ZW50KSB7XG4gICAgdGhpcy5fc2Nyb2xsVGFyZ2V0LnNjcm9sbFRvKHsgdG9wOiAwLCBiZWhhdmlvcjogJ3Ntb290aCcgfSk7XG4gICAgdGhpcy5jbGljay5lbWl0KGV2ZW50KTtcbiAgfVxuXG4gIGdldFRhcmdldCh0YXJnZXQ6IFRhcmdldFR5cGUpOiBFbGVtZW50IHwgV2luZG93IHtcbiAgICBjb25zdCBzY3JvbGxUYXJnZXQgPVxuICAgICAgKHR5cGVvZiB0YXJnZXQgPT09ICdzdHJpbmcnICYmIGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IodGFyZ2V0KSkgfHxcbiAgICAgIHRoaXMuY2RrU2Nyb2xsYWJsZT8uZ2V0RWxlbWVudFJlZigpLm5hdGl2ZUVsZW1lbnQgfHxcbiAgICAgIHdpbmRvdztcbiAgICB0aGlzLl9zY3JvbGxUYXJnZXQgPSBzY3JvbGxUYXJnZXQ7XG4gICAgcmV0dXJuIHNjcm9sbFRhcmdldDtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cImF1aS1iYWNrLXRvcFwiXG4gIChjbGljayk9XCJoYW5kbGVDbGljaygkZXZlbnQpXCJcbiAgW2NsYXNzLnNob3ddPVwiaXNEaXNwbGF5ZWQkIHwgYXN5bmNcIlxuPlxuICA8YXVpLWljb25cbiAgICBpY29uPVwiYmFja190b3BcIlxuICAgIGNsYXNzPVwiYXVpLWJhY2stdG9wX19pY29uXCJcbiAgPjwvYXVpLWljb24+XG48L2Rpdj5cbiJdfQ==
@@ -37,6 +37,7 @@ export class ButtonComponent {
37
37
  return this._size;
38
38
  }
39
39
  set size(val) {
40
+ // when change from other size to default
40
41
  if (!val) {
41
42
  val = ComponentSize.Medium;
42
43
  }
@@ -118,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
118
119
  }], square: [{
119
120
  type: Input
120
121
  }] } });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../src/button/button.component.ts","../../../src/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { ComponentSize } from '../types';\n\nimport { ButtonType } from './button.types';\n\nconst prefix = 'aui-button--';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'button[aui-button]',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class ButtonComponent implements OnDestroy {\n  @Input('aui-button')\n  get type() {\n    return this._type;\n  }\n\n  set type(val) {\n    if (!val || val === this._type) {\n      return;\n    }\n    this.renderer.removeClass(this.el.nativeElement, prefix + this._type);\n    this.renderer.addClass(this.el.nativeElement, prefix + val);\n    this._type = val;\n  }\n\n  @Input()\n  get size() {\n    return this._size;\n  }\n\n  set size(val) {\n    // when change from other size to default\n    if (!val) {\n      val = ComponentSize.Medium;\n    }\n    if (this._size === val) {\n      return;\n    }\n    this.renderer.removeClass(this.el.nativeElement, prefix + this._size);\n    this.renderer.addClass(this.el.nativeElement, prefix + val);\n    this._size = val;\n  }\n\n  @Input()\n  get plain() {\n    return this._plain;\n  }\n\n  set plain(val) {\n    if (this._plain === val) {\n      return;\n    }\n    this.switchAssertClass('isPlain', val);\n    this._plain = val;\n  }\n\n  @Input()\n  get loading() {\n    return this._loading;\n  }\n\n  set loading(val) {\n    if (this._loading === val) {\n      return;\n    }\n    this.switchAssertClass('isLoading', val);\n    this._loading = val;\n  }\n\n  @Input()\n  get round() {\n    return this._round;\n  }\n\n  set round(val) {\n    if (this._round === val) {\n      return;\n    }\n    this.switchAssertClass('isRound', val);\n    this._round = val;\n  }\n\n  @Input()\n  get square() {\n    return this._square;\n  }\n\n  set square(val) {\n    if (this._square === val) {\n      return;\n    }\n    this.switchAssertClass('isSquare', val);\n    this._square = val;\n  }\n\n  private _type: ButtonType = ButtonType.Default;\n  private _size: ComponentSize = ComponentSize.Medium;\n  private _plain = false;\n  private _loading = false;\n  private _round = false;\n  private _square = false;\n\n  constructor(\n    private readonly el: ElementRef,\n    private readonly renderer: Renderer2,\n    private readonly focusMonitor: FocusMonitor,\n  ) {\n    this.renderer.addClass(this.el.nativeElement, 'aui-button');\n    this.renderer.addClass(this.el.nativeElement, prefix + this.type);\n    this.renderer.addClass(this.el.nativeElement, prefix + this.size);\n\n    this.focusMonitor.monitor(this.el.nativeElement, false);\n  }\n\n  ngOnDestroy() {\n    this.focusMonitor.stopMonitoring(this.el.nativeElement);\n  }\n\n  private switchAssertClass(className: string, val: boolean) {\n    if (val) {\n      this.renderer.addClass(this.el.nativeElement, className);\n    } else {\n      this.renderer.removeClass(this.el.nativeElement, className);\n    }\n  }\n}\n","<span class=\"aui-button__content\"><ng-content></ng-content></span>\n<aui-icon\n  *ngIf=\"loading\"\n  class=\"aui-button__spinner\"\n  icon=\"spinner\"\n></aui-icon>\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../src/button/button.component.ts","../../../src/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  Renderer2,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { ComponentSize } from '../types';\n\nimport { ButtonType } from './button.types';\n\nconst prefix = 'aui-button--';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'button[aui-button]',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class ButtonComponent implements OnDestroy {\n  @Input('aui-button')\n  get type() {\n    return this._type;\n  }\n\n  set type(val) {\n    if (!val || val === this._type) {\n      return;\n    }\n    this.renderer.removeClass(this.el.nativeElement, prefix + this._type);\n    this.renderer.addClass(this.el.nativeElement, prefix + val);\n    this._type = val;\n  }\n\n  @Input()\n  get size() {\n    return this._size;\n  }\n\n  set size(val) {\n    // when change from other size to default\n    if (!val) {\n      val = ComponentSize.Medium;\n    }\n    if (this._size === val) {\n      return;\n    }\n    this.renderer.removeClass(this.el.nativeElement, prefix + this._size);\n    this.renderer.addClass(this.el.nativeElement, prefix + val);\n    this._size = val;\n  }\n\n  @Input()\n  get plain() {\n    return this._plain;\n  }\n\n  set plain(val) {\n    if (this._plain === val) {\n      return;\n    }\n    this.switchAssertClass('isPlain', val);\n    this._plain = val;\n  }\n\n  @Input()\n  get loading() {\n    return this._loading;\n  }\n\n  set loading(val) {\n    if (this._loading === val) {\n      return;\n    }\n    this.switchAssertClass('isLoading', val);\n    this._loading = val;\n  }\n\n  @Input()\n  get round() {\n    return this._round;\n  }\n\n  set round(val) {\n    if (this._round === val) {\n      return;\n    }\n    this.switchAssertClass('isRound', val);\n    this._round = val;\n  }\n\n  @Input()\n  get square() {\n    return this._square;\n  }\n\n  set square(val) {\n    if (this._square === val) {\n      return;\n    }\n    this.switchAssertClass('isSquare', val);\n    this._square = val;\n  }\n\n  private _type: ButtonType = ButtonType.Default;\n  private _size: ComponentSize = ComponentSize.Medium;\n  private _plain = false;\n  private _loading = false;\n  private _round = false;\n  private _square = false;\n\n  constructor(\n    private readonly el: ElementRef,\n    private readonly renderer: Renderer2,\n    private readonly focusMonitor: FocusMonitor,\n  ) {\n    this.renderer.addClass(this.el.nativeElement, 'aui-button');\n    this.renderer.addClass(this.el.nativeElement, prefix + this.type);\n    this.renderer.addClass(this.el.nativeElement, prefix + this.size);\n\n    this.focusMonitor.monitor(this.el.nativeElement, false);\n  }\n\n  ngOnDestroy() {\n    this.focusMonitor.stopMonitoring(this.el.nativeElement);\n  }\n\n  private switchAssertClass(className: string, val: boolean) {\n    if (val) {\n      this.renderer.addClass(this.el.nativeElement, className);\n    } else {\n      this.renderer.removeClass(this.el.nativeElement, className);\n    }\n  }\n}\n","<span class=\"aui-button__content\"><ng-content></ng-content></span>\n<aui-icon\n  *ngIf=\"loading\"\n  class=\"aui-button__spinner\"\n  icon=\"spinner\"\n></aui-icon>\n"]}
@@ -6,8 +6,17 @@ export const ButtonType = {
6
6
  Danger: 'danger',
7
7
  Text: 'text',
8
8
  Inline: 'inline',
9
+ /**
10
+ * represents default internally, @link https://github.com/angular/vscode-ng-language-service/issues/1147
11
+ */
9
12
  Empty: '',
13
+ /**
14
+ * @deprecated use `ButtonType.Danger` instead
15
+ */
10
16
  Error: 'danger',
17
+ /**
18
+ * @deprecated use `ButtonType.Default` instead
19
+ */
11
20
  Info: 'default',
12
21
  };
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2J1dHRvbi9idXR0b24udHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLElBQUksRUFBRSxNQUFNO0lBQ1osTUFBTSxFQUFFLFFBQVE7SUFJaEIsS0FBSyxFQUFFLEVBQUU7SUFJVCxLQUFLLEVBQUUsUUFBUTtJQUlmLElBQUksRUFBRSxTQUFTO0NBQ1AsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZhbHVlT2YgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBCdXR0b25UeXBlID0ge1xuICBEZWZhdWx0OiAnZGVmYXVsdCcsXG4gIFByaW1hcnk6ICdwcmltYXJ5JyxcbiAgU3VjY2VzczogJ3N1Y2Nlc3MnLFxuICBXYXJuaW5nOiAnd2FybmluZycsXG4gIERhbmdlcjogJ2RhbmdlcicsXG4gIFRleHQ6ICd0ZXh0JyxcbiAgSW5saW5lOiAnaW5saW5lJyxcbiAgLyoqXG4gICAqIHJlcHJlc2VudHMgZGVmYXVsdCBpbnRlcm5hbGx5LCBAbGluayBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci92c2NvZGUtbmctbGFuZ3VhZ2Utc2VydmljZS9pc3N1ZXMvMTE0N1xuICAgKi9cbiAgRW1wdHk6ICcnLFxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgdXNlIGBCdXR0b25UeXBlLkRhbmdlcmAgaW5zdGVhZFxuICAgKi9cbiAgRXJyb3I6ICdkYW5nZXInLFxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgdXNlIGBCdXR0b25UeXBlLkRlZmF1bHRgIGluc3RlYWRcbiAgICovXG4gIEluZm86ICdkZWZhdWx0Jyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCB0eXBlIEJ1dHRvblR5cGUgPSBWYWx1ZU9mPHR5cGVvZiBCdXR0b25UeXBlPjtcbiJdfQ==
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2J1dHRvbi9idXR0b24udHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLElBQUksRUFBRSxNQUFNO0lBQ1osTUFBTSxFQUFFLFFBQVE7SUFDaEI7O09BRUc7SUFDSCxLQUFLLEVBQUUsRUFBRTtJQUNUOztPQUVHO0lBQ0gsS0FBSyxFQUFFLFFBQVE7SUFDZjs7T0FFRztJQUNILElBQUksRUFBRSxTQUFTO0NBQ1AsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZhbHVlT2YgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBjb25zdCBCdXR0b25UeXBlID0ge1xuICBEZWZhdWx0OiAnZGVmYXVsdCcsXG4gIFByaW1hcnk6ICdwcmltYXJ5JyxcbiAgU3VjY2VzczogJ3N1Y2Nlc3MnLFxuICBXYXJuaW5nOiAnd2FybmluZycsXG4gIERhbmdlcjogJ2RhbmdlcicsXG4gIFRleHQ6ICd0ZXh0JyxcbiAgSW5saW5lOiAnaW5saW5lJyxcbiAgLyoqXG4gICAqIHJlcHJlc2VudHMgZGVmYXVsdCBpbnRlcm5hbGx5LCBAbGluayBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci92c2NvZGUtbmctbGFuZ3VhZ2Utc2VydmljZS9pc3N1ZXMvMTE0N1xuICAgKi9cbiAgRW1wdHk6ICcnLFxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgdXNlIGBCdXR0b25UeXBlLkRhbmdlcmAgaW5zdGVhZFxuICAgKi9cbiAgRXJyb3I6ICdkYW5nZXInLFxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgdXNlIGBCdXR0b25UeXBlLkRlZmF1bHRgIGluc3RlYWRcbiAgICovXG4gIEluZm86ICdkZWZhdWx0Jyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCB0eXBlIEJ1dHRvblR5cGUgPSBWYWx1ZU9mPHR5cGVvZiBCdXR0b25UeXBlPjtcbiJdfQ==
@@ -6,6 +6,7 @@ export const YEAR = 'year';
6
6
  export const HOUR = 'hour';
7
7
  export const MINUTE = 'minute';
8
8
  export const SECOND = 'second';
9
+ // 根据日期类型,分为年,月,日
9
10
  export var DatePickerType;
10
11
  (function (DatePickerType) {
11
12
  DatePickerType["Day"] = "date";
@@ -28,4 +29,4 @@ export const DATE_NAV_RANGES = [
28
29
  DateNavRange.Year,
29
30
  DateNavRange.Month,
30
31
  ];
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZGF0ZS1waWNrZXIvY2FsZW5kYXIvY29uc3RhbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRW5ELE1BQU0sQ0FBQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUM7QUFDM0IsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQztBQUN6QixNQUFNLENBQUMsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDO0FBQzdCLE1BQU0sQ0FBQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUM7QUFDM0IsTUFBTSxDQUFDLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQztBQUMzQixNQUFNLENBQUMsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDO0FBQy9CLE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUM7QUFHL0IsTUFBTSxDQUFOLElBQVksY0FJWDtBQUpELFdBQVksY0FBYztJQUN4Qiw4QkFBWSxDQUFBO0lBQ1osaUNBQWUsQ0FBQTtJQUNmLCtCQUFhLENBQUE7QUFDZixDQUFDLEVBSlcsY0FBYyxLQUFkLGNBQWMsUUFJekI7QUFFRCxNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxDQUFDLENBQUM7QUFDMUMsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsQ0FBQyxDQUFDO0FBRXZDLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLENBQUMsQ0FBQztBQUN6QyxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLENBQUM7QUFFdEMsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsQ0FBQyxDQUFDO0FBQ3hDLE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQUMsQ0FBQztBQUVyQyxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsY0FBYyxDQUFDLElBQUk7SUFDbkIsY0FBYyxDQUFDLEtBQUs7SUFDcEIsY0FBYyxDQUFDLEdBQUc7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRztJQUM3QixZQUFZLENBQUMsTUFBTTtJQUNuQixZQUFZLENBQUMsSUFBSTtJQUNqQixZQUFZLENBQUMsS0FBSztDQUNuQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGF0ZU5hdlJhbmdlIH0gZnJvbSAnLi4vZGF0ZS1waWNrZXIudHlwZSc7XG5cbmV4cG9ydCBjb25zdCBEQVRFID0gJ2RhdGUnO1xuZXhwb3J0IGNvbnN0IERBWSA9ICdkYXknO1xuZXhwb3J0IGNvbnN0IE1PTlRIID0gJ21vbnRoJztcbmV4cG9ydCBjb25zdCBZRUFSID0gJ3llYXInO1xuZXhwb3J0IGNvbnN0IEhPVVIgPSAnaG91cic7XG5leHBvcnQgY29uc3QgTUlOVVRFID0gJ21pbnV0ZSc7XG5leHBvcnQgY29uc3QgU0VDT05EID0gJ3NlY29uZCc7XG5cbi8vIOagueaNruaXpeacn+exu+Wei++8jOWIhuS4uuW5tO+8jOaciO+8jOaXpVxuZXhwb3J0IGVudW0gRGF0ZVBpY2tlclR5cGUge1xuICBEYXkgPSAnZGF0ZScsXG4gIE1vbnRoID0gJ21vbnRoJyxcbiAgWWVhciA9ICd5ZWFyJyxcbn1cblxuZXhwb3J0IGNvbnN0IE1PTlRIX1BBTkVMX0NPTFVNTl9DT1VOVCA9IDM7XG5leHBvcnQgY29uc3QgTU9OVEhfUEFORUxfUk9XX0NPVU5UID0gNDtcblxuZXhwb3J0IGNvbnN0IFlFQVJfUEFORUxfQ09MVU1OX0NPVU5UID0gMztcbmV4cG9ydCBjb25zdCBZRUFSX1BBTkVMX1JPV19DT1VOVCA9IDQ7XG5cbmV4cG9ydCBjb25zdCBEQVlfUEFORUxfQ09MVU1OX0NPVU5UID0gNztcbmV4cG9ydCBjb25zdCBEQVlfUEFORUxfUk9XX0NPVU5UID0gNjtcblxuZXhwb3J0IGNvbnN0IERBVEVfVFlQRVMgPSBbXG4gIERhdGVQaWNrZXJUeXBlLlllYXIsXG4gIERhdGVQaWNrZXJUeXBlLk1vbnRoLFxuICBEYXRlUGlja2VyVHlwZS5EYXksXG5dO1xuXG5leHBvcnQgY29uc3QgREFURV9OQVZfUkFOR0VTID0gW1xuICBEYXRlTmF2UmFuZ2UuRGVjYWRlLFxuICBEYXRlTmF2UmFuZ2UuWWVhcixcbiAgRGF0ZU5hdlJhbmdlLk1vbnRoLFxuXTtcbiJdfQ==
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZGF0ZS1waWNrZXIvY2FsZW5kYXIvY29uc3RhbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRW5ELE1BQU0sQ0FBQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUM7QUFDM0IsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQztBQUN6QixNQUFNLENBQUMsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDO0FBQzdCLE1BQU0sQ0FBQyxNQUFNLElBQUksR0FBRyxNQUFNLENBQUM7QUFDM0IsTUFBTSxDQUFDLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQztBQUMzQixNQUFNLENBQUMsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDO0FBQy9CLE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUM7QUFFL0IsaUJBQWlCO0FBQ2pCLE1BQU0sQ0FBTixJQUFZLGNBSVg7QUFKRCxXQUFZLGNBQWM7SUFDeEIsOEJBQVksQ0FBQTtJQUNaLGlDQUFlLENBQUE7SUFDZiwrQkFBYSxDQUFBO0FBQ2YsQ0FBQyxFQUpXLGNBQWMsS0FBZCxjQUFjLFFBSXpCO0FBRUQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcsQ0FBQyxDQUFDO0FBQzFDLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLENBQUMsQ0FBQztBQUV2QyxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLENBQUM7QUFDekMsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxDQUFDO0FBRXRDLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsQ0FBQztBQUN4QyxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxDQUFDLENBQUM7QUFFckMsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLGNBQWMsQ0FBQyxJQUFJO0lBQ25CLGNBQWMsQ0FBQyxLQUFLO0lBQ3BCLGNBQWMsQ0FBQyxHQUFHO0NBQ25CLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUc7SUFDN0IsWUFBWSxDQUFDLE1BQU07SUFDbkIsWUFBWSxDQUFDLElBQUk7SUFDakIsWUFBWSxDQUFDLEtBQUs7Q0FDbkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERhdGVOYXZSYW5nZSB9IGZyb20gJy4uL2RhdGUtcGlja2VyLnR5cGUnO1xuXG5leHBvcnQgY29uc3QgREFURSA9ICdkYXRlJztcbmV4cG9ydCBjb25zdCBEQVkgPSAnZGF5JztcbmV4cG9ydCBjb25zdCBNT05USCA9ICdtb250aCc7XG5leHBvcnQgY29uc3QgWUVBUiA9ICd5ZWFyJztcbmV4cG9ydCBjb25zdCBIT1VSID0gJ2hvdXInO1xuZXhwb3J0IGNvbnN0IE1JTlVURSA9ICdtaW51dGUnO1xuZXhwb3J0IGNvbnN0IFNFQ09ORCA9ICdzZWNvbmQnO1xuXG4vLyDmoLnmja7ml6XmnJ/nsbvlnovvvIzliIbkuLrlubTvvIzmnIjvvIzml6VcbmV4cG9ydCBlbnVtIERhdGVQaWNrZXJUeXBlIHtcbiAgRGF5ID0gJ2RhdGUnLFxuICBNb250aCA9ICdtb250aCcsXG4gIFllYXIgPSAneWVhcicsXG59XG5cbmV4cG9ydCBjb25zdCBNT05USF9QQU5FTF9DT0xVTU5fQ09VTlQgPSAzO1xuZXhwb3J0IGNvbnN0IE1PTlRIX1BBTkVMX1JPV19DT1VOVCA9IDQ7XG5cbmV4cG9ydCBjb25zdCBZRUFSX1BBTkVMX0NPTFVNTl9DT1VOVCA9IDM7XG5leHBvcnQgY29uc3QgWUVBUl9QQU5FTF9ST1dfQ09VTlQgPSA0O1xuXG5leHBvcnQgY29uc3QgREFZX1BBTkVMX0NPTFVNTl9DT1VOVCA9IDc7XG5leHBvcnQgY29uc3QgREFZX1BBTkVMX1JPV19DT1VOVCA9IDY7XG5cbmV4cG9ydCBjb25zdCBEQVRFX1RZUEVTID0gW1xuICBEYXRlUGlja2VyVHlwZS5ZZWFyLFxuICBEYXRlUGlja2VyVHlwZS5Nb250aCxcbiAgRGF0ZVBpY2tlclR5cGUuRGF5LFxuXTtcblxuZXhwb3J0IGNvbnN0IERBVEVfTkFWX1JBTkdFUyA9IFtcbiAgRGF0ZU5hdlJhbmdlLkRlY2FkZSxcbiAgRGF0ZU5hdlJhbmdlLlllYXIsXG4gIERhdGVOYXZSYW5nZS5Nb250aCxcbl07XG4iXX0=
@@ -34,17 +34,21 @@ export class CalendarHeaderComponent {
34
34
  get headerRange() {
35
35
  return calcRangeValue(this.dateNavRange, this.anchor);
36
36
  }
37
+ // maxAvail > current date :right btn hide
38
+ // minAvail > current date :left btn hide
37
39
  shouldShowNav(type, side) {
38
40
  const availValue = (side === Side.Left ? this._minAvail : this._maxAvail)?.clone();
39
41
  if (!availValue) {
40
42
  return true;
41
43
  }
44
+ // 对于年的判别,2014-5-1至2015-6-1日,仍当展示按钮
42
45
  const constrainDate = [DateNavRange.Month, DateNavRange.Year].includes(type)
43
46
  ? availValue.add(side === Side.Left ? 1 : -1, type)
44
47
  : availValue;
45
48
  return (this.compareNavValue(type, constrainDate, this.anchor) ===
46
49
  (side === Side.Left ? -1 : 1));
47
50
  }
51
+ // @return isBetween|isEqual:0, isBefore:-1,isAfter:1
48
52
  compareNavValue(type, constrain, anchor) {
49
53
  const range = calcRangeValue(type, anchor);
50
54
  const constrainValue = constrain;
@@ -96,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
96
100
  }], anchorChange: [{
97
101
  type: Output
98
102
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/header/component.ts","../../../../../src/date-picker/calendar/header/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { buildBem } from '../../../utils';\nimport {\n  CalendarHeaderRange,\n  DateNavRange,\n  Side,\n} from '../../date-picker.type';\nimport { MONTH, YEAR } from '../constant';\nimport { calcRangeValue } from '../util';\n\nconst bem = buildBem('aui-calendar-header');\n\n@Component({\n  selector: 'aui-calendar-header',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CalendarHeaderComponent {\n  @Input()\n  dateNavRange = DateNavRange.Month;\n\n  @Input()\n  anchor = dayjs();\n\n  @Input()\n  maxAvail?: ConfigType;\n\n  private get _maxAvail() {\n    return this.maxAvail ? dayjs(this.maxAvail) : null;\n  }\n\n  @Input()\n  minAvail?: ConfigType;\n\n  private get _minAvail() {\n    return this.minAvail ? dayjs(this.minAvail) : null;\n  }\n\n  @Output()\n  navRangeChange = new EventEmitter<DateNavRange>();\n\n  @Output()\n  anchorChange = new EventEmitter<Dayjs>();\n\n  get headerRange(): CalendarHeaderRange {\n    return calcRangeValue(this.dateNavRange, this.anchor);\n  }\n\n  bem = bem;\n\n  DateNavRange = DateNavRange;\n\n  // maxAvail > current date ：right btn hide\n  // minAvail > current date ：left btn hide\n  shouldShowNav(type: DateNavRange, side: Side) {\n    const availValue = (\n      side === Side.Left ? this._minAvail : this._maxAvail\n    )?.clone();\n    if (!availValue) {\n      return true;\n    }\n    // 对于年的判别，2014-5-1至2015-6-1日，仍当展示按钮\n    const constrainDate = [DateNavRange.Month, DateNavRange.Year].includes(type)\n      ? availValue.add(side === Side.Left ? 1 : -1, type as 'month' | 'year')\n      : availValue;\n    return (\n      this.compareNavValue(type, constrainDate, this.anchor) ===\n      (side === Side.Left ? -1 : 1)\n    );\n  }\n\n  // @return isBetween|isEqual:0, isBefore:-1,isAfter:1\n  compareNavValue(type: DateNavRange, constrain: Dayjs, anchor: Dayjs) {\n    const range = calcRangeValue(type, anchor);\n    const constrainValue = constrain;\n    if (type === DateNavRange.Decade) {\n      if (constrainValue.isBetween(range.start, range.end, YEAR)) {\n        return 0;\n      }\n      return constrainValue.isBefore(range.start) ? -1 : 1;\n    }\n    return constrainValue.isSame(range.start, MONTH)\n      ? 0\n      : constrainValue.isBefore(range.start, MONTH)\n      ? -1\n      : 1;\n  }\n\n  navHead(range: DateNavRange, value: number) {\n    let anchor: Dayjs;\n    switch (range) {\n      case DateNavRange.Month: {\n        anchor = this.anchor.add(value, MONTH);\n        break;\n      }\n      case DateNavRange.Year: {\n        anchor = this.anchor.add(value, YEAR);\n        break;\n      }\n      case DateNavRange.Decade:\n        anchor = this.anchor.add(value, YEAR);\n        break;\n    }\n    this.anchorChange.next(anchor);\n  }\n\n  clickNav = (range: DateNavRange) => {\n    if (![DateNavRange.Month, DateNavRange.Year].includes(range)) {\n      return;\n    }\n    this.navRangeChange.next(\n      range === DateNavRange.Month ? DateNavRange.Year : DateNavRange.Decade,\n    );\n  };\n}\n","<div [class]=\"bem.element('container')\">\n  <div>\n    <ng-container\n      *ngIf=\"dateNavRange !== DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"yearControl\"\n      [ngTemplateOutletContext]=\"{ side: 'left' }\"\n    ></ng-container>\n\n    <ng-container\n      *ngIf=\"dateNavRange === DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"decadeControl\"\n      [ngTemplateOutletContext]=\"{ side: 'left' }\"\n    ></ng-container>\n  </div>\n  <!-- 内容区 -->\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Month\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    <a\n      href=\"javascript:;\"\n      (click)=\"clickNav(DateNavRange.Year)\"\n    >\n      {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n    </a>\n    <a\n      href=\"javascript:;\"\n      (click)=\"clickNav(DateNavRange.Month)\"\n    >\n      {{ headerRange?.start?.month() + 1 }}{{ 'month_suffix' | auiI18n }}\n    </a>\n  </span>\n\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Year\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    <a\n      href=\"javascript:;\"\n      (click)=\"clickNav(DateNavRange.Year)\"\n    >\n      {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n    </a>\n  </span>\n\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Decade\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    {{ headerRange?.start.year() }} - {{ headerRange?.end?.year() }}\n  </span>\n\n  <div [class]=\"bem.element('nav-action')\">\n    <ng-container\n      *ngIf=\"dateNavRange !== DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"yearControl\"\n      [ngTemplateOutletContext]=\"{ side: 'right' }\"\n    ></ng-container>\n\n    <ng-container\n      *ngIf=\"dateNavRange === DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"decadeControl\"\n      [ngTemplateOutletContext]=\"{ side: 'right' }\"\n    ></ng-container>\n  </div>\n</div>\n\n<ng-template\n  #yearControl\n  let-side=\"side\"\n>\n  <span class=\"action-bar\">\n    <button\n      aui-button=\"text\"\n      *ngIf=\"side === 'right'\"\n      [class.hidden]=\"\n        !shouldShowNav(DateNavRange.Month, side) ||\n        dateNavRange !== DateNavRange.Month\n      \"\n      (click)=\"navHead(DateNavRange.Month, 1)\"\n    >\n      <aui-icon icon=\"angle_right\"></aui-icon>\n    </button>\n    <button\n      aui-button=\"text\"\n      (click)=\"navHead(DateNavRange.Year, side === 'left' ? -1 : 1)\"\n      [class.hidden]=\"!shouldShowNav(DateNavRange.Year, side)\"\n    >\n      <aui-icon\n        [icon]=\"side === 'left' ? 'angle_double_left' : 'angle_double_right'\"\n      ></aui-icon>\n    </button>\n    <button\n      aui-button=\"text\"\n      *ngIf=\"side === 'left'\"\n      [class.hidden]=\"\n        !shouldShowNav(DateNavRange.Month, side) ||\n        dateNavRange !== DateNavRange.Month\n      \"\n      (click)=\"navHead(DateNavRange.Month, -1)\"\n    >\n      <aui-icon icon=\"angle_left\"></aui-icon>\n    </button>\n  </span>\n</ng-template>\n\n<ng-template\n  #decadeControl\n  let-side=\"side\"\n>\n  <button\n    aui-button=\"text\"\n    (click)=\"navHead(DateNavRange.Decade, side === 'left' ? -10 : 10)\"\n    [class.hidden]=\"!shouldShowNav(DateNavRange.Decade, side)\"\n  >\n    <aui-icon\n      [icon]=\"side === 'left' ? 'angle_double_left' : 'angle_double_right'\"\n    ></aui-icon>\n  </button>\n</ng-template>\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/header/component.ts","../../../../../src/date-picker/calendar/header/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { buildBem } from '../../../utils';\nimport {\n  CalendarHeaderRange,\n  DateNavRange,\n  Side,\n} from '../../date-picker.type';\nimport { MONTH, YEAR } from '../constant';\nimport { calcRangeValue } from '../util';\n\nconst bem = buildBem('aui-calendar-header');\n\n@Component({\n  selector: 'aui-calendar-header',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CalendarHeaderComponent {\n  @Input()\n  dateNavRange = DateNavRange.Month;\n\n  @Input()\n  anchor = dayjs();\n\n  @Input()\n  maxAvail?: ConfigType;\n\n  private get _maxAvail() {\n    return this.maxAvail ? dayjs(this.maxAvail) : null;\n  }\n\n  @Input()\n  minAvail?: ConfigType;\n\n  private get _minAvail() {\n    return this.minAvail ? dayjs(this.minAvail) : null;\n  }\n\n  @Output()\n  navRangeChange = new EventEmitter<DateNavRange>();\n\n  @Output()\n  anchorChange = new EventEmitter<Dayjs>();\n\n  get headerRange(): CalendarHeaderRange {\n    return calcRangeValue(this.dateNavRange, this.anchor);\n  }\n\n  bem = bem;\n\n  DateNavRange = DateNavRange;\n\n  // maxAvail > current date ：right btn hide\n  // minAvail > current date ：left btn hide\n  shouldShowNav(type: DateNavRange, side: Side) {\n    const availValue = (\n      side === Side.Left ? this._minAvail : this._maxAvail\n    )?.clone();\n    if (!availValue) {\n      return true;\n    }\n    // 对于年的判别，2014-5-1至2015-6-1日，仍当展示按钮\n    const constrainDate = [DateNavRange.Month, DateNavRange.Year].includes(type)\n      ? availValue.add(side === Side.Left ? 1 : -1, type as 'month' | 'year')\n      : availValue;\n    return (\n      this.compareNavValue(type, constrainDate, this.anchor) ===\n      (side === Side.Left ? -1 : 1)\n    );\n  }\n\n  // @return isBetween|isEqual:0, isBefore:-1,isAfter:1\n  compareNavValue(type: DateNavRange, constrain: Dayjs, anchor: Dayjs) {\n    const range = calcRangeValue(type, anchor);\n    const constrainValue = constrain;\n    if (type === DateNavRange.Decade) {\n      if (constrainValue.isBetween(range.start, range.end, YEAR)) {\n        return 0;\n      }\n      return constrainValue.isBefore(range.start) ? -1 : 1;\n    }\n    return constrainValue.isSame(range.start, MONTH)\n      ? 0\n      : constrainValue.isBefore(range.start, MONTH)\n      ? -1\n      : 1;\n  }\n\n  navHead(range: DateNavRange, value: number) {\n    let anchor: Dayjs;\n    switch (range) {\n      case DateNavRange.Month: {\n        anchor = this.anchor.add(value, MONTH);\n        break;\n      }\n      case DateNavRange.Year: {\n        anchor = this.anchor.add(value, YEAR);\n        break;\n      }\n      case DateNavRange.Decade:\n        anchor = this.anchor.add(value, YEAR);\n        break;\n    }\n    this.anchorChange.next(anchor);\n  }\n\n  clickNav = (range: DateNavRange) => {\n    if (![DateNavRange.Month, DateNavRange.Year].includes(range)) {\n      return;\n    }\n    this.navRangeChange.next(\n      range === DateNavRange.Month ? DateNavRange.Year : DateNavRange.Decade,\n    );\n  };\n}\n","<div [class]=\"bem.element('container')\">\n  <div>\n    <ng-container\n      *ngIf=\"dateNavRange !== DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"yearControl\"\n      [ngTemplateOutletContext]=\"{ side: 'left' }\"\n    ></ng-container>\n\n    <ng-container\n      *ngIf=\"dateNavRange === DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"decadeControl\"\n      [ngTemplateOutletContext]=\"{ side: 'left' }\"\n    ></ng-container>\n  </div>\n  <!-- 内容区 -->\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Month\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    <a\n      href=\"javascript:;\"\n      (click)=\"clickNav(DateNavRange.Year)\"\n    >\n      {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n    </a>\n    <a\n      href=\"javascript:;\"\n      (click)=\"clickNav(DateNavRange.Month)\"\n    >\n      {{ headerRange?.start?.month() + 1 }}{{ 'month_suffix' | auiI18n }}\n    </a>\n  </span>\n\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Year\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    <a\n      href=\"javascript:;\"\n      (click)=\"clickNav(DateNavRange.Year)\"\n    >\n      {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n    </a>\n  </span>\n\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Decade\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    {{ headerRange?.start.year() }} - {{ headerRange?.end?.year() }}\n  </span>\n\n  <div [class]=\"bem.element('nav-action')\">\n    <ng-container\n      *ngIf=\"dateNavRange !== DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"yearControl\"\n      [ngTemplateOutletContext]=\"{ side: 'right' }\"\n    ></ng-container>\n\n    <ng-container\n      *ngIf=\"dateNavRange === DateNavRange.Decade\"\n      [ngTemplateOutlet]=\"decadeControl\"\n      [ngTemplateOutletContext]=\"{ side: 'right' }\"\n    ></ng-container>\n  </div>\n</div>\n\n<ng-template\n  #yearControl\n  let-side=\"side\"\n>\n  <span class=\"action-bar\">\n    <button\n      aui-button=\"text\"\n      *ngIf=\"side === 'right'\"\n      [class.hidden]=\"\n        !shouldShowNav(DateNavRange.Month, side) ||\n        dateNavRange !== DateNavRange.Month\n      \"\n      (click)=\"navHead(DateNavRange.Month, 1)\"\n    >\n      <aui-icon icon=\"angle_right\"></aui-icon>\n    </button>\n    <button\n      aui-button=\"text\"\n      (click)=\"navHead(DateNavRange.Year, side === 'left' ? -1 : 1)\"\n      [class.hidden]=\"!shouldShowNav(DateNavRange.Year, side)\"\n    >\n      <aui-icon\n        [icon]=\"side === 'left' ? 'angle_double_left' : 'angle_double_right'\"\n      ></aui-icon>\n    </button>\n    <button\n      aui-button=\"text\"\n      *ngIf=\"side === 'left'\"\n      [class.hidden]=\"\n        !shouldShowNav(DateNavRange.Month, side) ||\n        dateNavRange !== DateNavRange.Month\n      \"\n      (click)=\"navHead(DateNavRange.Month, -1)\"\n    >\n      <aui-icon icon=\"angle_left\"></aui-icon>\n    </button>\n  </span>\n</ng-template>\n\n<ng-template\n  #decadeControl\n  let-side=\"side\"\n>\n  <button\n    aui-button=\"text\"\n    (click)=\"navHead(DateNavRange.Decade, side === 'left' ? -10 : 10)\"\n    [class.hidden]=\"!shouldShowNav(DateNavRange.Decade, side)\"\n  >\n    <aui-icon\n      [icon]=\"side === 'left' ? 'angle_double_left' : 'angle_double_right'\"\n    ></aui-icon>\n  </button>\n</ng-template>\n"]}
@@ -46,9 +46,12 @@ export class PickerPanelComponent {
46
46
  return composeDisabledDateFn(date => this.minDate && date.isBefore(this.minDate), date => this.maxDate && date.isAfter(this.maxDate), this.disabledDate);
47
47
  }
48
48
  ngOnChanges() {
49
+ // 如果 dateValue 是一个数组,必然是同一个面板上,否则应当给与不同的面板不同的dateValue值
49
50
  const headerRange = calcRangeValue(this.navRange, this.anchor);
50
51
  this.renderPanelData(headerRange.start, this.navRange);
51
52
  }
53
+ // 根据当前数据,计算渲染表格
54
+ // eslint-disable-next-line sonarjs/cognitive-complexity
52
55
  renderPanelData(date, navRange) {
53
56
  const value = [];
54
57
  let colCounts = 0;
@@ -73,6 +76,7 @@ export class PickerPanelComponent {
73
76
  rowCounts = MONTH_PANEL_ROW_COUNT;
74
77
  break;
75
78
  }
79
+ // No default
76
80
  }
77
81
  for (let k = 0; k < rowCounts; k++) {
78
82
  const row = [];
@@ -148,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
148
152
  }], hovered: [{
149
153
  type: Output
150
154
  }] } });
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker-panel.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/panel/picker-panel.ts","../../../../../src/date-picker/calendar/panel/picker-panel.template.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAgB,MAAM,OAAO,CAAC;AACrC,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAE/C,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EACL,GAAG,EACH,sBAAsB,EACtB,mBAAmB,EAEnB,KAAK,EACL,wBAAwB,EACxB,qBAAqB,EACrB,IAAI,EACJ,uBAAuB,EACvB,oBAAoB,GACrB,MAAM,aAAa,CAAC;AACrB,OAAO,EAEL,cAAc,EACd,qBAAqB,EACrB,UAAU,EACV,oBAAoB,EACpB,iBAAiB,EACjB,iBAAiB,EACjB,SAAS,GACV,MAAM,SAAS,CAAC;;;;;AAEjB,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;AAExB,MAAM,GAAG,GAAG,QAAQ,CAAC,kBAAkB,CAAC,CAAC;AASzC,MAAM,OAAO,oBAAoB;IAmE/B,YAA6B,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QA3DnD,WAAM,GAAG,KAAK,EAAE,CAAC;QAMjB,iBAAY,GAAqD,GAAG,EAAE,CAAC,KAAK,CAAC;QA8BrE,kBAAa,GAAG,CAAC,CAAC;QAK1B,WAAM,GAAG,IAAI,YAAY,EAAS,CAAC;QAGnC,YAAO,GAAG,IAAI,YAAY,EAAS,CAAC;QAEpC,QAAG,GAAG,GAAG,CAAC;QACV,iBAAY,GAAG,YAAY,CAAC;QAE5B,aAAQ,GAAG;YACT,QAAQ;YACR,QAAQ;YACR,SAAS;YACT,WAAW;YACX,UAAU;YACV,QAAQ;YACR,UAAU;SACX,CAAC;IAEoD,CAAC;IAnDvD,IACI,YAAY,CAAC,GAAW;QAC1B,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7D,IAAI,CAAC,QAAQ,GAAG;YACd,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,UAAU,CAAC;YAClC,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC;SACtC,CAAC;QACF,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC;IAClC,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAQD,IAAI,cAAc;QAChB,OAAO,qBAAqB,CAC1B,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,EACnD,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,EAClD,IAAI,CAAC,YAAY,CAClB,CAAC;IACJ,CAAC;IA2BD,WAAW;QAET,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/D,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzD,CAAC;IAID,eAAe,CAAC,IAAW,EAAE,QAAsB;QACjD,MAAM,KAAK,GAAG,EAAE,CAAC;QACjB,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE,CAAC,CAAC;SACvB;QACD,MAAM,CAAC,GAAG,MAAM,CAAC,GAAG,oBAAoB,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC5E,QAAQ,QAAQ,EAAE;YAChB,KAAK,YAAY,CAAC,KAAK,CAAC,CAAC;gBACvB,SAAS,GAAG,sBAAsB,CAAC;gBACnC,SAAS,GAAG,mBAAmB,CAAC;gBAEhC,MAAM;aACP;YACD,KAAK,YAAY,CAAC,MAAM,CAAC,CAAC;gBACxB,SAAS,GAAG,uBAAuB,CAAC;gBACpC,SAAS,GAAG,oBAAoB,CAAC;gBAEjC,MAAM;aACP;YACD,KAAK,YAAY,CAAC,IAAI,CAAC,CAAC;gBACtB,SAAS,GAAG,wBAAwB,CAAC;gBACrC,SAAS,GAAG,qBAAqB,CAAC;gBAElC,MAAM;aACP;SAEF;QACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;YAClC,MAAM,GAAG,GAAG,EAAE,CAAC;YACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;gBAClC,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,GAAG,SAAS,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;gBACnE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;gBAC5D,MAAM,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC/C,IAAI,WAAW,EAAE,MAAM,KAAK,CAAC,IAAI,QAAQ,KAAK,YAAY,CAAC,KAAK,EAAE;oBAChE,IACE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC;wBACpD,CAAC,IAAI,CAAC,YAAY,EAClB;wBACA,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;qBACrB;oBACD,IAAI,CAAC,YAAY;wBACf,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;oBAC/D,IAAI,CAAC,UAAU;wBACb,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;oBAC/D,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,UAAU,EAAE;wBACxC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;wBAC1B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;qBACzB;iBACF;gBACD,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAChB;YACD,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACjB;QACD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,EAAE,CAAC;QAC/B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,KAAY;QAChB,IACE,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM;YAC1C,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,QAAQ,EAC9C;YACA,OAAO,KAAK,CAAC;SACd;QACD,OAAO,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,CACvC,IAAI,CAAC,QAAQ,KAAK,YAAY,CAAC,MAAM;YACnC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC;YAC/B,CAAC,CAAC,IAAI,CAAC,QAAQ,KAAK,YAAY,CAAC,IAAI;gBACrC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,KAAK,CAAC;gBAChC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,GAAG,CAAC,CACjC,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,KAAY;QACrB,OAAO,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACjE,CAAC;IAED,WAAW,CAAC,KAAY;QACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;;iHAlKU,oBAAoB;qGAApB,oBAAoB,gUCjDjC,2jDAmDA;2FDFa,oBAAoB;kBAPhC,SAAS;+BACE,kBAAkB,iBAGb,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;wGAI/C,QAAQ;sBADP,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,MAAM;sBADL,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIF,YAAY;sBADf,KAAK;gBAeN,OAAO;sBADN,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAgBN,MAAM;sBADL,MAAM;gBAIP,OAAO;sBADN,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport dayjs, { Dayjs } from 'dayjs';\nimport isBetween from 'dayjs/plugin/isBetween';\n\nimport { buildBem } from '../../../utils';\nimport { DateNavRange } from '../../date-picker.type';\nimport {\n  DAY,\n  DAY_PANEL_COLUMN_COUNT,\n  DAY_PANEL_ROW_COUNT,\n  DatePickerType,\n  MONTH,\n  MONTH_PANEL_COLUMN_COUNT,\n  MONTH_PANEL_ROW_COUNT,\n  YEAR,\n  YEAR_PANEL_COLUMN_COUNT,\n  YEAR_PANEL_ROW_COUNT,\n} from '../constant';\nimport {\n  DateCell,\n  calcRangeValue,\n  composeDisabledDateFn,\n  formatDate,\n  getDatePanelIterable,\n  getNavRangeByType,\n  getTypeByNavRange,\n  sortDates,\n} from '../util';\n\ndayjs.extend(isBetween);\n\nconst bem = buildBem('aui-picker-panel');\n\n@Component({\n  selector: 'aui-picker-panel',\n  templateUrl: './picker-panel.template.html',\n  styleUrls: ['./picker-panel.style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PickerPanelComponent implements OnChanges {\n  @Input()\n  navRange: DateNavRange;\n\n  @Input()\n  type: DatePickerType;\n\n  @Input()\n  anchor = dayjs();\n\n  @Input()\n  matchDates: Dayjs[];\n\n  @Input()\n  disabledDate: (date: Dayjs, navRange: DateNavRange) => boolean = () => false;\n\n  @Input()\n  set weekStartDay(day: number) {\n    const normalized = Math.max(Math.min(Math.round(day), 6), 0);\n    this.weekDefs = [\n      ...this.weekDefs.slice(normalized),\n      ...this.weekDefs.slice(0, normalized),\n    ];\n    this._weekStartDay = normalized;\n  }\n\n  get weekStartDay() {\n    return this._weekStartDay;\n  }\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  get disabledDateFn() {\n    return composeDisabledDateFn(\n      date => this.minDate && date.isBefore(this.minDate),\n      date => this.maxDate && date.isAfter(this.maxDate),\n      this.disabledDate,\n    );\n  }\n\n  private _weekStartDay = 0;\n\n  panelData: DateCell[][];\n\n  @Output()\n  select = new EventEmitter<Dayjs>();\n\n  @Output()\n  hovered = new EventEmitter<Dayjs>();\n\n  bem = bem;\n  DateNavRange = DateNavRange;\n\n  weekDefs = [\n    'sunday',\n    'monday',\n    'tuesday',\n    'wednesday',\n    'thursday',\n    'friday',\n    'saturday',\n  ];\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  ngOnChanges() {\n    // 如果 dateValue 是一个数组，必然是同一个面板上，否则应当给与不同的面板不同的dateValue值\n    const headerRange = calcRangeValue(this.navRange, this.anchor);\n    this.renderPanelData(headerRange.start, this.navRange);\n  }\n\n  // 根据当前数据，计算渲染表格\n  // eslint-disable-next-line sonarjs/cognitive-complexity\n  renderPanelData(date: Dayjs, navRange: DateNavRange) {\n    const value = [];\n    let colCounts = 0;\n    let rowCounts = 0;\n    if (!this.panelData) {\n      this.panelData = [[]];\n    }\n    const [...values] = getDatePanelIterable(date, navRange, this.weekStartDay);\n    switch (navRange) {\n      case DateNavRange.Month: {\n        colCounts = DAY_PANEL_COLUMN_COUNT;\n        rowCounts = DAY_PANEL_ROW_COUNT;\n\n        break;\n      }\n      case DateNavRange.Decade: {\n        colCounts = YEAR_PANEL_COLUMN_COUNT;\n        rowCounts = YEAR_PANEL_ROW_COUNT;\n\n        break;\n      }\n      case DateNavRange.Year: {\n        colCounts = MONTH_PANEL_COLUMN_COUNT;\n        rowCounts = MONTH_PANEL_ROW_COUNT;\n\n        break;\n      }\n      // No default\n    }\n    for (let k = 0; k < rowCounts; k++) {\n      const row = [];\n      for (let i = 0; i < colCounts; i++) {\n        const cell = formatDate(navRange, values[k * colCounts + i], date);\n        cell.isDisabled = this.disabledDateFn(cell.value, navRange);\n        const sortedDates = sortDates(this.matchDates);\n        if (sortedDates?.length === 2 && navRange === DateNavRange.Month) {\n          if (\n            cell.value.isBetween(sortedDates[0], sortedDates[1]) &&\n            !cell.isBackground\n          ) {\n            cell.inRange = true;\n          }\n          cell.isRangeStart =\n            cell.value.isSame(sortedDates[0], DAY) && !cell.isBackground;\n          cell.isRangeEnd =\n            cell.value.isSame(sortedDates[1], DAY) && !cell.isBackground;\n          if (cell.isRangeStart && cell.isRangeEnd) {\n            cell.isRangeStart = false;\n            cell.isRangeEnd = false;\n          }\n        }\n        row.push(cell);\n      }\n      value.push(row);\n    }\n    this.panelData = value.slice();\n    this.cdr.markForCheck();\n  }\n\n  match(value: Dayjs) {\n    if (\n      !this.matchDates?.filter(v => !!v)?.length ||\n      getNavRangeByType(this.type) !== this.navRange\n    ) {\n      return false;\n    }\n    return this.matchDates?.some(dateValue =>\n      this.navRange === DateNavRange.Decade\n        ? value.isSame(dateValue, YEAR)\n        : this.navRange === DateNavRange.Year\n        ? value.isSame(dateValue, MONTH)\n        : value.isSame(dateValue, DAY),\n    );\n  }\n\n  matchToday(value: Dayjs) {\n    return value.isSame(dayjs(), getTypeByNavRange(this.navRange));\n  }\n\n  selectValue(value: Dayjs) {\n    this.select.next(value);\n  }\n\n  trackByFn() {\n    return this.navRange;\n  }\n}\n","<div\n  [class]=\"bem.element('container')\"\n  [ngClass]=\"{\n    'day-panel-container': navRange === DateNavRange.Month,\n    'month-panel-container': navRange === DateNavRange.Year,\n    'year-panel-container': navRange === DateNavRange.Decade\n  }\"\n>\n  <div\n    [class]=\"[bem.element('row'), 'week-header'].join(' ')\"\n    *ngIf=\"navRange === DateNavRange.Month\"\n  >\n    <span\n      *ngFor=\"let item of weekDefs\"\n      [class]=\"bem.element('cell')\"\n    >\n      {{ item | auiI18n }}\n    </span>\n  </div>\n  <div\n    [class]=\"bem.element('row')\"\n    *ngFor=\"let row of panelData; trackBy: trackByFn\"\n  >\n    <span\n      *ngFor=\"let item of row; trackBy: trackByFn\"\n      [class]=\"bem.element('cell')\"\n      [ngClass]=\"{\n        inRange: item.inRange && !item.isDisabled,\n        isActive: match(item.value),\n        isBackground: item.isBackground && !item.isDisabled,\n        isRangeStart: item.isRangeStart,\n        isRangeEnd: item.isRangeEnd,\n        isToday: matchToday(item.value) && !item.isBackground,\n        isDisabled: item.isDisabled\n      }\"\n      ><button\n        aui-button=\"text\"\n        [plain]=\"true\"\n        [size]=\"navRange === DateNavRange.Month ? 'mini' : 'small'\"\n        [disabled]=\"item.isDisabled\"\n        (click)=\"selectValue(item.value)\"\n        (mouseenter)=\"hovered.next(item.value)\"\n      >\n        {{ item.label\n        }}<ng-container *ngIf=\"navRange === DateNavRange.Year\">{{\n          'month_suffix' | auiI18n\n        }}</ng-container>\n      </button>\n    </span>\n  </div>\n</div>\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker-panel.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/panel/picker-panel.ts","../../../../../src/date-picker/calendar/panel/picker-panel.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport dayjs, { Dayjs } from 'dayjs';\nimport isBetween from 'dayjs/plugin/isBetween';\n\nimport { buildBem } from '../../../utils';\nimport { DateNavRange } from '../../date-picker.type';\nimport {\n  DAY,\n  DAY_PANEL_COLUMN_COUNT,\n  DAY_PANEL_ROW_COUNT,\n  DatePickerType,\n  MONTH,\n  MONTH_PANEL_COLUMN_COUNT,\n  MONTH_PANEL_ROW_COUNT,\n  YEAR,\n  YEAR_PANEL_COLUMN_COUNT,\n  YEAR_PANEL_ROW_COUNT,\n} from '../constant';\nimport {\n  DateCell,\n  calcRangeValue,\n  composeDisabledDateFn,\n  formatDate,\n  getDatePanelIterable,\n  getNavRangeByType,\n  getTypeByNavRange,\n  sortDates,\n} from '../util';\n\ndayjs.extend(isBetween);\n\nconst bem = buildBem('aui-picker-panel');\n\n@Component({\n  selector: 'aui-picker-panel',\n  templateUrl: './picker-panel.template.html',\n  styleUrls: ['./picker-panel.style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PickerPanelComponent implements OnChanges {\n  @Input()\n  navRange: DateNavRange;\n\n  @Input()\n  type: DatePickerType;\n\n  @Input()\n  anchor = dayjs();\n\n  @Input()\n  matchDates: Dayjs[];\n\n  @Input()\n  disabledDate: (date: Dayjs, navRange: DateNavRange) => boolean = () => false;\n\n  @Input()\n  set weekStartDay(day: number) {\n    const normalized = Math.max(Math.min(Math.round(day), 6), 0);\n    this.weekDefs = [\n      ...this.weekDefs.slice(normalized),\n      ...this.weekDefs.slice(0, normalized),\n    ];\n    this._weekStartDay = normalized;\n  }\n\n  get weekStartDay() {\n    return this._weekStartDay;\n  }\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  get disabledDateFn() {\n    return composeDisabledDateFn(\n      date => this.minDate && date.isBefore(this.minDate),\n      date => this.maxDate && date.isAfter(this.maxDate),\n      this.disabledDate,\n    );\n  }\n\n  private _weekStartDay = 0;\n\n  panelData: DateCell[][];\n\n  @Output()\n  select = new EventEmitter<Dayjs>();\n\n  @Output()\n  hovered = new EventEmitter<Dayjs>();\n\n  bem = bem;\n  DateNavRange = DateNavRange;\n\n  weekDefs = [\n    'sunday',\n    'monday',\n    'tuesday',\n    'wednesday',\n    'thursday',\n    'friday',\n    'saturday',\n  ];\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  ngOnChanges() {\n    // 如果 dateValue 是一个数组，必然是同一个面板上，否则应当给与不同的面板不同的dateValue值\n    const headerRange = calcRangeValue(this.navRange, this.anchor);\n    this.renderPanelData(headerRange.start, this.navRange);\n  }\n\n  // 根据当前数据，计算渲染表格\n  // eslint-disable-next-line sonarjs/cognitive-complexity\n  renderPanelData(date: Dayjs, navRange: DateNavRange) {\n    const value = [];\n    let colCounts = 0;\n    let rowCounts = 0;\n    if (!this.panelData) {\n      this.panelData = [[]];\n    }\n    const [...values] = getDatePanelIterable(date, navRange, this.weekStartDay);\n    switch (navRange) {\n      case DateNavRange.Month: {\n        colCounts = DAY_PANEL_COLUMN_COUNT;\n        rowCounts = DAY_PANEL_ROW_COUNT;\n\n        break;\n      }\n      case DateNavRange.Decade: {\n        colCounts = YEAR_PANEL_COLUMN_COUNT;\n        rowCounts = YEAR_PANEL_ROW_COUNT;\n\n        break;\n      }\n      case DateNavRange.Year: {\n        colCounts = MONTH_PANEL_COLUMN_COUNT;\n        rowCounts = MONTH_PANEL_ROW_COUNT;\n\n        break;\n      }\n      // No default\n    }\n    for (let k = 0; k < rowCounts; k++) {\n      const row = [];\n      for (let i = 0; i < colCounts; i++) {\n        const cell = formatDate(navRange, values[k * colCounts + i], date);\n        cell.isDisabled = this.disabledDateFn(cell.value, navRange);\n        const sortedDates = sortDates(this.matchDates);\n        if (sortedDates?.length === 2 && navRange === DateNavRange.Month) {\n          if (\n            cell.value.isBetween(sortedDates[0], sortedDates[1]) &&\n            !cell.isBackground\n          ) {\n            cell.inRange = true;\n          }\n          cell.isRangeStart =\n            cell.value.isSame(sortedDates[0], DAY) && !cell.isBackground;\n          cell.isRangeEnd =\n            cell.value.isSame(sortedDates[1], DAY) && !cell.isBackground;\n          if (cell.isRangeStart && cell.isRangeEnd) {\n            cell.isRangeStart = false;\n            cell.isRangeEnd = false;\n          }\n        }\n        row.push(cell);\n      }\n      value.push(row);\n    }\n    this.panelData = value.slice();\n    this.cdr.markForCheck();\n  }\n\n  match(value: Dayjs) {\n    if (\n      !this.matchDates?.filter(v => !!v)?.length ||\n      getNavRangeByType(this.type) !== this.navRange\n    ) {\n      return false;\n    }\n    return this.matchDates?.some(dateValue =>\n      this.navRange === DateNavRange.Decade\n        ? value.isSame(dateValue, YEAR)\n        : this.navRange === DateNavRange.Year\n        ? value.isSame(dateValue, MONTH)\n        : value.isSame(dateValue, DAY),\n    );\n  }\n\n  matchToday(value: Dayjs) {\n    return value.isSame(dayjs(), getTypeByNavRange(this.navRange));\n  }\n\n  selectValue(value: Dayjs) {\n    this.select.next(value);\n  }\n\n  trackByFn() {\n    return this.navRange;\n  }\n}\n","<div\n  [class]=\"bem.element('container')\"\n  [ngClass]=\"{\n    'day-panel-container': navRange === DateNavRange.Month,\n    'month-panel-container': navRange === DateNavRange.Year,\n    'year-panel-container': navRange === DateNavRange.Decade\n  }\"\n>\n  <div\n    [class]=\"[bem.element('row'), 'week-header'].join(' ')\"\n    *ngIf=\"navRange === DateNavRange.Month\"\n  >\n    <span\n      *ngFor=\"let item of weekDefs\"\n      [class]=\"bem.element('cell')\"\n    >\n      {{ item | auiI18n }}\n    </span>\n  </div>\n  <div\n    [class]=\"bem.element('row')\"\n    *ngFor=\"let row of panelData; trackBy: trackByFn\"\n  >\n    <span\n      *ngFor=\"let item of row; trackBy: trackByFn\"\n      [class]=\"bem.element('cell')\"\n      [ngClass]=\"{\n        inRange: item.inRange && !item.isDisabled,\n        isActive: match(item.value),\n        isBackground: item.isBackground && !item.isDisabled,\n        isRangeStart: item.isRangeStart,\n        isRangeEnd: item.isRangeEnd,\n        isToday: matchToday(item.value) && !item.isBackground,\n        isDisabled: item.isDisabled\n      }\"\n      ><button\n        aui-button=\"text\"\n        [plain]=\"true\"\n        [size]=\"navRange === DateNavRange.Month ? 'mini' : 'small'\"\n        [disabled]=\"item.isDisabled\"\n        (click)=\"selectValue(item.value)\"\n        (mouseenter)=\"hovered.next(item.value)\"\n      >\n        {{ item.label\n        }}<ng-container *ngIf=\"navRange === DateNavRange.Year\">{{\n          'month_suffix' | auiI18n\n        }}</ng-container>\n      </button>\n    </span>\n  </div>\n</div>\n"]}