@alauda/ui 7.4.2-beta.1 → 7.4.2-beta.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/date-picker/calendar/header/component.d.ts +21 -4
- package/date-picker/date-picker/date-picker.component.d.ts +2 -4
- package/date-picker/trigger/trigger.component.d.ts +12 -4
- package/esm2022/accordion/accordion-item/accordion-item.component.mjs +9 -11
- package/esm2022/accordion/accordion.component.mjs +4 -6
- package/esm2022/accordion/accordion.module.mjs +6 -6
- package/esm2022/anchor/anchor.component.mjs +14 -18
- package/esm2022/anchor/anchor.directive.mjs +13 -29
- package/esm2022/anchor/anchor.module.mjs +5 -5
- package/esm2022/autocomplete/autocomplete-placeholder.component.mjs +3 -3
- package/esm2022/autocomplete/autocomplete.component.mjs +4 -12
- package/esm2022/autocomplete/autocomplete.directive.mjs +22 -23
- package/esm2022/autocomplete/autocomplete.module.mjs +6 -6
- package/esm2022/autocomplete/helper-directives.mjs +3 -3
- package/esm2022/autocomplete/suggestion/suggestion.component.mjs +8 -15
- package/esm2022/autocomplete/suggestion-group/suggestion-group.component.mjs +3 -5
- package/esm2022/back-top/back-top.component.mjs +12 -15
- package/esm2022/back-top/back-top.module.mjs +4 -4
- package/esm2022/breadcrumb/breadcrumb-item.component.mjs +5 -6
- package/esm2022/breadcrumb/breadcrumb.component.mjs +7 -6
- package/esm2022/breadcrumb/breadcrumb.module.mjs +6 -6
- package/esm2022/button/button-group/button-group.component.mjs +3 -3
- package/esm2022/button/button.component.mjs +9 -12
- package/esm2022/button/button.module.mjs +4 -4
- package/esm2022/card/card.component.mjs +6 -4
- package/esm2022/card/card.module.mjs +5 -5
- package/esm2022/card/helper-directives.mjs +7 -7
- package/esm2022/card/section.component.mjs +3 -3
- package/esm2022/checkbox/checkbox-group/checkbox-group.component.mjs +8 -7
- package/esm2022/checkbox/checkbox.component.mjs +10 -14
- package/esm2022/checkbox/checkbox.module.mjs +6 -6
- package/esm2022/color-picker/color-picker.component.mjs +4 -4
- package/esm2022/color-picker/color-picker.module.mjs +4 -4
- package/esm2022/date-picker/calendar/date-picker-panel/component.mjs +17 -26
- package/esm2022/date-picker/calendar/footer/component.mjs +8 -8
- package/esm2022/date-picker/calendar/header/component.mjs +56 -24
- package/esm2022/date-picker/calendar/panel/picker-panel.mjs +19 -26
- package/esm2022/date-picker/calendar/range-picker-panel/component.mjs +30 -33
- package/esm2022/date-picker/calendar/util.mjs +1 -8
- package/esm2022/date-picker/date-picker/date-picker.component.mjs +17 -37
- package/esm2022/date-picker/date-picker.module.mjs +6 -6
- package/esm2022/date-picker/range-picker/range-picker.component.mjs +17 -20
- package/esm2022/date-picker/trigger/trigger.component.mjs +72 -26
- package/esm2022/dialog/confirm-dialog/confirm-dialog-config.mjs +8 -9
- package/esm2022/dialog/confirm-dialog/confirm-dialog.component.mjs +8 -11
- package/esm2022/dialog/dialog-config.mjs +10 -9
- package/esm2022/dialog/dialog-content/dialog-close.directive.mjs +3 -7
- package/esm2022/dialog/dialog-content/dialog-content.component.mjs +4 -4
- package/esm2022/dialog/dialog-content/dialog-footer.component.mjs +6 -4
- package/esm2022/dialog/dialog-content/dialog-header.component.mjs +7 -10
- package/esm2022/dialog/dialog-ref.mjs +4 -8
- package/esm2022/dialog/dialog.component.mjs +6 -13
- package/esm2022/dialog/dialog.module.mjs +6 -6
- package/esm2022/dialog/dialog.service.mjs +7 -11
- package/esm2022/drawer/component/drawer.component.mjs +5 -24
- package/esm2022/drawer/component/internal/internal.component.mjs +8 -13
- package/esm2022/drawer/drawer-ref.mjs +3 -5
- package/esm2022/drawer/drawer.module.mjs +5 -5
- package/esm2022/drawer/drawer.service.mjs +4 -9
- package/esm2022/drawer/helper-directives.mjs +7 -7
- package/esm2022/dropdown/dropdown-active.directive.mjs +7 -4
- package/esm2022/dropdown/dropdown-button/dropdown-button.component.mjs +11 -12
- package/esm2022/dropdown/dropdown.directive.mjs +7 -7
- package/esm2022/dropdown/dropdown.module.mjs +6 -6
- package/esm2022/dropdown/helper-directives.mjs +3 -3
- package/esm2022/dropdown/menu/menu.component.mjs +7 -5
- package/esm2022/dropdown/menu-group/menu-group.component.mjs +3 -3
- package/esm2022/dropdown/menu-item/menu-item.component.mjs +10 -8
- package/esm2022/dropdown/submenu/submenu.component.mjs +9 -7
- package/esm2022/form/common-form.mjs +7 -12
- package/esm2022/form/form-item/form-item.component.mjs +9 -22
- package/esm2022/form/form.directive.mjs +16 -17
- package/esm2022/form/form.module.mjs +5 -5
- package/esm2022/form/helper-directives.mjs +11 -12
- package/esm2022/i18n/i18n.module.mjs +4 -4
- package/esm2022/i18n/i18n.pipe.mjs +6 -18
- package/esm2022/i18n/i18n.service.mjs +16 -24
- package/esm2022/icon/icon-register.service.mjs +4 -6
- package/esm2022/icon/icon.component.mjs +6 -15
- package/esm2022/icon/icon.module.mjs +4 -4
- package/esm2022/inline-alert/helper-directives.mjs +3 -3
- package/esm2022/inline-alert/inline-alert.component.mjs +10 -11
- package/esm2022/inline-alert/inline-alert.module.mjs +6 -6
- package/esm2022/input/autosize.directive.mjs +5 -7
- package/esm2022/input/helper-directives.mjs +9 -9
- package/esm2022/input/input-group/input-group.component.mjs +6 -13
- package/esm2022/input/input.component.mjs +7 -9
- package/esm2022/input/input.module.mjs +6 -6
- package/esm2022/input/number-input/number-input.component.mjs +18 -21
- package/esm2022/input/search/search.component.mjs +16 -15
- package/esm2022/input/tags-input/tags-input.component.mjs +16 -25
- package/esm2022/internal/utils/bem.mjs +1 -2
- package/esm2022/internal/utils/styles-renderer.mjs +1 -4
- package/esm2022/message/base-message.mjs +2 -11
- package/esm2022/message/message-wrapper.component.mjs +3 -4
- package/esm2022/message/message.component.mjs +10 -17
- package/esm2022/message/message.config.mjs +1 -5
- package/esm2022/message/message.module.mjs +6 -6
- package/esm2022/message/message.service.mjs +3 -3
- package/esm2022/notification/notification-wrapper.component.mjs +3 -4
- package/esm2022/notification/notification.component.mjs +13 -16
- package/esm2022/notification/notification.module.mjs +6 -6
- package/esm2022/notification/notification.service.mjs +3 -3
- package/esm2022/paginator/paginator-intl.mjs +10 -8
- package/esm2022/paginator/paginator.component.mjs +13 -16
- package/esm2022/paginator/paginator.module.mjs +6 -6
- package/esm2022/radio/base-radio.mjs +9 -14
- package/esm2022/radio/radio-button/radio-button.component.mjs +6 -6
- package/esm2022/radio/radio-group/radio-group.component.mjs +20 -17
- package/esm2022/radio/radio.component.mjs +4 -4
- package/esm2022/radio/radio.module.mjs +6 -6
- package/esm2022/scrolling/fixed-size-table-virtual-scroll-strategy.mjs +13 -12
- package/esm2022/scrolling/fixed-size-table-virtual-scroll.directive.mjs +12 -12
- package/esm2022/scrolling/fixed-size-virtual-scroll.directive.mjs +4 -4
- package/esm2022/scrolling/scrolling.module.mjs +5 -5
- package/esm2022/scrolling/virtual-for-of.directive.mjs +3 -3
- package/esm2022/scrolling/virtual-scroll-viewport.component.mjs +4 -4
- package/esm2022/select/base-select.mjs +25 -39
- package/esm2022/select/helper-directives.mjs +5 -13
- package/esm2022/select/multi-select/multi-select.component.mjs +16 -25
- package/esm2022/select/option/option.component.mjs +20 -27
- package/esm2022/select/option-group/option-group.component.mjs +3 -5
- package/esm2022/select/option-placeholder.component.mjs +3 -3
- package/esm2022/select/select.component.mjs +9 -9
- package/esm2022/select/select.module.mjs +6 -6
- package/esm2022/select/validators.mjs +5 -8
- package/esm2022/shared/click-outside.directive.mjs +4 -5
- package/esm2022/shared/shared.module.mjs +4 -4
- package/esm2022/sort/sort-header.component.mjs +5 -11
- package/esm2022/sort/sort.directive.mjs +10 -9
- package/esm2022/sort/sort.module.mjs +4 -4
- package/esm2022/status-bar/status-bar.component.mjs +9 -8
- package/esm2022/status-bar/status-bar.module.mjs +4 -4
- package/esm2022/steps/steps.component.mjs +14 -14
- package/esm2022/steps/steps.module.mjs +4 -4
- package/esm2022/switch/switch.component.mjs +9 -6
- package/esm2022/switch/switch.module.mjs +4 -4
- package/esm2022/table/table-cell-def.directive.mjs +4 -4
- package/esm2022/table/table-cell.component.mjs +18 -12
- package/esm2022/table/table-cell.directive.mjs +4 -4
- package/esm2022/table/table-column-def.directive.mjs +4 -4
- package/esm2022/table/table-column-resizable.directive.mjs +14 -13
- package/esm2022/table/table-header-cell-def.directive.mjs +4 -4
- package/esm2022/table/table-header-cell.directive.mjs +3 -3
- package/esm2022/table/table-header-row-def.directive.mjs +8 -6
- package/esm2022/table/table-header-row.component.mjs +3 -3
- package/esm2022/table/table-placeholder.directive.mjs +5 -8
- package/esm2022/table/table-row-def.directive.mjs +8 -5
- package/esm2022/table/table-row.component.mjs +5 -6
- package/esm2022/table/table-scroll.directive.mjs +14 -14
- package/esm2022/table/table.component.mjs +9 -9
- package/esm2022/table/table.module.mjs +6 -6
- package/esm2022/table-of-contents/table-of-contents.module.mjs +5 -5
- package/esm2022/table-of-contents/toc-container.directive.mjs +9 -11
- package/esm2022/table-of-contents/toc-content.directive.mjs +3 -7
- package/esm2022/table-of-contents/toc-link.directive.mjs +4 -8
- package/esm2022/tabs/tab-body.component.mjs +19 -23
- package/esm2022/tabs/tab-context.service.mjs +4 -6
- package/esm2022/tabs/tab-group.component.mjs +18 -28
- package/esm2022/tabs/tab-header-active-indicator.component.mjs +5 -7
- package/esm2022/tabs/tab-header.component.mjs +16 -26
- package/esm2022/tabs/tab.component.mjs +10 -17
- package/esm2022/tabs/tabs.module.mjs +6 -6
- package/esm2022/tag/check-tag/check-tag.component.mjs +11 -9
- package/esm2022/tag/tag.component.mjs +16 -14
- package/esm2022/tag/tag.module.mjs +4 -4
- package/esm2022/theme/theme.module.mjs +5 -5
- package/esm2022/theme/theme.pipe.mjs +19 -14
- package/esm2022/theme/theme.service.mjs +7 -10
- package/esm2022/time-picker/component.mjs +19 -21
- package/esm2022/time-picker/panel/panel.component.mjs +17 -29
- package/esm2022/time-picker/time-picker.module.mjs +6 -6
- package/esm2022/tooltip/base-tooltip.mjs +20 -31
- package/esm2022/tooltip/tooltip-active.directive.mjs +5 -7
- package/esm2022/tooltip/tooltip-copy.directive.mjs +4 -9
- package/esm2022/tooltip/tooltip-intl.mjs +8 -6
- package/esm2022/tooltip/tooltip.component.mjs +11 -25
- package/esm2022/tooltip/tooltip.directive.mjs +9 -6
- package/esm2022/tooltip/tooltip.module.mjs +6 -6
- package/esm2022/tree-select/tree-node-placeholder.component.mjs +3 -3
- package/esm2022/tree-select/tree-select.component.mjs +30 -44
- package/esm2022/tree-select/tree-select.module.mjs +6 -6
- package/fesm2022/alauda-ui.mjs +1358 -1660
- package/fesm2022/alauda-ui.mjs.map +1 -1
- package/i18n/i18n.pipe.d.ts +3 -6
- package/i18n/i18n.service.d.ts +3 -6
- package/package.json +1 -1
|
@@ -6,14 +6,14 @@ export class ColorPickerComponent extends CommonFormControl {
|
|
|
6
6
|
onInput(event) {
|
|
7
7
|
this.emitValue(event.target.value);
|
|
8
8
|
}
|
|
9
|
-
static
|
|
10
|
-
static
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ColorPickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
10
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: ColorPickerComponent, isStandalone: true, selector: "aui-color-picker", providers: [
|
|
11
11
|
{
|
|
12
12
|
provide: NG_VALUE_ACCESSOR,
|
|
13
13
|
useExisting: forwardRef(() => ColorPickerComponent),
|
|
14
14
|
multi: true,
|
|
15
15
|
},
|
|
16
|
-
], usesInheritance: true, ngImport: i0, template: "<input\n class=\"aui-color-picker\"\n type=\"color\"\n [disabled]=\"disabled\"\n [value]=\"model\"\n (input)=\"onInput($event)\"\n/>\n", styles: [".aui-color-picker{display:inline-block;padding:3px;width:var(--aui-inline-height-m);height:var(--aui-inline-height-m);border:1px solid rgb(var(--aui-color-n-7));border-radius:var(--aui-border-radius-m);background-color:rgb(var(--aui-color-main-bg));color:rgb(var(--aui-color-main-text));outline:none;cursor:pointer;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal)}.aui-color-picker::-webkit-color-swatch-wrapper{padding:0}.aui-color-picker::-moz-color-swatch-wrapper{padding:0}.aui-color-picker::-webkit-color-swatch{border:none;border-radius:var(--aui-border-radius-m)}.aui-color-picker::-moz-color-swatch{border:none;border-radius:var(--aui-border-radius-m)}.aui-color-picker:hover,.aui-color-picker:focus{border-color:rgb(var(--aui-color-primary))}.aui-color-picker[disabled]{background-color:rgb(var(--aui-color-n-8));border-color:rgb(var(--aui-color-n-7))!important;color:rgb(var(--aui-color-disabled-text));cursor:not-allowed}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
16
|
+
], usesInheritance: true, ngImport: i0, template: "<input\n class=\"aui-color-picker\"\n type=\"color\"\n [disabled]=\"disabled\"\n [value]=\"model\"\n (input)=\"onInput($event)\"\n/>\n", styles: [".aui-color-picker{display:inline-block;padding:3px;width:var(--aui-inline-height-m);height:var(--aui-inline-height-m);border:1px solid rgb(var(--aui-color-n-7));border-radius:var(--aui-border-radius-m);background-color:rgb(var(--aui-color-main-bg));color:rgb(var(--aui-color-main-text));outline:none;cursor:pointer;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal)}.aui-color-picker::-webkit-color-swatch-wrapper{padding:0}.aui-color-picker::-moz-color-swatch-wrapper{padding:0}.aui-color-picker::-webkit-color-swatch{border:none;border-radius:var(--aui-border-radius-m)}.aui-color-picker::-moz-color-swatch{border:none;border-radius:var(--aui-border-radius-m)}.aui-color-picker:hover,.aui-color-picker:focus{border-color:rgb(var(--aui-color-primary))}.aui-color-picker[disabled]{background-color:rgb(var(--aui-color-n-8));border-color:rgb(var(--aui-color-n-7))!important;color:rgb(var(--aui-color-disabled-text));cursor:not-allowed}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
17
17
|
}
|
|
18
18
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ColorPickerComponent, decorators: [{
|
|
19
19
|
type: Component,
|
|
@@ -25,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
25
25
|
},
|
|
26
26
|
], standalone: true, template: "<input\n class=\"aui-color-picker\"\n type=\"color\"\n [disabled]=\"disabled\"\n [value]=\"model\"\n (input)=\"onInput($event)\"\n/>\n", styles: [".aui-color-picker{display:inline-block;padding:3px;width:var(--aui-inline-height-m);height:var(--aui-inline-height-m);border:1px solid rgb(var(--aui-color-n-7));border-radius:var(--aui-border-radius-m);background-color:rgb(var(--aui-color-main-bg));color:rgb(var(--aui-color-main-text));outline:none;cursor:pointer;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal)}.aui-color-picker::-webkit-color-swatch-wrapper{padding:0}.aui-color-picker::-moz-color-swatch-wrapper{padding:0}.aui-color-picker::-webkit-color-swatch{border:none;border-radius:var(--aui-border-radius-m)}.aui-color-picker::-moz-color-swatch{border:none;border-radius:var(--aui-border-radius-m)}.aui-color-picker:hover,.aui-color-picker:focus{border-color:rgb(var(--aui-color-primary))}.aui-color-picker[disabled]{background-color:rgb(var(--aui-color-n-8));border-color:rgb(var(--aui-color-n-7))!important;color:rgb(var(--aui-color-disabled-text));cursor:not-allowed}\n"] }]
|
|
27
27
|
}] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb2xvci1waWNrZXIvY29sb3ItcGlja2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9jb2xvci1waWNrZXIvY29sb3ItcGlja2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULGlCQUFpQixFQUNqQixVQUFVLEdBQ1gsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sU0FBUyxDQUFDOztBQWtCNUMsTUFBTSxPQUFPLG9CQUFxQixTQUFRLGlCQUF5QjtJQUNqRSxPQUFPLENBQUMsS0FBWTtRQUNsQixJQUFJLENBQUMsU0FBUyxDQUFFLEtBQUssQ0FBQyxNQUEyQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNELENBQUM7OEdBSFUsb0JBQW9CO2tHQUFwQixvQkFBb0IsK0RBVHBCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztnQkFDbkQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGlEQ3ZCSCw2SUFPQTs7MkZEbUJhLG9CQUFvQjtrQkFoQmhDLFNBQVM7K0JBQ0Usa0JBQWtCLG1CQUdYLHVCQUF1QixDQUFDLE1BQU0saUJBQ2hDLGlCQUFpQixDQUFDLElBQUksdUJBQ2hCLEtBQUssYUFDZjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxxQkFBcUIsQ0FBQzs0QkFDbkQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0YsY0FDVyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGZvcndhcmRSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IENvbW1vbkZvcm1Db250cm9sIH0gZnJvbSAnLi4vZm9ybSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F1aS1jb2xvci1waWNrZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vY29sb3ItcGlja2VyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY29sb3ItcGlja2VyLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBwcmVzZXJ2ZVdoaXRlc3BhY2VzOiBmYWxzZSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBDb2xvclBpY2tlckNvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBDb2xvclBpY2tlckNvbXBvbmVudCBleHRlbmRzIENvbW1vbkZvcm1Db250cm9sPHN0cmluZz4ge1xuICBvbklucHV0KGV2ZW50OiBFdmVudCkge1xuICAgIHRoaXMuZW1pdFZhbHVlKChldmVudC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9XG59XG4iLCI8aW5wdXRcbiAgY2xhc3M9XCJhdWktY29sb3ItcGlja2VyXCJcbiAgdHlwZT1cImNvbG9yXCJcbiAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgW3ZhbHVlXT1cIm1vZGVsXCJcbiAgKGlucHV0KT1cIm9uSW5wdXQoJGV2ZW50KVwiXG4vPlxuIl19
|
|
@@ -4,9 +4,9 @@ import { FormsModule } from '@angular/forms';
|
|
|
4
4
|
import { ColorPickerComponent } from './color-picker.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class ColorPickerModule {
|
|
7
|
-
static
|
|
8
|
-
static
|
|
9
|
-
static
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ColorPickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.3", ngImport: i0, type: ColorPickerModule, imports: [CommonModule, FormsModule, ColorPickerComponent], exports: [ColorPickerComponent] }); }
|
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ColorPickerModule, imports: [CommonModule, FormsModule] }); }
|
|
10
10
|
}
|
|
11
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: ColorPickerModule, decorators: [{
|
|
12
12
|
type: NgModule,
|
|
@@ -15,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
15
15
|
exports: [ColorPickerComponent],
|
|
16
16
|
}]
|
|
17
17
|
}] });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItcGlja2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb2xvci1waWNrZXIvY29sb3ItcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFN0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBTWhFLE1BQU0sT0FBTyxpQkFBaUI7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLFlBSGxCLFlBQVksRUFBRSxXQUFXLEVBQUUsb0JBQW9CLGFBQy9DLG9CQUFvQjsrR0FFbkIsaUJBQWlCLFlBSGxCLFlBQVksRUFBRSxXQUFXOzsyRkFHeEIsaUJBQWlCO2tCQUo3QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsb0JBQW9CLENBQUM7b0JBQzFELE9BQU8sRUFBRSxDQUFDLG9CQUFvQixDQUFDO2lCQUNoQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IENvbG9yUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jb2xvci1waWNrZXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIENvbG9yUGlja2VyQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0NvbG9yUGlja2VyQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgQ29sb3JQaWNrZXJNb2R1bGUge31cbiJdfQ==
|
|
@@ -15,8 +15,19 @@ import { getNavRangeByType, getTimePickerModel, getTypeByNavRange, nextNavRangeT
|
|
|
15
15
|
import * as i0 from "@angular/core";
|
|
16
16
|
import * as i1 from "@angular/forms";
|
|
17
17
|
export class DatePickerPanelComponent extends CommonFormControl {
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
constructor() {
|
|
19
|
+
super(...arguments);
|
|
20
|
+
this.clearable = true;
|
|
21
|
+
this.showTime = false;
|
|
22
|
+
this.disabledDate = () => false;
|
|
23
|
+
this.disabledTime = () => null;
|
|
24
|
+
this.weekStartDay = 0;
|
|
25
|
+
this.showFooter = true;
|
|
26
|
+
this.confirm = new EventEmitter();
|
|
27
|
+
this.clear = new EventEmitter();
|
|
28
|
+
this.DateNavRange = DateNavRange;
|
|
29
|
+
this.DatePickerType = DatePickerType;
|
|
30
|
+
}
|
|
20
31
|
set type(type) {
|
|
21
32
|
this.navRange = getNavRangeByType(type);
|
|
22
33
|
this._type = type;
|
|
@@ -24,20 +35,6 @@ export class DatePickerPanelComponent extends CommonFormControl {
|
|
|
24
35
|
get type() {
|
|
25
36
|
return this._type;
|
|
26
37
|
}
|
|
27
|
-
_type;
|
|
28
|
-
showTime = false;
|
|
29
|
-
disabledDate = () => false;
|
|
30
|
-
disabledTime = () => null;
|
|
31
|
-
weekStartDay = 0;
|
|
32
|
-
showFooter = true;
|
|
33
|
-
footerTemplate;
|
|
34
|
-
extraFooter;
|
|
35
|
-
minDate;
|
|
36
|
-
maxDate;
|
|
37
|
-
confirm = new EventEmitter();
|
|
38
|
-
clear = new EventEmitter();
|
|
39
|
-
_cacheSelectedDate;
|
|
40
|
-
_cacheDisabledTimeFn;
|
|
41
38
|
getDisabledTimeFn(selectedDate, type) {
|
|
42
39
|
if (selectedDate !== this._cacheSelectedDate) {
|
|
43
40
|
this._cacheDisabledTimeFn = combineDisabledTimeFn(this._disabledTimeFn.bind(this), this.disabledTime)(selectedDate);
|
|
@@ -45,15 +42,9 @@ export class DatePickerPanelComponent extends CommonFormControl {
|
|
|
45
42
|
}
|
|
46
43
|
return this._cacheDisabledTimeFn?.[type];
|
|
47
44
|
}
|
|
48
|
-
navRange;
|
|
49
45
|
get currentNavType() {
|
|
50
46
|
return getTypeByNavRange(this.navRange);
|
|
51
47
|
}
|
|
52
|
-
anchor;
|
|
53
|
-
selectedDate;
|
|
54
|
-
selectedTime;
|
|
55
|
-
DateNavRange = DateNavRange;
|
|
56
|
-
DatePickerType = DatePickerType;
|
|
57
48
|
writeValue(obj) {
|
|
58
49
|
super.writeValue(obj);
|
|
59
50
|
this.selectedDate = obj;
|
|
@@ -115,14 +106,14 @@ export class DatePickerPanelComponent extends CommonFormControl {
|
|
|
115
106
|
seconds: () => [],
|
|
116
107
|
};
|
|
117
108
|
}
|
|
118
|
-
static
|
|
119
|
-
static
|
|
109
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DatePickerPanelComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
110
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: DatePickerPanelComponent, isStandalone: true, selector: "aui-date-picker-panel", inputs: { clearable: "clearable", clearText: "clearText", type: "type", showTime: "showTime", disabledDate: "disabledDate", disabledTime: "disabledTime", weekStartDay: "weekStartDay", showFooter: "showFooter", footerTemplate: "footerTemplate", extraFooter: "extraFooter", minDate: "minDate", maxDate: "maxDate" }, outputs: { confirm: "confirm", clear: "clear" }, providers: [
|
|
120
111
|
{
|
|
121
112
|
provide: NG_VALUE_ACCESSOR,
|
|
122
113
|
useExisting: forwardRef(() => DatePickerPanelComponent),
|
|
123
114
|
multi: true,
|
|
124
115
|
},
|
|
125
|
-
], usesInheritance: true, ngImport: i0, template: "<div class=\"aui-date-picker-panel__wrapper\">\n <aui-calendar-header\n [dateNavRange]=\"navRange\"\n [anchor]=\"anchor\"\n [minAvail]=\"minDate\"\n [maxAvail]=\"maxDate\"\n [style.margin-inline.px]=\"4\"\n (navRangeChange)=\"navRange = $event\"\n (anchorChange)=\"anchor = $event\"\n ></aui-calendar-header>\n\n <aui-picker-panel\n [style.margin]=\"'16px 0'\"\n [anchor]=\"anchor\"\n [navRange]=\"navRange\"\n [disabledDate]=\"disabledDate\"\n [weekStartDay]=\"weekStartDay\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [type]=\"type\"\n [matchDates]=\"[selectedDate]\"\n (select)=\"panelValueChange($event)\"\n ></aui-picker-panel>\n\n <ng-container\n *ngIf=\"extraFooter\"\n [ngTemplateOutlet]=\"extraFooter\"\n [ngTemplateOutletContext]=\"{ context: this }\"\n ></ng-container>\n\n <ng-container *ngIf=\"showFooter\">\n <aui-calendar-footer\n (clear)=\"clear.next()\"\n (confirm)=\"confirmValue()\"\n [clearable]=\"clearable\"\n [clearText]=\"clearText\"\n *ngIf=\"showTime; else today\"\n >\n <ng-container\n *ngIf=\"footerTemplate; else default\"\n [ngTemplateOutlet]=\"footerTemplate\"\n [ngTemplateOutletContext]=\"{ context: this }\"\n ></ng-container>\n\n <ng-template #default>\n <aui-time-picker\n *ngIf=\"currentNavType === DatePickerType.Day && showTime\"\n [showIcon]=\"false\"\n size=\"small\"\n [(ngModel)]=\"selectedTime\"\n [disableHours]=\"getDisabledTimeFn(selectedDate, 'hours')\"\n [disableMinutes]=\"getDisabledTimeFn(selectedDate, 'minutes')\"\n [disableSeconds]=\"getDisabledTimeFn(selectedDate, 'seconds')\"\n tooltipPosition=\"top start\"\n (ngModelChange)=\"timeDateChange($event)\"\n [placeholder]=\"'select_time' | auiI18n\"\n ></aui-time-picker>\n </ng-template>\n </aui-calendar-footer>\n\n <ng-template #today>\n <aui-calendar-footer\n *ngIf=\"type === DatePickerType.Day\"\n (clear)=\"clearValue()\"\n [clearable]=\"false\"\n [customAction]=\"todayBtn\"\n >\n </aui-calendar-footer>\n <ng-template #todayBtn>\n <button\n aui-button=\"inline\"\n (click)=\"setToday()\"\n >\n {{ 'today' | auiI18n }}\n </button>\n </ng-template>\n </ng-template>\n </ng-container>\n</div>\n", styles: [".aui-date-picker-panel__wrapper{display:flex;flex-direction:column;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal)}.aui-date-picker-panel__wrapper .aui-time-picker{width:88px}\n"], dependencies: [{ kind: "component", type: CalendarHeaderComponent, selector: "aui-calendar-header", inputs: ["dateNavRange", "anchor", "maxAvail", "minAvail"], outputs: ["navRangeChange", "anchorChange"] }, { kind: "component", type: PickerPanelComponent, selector: "aui-picker-panel", inputs: ["navRange", "type", "anchor", "matchDates", "disabledDate", "weekStartDay", "minDate", "maxDate"], outputs: ["select", "hovered"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: CalendarFooterComponent, selector: "aui-calendar-footer", inputs: ["clearable", "clearText", "customAction"], outputs: ["confirm", "clear"] }, { kind: "component", type: TimePickerComponent, selector: "aui-time-picker", inputs: ["format", "size", "placeholder", "clearable", "showIcon", "disableHours", "disableMinutes", "disableSeconds", "hourStep", "minuteStep", "secondStep", "footerTemplate"], outputs: ["open", "close"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ButtonComponent, selector: "button[aui-button]", inputs: ["aui-button", "size", "plain", "loading", "round", "square"] }, { kind: "pipe", type: I18nPipe, name: "auiI18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
116
|
+
], usesInheritance: true, ngImport: i0, template: "<div class=\"aui-date-picker-panel__wrapper\">\n <aui-calendar-header\n [dateNavRange]=\"navRange\"\n [anchor]=\"anchor\"\n [minAvail]=\"minDate\"\n [maxAvail]=\"maxDate\"\n [style.margin-inline.px]=\"4\"\n (navRangeChange)=\"navRange = $event\"\n (anchorChange)=\"anchor = $event\"\n ></aui-calendar-header>\n\n <aui-picker-panel\n [style.margin]=\"'16px 0'\"\n [anchor]=\"anchor\"\n [navRange]=\"navRange\"\n [disabledDate]=\"disabledDate\"\n [weekStartDay]=\"weekStartDay\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [type]=\"type\"\n [matchDates]=\"[selectedDate]\"\n (select)=\"panelValueChange($event)\"\n ></aui-picker-panel>\n\n <ng-container\n *ngIf=\"extraFooter\"\n [ngTemplateOutlet]=\"extraFooter\"\n [ngTemplateOutletContext]=\"{ context: this }\"\n ></ng-container>\n\n <ng-container *ngIf=\"showFooter\">\n <aui-calendar-footer\n (clear)=\"clear.next()\"\n (confirm)=\"confirmValue()\"\n [clearable]=\"clearable\"\n [clearText]=\"clearText\"\n *ngIf=\"showTime; else today\"\n >\n <ng-container\n *ngIf=\"footerTemplate; else default\"\n [ngTemplateOutlet]=\"footerTemplate\"\n [ngTemplateOutletContext]=\"{ context: this }\"\n ></ng-container>\n\n <ng-template #default>\n <aui-time-picker\n *ngIf=\"currentNavType === DatePickerType.Day && showTime\"\n [showIcon]=\"false\"\n size=\"small\"\n [(ngModel)]=\"selectedTime\"\n [disableHours]=\"getDisabledTimeFn(selectedDate, 'hours')\"\n [disableMinutes]=\"getDisabledTimeFn(selectedDate, 'minutes')\"\n [disableSeconds]=\"getDisabledTimeFn(selectedDate, 'seconds')\"\n tooltipPosition=\"top start\"\n (ngModelChange)=\"timeDateChange($event)\"\n [placeholder]=\"'select_time' | auiI18n\"\n ></aui-time-picker>\n </ng-template>\n </aui-calendar-footer>\n\n <ng-template #today>\n <aui-calendar-footer\n *ngIf=\"type === DatePickerType.Day\"\n (clear)=\"clearValue()\"\n [clearable]=\"false\"\n [customAction]=\"todayBtn\"\n >\n </aui-calendar-footer>\n <ng-template #todayBtn>\n <button\n aui-button=\"inline\"\n (click)=\"setToday()\"\n >\n {{ 'today' | auiI18n }}\n </button>\n </ng-template>\n </ng-template>\n </ng-container>\n</div>\n", styles: [".aui-date-picker-panel__wrapper{display:flex;flex-direction:column;font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);font-weight:var(--aui-font-weight-normal)}.aui-date-picker-panel__wrapper .aui-time-picker{width:88px}\n"], dependencies: [{ kind: "component", type: CalendarHeaderComponent, selector: "aui-calendar-header", inputs: ["dateNavRange", "anchor", "maxAvail", "minAvail"], outputs: ["navRangeChange", "anchorChange"] }, { kind: "component", type: PickerPanelComponent, selector: "aui-picker-panel", inputs: ["navRange", "type", "anchor", "matchDates", "disabledDate", "weekStartDay", "minDate", "maxDate"], outputs: ["select", "hovered"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: CalendarFooterComponent, selector: "aui-calendar-footer", inputs: ["clearable", "clearText", "customAction"], outputs: ["confirm", "clear"] }, { kind: "component", type: TimePickerComponent, selector: "aui-time-picker", inputs: ["format", "size", "placeholder", "clearable", "showIcon", "disableHours", "disableMinutes", "disableSeconds", "hourStep", "minuteStep", "secondStep", "footerTemplate"], outputs: ["open", "close"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ButtonComponent, selector: "button[aui-button]", inputs: ["aui-button", "size", "plain", "loading", "round", "square"] }, { kind: "pipe", type: I18nPipe, name: "auiI18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
126
117
|
}
|
|
127
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: DatePickerPanelComponent, decorators: [{
|
|
128
119
|
type: Component,
|
|
@@ -179,4 +170,4 @@ function combineDisabledTimeFn(...disabledFnList) {
|
|
|
179
170
|
seconds: (hour, minute) => Array.from(new Set(disabledFnList.flatMap(fn => fn(date)?.seconds(hour, minute) || []))),
|
|
180
171
|
});
|
|
181
172
|
}
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/date-picker-panel/component.ts","../../../../../src/date-picker/calendar/date-picker-panel/template.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,iBAAiB,EACjB,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAChE,OAAO,KAA4B,MAAM,OAAO,CAAC;AAEjD,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACnD,OAAO,EACL,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,mBAAmB,GAEpB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,YAAY,EAAkB,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,UAAU,EACV,qBAAqB,GACtB,MAAM,SAAS,CAAC;;;AA4BjB,MAAM,OAAO,wBAAyB,SAAQ,iBAAwB;IAEpE,SAAS,GAAG,IAAI,CAAC;IAGjB,SAAS,CAAS;IAElB,IACI,IAAI,CAAC,IAAoB;QAC3B,IAAI,CAAC,QAAQ,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAEO,KAAK,CAAiB;IAG9B,QAAQ,GAAG,KAAK,CAAC;IAGjB,YAAY,GAAiD,GAAG,EAAE,CAAC,KAAK,CAAC;IAGzE,YAAY,GAAmB,GAAG,EAAE,CAAC,IAAI,CAAC;IAG1C,YAAY,GAAG,CAAC,CAAC;IAGjB,UAAU,GAAG,IAAI,CAAC;IAGlB,cAAc,CAAuB;IAGrC,WAAW,CAAuB;IAGlC,OAAO,CAAQ;IAGf,OAAO,CAAQ;IAGf,OAAO,GAAG,IAAI,YAAY,EAAS,CAAC;IAGpC,KAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;IAEzB,kBAAkB,CAAQ;IAC1B,oBAAoB,CAA6B;IAEzD,iBAAiB,CACf,YAAmB,EACnB,IAAsC;QAEtC,IAAI,YAAY,KAAK,IAAI,CAAC,kBAAkB,EAAE;YAC5C,IAAI,CAAC,oBAAoB,GAAG,qBAAqB,CAC/C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,EAC/B,IAAI,CAAC,YAAY,CAClB,CAAC,YAAY,CAAC,CAAC;YAChB,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC;SACxC;QACD,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,IAAI,CAAC,CAAC;IAC3C,CAAC;IAED,QAAQ,CAAe;IAEvB,IAAI,cAAc;QAChB,OAAO,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC1C,CAAC;IAED,MAAM,CAAQ;IAEd,YAAY,CAAQ;IAEpB,YAAY,CAAkB;IAE9B,YAAY,GAAG,YAAY,CAAC;IAC5B,cAAc,GAAG,cAAc,CAAC;IAEvB,UAAU,CAAC,GAAU;QAC5B,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,CAAC,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;QAC7B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,KAAY;QAC3B,IAAI,CAAC,YAAY,GAAG,UAAU,CAC5B,IAAI,CAAC,YAAY,IAAI,KAAK,EAAE,EAC5B,KAAK,EACL,IAAI,CAAC,cAAc,CACpB,CAAC;QACF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,qBAAqB,CACvC,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,YAAY,CAClB,CAAC;QACF,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,cAAc,EAAE;YACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtD;QACD,MAAM,YAAY,GAAG,gBAAgB,CACnC,IAAI,CAAC,QAAQ,EACb,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAC7B,CAAC;QACF,IAAI,IAAI,CAAC,QAAQ,KAAK,YAAY,EAAE;YAClC,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC;SAC9B;IACH,CAAC;IAED,YAAY,CAAC,KAAkB,EAAE,iBAAiB,GAAG,IAAI;QACvD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACzD,iBAAiB,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAED,cAAc,CAAC,IAAqB;QAClC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,OAAO;SACR;QACD,IAAI,CAAC,YAAY,GAAG,qBAAqB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QACnE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACpC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,UAAU;QACR,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAEO,eAAe,CACrB,YAAmB;QAEnB,MAAM,aAAa,GAAG,CACpB,IAAW,EACX,UAA6C,EAC7C,EAAE,CAAC,CAAC;YACJ,KAAK,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YACrE,OAAO,EAAE,CAAC,IAAa,EAAE,EAAE,CACzB,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE;gBAClB,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;gBAC9D,CAAC,CAAC,EAAE;YACR,OAAO,EAAE,CAAC,IAAa,EAAE,MAAe,EAAE,EAAE,CAC1C,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE,IAAI,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE;gBAC9C,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;gBAC9D,CAAC,CAAC,EAAE;SACT,CAAC,CAAC;QAEH,IAAI,YAAY,EAAE;YAChB,IAAI,IAAI,CAAC,OAAO,IAAI,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE;gBAC7D,OAAO,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aACrD;YACD,IAAI,IAAI,CAAC,OAAO,IAAI,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE;gBAC7D,OAAO,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aACrD;SACF;QAED,OAAO;YACL,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE;YACf,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE;YACjB,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE;SAClB,CAAC;IACJ,CAAC;uGAzKU,wBAAwB;2FAAxB,wBAAwB,+aApBxB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC;gBACvD,KAAK,EAAE,IAAI;aACZ;SACF,iDClDH,o6EA+EA,2SD1BI,uBAAuB,yKACvB,oBAAoB,yMACpB,IAAI,6FACJ,gBAAgB,oJAChB,uBAAuB,mJACvB,mBAAmB,yQACnB,WAAW,+VACX,eAAe,iIACf,QAAQ;;2FAGC,wBAAwB;kBA1BpC,SAAS;+BACE,uBAAuB,mBAGhB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,yBAAyB,CAAC;4BACvD,KAAK,EAAE,IAAI;yBACZ;qBACF,cACW,IAAI,WACP;wBACP,uBAAuB;wBACvB,oBAAoB;wBACpB,IAAI;wBACJ,gBAAgB;wBAChB,uBAAuB;wBACvB,mBAAmB;wBACnB,WAAW;wBACX,eAAe;wBACf,QAAQ;qBACT;8BAID,SAAS;sBADR,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIF,IAAI;sBADP,KAAK;gBAaN,QAAQ;sBADP,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,cAAc;sBADb,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,OAAO;sBADN,MAAM;gBAIP,KAAK;sBADJ,MAAM;;AA2HT,SAAS,qBAAqB,CAC5B,GAAG,cAAgC;IAEnC,OAAO,CAAC,IAAW,EAAE,EAAE,CAAC,CAAC;QACvB,KAAK,EAAE,GAAG,EAAE,CACV,KAAK,CAAC,IAAI,CACR,IAAI,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAC/D;QACH,OAAO,EAAE,CAAC,IAAa,EAAE,EAAE,CACzB,KAAK,CAAC,IAAI,CACR,IAAI,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CACrE;QACH,OAAO,EAAE,CAAC,IAAa,EAAE,MAAe,EAAE,EAAE,CAC1C,KAAK,CAAC,IAAI,CACR,IAAI,GAAG,CACL,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CACpE,CACF;KACJ,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { ButtonComponent } from '../../../button/button.component';\nimport { CommonFormControl } from '../../../form/common-form';\nimport { I18nPipe } from '../../../i18n/i18n.pipe';\nimport {\n  HOUR_ITEMS,\n  MINUTE_ITEMS,\n  SECOND_ITEMS,\n  TimePickerComponent,\n  TimePickerModel,\n} from '../../../time-picker';\nimport { DateNavRange, DisabledTimeFn } from '../../date-picker.type';\nimport { DatePickerType } from '../constant';\nimport { CalendarFooterComponent } from '../footer/component';\nimport { CalendarHeaderComponent } from '../header/component';\nimport { PickerPanelComponent } from '../panel/picker-panel';\nimport {\n  getNavRangeByType,\n  getTimePickerModel,\n  getTypeByNavRange,\n  nextNavRangeType,\n  updateDate,\n  updateDateByTimeModel,\n} from '../util';\n\n@Component({\n  selector: 'aui-date-picker-panel',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerPanelComponent),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    CalendarHeaderComponent,\n    PickerPanelComponent,\n    NgIf,\n    NgTemplateOutlet,\n    CalendarFooterComponent,\n    TimePickerComponent,\n    FormsModule,\n    ButtonComponent,\n    I18nPipe,\n  ],\n})\nexport class DatePickerPanelComponent extends CommonFormControl<Dayjs> {\n  @Input()\n  clearable = true;\n\n  @Input()\n  clearText: string;\n\n  @Input()\n  set type(type: DatePickerType) {\n    this.navRange = getNavRangeByType(type);\n    this._type = type;\n  }\n\n  get type() {\n    return this._type;\n  }\n\n  private _type: DatePickerType;\n\n  @Input()\n  showTime = false;\n\n  @Input()\n  disabledDate: (date: Dayjs, type: DateNavRange) => boolean = () => false;\n\n  @Input()\n  disabledTime: DisabledTimeFn = () => null;\n\n  @Input()\n  weekStartDay = 0;\n\n  @Input()\n  showFooter = true;\n\n  @Input()\n  footerTemplate: TemplateRef<unknown>;\n\n  @Input()\n  extraFooter: TemplateRef<unknown>;\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  @Output()\n  confirm = new EventEmitter<Dayjs>();\n\n  @Output()\n  clear = new EventEmitter<void>();\n\n  private _cacheSelectedDate: Dayjs;\n  private _cacheDisabledTimeFn: ReturnType<DisabledTimeFn>;\n\n  getDisabledTimeFn(\n    selectedDate: Dayjs,\n    type: keyof ReturnType<DisabledTimeFn>,\n  ) {\n    if (selectedDate !== this._cacheSelectedDate) {\n      this._cacheDisabledTimeFn = combineDisabledTimeFn(\n        this._disabledTimeFn.bind(this),\n        this.disabledTime,\n      )(selectedDate);\n      this._cacheSelectedDate = selectedDate;\n    }\n    return this._cacheDisabledTimeFn?.[type];\n  }\n\n  navRange: DateNavRange;\n\n  get currentNavType() {\n    return getTypeByNavRange(this.navRange);\n  }\n\n  anchor: Dayjs;\n\n  selectedDate: Dayjs;\n\n  selectedTime: TimePickerModel;\n\n  DateNavRange = DateNavRange;\n  DatePickerType = DatePickerType;\n\n  override writeValue(obj: Dayjs) {\n    super.writeValue(obj);\n    this.selectedDate = obj;\n    this.selectedTime = getTimePickerModel(obj);\n    this.anchor = obj || dayjs();\n    this.cdr.markForCheck();\n  }\n\n  panelValueChange(value: Dayjs) {\n    this.selectedDate = updateDate(\n      this.selectedDate || dayjs(),\n      value,\n      this.currentNavType,\n    );\n    this.anchor = this.selectedDate;\n    this.selectedDate = updateDateByTimeModel(\n      this.selectedDate,\n      this.selectedTime,\n    );\n    if (this.type === this.currentNavType) {\n      this.confirmValue(this.selectedDate, !this.showTime);\n    }\n    const nextNavRange = nextNavRangeType(\n      this.navRange,\n      getNavRangeByType(this.type),\n    );\n    if (this.navRange !== nextNavRange) {\n      this.navRange = nextNavRange;\n    }\n  }\n\n  confirmValue(value?: ConfigType, closeAfterConfirm = true) {\n    this.emitValue(value ? dayjs(value) : this.selectedDate);\n    closeAfterConfirm && this.confirm.next(null);\n  }\n\n  timeDateChange(time: TimePickerModel) {\n    if (!this.selectedDate) {\n      return;\n    }\n    this.selectedDate = updateDateByTimeModel(this.selectedDate, time);\n    this.emitValue(this.selectedDate);\n  }\n\n  setToday() {\n    this.confirmValue(dayjs(), true);\n  }\n\n  clearValue() {\n    this.selectedTime = null;\n    this.clear.next();\n  }\n\n  private _disabledTimeFn(\n    selectedDate: Dayjs,\n  ): Record<keyof ReturnType<DisabledTimeFn>, () => number[]> {\n    const getTimeFilter = (\n      date: Dayjs,\n      comparator: (a: number, b: number) => boolean,\n    ) => ({\n      hours: () => HOUR_ITEMS.filter(item => comparator(item, date.hour())),\n      minutes: (hour?: number) =>\n        hour === date.hour()\n          ? MINUTE_ITEMS.filter(item => comparator(item, date.minute()))\n          : [],\n      seconds: (hour?: number, minute?: number) =>\n        hour === date.hour() && minute === date.minute()\n          ? SECOND_ITEMS.filter(item => comparator(item, date.second()))\n          : [],\n    });\n\n    if (selectedDate) {\n      if (this.minDate && selectedDate.isSame(this.minDate, 'date')) {\n        return getTimeFilter(this.minDate, (a, b) => a < b);\n      }\n      if (this.maxDate && selectedDate.isSame(this.maxDate, 'date')) {\n        return getTimeFilter(this.maxDate, (a, b) => a > b);\n      }\n    }\n\n    return {\n      hours: () => [],\n      minutes: () => [],\n      seconds: () => [],\n    };\n  }\n}\n\nfunction combineDisabledTimeFn(\n  ...disabledFnList: DisabledTimeFn[]\n): DisabledTimeFn {\n  return (date: Dayjs) => ({\n    hours: () =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.hours() || [])),\n      ),\n    minutes: (hour?: number) =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.minutes(hour) || [])),\n      ),\n    seconds: (hour?: number, minute?: number) =>\n      Array.from(\n        new Set(\n          disabledFnList.flatMap(fn => fn(date)?.seconds(hour, minute) || []),\n        ),\n      ),\n  });\n}\n","<div class=\"aui-date-picker-panel__wrapper\">\n  <aui-calendar-header\n    [dateNavRange]=\"navRange\"\n    [anchor]=\"anchor\"\n    [minAvail]=\"minDate\"\n    [maxAvail]=\"maxDate\"\n    [style.margin-inline.px]=\"4\"\n    (navRangeChange)=\"navRange = $event\"\n    (anchorChange)=\"anchor = $event\"\n  ></aui-calendar-header>\n\n  <aui-picker-panel\n    [style.margin]=\"'16px 0'\"\n    [anchor]=\"anchor\"\n    [navRange]=\"navRange\"\n    [disabledDate]=\"disabledDate\"\n    [weekStartDay]=\"weekStartDay\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [type]=\"type\"\n    [matchDates]=\"[selectedDate]\"\n    (select)=\"panelValueChange($event)\"\n  ></aui-picker-panel>\n\n  <ng-container\n    *ngIf=\"extraFooter\"\n    [ngTemplateOutlet]=\"extraFooter\"\n    [ngTemplateOutletContext]=\"{ context: this }\"\n  ></ng-container>\n\n  <ng-container *ngIf=\"showFooter\">\n    <aui-calendar-footer\n      (clear)=\"clear.next()\"\n      (confirm)=\"confirmValue()\"\n      [clearable]=\"clearable\"\n      [clearText]=\"clearText\"\n      *ngIf=\"showTime; else today\"\n    >\n      <ng-container\n        *ngIf=\"footerTemplate; else default\"\n        [ngTemplateOutlet]=\"footerTemplate\"\n        [ngTemplateOutletContext]=\"{ context: this }\"\n      ></ng-container>\n\n      <ng-template #default>\n        <aui-time-picker\n          *ngIf=\"currentNavType === DatePickerType.Day && showTime\"\n          [showIcon]=\"false\"\n          size=\"small\"\n          [(ngModel)]=\"selectedTime\"\n          [disableHours]=\"getDisabledTimeFn(selectedDate, 'hours')\"\n          [disableMinutes]=\"getDisabledTimeFn(selectedDate, 'minutes')\"\n          [disableSeconds]=\"getDisabledTimeFn(selectedDate, 'seconds')\"\n          tooltipPosition=\"top start\"\n          (ngModelChange)=\"timeDateChange($event)\"\n          [placeholder]=\"'select_time' | auiI18n\"\n        ></aui-time-picker>\n      </ng-template>\n    </aui-calendar-footer>\n\n    <ng-template #today>\n      <aui-calendar-footer\n        *ngIf=\"type === DatePickerType.Day\"\n        (clear)=\"clearValue()\"\n        [clearable]=\"false\"\n        [customAction]=\"todayBtn\"\n      >\n      </aui-calendar-footer>\n      <ng-template #todayBtn>\n        <button\n          aui-button=\"inline\"\n          (click)=\"setToday()\"\n        >\n          {{ 'today' | auiI18n }}\n        </button>\n      </ng-template>\n    </ng-template>\n  </ng-container>\n</div>\n"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/date-picker-panel/component.ts","../../../../../src/date-picker/calendar/date-picker-panel/template.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { ButtonComponent } from '../../../button/button.component';\nimport { CommonFormControl } from '../../../form/common-form';\nimport { I18nPipe } from '../../../i18n/i18n.pipe';\nimport {\n  HOUR_ITEMS,\n  MINUTE_ITEMS,\n  SECOND_ITEMS,\n  TimePickerComponent,\n  TimePickerModel,\n} from '../../../time-picker';\nimport { DateNavRange, DisabledTimeFn } from '../../date-picker.type';\nimport { DatePickerType } from '../constant';\nimport { CalendarFooterComponent } from '../footer/component';\nimport { CalendarHeaderComponent } from '../header/component';\nimport { PickerPanelComponent } from '../panel/picker-panel';\nimport {\n  getNavRangeByType,\n  getTimePickerModel,\n  getTypeByNavRange,\n  nextNavRangeType,\n  updateDate,\n  updateDateByTimeModel,\n} from '../util';\n\n@Component({\n  selector: 'aui-date-picker-panel',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerPanelComponent),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    CalendarHeaderComponent,\n    PickerPanelComponent,\n    NgIf,\n    NgTemplateOutlet,\n    CalendarFooterComponent,\n    TimePickerComponent,\n    FormsModule,\n    ButtonComponent,\n    I18nPipe,\n  ],\n})\nexport class DatePickerPanelComponent extends CommonFormControl<Dayjs> {\n  @Input()\n  clearable = true;\n\n  @Input()\n  clearText: string;\n\n  @Input()\n  set type(type: DatePickerType) {\n    this.navRange = getNavRangeByType(type);\n    this._type = type;\n  }\n\n  get type() {\n    return this._type;\n  }\n\n  private _type: DatePickerType;\n\n  @Input()\n  showTime = false;\n\n  @Input()\n  disabledDate: (date: Dayjs, type: DateNavRange) => boolean = () => false;\n\n  @Input()\n  disabledTime: DisabledTimeFn = () => null;\n\n  @Input()\n  weekStartDay = 0;\n\n  @Input()\n  showFooter = true;\n\n  @Input()\n  footerTemplate: TemplateRef<unknown>;\n\n  @Input()\n  extraFooter: TemplateRef<unknown>;\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  @Output()\n  confirm = new EventEmitter<Dayjs>();\n\n  @Output()\n  clear = new EventEmitter<void>();\n\n  private _cacheSelectedDate: Dayjs;\n  private _cacheDisabledTimeFn: ReturnType<DisabledTimeFn>;\n\n  getDisabledTimeFn(\n    selectedDate: Dayjs,\n    type: keyof ReturnType<DisabledTimeFn>,\n  ) {\n    if (selectedDate !== this._cacheSelectedDate) {\n      this._cacheDisabledTimeFn = combineDisabledTimeFn(\n        this._disabledTimeFn.bind(this),\n        this.disabledTime,\n      )(selectedDate);\n      this._cacheSelectedDate = selectedDate;\n    }\n    return this._cacheDisabledTimeFn?.[type];\n  }\n\n  navRange: DateNavRange;\n\n  get currentNavType() {\n    return getTypeByNavRange(this.navRange);\n  }\n\n  anchor: Dayjs;\n\n  selectedDate: Dayjs;\n\n  selectedTime: TimePickerModel;\n\n  DateNavRange = DateNavRange;\n  DatePickerType = DatePickerType;\n\n  override writeValue(obj: Dayjs) {\n    super.writeValue(obj);\n    this.selectedDate = obj;\n    this.selectedTime = getTimePickerModel(obj);\n    this.anchor = obj || dayjs();\n    this.cdr.markForCheck();\n  }\n\n  panelValueChange(value: Dayjs) {\n    this.selectedDate = updateDate(\n      this.selectedDate || dayjs(),\n      value,\n      this.currentNavType,\n    );\n    this.anchor = this.selectedDate;\n    this.selectedDate = updateDateByTimeModel(\n      this.selectedDate,\n      this.selectedTime,\n    );\n    if (this.type === this.currentNavType) {\n      this.confirmValue(this.selectedDate, !this.showTime);\n    }\n    const nextNavRange = nextNavRangeType(\n      this.navRange,\n      getNavRangeByType(this.type),\n    );\n    if (this.navRange !== nextNavRange) {\n      this.navRange = nextNavRange;\n    }\n  }\n\n  confirmValue(value?: ConfigType, closeAfterConfirm = true) {\n    this.emitValue(value ? dayjs(value) : this.selectedDate);\n    closeAfterConfirm && this.confirm.next(null);\n  }\n\n  timeDateChange(time: TimePickerModel) {\n    if (!this.selectedDate) {\n      return;\n    }\n    this.selectedDate = updateDateByTimeModel(this.selectedDate, time);\n    this.emitValue(this.selectedDate);\n  }\n\n  setToday() {\n    this.confirmValue(dayjs(), true);\n  }\n\n  clearValue() {\n    this.selectedTime = null;\n    this.clear.next();\n  }\n\n  private _disabledTimeFn(\n    selectedDate: Dayjs,\n  ): Record<keyof ReturnType<DisabledTimeFn>, () => number[]> {\n    const getTimeFilter = (\n      date: Dayjs,\n      comparator: (a: number, b: number) => boolean,\n    ) => ({\n      hours: () => HOUR_ITEMS.filter(item => comparator(item, date.hour())),\n      minutes: (hour?: number) =>\n        hour === date.hour()\n          ? MINUTE_ITEMS.filter(item => comparator(item, date.minute()))\n          : [],\n      seconds: (hour?: number, minute?: number) =>\n        hour === date.hour() && minute === date.minute()\n          ? SECOND_ITEMS.filter(item => comparator(item, date.second()))\n          : [],\n    });\n\n    if (selectedDate) {\n      if (this.minDate && selectedDate.isSame(this.minDate, 'date')) {\n        return getTimeFilter(this.minDate, (a, b) => a < b);\n      }\n      if (this.maxDate && selectedDate.isSame(this.maxDate, 'date')) {\n        return getTimeFilter(this.maxDate, (a, b) => a > b);\n      }\n    }\n\n    return {\n      hours: () => [],\n      minutes: () => [],\n      seconds: () => [],\n    };\n  }\n}\n\nfunction combineDisabledTimeFn(\n  ...disabledFnList: DisabledTimeFn[]\n): DisabledTimeFn {\n  return (date: Dayjs) => ({\n    hours: () =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.hours() || [])),\n      ),\n    minutes: (hour?: number) =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.minutes(hour) || [])),\n      ),\n    seconds: (hour?: number, minute?: number) =>\n      Array.from(\n        new Set(\n          disabledFnList.flatMap(fn => fn(date)?.seconds(hour, minute) || []),\n        ),\n      ),\n  });\n}\n","<div class=\"aui-date-picker-panel__wrapper\">\n  <aui-calendar-header\n    [dateNavRange]=\"navRange\"\n    [anchor]=\"anchor\"\n    [minAvail]=\"minDate\"\n    [maxAvail]=\"maxDate\"\n    [style.margin-inline.px]=\"4\"\n    (navRangeChange)=\"navRange = $event\"\n    (anchorChange)=\"anchor = $event\"\n  ></aui-calendar-header>\n\n  <aui-picker-panel\n    [style.margin]=\"'16px 0'\"\n    [anchor]=\"anchor\"\n    [navRange]=\"navRange\"\n    [disabledDate]=\"disabledDate\"\n    [weekStartDay]=\"weekStartDay\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [type]=\"type\"\n    [matchDates]=\"[selectedDate]\"\n    (select)=\"panelValueChange($event)\"\n  ></aui-picker-panel>\n\n  <ng-container\n    *ngIf=\"extraFooter\"\n    [ngTemplateOutlet]=\"extraFooter\"\n    [ngTemplateOutletContext]=\"{ context: this }\"\n  ></ng-container>\n\n  <ng-container *ngIf=\"showFooter\">\n    <aui-calendar-footer\n      (clear)=\"clear.next()\"\n      (confirm)=\"confirmValue()\"\n      [clearable]=\"clearable\"\n      [clearText]=\"clearText\"\n      *ngIf=\"showTime; else today\"\n    >\n      <ng-container\n        *ngIf=\"footerTemplate; else default\"\n        [ngTemplateOutlet]=\"footerTemplate\"\n        [ngTemplateOutletContext]=\"{ context: this }\"\n      ></ng-container>\n\n      <ng-template #default>\n        <aui-time-picker\n          *ngIf=\"currentNavType === DatePickerType.Day && showTime\"\n          [showIcon]=\"false\"\n          size=\"small\"\n          [(ngModel)]=\"selectedTime\"\n          [disableHours]=\"getDisabledTimeFn(selectedDate, 'hours')\"\n          [disableMinutes]=\"getDisabledTimeFn(selectedDate, 'minutes')\"\n          [disableSeconds]=\"getDisabledTimeFn(selectedDate, 'seconds')\"\n          tooltipPosition=\"top start\"\n          (ngModelChange)=\"timeDateChange($event)\"\n          [placeholder]=\"'select_time' | auiI18n\"\n        ></aui-time-picker>\n      </ng-template>\n    </aui-calendar-footer>\n\n    <ng-template #today>\n      <aui-calendar-footer\n        *ngIf=\"type === DatePickerType.Day\"\n        (clear)=\"clearValue()\"\n        [clearable]=\"false\"\n        [customAction]=\"todayBtn\"\n      >\n      </aui-calendar-footer>\n      <ng-template #todayBtn>\n        <button\n          aui-button=\"inline\"\n          (click)=\"setToday()\"\n        >\n          {{ 'today' | auiI18n }}\n        </button>\n      </ng-template>\n    </ng-template>\n  </ng-container>\n</div>\n"]}
|
|
@@ -4,13 +4,13 @@ import { ButtonComponent } from '../../../button/button.component';
|
|
|
4
4
|
import { I18nPipe } from '../../../i18n/i18n.pipe';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class CalendarFooterComponent {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
static
|
|
13
|
-
static
|
|
7
|
+
constructor() {
|
|
8
|
+
this.clearable = true;
|
|
9
|
+
this.confirm = new EventEmitter();
|
|
10
|
+
this.clear = new EventEmitter();
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CalendarFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: CalendarFooterComponent, isStandalone: true, selector: "aui-calendar-footer", inputs: { clearable: "clearable", clearText: "clearText", customAction: "customAction" }, outputs: { confirm: "confirm", clear: "clear" }, ngImport: i0, template: "<div class=\"aui-calendar-footer__wrapper\">\n <div style=\"flex: 1\">\n <ng-content></ng-content>\n </div>\n <div>\n <ng-container\n *ngIf=\"customAction; else default\"\n [ngTemplateOutlet]=\"customAction\"\n >\n </ng-container>\n <ng-template #default>\n <button\n aui-button=\"text\"\n *ngIf=\"clearable\"\n (click)=\"clear.emit()\"\n size=\"small\"\n >\n {{ clearText || ('clear' | auiI18n) }}\n </button>\n <button\n aui-button=\"primary\"\n (click)=\"confirm.emit()\"\n size=\"small\"\n >\n {{ 'confirm' | auiI18n }}\n </button>\n </ng-template>\n </div>\n</div>\n", styles: [".aui-calendar-footer__wrapper{display:flex;flex-direction:row;justify-content:space-between;border-top:1px solid rgb(var(--aui-color-n-8));padding:8px 0 0}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ButtonComponent, selector: "button[aui-button]", inputs: ["aui-button", "size", "plain", "loading", "round", "square"] }, { kind: "pipe", type: I18nPipe, name: "auiI18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
14
14
|
}
|
|
15
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CalendarFooterComponent, decorators: [{
|
|
16
16
|
type: Component,
|
|
@@ -26,4 +26,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
26
26
|
}], clear: [{
|
|
27
27
|
type: Output
|
|
28
28
|
}] } });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2RhdGUtcGlja2VyL2NhbGVuZGFyL2Zvb3Rlci9jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvZGF0ZS1waWNrZXIvY2FsZW5kYXIvZm9vdGVyL3RlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3pELE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBQ0wsTUFBTSxFQUVOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDbkUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQVduRCxNQUFNLE9BQU8sdUJBQXVCO0lBVHBDO1FBV0UsY0FBUyxHQUFHLElBQUksQ0FBQztRQVNqQixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUduQyxVQUFLLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztLQUNsQzs4R0FmWSx1QkFBdUI7a0dBQXZCLHVCQUF1QiwwTkN2QnBDLDByQkE2QkEsdU5EUlksSUFBSSw2RkFBRSxnQkFBZ0Isb0pBQUUsZUFBZSxpSUFBRSxRQUFROzsyRkFFaEQsdUJBQXVCO2tCQVRuQyxTQUFTOytCQUNFLHFCQUFxQixpQkFHaEIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1AsQ0FBQyxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLFFBQVEsQ0FBQzs4QkFJNUQsU0FBUztzQkFEUixLQUFLO2dCQUlOLFNBQVM7c0JBRFIsS0FBSztnQkFJTixZQUFZO3NCQURYLEtBQUs7Z0JBSU4sT0FBTztzQkFETixNQUFNO2dCQUlQLEtBQUs7c0JBREosTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nSWYsIE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBCdXR0b25Db21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJMThuUGlwZSB9IGZyb20gJy4uLy4uLy4uL2kxOG4vaTE4bi5waXBlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLWNhbGVuZGFyLWZvb3RlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi90ZW1wbGF0ZS5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3R5bGUuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW05nSWYsIE5nVGVtcGxhdGVPdXRsZXQsIEJ1dHRvbkNvbXBvbmVudCwgSTE4blBpcGVdLFxufSlcbmV4cG9ydCBjbGFzcyBDYWxlbmRhckZvb3RlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIGNsZWFyYWJsZSA9IHRydWU7XG5cbiAgQElucHV0KClcbiAgY2xlYXJUZXh0OiBzdHJpbmc7XG5cbiAgQElucHV0KClcbiAgY3VzdG9tQWN0aW9uOiBUZW1wbGF0ZVJlZjxhbnk+O1xuXG4gIEBPdXRwdXQoKVxuICBjb25maXJtID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIEBPdXRwdXQoKVxuICBjbGVhciA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJhdWktY2FsZW5kYXItZm9vdGVyX193cmFwcGVyXCI+XG4gIDxkaXYgc3R5bGU9XCJmbGV4OiAxXCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbiAgPGRpdj5cbiAgICA8bmctY29udGFpbmVyXG4gICAgICAqbmdJZj1cImN1c3RvbUFjdGlvbjsgZWxzZSBkZWZhdWx0XCJcbiAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImN1c3RvbUFjdGlvblwiXG4gICAgPlxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy10ZW1wbGF0ZSAjZGVmYXVsdD5cbiAgICAgIDxidXR0b25cbiAgICAgICAgYXVpLWJ1dHRvbj1cInRleHRcIlxuICAgICAgICAqbmdJZj1cImNsZWFyYWJsZVwiXG4gICAgICAgIChjbGljayk9XCJjbGVhci5lbWl0KClcIlxuICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgPlxuICAgICAgICB7eyBjbGVhclRleHQgfHwgKCdjbGVhcicgfCBhdWlJMThuKSB9fVxuICAgICAgPC9idXR0b24+XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGF1aS1idXR0b249XCJwcmltYXJ5XCJcbiAgICAgICAgKGNsaWNrKT1cImNvbmZpcm0uZW1pdCgpXCJcbiAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgID5cbiAgICAgICAge3sgJ2NvbmZpcm0nIHwgYXVpSTE4biB9fVxuICAgICAgPC9idXR0b24+XG4gICAgPC9uZy10ZW1wbGF0ZT5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -1,33 +1,71 @@
|
|
|
1
1
|
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, computed, signal, } from '@angular/core';
|
|
3
3
|
import dayjs from 'dayjs';
|
|
4
4
|
import { ButtonComponent } from '../../../button/button.component';
|
|
5
|
-
import { I18nPipe } from '../../../i18n
|
|
5
|
+
import { I18nPipe } from '../../../i18n';
|
|
6
6
|
import { IconComponent } from '../../../icon/icon.component';
|
|
7
7
|
import { buildBem } from '../../../internal/utils';
|
|
8
|
-
import { DateNavRange, Side
|
|
8
|
+
import { DateNavRange, Side } from '../../date-picker.type';
|
|
9
9
|
import { MONTH, YEAR } from '../constant';
|
|
10
10
|
import { calcRangeValue } from '../util';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "../../../i18n";
|
|
12
13
|
const bem = buildBem('aui-calendar-header');
|
|
13
14
|
export class CalendarHeaderComponent {
|
|
14
|
-
dateNavRange
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
get dateNavRange() {
|
|
16
|
+
return this.$$dateNavRange();
|
|
17
|
+
}
|
|
18
|
+
set dateNavRange(val) {
|
|
19
|
+
if (!val || this.$$dateNavRange() === val) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
this.$$dateNavRange.set(val);
|
|
23
|
+
}
|
|
24
|
+
get anchor() {
|
|
25
|
+
return this.$$anchor();
|
|
26
|
+
}
|
|
27
|
+
set anchor(val) {
|
|
28
|
+
if (!val || this.$$anchor() === val) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
this.$$anchor.set(val);
|
|
32
|
+
}
|
|
17
33
|
get _maxAvail() {
|
|
18
34
|
return this.maxAvail ? dayjs(this.maxAvail) : null;
|
|
19
35
|
}
|
|
20
|
-
minAvail;
|
|
21
36
|
get _minAvail() {
|
|
22
37
|
return this.minAvail ? dayjs(this.minAvail) : null;
|
|
23
38
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
39
|
+
constructor(i18nService) {
|
|
40
|
+
this.i18nService = i18nService;
|
|
41
|
+
this.navRangeChange = new EventEmitter();
|
|
42
|
+
this.anchorChange = new EventEmitter();
|
|
43
|
+
this.$$dateNavRange = signal(DateNavRange.Month);
|
|
44
|
+
this.$$anchor = signal(dayjs());
|
|
45
|
+
this.bem = bem;
|
|
46
|
+
this.DateNavRange = DateNavRange;
|
|
47
|
+
this.$monthBeforeYear = this.i18nService.$monthBeforeYear;
|
|
48
|
+
this.$headerRange = computed(() => {
|
|
49
|
+
const locale = this.i18nService.$locale();
|
|
50
|
+
const [start, end] = Object.values(calcRangeValue(this.$$dateNavRange(), this.$$anchor())).map(date => date.toDate());
|
|
51
|
+
return {
|
|
52
|
+
start: {
|
|
53
|
+
year: start.toLocaleDateString(locale, { year: 'numeric' }),
|
|
54
|
+
month: start.toLocaleDateString(locale, { month: 'short' }),
|
|
55
|
+
},
|
|
56
|
+
end: {
|
|
57
|
+
year: end?.toLocaleDateString(locale, { year: 'numeric' }),
|
|
58
|
+
month: end?.toLocaleDateString(locale, { month: 'short' }),
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
});
|
|
62
|
+
this.clickNav = (range) => {
|
|
63
|
+
if (![DateNavRange.Month, DateNavRange.Year].includes(range)) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
this.navRangeChange.next(range === DateNavRange.Month ? DateNavRange.Year : DateNavRange.Decade);
|
|
67
|
+
};
|
|
28
68
|
}
|
|
29
|
-
bem = bem;
|
|
30
|
-
DateNavRange = DateNavRange;
|
|
31
69
|
shouldShowNav(type, side) {
|
|
32
70
|
const availValue = (side === Side.Left ? this._minAvail : this._maxAvail)?.clone();
|
|
33
71
|
if (!availValue) {
|
|
@@ -72,19 +110,13 @@ export class CalendarHeaderComponent {
|
|
|
72
110
|
}
|
|
73
111
|
this.anchorChange.next(anchor);
|
|
74
112
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
this.navRangeChange.next(range === DateNavRange.Month ? DateNavRange.Year : DateNavRange.Decade);
|
|
80
|
-
};
|
|
81
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CalendarHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
82
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: CalendarHeaderComponent, isStandalone: true, selector: "aui-calendar-header", inputs: { dateNavRange: "dateNavRange", anchor: "anchor", maxAvail: "maxAvail", minAvail: "minAvail" }, outputs: { navRangeChange: "navRangeChange", anchorChange: "anchorChange" }, ngImport: i0, template: "<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 <!-- \u5185\u5BB9\u533A -->\n <span\n *ngIf=\"dateNavRange === DateNavRange.Month\"\n [class]=\"bem.element('nav-content')\"\n >\n <button\n aui-button=\"text\"\n (click)=\"clickNav(DateNavRange.Year)\"\n >\n {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n </button>\n <div class=\"separator\">\n <span *ngIf=\"!('year_suffix' | auiI18n) && !('month_suffix' | auiI18n)\">\n /\n </span>\n </div>\n <button\n aui-button=\"text\"\n (click)=\"clickNav(DateNavRange.Month)\"\n >\n {{ headerRange?.start?.month() + 1 }}{{ 'month_suffix' | auiI18n }}\n </button>\n </span>\n\n <span\n *ngIf=\"dateNavRange === DateNavRange.Year\"\n [class]=\"bem.element('nav-content')\"\n >\n <button\n aui-button=\"text\"\n (click)=\"clickNav(DateNavRange.Year)\"\n >\n {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n </button>\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' ? 'angles_left' : 'angles_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' ? 'angles_left' : 'angles_right'\"\n ></aui-icon>\n </button>\n</ng-template>\n", styles: [".aui-calendar-header__container{height:24px;display:flex;align-items:center;justify-content:space-between}.aui-calendar-header__nav-content{flex:1;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;font-size:var(--aui-font-size-l);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-bolder)}.aui-calendar-header__nav-content .separator{margin:0 var(--aui-spacing-s)}.aui-calendar-header__nav-content .aui-button--text{color:rgb(var(--aui-color-main-text))}.aui-calendar-header__nav-content .aui-button--text .aui-button__content{font-size:var(--aui-font-size-l);font-weight:var(--aui-font-weight-bolder);padding:0}.aui-calendar-header__nav-content .aui-button--text:hover{background-color:transparent;color:rgb(var(--aui-color-primary));text-decoration:none!important}.aui-calendar-header__nav-content .aui-button--text+.aui-button--text{margin-left:0}.action-bar{width:52px;display:flex}.action-bar .hidden{opacity:0;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ButtonComponent, selector: "button[aui-button]", inputs: ["aui-button", "size", "plain", "loading", "round", "square"] }, { kind: "component", type: IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }, { kind: "pipe", type: I18nPipe, name: "auiI18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
113
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CalendarHeaderComponent, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.3", type: CalendarHeaderComponent, isStandalone: true, selector: "aui-calendar-header", inputs: { dateNavRange: "dateNavRange", anchor: "anchor", maxAvail: "maxAvail", minAvail: "minAvail" }, outputs: { navRangeChange: "navRangeChange", anchorChange: "anchorChange" }, ngImport: i0, template: "<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 <!-- \u5185\u5BB9\u533A -->\n <span\n *ngIf=\"dateNavRange === DateNavRange.Month\"\n [class]=\"bem.element('nav-content')\"\n >\n <ng-container\n [ngTemplateOutlet]=\"$monthBeforeYear() ? monthTemplate : yearTemplate\"\n ></ng-container>\n <div class=\"separator\"></div>\n <ng-container\n [ngTemplateOutlet]=\"$monthBeforeYear() ? yearTemplate : monthTemplate\"\n ></ng-container>\n </span>\n\n <span\n *ngIf=\"dateNavRange === DateNavRange.Year\"\n [class]=\"bem.element('nav-content')\"\n >\n <button\n aui-button=\"text\"\n (click)=\"clickNav(DateNavRange.Year)\"\n >\n {{ $headerRange().start.year }}\n </button>\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 size=\"mini\"\n [square]=\"true\"\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 size=\"mini\"\n [square]=\"true\"\n (click)=\"navHead(DateNavRange.Year, side === 'left' ? -1 : 1)\"\n [class.hidden]=\"!shouldShowNav(DateNavRange.Year, side)\"\n >\n <aui-icon\n [icon]=\"side === 'left' ? 'angles_left' : 'angles_right'\"\n ></aui-icon>\n </button>\n <button\n aui-button=\"text\"\n size=\"mini\"\n [square]=\"true\"\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 size=\"mini\"\n [square]=\"true\"\n (click)=\"navHead(DateNavRange.Decade, side === 'left' ? -10 : 10)\"\n [class.hidden]=\"!shouldShowNav(DateNavRange.Decade, side)\"\n >\n <aui-icon\n [icon]=\"side === 'left' ? 'angles_left' : 'angles_right'\"\n ></aui-icon>\n </button>\n</ng-template>\n\n<ng-template #yearTemplate>\n <button\n aui-button=\"text\"\n class=\"header-range\"\n (click)=\"clickNav(DateNavRange.Year)\"\n >\n {{ $headerRange().start.year }}\n </button>\n</ng-template>\n<ng-template #monthTemplate>\n <button\n aui-button=\"text\"\n class=\"header-range\"\n (click)=\"clickNav(DateNavRange.Month)\"\n >\n {{ $headerRange().start.month }}\n </button>\n</ng-template>\n", styles: [".aui-calendar-header__container{height:24px;display:flex;align-items:center;justify-content:space-between}.aui-calendar-header__nav-content{flex:1;max-width:calc(100% - var(--aui-inline-height-xs) * 4 - var(--aui-spacing-s) * 2);display:flex;flex-wrap:wrap;justify-content:center;align-items:center;font-size:var(--aui-font-size-l);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-bolder)}.aui-calendar-header__nav-content .separator{margin:0 var(--aui-spacing-s)}.aui-calendar-header__nav-content .aui-button--text{color:rgb(var(--aui-color-main-text))}.aui-calendar-header__nav-content .aui-button--text .aui-button__content{font-size:var(--aui-font-size-l);font-weight:var(--aui-font-weight-bolder);padding:0}.aui-calendar-header__nav-content .aui-button--text:hover{background-color:transparent;color:rgb(var(--aui-color-primary));text-decoration:none!important}.aui-calendar-header__nav-content .aui-button--text+.aui-button--text{margin-left:0}.aui-calendar-header__nav-content .aui-button--text.header-range{max-width:100%}.action-bar{width:52px;display:flex}.action-bar .hidden{opacity:0;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ButtonComponent, selector: "button[aui-button]", inputs: ["aui-button", "size", "plain", "loading", "round", "square"] }, { kind: "component", type: IconComponent, selector: "aui-icon", inputs: ["icon", "light", "dark", "link", "margin", "size", "color", "background", "backgroundColor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
83
115
|
}
|
|
84
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CalendarHeaderComponent, decorators: [{
|
|
85
117
|
type: Component,
|
|
86
|
-
args: [{ selector: 'aui-calendar-header', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, NgTemplateOutlet, ButtonComponent, IconComponent, I18nPipe], template: "<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 <!-- \u5185\u5BB9\u533A -->\n <span\n *ngIf=\"dateNavRange === DateNavRange.Month\"\n [class]=\"bem.element('nav-content')\"\n >\n <
|
|
87
|
-
}], propDecorators: { dateNavRange: [{
|
|
118
|
+
args: [{ selector: 'aui-calendar-header', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, NgTemplateOutlet, ButtonComponent, IconComponent, I18nPipe], template: "<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 <!-- \u5185\u5BB9\u533A -->\n <span\n *ngIf=\"dateNavRange === DateNavRange.Month\"\n [class]=\"bem.element('nav-content')\"\n >\n <ng-container\n [ngTemplateOutlet]=\"$monthBeforeYear() ? monthTemplate : yearTemplate\"\n ></ng-container>\n <div class=\"separator\"></div>\n <ng-container\n [ngTemplateOutlet]=\"$monthBeforeYear() ? yearTemplate : monthTemplate\"\n ></ng-container>\n </span>\n\n <span\n *ngIf=\"dateNavRange === DateNavRange.Year\"\n [class]=\"bem.element('nav-content')\"\n >\n <button\n aui-button=\"text\"\n (click)=\"clickNav(DateNavRange.Year)\"\n >\n {{ $headerRange().start.year }}\n </button>\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 size=\"mini\"\n [square]=\"true\"\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 size=\"mini\"\n [square]=\"true\"\n (click)=\"navHead(DateNavRange.Year, side === 'left' ? -1 : 1)\"\n [class.hidden]=\"!shouldShowNav(DateNavRange.Year, side)\"\n >\n <aui-icon\n [icon]=\"side === 'left' ? 'angles_left' : 'angles_right'\"\n ></aui-icon>\n </button>\n <button\n aui-button=\"text\"\n size=\"mini\"\n [square]=\"true\"\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 size=\"mini\"\n [square]=\"true\"\n (click)=\"navHead(DateNavRange.Decade, side === 'left' ? -10 : 10)\"\n [class.hidden]=\"!shouldShowNav(DateNavRange.Decade, side)\"\n >\n <aui-icon\n [icon]=\"side === 'left' ? 'angles_left' : 'angles_right'\"\n ></aui-icon>\n </button>\n</ng-template>\n\n<ng-template #yearTemplate>\n <button\n aui-button=\"text\"\n class=\"header-range\"\n (click)=\"clickNav(DateNavRange.Year)\"\n >\n {{ $headerRange().start.year }}\n </button>\n</ng-template>\n<ng-template #monthTemplate>\n <button\n aui-button=\"text\"\n class=\"header-range\"\n (click)=\"clickNav(DateNavRange.Month)\"\n >\n {{ $headerRange().start.month }}\n </button>\n</ng-template>\n", styles: [".aui-calendar-header__container{height:24px;display:flex;align-items:center;justify-content:space-between}.aui-calendar-header__nav-content{flex:1;max-width:calc(100% - var(--aui-inline-height-xs) * 4 - var(--aui-spacing-s) * 2);display:flex;flex-wrap:wrap;justify-content:center;align-items:center;font-size:var(--aui-font-size-l);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-bolder)}.aui-calendar-header__nav-content .separator{margin:0 var(--aui-spacing-s)}.aui-calendar-header__nav-content .aui-button--text{color:rgb(var(--aui-color-main-text))}.aui-calendar-header__nav-content .aui-button--text .aui-button__content{font-size:var(--aui-font-size-l);font-weight:var(--aui-font-weight-bolder);padding:0}.aui-calendar-header__nav-content .aui-button--text:hover{background-color:transparent;color:rgb(var(--aui-color-primary));text-decoration:none!important}.aui-calendar-header__nav-content .aui-button--text+.aui-button--text{margin-left:0}.aui-calendar-header__nav-content .aui-button--text.header-range{max-width:100%}.action-bar{width:52px;display:flex}.action-bar .hidden{opacity:0;pointer-events:none}\n"] }]
|
|
119
|
+
}], ctorParameters: function () { return [{ type: i1.I18nService }]; }, propDecorators: { dateNavRange: [{
|
|
88
120
|
type: Input
|
|
89
121
|
}], anchor: [{
|
|
90
122
|
type: Input
|
|
@@ -97,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
97
129
|
}], anchorChange: [{
|
|
98
130
|
type: Output
|
|
99
131
|
}] } });
|
|
100
|
-
//# 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 { NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { ButtonComponent } from '../../../button/button.component';\nimport { I18nPipe } from '../../../i18n/i18n.pipe';\nimport { IconComponent } from '../../../icon/icon.component';\nimport { buildBem } from '../../../internal/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  standalone: true,\n  imports: [NgIf, NgTemplateOutlet, ButtonComponent, IconComponent, I18nPipe],\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    }\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    <button\n      aui-button=\"text\"\n      (click)=\"clickNav(DateNavRange.Year)\"\n    >\n      {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n    </button>\n    <div class=\"separator\">\n      <span *ngIf=\"!('year_suffix' | auiI18n) && !('month_suffix' | auiI18n)\">\n        /\n      </span>\n    </div>\n    <button\n      aui-button=\"text\"\n      (click)=\"clickNav(DateNavRange.Month)\"\n    >\n      {{ headerRange?.start?.month() + 1 }}{{ 'month_suffix' | auiI18n }}\n    </button>\n  </span>\n\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Year\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    <button\n      aui-button=\"text\"\n      (click)=\"clickNav(DateNavRange.Year)\"\n    >\n      {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\n    </button>\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' ? 'angles_left' : 'angles_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' ? 'angles_left' : 'angles_right'\"\n    ></aui-icon>\n  </button>\n</ng-template>\n"]}
|
|
132
|
+
//# 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 { NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n  computed,\n  signal,\n} from '@angular/core';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { ButtonComponent } from '../../../button/button.component';\nimport { I18nPipe, I18nService } from '../../../i18n';\nimport { IconComponent } from '../../../icon/icon.component';\nimport { buildBem } from '../../../internal/utils';\nimport { DateNavRange, Side } 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  standalone: true,\n  imports: [NgIf, NgTemplateOutlet, ButtonComponent, IconComponent, I18nPipe],\n})\nexport class CalendarHeaderComponent {\n  @Input()\n  get dateNavRange() {\n    return this.$$dateNavRange();\n  }\n\n  set dateNavRange(val) {\n    if (!val || this.$$dateNavRange() === val) {\n      return;\n    }\n    this.$$dateNavRange.set(val);\n  }\n\n  @Input()\n  get anchor() {\n    return this.$$anchor();\n  }\n\n  set anchor(val) {\n    if (!val || this.$$anchor() === val) {\n      return;\n    }\n    this.$$anchor.set(val);\n  }\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  private readonly $$dateNavRange = signal(DateNavRange.Month);\n  private readonly $$anchor = signal(dayjs());\n\n  bem = bem;\n\n  DateNavRange = DateNavRange;\n\n  $monthBeforeYear = this.i18nService.$monthBeforeYear;\n\n  $headerRange = computed(() => {\n    const locale = this.i18nService.$locale();\n    const [start, end] = Object.values(\n      calcRangeValue(this.$$dateNavRange(), this.$$anchor()),\n    ).map(date => date.toDate());\n\n    return {\n      start: {\n        year: start.toLocaleDateString(locale, { year: 'numeric' }),\n        month: start.toLocaleDateString(locale, { month: 'short' }),\n      },\n      end: {\n        year: end?.toLocaleDateString(locale, { year: 'numeric' }),\n        month: end?.toLocaleDateString(locale, { month: 'short' }),\n      },\n    };\n  });\n\n  constructor(private readonly i18nService: I18nService) {}\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    }\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    <ng-container\n      [ngTemplateOutlet]=\"$monthBeforeYear() ? monthTemplate : yearTemplate\"\n    ></ng-container>\n    <div class=\"separator\"></div>\n    <ng-container\n      [ngTemplateOutlet]=\"$monthBeforeYear() ? yearTemplate : monthTemplate\"\n    ></ng-container>\n  </span>\n\n  <span\n    *ngIf=\"dateNavRange === DateNavRange.Year\"\n    [class]=\"bem.element('nav-content')\"\n  >\n    <button\n      aui-button=\"text\"\n      (click)=\"clickNav(DateNavRange.Year)\"\n    >\n      {{ $headerRange().start.year }}\n    </button>\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      size=\"mini\"\n      [square]=\"true\"\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      size=\"mini\"\n      [square]=\"true\"\n      (click)=\"navHead(DateNavRange.Year, side === 'left' ? -1 : 1)\"\n      [class.hidden]=\"!shouldShowNav(DateNavRange.Year, side)\"\n    >\n      <aui-icon\n        [icon]=\"side === 'left' ? 'angles_left' : 'angles_right'\"\n      ></aui-icon>\n    </button>\n    <button\n      aui-button=\"text\"\n      size=\"mini\"\n      [square]=\"true\"\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    size=\"mini\"\n    [square]=\"true\"\n    (click)=\"navHead(DateNavRange.Decade, side === 'left' ? -10 : 10)\"\n    [class.hidden]=\"!shouldShowNav(DateNavRange.Decade, side)\"\n  >\n    <aui-icon\n      [icon]=\"side === 'left' ? 'angles_left' : 'angles_right'\"\n    ></aui-icon>\n  </button>\n</ng-template>\n\n<ng-template #yearTemplate>\n  <button\n    aui-button=\"text\"\n    class=\"header-range\"\n    (click)=\"clickNav(DateNavRange.Year)\"\n  >\n    {{ $headerRange().start.year }}\n  </button>\n</ng-template>\n<ng-template #monthTemplate>\n  <button\n    aui-button=\"text\"\n    class=\"header-range\"\n    (click)=\"clickNav(DateNavRange.Month)\"\n  >\n    {{ $headerRange().start.month }}\n  </button>\n</ng-template>\n"]}
|