@odx/angular 12.21.1 → 12.21.2
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/CHANGELOG.md +6 -0
- package/cdk/date-input/index.d.ts +1 -0
- package/cdk/date-input/lib/utils/ngx-mask-init.d.ts +3 -0
- package/components/datepicker/lib/directives/datepicker-input-control.directive.d.ts +4 -16
- package/components/daterangepicker/lib/directives/daterangepicker-input-control.directive.d.ts +4 -16
- package/components/timepicker/lib/directives/timepicker-input-control.directive.d.ts +6 -15
- package/components/timepicker/lib/timepicker.service.d.ts +5 -4
- package/esm2022/cdk/date-input/index.mjs +2 -1
- package/esm2022/cdk/date-input/lib/utils/ngx-mask-init.mjs +22 -0
- package/esm2022/components/datepicker/lib/datepicker.component.mjs +3 -2
- package/esm2022/components/datepicker/lib/directives/datepicker-input-control.directive.mjs +8 -23
- package/esm2022/components/daterangepicker/lib/daterangepicker.component.mjs +4 -2
- package/esm2022/components/daterangepicker/lib/directives/daterangepicker-input-control.directive.mjs +8 -23
- package/esm2022/components/timepicker/lib/directives/timepicker-input-control.directive.mjs +17 -37
- package/esm2022/components/timepicker/lib/timepicker.component.mjs +21 -6
- package/esm2022/components/timepicker/lib/timepicker.service.mjs +42 -15
- package/fesm2022/odx-angular-cdk-date-input.mjs +23 -2
- package/fesm2022/odx-angular-cdk-date-input.mjs.map +1 -1
- package/fesm2022/odx-angular-components-datepicker.mjs +10 -24
- package/fesm2022/odx-angular-components-datepicker.mjs.map +1 -1
- package/fesm2022/odx-angular-components-daterangepicker.mjs +11 -24
- package/fesm2022/odx-angular-components-daterangepicker.mjs.map +1 -1
- package/fesm2022/odx-angular-components-timepicker.mjs +113 -90
- package/fesm2022/odx-angular-components-timepicker.mjs.map +1 -1
- package/package.json +7 -7
package/CHANGELOG.md
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { EventEmitter } from '@angular/core';
|
|
2
2
|
import { ReadonlyController } from '@odx/angular';
|
|
3
3
|
import { InputControlDirective } from '@odx/angular/cdk/custom-form-control';
|
|
4
|
-
import {
|
|
4
|
+
import { NgxMaskDirective } from 'ngx-mask';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@odx/angular";
|
|
7
|
+
import * as i2 from "ngx-mask";
|
|
7
8
|
/**
|
|
8
9
|
* A directive to enhance an input element as part of a datepicker control. It applies date input formatting,
|
|
9
10
|
* mask handling, and emits focus events. This directive integrates with ngx-mask to handle input masking and
|
|
@@ -15,31 +16,18 @@ import * as i1 from "@odx/angular";
|
|
|
15
16
|
* @see {WithTabIndex}
|
|
16
17
|
*/
|
|
17
18
|
export declare class DatepickerInputControlDirective extends InputControlDirective {
|
|
18
|
-
private readonly maskConfig;
|
|
19
19
|
protected readonly readonlyController: ReadonlyController | null;
|
|
20
20
|
protected readonly config: {
|
|
21
21
|
inputDateOrder: string;
|
|
22
22
|
inputDateSeparator: string;
|
|
23
23
|
};
|
|
24
|
-
|
|
25
|
-
protected readonly ngxMaskPipe: NgxMaskPipe;
|
|
24
|
+
readonly ngxMaskDirective: NgxMaskDirective;
|
|
26
25
|
/**
|
|
27
26
|
* Emits an event when the input field receives focus or loses focus, indicating the focus state.
|
|
28
27
|
*
|
|
29
28
|
* @emits {boolean} - Indicates whether the input field is focused.
|
|
30
29
|
*/
|
|
31
30
|
focused: EventEmitter<boolean>;
|
|
32
|
-
/**
|
|
33
|
-
* Observable stream capturing and processing input events on the native element, applying the mask,
|
|
34
|
-
* and emitting the current value.
|
|
35
|
-
*
|
|
36
|
-
* @emits {string} - The current value of the input field.
|
|
37
|
-
*/
|
|
38
|
-
valueChange$: import("rxjs").Observable<string>;
|
|
39
|
-
/**
|
|
40
|
-
* Applies the configured input mask to the native element's value.
|
|
41
|
-
*/
|
|
42
|
-
applyMask(): void;
|
|
43
31
|
/**
|
|
44
32
|
* Gets the current value of the input field as a `Date` object, based on the date format from the datepicker
|
|
45
33
|
* configuration.
|
|
@@ -57,5 +45,5 @@ export declare class DatepickerInputControlDirective extends InputControlDirecti
|
|
|
57
45
|
protected handleFocusIn(): void;
|
|
58
46
|
protected handleFocusOut(): void;
|
|
59
47
|
static ɵfac: i0.ɵɵFactoryDeclaration<DatepickerInputControlDirective, never>;
|
|
60
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<DatepickerInputControlDirective, "input[odxDatepickerControl]", never, {}, { "focused": "focused"; }, never, never, true, [{ directive: typeof i1.WithTabIndex; inputs: {}; outputs: {}; }]>;
|
|
48
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<DatepickerInputControlDirective, "input[odxDatepickerControl]", never, {}, { "focused": "focused"; }, never, never, true, [{ directive: typeof i1.WithTabIndex; inputs: {}; outputs: {}; }, { directive: typeof i2.NgxMaskDirective; inputs: {}; outputs: {}; }]>;
|
|
61
49
|
}
|
package/components/daterangepicker/lib/directives/daterangepicker-input-control.directive.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { EventEmitter } from '@angular/core';
|
|
2
2
|
import { ReadonlyController } from '@odx/angular';
|
|
3
3
|
import { InputControlDirective } from '@odx/angular/cdk/custom-form-control';
|
|
4
|
-
import {
|
|
4
|
+
import { NgxMaskDirective } from 'ngx-mask';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@odx/angular";
|
|
7
|
+
import * as i2 from "ngx-mask";
|
|
7
8
|
/**
|
|
8
9
|
* Enhances an input element to support date range picking, applying an input mask for date formatting
|
|
9
10
|
* and managing focus events. This directive is typically used within a date range picker to provide
|
|
@@ -13,31 +14,18 @@ import * as i1 from "@odx/angular";
|
|
|
13
14
|
* @see {InputControlDirective}
|
|
14
15
|
*/
|
|
15
16
|
export declare class DaterangepickerInputControlDirective extends InputControlDirective {
|
|
16
|
-
private readonly maskConfig;
|
|
17
17
|
protected readonly readonlyController: ReadonlyController | null;
|
|
18
18
|
protected readonly config: {
|
|
19
19
|
inputDateOrder: string;
|
|
20
20
|
inputDateSeparator: string;
|
|
21
21
|
};
|
|
22
|
-
|
|
23
|
-
protected readonly ngxMaskPipe: NgxMaskPipe;
|
|
22
|
+
readonly ngxMaskDirective: NgxMaskDirective;
|
|
24
23
|
/**
|
|
25
24
|
* Emits an event when the input gains or loses focus, facilitating external event handling.
|
|
26
25
|
*
|
|
27
26
|
* @emits {boolean} - Indicates whether the input is focused.
|
|
28
27
|
*/
|
|
29
28
|
focused: EventEmitter<boolean>;
|
|
30
|
-
/**
|
|
31
|
-
* Captures and processes changes to the input element's value, applying the mask and updating
|
|
32
|
-
* the form control.
|
|
33
|
-
*
|
|
34
|
-
* @emits {string} - The updated value of the input element.
|
|
35
|
-
*/
|
|
36
|
-
valueChange$: import("rxjs").Observable<string>;
|
|
37
|
-
/**
|
|
38
|
-
* Applies the configured input mask to the native input element's value.
|
|
39
|
-
*/
|
|
40
|
-
applyMask(): void;
|
|
41
29
|
/**
|
|
42
30
|
* Converts the current input value to a Date object based on the configuration's date format.
|
|
43
31
|
*
|
|
@@ -53,5 +41,5 @@ export declare class DaterangepickerInputControlDirective extends InputControlDi
|
|
|
53
41
|
protected handleFocusIn(): void;
|
|
54
42
|
protected handleFocusOut(): void;
|
|
55
43
|
static ɵfac: i0.ɵɵFactoryDeclaration<DaterangepickerInputControlDirective, never>;
|
|
56
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<DaterangepickerInputControlDirective, "input[odxDaterangepickerControl],input[odxDaterangepickerStartDateControl], input[odxDaterangepickerEndDateControl]", never, {}, { "focused": "focused"; }, never, never, true, [{ directive: typeof i1.WithTabIndex; inputs: {}; outputs: {}; }]>;
|
|
44
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<DaterangepickerInputControlDirective, "input[odxDaterangepickerControl],input[odxDaterangepickerStartDateControl], input[odxDaterangepickerEndDateControl]", never, {}, { "focused": "focused"; }, never, never, true, [{ directive: typeof i1.WithTabIndex; inputs: {}; outputs: {}; }, { directive: typeof i2.NgxMaskDirective; inputs: {}; outputs: {}; }]>;
|
|
57
45
|
}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { InputControlDirective } from '@odx/angular/cdk/custom-form-control';
|
|
2
|
-
import {
|
|
2
|
+
import { NgxMaskDirective } from 'ngx-mask';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@odx/angular";
|
|
5
|
+
import * as i2 from "ngx-mask";
|
|
5
6
|
/**
|
|
6
7
|
* Directive to enhance a standard input element for time picking, integrating mask functionality for time format.
|
|
7
8
|
* It automatically adapts to locale settings provided by the enclosing `TimepickerComponent` to display time in the appropriate format.
|
|
@@ -11,19 +12,9 @@ import * as i1 from "@odx/angular";
|
|
|
11
12
|
export declare class TimepickerInputControlDirective extends InputControlDirective {
|
|
12
13
|
private readonly timepicker;
|
|
13
14
|
private readonly timepickerService;
|
|
14
|
-
|
|
15
|
+
readonly ngxMaskDirective: NgxMaskDirective | null;
|
|
15
16
|
/**
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
* @returns {Partial<NgxMaskConfig>} The mask configuration for the timepicker input.
|
|
19
|
-
*/
|
|
20
|
-
protected get maskConfig(): Partial<NgxMaskConfig>;
|
|
21
|
-
/**
|
|
22
|
-
* Stream of value changes for the input element, applying the mask and processing the input based on locale.
|
|
23
|
-
*/
|
|
24
|
-
valueChange$: import("rxjs").Observable<string>;
|
|
25
|
-
/**
|
|
26
|
-
* Computes and returns the placeholder text for the input based on locale settings.
|
|
17
|
+
* Returns the placeholder text for the input based on locale settings.
|
|
27
18
|
*
|
|
28
19
|
* @returns {string} The placeholder text for the input.
|
|
29
20
|
*/
|
|
@@ -40,7 +31,7 @@ export declare class TimepickerInputControlDirective extends InputControlDirecti
|
|
|
40
31
|
* @param {Event} event - The input event triggering the mask application.
|
|
41
32
|
* @returns {string} The masked input value.
|
|
42
33
|
*/
|
|
43
|
-
|
|
34
|
+
applyMask(useLocale: boolean): void;
|
|
44
35
|
static ɵfac: i0.ɵɵFactoryDeclaration<TimepickerInputControlDirective, never>;
|
|
45
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<TimepickerInputControlDirective, "input[odxTimepickerControl]", never, {}, {}, never, never, true, [{ directive: typeof i1.WithTabIndex; inputs: {}; outputs: {}; }, { directive: typeof i1.WithDisabledState; inputs: {}; outputs: {}; }]>;
|
|
36
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TimepickerInputControlDirective, "input[odxTimepickerControl]", never, {}, {}, never, never, true, [{ directive: typeof i1.WithTabIndex; inputs: {}; outputs: {}; }, { directive: typeof i1.WithDisabledState; inputs: {}; outputs: {}; }, { directive: typeof i2.NgxMaskDirective; inputs: {}; outputs: {}; }]>;
|
|
46
37
|
}
|
|
@@ -5,11 +5,10 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
*/
|
|
6
6
|
export declare class TimepickerService {
|
|
7
7
|
private readonly windowRef;
|
|
8
|
+
useLocale: import("@angular/core").WritableSignal<boolean>;
|
|
8
9
|
/**
|
|
9
|
-
*
|
|
10
|
-
*
|
|
11
|
-
* @param {boolean} [apm=false] - Specifies if the placeholder should include AM/PM notation.
|
|
12
|
-
* @returns {string} The placeholder string.
|
|
10
|
+
* @deprecated Will be removed in a future major version. Use `useLocale` signal instead.
|
|
11
|
+
* Generates a placeholder string for time input fields, preserving legacy API.
|
|
13
12
|
*/
|
|
14
13
|
getPlaceholder(apm?: boolean): string;
|
|
15
14
|
/**
|
|
@@ -28,6 +27,7 @@ export declare class TimepickerService {
|
|
|
28
27
|
* @returns {time is string} True if the value is a valid time string, false otherwise.
|
|
29
28
|
*/
|
|
30
29
|
isValidTime(time: unknown): time is string;
|
|
30
|
+
is12HourFormat(value: string): boolean;
|
|
31
31
|
/**
|
|
32
32
|
* Validates if the given time is greater than or equal to a minimum time constraint.
|
|
33
33
|
*
|
|
@@ -53,6 +53,7 @@ export declare class TimepickerService {
|
|
|
53
53
|
*/
|
|
54
54
|
getLocalizedTimeFormat(time: unknown, hour12?: boolean): string;
|
|
55
55
|
private convertToDates;
|
|
56
|
+
private parseTimeString;
|
|
56
57
|
static ɵfac: i0.ɵɵFactoryDeclaration<TimepickerService, never>;
|
|
57
58
|
static ɵprov: i0.ɵɵInjectableDeclaration<TimepickerService>;
|
|
58
59
|
}
|
|
@@ -2,4 +2,5 @@ export * from './lib/date.config';
|
|
|
2
2
|
export * from './lib/models/input-date-order';
|
|
3
3
|
export * from './lib/utils/get-date-input-pattern';
|
|
4
4
|
export * from './lib/utils/get-input-value-as-date';
|
|
5
|
-
|
|
5
|
+
export * from './lib/utils/ngx-mask-init';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY2RrL2RhdGUtaW5wdXQvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUuY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9pbnB1dC1kYXRlLW9yZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2dldC1kYXRlLWlucHV0LXBhdHRlcm4nO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvZ2V0LWlucHV0LXZhbHVlLWFzLWRhdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvbmd4LW1hc2staW5pdCc7XG4iXX0=
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { isFunction } from '@odx/angular/utils';
|
|
2
|
+
import { initialConfig } from 'ngx-mask';
|
|
3
|
+
export function initNgxMask(ngxMask = undefined, mask) {
|
|
4
|
+
if (!ngxMask)
|
|
5
|
+
return;
|
|
6
|
+
if (!Object.hasOwn(ngxMask, '_maskValue')) {
|
|
7
|
+
throw new Error('[DatepickerInputControlDirective] initNgxMask: ngx-mask internal API changed, mask signal not available.');
|
|
8
|
+
}
|
|
9
|
+
const maskSignal = ngxMask['_maskValue'];
|
|
10
|
+
isFunction(maskSignal.set) && maskSignal.set(mask);
|
|
11
|
+
ngxMask._maskService.maskExpression = mask;
|
|
12
|
+
}
|
|
13
|
+
export const ngxMaskProviderConfig = {
|
|
14
|
+
validation: false,
|
|
15
|
+
leadZeroDateTime: true,
|
|
16
|
+
patterns: {
|
|
17
|
+
...initialConfig.patterns,
|
|
18
|
+
A: { pattern: new RegExp('[AaPp]') },
|
|
19
|
+
M: { pattern: new RegExp('[mM]') },
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LW1hc2staW5pdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jZGsvZGF0ZS1pbnB1dC9zcmMvbGliL3V0aWxzL25neC1tYXNrLWluaXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxhQUFhLEVBQW1DLE1BQU0sVUFBVSxDQUFDO0FBRTFFLE1BQU0sVUFBVSxXQUFXLENBQUMsVUFBd0MsU0FBUyxFQUFFLElBQVk7SUFDekYsSUFBSSxDQUFDLE9BQU87UUFBRSxPQUFPO0lBQ3JCLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxZQUFZLENBQUMsRUFBRSxDQUFDO1FBQzFDLE1BQU0sSUFBSSxLQUFLLENBQUMsMEdBQTBHLENBQUMsQ0FBQztJQUM5SCxDQUFDO0lBQ0QsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ3pDLFVBQVUsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksVUFBVSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuRCxPQUFPLENBQUMsWUFBWSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7QUFDN0MsQ0FBQztBQUVELE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUEyQjtJQUMzRCxVQUFVLEVBQUUsS0FBSztJQUNqQixnQkFBZ0IsRUFBRSxJQUFJO0lBQ3RCLFFBQVEsRUFBRTtRQUNSLEdBQUcsYUFBYSxDQUFDLFFBQVE7UUFDekIsQ0FBQyxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxFQUFFO1FBQ3BDLENBQUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRTtLQUNuQztDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0Z1bmN0aW9uIH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcbmltcG9ydCB7IGluaXRpYWxDb25maWcsIE5neE1hc2tDb25maWcsIE5neE1hc2tEaXJlY3RpdmUgfSBmcm9tICduZ3gtbWFzayc7XG5cbmV4cG9ydCBmdW5jdGlvbiBpbml0Tmd4TWFzayhuZ3hNYXNrOiBOZ3hNYXNrRGlyZWN0aXZlIHwgdW5kZWZpbmVkID0gdW5kZWZpbmVkLCBtYXNrOiBzdHJpbmcpOiB2b2lkIHtcbiAgaWYgKCFuZ3hNYXNrKSByZXR1cm47XG4gIGlmICghT2JqZWN0Lmhhc093bihuZ3hNYXNrLCAnX21hc2tWYWx1ZScpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdbRGF0ZXBpY2tlcklucHV0Q29udHJvbERpcmVjdGl2ZV0gaW5pdE5neE1hc2s6IG5neC1tYXNrIGludGVybmFsIEFQSSBjaGFuZ2VkLCBtYXNrIHNpZ25hbCBub3QgYXZhaWxhYmxlLicpO1xuICB9XG4gIGNvbnN0IG1hc2tTaWduYWwgPSBuZ3hNYXNrWydfbWFza1ZhbHVlJ107XG4gIGlzRnVuY3Rpb24obWFza1NpZ25hbC5zZXQpICYmIG1hc2tTaWduYWwuc2V0KG1hc2spO1xuICBuZ3hNYXNrLl9tYXNrU2VydmljZS5tYXNrRXhwcmVzc2lvbiA9IG1hc2s7XG59XG5cbmV4cG9ydCBjb25zdCBuZ3hNYXNrUHJvdmlkZXJDb25maWc6IFBhcnRpYWw8Tmd4TWFza0NvbmZpZz4gPSB7XG4gIHZhbGlkYXRpb246IGZhbHNlLFxuICBsZWFkWmVyb0RhdGVUaW1lOiB0cnVlLFxuICBwYXR0ZXJuczoge1xuICAgIC4uLmluaXRpYWxDb25maWcucGF0dGVybnMsXG4gICAgQTogeyBwYXR0ZXJuOiBuZXcgUmVnRXhwKCdbQWFQcF0nKSB9LFxuICAgIE06IHsgcGF0dGVybjogbmV3IFJlZ0V4cCgnW21NXScpIH0sXG4gIH0sXG59O1xuIl19
|
|
@@ -3,7 +3,7 @@ import { A11yModule } from '@angular/cdk/a11y';
|
|
|
3
3
|
import { booleanAttribute, ChangeDetectionStrategy, Component, ContentChild, ElementRef, EventEmitter, HostListener, input, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
4
4
|
import { detectControllerChanges } from '@odx/angular';
|
|
5
5
|
import { CustomFormControl } from '@odx/angular/cdk/custom-form-control';
|
|
6
|
-
import { getDateInputFormat, injectDateConfig } from '@odx/angular/cdk/date-input';
|
|
6
|
+
import { getDateInputFormat, getDateInputMask, initNgxMask, injectDateConfig } from '@odx/angular/cdk/date-input';
|
|
7
7
|
import { ActionGroupComponent } from '@odx/angular/components/action-group';
|
|
8
8
|
import { ButtonComponent } from '@odx/angular/components/button';
|
|
9
9
|
import { CalendarComponent } from '@odx/angular/components/calendar';
|
|
@@ -147,6 +147,7 @@ let DatepickerComponent = class DatepickerComponent extends CustomFormControl {
|
|
|
147
147
|
this.updateDateField(value);
|
|
148
148
|
}
|
|
149
149
|
handleDateFieldChanges() {
|
|
150
|
+
initNgxMask(this.dateField?.ngxMaskDirective, getDateInputMask(this.config));
|
|
150
151
|
this.dateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe(() => {
|
|
151
152
|
if (!this.dateField?.valueAsDate)
|
|
152
153
|
return;
|
|
@@ -203,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
203
204
|
type: HostListener,
|
|
204
205
|
args: ['keydown.alt.ArrowDown', ['$event']]
|
|
205
206
|
}] } });
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/datepicker/src/lib/datepicker.component.ts","../../../../../../../libs/angular/components/datepicker/src/lib/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  input,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { detectControllerChanges } from '@odx/angular';\nimport { CustomFormControl } from '@odx/angular/cdk/custom-form-control';\nimport { getDateInputFormat, injectDateConfig } from '@odx/angular/cdk/date-input';\nimport { ActionGroupComponent } from '@odx/angular/components/action-group';\nimport { ButtonComponent } from '@odx/angular/components/button';\nimport { CalendarComponent, DateFilter } from '@odx/angular/components/calendar';\nimport { DropdownDirective, DropdownModule } from '@odx/angular/components/dropdown';\nimport { IconComponent } from '@odx/angular/components/icon';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn, injectElement, Position, untilDestroyed } from '@odx/angular/utils';\nimport { format, startOfDay } from 'date-fns';\nimport { DatepickerInputControlDirective } from './directives';\n\n/**\n * Represents a datepicker component for selecting a date.\n * Extends the `CustomFormControl` class and implements the `AfterViewInit` interface.\n *\n * @see {CustomFormControl}\n */\n@CSSComponent('datepicker')\n@Component({\n  selector: 'odx-datepicker',\n  standalone: true,\n  imports: [A11yModule, ActionGroupComponent, ButtonComponent, CalendarComponent, DropdownModule, IconComponent],\n  templateUrl: './datepicker.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DatepickerComponent extends CustomFormControl<Date | null> implements AfterViewInit {\n  protected readonly takeUntilDestroyed = untilDestroyed();\n\n  protected readonly config = injectDateConfig();\n\n  public readonly element = injectElement();\n\n  /**\n   * Gets a value indicating whether the datepicker is currently open.\n   *\n   * @returns {boolean}\n   */\n  public get isOpen(): boolean {\n    return !!this.dropdown.isOpen;\n  }\n\n  /**\n   * Represents the current date.\n   *\n   * @type {Date}\n   */\n  public today = new Date();\n\n  /**\n   * The filter function used to determine if a date should be included or excluded in the datepicker.\n   * If set to `null`, no filtering will be applied.\n   *\n   * @type {DateFilter | null}\n   * @default null\n   *\n   * @example\n   * ```ts\n   * // Excludes mondays from the datepicker.\n   * const filterFn: DateFilter = (date) => date.getDay() !== 1;\n   * ```\n   */\n  @Input()\n  public filterFn: DateFilter | null = null;\n\n  /**\n   * The minimum selectable date for the datepicker.\n   * If set to null, there is no minimum date restriction.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public minDate: Date | null = null;\n\n  /**\n   * The maximum selectable date for the datepicker.\n   * If set to null, there is no maximum date restriction.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public maxDate: Date | null = null;\n\n  /**\n   * The position of the dropdown relative to the input field.\n   *\n   * @type {Position}\n   * @default Position.BOTTOM\n   */\n  @Input()\n  public dropdownPosition: Position = 'bottom';\n\n  /**\n   * When set to true, the select will display a reset button.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  public clearable = input(false, { transform: booleanAttribute });\n\n  /**\n   * Emits the selected date when it changes.\n   *\n   * @emits {Date}\n   */\n  @Output()\n  public selectedChange = new EventEmitter<Date>();\n\n  /**\n   * The dropdown directive used in the datepicker component.\n   *\n   * @type {DropdownDirective}\n   */\n  @ViewChild(DropdownDirective)\n  public dropdown!: DropdownDirective;\n\n  /**\n   * The dropdown trigger element used in the datepicker component.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('dropdownTrigger', { read: ElementRef, static: true })\n  public dropdownTriggerElement!: ElementRef<HTMLElement>;\n\n  /**\n   * The date field input control directive used in the datepicker component.\n   *\n   * @type {DatepickerInputControlDirective | undefined}\n   */\n  @ContentChild(DatepickerInputControlDirective)\n  public dateField?: DatepickerInputControlDirective;\n\n  constructor() {\n    super(null);\n    detectControllerChanges(this).subscribe();\n  }\n\n  public ngAfterViewInit(): void {\n    this.handleDateFieldChanges();\n    this.handleDateFieldFocus();\n\n    deferFn(() => {\n      if (!this.value) return;\n      this.updateDateField(startOfDay(this.value));\n    });\n  }\n\n  /**\n   * Selects a date.\n   *\n   * @param {Date | null} value - The date value to be selected.\n   */\n  public selectDate(value: Date | null): void {\n    if (!value) return;\n\n    this.updateInternalValue(value);\n\n    this.selectedChange.emit(value);\n\n    this.dropdown.close();\n  }\n\n  /**\n   * Resets the datepicker's value to null.\n   */\n  public reset(): void {\n    this.updateInternalValue(null);\n  }\n\n  /**\n   * @internal\n   * Writes a new value to the element.\n   * Part of the ControlValueAccessor interface.\n   * @param {Date | null} value - The new value.\n   */\n  public override writeValue(value: Date | null): void {\n    super.writeValue(value);\n    this.updateDateField(value);\n  }\n\n  /**\n   * Opens the datepicker dropdown.\n   *\n   * @param {KeyboardEvent} event\n   */\n  @HostListener('keydown.alt.ArrowDown', ['$event'])\n  public openDatepicker(event?: KeyboardEvent) {\n    event?.stopPropagation();\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    this.dropdown.open(event);\n  }\n\n  protected updateInternalValue(value: Date | null): void {\n    this.updateValue(value);\n    this.updateDateField(value);\n  }\n\n  protected handleDateFieldChanges(): void {\n    this.dateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe(() => {\n      if (!this.dateField?.valueAsDate) return;\n      this.updateValue(this.dateField?.valueAsDate ?? null);\n    });\n  }\n\n  protected handleDateFieldFocus(): void {\n    this.dateField?.focused.pipe(this.takeUntilDestroyed()).subscribe((isFocused) => {\n      if (!isFocused) {\n        this.onTouched();\n      }\n      if (this.isOpen) {\n        this.dropdown.close();\n      }\n    });\n  }\n\n  private updateDateField(date: Date | null): void {\n    if (!this.dateField) return;\n\n    const dateFormat = getDateInputFormat(this.config);\n    this.dateField.nativeElementValue = date ? format(date, dateFormat) : '';\n  }\n}\n","<ng-content select=\"input[odxDatepickerControl]\" />\n\n<odx-action-group class=\"odx-datepicker__trigger-wrapper\">\n  @if (clearable() && value) {\n    <button odxButton class=\"odx-datepicker__clear\" (click)=\"reset()\" size=\"small\" aria-label=\"Reset time\">\n      <odx-icon name=\"close\" iconSet=\"core\" />\n    </button>\n  }\n  <button\n    #dropdownTrigger\n    odxButton\n    size=\"small\"\n    variant=\"ghost\"\n    class=\"odx-datepicker__trigger\"\n    [odxDropdown]=\"calendarOverlay\"\n    [odxDropdownOptions]=\"{ position: dropdownPosition }\"\n    [odxDropdownTriggerElement]=\"dropdownTriggerElement.nativeElement\"\n    [odxDropdownHost]=\"null\"\n    [odxDropdownReferenceElement]=\"element.nativeElement\"\n    (odxDropdownBeforeClose)=\"onTouched()\"\n  >\n    <odx-icon name=\"calendar\" />\n  </button>\n  <ng-content select=\"[odxButton]\" ngProjectAs=\"[odxButton]\" />\n</odx-action-group>\n\n<ng-template #calendarOverlay>\n  <odx-calendar\n    [selectedDate]=\"value || today\"\n    [filterFn]=\"filterFn\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    cdkTrapFocus\n    cdkTrapFocusAutoCapture\n    (selectedDateChange)=\"selectDate($event)\"\n  />\n</ng-template>\n"]}
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/datepicker/src/lib/datepicker.component.ts","../../../../../../../libs/angular/components/datepicker/src/lib/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  input,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { detectControllerChanges } from '@odx/angular';\nimport { CustomFormControl } from '@odx/angular/cdk/custom-form-control';\nimport { getDateInputFormat, getDateInputMask, initNgxMask, injectDateConfig } from '@odx/angular/cdk/date-input';\nimport { ActionGroupComponent } from '@odx/angular/components/action-group';\nimport { ButtonComponent } from '@odx/angular/components/button';\nimport { CalendarComponent, DateFilter } from '@odx/angular/components/calendar';\nimport { DropdownDirective, DropdownModule } from '@odx/angular/components/dropdown';\nimport { IconComponent } from '@odx/angular/components/icon';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn, injectElement, Position, untilDestroyed } from '@odx/angular/utils';\nimport { format, startOfDay } from 'date-fns';\nimport { DatepickerInputControlDirective } from './directives';\n\n/**\n * Represents a datepicker component for selecting a date.\n * Extends the `CustomFormControl` class and implements the `AfterViewInit` interface.\n *\n * @see {CustomFormControl}\n */\n@CSSComponent('datepicker')\n@Component({\n  selector: 'odx-datepicker',\n  standalone: true,\n  imports: [A11yModule, ActionGroupComponent, ButtonComponent, CalendarComponent, DropdownModule, IconComponent],\n  templateUrl: './datepicker.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DatepickerComponent extends CustomFormControl<Date | null> implements AfterViewInit {\n  protected readonly takeUntilDestroyed = untilDestroyed();\n\n  protected readonly config = injectDateConfig();\n\n  public readonly element = injectElement();\n\n  /**\n   * Gets a value indicating whether the datepicker is currently open.\n   *\n   * @returns {boolean}\n   */\n  public get isOpen(): boolean {\n    return !!this.dropdown.isOpen;\n  }\n\n  /**\n   * Represents the current date.\n   *\n   * @type {Date}\n   */\n  public today = new Date();\n\n  /**\n   * The filter function used to determine if a date should be included or excluded in the datepicker.\n   * If set to `null`, no filtering will be applied.\n   *\n   * @type {DateFilter | null}\n   * @default null\n   *\n   * @example\n   * ```ts\n   * // Excludes mondays from the datepicker.\n   * const filterFn: DateFilter = (date) => date.getDay() !== 1;\n   * ```\n   */\n  @Input()\n  public filterFn: DateFilter | null = null;\n\n  /**\n   * The minimum selectable date for the datepicker.\n   * If set to null, there is no minimum date restriction.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public minDate: Date | null = null;\n\n  /**\n   * The maximum selectable date for the datepicker.\n   * If set to null, there is no maximum date restriction.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public maxDate: Date | null = null;\n\n  /**\n   * The position of the dropdown relative to the input field.\n   *\n   * @type {Position}\n   * @default Position.BOTTOM\n   */\n  @Input()\n  public dropdownPosition: Position = 'bottom';\n\n  /**\n   * When set to true, the select will display a reset button.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  public clearable = input(false, { transform: booleanAttribute });\n\n  /**\n   * Emits the selected date when it changes.\n   *\n   * @emits {Date}\n   */\n  @Output()\n  public selectedChange = new EventEmitter<Date>();\n\n  /**\n   * The dropdown directive used in the datepicker component.\n   *\n   * @type {DropdownDirective}\n   */\n  @ViewChild(DropdownDirective)\n  public dropdown!: DropdownDirective;\n\n  /**\n   * The dropdown trigger element used in the datepicker component.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('dropdownTrigger', { read: ElementRef, static: true })\n  public dropdownTriggerElement!: ElementRef<HTMLElement>;\n\n  /**\n   * The date field input control directive used in the datepicker component.\n   *\n   * @type {DatepickerInputControlDirective | undefined}\n   */\n  @ContentChild(DatepickerInputControlDirective)\n  public dateField?: DatepickerInputControlDirective;\n\n  constructor() {\n    super(null);\n    detectControllerChanges(this).subscribe();\n  }\n\n  public ngAfterViewInit(): void {\n    this.handleDateFieldChanges();\n    this.handleDateFieldFocus();\n\n    deferFn(() => {\n      if (!this.value) return;\n      this.updateDateField(startOfDay(this.value));\n    });\n  }\n\n  /**\n   * Selects a date.\n   *\n   * @param {Date | null} value - The date value to be selected.\n   */\n  public selectDate(value: Date | null): void {\n    if (!value) return;\n\n    this.updateInternalValue(value);\n\n    this.selectedChange.emit(value);\n\n    this.dropdown.close();\n  }\n\n  /**\n   * Resets the datepicker's value to null.\n   */\n  public reset(): void {\n    this.updateInternalValue(null);\n  }\n\n  /**\n   * @internal\n   * Writes a new value to the element.\n   * Part of the ControlValueAccessor interface.\n   * @param {Date | null} value - The new value.\n   */\n  public override writeValue(value: Date | null): void {\n    super.writeValue(value);\n    this.updateDateField(value);\n  }\n\n  /**\n   * Opens the datepicker dropdown.\n   *\n   * @param {KeyboardEvent} event\n   */\n  @HostListener('keydown.alt.ArrowDown', ['$event'])\n  public openDatepicker(event?: KeyboardEvent) {\n    event?.stopPropagation();\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    this.dropdown.open(event);\n  }\n\n  protected updateInternalValue(value: Date | null): void {\n    this.updateValue(value);\n    this.updateDateField(value);\n  }\n\n  protected handleDateFieldChanges(): void {\n    initNgxMask(this.dateField?.ngxMaskDirective, getDateInputMask(this.config));\n    this.dateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe(() => {\n      if (!this.dateField?.valueAsDate) return;\n      this.updateValue(this.dateField?.valueAsDate ?? null);\n    });\n  }\n\n  protected handleDateFieldFocus(): void {\n    this.dateField?.focused.pipe(this.takeUntilDestroyed()).subscribe((isFocused) => {\n      if (!isFocused) {\n        this.onTouched();\n      }\n      if (this.isOpen) {\n        this.dropdown.close();\n      }\n    });\n  }\n\n  private updateDateField(date: Date | null): void {\n    if (!this.dateField) return;\n\n    const dateFormat = getDateInputFormat(this.config);\n    this.dateField.nativeElementValue = date ? format(date, dateFormat) : '';\n  }\n}\n","<ng-content select=\"input[odxDatepickerControl]\" />\n\n<odx-action-group class=\"odx-datepicker__trigger-wrapper\">\n  @if (clearable() && value) {\n    <button odxButton class=\"odx-datepicker__clear\" (click)=\"reset()\" size=\"small\" aria-label=\"Reset time\">\n      <odx-icon name=\"close\" iconSet=\"core\" />\n    </button>\n  }\n  <button\n    #dropdownTrigger\n    odxButton\n    size=\"small\"\n    variant=\"ghost\"\n    class=\"odx-datepicker__trigger\"\n    [odxDropdown]=\"calendarOverlay\"\n    [odxDropdownOptions]=\"{ position: dropdownPosition }\"\n    [odxDropdownTriggerElement]=\"dropdownTriggerElement.nativeElement\"\n    [odxDropdownHost]=\"null\"\n    [odxDropdownReferenceElement]=\"element.nativeElement\"\n    (odxDropdownBeforeClose)=\"onTouched()\"\n  >\n    <odx-icon name=\"calendar\" />\n  </button>\n  <ng-content select=\"[odxButton]\" ngProjectAs=\"[odxButton]\" />\n</odx-action-group>\n\n<ng-template #calendarOverlay>\n  <odx-calendar\n    [selectedDate]=\"value || today\"\n    [filterFn]=\"filterFn\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    cdkTrapFocus\n    cdkTrapFocusAutoCapture\n    (selectedDateChange)=\"selectDate($event)\"\n  />\n</ng-template>\n"]}
|
|
@@ -2,12 +2,12 @@ import { __decorate } from "tslib";
|
|
|
2
2
|
import { Directive, EventEmitter, HostListener, inject, Output } from '@angular/core';
|
|
3
3
|
import { ReadonlyController, WithTabIndex } from '@odx/angular';
|
|
4
4
|
import { InputControlDirective } from '@odx/angular/cdk/custom-form-control';
|
|
5
|
-
import { getDateInputFormat,
|
|
5
|
+
import { getDateInputFormat, getDateInputValueAsDate, injectDateConfig } from '@odx/angular/cdk/date-input';
|
|
6
6
|
import { CSSComponent } from '@odx/angular/internal';
|
|
7
|
-
import {
|
|
8
|
-
import { distinctUntilChanged, fromEvent, map, tap } from 'rxjs';
|
|
7
|
+
import { NgxMaskDirective, provideNgxMask } from 'ngx-mask';
|
|
9
8
|
import * as i0 from "@angular/core";
|
|
10
9
|
import * as i1 from "@odx/angular";
|
|
10
|
+
import * as i2 from "ngx-mask";
|
|
11
11
|
/**
|
|
12
12
|
* A directive to enhance an input element as part of a datepicker control. It applies date input formatting,
|
|
13
13
|
* mask handling, and emits focus events. This directive integrates with ngx-mask to handle input masking and
|
|
@@ -21,30 +21,15 @@ import * as i1 from "@odx/angular";
|
|
|
21
21
|
let DatepickerInputControlDirective = class DatepickerInputControlDirective extends InputControlDirective {
|
|
22
22
|
constructor() {
|
|
23
23
|
super(...arguments);
|
|
24
|
-
this.maskConfig = { validation: false, leadZeroDateTime: true };
|
|
25
24
|
this.readonlyController = ReadonlyController.inject();
|
|
26
25
|
this.config = injectDateConfig();
|
|
27
|
-
this.
|
|
28
|
-
this.ngxMaskPipe = inject(NgxMaskPipe);
|
|
26
|
+
this.ngxMaskDirective = inject(NgxMaskDirective);
|
|
29
27
|
/**
|
|
30
28
|
* Emits an event when the input field receives focus or loses focus, indicating the focus state.
|
|
31
29
|
*
|
|
32
30
|
* @emits {boolean} - Indicates whether the input field is focused.
|
|
33
31
|
*/
|
|
34
32
|
this.focused = new EventEmitter();
|
|
35
|
-
/**
|
|
36
|
-
* Observable stream capturing and processing input events on the native element, applying the mask,
|
|
37
|
-
* and emitting the current value.
|
|
38
|
-
*
|
|
39
|
-
* @emits {string} - The current value of the input field.
|
|
40
|
-
*/
|
|
41
|
-
this.valueChange$ = fromEvent(this.element.nativeElement, 'input').pipe(distinctUntilChanged(), tap(() => this.applyMask()), map(() => this.nativeElementValue));
|
|
42
|
-
}
|
|
43
|
-
/**
|
|
44
|
-
* Applies the configured input mask to the native element's value.
|
|
45
|
-
*/
|
|
46
|
-
applyMask() {
|
|
47
|
-
this.nativeElementValue = this.ngxMaskPipe.transform(this.nativeElementValue, this.inputMask, this.maskConfig);
|
|
48
33
|
}
|
|
49
34
|
/**
|
|
50
35
|
* Gets the current value of the input field as a `Date` object, based on the date format from the datepicker
|
|
@@ -71,7 +56,7 @@ let DatepickerInputControlDirective = class DatepickerInputControlDirective exte
|
|
|
71
56
|
this.focused.emit(false);
|
|
72
57
|
}
|
|
73
58
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatepickerInputControlDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
74
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DatepickerInputControlDirective, isStandalone: true, selector: "input[odxDatepickerControl]", outputs: { focused: "focused" }, host: { listeners: { "focusin": "handleFocusIn()", "focusout": "handleFocusOut()" }, properties: { "attr.readonly": "readonlyController?.readonly || null", "attr.placeholder": "placeholder" } }, providers: [ReadonlyController.connect(), provideNgxMask(
|
|
59
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DatepickerInputControlDirective, isStandalone: true, selector: "input[odxDatepickerControl]", outputs: { focused: "focused" }, host: { listeners: { "focusin": "handleFocusIn()", "focusout": "handleFocusOut()" }, properties: { "attr.readonly": "readonlyController?.readonly || null", "attr.placeholder": "placeholder" } }, providers: [ReadonlyController.connect(), provideNgxMask({ validation: false, leadZeroDateTime: true })], usesInheritance: true, hostDirectives: [{ directive: i1.WithTabIndex }, { directive: i2.NgxMaskDirective }], ngImport: i0 }); }
|
|
75
60
|
};
|
|
76
61
|
DatepickerInputControlDirective = __decorate([
|
|
77
62
|
CSSComponent('datepicker__control')
|
|
@@ -86,8 +71,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
86
71
|
'[attr.readonly]': 'readonlyController?.readonly || null',
|
|
87
72
|
'[attr.placeholder]': 'placeholder',
|
|
88
73
|
},
|
|
89
|
-
providers: [ReadonlyController.connect(), provideNgxMask(
|
|
90
|
-
hostDirectives: [WithTabIndex],
|
|
74
|
+
providers: [ReadonlyController.connect(), provideNgxMask({ validation: false, leadZeroDateTime: true })],
|
|
75
|
+
hostDirectives: [WithTabIndex, NgxMaskDirective],
|
|
91
76
|
}]
|
|
92
77
|
}], propDecorators: { focused: [{
|
|
93
78
|
type: Output
|
|
@@ -98,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
98
83
|
type: HostListener,
|
|
99
84
|
args: ['focusout']
|
|
100
85
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1pbnB1dC1jb250cm9sLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jb21wb25lbnRzL2RhdGVwaWNrZXIvc3JjL2xpYi9kaXJlY3RpdmVzL2RhdGVwaWNrZXItaW5wdXQtY29udHJvbC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxZQUFZLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDaEUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLHVCQUF1QixFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDNUcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3JELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxjQUFjLEVBQUUsTUFBTSxVQUFVLENBQUM7Ozs7QUFFNUQ7Ozs7Ozs7OztHQVNHO0FBWUksSUFBTSwrQkFBK0IsR0FBckMsTUFBTSwrQkFBZ0MsU0FBUSxxQkFBcUI7SUFBbkU7O1FBQ2MsdUJBQWtCLEdBQUcsa0JBQWtCLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDakQsV0FBTSxHQUFHLGdCQUFnQixFQUFFLENBQUM7UUFDL0IscUJBQWdCLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFFNUQ7Ozs7V0FJRztRQUVJLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO0tBK0I5QztJQTdCQzs7Ozs7T0FLRztJQUNILElBQVcsV0FBVztRQUNwQixPQUFPLHVCQUF1QixDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDdkUsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsSUFBVyxXQUFXO1FBQ3BCLE9BQU8sa0JBQWtCLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3ZELENBQUM7SUFHUyxhQUFhO1FBQ3JCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzFCLENBQUM7SUFHUyxjQUFjO1FBQ3RCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzNCLENBQUM7K0dBekNVLCtCQUErQjttR0FBL0IsK0JBQStCLDhTQUgvQixDQUFDLGtCQUFrQixDQUFDLE9BQU8sRUFBRSxFQUFFLGNBQWMsQ0FBQyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQzs7QUFHN0YsK0JBQStCO0lBWDNDLFlBQVksQ0FBQyxxQkFBcUIsQ0FBQztHQVd2QiwrQkFBK0IsQ0EwQzNDOzs0RkExQ1ksK0JBQStCO2tCQVYzQyxTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsNkJBQTZCO29CQUN2QyxJQUFJLEVBQUU7d0JBQ0osaUJBQWlCLEVBQUUsc0NBQXNDO3dCQUN6RCxvQkFBb0IsRUFBRSxhQUFhO3FCQUNwQztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLEVBQUUsRUFBRSxjQUFjLENBQUMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLGdCQUFnQixFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7b0JBQ3hHLGNBQWMsRUFBRSxDQUFDLFlBQVksRUFBRSxnQkFBZ0IsQ0FBQztpQkFDakQ7OEJBWVEsT0FBTztzQkFEYixNQUFNO2dCQXdCRyxhQUFhO3NCQUR0QixZQUFZO3VCQUFDLFNBQVM7Z0JBTWIsY0FBYztzQkFEdkIsWUFBWTt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFdmVudEVtaXR0ZXIsIEhvc3RMaXN0ZW5lciwgaW5qZWN0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJlYWRvbmx5Q29udHJvbGxlciwgV2l0aFRhYkluZGV4IH0gZnJvbSAnQG9keC9hbmd1bGFyJztcbmltcG9ydCB7IElucHV0Q29udHJvbERpcmVjdGl2ZSB9IGZyb20gJ0BvZHgvYW5ndWxhci9jZGsvY3VzdG9tLWZvcm0tY29udHJvbCc7XG5pbXBvcnQgeyBnZXREYXRlSW5wdXRGb3JtYXQsIGdldERhdGVJbnB1dFZhbHVlQXNEYXRlLCBpbmplY3REYXRlQ29uZmlnIH0gZnJvbSAnQG9keC9hbmd1bGFyL2Nkay9kYXRlLWlucHV0JztcbmltcG9ydCB7IENTU0NvbXBvbmVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9pbnRlcm5hbCc7XG5pbXBvcnQgeyBOZ3hNYXNrRGlyZWN0aXZlLCBwcm92aWRlTmd4TWFzayB9IGZyb20gJ25neC1tYXNrJztcblxuLyoqXG4gKiBBIGRpcmVjdGl2ZSB0byBlbmhhbmNlIGFuIGlucHV0IGVsZW1lbnQgYXMgcGFydCBvZiBhIGRhdGVwaWNrZXIgY29udHJvbC4gSXQgYXBwbGllcyBkYXRlIGlucHV0IGZvcm1hdHRpbmcsXG4gKiBtYXNrIGhhbmRsaW5nLCBhbmQgZW1pdHMgZm9jdXMgZXZlbnRzLiBUaGlzIGRpcmVjdGl2ZSBpbnRlZ3JhdGVzIHdpdGggbmd4LW1hc2sgdG8gaGFuZGxlIGlucHV0IG1hc2tpbmcgYW5kXG4gKiBlbnN1cmVzIHRoYXQgdGhlIGlucHV0IGNvbXBsaWVzIHdpdGggdGhlIGRhdGUgZm9ybWF0IHNwZWNpZmllZCBpbiB0aGUgZGF0ZXBpY2tlciBjb25maWd1cmF0aW9uLlxuICogRXh0ZW5kcyB0aGUgYElucHV0Q29udHJvbERpcmVjdGl2ZWAgdG8gcHJvdmlkZSBpbnB1dCBjb250cm9sIGZ1bmN0aW9uYWxpdHkuXG4gKiBIYXMgaG9zdCBkaXJlY3RpdmUgYFdpdGhUYWJJbmRleGAgdG8gbWFuYWdlIHRoZSB0YWJpbmRleCBhdHRyaWJ1dGUgb2YgdGhlIGlucHV0IGVsZW1lbnQuXG4gKlxuICogQHNlZSB7SW5wdXRDb250cm9sRGlyZWN0aXZlfVxuICogQHNlZSB7V2l0aFRhYkluZGV4fVxuICovXG5AQ1NTQ29tcG9uZW50KCdkYXRlcGlja2VyX19jb250cm9sJylcbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ2lucHV0W29keERhdGVwaWNrZXJDb250cm9sXScsXG4gIGhvc3Q6IHtcbiAgICAnW2F0dHIucmVhZG9ubHldJzogJ3JlYWRvbmx5Q29udHJvbGxlcj8ucmVhZG9ubHkgfHwgbnVsbCcsXG4gICAgJ1thdHRyLnBsYWNlaG9sZGVyXSc6ICdwbGFjZWhvbGRlcicsXG4gIH0sXG4gIHByb3ZpZGVyczogW1JlYWRvbmx5Q29udHJvbGxlci5jb25uZWN0KCksIHByb3ZpZGVOZ3hNYXNrKHsgdmFsaWRhdGlvbjogZmFsc2UsIGxlYWRaZXJvRGF0ZVRpbWU6IHRydWUgfSldLFxuICBob3N0RGlyZWN0aXZlczogW1dpdGhUYWJJbmRleCwgTmd4TWFza0RpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIERhdGVwaWNrZXJJbnB1dENvbnRyb2xEaXJlY3RpdmUgZXh0ZW5kcyBJbnB1dENvbnRyb2xEaXJlY3RpdmUge1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgcmVhZG9ubHlDb250cm9sbGVyID0gUmVhZG9ubHlDb250cm9sbGVyLmluamVjdCgpO1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgY29uZmlnID0gaW5qZWN0RGF0ZUNvbmZpZygpO1xuICBwdWJsaWMgcmVhZG9ubHkgbmd4TWFza0RpcmVjdGl2ZSA9IGluamVjdChOZ3hNYXNrRGlyZWN0aXZlKTtcblxuICAvKipcbiAgICogRW1pdHMgYW4gZXZlbnQgd2hlbiB0aGUgaW5wdXQgZmllbGQgcmVjZWl2ZXMgZm9jdXMgb3IgbG9zZXMgZm9jdXMsIGluZGljYXRpbmcgdGhlIGZvY3VzIHN0YXRlLlxuICAgKlxuICAgKiBAZW1pdHMge2Jvb2xlYW59IC0gSW5kaWNhdGVzIHdoZXRoZXIgdGhlIGlucHV0IGZpZWxkIGlzIGZvY3VzZWQuXG4gICAqL1xuICBAT3V0cHV0KClcbiAgcHVibGljIGZvY3VzZWQgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XG5cbiAgLyoqXG4gICAqIEdldHMgdGhlIGN1cnJlbnQgdmFsdWUgb2YgdGhlIGlucHV0IGZpZWxkIGFzIGEgYERhdGVgIG9iamVjdCwgYmFzZWQgb24gdGhlIGRhdGUgZm9ybWF0IGZyb20gdGhlIGRhdGVwaWNrZXJcbiAgICogY29uZmlndXJhdGlvbi5cbiAgICpcbiAgICogQHJldHVybnMge0RhdGUgfCBudWxsfSAtIFRoZSBjdXJyZW50IHZhbHVlIG9mIHRoZSBpbnB1dCBmaWVsZCBhcyBhIGBEYXRlYCBvYmplY3QsIG9yIGBudWxsYCBpZiB0aGUgdmFsdWUgaXMgaW52YWxpZC5cbiAgICovXG4gIHB1YmxpYyBnZXQgdmFsdWVBc0RhdGUoKTogRGF0ZSB8IG51bGwge1xuICAgIHJldHVybiBnZXREYXRlSW5wdXRWYWx1ZUFzRGF0ZSh0aGlzLmNvbmZpZywgdGhpcy5uYXRpdmVFbGVtZW50VmFsdWUpO1xuICB9XG5cbiAgLyoqXG4gICAqIENvbXB1dGVzIHRoZSBwbGFjZWhvbGRlciB0ZXh0IGZvciB0aGUgaW5wdXQgYmFzZWQgb24gdGhlIGRhdGUgZm9ybWF0IGZyb21cbiAgICogdGhlIGRhdGVwaWNrZXIgY29uZmlndXJhdGlvbi5cbiAgICpcbiAgICogQHJldHVybnMge3N0cmluZ30gLSBUaGUgcGxhY2Vob2xkZXIgdGV4dCwgdHlwaWNhbGx5IHRoZSBkYXRlIGZvcm1hdCBpbiB1cHBlcmNhc2UuXG4gICAqL1xuICBwdWJsaWMgZ2V0IHBsYWNlaG9sZGVyKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGdldERhdGVJbnB1dEZvcm1hdCh0aGlzLmNvbmZpZykudG9VcHBlckNhc2UoKTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2ZvY3VzaW4nKVxuICBwcm90ZWN0ZWQgaGFuZGxlRm9jdXNJbigpOiB2b2lkIHtcbiAgICB0aGlzLmZvY3VzZWQuZW1pdCh0cnVlKTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2ZvY3Vzb3V0JylcbiAgcHJvdGVjdGVkIGhhbmRsZUZvY3VzT3V0KCk6IHZvaWQge1xuICAgIHRoaXMuZm9jdXNlZC5lbWl0KGZhbHNlKTtcbiAgfVxufVxuIl19
|
|
@@ -3,7 +3,7 @@ import { A11yModule } from '@angular/cdk/a11y';
|
|
|
3
3
|
import { booleanAttribute, ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, HostListener, input, Input, Output, QueryList, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
4
4
|
import { detectControllerChanges } from '@odx/angular';
|
|
5
5
|
import { CustomFormControl } from '@odx/angular/cdk/custom-form-control';
|
|
6
|
-
import { getDateInputFormat, injectDateConfig } from '@odx/angular/cdk/date-input';
|
|
6
|
+
import { getDateInputFormat, getDateInputMask, initNgxMask, injectDateConfig } from '@odx/angular/cdk/date-input';
|
|
7
7
|
import { ActionGroupComponent } from '@odx/angular/components/action-group';
|
|
8
8
|
import { ButtonComponent } from '@odx/angular/components/button';
|
|
9
9
|
import { CalendarComponent, CalendarSelectionMode, provideCalendarConfig } from '@odx/angular/components/calendar';
|
|
@@ -166,6 +166,8 @@ let DaterangepickerComponent = class DaterangepickerComponent extends CustomForm
|
|
|
166
166
|
this.updateEndDateField(value.end);
|
|
167
167
|
}
|
|
168
168
|
handleDateFieldChanges() {
|
|
169
|
+
initNgxMask(this.startDateField?.ngxMaskDirective, getDateInputMask(this.config));
|
|
170
|
+
initNgxMask(this.endDateField?.ngxMaskDirective, getDateInputMask(this.config));
|
|
169
171
|
this.startDateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe((value) => {
|
|
170
172
|
this.updateWidth(this.startDateField, this.startDateMirror, value);
|
|
171
173
|
this.updateValue({ start: this.startDateField?.valueAsDate ?? null, end: this.endDateField?.valueAsDate ?? null });
|
|
@@ -274,4 +276,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
274
276
|
type: HostListener,
|
|
275
277
|
args: ['keydown.alt.ArrowDown', ['$event']]
|
|
276
278
|
}] } });
|
|
277
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daterangepicker.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/daterangepicker/src/lib/daterangepicker.component.ts","../../../../../../../libs/angular/components/daterangepicker/src/lib/daterangepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  input,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { detectControllerChanges } from '@odx/angular';\nimport { CustomFormControl } from '@odx/angular/cdk/custom-form-control';\nimport { getDateInputFormat, injectDateConfig } from '@odx/angular/cdk/date-input';\nimport { ActionGroupComponent } from '@odx/angular/components/action-group';\nimport { ButtonComponent } from '@odx/angular/components/button';\nimport { CalendarComponent, CalendarSelectionMode, DateFilter, DateRange, provideCalendarConfig } from '@odx/angular/components/calendar';\nimport { DropdownDirective, DropdownModule } from '@odx/angular/components/dropdown';\nimport { IconComponent } from '@odx/angular/components/icon';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn, injectElement, Position, untilDestroyed } from '@odx/angular/utils';\nimport { format, startOfDay } from 'date-fns';\nimport { DaterangepickerInputControlDirective } from './directives';\n\n/**\n * A component for selecting a date range, integrated with dropdowns and input fields for start and end dates.\n * It supports custom configurations for minimum, maximum dates, and date filters. The component also handles\n * the dropdown's behavior for date selection and applies date formats automatically based on configuration.\n * The component extends the `CustomFormControl` class to provide form control functionality.\n *\n * @see {CustomFormControl}\n */\n@CSSComponent('daterangepicker')\n@Component({\n  selector: 'odx-daterangepicker',\n  standalone: true,\n  imports: [A11yModule, ActionGroupComponent, ButtonComponent, CalendarComponent, DropdownModule, IconComponent],\n  templateUrl: './daterangepicker.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    provideCalendarConfig({\n      displayAdjacentDays: false,\n      selectionMode: CalendarSelectionMode.DateRange,\n    }),\n  ],\n})\nexport class DaterangepickerComponent extends CustomFormControl<DateRange | null> implements AfterViewInit {\n  protected readonly takeUntilDestroyed = untilDestroyed();\n\n  protected readonly config = injectDateConfig();\n\n  public readonly element = injectElement();\n\n  /**\n   * Indicates whether the dropdown part of the date range picker is open.\n   *\n   * @type {boolean}\n   */\n  public get isOpen(): boolean {\n    return !!this.dropdown.isOpen;\n  }\n\n  /**\n   * Represents today's date, used for default selections and validations.\n   *\n   * @type {Date}\n   */\n  public today = new Date();\n\n  /**\n   * A function that defines additional rules for disabled dates within the picker.\n   *\n   * @type {DateFilter | null}\n   * @default null\n   *\n   * @example\n   * ```ts\n   * // Disables all Wednesdays in the picker.\n   * const filterFn: DateFilter = (date: Date) => date.getDay() !== 3;\n   * ```\n   */\n  @Input()\n  public filterFn: DateFilter | null = null;\n\n  /**\n   * The earliest date that can be selected in the picker.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public minDate: Date | null = null;\n\n  /**\n   * The latest date that can be selected in the picker.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public maxDate: Date | null = null;\n\n  /**\n   * Position of the dropdown relative to the input fields.\n   *\n   * @type {Position}\n   * @default Position.BOTTOM\n   */\n  @Input()\n  public dropdownPosition: Position = 'bottom';\n\n  /**\n   * When set to true, the select will display a reset button.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  public clearable = input(false, { transform: booleanAttribute });\n\n  /**\n   * Emits the selected date range when it changes.\n   *\n   * @emits {DateRange}\n   */\n  @Output()\n  public selectedChange = new EventEmitter<DateRange>();\n\n  /**\n   * Directive managing the dropdown functionality.\n   *\n   * @type {DropdownDirective}\n   */\n  @ViewChild(DropdownDirective)\n  public dropdown!: DropdownDirective;\n\n  /**\n   * Reference to the element triggering the dropdown.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('dropdownTrigger', { read: ElementRef, static: true })\n  public dropdownTriggerElement!: ElementRef<HTMLElement>;\n\n  /**\n   * Query list of the input controls within the date range picker.\n   *\n   * @type {QueryList<DaterangepickerInputControlDirective>}\n   */\n  @ContentChildren(DaterangepickerInputControlDirective)\n  public dateFields!: QueryList<DaterangepickerInputControlDirective>;\n\n  /**\n   * Reference to the element mirroring the start date input field.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('startDateMirror', { read: ElementRef, static: true })\n  public startDateMirror!: ElementRef<HTMLElement>;\n\n  /**\n   * Reference to the element mirroring the end date input field.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('endDateMirror', { read: ElementRef, static: true })\n  public endDateMirror!: ElementRef<HTMLElement>;\n\n  /**\n   * The input control for the start date.\n   *\n   * @type {DaterangepickerInputControlDirective | undefined}\n   */\n  public get startDateField(): DaterangepickerInputControlDirective | undefined {\n    const [startDate, _endDate] = this.dateFields;\n    return startDate;\n  }\n\n  /**\n   * The input control for the end date.\n   *\n   * @type {DaterangepickerInputControlDirective | undefined}\n   */\n  public get endDateField(): DaterangepickerInputControlDirective | undefined {\n    const [_startDate, endDate] = this.dateFields;\n    return endDate;\n  }\n\n  constructor() {\n    super(null);\n    detectControllerChanges(this).subscribe();\n  }\n\n  public ngAfterViewInit(): void {\n    this.updateWidth(this.startDateField, this.startDateMirror);\n    this.updateWidth(this.endDateField, this.endDateMirror);\n    this.handleDateFieldChanges();\n    this.handleDateFieldFocus();\n    this.updateInputFields();\n  }\n\n  /**\n   * Selects a date range, updates the form value, and emits the selected range.\n   *\n   * @param {DateRange | null} value - The date range to select.\n   */\n  public selectDateRange(value: DateRange | null): void {\n    if (!value || !value.start || !value.end) return;\n\n    this.updateInternalValue(value);\n\n    this.selectedChange.emit(value);\n    this.dropdown.close();\n  }\n\n  /**\n   * Resets the daterangepicker's value to an empty date range (both start and end as null).\n   */\n  public reset(): void {\n    this.updateInternalValue({ start: null, end: null });\n  }\n\n  /**\n   * @internal\n   * Writes a new value to the element.\n   * Part of the ControlValueAccessor interface.\n   * @param {DateRange | null} value - The new date range value.\n   */\n  public override writeValue(value: DateRange | null): void {\n    super.writeValue(value);\n    this.updateInputFields();\n  }\n\n  /**\n   * Opens the date range picker dropdown.\n   *\n   * @param {KeyboardEvent} event\n   */\n  @HostListener('keydown.alt.ArrowDown', ['$event'])\n  public openDaterangepicker(event?: KeyboardEvent) {\n    event?.stopPropagation();\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    this.dropdown.open(event);\n  }\n\n  protected isEmpty(value: DateRange | null): boolean {\n    return !value || !value.start || !value.end;\n  }\n\n  protected updateInternalValue(value: DateRange): void {\n    this.updateValue(value);\n    this.updateStartDateField(value.start);\n    this.updateEndDateField(value.end);\n  }\n\n  protected handleDateFieldChanges(): void {\n    this.startDateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe((value) => {\n      this.updateWidth(this.startDateField, this.startDateMirror, value);\n      this.updateValue({ start: this.startDateField?.valueAsDate ?? null, end: this.endDateField?.valueAsDate ?? null });\n    });\n    this.endDateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe((value) => {\n      this.updateWidth(this.endDateField, this.endDateMirror, value);\n      this.updateValue({ start: this.startDateField?.valueAsDate ?? null, end: this.endDateField?.valueAsDate ?? null });\n    });\n  }\n\n  protected updateWidth(target: DaterangepickerInputControlDirective | undefined, source: ElementRef<HTMLElement>, value = ''): void {\n    const compensationPx = 2;\n    source.nativeElement.textContent = value || target?.placeholder || null;\n    if (target) {\n      deferFn(() => (target.element.nativeElement.style.width = `${source.nativeElement.offsetWidth + compensationPx}px`));\n    }\n  }\n\n  protected handleDateFieldFocus(): void {\n    this.startDateField?.focused.pipe(this.takeUntilDestroyed()).subscribe((isFocused) => {\n      if (!isFocused) {\n        this.onTouched();\n      }\n      if (this.isOpen) {\n        this.dropdown.close();\n      }\n    });\n    this.endDateField?.focused.pipe(this.takeUntilDestroyed()).subscribe((isFocused) => {\n      if (!isFocused) {\n        this.onTouched();\n      }\n      if (this.isOpen) {\n        this.dropdown.close();\n      }\n    });\n  }\n\n  private updateStartDateField(date: Date | null): void {\n    if (!this.startDateField) return;\n\n    const dateFormat = getDateInputFormat(this.config);\n    this.startDateField.nativeElementValue = date ? format(date, dateFormat) : '';\n    this.updateWidth(this.startDateField, this.startDateMirror, date ? format(date, dateFormat) : '');\n  }\n\n  private updateEndDateField(date: Date | null): void {\n    if (!this.endDateField) return;\n\n    const dateFormat = getDateInputFormat(this.config);\n    this.endDateField.nativeElementValue = date ? format(date, dateFormat) : '';\n    this.updateWidth(this.endDateField, this.endDateMirror, date ? format(date, dateFormat) : '');\n  }\n\n  private updateInputFields(): void {\n    deferFn(() => {\n      if (this.value === null) return this.reset();\n      if (!this.value || !this.value.start || !this.value.end) return;\n      this.updateStartDateField(startOfDay(this.value.start));\n      this.updateEndDateField(startOfDay(this.value.end));\n    });\n  }\n}\n","<span #startDateMirror role=\"none\" class=\"odx-daterangepicker__mirror\"></span>\n<ng-content select=\"input[odxDaterangepickerStartDateControl]\" />\n<span role=\"none\" class=\"odx-daterangepicker__separator\">–</span>\n<span #endDateMirror role=\"none\" class=\"odx-daterangepicker__mirror\"></span>\n<ng-content select=\"input[odxDaterangepickerEndDateControl]\" />\n\n<odx-action-group class=\"odx-daterangepicker__trigger-wrapper\">\n  @if (clearable() && !isEmpty(value)) {\n    <button class=\"odx-daterangepicker__clear\" (click)=\"reset()\" odxButton size=\"small\" aria-label=\"Reset time\">\n      <odx-icon name=\"close\" iconSet=\"core\" />\n    </button>\n  }\n  <button\n    #dropdownTrigger\n    odxButton\n    size=\"small\"\n    variant=\"ghost\"\n    class=\"odx-daterangepicker__trigger\"\n    [odxDropdown]=\"calendarOverlay\"\n    [odxDropdownOptions]=\"{ position: dropdownPosition }\"\n    [odxDropdownTriggerElement]=\"dropdownTriggerElement.nativeElement\"\n    [odxDropdownHost]=\"null\"\n    [odxDropdownReferenceElement]=\"element.nativeElement\"\n    (odxDropdownBeforeClose)=\"onTouched()\"\n  >\n    <odx-icon name=\"calendar\" />\n  </button>\n  <ng-content select=\"[odxButton]\" ngProjectAs=\"[odxButton]\" />\n</odx-action-group>\n\n<ng-template #calendarOverlay>\n  <odx-calendar\n    [selectedDate]=\"today\"\n    [selectedDateRange]=\"value\"\n    (selectedDateRangeChange)=\"selectDateRange($event)\"\n    [filterFn]=\"filterFn\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    cdkTrapFocus\n    cdkTrapFocusAutoCapture\n  />\n</ng-template>\n"]}
|
|
279
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daterangepicker.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/daterangepicker/src/lib/daterangepicker.component.ts","../../../../../../../libs/angular/components/daterangepicker/src/lib/daterangepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  input,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { detectControllerChanges } from '@odx/angular';\nimport { CustomFormControl } from '@odx/angular/cdk/custom-form-control';\nimport { getDateInputFormat, getDateInputMask, initNgxMask, injectDateConfig } from '@odx/angular/cdk/date-input';\nimport { ActionGroupComponent } from '@odx/angular/components/action-group';\nimport { ButtonComponent } from '@odx/angular/components/button';\nimport { CalendarComponent, CalendarSelectionMode, DateFilter, DateRange, provideCalendarConfig } from '@odx/angular/components/calendar';\nimport { DropdownDirective, DropdownModule } from '@odx/angular/components/dropdown';\nimport { IconComponent } from '@odx/angular/components/icon';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn, injectElement, Position, untilDestroyed } from '@odx/angular/utils';\nimport { format, startOfDay } from 'date-fns';\nimport { DaterangepickerInputControlDirective } from './directives';\n\n/**\n * A component for selecting a date range, integrated with dropdowns and input fields for start and end dates.\n * It supports custom configurations for minimum, maximum dates, and date filters. The component also handles\n * the dropdown's behavior for date selection and applies date formats automatically based on configuration.\n * The component extends the `CustomFormControl` class to provide form control functionality.\n *\n * @see {CustomFormControl}\n */\n@CSSComponent('daterangepicker')\n@Component({\n  selector: 'odx-daterangepicker',\n  standalone: true,\n  imports: [A11yModule, ActionGroupComponent, ButtonComponent, CalendarComponent, DropdownModule, IconComponent],\n  templateUrl: './daterangepicker.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    provideCalendarConfig({\n      displayAdjacentDays: false,\n      selectionMode: CalendarSelectionMode.DateRange,\n    }),\n  ],\n})\nexport class DaterangepickerComponent extends CustomFormControl<DateRange | null> implements AfterViewInit {\n  protected readonly takeUntilDestroyed = untilDestroyed();\n\n  protected readonly config = injectDateConfig();\n\n  public readonly element = injectElement();\n\n  /**\n   * Indicates whether the dropdown part of the date range picker is open.\n   *\n   * @type {boolean}\n   */\n  public get isOpen(): boolean {\n    return !!this.dropdown.isOpen;\n  }\n\n  /**\n   * Represents today's date, used for default selections and validations.\n   *\n   * @type {Date}\n   */\n  public today = new Date();\n\n  /**\n   * A function that defines additional rules for disabled dates within the picker.\n   *\n   * @type {DateFilter | null}\n   * @default null\n   *\n   * @example\n   * ```ts\n   * // Disables all Wednesdays in the picker.\n   * const filterFn: DateFilter = (date: Date) => date.getDay() !== 3;\n   * ```\n   */\n  @Input()\n  public filterFn: DateFilter | null = null;\n\n  /**\n   * The earliest date that can be selected in the picker.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public minDate: Date | null = null;\n\n  /**\n   * The latest date that can be selected in the picker.\n   *\n   * @type {Date | null}\n   * @default null\n   */\n  @Input()\n  public maxDate: Date | null = null;\n\n  /**\n   * Position of the dropdown relative to the input fields.\n   *\n   * @type {Position}\n   * @default Position.BOTTOM\n   */\n  @Input()\n  public dropdownPosition: Position = 'bottom';\n\n  /**\n   * When set to true, the select will display a reset button.\n   *\n   * @type {boolean}\n   * @default false\n   */\n  public clearable = input(false, { transform: booleanAttribute });\n\n  /**\n   * Emits the selected date range when it changes.\n   *\n   * @emits {DateRange}\n   */\n  @Output()\n  public selectedChange = new EventEmitter<DateRange>();\n\n  /**\n   * Directive managing the dropdown functionality.\n   *\n   * @type {DropdownDirective}\n   */\n  @ViewChild(DropdownDirective)\n  public dropdown!: DropdownDirective;\n\n  /**\n   * Reference to the element triggering the dropdown.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('dropdownTrigger', { read: ElementRef, static: true })\n  public dropdownTriggerElement!: ElementRef<HTMLElement>;\n\n  /**\n   * Query list of the input controls within the date range picker.\n   *\n   * @type {QueryList<DaterangepickerInputControlDirective>}\n   */\n  @ContentChildren(DaterangepickerInputControlDirective)\n  public dateFields!: QueryList<DaterangepickerInputControlDirective>;\n\n  /**\n   * Reference to the element mirroring the start date input field.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('startDateMirror', { read: ElementRef, static: true })\n  public startDateMirror!: ElementRef<HTMLElement>;\n\n  /**\n   * Reference to the element mirroring the end date input field.\n   *\n   * @type {ElementRef<HTMLElement>}\n   */\n  @ViewChild('endDateMirror', { read: ElementRef, static: true })\n  public endDateMirror!: ElementRef<HTMLElement>;\n\n  /**\n   * The input control for the start date.\n   *\n   * @type {DaterangepickerInputControlDirective | undefined}\n   */\n  public get startDateField(): DaterangepickerInputControlDirective | undefined {\n    const [startDate, _endDate] = this.dateFields;\n    return startDate;\n  }\n\n  /**\n   * The input control for the end date.\n   *\n   * @type {DaterangepickerInputControlDirective | undefined}\n   */\n  public get endDateField(): DaterangepickerInputControlDirective | undefined {\n    const [_startDate, endDate] = this.dateFields;\n    return endDate;\n  }\n\n  constructor() {\n    super(null);\n    detectControllerChanges(this).subscribe();\n  }\n\n  public ngAfterViewInit(): void {\n    this.updateWidth(this.startDateField, this.startDateMirror);\n    this.updateWidth(this.endDateField, this.endDateMirror);\n    this.handleDateFieldChanges();\n    this.handleDateFieldFocus();\n    this.updateInputFields();\n  }\n\n  /**\n   * Selects a date range, updates the form value, and emits the selected range.\n   *\n   * @param {DateRange | null} value - The date range to select.\n   */\n  public selectDateRange(value: DateRange | null): void {\n    if (!value || !value.start || !value.end) return;\n\n    this.updateInternalValue(value);\n\n    this.selectedChange.emit(value);\n    this.dropdown.close();\n  }\n\n  /**\n   * Resets the daterangepicker's value to an empty date range (both start and end as null).\n   */\n  public reset(): void {\n    this.updateInternalValue({ start: null, end: null });\n  }\n\n  /**\n   * @internal\n   * Writes a new value to the element.\n   * Part of the ControlValueAccessor interface.\n   * @param {DateRange | null} value - The new date range value.\n   */\n  public override writeValue(value: DateRange | null): void {\n    super.writeValue(value);\n    this.updateInputFields();\n  }\n\n  /**\n   * Opens the date range picker dropdown.\n   *\n   * @param {KeyboardEvent} event\n   */\n  @HostListener('keydown.alt.ArrowDown', ['$event'])\n  public openDaterangepicker(event?: KeyboardEvent) {\n    event?.stopPropagation();\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    this.dropdown.open(event);\n  }\n\n  protected isEmpty(value: DateRange | null): boolean {\n    return !value || !value.start || !value.end;\n  }\n\n  protected updateInternalValue(value: DateRange): void {\n    this.updateValue(value);\n    this.updateStartDateField(value.start);\n    this.updateEndDateField(value.end);\n  }\n\n  protected handleDateFieldChanges(): void {\n    initNgxMask(this.startDateField?.ngxMaskDirective, getDateInputMask(this.config));\n    initNgxMask(this.endDateField?.ngxMaskDirective, getDateInputMask(this.config));\n    this.startDateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe((value) => {\n      this.updateWidth(this.startDateField, this.startDateMirror, value);\n      this.updateValue({ start: this.startDateField?.valueAsDate ?? null, end: this.endDateField?.valueAsDate ?? null });\n    });\n    this.endDateField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe((value) => {\n      this.updateWidth(this.endDateField, this.endDateMirror, value);\n      this.updateValue({ start: this.startDateField?.valueAsDate ?? null, end: this.endDateField?.valueAsDate ?? null });\n    });\n  }\n\n  protected updateWidth(target: DaterangepickerInputControlDirective | undefined, source: ElementRef<HTMLElement>, value = ''): void {\n    const compensationPx = 2;\n    source.nativeElement.textContent = value || target?.placeholder || null;\n    if (target) {\n      deferFn(() => (target.element.nativeElement.style.width = `${source.nativeElement.offsetWidth + compensationPx}px`));\n    }\n  }\n\n  protected handleDateFieldFocus(): void {\n    this.startDateField?.focused.pipe(this.takeUntilDestroyed()).subscribe((isFocused) => {\n      if (!isFocused) {\n        this.onTouched();\n      }\n      if (this.isOpen) {\n        this.dropdown.close();\n      }\n    });\n    this.endDateField?.focused.pipe(this.takeUntilDestroyed()).subscribe((isFocused) => {\n      if (!isFocused) {\n        this.onTouched();\n      }\n      if (this.isOpen) {\n        this.dropdown.close();\n      }\n    });\n  }\n\n  private updateStartDateField(date: Date | null): void {\n    if (!this.startDateField) return;\n\n    const dateFormat = getDateInputFormat(this.config);\n    this.startDateField.nativeElementValue = date ? format(date, dateFormat) : '';\n    this.updateWidth(this.startDateField, this.startDateMirror, date ? format(date, dateFormat) : '');\n  }\n\n  private updateEndDateField(date: Date | null): void {\n    if (!this.endDateField) return;\n\n    const dateFormat = getDateInputFormat(this.config);\n    this.endDateField.nativeElementValue = date ? format(date, dateFormat) : '';\n    this.updateWidth(this.endDateField, this.endDateMirror, date ? format(date, dateFormat) : '');\n  }\n\n  private updateInputFields(): void {\n    deferFn(() => {\n      if (this.value === null) return this.reset();\n      if (!this.value || !this.value.start || !this.value.end) return;\n      this.updateStartDateField(startOfDay(this.value.start));\n      this.updateEndDateField(startOfDay(this.value.end));\n    });\n  }\n}\n","<span #startDateMirror role=\"none\" class=\"odx-daterangepicker__mirror\"></span>\n<ng-content select=\"input[odxDaterangepickerStartDateControl]\" />\n<span role=\"none\" class=\"odx-daterangepicker__separator\">–</span>\n<span #endDateMirror role=\"none\" class=\"odx-daterangepicker__mirror\"></span>\n<ng-content select=\"input[odxDaterangepickerEndDateControl]\" />\n\n<odx-action-group class=\"odx-daterangepicker__trigger-wrapper\">\n  @if (clearable() && !isEmpty(value)) {\n    <button class=\"odx-daterangepicker__clear\" (click)=\"reset()\" odxButton size=\"small\" aria-label=\"Reset time\">\n      <odx-icon name=\"close\" iconSet=\"core\" />\n    </button>\n  }\n  <button\n    #dropdownTrigger\n    odxButton\n    size=\"small\"\n    variant=\"ghost\"\n    class=\"odx-daterangepicker__trigger\"\n    [odxDropdown]=\"calendarOverlay\"\n    [odxDropdownOptions]=\"{ position: dropdownPosition }\"\n    [odxDropdownTriggerElement]=\"dropdownTriggerElement.nativeElement\"\n    [odxDropdownHost]=\"null\"\n    [odxDropdownReferenceElement]=\"element.nativeElement\"\n    (odxDropdownBeforeClose)=\"onTouched()\"\n  >\n    <odx-icon name=\"calendar\" />\n  </button>\n  <ng-content select=\"[odxButton]\" ngProjectAs=\"[odxButton]\" />\n</odx-action-group>\n\n<ng-template #calendarOverlay>\n  <odx-calendar\n    [selectedDate]=\"today\"\n    [selectedDateRange]=\"value\"\n    (selectedDateRangeChange)=\"selectDateRange($event)\"\n    [filterFn]=\"filterFn\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    cdkTrapFocus\n    cdkTrapFocusAutoCapture\n  />\n</ng-template>\n"]}
|