@acorex/components 5.0.2 → 5.0.7
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/bundles/acorex-components.umd.js +1528 -1038
- package/bundles/acorex-components.umd.js.map +1 -1
- package/esm2015/lib/alert/alert.component.js +17 -17
- package/esm2015/lib/badge/badge.component.js +34 -0
- package/esm2015/lib/badge/badge.module.js +21 -0
- package/esm2015/lib/badge/index.js +3 -0
- package/esm2015/lib/base/events.class.js +7 -1
- package/esm2015/lib/base/mixin/base-components.class.js +6 -6
- package/esm2015/lib/base/mixin/button-mixin.class.js +2 -2
- package/esm2015/lib/base/mixin/interactive-mixin.class.js +6 -1
- package/esm2015/lib/base/mixin/mixin.class.js +2 -3
- package/esm2015/lib/button/button-group.component.js +3 -3
- package/esm2015/lib/button/button.component.js +27 -6
- package/esm2015/lib/button/button.module.js +1 -5
- package/esm2015/lib/button/index.js +1 -2
- package/esm2015/lib/calendar/calendar.component.js +266 -38
- package/esm2015/lib/calendar/calendar.module.js +4 -3
- package/esm2015/lib/checkbox/checkbox.component.js +2 -2
- package/esm2015/lib/datepicker/datepicker.component.js +21 -5
- package/esm2015/lib/decorators/prefix.component.js +3 -3
- package/esm2015/lib/decorators/suffix.component.js +3 -11
- package/esm2015/lib/dialog/dialog.component.js +2 -2
- package/esm2015/lib/dialog/dialog.service.js +24 -5
- package/esm2015/lib/dropdown/dropdown-base.class.js +98 -0
- package/esm2015/lib/dropdown/dropdown-panel.component.js +23 -130
- package/esm2015/lib/dropdown/dropdown.component.js +16 -123
- package/esm2015/lib/dropdown/dropdown.module.js +5 -4
- package/esm2015/lib/icon/icon.component.js +4 -4
- package/esm2015/lib/number-box/number-box.component.js +4 -4
- package/esm2015/lib/password-box/index.js +3 -0
- package/esm2015/lib/password-box/password-box.component.js +74 -0
- package/esm2015/lib/password-box/password-box.module.js +35 -0
- package/esm2015/lib/popover/popover.component.js +183 -82
- package/esm2015/lib/range-slider/index.js +3 -0
- package/esm2015/lib/range-slider/range-slider.component.js +22 -0
- package/esm2015/lib/range-slider/range-slider.module.js +21 -0
- package/esm2015/lib/selectbox/selectbox.component.js +11 -3
- package/esm2015/lib/selectbox/selectbox.module.js +8 -4
- package/esm2015/lib/selection-list/selection-list.component.js +3 -2
- package/esm2015/lib/switch/switch.component.js +2 -2
- package/esm2015/lib/tabs/index.js +4 -2
- package/esm2015/lib/tabs/tab-content.directive.js +27 -0
- package/esm2015/lib/tabs/tab-item.component.js +76 -0
- package/esm2015/lib/tabs/tab-strip.component.js +15 -7
- package/esm2015/lib/tabs/tab-view.component.js +4 -5
- package/esm2015/lib/tabs/tab.component.js +2 -3
- package/esm2015/lib/tabs/tabs.component.js +74 -0
- package/esm2015/lib/tabs/tabs.module.js +9 -7
- package/esm2015/lib/textbox/textbox.component.js +8 -6
- package/esm2015/lib/textbox/textbox.module.js +6 -2
- package/esm2015/lib/time-box/time-box.component.js +1 -1
- package/esm2015/lib/toast/toast.component.js +2 -2
- package/esm2015/public-api.js +4 -1
- package/fesm2015/acorex-components.js +1316 -883
- package/fesm2015/acorex-components.js.map +1 -1
- package/lib/alert/alert.component.d.ts +4 -4
- package/lib/badge/badge.component.d.ts +11 -0
- package/lib/badge/badge.module.d.ts +8 -0
- package/lib/badge/index.d.ts +2 -0
- package/lib/base/events.class.d.ts +7 -0
- package/lib/base/mixin/button-mixin.class.d.ts +3 -1
- package/lib/base/mixin/interactive-mixin.class.d.ts +2 -3
- package/lib/base/mixin/loading-mixin.class.d.ts +1 -3
- package/lib/base/mixin/mixin.class.d.ts +1 -224
- package/lib/base/mixin/textbox-mixin.class.d.ts +4 -7
- package/lib/base/mixin/value-mixin.class.d.ts +4 -5
- package/lib/button/button-group.component.d.ts +3 -2
- package/lib/button/button.component.d.ts +4 -1
- package/lib/button/button.module.d.ts +6 -7
- package/lib/button/index.d.ts +0 -1
- package/lib/calendar/calendar.component.d.ts +52 -12
- package/lib/calendar/calendar.module.d.ts +4 -3
- package/lib/datepicker/datepicker.component.d.ts +3 -3
- package/lib/decorators/prefix.component.d.ts +1 -1
- package/lib/decorators/suffix.component.d.ts +1 -1
- package/lib/dialog/dialog.service.d.ts +20 -2
- package/lib/dropdown/dropdown-base.class.d.ts +92 -0
- package/lib/dropdown/dropdown-panel.component.d.ts +12 -100
- package/lib/dropdown/dropdown.component.d.ts +9 -27
- package/lib/dropdown/dropdown.module.d.ts +2 -1
- package/lib/icon/icon.component.d.ts +1 -1
- package/lib/number-box/number-box.component.d.ts +1 -1
- package/lib/password-box/index.d.ts +2 -0
- package/lib/password-box/password-box.component.d.ts +24 -0
- package/lib/password-box/password-box.module.d.ts +12 -0
- package/lib/popover/popover.component.d.ts +37 -23
- package/lib/range-slider/index.d.ts +2 -0
- package/lib/range-slider/range-slider.component.d.ts +8 -0
- package/lib/range-slider/range-slider.module.d.ts +8 -0
- package/lib/selectbox/selectbox.component.d.ts +1 -0
- package/lib/selectbox/selectbox.module.d.ts +5 -1
- package/lib/selection-list/selection-list.component.d.ts +1 -1
- package/lib/tabs/index.d.ts +3 -1
- package/lib/tabs/tab-content.directive.d.ts +11 -0
- package/lib/tabs/tab-item.component.d.ts +16 -0
- package/lib/tabs/tab-strip.component.d.ts +5 -3
- package/lib/tabs/tab-view.component.d.ts +2 -2
- package/lib/tabs/tabs.component.d.ts +19 -0
- package/lib/tabs/tabs.module.d.ts +6 -4
- package/lib/textbox/textbox.module.d.ts +3 -2
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
- package/esm2015/lib/button/dropdown-button.component.js +0 -200
- package/lib/button/dropdown-button.component.d.ts +0 -234
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, HostListener, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, HostListener, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { BUTTON_INPUTS, BUTTON_OUTPUT } from '../base/mixin/button-mixin.class';
|
|
3
3
|
import { AXBaseButtonMixin } from '../base/mixin/mixin.class';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -24,7 +24,6 @@ export class AXButtonComponent extends AXBaseButtonMixin {
|
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
26
|
_emitOnClickEvent(e) {
|
|
27
|
-
debugger;
|
|
28
27
|
if (this.disabled)
|
|
29
28
|
return;
|
|
30
29
|
if (this.toggleable) {
|
|
@@ -32,21 +31,43 @@ export class AXButtonComponent extends AXBaseButtonMixin {
|
|
|
32
31
|
}
|
|
33
32
|
super._emitOnClickEvent(e);
|
|
34
33
|
}
|
|
34
|
+
_emitOnFocusEvent(e) {
|
|
35
|
+
super._emitOnFocusEvent(e);
|
|
36
|
+
}
|
|
37
|
+
_emitOnBlurEvent(e) {
|
|
38
|
+
super._emitOnBlurEvent(e);
|
|
39
|
+
}
|
|
40
|
+
get __hostClass() {
|
|
41
|
+
return Object.entries(this._classes).filter(c => c[1]).map(c => c[0]).concat(...[`ax-${this.size}`]).join(' ');
|
|
42
|
+
}
|
|
35
43
|
}
|
|
36
44
|
AXButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXButtonComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
37
|
-
AXButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.6", type: AXButtonComponent, selector: "ax-button", inputs: { disabled: "disabled", tabIndex: "tabIndex", size: "size",
|
|
45
|
+
AXButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.6", type: AXButtonComponent, selector: "ax-button", inputs: { disabled: "disabled", tabIndex: "tabIndex", size: "size", text: "text", submitBehavior: "submitBehavior", cancelBehavior: "cancelBehavior", color: "color", look: "look", toggleable: "toggleable", selected: "selected" }, outputs: { onBlur: "onBlur", onFocus: "onFocus", onClick: "onClick", selectedChange: "selectedChange", toggleableChange: "toggleableChange" }, host: { attributes: { "role": "button" }, listeners: { "document:keydown.escape": "onKeydownHandler($event)", "click": "_emitOnClickEvent($event)", "focus": "_emitOnFocusEvent($event)", "blur": "_emitOnBlurEvent($event)" }, properties: { "class": "this.__hostClass" } }, usesInheritance: true, ngImport: i0, template: "<!-- <button [ngClass]=\"_classes\" class=\"{{cssClass}} ax-{{size}}\" [disabled]=\"disabled\" [tabindex]=\"tabIndex\" [attr.style]=\"cssStyle\" (click)=\"_emitOnClickEvent($event)\" (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_emitOnBlurEvent($event)\">\r\n <ng-content select=\"ax-prefix,ax-loading,ax-icon\">\r\n </ng-content>\r\n <span *ngIf=\"text\">{{text}}</span>\r\n <ng-content select=\"ax-suffix\">\r\n </ng-content>\r\n <ng-content select=\"ax-dropdown-panel\">\r\n </ng-content>\r\n</button> -->\r\n<!-- <button [ngClass]=\"_classes\" class=\"{{cssClass}} ax-{{size}}\" [disabled]=\"disabled\" [tabindex]=\"tabIndex\" [attr.style]=\"cssStyle\" (click)=\"_emitOnClickEvent($event)\" (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_emitOnBlurEvent($event)\"> -->\r\n<ng-content select=\"ax-prefix,ax-loading,ax-icon\">\r\n</ng-content>\r\n<span *ngIf=\"text\">{{text}}</span>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-dropdown-panel\">\r\n</ng-content>\r\n<!-- </button> -->", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
38
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXButtonComponent, decorators: [{
|
|
39
47
|
type: Component,
|
|
40
48
|
args: [{
|
|
41
49
|
selector: 'ax-button',
|
|
42
50
|
templateUrl: './button.component.html',
|
|
43
|
-
inputs: ['disabled', 'tabIndex', 'size',
|
|
51
|
+
inputs: ['disabled', 'tabIndex', 'size', ...BUTTON_INPUTS],
|
|
44
52
|
outputs: [...BUTTON_OUTPUT],
|
|
45
53
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
46
|
-
encapsulation: ViewEncapsulation.None
|
|
54
|
+
encapsulation: ViewEncapsulation.None,
|
|
55
|
+
host: { role: 'button' }
|
|
47
56
|
}]
|
|
48
57
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { onKeydownHandler: [{
|
|
49
58
|
type: HostListener,
|
|
50
59
|
args: ['document:keydown.escape', ['$event']]
|
|
60
|
+
}], _emitOnClickEvent: [{
|
|
61
|
+
type: HostListener,
|
|
62
|
+
args: ['click', ['$event']]
|
|
63
|
+
}], _emitOnFocusEvent: [{
|
|
64
|
+
type: HostListener,
|
|
65
|
+
args: ['focus', ['$event']]
|
|
66
|
+
}], _emitOnBlurEvent: [{
|
|
67
|
+
type: HostListener,
|
|
68
|
+
args: ['blur', ['$event']]
|
|
69
|
+
}], __hostClass: [{
|
|
70
|
+
type: HostBinding,
|
|
71
|
+
args: ['class']
|
|
51
72
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9jb21wb25lbnRzL3NyYy9saWIvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2J1dHRvbi9idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQWMsV0FBVyxFQUFFLFlBQVksRUFBUyxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2SixPQUFPLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7QUFFOUQ7Ozs7R0FJRztBQVVILE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxpQkFBaUI7SUFFcEQ7O01BRUU7SUFDRixZQUFZLFVBQXNCLEVBQUUsR0FBc0I7UUFDdEQsS0FBSyxDQUFDLFVBQVUsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBR0QsZ0JBQWdCLENBQUMsQ0FBZ0I7UUFDN0IsSUFBSSxJQUFJLENBQUMsY0FBYyxFQUFFO1lBQ3JCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFRLENBQUMsQ0FBQztZQUNqQyxDQUFDLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDcEIsQ0FBQyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ25CLE9BQU8sS0FBSyxDQUFDO1NBQ2hCO0lBQ0wsQ0FBQztJQUdELGlCQUFpQixDQUFDLENBQWE7UUFDM0IsSUFBSSxJQUFJLENBQUMsUUFBUTtZQUNiLE9BQU87UUFDWCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7U0FDbEM7UUFDRCxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUdELGlCQUFpQixDQUFDLENBQWE7UUFDM0IsS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFJRCxnQkFBZ0IsQ0FBQyxDQUFhO1FBQzFCLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBSUQsSUFDWSxXQUFXO1FBQ25CLE9BQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ25ILENBQUM7OzhHQTdDUSxpQkFBaUI7a0dBQWpCLGlCQUFpQiw0c0JDbEI5QiwyZ0NBaUJrQjsyRkRDTCxpQkFBaUI7a0JBVDdCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFdBQVc7b0JBQ3JCLFdBQVcsRUFBRSx5QkFBeUI7b0JBQ3RDLE1BQU0sRUFBRSxDQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLEdBQUcsYUFBYSxDQUFDO29CQUMxRCxPQUFPLEVBQUUsQ0FBQyxHQUFHLGFBQWEsQ0FBQztvQkFDM0IsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxJQUFJLEVBQUUsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFO2lCQUMzQjtpSUFXRyxnQkFBZ0I7c0JBRGYsWUFBWTt1QkFBQyx5QkFBeUIsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFXbkQsaUJBQWlCO3NCQURoQixZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFXakMsaUJBQWlCO3NCQURoQixZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFPakMsZ0JBQWdCO3NCQURmLFlBQVk7dUJBQUMsTUFBTSxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQVFwQixXQUFXO3NCQUR0QixXQUFXO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgRWxlbWVudFJlZiwgSG9zdEJpbmRpbmcsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJVVFRPTl9JTlBVVFMsIEJVVFRPTl9PVVRQVVQgfSBmcm9tICcuLi9iYXNlL21peGluL2J1dHRvbi1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IEFYQmFzZUJ1dHRvbk1peGluIH0gZnJvbSAnLi4vYmFzZS9taXhpbi9taXhpbi5jbGFzcyc7XHJcblxyXG4vKipcclxuICogVGhlIEJ1dHRvbiBpcyBhIGNvbXBvbmVudCB3aGljaCBkZXRlY3RzIHVzZXIgaW50ZXJhY3Rpb24gYW5kIHRyaWdnZXJzIGEgY29ycmVzcG9uZGluZyBldmVudFxyXG4gKlxyXG4gKiBAY2F0ZWdvcnkgQ29tcG9uZW50c1xyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2F4LWJ1dHRvbicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcclxuICAgIGlucHV0czogWydkaXNhYmxlZCcsICd0YWJJbmRleCcsICdzaXplJywgLi4uQlVUVE9OX0lOUFVUU10sXHJcbiAgICBvdXRwdXRzOiBbLi4uQlVUVE9OX09VVFBVVF0sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbiAgICBob3N0OiB7IHJvbGU6ICdidXR0b24nIH1cclxufSlcclxuZXhwb3J0IGNsYXNzIEFYQnV0dG9uQ29tcG9uZW50IGV4dGVuZHMgQVhCYXNlQnV0dG9uTWl4aW4ge1xyXG5cclxuICAgIC8qKlxyXG4gICAgKiAgQGlnbm9yZVxyXG4gICAgKi9cclxuICAgIGNvbnN0cnVjdG9yKGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgICAgICBzdXBlcihlbGVtZW50UmVmLCBjZHIpO1xyXG4gICAgfVxyXG5cclxuICAgIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmtleWRvd24uZXNjYXBlJywgWyckZXZlbnQnXSlcclxuICAgIG9uS2V5ZG93bkhhbmRsZXIoZTogS2V5Ym9hcmRFdmVudCkge1xyXG4gICAgICAgIGlmICh0aGlzLmNhbmNlbEJlaGF2aW9yKSB7XHJcbiAgICAgICAgICAgIHRoaXMuX2VtaXRPbkNsaWNrRXZlbnQoZSBhcyBhbnkpO1xyXG4gICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKVxyXG4gICAgX2VtaXRPbkNsaWNrRXZlbnQoZTogTW91c2VFdmVudCkge1xyXG4gICAgICAgIGlmICh0aGlzLmRpc2FibGVkKVxyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgaWYgKHRoaXMudG9nZ2xlYWJsZSkge1xyXG4gICAgICAgICAgICB0aGlzLnNlbGVjdGVkID0gIXRoaXMuc2VsZWN0ZWQ7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHN1cGVyLl9lbWl0T25DbGlja0V2ZW50KGUpO1xyXG4gICAgfVxyXG5cclxuICAgIEBIb3N0TGlzdGVuZXIoJ2ZvY3VzJywgWyckZXZlbnQnXSlcclxuICAgIF9lbWl0T25Gb2N1c0V2ZW50KGU6IE1vdXNlRXZlbnQpIHtcclxuICAgICAgICBzdXBlci5fZW1pdE9uRm9jdXNFdmVudChlKTtcclxuICAgIH1cclxuXHJcblxyXG4gICAgQEhvc3RMaXN0ZW5lcignYmx1cicsIFsnJGV2ZW50J10pXHJcbiAgICBfZW1pdE9uQmx1ckV2ZW50KGU6IE1vdXNlRXZlbnQpIHtcclxuICAgICAgICBzdXBlci5fZW1pdE9uQmx1ckV2ZW50KGUpO1xyXG4gICAgfVxyXG5cclxuXHJcblxyXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXHJcbiAgICBwcml2YXRlIGdldCBfX2hvc3RDbGFzcygpOiBzdHJpbmcge1xyXG4gICAgICAgIHJldHVybiBPYmplY3QuZW50cmllcyh0aGlzLl9jbGFzc2VzKS5maWx0ZXIoYyA9PiBjWzFdKS5tYXAoYyA9PiBjWzBdKS5jb25jYXQoLi4uW2BheC0ke3RoaXMuc2l6ZX1gXSkuam9pbignICcpO1xyXG4gICAgfVxyXG5cclxufVxyXG4iLCI8IS0tIDxidXR0b24gW25nQ2xhc3NdPVwiX2NsYXNzZXNcIiBjbGFzcz1cInt7Y3NzQ2xhc3N9fSBheC17e3NpemV9fVwiIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIFt0YWJpbmRleF09XCJ0YWJJbmRleFwiIFthdHRyLnN0eWxlXT1cImNzc1N0eWxlXCIgKGNsaWNrKT1cIl9lbWl0T25DbGlja0V2ZW50KCRldmVudClcIiAoZm9jdXMpPVwiX2VtaXRPbkZvY3VzRXZlbnQoJGV2ZW50KVwiIChibHVyKT1cIl9lbWl0T25CbHVyRXZlbnQoJGV2ZW50KVwiPlxyXG4gIDxuZy1jb250ZW50IHNlbGVjdD1cImF4LXByZWZpeCxheC1sb2FkaW5nLGF4LWljb25cIj5cclxuICA8L25nLWNvbnRlbnQ+XHJcbiAgPHNwYW4gKm5nSWY9XCJ0ZXh0XCI+e3t0ZXh0fX08L3NwYW4+XHJcbiAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtc3VmZml4XCI+XHJcbiAgPC9uZy1jb250ZW50PlxyXG4gIDxuZy1jb250ZW50IHNlbGVjdD1cImF4LWRyb3Bkb3duLXBhbmVsXCI+XHJcbiAgPC9uZy1jb250ZW50PlxyXG48L2J1dHRvbj4gLS0+XHJcbjwhLS0gPGJ1dHRvbiBbbmdDbGFzc109XCJfY2xhc3Nlc1wiIGNsYXNzPVwie3tjc3NDbGFzc319IGF4LXt7c2l6ZX19XCIgW2Rpc2FibGVkXT1cImRpc2FibGVkXCIgW3RhYmluZGV4XT1cInRhYkluZGV4XCIgW2F0dHIuc3R5bGVdPVwiY3NzU3R5bGVcIiAoY2xpY2spPVwiX2VtaXRPbkNsaWNrRXZlbnQoJGV2ZW50KVwiIChmb2N1cyk9XCJfZW1pdE9uRm9jdXNFdmVudCgkZXZlbnQpXCIgKGJsdXIpPVwiX2VtaXRPbkJsdXJFdmVudCgkZXZlbnQpXCI+IC0tPlxyXG48bmctY29udGVudCBzZWxlY3Q9XCJheC1wcmVmaXgsYXgtbG9hZGluZyxheC1pY29uXCI+XHJcbjwvbmctY29udGVudD5cclxuPHNwYW4gKm5nSWY9XCJ0ZXh0XCI+e3t0ZXh0fX08L3NwYW4+XHJcbjxuZy1jb250ZW50IHNlbGVjdD1cImF4LXN1ZmZpeFwiPlxyXG48L25nLWNvbnRlbnQ+XHJcbjxuZy1jb250ZW50IHNlbGVjdD1cImF4LWRyb3Bkb3duLXBhbmVsXCI+XHJcbjwvbmctY29udGVudD5cclxuPCEtLSA8L2J1dHRvbj4gLS0+Il19
|
|
@@ -5,11 +5,9 @@ import { AXIconModule } from '../icon';
|
|
|
5
5
|
import { AXButtonGroupComponent } from './button-group.component';
|
|
6
6
|
import { AXButtonItemComponent } from './button-item.component';
|
|
7
7
|
import { AXButtonComponent } from './button.component';
|
|
8
|
-
import { AXDropdownButtonComponent } from './dropdown-button.component';
|
|
9
8
|
import * as i0 from "@angular/core";
|
|
10
9
|
const COMPONENT = [
|
|
11
10
|
AXButtonComponent,
|
|
12
|
-
AXDropdownButtonComponent,
|
|
13
11
|
AXButtonItemComponent,
|
|
14
12
|
AXButtonGroupComponent,
|
|
15
13
|
];
|
|
@@ -18,10 +16,8 @@ export class AXButtonModule {
|
|
|
18
16
|
}
|
|
19
17
|
AXButtonModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXButtonModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
20
18
|
AXButtonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXButtonModule, declarations: [AXButtonComponent,
|
|
21
|
-
AXDropdownButtonComponent,
|
|
22
19
|
AXButtonItemComponent,
|
|
23
20
|
AXButtonGroupComponent], imports: [CommonModule, AXIconModule, AXEditorDecoratorModule], exports: [AXButtonComponent,
|
|
24
|
-
AXDropdownButtonComponent,
|
|
25
21
|
AXButtonItemComponent,
|
|
26
22
|
AXButtonGroupComponent] });
|
|
27
23
|
AXButtonModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXButtonModule, providers: [], imports: [[MODULES]] });
|
|
@@ -34,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.6", ngImpor
|
|
|
34
30
|
providers: [],
|
|
35
31
|
}]
|
|
36
32
|
}] });
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fjb3JleC9jb21wb25lbnRzL3NyYy9saWIvYnV0dG9uL2J1dHRvbi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDdkMsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDbEUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBR3ZELE1BQU0sU0FBUyxHQUFHO0lBQ2QsaUJBQWlCO0lBQ2pCLHFCQUFxQjtJQUNyQixzQkFBc0I7Q0FDekIsQ0FBQztBQUNGLE1BQU0sT0FBTyxHQUFHLENBQUMsWUFBWSxFQUFDLFlBQVksRUFBQyx1QkFBdUIsQ0FBQyxDQUFDO0FBUXBFLE1BQU0sT0FBTyxjQUFjOzsyR0FBZCxjQUFjOzRHQUFkLGNBQWMsaUJBWnZCLGlCQUFpQjtRQUNqQixxQkFBcUI7UUFDckIsc0JBQXNCLGFBRVQsWUFBWSxFQUFDLFlBQVksRUFBQyx1QkFBdUIsYUFKOUQsaUJBQWlCO1FBQ2pCLHFCQUFxQjtRQUNyQixzQkFBc0I7NEdBVWIsY0FBYyxhQUZaLEVBQUUsWUFISixDQUFDLE9BQU8sQ0FBQzsyRkFLVCxjQUFjO2tCQU4xQixRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQztvQkFDbEIsT0FBTyxFQUFFLENBQUMsU0FBUyxDQUFDO29CQUNwQixZQUFZLEVBQUUsQ0FBQyxTQUFTLENBQUM7b0JBQ3pCLFNBQVMsRUFBRSxFQUFFO2lCQUNoQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYRWRpdG9yRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnLi4vZGVjb3JhdG9ycyc7XHJcbmltcG9ydCB7IEFYSWNvbk1vZHVsZSB9IGZyb20gJy4uL2ljb24nO1xyXG5pbXBvcnQgeyBBWEJ1dHRvbkdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi9idXR0b24tZ3JvdXAuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhCdXR0b25JdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9idXR0b24taXRlbS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBWEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vYnV0dG9uLmNvbXBvbmVudCc7XHJcblxyXG5cclxuY29uc3QgQ09NUE9ORU5UID0gW1xyXG4gICAgQVhCdXR0b25Db21wb25lbnQsXHJcbiAgICBBWEJ1dHRvbkl0ZW1Db21wb25lbnQsXHJcbiAgICBBWEJ1dHRvbkdyb3VwQ29tcG9uZW50LFxyXG5dO1xyXG5jb25zdCBNT0RVTEVTID0gW0NvbW1vbk1vZHVsZSxBWEljb25Nb2R1bGUsQVhFZGl0b3JEZWNvcmF0b3JNb2R1bGVdO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtNT0RVTEVTXSxcclxuICAgIGV4cG9ydHM6IFtDT01QT05FTlRdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbQ09NUE9ORU5UXSxcclxuICAgIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWEJ1dHRvbk1vZHVsZSB7IH1cclxuIl19
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
export * from './button.component';
|
|
2
|
-
export * from './dropdown-button.component';
|
|
3
2
|
export * from './button-group.component';
|
|
4
3
|
export * from './button-item.component';
|
|
5
4
|
export * from './button.module';
|
|
6
5
|
export * from './button-item.class';
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2J1dHRvbi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMscUJBQXFCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2J1dHRvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2J1dHRvbi1ncm91cC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2J1dHRvbi1pdGVtLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLWl0ZW0uY2xhc3MnOyJdfQ==
|
|
@@ -1,59 +1,287 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { AXDateTime, AXDateTimeRange } from '@acorex/core';
|
|
2
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, Output, EventEmitter, HostBinding, } from '@angular/core';
|
|
3
|
+
import { AXCalendarComponentMixin } from '../base';
|
|
4
|
+
import { INTERACTIVE_INPUTS, INTERACTIVE_OUTPUT } from '../base/mixin/interactive-mixin.class';
|
|
5
|
+
import { VALUE_INPUTS, VALUE_OUTPUT } from '../base/mixin/value-mixin.class';
|
|
3
6
|
import * as i0 from "@angular/core";
|
|
4
7
|
import * as i1 from "../button/button.component";
|
|
5
8
|
import * as i2 from "../decorators/prefix.component";
|
|
6
9
|
import * as i3 from "../icon/icon.component";
|
|
7
|
-
|
|
10
|
+
import * as i4 from "@angular/common";
|
|
11
|
+
export class AXCalendarComponent extends AXCalendarComponentMixin {
|
|
8
12
|
constructor(elementRef, cdr) {
|
|
9
13
|
super(elementRef, cdr);
|
|
10
|
-
this.
|
|
11
|
-
this.
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
'
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
14
|
+
this.cdr = cdr;
|
|
15
|
+
this._today = new AXDateTime(new Date());
|
|
16
|
+
this._navText = '';
|
|
17
|
+
this._todayText = '';
|
|
18
|
+
this._slots = [];
|
|
19
|
+
this._activeView = 'days';
|
|
20
|
+
this.depthChange = new EventEmitter();
|
|
21
|
+
this._depth = 'days';
|
|
22
|
+
}
|
|
23
|
+
get _viewRange() {
|
|
24
|
+
const current = this._viewStartDate || this._today;
|
|
25
|
+
switch (this.activeView) {
|
|
26
|
+
case 'years':
|
|
27
|
+
let y = current.startOf('year').year;
|
|
28
|
+
let min = y - (y % 10) - 1;
|
|
29
|
+
let max = min + 11;
|
|
30
|
+
return new AXDateTimeRange(AXDateTime.convert(new Date(min, 0), this._today.calendar.name()), AXDateTime.convert(new Date(max, 0), this._today.calendar.name()));
|
|
31
|
+
case 'months':
|
|
32
|
+
//TODO: check add month function
|
|
33
|
+
return new AXDateTimeRange(current.startOf('year'), current.endOf('year').add('month', 4).add('day', -1));
|
|
34
|
+
default:
|
|
35
|
+
//return new AXDateTimeRange(current.startOf('month').startOf('week'), current.endOf('month').endOf('week'));
|
|
36
|
+
return new AXDateTimeRange(current.startOf('month'), current.endOf('month'));
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
get activeView() {
|
|
40
|
+
return this._activeView;
|
|
41
|
+
}
|
|
42
|
+
set activeView(v) {
|
|
43
|
+
this._activeView = v;
|
|
44
|
+
this._genearteSlots();
|
|
45
|
+
}
|
|
46
|
+
get depth() {
|
|
47
|
+
return this._depth;
|
|
48
|
+
}
|
|
49
|
+
set depth(v) {
|
|
50
|
+
this._depth = v;
|
|
51
|
+
this._activeView = v;
|
|
52
|
+
this.depthChange.emit(v);
|
|
53
|
+
this._genearteSlots();
|
|
54
|
+
}
|
|
55
|
+
get min() {
|
|
56
|
+
return this._min;
|
|
57
|
+
}
|
|
58
|
+
set min(v) {
|
|
59
|
+
this._min = v;
|
|
60
|
+
}
|
|
61
|
+
get max() {
|
|
62
|
+
return this._max;
|
|
63
|
+
}
|
|
64
|
+
set max(v) {
|
|
65
|
+
this._max = v;
|
|
66
|
+
}
|
|
67
|
+
get disabledDates() {
|
|
68
|
+
return this._disabledDates;
|
|
69
|
+
}
|
|
70
|
+
set disabledDates(v) {
|
|
71
|
+
this._disabledDates = v;
|
|
72
|
+
}
|
|
73
|
+
get holidayDates() {
|
|
74
|
+
return this._holidayDates;
|
|
75
|
+
}
|
|
76
|
+
set holidayDates(v) {
|
|
77
|
+
this._holidayDates = v;
|
|
78
|
+
}
|
|
79
|
+
onInit() {
|
|
80
|
+
this.goToday();
|
|
81
|
+
}
|
|
82
|
+
_genearteSlots() {
|
|
83
|
+
if (!this._viewStartDate)
|
|
84
|
+
return;
|
|
85
|
+
const vr = this._viewRange;
|
|
86
|
+
// year view
|
|
87
|
+
if (this.activeView == 'years') {
|
|
88
|
+
const a = vr.enumurate('year');
|
|
89
|
+
this._slots = a.map((d, i) => {
|
|
90
|
+
const r = {};
|
|
91
|
+
r.date = d.date;
|
|
92
|
+
r.text = d.format('YYYY');
|
|
93
|
+
r.disabled = (this.min && d.compare(this.min, 'year') == -1) || (this.max && d.compare(this.max, 'year') == 1);
|
|
94
|
+
if (r.disabled) {
|
|
95
|
+
r.cssClass = {
|
|
96
|
+
'ax-state-disabled': r.disabled,
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
r.cssClass = {
|
|
101
|
+
'ax-state-today': d.equal(this._today, 'year'),
|
|
102
|
+
'ax-state-selected': this.value && this.depth == 'years' && d.equal(this.value, 'year'),
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
return r;
|
|
106
|
+
});
|
|
107
|
+
this._navText = `${vr.startTime.year} - ${vr.endTime.year}`;
|
|
108
|
+
this._todayText = this._today.format('YYYY');
|
|
109
|
+
}
|
|
110
|
+
// month view
|
|
111
|
+
else if (this.activeView == 'months') {
|
|
112
|
+
const a = vr.enumurate('month');
|
|
113
|
+
this._slots = a.map((d, i) => {
|
|
114
|
+
const r = {};
|
|
115
|
+
r.date = d.date;
|
|
116
|
+
r.text = d.format('MMM');
|
|
117
|
+
r.tooltip = d.format('MMMM YYYY');
|
|
118
|
+
r.disabled = (this.min && d.compare(this.min, 'month') == -1) || (this.max && d.compare(this.max, 'month') == 1);
|
|
119
|
+
if (r.disabled) {
|
|
120
|
+
r.cssClass = {
|
|
121
|
+
'ax-state-disabled': r.disabled,
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
r.cssClass = {
|
|
126
|
+
'ax-state-today': d.equal(this._today, 'month'),
|
|
127
|
+
'ax-state-selected': this.value && this.depth == 'months' && d.equal(this.value, 'month'),
|
|
128
|
+
'ax-state-other': d.year != this._viewStartDate.year
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
return r;
|
|
132
|
+
});
|
|
133
|
+
this._navText = this._viewStartDate.format('YYYY');
|
|
134
|
+
this._todayText = this._today.format('MMMM YYYY');
|
|
135
|
+
}
|
|
136
|
+
// day view
|
|
137
|
+
else {
|
|
138
|
+
const a = vr.enumurate('day');
|
|
139
|
+
this._slots = a.map((d, i) => {
|
|
140
|
+
const r = {};
|
|
141
|
+
r.date = d.date;
|
|
142
|
+
r.text = d.dayOfMonth;
|
|
143
|
+
r.tooltip = d.format();
|
|
144
|
+
r.disabled = (this.min && d.compare(this.min, 'day') == -1) || (this.max && d.compare(this.max, 'day') == 1);
|
|
145
|
+
if (r.disabled || this.isDisabled(d)) {
|
|
146
|
+
r.cssClass = {
|
|
147
|
+
'ax-state-disabled': true,
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
r.cssClass = {
|
|
152
|
+
'ax-state-today': d.equal(this._today, 'day'),
|
|
153
|
+
'ax-state-selected': this.value && d.equal(this.value, 'day'),
|
|
154
|
+
'ax-state-holiday': this.isHoliday(d) || this.isWeekend(d),
|
|
155
|
+
// 'ax-state-event-info': d.dayOfMonth == 12,
|
|
156
|
+
// 'ax-state-event': d.dayOfMonth == 12,
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
r.cssClass[`ax-col-start-${vr.startTime.dayOfWeek}`] = i == 0;
|
|
160
|
+
return r;
|
|
161
|
+
});
|
|
162
|
+
this._navText = this._viewStartDate.format('MMMM YYYY');
|
|
163
|
+
this._todayText = this._today.format('DDDD, MMMM dd, YYYY');
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
_handlePrevClick(e) {
|
|
167
|
+
this.prev();
|
|
168
|
+
}
|
|
169
|
+
_handleNextClick(e) {
|
|
170
|
+
this.next();
|
|
171
|
+
}
|
|
172
|
+
_handleSlotClick(slot) {
|
|
173
|
+
if (slot.disabled || this.disabled)
|
|
174
|
+
return;
|
|
175
|
+
if (this.activeView == 'days') {
|
|
176
|
+
this.value = slot.date;
|
|
177
|
+
}
|
|
178
|
+
else if (this.activeView == 'months' && this.depth == 'days') {
|
|
179
|
+
this.activeView = 'days';
|
|
180
|
+
this.navTo(slot.date);
|
|
37
181
|
}
|
|
182
|
+
else if (this.activeView == 'months' && this.depth == 'months') {
|
|
183
|
+
this.value = slot.date;
|
|
184
|
+
}
|
|
185
|
+
else if (this.activeView == 'years' && (this.depth == 'days' || this.depth == 'months')) {
|
|
186
|
+
this.activeView = 'months';
|
|
187
|
+
this.navTo(slot.date);
|
|
188
|
+
}
|
|
189
|
+
else if (this.activeView == 'years' && this.depth == 'years') {
|
|
190
|
+
this.value = slot.date;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
_handleNavClick(e) {
|
|
194
|
+
if (this.activeView == 'days')
|
|
195
|
+
this.activeView = 'months';
|
|
196
|
+
else if (this.activeView == 'months')
|
|
197
|
+
this.activeView = 'years';
|
|
198
|
+
}
|
|
199
|
+
_onValueChanged(oldValue, newValue) {
|
|
200
|
+
this._genearteSlots();
|
|
201
|
+
}
|
|
202
|
+
_handleGoToday() {
|
|
203
|
+
this.value = this._today.date;
|
|
204
|
+
this.goToday();
|
|
205
|
+
}
|
|
206
|
+
next() {
|
|
207
|
+
this._navNextPrev(false);
|
|
208
|
+
}
|
|
209
|
+
prev() {
|
|
210
|
+
this._navNextPrev(true);
|
|
211
|
+
}
|
|
212
|
+
_navNextPrev(prev) {
|
|
213
|
+
const sign = (prev ? -1 : 1);
|
|
214
|
+
if (this.activeView == 'days')
|
|
215
|
+
this.navTo(this._viewStartDate.add('month', sign * 1));
|
|
216
|
+
else if (this.activeView == 'months')
|
|
217
|
+
this.navTo(this._viewStartDate.add('year', sign * 1));
|
|
218
|
+
else
|
|
219
|
+
this.navTo(this._viewStartDate.add('year', sign * 12));
|
|
220
|
+
}
|
|
221
|
+
goToday() {
|
|
222
|
+
this.navTo(this._today.startOf());
|
|
223
|
+
}
|
|
224
|
+
navTo(date) {
|
|
225
|
+
this._viewStartDate = AXDateTime.convert(date, this._today.calendar.name());
|
|
226
|
+
this._genearteSlots();
|
|
227
|
+
}
|
|
228
|
+
get __hostClass() {
|
|
229
|
+
const _classes = {
|
|
230
|
+
'ax-state-disabled': this.disabled
|
|
231
|
+
};
|
|
232
|
+
return Object.entries(_classes).filter(c => c[1]).map(c => c[0]).join(' ');
|
|
233
|
+
}
|
|
234
|
+
isDisabled(date) {
|
|
235
|
+
if (Array.isArray(this.disabledDates) && this.disabledDates.length != 0) {
|
|
236
|
+
debugger;
|
|
237
|
+
return this.disabledDates.some(d => date.equal(d, 'day'));
|
|
238
|
+
}
|
|
239
|
+
else if (typeof this.disabledDates == 'function') {
|
|
240
|
+
return this.disabledDates(date.date);
|
|
241
|
+
}
|
|
242
|
+
return false;
|
|
243
|
+
}
|
|
244
|
+
isHoliday(date) {
|
|
245
|
+
if (Array.isArray(this.holidayDates) && this.holidayDates.length != 0) {
|
|
246
|
+
return this.holidayDates.some(d => date.equal(d, 'day'));
|
|
247
|
+
}
|
|
248
|
+
else if (typeof this.holidayDates == 'function') {
|
|
249
|
+
return this.holidayDates(date.date);
|
|
250
|
+
}
|
|
251
|
+
return false;
|
|
252
|
+
}
|
|
253
|
+
isWeekend(date) {
|
|
254
|
+
return date.dayOfWeek == 7 || date.dayOfWeek == 1;
|
|
38
255
|
}
|
|
39
256
|
}
|
|
40
257
|
AXCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXCalendarComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
41
|
-
AXCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.6", type: AXCalendarComponent, selector: "ax-calendar", inputs: { disabled: "disabled", tabIndex: "tabIndex",
|
|
258
|
+
AXCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.6", type: AXCalendarComponent, selector: "ax-calendar", inputs: { readonly: "readonly", allowNull: "allowNull", value: "value", debounceTime: "debounceTime", name: "name", disabled: "disabled", tabIndex: "tabIndex", activeView: "activeView", depth: "depth", min: "min", max: "max", disabledDates: "disabledDates", holidayDates: "holidayDates" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", depthChange: "depthChange" }, host: { properties: { "class": "this.__hostClass" } }, usesInheritance: true, ngImport: i0, template: "<div class=\"ax-calendar-header\">\r\n <ax-button class=\"ax-nav-button\" [text]=\"_navText\" color=\"light\" look=\"blank\" (onClick)=\"_handleNavClick($event)\" [disabled]=\"disabled\">\r\n </ax-button>\r\n <ax-button class=\"ax-prev-button\" color=\"light\" look=\"blank\" (onClick)=\"_handlePrevClick($event)\" [disabled]=\"disabled\">\r\n <ax-prefix>\r\n <ax-icon icon=\"ax-ic ax-ic-chevron ax-transform ax-rotate-90\"></ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n <ax-button class=\"ax-next-button\" color=\"light\" look=\"blank\" (onClick)=\"_handleNextClick($event)\" [disabled]=\"disabled\">\r\n <ax-prefix>\r\n <ax-icon icon=\"ax-ic ax-ic-chevron ax-transform ax--rotate-90\"></ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n</div>\r\n<div class=\"ax-calendar-body\">\r\n <div [ngSwitch]=\"activeView\">\r\n <ng-container *ngSwitchCase=\"'years'\">\r\n <div class=\"ax-calendar-slots ax-calendar-slots-year\">\r\n <div tabindex=\"0\" *ngFor=\"let slot of _slots\" [ngClass]=\"slot.cssClass\" \r\n (click)=\"_handleSlotClick(slot)\">{{slot.text}}</div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'months'\">\r\n <div class=\"ax-calendar-slots ax-calendar-slots-month\">\r\n <div tabindex=\"0\" *ngFor=\"let slot of _slots\" [title]=\"slot.tooltip\" [ngClass]=\"slot.cssClass\" \r\n (click)=\"_handleSlotClick(slot)\">{{slot.text}}</div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n <div class=\"ax-calendar-week\">\r\n <div>SU</div>\r\n <div>MO</div>\r\n <div>TU</div>\r\n <div>WE</div>\r\n <div>TH</div>\r\n <div>FR</div>\r\n <div>SA</div>\r\n </div>\r\n <div class=\"ax-calendar-slots ax-calendar-slots-day\">\r\n <div tabindex=\"0\" *ngFor=\"let slot of _slots\" [title]=\"slot.tooltip\" [ngClass]=\"slot.cssClass\"\r\n (click)=\"_handleSlotClick(slot)\">{{slot.text}}</div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n\r\n</div>\r\n<div class=\"ax-calendar-footer\">\r\n <ax-button [text]=\"_todayText\" color=\"dark\" look=\"blank\" size=\"sm\" (onClick)=\"_handleGoToday()\" [disabled]=\"disabled\"></ax-button>\r\n</div>", components: [{ type: i1.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "tabIndex", "size", "text", "submitBehavior", "cancelBehavior", "color", "look", "toggleable", "selected"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange"] }, { type: i2.AXDecoratorPrefixComponent, selector: "ax-prefix" }, { type: i3.AXIconComponent, selector: "ax-icon", inputs: ["icon"] }], directives: [{ type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgSwitchDefault, selector: "[ngSwitchDefault]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
42
259
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXCalendarComponent, decorators: [{
|
|
43
260
|
type: Component,
|
|
44
261
|
args: [{
|
|
45
262
|
selector: 'ax-calendar',
|
|
46
263
|
templateUrl: './calendar.component.html',
|
|
47
264
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
48
|
-
inputs: [
|
|
265
|
+
inputs: [...VALUE_INPUTS, ...INTERACTIVE_INPUTS],
|
|
266
|
+
outputs: [...VALUE_OUTPUT, ...INTERACTIVE_OUTPUT],
|
|
49
267
|
encapsulation: ViewEncapsulation.None,
|
|
50
268
|
}]
|
|
51
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: {
|
|
52
|
-
type:
|
|
53
|
-
|
|
54
|
-
|
|
269
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { activeView: [{
|
|
270
|
+
type: Input
|
|
271
|
+
}], depthChange: [{
|
|
272
|
+
type: Output
|
|
273
|
+
}], depth: [{
|
|
274
|
+
type: Input
|
|
275
|
+
}], min: [{
|
|
276
|
+
type: Input
|
|
277
|
+
}], max: [{
|
|
278
|
+
type: Input
|
|
279
|
+
}], disabledDates: [{
|
|
55
280
|
type: Input
|
|
56
|
-
}],
|
|
281
|
+
}], holidayDates: [{
|
|
57
282
|
type: Input
|
|
283
|
+
}], __hostClass: [{
|
|
284
|
+
type: HostBinding,
|
|
285
|
+
args: ['class']
|
|
58
286
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/calendar/calendar.component.ts","../../../../../../projects/acorex/components/src/lib/calendar/calendar.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,iBAAiB,EACjB,uBAAuB,EAGvB,KAAK,EACL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,eAAe,EAAE,MAAM,SAAS,CAAC;;;;;AAShE,MAAM,OAAO,mBAAoB,SAAQ,eAAe;IAGtD,YAAY,UAAsB,EAAE,GAAsB;QACxD,KAAK,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QAIzB,cAAS,GAAY,KAAK,CAAC;QAG3B,aAAQ,GAAY,KAAK,CAAC;QAE1B,aAAQ,GAAa,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC;QACnC,cAAS,GAAa,CAAC,IAAI,CAAC,CAAC;QAC7B,eAAU,GAAa;YACrB,SAAS;YACT,UAAU;YACV,OAAO;YACP,OAAO;YACP,KAAK;YACL,MAAM;YACN,MAAM;YACN,QAAQ;YACR,WAAW;YACX,SAAS;YACT,UAAU;YACV,UAAU;SACX,CAAC;QAvBA,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAwBD,eAAe;IAEf,CAAC;IAED,WAAW;QACT,IAAI,MAAM,GAAG,IAAI,CAAC;QAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE;YAC3B,MAAM,GAAG,MAAM,GAAG,CAAC,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC7B;IACH,CAAC;;gHAxCU,mBAAmB;oGAAnB,mBAAmB,wUClBhC,+0HAyEM;2FDvDO,mBAAmB;kBAP/B,SAAS;mBAAC;oBACT,QAAQ,EAAE,aAAa;oBACvB,WAAW,EAAE,2BAA2B;oBACxC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,MAAM,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,CAAC;oBAChE,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACtC;iIAEoB,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBAOjB,SAAS;sBADR,KAAK;gBAIN,QAAQ;sBADP,KAAK","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { AXBaseComponentMixin, AXCalendarMixin } from '../base';\r\n\r\n@Component({\r\n  selector: 'ax-calendar',\r\n  templateUrl: './calendar.component.html',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  inputs: ['disabled', 'tabIndex', 'size', 'cssClass', 'cssStyle'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class AXCalendarComponent extends AXCalendarMixin {\r\n  @ViewChild('days') days: ElementRef<HTMLDivElement>;\r\n\r\n  constructor(elementRef: ElementRef, cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n    this.createYears();\r\n  }\r\n  @Input()\r\n  actionBar: boolean = false;\r\n\r\n  @Input()\r\n  showTime: boolean = false;\r\n\r\n  dayItems: number[] = new Array(32);\r\n  yearItems: number[] = [1990];\r\n  monthItems: string[] = [\r\n    'January',\r\n    'February',\r\n    'March',\r\n    'April',\r\n    'May',\r\n    'June',\r\n    'July',\r\n    'August',\r\n    'September',\r\n    'October',\r\n    'November',\r\n    'December',\r\n  ];\r\n\r\n  ngAfterViewInit() {\r\n\r\n  }\r\n\r\n  createYears() {\r\n    let number = 1990;\r\n    for (let i = 0; i < 40; i++) {\r\n      number = number + 1;\r\n      this.yearItems.push(number);\r\n    }\r\n  }\r\n}\r\n","<div class=\"ax-calendar\">\r\n    <div class=\"ax-calendar-header\">\r\n        <ax-button cssClass=\"ax-nav-button\" text=\"October 2021\" color=\"light\" look=\"blank\"></ax-button>\r\n        <ax-button cssClass=\"ax-prev-button\" color=\"light\" look=\"blank\">\r\n            <ax-prefix>\r\n                <ax-icon icon=\"ax-ic ax-ic-chevron ax-transform ax-rotate-90\"></ax-icon>\r\n            </ax-prefix>\r\n        </ax-button>\r\n        <ax-button cssClass=\"ax-next-button\" color=\"light\" look=\"blank\">\r\n            <ax-prefix>\r\n                <ax-icon icon=\"ax-ic ax-ic-chevron ax-transform ax--rotate-90\"></ax-icon>\r\n            </ax-prefix>\r\n        </ax-button>\r\n    </div>\r\n    <div class=\"ax-calendar-body\">\r\n        <div class=\"ax-month-items\">\r\n            <div class=\"ax-month-item\">MO</div>\r\n            <div class=\"ax-month-item\">TU</div>\r\n            <div class=\"ax-month-item\">WE</div>\r\n            <div class=\"ax-month-item\">TH</div>\r\n            <div class=\"ax-month-item\">FR</div>\r\n            <div class=\"ax-month-item\">SA</div>\r\n            <div class=\"ax-month-item\">SU</div>\r\n        </div>\r\n        <div class=\"ax-day-items\">\r\n            <div class=\"ax-day-item ax-state-event\">27</div>\r\n            <div class=\"ax-day-item ax-state-event ax-state-event-primary\">28</div>\r\n            <div class=\"ax-day-item ax-state-event ax-state-event-secondary\">29</div>\r\n            <div class=\"ax-day-item ax-state-event ax-state-event-success\">30</div>\r\n            <div class=\"ax-day-item ax-state-event ax-state-event-warning\">01</div>\r\n            <div class=\"ax-day-item ax-state-event ax-state-event-danger\">02</div>\r\n            <div class=\"ax-day-item ax-state-holiday\">03</div>\r\n            <div class=\"ax-day-item\">04</div>\r\n            <div class=\"ax-day-item\">05</div>\r\n            <div class=\"ax-day-item\">06</div>\r\n            <div class=\"ax-day-item\">07</div>\r\n            <div class=\"ax-day-item\">08</div>\r\n            <div class=\"ax-day-item\">09</div>\r\n            <div class=\"ax-day-item ax-state-holiday\">10</div>\r\n            <div class=\"ax-day-item\">11</div>\r\n            <div class=\"ax-day-item ax-state-event ax-state-event-info\">12</div>\r\n            <div class=\"ax-day-item\">13</div>\r\n            <div class=\"ax-day-item\">14</div>\r\n            <div class=\"ax-day-item\">15</div>\r\n            <div class=\"ax-day-item\">16</div>\r\n            <div class=\"ax-day-item ax-state-holiday\">17</div>\r\n            <div class=\"ax-day-item\">18</div>\r\n            <div class=\"ax-day-item\">19</div>\r\n            <div class=\"ax-day-item\">20</div>\r\n            <div class=\"ax-day-item\">21</div>\r\n            <div class=\"ax-day-item\">22</div>\r\n            <div class=\"ax-day-item\">23</div>\r\n            <div class=\"ax-day-item ax-state-holiday\">24</div>\r\n            <div class=\"ax-day-item\">25</div>\r\n            <div class=\"ax-day-item\">26</div>\r\n            <div class=\"ax-day-item\">27</div>\r\n            <div class=\"ax-day-item ax-state-today\">28</div>\r\n            <div class=\"ax-day-item\">29</div>\r\n            <div class=\"ax-day-item\">30</div>\r\n            <div class=\"ax-day-item ax-state-holiday\">31</div>\r\n            <div class=\"ax-day-item\">01</div>\r\n            <div class=\"ax-day-item\">02</div>\r\n            <div class=\"ax-day-item\">03</div>\r\n            <div class=\"ax-day-item\">04</div>\r\n            <div class=\"ax-day-item ax-state-selected\">05</div>\r\n            <div class=\"ax-day-item\">06</div>\r\n            <div class=\"ax-day-item ax-state-holiday\">07</div>\r\n        </div>\r\n\r\n    </div>\r\n    <div class=\"ax-calendar-footer\">\r\n        <ax-button text=\"Today\" color=\"dark\" size=\"sm\"></ax-button>\r\n    </div>\r\n</div>"]}
|
|
287
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/calendar/calendar.component.ts","../../../../../../projects/acorex/components/src/lib/calendar/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXDateTime, AXDateTimeRange } from '@acorex/core';\r\nimport {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  HostBinding,\r\n} from '@angular/core';\r\nimport { AXCalendarComponentMixin, AXClickEvent } from '../base';\r\nimport { INTERACTIVE_INPUTS, INTERACTIVE_OUTPUT } from '../base/mixin/interactive-mixin.class';\r\nimport { VALUE_INPUTS, VALUE_OUTPUT } from '../base/mixin/value-mixin.class';\r\n\r\n\r\nexport type AXCalendarViewType = 'years' | 'months' | 'days';\r\nexport type AXCalendarViewDepth = AXCalendarViewType;\r\nexport type AXCalendarDisabledDates = Date[] | ((date: Date) => boolean);\r\nexport type AXCalendarHolidayDates = Date[] | ((date: Date) => boolean);\r\n\r\n@Component({\r\n  selector: 'ax-calendar',\r\n  templateUrl: './calendar.component.html',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  inputs: [...VALUE_INPUTS, ...INTERACTIVE_INPUTS],\r\n  outputs: [...VALUE_OUTPUT, ...INTERACTIVE_OUTPUT],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class AXCalendarComponent extends AXCalendarComponentMixin {\r\n\r\n\r\n  private get _viewRange(): AXDateTimeRange {\r\n    const current = this._viewStartDate || this._today;\r\n    switch (this.activeView) {\r\n      case 'years':\r\n        let y = current.startOf('year').year;\r\n        let min = y - (y % 10) - 1;\r\n        let max = min + 11;\r\n        return new AXDateTimeRange(\r\n          AXDateTime.convert(new Date(min, 0), this._today.calendar.name()),\r\n          AXDateTime.convert(new Date(max, 0), this._today.calendar.name())\r\n        );\r\n      case 'months':\r\n        //TODO: check add month function\r\n        return new AXDateTimeRange(current.startOf('year'), current.endOf('year').add('month', 4).add('day', -1));\r\n      default:\r\n        //return new AXDateTimeRange(current.startOf('month').startOf('week'), current.endOf('month').endOf('week'));\r\n        return new AXDateTimeRange(current.startOf('month'), current.endOf('month'));\r\n    }\r\n  }\r\n\r\n\r\n\r\n  _today = new AXDateTime(new Date());\r\n  private _viewStartDate: AXDateTime;\r\n\r\n  _navText: string = '';\r\n  _todayText: string = '';\r\n\r\n  _slots: any[] = []\r\n\r\n\r\n\r\n  private _activeView: AXCalendarViewType = 'days';\r\n  @Input()\r\n  public get activeView(): AXCalendarViewType {\r\n    return this._activeView;\r\n  }\r\n  public set activeView(v: AXCalendarViewType) {\r\n    this._activeView = v;\r\n    this._genearteSlots();\r\n  }\r\n\r\n\r\n\r\n  @Output()\r\n  depthChange: EventEmitter<AXCalendarViewDepth> = new EventEmitter<AXCalendarViewDepth>();\r\n\r\n  private _depth: AXCalendarViewDepth = 'days';\r\n  @Input()\r\n  public get depth(): AXCalendarViewDepth {\r\n    return this._depth;\r\n  }\r\n  public set depth(v: AXCalendarViewDepth) {\r\n    this._depth = v;\r\n    this._activeView = v;\r\n    this.depthChange.emit(v);\r\n\r\n    this._genearteSlots();\r\n  }\r\n\r\n\r\n\r\n  private _min: Date;\r\n  @Input()\r\n  public get min(): Date {\r\n    return this._min;\r\n  }\r\n  public set min(v: Date) {\r\n    this._min = v;\r\n  }\r\n\r\n\r\n  private _max: Date;\r\n  @Input()\r\n  public get max(): Date {\r\n    return this._max;\r\n  }\r\n  public set max(v: Date) {\r\n    this._max = v;\r\n  }\r\n\r\n\r\n\r\n  private _disabledDates: AXCalendarDisabledDates;\r\n  @Input()\r\n  public get disabledDates(): AXCalendarDisabledDates {\r\n    return this._disabledDates;\r\n  }\r\n  public set disabledDates(v: AXCalendarDisabledDates) {\r\n    this._disabledDates = v;\r\n  }\r\n\r\n\r\n  private _holidayDates: AXCalendarHolidayDates;\r\n  @Input()\r\n  public get holidayDates(): AXCalendarHolidayDates {\r\n    return this._holidayDates;\r\n  }\r\n  public set holidayDates(v: AXCalendarHolidayDates) {\r\n    this._holidayDates = v;\r\n  }\r\n\r\n\r\n\r\n  constructor(elementRef: ElementRef, private cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n\r\n  }\r\n\r\n  onInit() {\r\n    this.goToday();\r\n  }\r\n\r\n  private _genearteSlots() {\r\n    if (!this._viewStartDate)\r\n      return;\r\n    const vr = this._viewRange;\r\n    // year view\r\n    if (this.activeView == 'years') {\r\n      const a = vr.enumurate('year');\r\n      this._slots = a.map((d, i) => {\r\n        const r: any = {};\r\n        r.date = d.date;\r\n        r.text = d.format('YYYY');\r\n        r.disabled = (this.min && d.compare(this.min, 'year') == -1) || (this.max && d.compare(this.max, 'year') == 1);\r\n        if (r.disabled) {\r\n          r.cssClass = {\r\n            'ax-state-disabled': r.disabled,\r\n          }\r\n        }\r\n        else {\r\n          r.cssClass = {\r\n            'ax-state-today': d.equal(this._today, 'year'),\r\n            'ax-state-selected': this.value && this.depth == 'years' && d.equal(this.value, 'year'),\r\n          }\r\n        }\r\n        return r;\r\n      });\r\n      this._navText = `${vr.startTime.year} - ${vr.endTime.year}`;\r\n      this._todayText = this._today.format('YYYY');\r\n    }\r\n    // month view\r\n    else if (this.activeView == 'months') {\r\n      const a = vr.enumurate('month');\r\n      this._slots = a.map((d, i) => {\r\n        const r: any = {};\r\n        r.date = d.date;\r\n        r.text = d.format('MMM');\r\n        r.tooltip = d.format('MMMM YYYY');\r\n        r.disabled = (this.min && d.compare(this.min, 'month') == -1) || (this.max && d.compare(this.max, 'month') == 1);\r\n        if (r.disabled) {\r\n          r.cssClass = {\r\n            'ax-state-disabled': r.disabled,\r\n          }\r\n        }\r\n        else {\r\n          r.cssClass = {\r\n            'ax-state-today': d.equal(this._today, 'month'),\r\n            'ax-state-selected': this.value && this.depth == 'months' && d.equal(this.value, 'month'),\r\n            'ax-state-other': d.year != this._viewStartDate.year\r\n          }\r\n        }\r\n        return r;\r\n      });\r\n      this._navText = this._viewStartDate.format('YYYY');\r\n      this._todayText = this._today.format('MMMM YYYY');\r\n    }\r\n    // day view\r\n    else {\r\n      const a = vr.enumurate('day');\r\n      this._slots = a.map((d, i) => {\r\n        const r: any = {};\r\n        r.date = d.date;\r\n        r.text = d.dayOfMonth;\r\n        r.tooltip = d.format();\r\n        r.disabled = (this.min && d.compare(this.min, 'day') == -1) || (this.max && d.compare(this.max, 'day') == 1);\r\n        if (r.disabled || this.isDisabled(d)) {\r\n          r.cssClass = {\r\n            'ax-state-disabled': true,\r\n          }\r\n        }\r\n        else {\r\n          r.cssClass = {\r\n            'ax-state-today': d.equal(this._today, 'day'),\r\n            'ax-state-selected': this.value && d.equal(this.value, 'day'),\r\n            'ax-state-holiday': this.isHoliday(d) || this.isWeekend(d),\r\n            // 'ax-state-event-info': d.dayOfMonth == 12,\r\n            // 'ax-state-event': d.dayOfMonth == 12,\r\n          }\r\n        }\r\n        r.cssClass[`ax-col-start-${vr.startTime.dayOfWeek}`] = i == 0\r\n        return r;\r\n      });\r\n      this._navText = this._viewStartDate.format('MMMM YYYY');\r\n      this._todayText = this._today.format('DDDD, MMMM dd, YYYY');\r\n    }\r\n  }\r\n\r\n\r\n  _handlePrevClick(e: AXClickEvent) {\r\n    this.prev();\r\n  }\r\n\r\n  _handleNextClick(e: AXClickEvent) {\r\n    this.next();\r\n  }\r\n\r\n  _handleSlotClick(slot) {\r\n    if (slot.disabled || this.disabled)\r\n      return;\r\n    if (this.activeView == 'days') {\r\n      this.value = slot.date;\r\n    }\r\n    else if (this.activeView == 'months' && this.depth == 'days') {\r\n      this.activeView = 'days';\r\n      this.navTo(slot.date);\r\n    }\r\n    else if (this.activeView == 'months' && this.depth == 'months') {\r\n      this.value = slot.date;\r\n    }\r\n    else if (this.activeView == 'years' && (this.depth == 'days' || this.depth == 'months')) {\r\n      this.activeView = 'months';\r\n      this.navTo(slot.date);\r\n    }\r\n    else if (this.activeView == 'years' && this.depth == 'years') {\r\n      this.value = slot.date;\r\n    }\r\n  }\r\n\r\n  _handleNavClick(e: AXClickEvent) {\r\n    if (this.activeView == 'days')\r\n      this.activeView = 'months';\r\n    else if (this.activeView == 'months')\r\n      this.activeView = 'years';\r\n  }\r\n\r\n  _onValueChanged(oldValue, newValue) {\r\n    this._genearteSlots();\r\n  }\r\n\r\n  _handleGoToday() {\r\n    this.value = this._today.date;\r\n    this.goToday();\r\n  }\r\n\r\n  next() {\r\n    this._navNextPrev(false)\r\n  }\r\n\r\n  prev() {\r\n    this._navNextPrev(true)\r\n  }\r\n\r\n  private _navNextPrev(prev: boolean) {\r\n    const sign = (prev ? -1 : 1);\r\n    if (this.activeView == 'days')\r\n      this.navTo(this._viewStartDate.add('month', sign * 1));\r\n    else if (this.activeView == 'months')\r\n      this.navTo(this._viewStartDate.add('year', sign * 1));\r\n    else\r\n      this.navTo(this._viewStartDate.add('year', sign * 12));\r\n  }\r\n\r\n  goToday() {\r\n    this.navTo(this._today.startOf());\r\n  }\r\n\r\n\r\n  navTo(date: Date | AXDateTime) {\r\n    this._viewStartDate = AXDateTime.convert(date, this._today.calendar.name());\r\n    this._genearteSlots();\r\n  }\r\n\r\n\r\n  @HostBinding('class')\r\n  private get __hostClass(): string {\r\n    const _classes = {\r\n      'ax-state-disabled': this.disabled\r\n    }\r\n    return Object.entries(_classes).filter(c => c[1]).map(c => c[0]).join(' ');\r\n  }\r\n\r\n\r\n  private isDisabled(date: AXDateTime): boolean {\r\n    if (Array.isArray(this.disabledDates) && this.disabledDates.length != 0) {\r\n      debugger;\r\n      return this.disabledDates.some(d => date.equal(d, 'day'));\r\n    }\r\n    else if (typeof this.disabledDates == 'function') {\r\n      return this.disabledDates(date.date);\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private isHoliday(date: AXDateTime): boolean {\r\n    if (Array.isArray(this.holidayDates) && this.holidayDates.length != 0) {\r\n      return this.holidayDates.some(d => date.equal(d, 'day'));\r\n    }\r\n    else if (typeof this.holidayDates == 'function') {\r\n      return this.holidayDates(date.date);\r\n    }\r\n    return false;\r\n  }\r\n\r\n  private isWeekend(date: AXDateTime): boolean {\r\n    return date.dayOfWeek == 7 || date.dayOfWeek == 1;\r\n  }\r\n}\r\n","<div class=\"ax-calendar-header\">\r\n    <ax-button class=\"ax-nav-button\" [text]=\"_navText\" color=\"light\" look=\"blank\" (onClick)=\"_handleNavClick($event)\" [disabled]=\"disabled\">\r\n    </ax-button>\r\n    <ax-button class=\"ax-prev-button\" color=\"light\" look=\"blank\" (onClick)=\"_handlePrevClick($event)\" [disabled]=\"disabled\">\r\n        <ax-prefix>\r\n            <ax-icon icon=\"ax-ic ax-ic-chevron ax-transform ax-rotate-90\"></ax-icon>\r\n        </ax-prefix>\r\n    </ax-button>\r\n    <ax-button class=\"ax-next-button\" color=\"light\" look=\"blank\" (onClick)=\"_handleNextClick($event)\" [disabled]=\"disabled\">\r\n        <ax-prefix>\r\n            <ax-icon icon=\"ax-ic ax-ic-chevron ax-transform ax--rotate-90\"></ax-icon>\r\n        </ax-prefix>\r\n    </ax-button>\r\n</div>\r\n<div class=\"ax-calendar-body\">\r\n    <div [ngSwitch]=\"activeView\">\r\n        <ng-container *ngSwitchCase=\"'years'\">\r\n            <div class=\"ax-calendar-slots ax-calendar-slots-year\">\r\n                <div tabindex=\"0\" *ngFor=\"let slot of _slots\" [ngClass]=\"slot.cssClass\" \r\n                    (click)=\"_handleSlotClick(slot)\">{{slot.text}}</div>\r\n            </div>\r\n        </ng-container>\r\n        <ng-container *ngSwitchCase=\"'months'\">\r\n            <div class=\"ax-calendar-slots ax-calendar-slots-month\">\r\n                <div tabindex=\"0\" *ngFor=\"let slot of _slots\" [title]=\"slot.tooltip\" [ngClass]=\"slot.cssClass\" \r\n                    (click)=\"_handleSlotClick(slot)\">{{slot.text}}</div>\r\n            </div>\r\n        </ng-container>\r\n        <ng-container *ngSwitchDefault>\r\n            <div class=\"ax-calendar-week\">\r\n                <div>SU</div>\r\n                <div>MO</div>\r\n                <div>TU</div>\r\n                <div>WE</div>\r\n                <div>TH</div>\r\n                <div>FR</div>\r\n                <div>SA</div>\r\n            </div>\r\n            <div class=\"ax-calendar-slots ax-calendar-slots-day\">\r\n                <div tabindex=\"0\" *ngFor=\"let slot of _slots\" [title]=\"slot.tooltip\"  [ngClass]=\"slot.cssClass\"\r\n                    (click)=\"_handleSlotClick(slot)\">{{slot.text}}</div>\r\n            </div>\r\n        </ng-container>\r\n    </div>\r\n\r\n</div>\r\n<div class=\"ax-calendar-footer\">\r\n    <ax-button [text]=\"_todayText\" color=\"dark\" look=\"blank\" size=\"sm\" (onClick)=\"_handleGoToday()\" [disabled]=\"disabled\"></ax-button>\r\n</div>"]}
|
|
@@ -4,13 +4,14 @@ import { AXCalendarComponent } from './calendar.component';
|
|
|
4
4
|
import { AXButtonModule } from '../button';
|
|
5
5
|
import { AXEditorDecoratorModule } from '../decorators';
|
|
6
6
|
import { AXIconModule } from '../icon';
|
|
7
|
+
import { AXDateTimeModule } from '@acorex/core';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
const COMPONENT = [AXCalendarComponent];
|
|
9
|
-
const MODULES = [CommonModule, AXButtonModule, AXEditorDecoratorModule,
|
|
10
|
+
const MODULES = [CommonModule, AXButtonModule, AXIconModule, AXEditorDecoratorModule, AXDateTimeModule];
|
|
10
11
|
export class AXCalendarModule {
|
|
11
12
|
}
|
|
12
13
|
AXCalendarModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXCalendarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
-
AXCalendarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXCalendarModule, declarations: [AXCalendarComponent], imports: [CommonModule, AXButtonModule, AXEditorDecoratorModule,
|
|
14
|
+
AXCalendarModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXCalendarModule, declarations: [AXCalendarComponent], imports: [CommonModule, AXButtonModule, AXIconModule, AXEditorDecoratorModule, AXDateTimeModule], exports: [AXCalendarComponent] });
|
|
14
15
|
AXCalendarModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXCalendarModule, providers: [], imports: [[...MODULES]] });
|
|
15
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXCalendarModule, decorators: [{
|
|
16
17
|
type: NgModule,
|
|
@@ -21,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.6", ngImpor
|
|
|
21
22
|
providers: [],
|
|
22
23
|
}]
|
|
23
24
|
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi9jYWxlbmRhci9jYWxlbmRhci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUMzQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUV2QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxjQUFjLENBQUM7O0FBRWhELE1BQU0sU0FBUyxHQUFHLENBQUMsbUJBQW1CLENBQUMsQ0FBQztBQUN4QyxNQUFNLE9BQU8sR0FBRyxDQUFDLFlBQVksRUFBRSxjQUFjLEVBQUUsWUFBWSxFQUFFLHVCQUF1QixFQUFFLGdCQUFnQixDQUFDLENBQUM7QUFReEcsTUFBTSxPQUFPLGdCQUFnQjs7NkdBQWhCLGdCQUFnQjs4R0FBaEIsZ0JBQWdCLGlCQVRWLG1CQUFtQixhQUNyQixZQUFZLEVBQUUsY0FBYyxFQUFFLFlBQVksRUFBRSx1QkFBdUIsRUFBRSxnQkFBZ0IsYUFEbkYsbUJBQW1COzhHQVN6QixnQkFBZ0IsYUFGZCxFQUFFLFlBRkosQ0FBQyxHQUFHLE9BQU8sQ0FBQzsyRkFJWixnQkFBZ0I7a0JBTjVCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLEdBQUcsT0FBTyxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDdkIsU0FBUyxFQUFFLEVBQUU7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQVhDYWxlbmRhckNvbXBvbmVudCB9IGZyb20gJy4vY2FsZW5kYXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9idXR0b24nO1xyXG5pbXBvcnQgeyBBWEVkaXRvckRlY29yYXRvck1vZHVsZSB9IGZyb20gJy4uL2RlY29yYXRvcnMnO1xyXG5pbXBvcnQgeyBBWEljb25Nb2R1bGUgfSBmcm9tICcuLi9pY29uJztcclxuaW1wb3J0IHsgQnJvd3Nlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xyXG5pbXBvcnQgeyBBWERhdGVUaW1lTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb3JlJztcclxuXHJcbmNvbnN0IENPTVBPTkVOVCA9IFtBWENhbGVuZGFyQ29tcG9uZW50XTtcclxuY29uc3QgTU9EVUxFUyA9IFtDb21tb25Nb2R1bGUsIEFYQnV0dG9uTW9kdWxlLCBBWEljb25Nb2R1bGUsIEFYRWRpdG9yRGVjb3JhdG9yTW9kdWxlLCBBWERhdGVUaW1lTW9kdWxlXTtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBkZWNsYXJhdGlvbnM6IFsuLi5DT01QT05FTlRdLFxyXG4gICAgaW1wb3J0czogWy4uLk1PRFVMRVNdLFxyXG4gICAgZXhwb3J0czogWy4uLkNPTVBPTkVOVF0sXHJcbiAgICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhDYWxlbmRhck1vZHVsZSB7IH1cclxuIl19
|