@acorex/components 7.1.9 → 7.1.11

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.
@@ -1,8 +1,8 @@
1
- import { ChangeDetectorRef, ElementRef, EventEmitter, TemplateRef } from "@angular/core";
1
+ import { EventEmitter, TemplateRef } from "@angular/core";
2
2
  import { AXItemClickEvent, AXRangeChangedEvent, MXBaseComponent } from "@acorex/components/common";
3
- import { AXBaseComponent } from "@acorex/components/mixin";
3
+ import { AXDateTimeRange } from "@acorex/core/dateTime";
4
4
  import * as i0 from "@angular/core";
5
- export type AXCalendarViewType = 'years' | 'months' | 'days';
5
+ export type AXCalendarViewType = 'year' | 'month' | 'day';
6
6
  export type AXCalendarViewDepth = AXCalendarViewType;
7
7
  export type AXCalendarDisabledDates = Date[] | ((date: Date) => boolean);
8
8
  export type AXCalendarHolidayDates = Date[] | ((date: Date) => boolean);
@@ -21,12 +21,28 @@ export declare class AXCalendarNavigateEvent extends AXRangeChangedEvent<Date> {
21
21
  */
22
22
  export declare class AXCalendarSlotClick extends AXItemClickEvent<Date> {
23
23
  }
24
+ export interface AXCalendarViewSlot {
25
+ date: Date;
26
+ text: string;
27
+ tooltip: string;
28
+ today: boolean;
29
+ selected: boolean;
30
+ disabled: boolean;
31
+ cssClass: {
32
+ [key: string]: boolean;
33
+ };
34
+ }
35
+ export interface AXCalendarView {
36
+ range: AXDateTimeRange;
37
+ slots: AXCalendarViewSlot[];
38
+ }
24
39
  declare const MXCalendarBaseComponent_base: import("polytype").Polytype.ClusteredConstructor<[typeof MXBaseComponent]>;
25
40
  export declare class MXCalendarBaseComponent extends MXCalendarBaseComponent_base {
26
41
  interface: 'calendar' | 'picker';
27
42
  cellTemplate?: TemplateRef<any>;
28
43
  cellClass?: AXCalendarCellCssClass;
29
44
  showNavigation: boolean;
45
+ count: number;
30
46
  onSlotClick: EventEmitter<AXCalendarSlotClick>;
31
47
  onNavigate: EventEmitter<AXCalendarNavigateEvent>;
32
48
  activeViewChange: EventEmitter<AXCalendarViewType>;
@@ -60,41 +76,6 @@ export declare class MXCalendarBaseComponent extends MXCalendarBaseComponent_bas
60
76
  static ɵfac: i0.ɵɵFactoryDeclaration<MXCalendarBaseComponent, never>;
61
77
  static ɵprov: i0.ɵɵInjectableDeclaration<MXCalendarBaseComponent>;
62
78
  }
63
- export declare class AXCalendarBaseComponent extends AXBaseComponent {
64
- constructor(elementRef: ElementRef, cdr: ChangeDetectorRef);
65
- onSlotClick: EventEmitter<AXItemClickEvent<Date>>;
66
- onNavigate: EventEmitter<AXCalendarNavigateEvent>;
67
- activeViewChange: EventEmitter<AXCalendarViewType>;
68
- private _activeView;
69
- get activeView(): AXCalendarViewType;
70
- set activeView(v: AXCalendarViewType);
71
- typeChange: EventEmitter<string>;
72
- private _type;
73
- get type(): string;
74
- set type(v: string);
75
- depthChange: EventEmitter<AXCalendarViewDepth>;
76
- private _depth;
77
- get depth(): AXCalendarViewDepth;
78
- set depth(v: AXCalendarViewDepth);
79
- minChange: EventEmitter<Date>;
80
- private _min;
81
- get min(): Date;
82
- set min(v: Date);
83
- maxChange: EventEmitter<Date>;
84
- private _max;
85
- get max(): Date;
86
- set max(v: Date);
87
- disabledDatesChange: EventEmitter<AXCalendarDisabledDates>;
88
- private _disabledDates;
89
- get disabledDates(): AXCalendarDisabledDates;
90
- set disabledDates(v: AXCalendarDisabledDates);
91
- holidayDatesChange: EventEmitter<AXCalendarHolidayDates>;
92
- private _holidayDates;
93
- get holidayDates(): AXCalendarHolidayDates;
94
- set holidayDates(v: AXCalendarHolidayDates);
95
- static ɵfac: i0.ɵɵFactoryDeclaration<AXCalendarBaseComponent, never>;
96
- static ɵprov: i0.ɵɵInjectableDeclaration<AXCalendarBaseComponent>;
97
- }
98
79
  export declare const CALENDAR_INPUTS: string[];
99
80
  export declare const CALENDAR_OUTPUTS: string[];
100
81
  export {};
@@ -1,6 +1,6 @@
1
1
  import { AXDateTime, AXDateTimeRange } from '@acorex/core/dateTime';
2
2
  import { AXClickEvent, AXOptionChangedEvent, MXInteractiveComponent, MXValueComponent } from '@acorex/components/common';
3
- import { MXCalendarBaseComponent } from './calendar.class';
3
+ import { AXCalendarView, AXCalendarViewSlot, AXCalendarViewType, MXCalendarBaseComponent } from './calendar.class';
4
4
  import * as i0 from "@angular/core";
5
5
  declare const AXCalendarComponent_base: import("polytype").Polytype.ClusteredConstructor<[{
6
6
  new (): MXValueComponent<Date>;
@@ -9,20 +9,22 @@ declare const AXCalendarComponent_base: import("polytype").Polytype.ClusteredCon
9
9
  }, typeof MXInteractiveComponent, typeof MXCalendarBaseComponent]>;
10
10
  export declare class AXCalendarComponent extends AXCalendarComponent_base {
11
11
  get displayRange(): AXDateTimeRange;
12
+ private _setDisplayRange;
12
13
  protected _today: AXDateTime;
13
14
  private _viewStartDate;
14
- protected _navText: string;
15
- protected _todayText: string;
16
- protected _slots: any[];
15
+ private _footPrint;
16
+ protected views: AXCalendarView[];
17
17
  protected _dayNames: string[];
18
18
  private _initValues;
19
19
  private _refresh;
20
+ constructor();
20
21
  protected ngOnInit(): void;
22
+ protected ngAfterViewInit(): void;
21
23
  render(): void;
22
24
  protected _handlePrevClick(): void;
23
25
  protected _handleNextClick(): void;
24
- protected _handleSlotClick(e: MouseEvent, slot: any): void;
25
- protected _handleNavClick(e: AXClickEvent | any): void;
26
+ protected _handleSlotClick(e: MouseEvent, slot: AXCalendarViewSlot): void;
27
+ protected _handleNavClick(e: AXClickEvent | any, view: AXCalendarViewType): void;
26
28
  toggleView(): void;
27
29
  protected _handleOnOptionChanged(e: AXOptionChangedEvent): void;
28
30
  private _handleOnValueChanged;
@@ -39,6 +41,6 @@ export declare class AXCalendarComponent extends AXCalendarComponent_base {
39
41
  protected isHoliday(date: AXDateTime): boolean;
40
42
  protected isWeekend(date: AXDateTime): boolean;
41
43
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCalendarComponent, never>;
42
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCalendarComponent, "ax-calendar", never, { "rtl": { "alias": "rtl"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "value": { "alias": "value"; "required": false; }; "name": { "alias": "name"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "depth": { "alias": "depth"; "required": false; }; "activeView": { "alias": "activeView"; "required": false; }; "min": { "alias": "min"; "required": false; }; "max": { "alias": "max"; "required": false; }; "disabledDates": { "alias": "disabledDates"; "required": false; }; "holidayDates": { "alias": "holidayDates"; "required": false; }; "type": { "alias": "type"; "required": false; }; "cellTemplate": { "alias": "cellTemplate"; "required": false; }; "cellClass": { "alias": "cellClass"; "required": false; }; "showNavigation": { "alias": "showNavigation"; "required": false; }; }, { "onOptionChanged": "onOptionChanged"; "valueChange": "valueChange"; "onValueChanged": "onValueChanged"; "onBlur": "onBlur"; "onFocus": "onFocus"; "depthChange": "depthChange"; "typeChange": "typeChange"; "activeViewChange": "activeViewChange"; "disabledDatesChange": "disabledDatesChange"; "holidayDatesChange": "holidayDatesChange"; "onNavigate": "onNavigate"; "onSlotClick": "onSlotClick"; }, never, ["ax-header", "ax-footer"], false, never>;
44
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCalendarComponent, "ax-calendar", never, { "rtl": { "alias": "rtl"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "value": { "alias": "value"; "required": false; }; "name": { "alias": "name"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "depth": { "alias": "depth"; "required": false; }; "activeView": { "alias": "activeView"; "required": false; }; "min": { "alias": "min"; "required": false; }; "max": { "alias": "max"; "required": false; }; "disabledDates": { "alias": "disabledDates"; "required": false; }; "holidayDates": { "alias": "holidayDates"; "required": false; }; "type": { "alias": "type"; "required": false; }; "cellTemplate": { "alias": "cellTemplate"; "required": false; }; "cellClass": { "alias": "cellClass"; "required": false; }; "showNavigation": { "alias": "showNavigation"; "required": false; }; "count": { "alias": "count"; "required": false; }; }, { "onOptionChanged": "onOptionChanged"; "valueChange": "valueChange"; "onValueChanged": "onValueChanged"; "onBlur": "onBlur"; "onFocus": "onFocus"; "depthChange": "depthChange"; "typeChange": "typeChange"; "activeViewChange": "activeViewChange"; "disabledDatesChange": "disabledDatesChange"; "holidayDatesChange": "holidayDatesChange"; "onNavigate": "onNavigate"; "onSlotClick": "onSlotClick"; "countChange": "countChange"; }, never, ["ax-header", "ax-footer"], false, never>;
43
45
  }
44
46
  export {};
@@ -57,20 +57,20 @@ class AXCalendarRangeComponent extends classes((MXValueComponent), MXInteractive
57
57
  handlePrevClick() {
58
58
  const view = this._c1.activeView;
59
59
  const d1 = this._c1.displayRange.startTime;
60
- if (view == 'days' || view == 'months') {
60
+ if (view == 'day' || view == 'month') {
61
61
  this._c1.prev();
62
62
  }
63
- else if (view == 'years') {
63
+ else if (view == 'year') {
64
64
  this._c1.navTo(d1.add('year', -20));
65
65
  }
66
66
  }
67
67
  handleNextClick() {
68
68
  const view = this._c1.activeView;
69
69
  const d1 = this._c1.displayRange.startTime;
70
- if (view == 'days' || view == 'months') {
70
+ if (view == 'day' || view == 'month') {
71
71
  this._c1.next();
72
72
  }
73
- else if (view == 'years') {
73
+ else if (view == 'year') {
74
74
  this._c1.navTo(d1.add('year', 20));
75
75
  }
76
76
  }
@@ -80,15 +80,15 @@ class AXCalendarRangeComponent extends classes((MXValueComponent), MXInteractive
80
80
  _syncNavText() {
81
81
  const view = this._c1.activeView;
82
82
  const d1 = this._c1.displayRange.startTime;
83
- if (view == 'days') {
83
+ if (view == 'day') {
84
84
  const d2 = this._c2.displayRange.endTime;
85
85
  this._navText = `${d1.format('MMM yyyy')} - ${d2.format('MMM yyyy')}`;
86
86
  }
87
- else if (view == 'months') {
87
+ else if (view == 'month') {
88
88
  const d2 = this._c2.displayRange.endTime;
89
89
  this._navText = `${d1.format('yyyy')} - ${d2.format('yyyy')}`;
90
90
  }
91
- else if (view == 'years') {
91
+ else if (view == 'year') {
92
92
  const d2 = this._c2.displayRange.endTime;
93
93
  this._navText = `${d1.format('yyyy')} - ${d2.format('yyyy')}`;
94
94
  }
@@ -108,28 +108,28 @@ class AXCalendarRangeComponent extends classes((MXValueComponent), MXInteractive
108
108
  _syncNav1() {
109
109
  const view = (this._c2.activeView = this._c1.activeView);
110
110
  const range = this._c1.displayRange;
111
- if (view == 'days') {
111
+ if (view == 'day') {
112
112
  this._c2.navTo(range.startTime.add('month', 1));
113
113
  }
114
- else if (view == 'months') {
114
+ else if (view == 'month') {
115
115
  this._c2.navTo(range.startTime.add('year', 1));
116
116
  }
117
- else if (view == 'years') {
117
+ else if (view == 'year') {
118
118
  this._c2.navTo(range.endTime.add('year', 4));
119
119
  }
120
120
  this._syncNavText();
121
121
  }
122
122
  _syncNav2(e) {
123
123
  const view = this._c2.activeView;
124
- if (view == 'months') {
124
+ if (view == 'month') {
125
125
  this._c1.navTo(e.add('month', -1));
126
126
  }
127
- else if (view == 'years') {
127
+ else if (view == 'year') {
128
128
  this._c1.navTo(e.startOf('year'));
129
129
  }
130
130
  }
131
131
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AXCalendarRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
132
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AXCalendarRangeComponent, selector: "ax-calendar-range", inputs: { rtl: "rtl", readonly: "readonly", value: "value", name: "name", disabled: "disabled", depth: "depth", activeView: "activeView", min: "min", max: "max", disabledDates: "disabledDates", holidayDates: "holidayDates", type: "type", cellTemplate: "cellTemplate", cellClass: "cellClass", showNavigation: "showNavigation" }, outputs: { onOptionChanged: "onOptionChanged", valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", depthChange: "depthChange", typeChange: "typeChange", activeViewChange: "activeViewChange", disabledDatesChange: "disabledDatesChange", holidayDatesChange: "holidayDatesChange", onNavigate: "onNavigate", onSlotClick: "onSlotClick" }, viewQueries: [{ propertyName: "_c1", first: true, predicate: ["c1"], descendants: true, static: true }, { propertyName: "_c2", first: true, predicate: ["c2"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-calendar-range-header\">\n <ng-content></ng-content>\n <div class=\"ax-calendar-header-range-info\">\n <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button\" (click)=\"handleNavClick()\">\n {{ _navText }}\n </button>\n </div>\n <div class=\"ax-calendar-header-range-buttons\">\n <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n (click)=\"handlePrevClick()\">\n <i class=\"ax-icon\" [ngClass]=\"{\n 'ax-icon-chevron-left': !rtl,\n 'ax-icon-chevron-right': rtl\n }\"></i>\n </button>\n <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n (click)=\"handleNextClick()\">\n <i class=\"ax-icon\" [ngClass]=\"{\n 'ax-icon-chevron-left': rtl,\n 'ax-icon-chevron-right': !rtl\n }\"></i>\n </button>\n </div>\n</div>\n<div class=\"ax-calendar-range-body\">\n <ax-calendar #c1 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n (onNavigate)=\"handleNavigate()\" (activeViewChange)=\"handleActiveViewChange1()\">\n </ax-calendar>\n <ax-calendar #c2 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n (activeViewChange)=\"handleActiveViewChange2()\">\n </ax-calendar>\n</div>", styles: [".ax-dark ax-calendar-range{background:rgba(var(--ax-color-on-surface))}.ax-dark ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-between{background-color:rgba(var(--ax-color-primary-800));color:rgba(var(--ax-color-primary-fore))}ax-calendar-range{background:rgba(var(--ax-color-surface));color:rgba(var(--ax-color-text-default));padding:.5rem}ax-calendar-range .ax-calendar-range-header{display:flex;justify-content:space-between;padding-top:.25rem;padding-left:.25rem;padding-right:.25rem}ax-calendar-range .ax-calendar-range-header .ax-calendar-header-range-info{font-weight:500}ax-calendar-range .ax-calendar-range-header .ax-calendar-header-range-buttons{display:flex}ax-calendar-range .ax-calendar-range-body{display:flex;flex-direction:row}ax-calendar-range ax-calendar{margin:0;padding:0}ax-calendar-range ax-calendar .ax-calendar-body{margin-top:0;padding-top:0}ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-between{background-color:rgba(var(--ax-color-primary-100));color:rgba(var(--ax-color-primary-500))}ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-start,ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-end{background-color:rgba(var(--ax-color-primary-500));color:rgba(var(--ax-color-primary-fore))}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.AXCalendarComponent, selector: "ax-calendar", inputs: ["rtl", "readonly", "value", "name", "disabled", "depth", "activeView", "min", "max", "disabledDates", "holidayDates", "type", "cellTemplate", "cellClass", "showNavigation"], outputs: ["onOptionChanged", "valueChange", "onValueChanged", "onBlur", "onFocus", "depthChange", "typeChange", "activeViewChange", "disabledDatesChange", "holidayDatesChange", "onNavigate", "onSlotClick"] }], encapsulation: i0.ViewEncapsulation.None });
132
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: AXCalendarRangeComponent, selector: "ax-calendar-range", inputs: { rtl: "rtl", readonly: "readonly", value: "value", name: "name", disabled: "disabled", depth: "depth", activeView: "activeView", min: "min", max: "max", disabledDates: "disabledDates", holidayDates: "holidayDates", type: "type", cellTemplate: "cellTemplate", cellClass: "cellClass", showNavigation: "showNavigation" }, outputs: { onOptionChanged: "onOptionChanged", valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", depthChange: "depthChange", typeChange: "typeChange", activeViewChange: "activeViewChange", disabledDatesChange: "disabledDatesChange", holidayDatesChange: "holidayDatesChange", onNavigate: "onNavigate", onSlotClick: "onSlotClick" }, viewQueries: [{ propertyName: "_c1", first: true, predicate: ["c1"], descendants: true, static: true }, { propertyName: "_c2", first: true, predicate: ["c2"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-calendar-range-header\">\n <ng-content></ng-content>\n <div class=\"ax-calendar-header-range-info\">\n <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button\" (click)=\"handleNavClick()\">\n {{ _navText }}\n </button>\n </div>\n <div class=\"ax-calendar-header-range-buttons\">\n <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n (click)=\"handlePrevClick()\">\n <i class=\"ax-icon\" [ngClass]=\"{\n 'ax-icon-chevron-left': !rtl,\n 'ax-icon-chevron-right': rtl\n }\"></i>\n </button>\n <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n (click)=\"handleNextClick()\">\n <i class=\"ax-icon\" [ngClass]=\"{\n 'ax-icon-chevron-left': rtl,\n 'ax-icon-chevron-right': !rtl\n }\"></i>\n </button>\n </div>\n</div>\n<div class=\"ax-calendar-range-body\">\n <ax-calendar #c1 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n (onNavigate)=\"handleNavigate()\" (activeViewChange)=\"handleActiveViewChange1()\">\n </ax-calendar>\n <ax-calendar #c2 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n (activeViewChange)=\"handleActiveViewChange2()\">\n </ax-calendar>\n</div>", styles: [".ax-dark ax-calendar-range{background:rgba(var(--ax-color-on-surface))}.ax-dark ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-between{background-color:rgba(var(--ax-color-primary-800));color:rgba(var(--ax-color-primary-fore))}ax-calendar-range{background:rgba(var(--ax-color-surface));color:rgba(var(--ax-color-text-default));padding:.5rem}ax-calendar-range .ax-calendar-range-header{display:flex;justify-content:space-between;padding-top:.25rem;padding-left:.25rem;padding-right:.25rem}ax-calendar-range .ax-calendar-range-header .ax-calendar-header-range-info{font-weight:500}ax-calendar-range .ax-calendar-range-header .ax-calendar-header-range-buttons{display:flex}ax-calendar-range .ax-calendar-range-body{display:flex;flex-direction:row}ax-calendar-range ax-calendar{margin:0;padding:0}ax-calendar-range ax-calendar .ax-calendar-body{margin-top:0;padding-top:0}ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-between{background-color:rgba(var(--ax-color-primary-100));color:rgba(var(--ax-color-primary-500))}ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-start,ax-calendar-range ax-calendar .ax-calendar-body .ax-calendar-slots .ax-calendar-slot.ax-range-end{background-color:rgba(var(--ax-color-primary-500));color:rgba(var(--ax-color-primary-fore))}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.AXCalendarComponent, selector: "ax-calendar", inputs: ["rtl", "readonly", "value", "name", "disabled", "depth", "activeView", "min", "max", "disabledDates", "holidayDates", "type", "cellTemplate", "cellClass", "showNavigation", "count"], outputs: ["onOptionChanged", "valueChange", "onValueChanged", "onBlur", "onFocus", "depthChange", "typeChange", "activeViewChange", "disabledDatesChange", "holidayDatesChange", "onNavigate", "onSlotClick", "countChange"] }], encapsulation: i0.ViewEncapsulation.None });
133
133
  }
134
134
  export { AXCalendarRangeComponent };
135
135
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AXCalendarRangeComponent, decorators: [{
@@ -171,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
171
171
  type: ViewChild,
172
172
  args: ['c2', { static: true }]
173
173
  }] } });
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-range.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/calendar/src/calendar-range.component.ts","../../../../../../projects/acorex/components/calendar/src/calendar-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXRange, MXInteractiveComponent, MXValueComponent } from '@acorex/components/common';\nimport { Component, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { classes } from 'polytype';\nimport { AXCalendarComponent } from './calendar.component';\nimport { AXCalendarSlotClick, MXCalendarBaseComponent } from './calendar.class';\nimport { AXDateTime } from '@acorex/core/dateTime';\n\n@Component({\n  selector: 'ax-calendar-range',\n  templateUrl: 'calendar-range.component.html',\n  styleUrls: ['calendar-range.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  inputs: [\n    'rtl',\n    'readonly',\n    'value',\n    'name',\n    'disabled',\n    'depth',\n    'activeView',\n    'min',\n    'max',\n    'disabledDates',\n    'holidayDates',\n    'type',\n    'cellTemplate',\n    'cellClass',\n    'showNavigation',\n  ],\n  outputs: [\n    'onOptionChanged',\n    'valueChange',\n    'onValueChanged',\n    'onBlur',\n    'onFocus',\n    'depthChange',\n    'typeChange',\n    'activeViewChange',\n    'disabledDatesChange',\n    'holidayDatesChange',\n    'onNavigate',\n    'onSlotClick',\n  ],\n})\nexport class AXCalendarRangeComponent extends classes(MXValueComponent<AXRange<Date>>, MXInteractiveComponent, MXCalendarBaseComponent) {\n  @ViewChild('c1', { static: true })\n  private _c1: AXCalendarComponent;\n\n  @ViewChild('c2', { static: true })\n  private _c2: AXCalendarComponent;\n\n  _navText: string = '';\n\n  constructor() {\n    super();\n    this.defaultValue = { from: null, end: null };\n  }\n\n  protected ngAfterViewInit(): void {\n    super.ngAfterViewInit();\n    this._syncNav1();\n  }\n\n  getCellClass = (date: Date) => {\n    const d = new AXDateTime(date);\n    const from = new AXDateTime(this.value.from);\n    const end = new AXDateTime(this.value.end);\n    if (this.value.from && d.equal(from, 'day')) {\n      return 'ax-range-start';\n    }\n    if (this.value.end && d.equal(end, 'day')) return 'ax-range-end';\n    if (this.value.from && this.value.end && d.compare(from, 'day') > 0 && d.compare(end, 'day') < 0) return 'ax-range-between';\n    return null;\n  };\n\n  protected handleSlotClick(e: AXCalendarSlotClick) {\n    if (this._c1.activeView == this.depth) {\n      if (!this.value.from || (this.value.from && this.value.end)) {\n        this.value.from = e.item;\n        this.value.end = null;\n      }\n      if (this.value.from && e.item <= this.value.from) {\n        this.value.from = e.item;\n      } else if (this.value.from && !this.value.end) {\n        this.value.end = e.item;\n      }\n    } else {\n      if (e.component == this._c1) this._syncNav1();\n      if (e.component == this._c2) {\n        this._syncNav2(new AXDateTime(e.item));\n      }\n    }\n    this._c1.render();\n    this._c2.render();\n  }\n\n  protected handlePrevClick() {\n    const view = this._c1.activeView;\n    const d1 = this._c1.displayRange.startTime;\n    if (view == 'days' || view == 'months') {\n      this._c1.prev();\n    } else if (view == 'years') {\n      this._c1.navTo(d1.add('year', -20));\n    }\n  }\n\n  protected handleNextClick() {\n    const view = this._c1.activeView;\n    const d1 = this._c1.displayRange.startTime;\n    if (view == 'days' || view == 'months') {\n      this._c1.next();\n    } else if (view == 'years') {\n      this._c1.navTo(d1.add('year', 20));\n    }\n  }\n\n  protected handleNavClick() {\n    this._c1.toggleView();\n  }\n\n  private _syncNavText() {\n    const view = this._c1.activeView;\n    const d1 = this._c1.displayRange.startTime;\n    if (view == 'days') {\n      const d2 = this._c2.displayRange.endTime;\n      this._navText = `${d1.format('MMM yyyy')} - ${d2.format('MMM yyyy')}`;\n    } else if (view == 'months') {\n      const d2 = this._c2.displayRange.endTime;\n      this._navText = `${d1.format('yyyy')} - ${d2.format('yyyy')}`;\n    } else if (view == 'years') {\n      const d2 = this._c2.displayRange.endTime;\n      this._navText = `${d1.format('yyyy')} - ${d2.format('yyyy')}`;\n    }\n  }\n\n  protected handleNavigate() {\n    this._syncNav1();\n  }\n\n  protected handleActiveViewChange1() {\n    this._c2.activeView = this._c1.activeView;\n    this._syncNav1();\n  }\n\n  protected handleActiveViewChange2() {\n    if (this._c2.activeView != this._c1.activeView) {\n      this._c1.activeView = this._c2.activeView;\n    }\n  }\n\n  private _syncNav1() {\n    const view = (this._c2.activeView = this._c1.activeView);\n    const range = this._c1.displayRange;\n    if (view == 'days') {\n      this._c2.navTo(range.startTime.add('month', 1));\n    } else if (view == 'months') {\n      this._c2.navTo(range.startTime.add('year', 1));\n    } else if (view == 'years') {\n      this._c2.navTo(range.endTime.add('year', 4));\n    }\n    this._syncNavText();\n  }\n\n  private _syncNav2(e: AXDateTime) {\n    const view = this._c2.activeView;\n    if (view == 'months') {\n      this._c1.navTo(e.add('month', -1));\n    } else if (view == 'years') {\n      this._c1.navTo(e.startOf('year'));\n    }\n  }\n}\n","<div class=\"ax-calendar-range-header\">\n    <ng-content></ng-content>\n    <div class=\"ax-calendar-header-range-info\">\n        <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button\" (click)=\"handleNavClick()\">\n            {{ _navText }}\n        </button>\n    </div>\n    <div class=\"ax-calendar-header-range-buttons\">\n        <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n            (click)=\"handlePrevClick()\">\n            <i class=\"ax-icon\" [ngClass]=\"{\n                'ax-icon-chevron-left': !rtl,\n                'ax-icon-chevron-right': rtl\n              }\"></i>\n        </button>\n        <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n            (click)=\"handleNextClick()\">\n            <i class=\"ax-icon\" [ngClass]=\"{\n                'ax-icon-chevron-left': rtl,\n                'ax-icon-chevron-right': !rtl\n              }\"></i>\n        </button>\n    </div>\n</div>\n<div class=\"ax-calendar-range-body\">\n    <ax-calendar #c1 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n        [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n        (onNavigate)=\"handleNavigate()\" (activeViewChange)=\"handleActiveViewChange1()\">\n    </ax-calendar>\n    <ax-calendar #c2 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n        [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n        (activeViewChange)=\"handleActiveViewChange2()\">\n    </ax-calendar>\n</div>"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-range.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/calendar/src/calendar-range.component.ts","../../../../../../projects/acorex/components/calendar/src/calendar-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXRange, MXInteractiveComponent, MXValueComponent } from '@acorex/components/common';\nimport { Component, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { classes } from 'polytype';\nimport { AXCalendarComponent } from './calendar.component';\nimport { AXCalendarSlotClick, MXCalendarBaseComponent } from './calendar.class';\nimport { AXDateTime } from '@acorex/core/dateTime';\n\n@Component({\n  selector: 'ax-calendar-range',\n  templateUrl: 'calendar-range.component.html',\n  styleUrls: ['calendar-range.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  inputs: [\n    'rtl',\n    'readonly',\n    'value',\n    'name',\n    'disabled',\n    'depth',\n    'activeView',\n    'min',\n    'max',\n    'disabledDates',\n    'holidayDates',\n    'type',\n    'cellTemplate',\n    'cellClass',\n    'showNavigation',\n  ],\n  outputs: [\n    'onOptionChanged',\n    'valueChange',\n    'onValueChanged',\n    'onBlur',\n    'onFocus',\n    'depthChange',\n    'typeChange',\n    'activeViewChange',\n    'disabledDatesChange',\n    'holidayDatesChange',\n    'onNavigate',\n    'onSlotClick',\n  ],\n})\nexport class AXCalendarRangeComponent extends classes(MXValueComponent<AXRange<Date>>, MXInteractiveComponent, MXCalendarBaseComponent) {\n  @ViewChild('c1', { static: true })\n  private _c1: AXCalendarComponent;\n\n  @ViewChild('c2', { static: true })\n  private _c2: AXCalendarComponent;\n\n  _navText: string = '';\n\n  constructor() {\n    super();\n    this.defaultValue = { from: null, end: null };\n  }\n\n  protected ngAfterViewInit(): void {\n    super.ngAfterViewInit();\n    this._syncNav1();\n  }\n\n  getCellClass = (date: Date) => {\n    const d = new AXDateTime(date);\n    const from = new AXDateTime(this.value.from);\n    const end = new AXDateTime(this.value.end);\n    if (this.value.from && d.equal(from, 'day')) {\n      return 'ax-range-start';\n    }\n    if (this.value.end && d.equal(end, 'day')) return 'ax-range-end';\n    if (this.value.from && this.value.end && d.compare(from, 'day') > 0 && d.compare(end, 'day') < 0) return 'ax-range-between';\n    return null;\n  };\n\n  protected handleSlotClick(e: AXCalendarSlotClick) {\n    if (this._c1.activeView == this.depth) {\n      if (!this.value.from || (this.value.from && this.value.end)) {\n        this.value.from = e.item;\n        this.value.end = null;\n      }\n      if (this.value.from && e.item <= this.value.from) {\n        this.value.from = e.item;\n      } else if (this.value.from && !this.value.end) {\n        this.value.end = e.item;\n      }\n    } else {\n      if (e.component == this._c1) this._syncNav1();\n      if (e.component == this._c2) {\n        this._syncNav2(new AXDateTime(e.item));\n      }\n    }\n    this._c1.render();\n    this._c2.render();\n  }\n\n  protected handlePrevClick() {\n    const view = this._c1.activeView;\n    const d1 = this._c1.displayRange.startTime;\n    if (view == 'day' || view == 'month') {\n      this._c1.prev();\n    } else if (view == 'year') {\n      this._c1.navTo(d1.add('year', -20));\n    }\n  }\n\n  protected handleNextClick() {\n    const view = this._c1.activeView;\n    const d1 = this._c1.displayRange.startTime;\n    if (view == 'day' || view == 'month') {\n      this._c1.next();\n    } else if (view == 'year') {\n      this._c1.navTo(d1.add('year', 20));\n    }\n  }\n\n  protected handleNavClick() {\n    this._c1.toggleView();\n  }\n\n  private _syncNavText() {\n    const view = this._c1.activeView;\n    const d1 = this._c1.displayRange.startTime;\n    if (view == 'day') {\n      const d2 = this._c2.displayRange.endTime;\n      this._navText = `${d1.format('MMM yyyy')} - ${d2.format('MMM yyyy')}`;\n    } else if (view == 'month') {\n      const d2 = this._c2.displayRange.endTime;\n      this._navText = `${d1.format('yyyy')} - ${d2.format('yyyy')}`;\n    } else if (view == 'year') {\n      const d2 = this._c2.displayRange.endTime;\n      this._navText = `${d1.format('yyyy')} - ${d2.format('yyyy')}`;\n    }\n  }\n\n  protected handleNavigate() {\n    this._syncNav1();\n  }\n\n  protected handleActiveViewChange1() {\n    this._c2.activeView = this._c1.activeView;\n    this._syncNav1();\n  }\n\n  protected handleActiveViewChange2() {\n    if (this._c2.activeView != this._c1.activeView) {\n      this._c1.activeView = this._c2.activeView;\n    }\n  }\n\n  private _syncNav1() {\n    const view = (this._c2.activeView = this._c1.activeView);\n    const range = this._c1.displayRange;\n    if (view == 'day') {\n      this._c2.navTo(range.startTime.add('month', 1));\n    } else if (view == 'month') {\n      this._c2.navTo(range.startTime.add('year', 1));\n    } else if (view == 'year') {\n      this._c2.navTo(range.endTime.add('year', 4));\n    }\n    this._syncNavText();\n  }\n\n  private _syncNav2(e: AXDateTime) {\n    const view = this._c2.activeView;\n    if (view == 'month') {\n      this._c1.navTo(e.add('month', -1));\n    } else if (view == 'year') {\n      this._c1.navTo(e.startOf('year'));\n    }\n  }\n}\n","<div class=\"ax-calendar-range-header\">\n    <ng-content></ng-content>\n    <div class=\"ax-calendar-header-range-info\">\n        <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button\" (click)=\"handleNavClick()\">\n            {{ _navText }}\n        </button>\n    </div>\n    <div class=\"ax-calendar-header-range-buttons\">\n        <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n            (click)=\"handlePrevClick()\">\n            <i class=\"ax-icon\" [ngClass]=\"{\n                'ax-icon-chevron-left': !rtl,\n                'ax-icon-chevron-right': rtl\n              }\"></i>\n        </button>\n        <button [attr.disabled]=\"disabled ? '' : null\" class=\"ax-general-button ax-button-icon\"\n            (click)=\"handleNextClick()\">\n            <i class=\"ax-icon\" [ngClass]=\"{\n                'ax-icon-chevron-left': rtl,\n                'ax-icon-chevron-right': !rtl\n              }\"></i>\n        </button>\n    </div>\n</div>\n<div class=\"ax-calendar-range-body\">\n    <ax-calendar #c1 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n        [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n        (onNavigate)=\"handleNavigate()\" (activeViewChange)=\"handleActiveViewChange1()\">\n    </ax-calendar>\n    <ax-calendar #c2 style=\"width: 50%;\" [showNavigation]=\"false\" [cellClass]=\"getCellClass\" [type]=\"type\"\n        [cellTemplate]=\"cellTemplate\" [min]=\"min\" [max]=\"max\" [readonly]=\"true\" [depth]=\"depth\" (onSlotClick)=\"handleSlotClick($event)\"\n        (activeViewChange)=\"handleActiveViewChange2()\">\n    </ax-calendar>\n</div>"]}
@@ -1,7 +1,6 @@
1
1
  import { AXConfig } from "@acorex/core/config";
2
2
  import { EventEmitter, Injectable, Input, Output } from "@angular/core";
3
3
  import { AXItemClickEvent, AXRangeChangedEvent, MXBaseComponent } from "@acorex/components/common";
4
- import { AXBaseComponent } from "@acorex/components/mixin";
5
4
  import { classes } from "polytype";
6
5
  import * as i0 from "@angular/core";
7
6
  /**
@@ -16,15 +15,73 @@ export class AXCalendarNavigateEvent extends AXRangeChangedEvent {
16
15
  */
17
16
  export class AXCalendarSlotClick extends AXItemClickEvent {
18
17
  }
18
+ // export class AXCalendarView {
19
+ // private _range: AXDateTimeRange;
20
+ // private _slots: AXCalendarViewSlot[] = [];
21
+ // get range(): AXDateTimeRange {
22
+ // return this.range;
23
+ // }
24
+ // get slots(): AXCalendarViewSlot[] {
25
+ // return this._slots;
26
+ // }
27
+ // constructor(
28
+ // private readonly startDate: AXDateTime,
29
+ // private readonly view: AXCalendarViewType
30
+ // ) {
31
+ // const current = this.startDate;
32
+ // let textFormat = 'YYYY';
33
+ // let tooltipFormat = 'YYYY';
34
+ // switch (this.view) {
35
+ // case 'year':
36
+ // let y = current.startOf('year').year;
37
+ // let min = y - (y % 10);
38
+ // let max = min + 9;
39
+ // this._range = new AXDateTimeRange(
40
+ // AXDateTime.from({
41
+ // year: min,
42
+ // month: 1,
43
+ // date: 1,
44
+ // calendar: this.startDate.calendar.name(),
45
+ // }),
46
+ // AXDateTime.from({
47
+ // year: max,
48
+ // month: 12,
49
+ // date: 28,
50
+ // calendar: this.startDate.calendar.name(),
51
+ // })
52
+ // );
53
+ // break;
54
+ // case 'month':
55
+ // textFormat = 'MMM';
56
+ // tooltipFormat = 'MMMM YYYY';
57
+ // this._range = new AXDateTimeRange(
58
+ // current.startOf('year'),
59
+ // current.endOf('year').add('day', -1)
60
+ // );
61
+ // break;
62
+ // default:
63
+ // this._range = new AXDateTimeRange(
64
+ // current.startOf('month'),
65
+ // current.endOf('month')
66
+ // );
67
+ // }
68
+ // //
69
+ // this._slots = this.range.enumurate(view).map(r => ({
70
+ // date: r.date,
71
+ // tooltip: r.format()
72
+ // }));
73
+ // }
74
+ // }
19
75
  class MXCalendarBaseComponent extends classes(MXBaseComponent) {
20
76
  interface = 'calendar';
21
77
  cellTemplate;
22
78
  cellClass;
23
79
  showNavigation = true;
80
+ count = 1;
24
81
  onSlotClick = new EventEmitter();
25
82
  onNavigate = new EventEmitter();
26
83
  activeViewChange = new EventEmitter();
27
- _activeView = 'days';
84
+ _activeView = 'day';
28
85
  get activeView() {
29
86
  return this._activeView;
30
87
  }
@@ -52,7 +109,7 @@ class MXCalendarBaseComponent extends classes(MXBaseComponent) {
52
109
  });
53
110
  }
54
111
  depthChange = new EventEmitter();
55
- _depth = 'days';
112
+ _depth = 'day';
56
113
  get depth() {
57
114
  return this._depth;
58
115
  }
@@ -126,117 +183,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
126
183
  type: Input
127
184
  }], showNavigation: [{
128
185
  type: Input
129
- }], onSlotClick: [{
130
- type: Output
131
- }], onNavigate: [{
132
- type: Output
133
- }], activeViewChange: [{
134
- type: Output
135
- }], activeView: [{
136
- type: Input
137
- }], typeChange: [{
138
- type: Output
139
- }], type: [{
140
- type: Input
141
- }], depthChange: [{
142
- type: Output
143
- }], depth: [{
144
- type: Input
145
- }], minChange: [{
146
- type: Output
147
- }], min: [{
148
- type: Input
149
- }], maxChange: [{
150
- type: Output
151
- }], max: [{
186
+ }], count: [{
152
187
  type: Input
153
- }], disabledDatesChange: [{
154
- type: Output
155
- }], disabledDates: [{
156
- type: Input
157
- }], holidayDatesChange: [{
158
- type: Output
159
- }], holidayDates: [{
160
- type: Input
161
- }] } });
162
- class AXCalendarBaseComponent extends AXBaseComponent {
163
- constructor(elementRef, cdr) {
164
- super(elementRef, cdr);
165
- }
166
- onSlotClick = new EventEmitter();
167
- onNavigate = new EventEmitter();
168
- activeViewChange = new EventEmitter();
169
- _activeView = 'days';
170
- get activeView() {
171
- return this._activeView;
172
- }
173
- set activeView(v) {
174
- this._setOption({ name: 'activeView', value: v });
175
- }
176
- typeChange = new EventEmitter();
177
- _type = AXConfig.get(`dateTime.calendar`);
178
- get type() {
179
- return this._type || AXConfig.get(`dateTime.calendar`);
180
- }
181
- set type(v) {
182
- this._setOption({
183
- name: 'type',
184
- value: v
185
- });
186
- }
187
- depthChange = new EventEmitter();
188
- _depth = 'days';
189
- get depth() {
190
- return this._depth;
191
- }
192
- set depth(v) {
193
- this._setOption({
194
- name: 'depth',
195
- value: v,
196
- beforeCallback: () => {
197
- this._activeView = v;
198
- }
199
- });
200
- }
201
- minChange = new EventEmitter();
202
- _min;
203
- get min() {
204
- return this._min;
205
- }
206
- set min(v) {
207
- this._setOption({ name: 'min', value: v });
208
- }
209
- maxChange = new EventEmitter();
210
- _max;
211
- get max() {
212
- return this._max;
213
- }
214
- set max(v) {
215
- this._setOption({ name: 'max', value: v });
216
- }
217
- disabledDatesChange = new EventEmitter();
218
- _disabledDates;
219
- get disabledDates() {
220
- return this._disabledDates;
221
- }
222
- set disabledDates(v) {
223
- this._setOption({ name: 'disabledDates', value: v });
224
- }
225
- holidayDatesChange = new EventEmitter();
226
- _holidayDates;
227
- get holidayDates() {
228
- return this._holidayDates;
229
- }
230
- set holidayDates(v) {
231
- this._setOption({ name: 'holidayDates', value: v });
232
- }
233
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AXCalendarBaseComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Injectable });
234
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AXCalendarBaseComponent });
235
- }
236
- export { AXCalendarBaseComponent };
237
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: AXCalendarBaseComponent, decorators: [{
238
- type: Injectable
239
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { onSlotClick: [{
188
+ }], onSlotClick: [{
240
189
  type: Output
241
190
  }], onNavigate: [{
242
191
  type: Output
@@ -279,4 +228,4 @@ export const CALENDAR_INPUTS = [
279
228
  'holidayDates',
280
229
  ];
281
230
  export const CALENDAR_OUTPUTS = ['depthChange', 'typeChange', 'disabledDatesChange', 'holidayDatesChange', 'onNavigate'];
282
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/calendar/src/calendar.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXConfig } from \"@acorex/core/config\";\nimport { ChangeDetectorRef, ElementRef, EventEmitter, Injectable, Input, Output, TemplateRef } from \"@angular/core\";\nimport { AXItemClickEvent, AXRangeChangedEvent, MXBaseComponent } from \"@acorex/components/common\";\nimport { AXBaseComponent } from \"@acorex/components/mixin\";\nimport { classes } from \"polytype\";\n\nexport type AXCalendarViewType = 'years' | 'months' | 'days';\nexport type AXCalendarViewDepth = AXCalendarViewType;\nexport type AXCalendarDisabledDates = Date[] | ((date: Date) => boolean);\nexport type AXCalendarHolidayDates = Date[] | ((date: Date) => boolean);\nexport type AXCalendarCellCssClass = string | { [key: string]: boolean } | ((date: Date) => string);\n\n\n/**\n*  Contains native event\n* @category Events\n*/\nexport class AXCalendarNavigateEvent extends AXRangeChangedEvent<Date> {\n\n}\n\n/**\n*  Contains native event\n* @category Events\n*/\nexport class AXCalendarSlotClick extends AXItemClickEvent<Date> {\n\n}\n\n@Injectable()\nexport class MXCalendarBaseComponent extends classes(MXBaseComponent) {\n\n    @Input()\n    interface: 'calendar' | 'picker' = 'calendar';\n\n    @Input()\n    cellTemplate?: TemplateRef<any>;\n\n    @Input()\n    cellClass?: AXCalendarCellCssClass;\n\n    @Input()\n    showNavigation: boolean = true;\n\n\n    @Output()\n    onSlotClick: EventEmitter<AXCalendarSlotClick> = new EventEmitter<AXCalendarSlotClick>();\n\n    @Output()\n    onNavigate: EventEmitter<AXCalendarNavigateEvent> = new EventEmitter<AXCalendarNavigateEvent>();\n\n    @Output()\n    activeViewChange: EventEmitter<AXCalendarViewType> = new EventEmitter<AXCalendarViewType>();\n\n    private _activeView: AXCalendarViewType = 'days';\n    @Input()\n    public get activeView(): AXCalendarViewType {\n        return this._activeView;\n    }\n    public set activeView(v: AXCalendarViewType) {\n        this.setOption({\n            name: 'activeView',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n\n    @Output()\n    public typeChange: EventEmitter<string> = new EventEmitter<string>();\n\n    private _type: string = AXConfig.get(`dateTime.calendar`);\n\n    @Input()\n    public get type(): string {\n        return this._type || AXConfig.get(`dateTime.calendar`);\n    }\n    public set type(v: string) {\n        this.setOption({\n            name: 'type',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n\n    @Output()\n    depthChange: EventEmitter<AXCalendarViewDepth> = new EventEmitter<AXCalendarViewDepth>();\n\n    private _depth: AXCalendarViewDepth = 'days';\n    @Input()\n    public get depth(): AXCalendarViewDepth {\n        return this._depth;\n    }\n    public set depth(v: AXCalendarViewDepth) {\n        this.setOption({\n            name: 'depth',\n            value: v,\n            beforeCallback: () => {\n                this.activeView = v;\n            },\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n    @Output()\n    minChange: EventEmitter<Date> = new EventEmitter<Date>();\n\n    private _min: Date;\n    @Input()\n    public get min(): Date {\n        return this._min;\n    }\n    public set min(v: Date) {\n        this.setOption({\n            name: 'min',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n\n    @Output()\n    maxChange: EventEmitter<Date> = new EventEmitter<Date>();\n\n    private _max: Date;\n    @Input()\n    public get max(): Date {\n        return this._max;\n    }\n    public set max(v: Date) {\n        this.setOption({\n            name: 'max',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n    @Output()\n    disabledDatesChange: EventEmitter<AXCalendarDisabledDates> = new EventEmitter<AXCalendarDisabledDates>();\n\n    private _disabledDates: AXCalendarDisabledDates;\n    @Input()\n    public get disabledDates(): AXCalendarDisabledDates {\n        return this._disabledDates;\n    }\n    public set disabledDates(v: AXCalendarDisabledDates) {\n        this.setOption({ name: 'disabledDates', value: v });\n    }\n\n    @Output()\n    holidayDatesChange: EventEmitter<AXCalendarHolidayDates> = new EventEmitter<AXCalendarHolidayDates>();\n\n    private _holidayDates: AXCalendarHolidayDates;\n    @Input()\n    public get holidayDates(): AXCalendarHolidayDates {\n        return this._holidayDates;\n    }\n    public set holidayDates(v: AXCalendarHolidayDates) {\n        this.setOption({ name: 'holidayDates', value: v });\n    }\n}\n\n\n\n@Injectable()\nexport class AXCalendarBaseComponent extends AXBaseComponent {\n\n\n    constructor(elementRef: ElementRef, cdr: ChangeDetectorRef) {\n        super(elementRef, cdr);\n    }\n\n    @Output()\n    onSlotClick: EventEmitter<AXItemClickEvent<Date>> = new EventEmitter<AXItemClickEvent<Date>>();\n\n    @Output()\n    onNavigate: EventEmitter<AXCalendarNavigateEvent> = new EventEmitter<AXCalendarNavigateEvent>();\n\n    @Output()\n    activeViewChange: EventEmitter<AXCalendarViewType> = new EventEmitter<AXCalendarViewType>();\n\n    private _activeView: AXCalendarViewType = 'days';\n    @Input()\n    public get activeView(): AXCalendarViewType {\n        return this._activeView;\n    }\n    public set activeView(v: AXCalendarViewType) {\n        this._setOption({ name: 'activeView', value: v });\n    }\n\n\n    @Output()\n    public typeChange: EventEmitter<string> = new EventEmitter<string>();\n\n    private _type: string = AXConfig.get(`dateTime.calendar`);\n\n    @Input()\n    public get type(): string {\n        return this._type || AXConfig.get(`dateTime.calendar`);\n    }\n    public set type(v: string) {\n        this._setOption({\n            name: 'type',\n            value: v\n        })\n    }\n\n\n    @Output()\n    depthChange: EventEmitter<AXCalendarViewDepth> = new EventEmitter<AXCalendarViewDepth>();\n\n    private _depth: AXCalendarViewDepth = 'days';\n    @Input()\n    public get depth(): AXCalendarViewDepth {\n        return this._depth;\n    }\n    public set depth(v: AXCalendarViewDepth) {\n        this._setOption({\n            name: 'depth',\n            value: v,\n            beforeCallback: () => {\n                this._activeView = v;\n            }\n        });\n    }\n\n    @Output()\n    minChange: EventEmitter<Date> = new EventEmitter<Date>();\n\n    private _min: Date;\n    @Input()\n    public get min(): Date {\n        return this._min;\n    }\n    public set min(v: Date) {\n        this._setOption({ name: 'min', value: v });\n    }\n\n\n    @Output()\n    maxChange: EventEmitter<Date> = new EventEmitter<Date>();\n\n    private _max: Date;\n    @Input()\n    public get max(): Date {\n        return this._max;\n    }\n    public set max(v: Date) {\n        this._setOption({ name: 'max', value: v });\n    }\n\n    @Output()\n    disabledDatesChange: EventEmitter<AXCalendarDisabledDates> = new EventEmitter<AXCalendarDisabledDates>();\n\n    private _disabledDates: AXCalendarDisabledDates;\n    @Input()\n    public get disabledDates(): AXCalendarDisabledDates {\n        return this._disabledDates;\n    }\n    public set disabledDates(v: AXCalendarDisabledDates) {\n        this._setOption({ name: 'disabledDates', value: v });\n    }\n\n    @Output()\n    holidayDatesChange: EventEmitter<AXCalendarHolidayDates> = new EventEmitter<AXCalendarHolidayDates>();\n\n    private _holidayDates: AXCalendarHolidayDates;\n    @Input()\n    public get holidayDates(): AXCalendarHolidayDates {\n        return this._holidayDates;\n    }\n    public set holidayDates(v: AXCalendarHolidayDates) {\n        this._setOption({ name: 'holidayDates', value: v });\n    }\n}\n\n\n\nexport const CALENDAR_INPUTS = [\n    'depth',\n    'activeView',\n    'min',\n    'max',\n    'disabledDates',\n    'type',\n    'holidayDates',\n];\nexport const CALENDAR_OUTPUTS = ['depthChange', 'typeChange', 'disabledDatesChange', 'holidayDatesChange', 'onNavigate'];\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/calendar/src/calendar.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXConfig } from \"@acorex/core/config\";\nimport { EventEmitter, Injectable, Input, Output, TemplateRef } from \"@angular/core\";\nimport { AXItemClickEvent, AXRangeChangedEvent, MXBaseComponent } from \"@acorex/components/common\";\nimport { classes } from \"polytype\";\nimport { AXDateTime, AXDateTimeRange } from \"@acorex/core/dateTime\";\n\nexport type AXCalendarViewType = 'year' | 'month' | 'day';\nexport type AXCalendarViewDepth = AXCalendarViewType;\nexport type AXCalendarDisabledDates = Date[] | ((date: Date) => boolean);\nexport type AXCalendarHolidayDates = Date[] | ((date: Date) => boolean);\nexport type AXCalendarCellCssClass = string | { [key: string]: boolean } | ((date: Date) => string);\n\n\n/**\n*  Contains native event\n* @category Events\n*/\nexport class AXCalendarNavigateEvent extends AXRangeChangedEvent<Date> {\n\n}\n\n/**\n*  Contains native event\n* @category Events\n*/\nexport class AXCalendarSlotClick extends AXItemClickEvent<Date> {\n\n}\n\nexport interface AXCalendarViewSlot {\n    date: Date;\n    text: string;\n    tooltip: string;\n    today: boolean;\n    selected: boolean;\n    disabled: boolean;\n    cssClass: { [key: string]: boolean };\n}\nexport interface AXCalendarView {\n    range: AXDateTimeRange;\n    slots: AXCalendarViewSlot[];\n}\n// export class AXCalendarView {\n//     private _range: AXDateTimeRange;\n//     private _slots: AXCalendarViewSlot[] = [];\n\n//     get range(): AXDateTimeRange {\n//         return this.range;\n//     }\n\n//     get slots(): AXCalendarViewSlot[] {\n//         return this._slots;\n//     }\n\n//     constructor(\n//         private readonly startDate: AXDateTime,\n//         private readonly view: AXCalendarViewType\n//     ) {\n//         const current = this.startDate;\n//         let textFormat = 'YYYY';\n//         let tooltipFormat = 'YYYY';\n//         switch (this.view) {\n//             case 'year':\n//                 let y = current.startOf('year').year;\n//                 let min = y - (y % 10);\n//                 let max = min + 9;\n//                 this._range = new AXDateTimeRange(\n//                     AXDateTime.from({\n//                         year: min,\n//                         month: 1,\n//                         date: 1,\n//                         calendar: this.startDate.calendar.name(),\n//                     }),\n//                     AXDateTime.from({\n//                         year: max,\n//                         month: 12,\n//                         date: 28,\n//                         calendar: this.startDate.calendar.name(),\n//                     })\n//                 );\n//                 break;\n//             case 'month':\n//                 textFormat = 'MMM';\n//                 tooltipFormat = 'MMMM YYYY';\n//                 this._range = new AXDateTimeRange(\n//                     current.startOf('year'),\n//                     current.endOf('year').add('day', -1)\n//                 );\n//                 break;\n//             default:\n//                 this._range = new AXDateTimeRange(\n//                     current.startOf('month'),\n//                     current.endOf('month')\n//                 );\n//         }\n//         //\n//         this._slots = this.range.enumurate(view).map(r => ({\n//             date: r.date,\n//             tooltip: r.format()\n\n//         }));\n//     }\n// }\n\n@Injectable()\nexport class MXCalendarBaseComponent extends classes(MXBaseComponent) {\n\n    @Input()\n    interface: 'calendar' | 'picker' = 'calendar';\n\n    @Input()\n    cellTemplate?: TemplateRef<any>;\n\n    @Input()\n    cellClass?: AXCalendarCellCssClass;\n\n    @Input()\n    showNavigation: boolean = true;\n\n    @Input()\n    count: number = 1;\n\n\n    @Output()\n    onSlotClick: EventEmitter<AXCalendarSlotClick> = new EventEmitter<AXCalendarSlotClick>();\n\n    @Output()\n    onNavigate: EventEmitter<AXCalendarNavigateEvent> = new EventEmitter<AXCalendarNavigateEvent>();\n\n    @Output()\n    activeViewChange: EventEmitter<AXCalendarViewType> = new EventEmitter<AXCalendarViewType>();\n\n    private _activeView: AXCalendarViewType = 'day';\n    @Input()\n    public get activeView(): AXCalendarViewType {\n        return this._activeView;\n    }\n    public set activeView(v: AXCalendarViewType) {\n        this.setOption({\n            name: 'activeView',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n\n    @Output()\n    public typeChange: EventEmitter<string> = new EventEmitter<string>();\n\n    private _type: string = AXConfig.get(`dateTime.calendar`);\n\n    @Input()\n    public get type(): string {\n        return this._type || AXConfig.get(`dateTime.calendar`);\n    }\n    public set type(v: string) {\n        this.setOption({\n            name: 'type',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n\n    @Output()\n    depthChange: EventEmitter<AXCalendarViewDepth> = new EventEmitter<AXCalendarViewDepth>();\n\n    private _depth: AXCalendarViewDepth = 'day';\n    @Input()\n    public get depth(): AXCalendarViewDepth {\n        return this._depth;\n    }\n    public set depth(v: AXCalendarViewDepth) {\n        this.setOption({\n            name: 'depth',\n            value: v,\n            beforeCallback: () => {\n                this.activeView = v;\n            },\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n    @Output()\n    minChange: EventEmitter<Date> = new EventEmitter<Date>();\n\n    private _min: Date;\n    @Input()\n    public get min(): Date {\n        return this._min;\n    }\n    public set min(v: Date) {\n        this.setOption({\n            name: 'min',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n\n    @Output()\n    maxChange: EventEmitter<Date> = new EventEmitter<Date>();\n\n    private _max: Date;\n    @Input()\n    public get max(): Date {\n        return this._max;\n    }\n    public set max(v: Date) {\n        this.setOption({\n            name: 'max',\n            value: v,\n            afterCallback: () => {\n                this.cdr.markForCheck();\n            }\n        });\n    }\n\n    @Output()\n    disabledDatesChange: EventEmitter<AXCalendarDisabledDates> = new EventEmitter<AXCalendarDisabledDates>();\n\n    private _disabledDates: AXCalendarDisabledDates;\n    @Input()\n    public get disabledDates(): AXCalendarDisabledDates {\n        return this._disabledDates;\n    }\n    public set disabledDates(v: AXCalendarDisabledDates) {\n        this.setOption({ name: 'disabledDates', value: v });\n    }\n\n    @Output()\n    holidayDatesChange: EventEmitter<AXCalendarHolidayDates> = new EventEmitter<AXCalendarHolidayDates>();\n\n    private _holidayDates: AXCalendarHolidayDates;\n    @Input()\n    public get holidayDates(): AXCalendarHolidayDates {\n        return this._holidayDates;\n    }\n    public set holidayDates(v: AXCalendarHolidayDates) {\n        this.setOption({ name: 'holidayDates', value: v });\n    }\n}\n\n\n\n\n\nexport const CALENDAR_INPUTS = [\n    'depth',\n    'activeView',\n    'min',\n    'max',\n    'disabledDates',\n    'type',\n    'holidayDates',\n];\nexport const CALENDAR_OUTPUTS = ['depthChange', 'typeChange', 'disabledDatesChange', 'holidayDatesChange', 'onNavigate'];\n"]}