@alauda/ui 7.4.2-beta.4 → 7.4.2-beta.6
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 +18 -5
- package/esm2022/date-picker/calendar/header/component.mjs +43 -26
- package/esm2022/i18n/i18n.pipe.mjs +5 -15
- package/esm2022/i18n/i18n.service.mjs +15 -20
- package/fesm2022/alauda-ui.mjs +53 -49
- 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
|
@@ -1,22 +1,35 @@
|
|
|
1
1
|
import { EventEmitter } from '@angular/core';
|
|
2
2
|
import dayjs, { ConfigType, Dayjs } from 'dayjs';
|
|
3
3
|
import { I18nService } from '../../../i18n';
|
|
4
|
-
import {
|
|
4
|
+
import { DateNavRange, Side } from '../../date-picker.type';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class CalendarHeaderComponent {
|
|
7
7
|
private readonly i18nService;
|
|
8
|
-
dateNavRange: DateNavRange;
|
|
9
|
-
|
|
8
|
+
get dateNavRange(): DateNavRange;
|
|
9
|
+
set dateNavRange(val: DateNavRange);
|
|
10
|
+
get anchor(): dayjs.Dayjs;
|
|
11
|
+
set anchor(val: dayjs.Dayjs);
|
|
10
12
|
maxAvail?: ConfigType;
|
|
11
13
|
private get _maxAvail();
|
|
12
14
|
minAvail?: ConfigType;
|
|
13
15
|
private get _minAvail();
|
|
14
16
|
navRangeChange: EventEmitter<DateNavRange>;
|
|
15
17
|
anchorChange: EventEmitter<dayjs.Dayjs>;
|
|
16
|
-
|
|
18
|
+
private readonly $$dateNavRange;
|
|
19
|
+
private readonly $$anchor;
|
|
17
20
|
bem: import("../../../internal/utils").Bem;
|
|
18
21
|
DateNavRange: typeof DateNavRange;
|
|
19
|
-
monthBeforeYear
|
|
22
|
+
$monthBeforeYear: import("@angular/core").Signal<boolean>;
|
|
23
|
+
$headerRange: import("@angular/core").Signal<{
|
|
24
|
+
start: {
|
|
25
|
+
year: string;
|
|
26
|
+
month: string;
|
|
27
|
+
};
|
|
28
|
+
end: {
|
|
29
|
+
year: string;
|
|
30
|
+
month: string;
|
|
31
|
+
};
|
|
32
|
+
}>;
|
|
20
33
|
constructor(i18nService: I18nService);
|
|
21
34
|
shouldShowNav(type: DateNavRange, side: Side): boolean;
|
|
22
35
|
compareNavValue(type: DateNavRange, constrain: Dayjs, anchor: Dayjs): 1 | 0 | -1;
|
|
@@ -1,40 +1,64 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
1
|
+
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, computed, signal, } from '@angular/core';
|
|
3
3
|
import dayjs from 'dayjs';
|
|
4
|
-
import { map, startWith } from 'rxjs';
|
|
5
4
|
import { ButtonComponent } from '../../../button/button.component';
|
|
6
5
|
import { I18nPipe } from '../../../i18n';
|
|
7
6
|
import { IconComponent } from '../../../icon/icon.component';
|
|
8
|
-
import { buildBem
|
|
9
|
-
import { DateNavRange, Side
|
|
10
|
-
import {
|
|
7
|
+
import { buildBem } from '../../../internal/utils';
|
|
8
|
+
import { DateNavRange, Side } from '../../date-picker.type';
|
|
9
|
+
import { MONTH, YEAR } from '../constant';
|
|
11
10
|
import { calcRangeValue } from '../util';
|
|
12
11
|
import * as i0 from "@angular/core";
|
|
13
12
|
import * as i1 from "../../../i18n";
|
|
14
13
|
const bem = buildBem('aui-calendar-header');
|
|
15
14
|
export class CalendarHeaderComponent {
|
|
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
|
+
}
|
|
16
33
|
get _maxAvail() {
|
|
17
34
|
return this.maxAvail ? dayjs(this.maxAvail) : null;
|
|
18
35
|
}
|
|
19
36
|
get _minAvail() {
|
|
20
37
|
return this.minAvail ? dayjs(this.minAvail) : null;
|
|
21
38
|
}
|
|
22
|
-
get headerRange() {
|
|
23
|
-
return calcRangeValue(this.dateNavRange, this.anchor);
|
|
24
|
-
}
|
|
25
39
|
constructor(i18nService) {
|
|
26
40
|
this.i18nService = i18nService;
|
|
27
|
-
this.dateNavRange = DateNavRange.Month;
|
|
28
|
-
this.anchor = dayjs();
|
|
29
41
|
this.navRangeChange = new EventEmitter();
|
|
30
42
|
this.anchorChange = new EventEmitter();
|
|
43
|
+
this.$$dateNavRange = signal(DateNavRange.Month);
|
|
44
|
+
this.$$anchor = signal(dayjs());
|
|
31
45
|
this.bem = bem;
|
|
32
46
|
this.DateNavRange = DateNavRange;
|
|
33
|
-
this
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
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
|
+
});
|
|
38
62
|
this.clickNav = (range) => {
|
|
39
63
|
if (![DateNavRange.Month, DateNavRange.Year].includes(range)) {
|
|
40
64
|
return;
|
|
@@ -87,18 +111,11 @@ export class CalendarHeaderComponent {
|
|
|
87
111
|
this.anchorChange.next(anchor);
|
|
88
112
|
}
|
|
89
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 }); }
|
|
90
|
-
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]=\"
|
|
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 - 4px);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 }); }
|
|
91
115
|
}
|
|
92
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: CalendarHeaderComponent, decorators: [{
|
|
93
117
|
type: Component,
|
|
94
|
-
args: [{ selector: 'aui-calendar-header', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
95
|
-
NgIf,
|
|
96
|
-
NgTemplateOutlet,
|
|
97
|
-
ButtonComponent,
|
|
98
|
-
IconComponent,
|
|
99
|
-
I18nPipe,
|
|
100
|
-
AsyncPipe,
|
|
101
|
-
], 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]=\"\n (monthBeforeYear$ | async) ? monthTemplate : yearTemplate\n \"\n ></ng-container>\n <div class=\"separator\">\n <span *ngIf=\"!('year_suffix' | auiI18n) && !('month_suffix' | auiI18n)\">\n /\n </span>\n </div>\n <ng-container\n [ngTemplateOutlet]=\"\n (monthBeforeYear$ | async) ? yearTemplate : monthTemplate\n \"\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() }}{{ '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\n<ng-template #yearTemplate>\n <button\n aui-button=\"text\"\n class=\"header-range\"\n (click)=\"clickNav(DateNavRange.Year)\"\n >\n {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\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() + 1 }}{{ 'month_suffix' | auiI18n }}\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% - 100px);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"] }]
|
|
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 - 4px);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"] }]
|
|
102
119
|
}], ctorParameters: function () { return [{ type: i1.I18nService }]; }, propDecorators: { dateNavRange: [{
|
|
103
120
|
type: Input
|
|
104
121
|
}], anchor: [{
|
|
@@ -112,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
112
129
|
}], anchorChange: [{
|
|
113
130
|
type: Output
|
|
114
131
|
}] } });
|
|
115
|
-
//# 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 { AsyncPipe, 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';\nimport { map, startWith } from 'rxjs';\n\nimport { ButtonComponent } from '../../../button/button.component';\nimport { I18nPipe, I18nService } from '../../../i18n';\nimport { IconComponent } from '../../../icon/icon.component';\nimport { buildBem, publishRef } from '../../../internal/utils';\nimport {\n  CalendarHeaderRange,\n  DateNavRange,\n  Side,\n} from '../../date-picker.type';\nimport { DatePickerType, 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: [\n    NgIf,\n    NgTemplateOutlet,\n    ButtonComponent,\n    IconComponent,\n    I18nPipe,\n    AsyncPipe,\n  ],\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  monthBeforeYear$ = this.i18nService.localeChange$.pipe(\n    map(locale => {\n      const parts = new Intl.DateTimeFormat(locale).formatToParts(new Date());\n      return (\n        parts.findIndex(part => part.type === DatePickerType.Month) <\n        parts.findIndex(part => part.type === DatePickerType.Year)\n      );\n    }),\n    startWith(false),\n    publishRef(),\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]=\"\n        (monthBeforeYear$ | async) ? monthTemplate : yearTemplate\n      \"\n    ></ng-container>\n    <div class=\"separator\">\n      <span *ngIf=\"!('year_suffix' | auiI18n) && !('month_suffix' | auiI18n)\">\n        /\n      </span>\n    </div>\n    <ng-container\n      [ngTemplateOutlet]=\"\n        (monthBeforeYear$ | async) ? yearTemplate : monthTemplate\n      \"\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() }}{{ '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\n<ng-template #yearTemplate>\n  <button\n    aui-button=\"text\"\n    class=\"header-range\"\n    (click)=\"clickNav(DateNavRange.Year)\"\n  >\n    {{ headerRange?.start?.year() }}{{ 'year_suffix' | auiI18n }}\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() + 1 }}{{ 'month_suffix' | auiI18n }}\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"]}
|
|
@@ -1,24 +1,14 @@
|
|
|
1
|
-
import { Pipe
|
|
2
|
-
import { Subject, takeUntil } from 'rxjs';
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
4
3
|
import * as i1 from "./i18n.service";
|
|
5
4
|
export class I18nPipe {
|
|
6
|
-
constructor(i18n
|
|
5
|
+
constructor(i18n) {
|
|
7
6
|
this.i18n = i18n;
|
|
8
|
-
this.cdr = cdr;
|
|
9
|
-
this.destroy$$ = new Subject();
|
|
10
|
-
this.i18n.localeChange$
|
|
11
|
-
.pipe(takeUntil(this.destroy$$))
|
|
12
|
-
.subscribe(() => this.cdr.markForCheck());
|
|
13
7
|
}
|
|
14
8
|
transform(value, data) {
|
|
15
9
|
return this.i18n.translate(value, data);
|
|
16
10
|
}
|
|
17
|
-
|
|
18
|
-
this.destroy$$.next();
|
|
19
|
-
this.destroy$$.complete();
|
|
20
|
-
}
|
|
21
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: I18nPipe, deps: [{ token: i1.I18nService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: I18nPipe, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
22
12
|
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.3", ngImport: i0, type: I18nPipe, isStandalone: true, name: "auiI18n", pure: false }); }
|
|
23
13
|
}
|
|
24
14
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: I18nPipe, decorators: [{
|
|
@@ -28,5 +18,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
28
18
|
pure: false,
|
|
29
19
|
standalone: true,
|
|
30
20
|
}]
|
|
31
|
-
}], ctorParameters: function () { return [{ type: i1.I18nService }
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
}], ctorParameters: function () { return [{ type: i1.I18nService }]; } });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2kxOG4vaTE4bi5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7QUFTcEQsTUFBTSxPQUFPLFFBQVE7SUFDbkIsWUFBNkIsSUFBaUI7UUFBakIsU0FBSSxHQUFKLElBQUksQ0FBYTtJQUFHLENBQUM7SUFFbEQsU0FBUyxDQUFDLEtBQVUsRUFBRSxJQUE2QjtRQUNqRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMxQyxDQUFDOzhHQUxVLFFBQVE7NEdBQVIsUUFBUTs7MkZBQVIsUUFBUTtrQkFMcEIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsU0FBUztvQkFDZixJQUFJLEVBQUUsS0FBSztvQkFDWCxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEkxOG5TZXJ2aWNlIH0gZnJvbSAnLi9pMThuLnNlcnZpY2UnO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdhdWlJMThuJyxcbiAgcHVyZTogZmFsc2UsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEkxOG5QaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgaTE4bjogSTE4blNlcnZpY2UpIHt9XG5cbiAgdHJhbnNmb3JtKHZhbHVlOiBhbnksIGRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KSB7XG4gICAgcmV0dXJuIHRoaXMuaTE4bi50cmFuc2xhdGUodmFsdWUsIGRhdGEpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,24 +1,22 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { Injectable, computed, inject, isDevMode, signal } from '@angular/core';
|
|
2
|
+
import { DatePickerType } from '..';
|
|
3
3
|
import { I18NInterfaceToken } from './i18n.type';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class I18nService {
|
|
6
|
-
constructor(
|
|
7
|
-
this
|
|
8
|
-
this
|
|
9
|
-
this
|
|
10
|
-
.
|
|
11
|
-
.
|
|
6
|
+
constructor() {
|
|
7
|
+
this.$$i18n = signal(inject(I18NInterfaceToken));
|
|
8
|
+
this.$locale = computed(() => this.$$i18n().locale);
|
|
9
|
+
this.$monthBeforeYear = computed(() => {
|
|
10
|
+
const parts = new Intl.DateTimeFormat(this.$locale()).formatToParts(new Date());
|
|
11
|
+
return (parts.findIndex(part => part.type === DatePickerType.Month) <
|
|
12
|
+
parts.findIndex(part => part.type === DatePickerType.Year));
|
|
13
|
+
});
|
|
12
14
|
}
|
|
13
15
|
setI18n(i18n) {
|
|
14
|
-
this.
|
|
15
|
-
this.i18nChange$$.next(i18n);
|
|
16
|
-
}
|
|
17
|
-
get i18n() {
|
|
18
|
-
return this._i18n;
|
|
16
|
+
this.$$i18n.set(i18n);
|
|
19
17
|
}
|
|
20
18
|
translate(key, data, ignoreNonExist = false) {
|
|
21
|
-
let content = this.
|
|
19
|
+
let content = this.$$i18n().translation[key];
|
|
22
20
|
if (content == null) {
|
|
23
21
|
if (isDevMode() && !ignoreNonExist) {
|
|
24
22
|
console.warn(`No exist translate key for ${key}`);
|
|
@@ -30,7 +28,7 @@ export class I18nService {
|
|
|
30
28
|
}
|
|
31
29
|
return content;
|
|
32
30
|
}
|
|
33
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: I18nService, deps: [
|
|
31
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: I18nService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
34
32
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: I18nService, providedIn: 'root' }); }
|
|
35
33
|
}
|
|
36
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: I18nService, decorators: [{
|
|
@@ -38,8 +36,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
38
36
|
args: [{
|
|
39
37
|
providedIn: 'root',
|
|
40
38
|
}]
|
|
41
|
-
}]
|
|
42
|
-
|
|
43
|
-
args: [I18NInterfaceToken]
|
|
44
|
-
}] }]; } });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2kxOG4vaTE4bi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZUFBZSxFQUFjLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUV4RCxPQUFPLEVBQWlCLGtCQUFrQixFQUFFLE1BQU0sYUFBYSxDQUFDOztBQUtoRSxNQUFNLE9BQU8sV0FBVztJQUt0QixZQUFnRCxLQUFvQjtRQUFwQixVQUFLLEdBQUwsS0FBSyxDQUFlO1FBQ2xFLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxlQUFlLENBQWdCLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNuRSxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxZQUFZO2FBQ25DLFlBQVksRUFBRTthQUNkLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsT0FBTyxDQUFDLElBQW1CO1FBQ3pCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELFNBQVMsQ0FDUCxHQUFXLEVBQ1gsSUFBNkIsRUFDN0IsY0FBYyxHQUFHLEtBQUs7UUFFdEIsSUFBSSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUMsSUFBSSxPQUFPLElBQUksSUFBSSxFQUFFO1lBQ25CLElBQUksU0FBUyxFQUFFLElBQUksQ0FBQyxjQUFjLEVBQUU7Z0JBQ2xDLE9BQU8sQ0FBQyxJQUFJLENBQUMsOEJBQThCLEdBQUcsRUFBRSxDQUFDLENBQUM7YUFDbkQ7WUFDRCxPQUFPLEdBQUcsQ0FBQztTQUNaO1FBQ0QsSUFBSSxJQUFJLEVBQUU7WUFDUixPQUFPLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FDMUIsY0FBYyxFQUNkLENBQUMsUUFBUSxFQUFFLEVBQVUsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUMxQyxDQUFDO1NBQ0g7UUFDRCxPQUFPLE9BQU8sQ0FBQztJQUNqQixDQUFDOzhHQXhDVSxXQUFXLGtCQUtGLGtCQUFrQjtrSEFMM0IsV0FBVyxjQUZWLE1BQU07OzJGQUVQLFdBQVc7a0JBSHZCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzswQkFNYyxNQUFNOzJCQUFDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgaXNEZXZNb2RlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUsIG1hcCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBJMThOSW50ZXJmYWNlLCBJMThOSW50ZXJmYWNlVG9rZW4gfSBmcm9tICcuL2kxOG4udHlwZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBJMThuU2VydmljZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgaTE4bkNoYW5nZSQkOiBCZWhhdmlvclN1YmplY3Q8STE4TkludGVyZmFjZT47XG5cbiAgbG9jYWxlQ2hhbmdlJDogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoSTE4TkludGVyZmFjZVRva2VuKSBwcml2YXRlIF9pMThuOiBJMThOSW50ZXJmYWNlKSB7XG4gICAgdGhpcy5pMThuQ2hhbmdlJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PEkxOE5JbnRlcmZhY2U+KHRoaXMuX2kxOG4pO1xuICAgIHRoaXMubG9jYWxlQ2hhbmdlJCA9IHRoaXMuaTE4bkNoYW5nZSQkXG4gICAgICAuYXNPYnNlcnZhYmxlKClcbiAgICAgIC5waXBlKG1hcChpMThuID0+IGkxOG4ubG9jYWxlKSk7XG4gIH1cblxuICBzZXRJMThuKGkxOG46IEkxOE5JbnRlcmZhY2UpIHtcbiAgICB0aGlzLl9pMThuID0gaTE4bjtcbiAgICB0aGlzLmkxOG5DaGFuZ2UkJC5uZXh0KGkxOG4pO1xuICB9XG5cbiAgZ2V0IGkxOG4oKSB7XG4gICAgcmV0dXJuIHRoaXMuX2kxOG47XG4gIH1cblxuICB0cmFuc2xhdGUoXG4gICAga2V5OiBzdHJpbmcsXG4gICAgZGF0YT86IFJlY29yZDxzdHJpbmcsIHN0cmluZz4sXG4gICAgaWdub3JlTm9uRXhpc3QgPSBmYWxzZSxcbiAgKSB7XG4gICAgbGV0IGNvbnRlbnQgPSB0aGlzLl9pMThuLnRyYW5zbGF0aW9uW2tleV07XG4gICAgaWYgKGNvbnRlbnQgPT0gbnVsbCkge1xuICAgICAgaWYgKGlzRGV2TW9kZSgpICYmICFpZ25vcmVOb25FeGlzdCkge1xuICAgICAgICBjb25zb2xlLndhcm4oYE5vIGV4aXN0IHRyYW5zbGF0ZSBrZXkgZm9yICR7a2V5fWApO1xuICAgICAgfVxuICAgICAgcmV0dXJuIGtleTtcbiAgICB9XG4gICAgaWYgKGRhdGEpIHtcbiAgICAgIGNvbnRlbnQgPSBjb250ZW50LnJlcGxhY2VBbGwoXG4gICAgICAgIC97eyhbXnt9XSspfX0vLFxuICAgICAgICAoX21hdGNoZWQsICQwOiBzdHJpbmcpID0+IGRhdGFbJDAudHJpbSgpXSxcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiBjb250ZW50O1xuICB9XG59XG4iXX0=
|
|
39
|
+
}] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2kxOG4vaTE4bi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWhGLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxJQUFJLENBQUM7QUFFcEMsT0FBTyxFQUFpQixrQkFBa0IsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFLaEUsTUFBTSxPQUFPLFdBQVc7SUFIeEI7UUFJVyxXQUFNLEdBQUcsTUFBTSxDQUFnQixNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUFDO1FBRXBFLFlBQU8sR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRS9DLHFCQUFnQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDL0IsTUFBTSxLQUFLLEdBQUcsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLGFBQWEsQ0FDakUsSUFBSSxJQUFJLEVBQUUsQ0FDWCxDQUFDO1lBQ0YsT0FBTyxDQUNMLEtBQUssQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLGNBQWMsQ0FBQyxLQUFLLENBQUM7Z0JBQzNELEtBQUssQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FDM0QsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO0tBMEJKO0lBeEJDLE9BQU8sQ0FBQyxJQUFtQjtRQUN6QixJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QixDQUFDO0lBRUQsU0FBUyxDQUNQLEdBQVcsRUFDWCxJQUE2QixFQUM3QixjQUFjLEdBQUcsS0FBSztRQUV0QixJQUFJLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzdDLElBQUksT0FBTyxJQUFJLElBQUksRUFBRTtZQUNuQixJQUFJLFNBQVMsRUFBRSxJQUFJLENBQUMsY0FBYyxFQUFFO2dCQUNsQyxPQUFPLENBQUMsSUFBSSxDQUFDLDhCQUE4QixHQUFHLEVBQUUsQ0FBQyxDQUFDO2FBQ25EO1lBQ0QsT0FBTyxHQUFHLENBQUM7U0FDWjtRQUNELElBQUksSUFBSSxFQUFFO1lBQ1IsT0FBTyxHQUFHLE9BQU8sQ0FBQyxVQUFVLENBQzFCLGNBQWMsRUFDZCxDQUFDLFFBQVEsRUFBRSxFQUFVLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FDMUMsQ0FBQztTQUNIO1FBQ0QsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQzs4R0F0Q1UsV0FBVztrSEFBWCxXQUFXLGNBRlYsTUFBTTs7MkZBRVAsV0FBVztrQkFIdkIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBjb21wdXRlZCwgaW5qZWN0LCBpc0Rldk1vZGUsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEYXRlUGlja2VyVHlwZSB9IGZyb20gJy4uJztcblxuaW1wb3J0IHsgSTE4TkludGVyZmFjZSwgSTE4TkludGVyZmFjZVRva2VuIH0gZnJvbSAnLi9pMThuLnR5cGUnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgSTE4blNlcnZpY2Uge1xuICByZWFkb25seSAkJGkxOG4gPSBzaWduYWw8STE4TkludGVyZmFjZT4oaW5qZWN0KEkxOE5JbnRlcmZhY2VUb2tlbikpO1xuXG4gICRsb2NhbGUgPSBjb21wdXRlZCgoKSA9PiB0aGlzLiQkaTE4bigpLmxvY2FsZSk7XG5cbiAgJG1vbnRoQmVmb3JlWWVhciA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBwYXJ0cyA9IG5ldyBJbnRsLkRhdGVUaW1lRm9ybWF0KHRoaXMuJGxvY2FsZSgpKS5mb3JtYXRUb1BhcnRzKFxuICAgICAgbmV3IERhdGUoKSxcbiAgICApO1xuICAgIHJldHVybiAoXG4gICAgICBwYXJ0cy5maW5kSW5kZXgocGFydCA9PiBwYXJ0LnR5cGUgPT09IERhdGVQaWNrZXJUeXBlLk1vbnRoKSA8XG4gICAgICBwYXJ0cy5maW5kSW5kZXgocGFydCA9PiBwYXJ0LnR5cGUgPT09IERhdGVQaWNrZXJUeXBlLlllYXIpXG4gICAgKTtcbiAgfSk7XG5cbiAgc2V0STE4bihpMThuOiBJMThOSW50ZXJmYWNlKSB7XG4gICAgdGhpcy4kJGkxOG4uc2V0KGkxOG4pO1xuICB9XG5cbiAgdHJhbnNsYXRlKFxuICAgIGtleTogc3RyaW5nLFxuICAgIGRhdGE/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+LFxuICAgIGlnbm9yZU5vbkV4aXN0ID0gZmFsc2UsXG4gICkge1xuICAgIGxldCBjb250ZW50ID0gdGhpcy4kJGkxOG4oKS50cmFuc2xhdGlvbltrZXldO1xuICAgIGlmIChjb250ZW50ID09IG51bGwpIHtcbiAgICAgIGlmIChpc0Rldk1vZGUoKSAmJiAhaWdub3JlTm9uRXhpc3QpIHtcbiAgICAgICAgY29uc29sZS53YXJuKGBObyBleGlzdCB0cmFuc2xhdGUga2V5IGZvciAke2tleX1gKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBrZXk7XG4gICAgfVxuICAgIGlmIChkYXRhKSB7XG4gICAgICBjb250ZW50ID0gY29udGVudC5yZXBsYWNlQWxsKFxuICAgICAgICAve3soW157fV0rKX19LyxcbiAgICAgICAgKF9tYXRjaGVkLCAkMDogc3RyaW5nKSA9PiBkYXRhWyQwLnRyaW0oKV0sXG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gY29udGVudDtcbiAgfVxufVxuIl19
|