@wemake4u/form-player-se 1.0.36 → 1.0.37
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/README.md +17 -0
- package/THIRD_PARTY_LICENSES.txt +73 -0
- package/esm2022/lib/directives/date.directive.mjs +3 -3
- package/esm2022/lib/directives/datetime.directive.mjs +199 -0
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +5 -3
- package/esm2022/lib/dynamic-host/dynamic-host.component.mjs +14 -3
- package/esm2022/lib/utils/date.mjs +59 -0
- package/fesm2022/wemake4u-form-player-se.mjs +267 -6
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/directives/date.directive.d.ts +2 -0
- package/lib/directives/datetime.directive.d.ts +42 -0
- package/lib/dynamic-host/dynamic-host.component.d.ts +1 -0
- package/lib/utils/date.d.ts +6 -0
- package/package.json +2 -1
package/README.md
CHANGED
|
@@ -15,3 +15,20 @@ This library provides a robust implementation of forms using the Sirio Angular L
|
|
|
15
15
|
## Installation
|
|
16
16
|
|
|
17
17
|
Run `npm install @wemake4u/form-player-se` to install package.
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
## Third-Party Licenses
|
|
21
|
+
|
|
22
|
+
This project includes the following third-party components:
|
|
23
|
+
|
|
24
|
+
Runtime dependencies (MIT License)
|
|
25
|
+
|
|
26
|
+
tslib — MIT
|
|
27
|
+
feelers — MIT
|
|
28
|
+
feelin — MIT
|
|
29
|
+
marked — MIT
|
|
30
|
+
mime-db — MIT
|
|
31
|
+
sanitize-html — MIT
|
|
32
|
+
vanillajs-datepicker — MIT
|
|
33
|
+
|
|
34
|
+
All listed packages are licensed under MIT License and impose no additional restrictions.
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
Third-Party Licenses for @wemake4u/form-player-se
|
|
2
|
+
=================================================
|
|
3
|
+
|
|
4
|
+
This project includes third-party software components licensed under the
|
|
5
|
+
terms described below.
|
|
6
|
+
|
|
7
|
+
All dependencies listed here are used at runtime and are required by the
|
|
8
|
+
functionality of this package. Unless otherwise stated, each component is
|
|
9
|
+
licensed under the MIT License, which permits use, modification,
|
|
10
|
+
distribution and private/commercial usage.
|
|
11
|
+
|
|
12
|
+
-------------------------------------------------------
|
|
13
|
+
tslib — MIT License
|
|
14
|
+
© Microsoft
|
|
15
|
+
https://github.com/Microsoft/tslib/blob/master/LICENSE.txt
|
|
16
|
+
-------------------------------------------------------
|
|
17
|
+
|
|
18
|
+
-------------------------------------------------------
|
|
19
|
+
@types/mime-db — MIT License
|
|
20
|
+
© DefinitelyTyped contributors
|
|
21
|
+
https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/LICENSE
|
|
22
|
+
-------------------------------------------------------
|
|
23
|
+
|
|
24
|
+
-------------------------------------------------------
|
|
25
|
+
@types/sanitize-html — MIT License
|
|
26
|
+
© DefinitelyTyped contributors
|
|
27
|
+
https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/LICENSE
|
|
28
|
+
-------------------------------------------------------
|
|
29
|
+
|
|
30
|
+
-------------------------------------------------------
|
|
31
|
+
@types/vanillajs-datepicker — MIT License
|
|
32
|
+
© DefinitelyTyped contributors
|
|
33
|
+
https://github.com/DefinitelyTyped/DefinitelyTyped/blob/master/LICENSE
|
|
34
|
+
-------------------------------------------------------
|
|
35
|
+
|
|
36
|
+
-------------------------------------------------------
|
|
37
|
+
feelers — MIT License
|
|
38
|
+
© Contributors
|
|
39
|
+
https://github.com/bpmn-io/feelers/blob/master/LICENSE
|
|
40
|
+
-------------------------------------------------------
|
|
41
|
+
|
|
42
|
+
-------------------------------------------------------
|
|
43
|
+
feelin — MIT License
|
|
44
|
+
© Camunda Services GmbH
|
|
45
|
+
https://github.com/camunda/feelin/blob/master/LICENSE
|
|
46
|
+
-------------------------------------------------------
|
|
47
|
+
|
|
48
|
+
-------------------------------------------------------
|
|
49
|
+
marked — MIT License
|
|
50
|
+
© MarkedJS and contributors
|
|
51
|
+
https://github.com/markedjs/marked/blob/master/LICENSE.md
|
|
52
|
+
-------------------------------------------------------
|
|
53
|
+
|
|
54
|
+
-------------------------------------------------------
|
|
55
|
+
mime-db — MIT License
|
|
56
|
+
© Jonathan Ong and Contributors
|
|
57
|
+
https://github.com/jshttp/mime-db/blob/master/LICENSE
|
|
58
|
+
-------------------------------------------------------
|
|
59
|
+
|
|
60
|
+
-------------------------------------------------------
|
|
61
|
+
sanitize-html — MIT License
|
|
62
|
+
© Apostrophe Technologies, Inc.
|
|
63
|
+
https://github.com/apostrophecms/sanitize-html/blob/main/LICENSE
|
|
64
|
+
-------------------------------------------------------
|
|
65
|
+
|
|
66
|
+
-------------------------------------------------------
|
|
67
|
+
vanillajs-datepicker — MIT License
|
|
68
|
+
© mdb
|
|
69
|
+
https://github.com/mymth/vanillajs-datepicker/blob/master/LICENSE
|
|
70
|
+
-------------------------------------------------------
|
|
71
|
+
|
|
72
|
+
End of Third-Party License Report
|
|
73
|
+
=================================================
|
|
@@ -31,7 +31,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
31
31
|
}] }] });
|
|
32
32
|
const dislayFormat = 'dd/mm/yyyy';
|
|
33
33
|
const storeFormat = 'yyyy-mm-dd';
|
|
34
|
-
function dateToDisplay(value) {
|
|
34
|
+
export function dateToDisplay(value) {
|
|
35
35
|
if (typeof value === "string") {
|
|
36
36
|
const date = parseStore(value) ?? parseDisplay(value);
|
|
37
37
|
return (date == null)
|
|
@@ -42,7 +42,7 @@ function dateToDisplay(value) {
|
|
|
42
42
|
return null;
|
|
43
43
|
}
|
|
44
44
|
}
|
|
45
|
-
function dateToStore(value) {
|
|
45
|
+
export function dateToStore(value) {
|
|
46
46
|
if (typeof value === "string") {
|
|
47
47
|
const date = parseStore(value) ?? parseDisplay(value);
|
|
48
48
|
return (date == null)
|
|
@@ -90,4 +90,4 @@ function parseStore(value) {
|
|
|
90
90
|
return null;
|
|
91
91
|
}
|
|
92
92
|
}
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc2lyaW8vc3JjL2xpYi9kaXJlY3RpdmVzL2RhdGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWhELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBTWxELE1BQU0sT0FBTyxhQUFhO0lBRUk7SUFBNUIsWUFBNEIsZUFBeUM7UUFBekMsb0JBQWUsR0FBZixlQUFlLENBQTBCO1FBRW5FLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBRTFGLElBQUksQ0FBQyxlQUFlLENBQUMsZ0JBQWdCLEdBQUcsVUFBVSxFQUFvQjtZQUNwRSxnQkFBZ0IsQ0FBQyxVQUFVLEtBQVU7Z0JBQ25DLEVBQUUsQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUN6QixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQztRQUVGLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7UUFFOUUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxVQUFVLEdBQUcsVUFBVSxLQUFVLEVBQUUsS0FBZSxFQUFFLGNBQXdCO1lBQy9GLFVBQVUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLEVBQUUsS0FBSyxFQUFFLGNBQWMsQ0FBQyxDQUFDO1FBQzFELENBQUMsQ0FBQztJQUVKLENBQUM7d0dBbEJVLGFBQWE7NEZBQWIsYUFBYTs7NEZBQWIsYUFBYTtrQkFKekIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsV0FBVztv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RUFBRSxDQUFDLENBQUM7SUFFbkMsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLEtBQUssR0FBRyxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFFNUMsSUFDRSxJQUFJLENBQUMsV0FBVyxFQUFFLEtBQUssSUFBSTtRQUMzQixJQUFJLENBQUMsUUFBUSxFQUFFLEtBQUssS0FBSyxHQUFHLENBQUM7UUFDN0IsSUFBSSxDQUFDLE9BQU8sRUFBRSxLQUFLLEdBQUcsRUFDdEIsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztTQUNJLENBQUM7UUFDSixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNpcmlvRGF0ZXBpY2tlckNvbXBvbmVudCB9IGZyb20gJ25neC1zaXJpby1saWInO1xyXG5pbXBvcnQgeyBEYXRlcGlja2VyIH0gZnJvbSAndmFuaWxsYWpzLWRhdGVwaWNrZXInO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbaXNvRGF0ZV0nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWVcclxufSlcclxuZXhwb3J0IGNsYXNzIERhdGVEaXJlY3RpdmUge1xyXG5cclxuICBjb25zdHJ1Y3RvcihASG9zdCgpIHByaXZhdGUgc2lyaW9EYXRlcGlja2VyOiBTaXJpb0RhdGVwaWNrZXJDb21wb25lbnQpIHtcclxuXHJcbiAgICBjb25zdCByZWdpc3Rlck9uQ2hhbmdlID0gdGhpcy5zaXJpb0RhdGVwaWNrZXIucmVnaXN0ZXJPbkNoYW5nZS5iaW5kKHRoaXMuc2lyaW9EYXRlcGlja2VyKTtcclxuXHJcbiAgICB0aGlzLnNpcmlvRGF0ZXBpY2tlci5yZWdpc3Rlck9uQ2hhbmdlID0gZnVuY3Rpb24gKGZuOiAoXzogYW55KSA9PiB2b2lkKSB7XHJcbiAgICAgIHJlZ2lzdGVyT25DaGFuZ2UoZnVuY3Rpb24gKHZhbHVlOiBhbnkpIHtcclxuICAgICAgICBmbihkYXRlVG9TdG9yZSh2YWx1ZSkpO1xyXG4gICAgICB9KTtcclxuICAgIH07XHJcblxyXG4gICAgY29uc3Qgd3JpdGVWYWx1ZSA9IHRoaXMuc2lyaW9EYXRlcGlja2VyLndyaXRlVmFsdWUuYmluZCh0aGlzLnNpcmlvRGF0ZXBpY2tlcik7XHJcblxyXG4gICAgdGhpcy5zaXJpb0RhdGVwaWNrZXIud3JpdGVWYWx1ZSA9IGZ1bmN0aW9uICh2YWx1ZTogYW55LCBldmVudD86IGJvb2xlYW4sIHVwZGF0ZUNhbGVuZGFyPzogYm9vbGVhbikge1xyXG4gICAgICB3cml0ZVZhbHVlKGRhdGVUb0Rpc3BsYXkodmFsdWUpLCBldmVudCwgdXBkYXRlQ2FsZW5kYXIpO1xyXG4gICAgfTtcclxuXHJcbiAgfSAgXHJcbn1cclxuXHJcbmNvbnN0IGRpc2xheUZvcm1hdCA9ICdkZC9tbS95eXl5JztcclxuY29uc3Qgc3RvcmVGb3JtYXQgPSAneXl5eS1tbS1kZCc7XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gZGF0ZVRvRGlzcGxheSh2YWx1ZTogc3RyaW5nKTogc3RyaW5nIHwgbnVsbCB7XHJcbiAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gXCJzdHJpbmdcIikge1xyXG4gICAgY29uc3QgZGF0ZSA9IHBhcnNlU3RvcmUodmFsdWUpID8/IHBhcnNlRGlzcGxheSh2YWx1ZSk7XHJcbiAgICByZXR1cm4gKGRhdGUgPT0gbnVsbClcclxuICAgICAgPyB2YWx1ZVxyXG4gICAgICA6IERhdGVwaWNrZXIuZm9ybWF0RGF0ZShkYXRlLCBkaXNsYXlGb3JtYXQsICdpdCcpO1xyXG4gIH1cclxuICBlbHNlIHtcclxuICAgIHJldHVybiBudWxsO1xyXG4gIH0gIFxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gZGF0ZVRvU3RvcmUodmFsdWU6IHN0cmluZyk6IHN0cmluZyB8IG51bGwge1xyXG4gIGlmICh0eXBlb2YgdmFsdWUgPT09IFwic3RyaW5nXCIpIHtcclxuICAgIGNvbnN0IGRhdGUgPSBwYXJzZVN0b3JlKHZhbHVlKSA/PyBwYXJzZURpc3BsYXkodmFsdWUpO1xyXG4gICAgcmV0dXJuIChkYXRlID09IG51bGwpXHJcbiAgICAgID8gbnVsbFxyXG4gICAgICA6IERhdGVwaWNrZXIuZm9ybWF0RGF0ZShkYXRlLCBzdG9yZUZvcm1hdCwgJ2l0Jyk7XHJcbiAgfVxyXG4gIGVsc2Uge1xyXG4gICAgcmV0dXJuIG51bGw7XHJcbiAgfSBcclxufVxyXG5cclxuZnVuY3Rpb24gcGFyc2VEaXNwbGF5KHZhbHVlOiBzdHJpbmcpOiBEYXRlIHwgbnVsbCB7XHJcbiAgY29uc3QgcmVnZXggPSAvXihcXGR7Mn0pXFwvKFxcZHsyfSlcXC8oXFxkezR9KSQvO1xyXG4gIGNvbnN0IG1hdGNoID0gdmFsdWUubWF0Y2gocmVnZXgpO1xyXG4gIGlmICghbWF0Y2gpIHJldHVybiBudWxsO1xyXG5cclxuICBjb25zdCBkYXkgPSBwYXJzZUludChtYXRjaFsxXSwgMTApO1xyXG4gIGNvbnN0IG1vbnRoID0gcGFyc2VJbnQobWF0Y2hbMl0sIDEwKTtcclxuICBjb25zdCB5ZWFyID0gcGFyc2VJbnQobWF0Y2hbM10sIDEwKTtcclxuXHJcbiAgY29uc3QgZGF0ZSA9IG5ldyBEYXRlKHllYXIsIG1vbnRoIC0gMSwgZGF5KTtcclxuXHJcbiAgaWYgKFxyXG4gICAgZGF0ZS5nZXRGdWxsWWVhcigpID09PSB5ZWFyICYmXHJcbiAgICBkYXRlLmdldE1vbnRoKCkgPT09IG1vbnRoIC0gMSAmJlxyXG4gICAgZGF0ZS5nZXREYXRlKCkgPT09IGRheVxyXG4gICkge1xyXG4gICAgcmV0dXJuIGRhdGU7XHJcbiAgfVxyXG4gIGVsc2Uge1xyXG4gICAgcmV0dXJuIG51bGw7XHJcbiAgfVxyXG59XHJcblxyXG5mdW5jdGlvbiBwYXJzZVN0b3JlKHZhbHVlOiBzdHJpbmcpOiBEYXRlIHwgbnVsbCB7XHJcbiAgY29uc3QgcmVnZXggPSAvXihcXGR7NH0pLShcXGR7Mn0pLShcXGR7Mn0pKFRcXGR7Mn06XFxkezJ9OlxcZHsyfShcXC5cXGQrKT8oWnxbKy1dXFxkezJ9OlxcZHsyfSk/KT8kLztcclxuICBjb25zdCBtYXRjaCA9IHZhbHVlLm1hdGNoKHJlZ2V4KTtcclxuICBpZiAoIW1hdGNoKSB7XHJcbiAgICByZXR1cm4gbnVsbDtcclxuICB9XHJcblxyXG4gIGNvbnN0IHllYXIgPSBwYXJzZUludChtYXRjaFsxXSwgMTApO1xyXG4gIGNvbnN0IG1vbnRoID0gcGFyc2VJbnQobWF0Y2hbMl0sIDEwKTtcclxuICBjb25zdCBkYXkgPSBwYXJzZUludChtYXRjaFszXSwgMTApO1xyXG5cclxuICBjb25zdCBkYXRlID0gbmV3IERhdGUoeWVhciwgbW9udGggLSAxLCBkYXkpO1xyXG5cclxuICBpZiAoXHJcbiAgICBkYXRlLmdldEZ1bGxZZWFyKCkgPT09IHllYXIgJiZcclxuICAgIGRhdGUuZ2V0TW9udGgoKSA9PT0gbW9udGggLSAxICYmXHJcbiAgICBkYXRlLmdldERhdGUoKSA9PT0gZGF5XHJcbiAgKSB7XHJcbiAgICByZXR1cm4gZGF0ZTtcclxuICB9XHJcbiAgZWxzZSB7XHJcbiAgICByZXR1cm4gbnVsbDtcclxuICB9XHJcbn1cclxuXHJcblxyXG4iXX0=
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
import { Directive, Input, forwardRef } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { toLocalString, toLocalDateString, isValidTime, isValidDate } from '../utils/date';
|
|
4
|
+
import { dateToStore } from '../directives/date.directive';
|
|
5
|
+
import { Subject } from 'rxjs';
|
|
6
|
+
import { takeUntil } from 'rxjs/operators';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/forms";
|
|
9
|
+
export class DateTimeCoordinatorDirective {
|
|
10
|
+
datePicker;
|
|
11
|
+
timePicker;
|
|
12
|
+
onChange = (_) => { };
|
|
13
|
+
onTouched = () => { };
|
|
14
|
+
dateValue = null;
|
|
15
|
+
timeValue = null;
|
|
16
|
+
destroy$ = new Subject();
|
|
17
|
+
ngOnDestroy() {
|
|
18
|
+
this.destroy$.next();
|
|
19
|
+
this.destroy$.complete();
|
|
20
|
+
}
|
|
21
|
+
ngAfterViewInit() {
|
|
22
|
+
this.datePicker?.blurEvent
|
|
23
|
+
.pipe(takeUntil(this.destroy$))
|
|
24
|
+
.subscribe((event) => {
|
|
25
|
+
const value = dateToStore(event.component.value);
|
|
26
|
+
this.dateValue = isValidDate(value ?? "") ? value : null;
|
|
27
|
+
this.recalculate("date");
|
|
28
|
+
});
|
|
29
|
+
this.timePicker?.blurEvent
|
|
30
|
+
.pipe(takeUntil(this.destroy$))
|
|
31
|
+
.subscribe((event) => {
|
|
32
|
+
this.timeValue = isValidTime(event.component.value)
|
|
33
|
+
? event.component.value : null;
|
|
34
|
+
this.recalculate("time");
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
writeValue(value) {
|
|
38
|
+
if (!value) {
|
|
39
|
+
this.dateValue = null;
|
|
40
|
+
this.timeValue = null;
|
|
41
|
+
this.datePicker?.writeValue(null);
|
|
42
|
+
this.timePicker?.writeValue(null);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const date = value instanceof Date ? value : new Date(value);
|
|
46
|
+
const local = toLocalString(date);
|
|
47
|
+
this.dateValue = local ? local.substring(0, 10) : null;
|
|
48
|
+
this.timeValue = local ? local.substring(11, 16) : null;
|
|
49
|
+
this.datePicker?.writeValue(this.dateValue);
|
|
50
|
+
this.timePicker?.writeValue(this.timeValue);
|
|
51
|
+
}
|
|
52
|
+
setDisabledState(isDisabled) {
|
|
53
|
+
this.datePicker?.setDisabledState(isDisabled);
|
|
54
|
+
this.timePicker?.setDisabledState(isDisabled);
|
|
55
|
+
}
|
|
56
|
+
registerOnChange(fn) { this.onChange = fn; }
|
|
57
|
+
registerOnTouched(fn) { this.onTouched = fn; }
|
|
58
|
+
recalculate(part) {
|
|
59
|
+
// Case: both fields cleared
|
|
60
|
+
if (!this.dateValue && !this.timeValue) {
|
|
61
|
+
this.onChange(null);
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
// Case: date is set but time is empty → apply default time
|
|
65
|
+
if (this.dateValue && !this.timeValue) {
|
|
66
|
+
this.timeValue = '00:00';
|
|
67
|
+
this.timePicker?.writeValue(this.timeValue);
|
|
68
|
+
}
|
|
69
|
+
// Case: time is set but date is empty → apply default date
|
|
70
|
+
if (part === "time" && !this.dateValue && this.timeValue) {
|
|
71
|
+
const today = new Date();
|
|
72
|
+
this.dateValue = toLocalDateString(today);
|
|
73
|
+
this.datePicker?.writeValue(this.dateValue);
|
|
74
|
+
}
|
|
75
|
+
// If after applying the rules one of the values is still missing → null
|
|
76
|
+
if (!this.dateValue || !this.timeValue) {
|
|
77
|
+
this.onChange(null);
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
let combined = `${this.dateValue}T${this.timeValue}:00`;
|
|
81
|
+
this.onChange(combined);
|
|
82
|
+
}
|
|
83
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeCoordinatorDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
84
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: DateTimeCoordinatorDirective, isStandalone: true, selector: "[dateTimeCoordinator]", inputs: { datePicker: "datePicker", timePicker: "timePicker" }, providers: [
|
|
85
|
+
{
|
|
86
|
+
provide: NG_VALUE_ACCESSOR,
|
|
87
|
+
useExisting: forwardRef(() => DateTimeCoordinatorDirective),
|
|
88
|
+
multi: true
|
|
89
|
+
}
|
|
90
|
+
], ngImport: i0 });
|
|
91
|
+
}
|
|
92
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeCoordinatorDirective, decorators: [{
|
|
93
|
+
type: Directive,
|
|
94
|
+
args: [{
|
|
95
|
+
selector: '[dateTimeCoordinator]',
|
|
96
|
+
standalone: true,
|
|
97
|
+
providers: [
|
|
98
|
+
{
|
|
99
|
+
provide: NG_VALUE_ACCESSOR,
|
|
100
|
+
useExisting: forwardRef(() => DateTimeCoordinatorDirective),
|
|
101
|
+
multi: true
|
|
102
|
+
}
|
|
103
|
+
]
|
|
104
|
+
}]
|
|
105
|
+
}], propDecorators: { datePicker: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], timePicker: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}] } });
|
|
110
|
+
const classNames = ['sirio-is-invalid', 'sirio-is-valid', 'sirio-is-warning', 'sirio-is-pending'];
|
|
111
|
+
export class DateTimeValidationDirective {
|
|
112
|
+
ngControl;
|
|
113
|
+
renderer;
|
|
114
|
+
isWarning = false;
|
|
115
|
+
showWhenValid = false;
|
|
116
|
+
sub;
|
|
117
|
+
constructor(ngControl, renderer) {
|
|
118
|
+
this.ngControl = ngControl;
|
|
119
|
+
this.renderer = renderer;
|
|
120
|
+
}
|
|
121
|
+
ngOnDestroy() {
|
|
122
|
+
this.sub?.unsubscribe();
|
|
123
|
+
}
|
|
124
|
+
ngAfterViewInit() {
|
|
125
|
+
if (!this.ngControl?.statusChanges) {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
this.sub = this.ngControl.statusChanges.subscribe(status => {
|
|
129
|
+
const coordinator = this.getCoordinator();
|
|
130
|
+
if (coordinator) {
|
|
131
|
+
this.checkValidation(coordinator.datePicker.validationTarget);
|
|
132
|
+
this.checkValidation(coordinator.timePicker.validationTarget);
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
getCoordinator() {
|
|
137
|
+
return this.ngControl?.valueAccessor ?? null;
|
|
138
|
+
}
|
|
139
|
+
checkValidation(validationTarget) {
|
|
140
|
+
if (this.ngControl?.status === "PENDING") {
|
|
141
|
+
this.setPending(validationTarget);
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
const isDisabled = this.ngControl?.disabled;
|
|
145
|
+
if (isDisabled) {
|
|
146
|
+
this.cleanupValidation(validationTarget);
|
|
147
|
+
return;
|
|
148
|
+
}
|
|
149
|
+
const isValid = this.ngControl?.valid;
|
|
150
|
+
if (isValid) {
|
|
151
|
+
if (this.showWhenValid) {
|
|
152
|
+
this.setValid(validationTarget);
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
this.cleanupValidation(validationTarget);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
if (!isValid && this.isWarning) {
|
|
159
|
+
this.setWarning(validationTarget);
|
|
160
|
+
}
|
|
161
|
+
if (!isValid && !this.isWarning) {
|
|
162
|
+
this.setInvalid(validationTarget);
|
|
163
|
+
}
|
|
164
|
+
//this.cd.detectChanges();
|
|
165
|
+
}
|
|
166
|
+
cleanupValidation(validationTarget) {
|
|
167
|
+
classNames.forEach(c => this.renderer.removeClass(validationTarget, c));
|
|
168
|
+
}
|
|
169
|
+
setValid(validationTarget) {
|
|
170
|
+
this.applyClass(validationTarget, 'sirio-is-valid');
|
|
171
|
+
}
|
|
172
|
+
setInvalid(validationTarget) {
|
|
173
|
+
this.applyClass(validationTarget, 'sirio-is-invalid');
|
|
174
|
+
}
|
|
175
|
+
setWarning(validationTarget) {
|
|
176
|
+
this.applyClass(validationTarget, 'sirio-is-warning');
|
|
177
|
+
}
|
|
178
|
+
setPending(validationTarget) {
|
|
179
|
+
this.applyClass(validationTarget, 'sirio-is-pending');
|
|
180
|
+
}
|
|
181
|
+
applyClass(validationTarget, className) {
|
|
182
|
+
this.cleanupValidation(validationTarget);
|
|
183
|
+
this.renderer.addClass(validationTarget, className);
|
|
184
|
+
}
|
|
185
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeValidationDirective, deps: [{ token: i1.NgControl }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
186
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: DateTimeValidationDirective, isStandalone: true, selector: "[dateTimeValidator]", inputs: { isWarning: "isWarning", showWhenValid: "showWhenValid" }, ngImport: i0 });
|
|
187
|
+
}
|
|
188
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DateTimeValidationDirective, decorators: [{
|
|
189
|
+
type: Directive,
|
|
190
|
+
args: [{
|
|
191
|
+
selector: '[dateTimeValidator]',
|
|
192
|
+
standalone: true
|
|
193
|
+
}]
|
|
194
|
+
}], ctorParameters: () => [{ type: i1.NgControl }, { type: i0.Renderer2 }], propDecorators: { isWarning: [{
|
|
195
|
+
type: Input
|
|
196
|
+
}], showWhenValid: [{
|
|
197
|
+
type: Input
|
|
198
|
+
}] } });
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/directives/datetime.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, AfterViewInit, Input, forwardRef, OnDestroy, Renderer2 } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\nimport { NgxSirioEvent, SirioDatepickerComponent, SirioTimepickerComponent, } from 'ngx-sirio-lib';\r\nimport { toLocalString, toLocalDateString, isValidTime, isValidDate, isValidDateObject } from '../utils/date';\r\nimport { dateToStore } from '../directives/date.directive';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\n@Directive({\r\n  selector: '[dateTimeCoordinator]',\r\n  standalone: true,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => DateTimeCoordinatorDirective),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class DateTimeCoordinatorDirective implements ControlValueAccessor, AfterViewInit, OnDestroy {\r\n\r\n  @Input() datePicker!: SirioDatepickerComponent;\r\n  @Input() timePicker!: SirioTimepickerComponent;\r\n  \r\n  private onChange = (_: any) => { };\r\n  private onTouched = () => { };\r\n\r\n  private dateValue: string | null = null;\r\n  private timeValue: string | null = null;\r\n\r\n  private destroy$ = new Subject<void>();\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n    this.datePicker?.blurEvent\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((event: NgxSirioEvent<SirioDatepickerComponent>) => {\r\n        const value = dateToStore(event.component.value);\r\n        this.dateValue = isValidDate(value ?? \"\") ? value : null;\r\n        this.recalculate(\"date\");\r\n      });\r\n\r\n    this.timePicker?.blurEvent\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((event: NgxSirioEvent<SirioTimepickerComponent>) => {\r\n        this.timeValue = isValidTime(event.component.value)\r\n          ? event.component.value : null;\r\n        this.recalculate(\"time\");\r\n      });\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    if (!value) {\r\n      this.dateValue = null;\r\n      this.timeValue = null;\r\n      this.datePicker?.writeValue(null);\r\n      this.timePicker?.writeValue(null);\r\n      return;\r\n    }\r\n\r\n    const date = value instanceof Date ? value : new Date(value);\r\n    const local = toLocalString(date);\r\n    this.dateValue = local ? local.substring(0, 10) : null;\r\n    this.timeValue = local ? local.substring(11, 16) : null;\r\n    this.datePicker?.writeValue(this.dateValue);\r\n    this.timePicker?.writeValue(this.timeValue);\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.datePicker?.setDisabledState(isDisabled);\r\n    this.timePicker?.setDisabledState(isDisabled);\r\n  }\r\n\r\n  registerOnChange(fn: any): void { this.onChange = fn; }\r\n  registerOnTouched(fn: any): void { this.onTouched = fn; }\r\n\r\n  private recalculate(part: \"date\" | \"time\") {\r\n    // Case: both fields cleared\r\n    if (!this.dateValue && !this.timeValue) {\r\n      this.onChange(null);\r\n      return;\r\n    }\r\n\r\n    // Case: date is set but time is empty → apply default time\r\n    if (this.dateValue && !this.timeValue) {\r\n      this.timeValue = '00:00';\r\n      this.timePicker?.writeValue(this.timeValue);\r\n    }\r\n\r\n    // Case: time is set but date is empty → apply default date\r\n    if (part === \"time\" && !this.dateValue && this.timeValue) {\r\n      const today = new Date();\r\n      this.dateValue = toLocalDateString(today);\r\n      this.datePicker?.writeValue(this.dateValue);\r\n    }\r\n\r\n    // If after applying the rules one of the values is still missing → null\r\n    if (!this.dateValue || !this.timeValue) {\r\n      this.onChange(null);\r\n      return;\r\n    }\r\n\r\n    let combined = `${this.dateValue}T${this.timeValue}:00`;\r\n\r\n    this.onChange(combined);\r\n  }\r\n\r\n}\r\n\r\nconst classNames = ['sirio-is-invalid', 'sirio-is-valid', 'sirio-is-warning', 'sirio-is-pending'];\r\n\r\n@Directive({\r\n  selector: '[dateTimeValidator]',\r\n  standalone: true  \r\n})\r\nexport class DateTimeValidationDirective implements AfterViewInit, OnDestroy {\r\n  @Input() isWarning: boolean = false;\r\n  @Input() showWhenValid: boolean = false;\r\n\r\n  private sub?: Subscription;\r\n\r\n  constructor(private ngControl: NgControl,\r\n    private renderer: Renderer2)\r\n  {    \r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.sub?.unsubscribe();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.ngControl?.statusChanges) {\r\n      return;\r\n    }\r\n\r\n    this.sub = this.ngControl.statusChanges.subscribe(status => {\r\n      const coordinator = this.getCoordinator();\r\n      if (coordinator) {\r\n        this.checkValidation(coordinator.datePicker.validationTarget);\r\n        this.checkValidation(coordinator.timePicker.validationTarget);\r\n      }\r\n    });\r\n  }\r\n\r\n  private getCoordinator(): DateTimeCoordinatorDirective | null {\r\n    return this.ngControl?.valueAccessor as DateTimeCoordinatorDirective ?? null;\r\n  }\r\n\r\n  private checkValidation(validationTarget: any) {\r\n    if (this.ngControl?.status === \"PENDING\") {\r\n      this.setPending(validationTarget);\r\n      return;\r\n    }\r\n\r\n    const isDisabled = this.ngControl?.disabled;\r\n    if (isDisabled) {\r\n      this.cleanupValidation(validationTarget);\r\n      return;\r\n    }\r\n    const isValid = this.ngControl?.valid;\r\n    if (isValid) {\r\n      if (this.showWhenValid) {\r\n        this.setValid(validationTarget);\r\n      }\r\n      else {\r\n        this.cleanupValidation(validationTarget);\r\n      }\r\n    }\r\n    if (!isValid && this.isWarning) {\r\n      this.setWarning(validationTarget);\r\n    }\r\n    if (!isValid && !this.isWarning) {\r\n      this.setInvalid(validationTarget);\r\n    }\r\n    //this.cd.detectChanges();\r\n  }\r\n\r\n  private cleanupValidation(validationTarget: any) {\r\n    classNames.forEach(c => this.renderer.removeClass(validationTarget, c));\r\n  }\r\n\r\n  private setValid(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-valid');\r\n  }\r\n\r\n  private setInvalid(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-invalid');\r\n  }\r\n\r\n  private setWarning(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-warning');\r\n  }\r\n\r\n  private setPending(validationTarget: any) {\r\n    this.applyClass(validationTarget, 'sirio-is-pending');\r\n  }\r\n\r\n  private applyClass(validationTarget: any, className: string) {\r\n    this.cleanupValidation(validationTarget);\r\n    this.renderer.addClass(validationTarget, className);\r\n  }\r\n\r\n}\r\n"]}
|