@dereekb/dbx-form 12.6.20 → 12.7.0
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/esm2022/lib/form/action/form.action.dialog.component.mjs +6 -10
- package/esm2022/lib/form/action/form.action.directive.mjs +14 -13
- package/esm2022/lib/form/io/form.change.directive.mjs +9 -7
- package/esm2022/lib/form/io/form.input.directive.mjs +8 -9
- package/esm2022/lib/form/io/form.loading.directive.mjs +6 -7
- package/esm2022/lib/formly/field/checklist/checklist.item.field.component.mjs +8 -7
- package/esm2022/lib/formly/field/wrapper/working.wrapper.component.mjs +2 -2
- package/esm2022/lib/formly/form/search.form.component.mjs +1 -1
- package/esm2022/lib/formly/formly.context.directive.mjs +1 -1
- package/esm2022/lib/formly/formly.directive.mjs +8 -13
- package/esm2022/lib/formly/formly.form.component.mjs +18 -19
- package/fesm2022/dereekb-dbx-form.mjs +61 -71
- package/fesm2022/dereekb-dbx-form.mjs.map +1 -1
- package/lib/form/action/form.action.dialog.component.d.ts +2 -3
- package/lib/form/action/form.action.directive.d.ts +4 -5
- package/lib/form/io/form.change.directive.d.ts +3 -3
- package/lib/form/io/form.input.directive.d.ts +2 -3
- package/lib/form/io/form.loading.directive.d.ts +1 -3
- package/lib/formly/field/checklist/checklist.item.field.component.d.ts +2 -2
- package/lib/formly/field/wrapper/working.wrapper.component.d.ts +1 -1
- package/lib/formly/form/search.form.component.d.ts +1 -2
- package/lib/formly/formly.context.directive.d.ts +1 -2
- package/lib/formly/formly.directive.d.ts +7 -9
- package/lib/formly/formly.form.component.d.ts +3 -4
- package/package.json +1 -1
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { Component, inject } from '@angular/core';
|
|
2
2
|
import { AbstractDialogDirective, DbxDialogContentDirective, DbxDialogContentCloseComponent, DbxActionModule, DbxButtonModule } from '@dereekb/dbx-web';
|
|
3
|
-
import { asObservableFromGetter
|
|
3
|
+
import { asObservableFromGetter } from '@dereekb/rxjs';
|
|
4
4
|
import { distinctUntilChanged } from 'rxjs';
|
|
5
|
+
import { cleanSubscription } from '@dereekb/dbx-core';
|
|
5
6
|
import { DbxFormlyContext, provideFormlyContext } from '../../formly/formly.context';
|
|
6
7
|
import { DbxFormlyComponent } from '../../formly/formly.form.component';
|
|
7
8
|
import { DbxFormSourceDirective } from '../io/form.input.directive';
|
|
@@ -13,7 +14,7 @@ import * as i2 from "@dereekb/dbx-web";
|
|
|
13
14
|
*
|
|
14
15
|
*/
|
|
15
16
|
export class DbxFormActionDialogComponent extends AbstractDialogDirective {
|
|
16
|
-
_fieldsSub =
|
|
17
|
+
_fieldsSub = cleanSubscription();
|
|
17
18
|
context = inject((DbxFormlyContext), { self: true });
|
|
18
19
|
fields$ = asObservableFromGetter(this.data.fields);
|
|
19
20
|
initialValue$ = asObservableFromGetter(this.data.initialValue);
|
|
@@ -23,14 +24,9 @@ export class DbxFormActionDialogComponent extends AbstractDialogDirective {
|
|
|
23
24
|
...this.data.submitButtonConfig
|
|
24
25
|
};
|
|
25
26
|
ngOnInit() {
|
|
26
|
-
|
|
27
|
-
this._fieldsSub.subscription = this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
|
|
27
|
+
this._fieldsSub.setSub(this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
|
|
28
28
|
this.context.fields = fields;
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
ngOnDestroy() {
|
|
32
|
-
super.ngOnDestroy();
|
|
33
|
-
this._fieldsSub.destroy();
|
|
29
|
+
}));
|
|
34
30
|
}
|
|
35
31
|
handleSubmitValue = (value, context) => {
|
|
36
32
|
context.success();
|
|
@@ -76,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
76
72
|
imports: [DbxDialogContentDirective, DbxActionModule, DbxButtonModule, DbxDialogContentCloseComponent, DbxFormlyComponent, DbxFormSourceDirective, DbxActionFormDirective, DbxFormlyComponent]
|
|
77
73
|
}]
|
|
78
74
|
}] });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5hY3Rpb24uZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL3NyYy9saWIvZm9ybS9hY3Rpb24vZm9ybS5hY3Rpb24uZGlhbG9nLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMxRCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUseUJBQXlCLEVBQUUsOEJBQThCLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBa0IsTUFBTSxrQkFBa0IsQ0FBQztBQUd4SyxPQUFPLEVBQUUsc0JBQXNCLEVBQTJFLE1BQU0sZUFBZSxDQUFDO0FBRWhJLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM1QyxPQUFPLEVBQUUsaUJBQWlCLEVBQW9CLE1BQU0sbUJBQW1CLENBQUM7QUFDeEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDckYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDeEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDcEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0seUJBQXlCLENBQUM7Ozs7QUEyQmpFOztHQUVHO0FBZ0JILE1BQU0sT0FBTyw0QkFBZ0MsU0FBUSx1QkFBaUU7SUFDbkcsVUFBVSxHQUFHLGlCQUFpQixFQUFFLENBQUM7SUFFekMsT0FBTyxHQUFHLE1BQU0sQ0FBQyxDQUFBLGdCQUFtQixDQUFBLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN0RCxPQUFPLEdBQUcsc0JBQXNCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNuRCxhQUFhLEdBQUcsc0JBQXNCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUUvRCxNQUFNLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7SUFFMUIsa0JBQWtCLEdBQUc7UUFDNUIsSUFBSSxFQUFFLFFBQVE7UUFDZCxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsa0JBQWtCO0tBQ2hDLENBQUM7SUFFRixRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQ3BCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUM3RCxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7SUFFUSxpQkFBaUIsR0FBd0IsQ0FBQyxLQUFLLEVBQUUsT0FBTyxFQUFFLEVBQUU7UUFDbkUsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEIsQ0FBQyxDQUFDO0lBRUYsTUFBTSxDQUFDLGtCQUFrQixDQUFJLFNBQW9CLEVBQUUsTUFBNkM7UUFDOUYsTUFBTSxTQUFTLEdBQUcsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFBLDRCQUErQixDQUFBLEVBQUU7WUFDaEUsS0FBSyxFQUFFLE1BQU07WUFDYixTQUFTLEVBQUUsT0FBTztZQUNsQixRQUFRLEVBQUUsT0FBTztZQUNqQixHQUFHLE1BQU0sQ0FBQyxNQUFNO1lBQ2hCLElBQUksRUFBRSxNQUFNO1NBQ2IsQ0FBQyxDQUFDO1FBRUgsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQzt3R0FyQ1UsNEJBQTRCOzRGQUE1Qiw0QkFBNEIsMkRBSDVCLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxpREFYekI7Ozs7Ozs7OztHQVNULDREQUdTLHlCQUF5Qix3SEFBRSxlQUFlLGlaQUFFLGVBQWUsMlNBQUUsOEJBQThCLDZHQUFFLGtCQUFrQiw2RUFBRSxzQkFBc0IsNEdBQUUsc0JBQXNCOzs0RkFFOUosNEJBQTRCO2tCQWZ4QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRTs7Ozs7Ozs7O0dBU1Q7b0JBQ0QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFNBQVMsRUFBRSxDQUFDLG9CQUFvQixFQUFFLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsOEJBQThCLEVBQUUsa0JBQWtCLEVBQUUsc0JBQXNCLEVBQUUsc0JBQXNCLEVBQUUsa0JBQWtCLENBQUM7aUJBQy9MIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWJzdHJhY3REaWFsb2dEaXJlY3RpdmUsIERieERpYWxvZ0NvbnRlbnREaXJlY3RpdmUsIERieERpYWxvZ0NvbnRlbnRDbG9zZUNvbXBvbmVudCwgRGJ4QWN0aW9uTW9kdWxlLCBEYnhCdXR0b25Nb2R1bGUsIERieEJ1dHRvblN0eWxlIH0gZnJvbSAnQGRlcmVla2IvZGJ4LXdlYic7XG5pbXBvcnQgeyBNYXREaWFsb2csIE1hdERpYWxvZ0NvbmZpZywgTWF0RGlhbG9nUmVmIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBhc09ic2VydmFibGVGcm9tR2V0dGVyLCBNYXliZU9ic2VydmFibGVPclZhbHVlR2V0dGVyLCBPYnNlcnZhYmxlT3JWYWx1ZUdldHRlciwgV29ya1VzaW5nQ29udGV4dCB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IGRpc3RpbmN0VW50aWxDaGFuZ2VkIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBjbGVhblN1YnNjcmlwdGlvbiwgRGJ4QnV0dG9uRGlzcGxheSB9IGZyb20gJ0BkZXJlZWtiL2RieC1jb3JlJztcbmltcG9ydCB7IERieEZvcm1seUNvbnRleHQsIHByb3ZpZGVGb3JtbHlDb250ZXh0IH0gZnJvbSAnLi4vLi4vZm9ybWx5L2Zvcm1seS5jb250ZXh0JztcbmltcG9ydCB7IERieEZvcm1seUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2Zvcm1seS9mb3JtbHkuZm9ybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGJ4Rm9ybVNvdXJjZURpcmVjdGl2ZSB9IGZyb20gJy4uL2lvL2Zvcm0uaW5wdXQuZGlyZWN0aXZlJztcbmltcG9ydCB7IERieEFjdGlvbkZvcm1EaXJlY3RpdmUgfSBmcm9tICcuL2Zvcm0uYWN0aW9uLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4Rm9ybUFjdGlvbkRpYWxvZ0NvbXBvbmVudEJ1dHRvbkNvbmZpZyBleHRlbmRzIERieEJ1dHRvbkRpc3BsYXksIERieEJ1dHRvblN0eWxlIHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGJ4Rm9ybUFjdGlvbkRpYWxvZ0NvbXBvbmVudENvbmZpZzxPPiB7XG4gIC8qKlxuICAgKiBIZWFkZXIgdGV4dCBmb3IgdGhlIGRpYWxvZy5cbiAgICovXG4gIHJlYWRvbmx5IGhlYWRlcjogc3RyaW5nO1xuICAvKipcbiAgICogVXNlZCBmb3IgcmV0cmlldmluZyB0aGUgZmllbGRzIHRvIGRpc3BsYXkgaW4gdGhlIGRpYWxvZy5cbiAgICovXG4gIHJlYWRvbmx5IGZpZWxkczogT2JzZXJ2YWJsZU9yVmFsdWVHZXR0ZXI8Rm9ybWx5RmllbGRDb25maWdbXT47XG4gIC8qKlxuICAgKiBJbml0aWFsIHZhbHVlIGZvciB0aGUgZm9ybS5cbiAgICovXG4gIHJlYWRvbmx5IGluaXRpYWxWYWx1ZT86IE1heWJlT2JzZXJ2YWJsZU9yVmFsdWVHZXR0ZXI8Tz47XG4gIC8qKlxuICAgKiBUZXh0L0ljb24gZm9yIHRoZSBzdWJtaXQgYnV0dG9uLlxuICAgKi9cbiAgcmVhZG9ubHkgc3VibWl0QnV0dG9uQ29uZmlnPzogRGJ4Rm9ybUFjdGlvbkRpYWxvZ0NvbXBvbmVudEJ1dHRvbkNvbmZpZztcbiAgLyoqXG4gICAqIERpYWxvZy1zcGVjaWZpYyBjb25maWd1cmF0aW9uXG4gICAqL1xuICByZWFkb25seSBkaWFsb2c/OiBPbWl0PE1hdERpYWxvZ0NvbmZpZywgJ2RhdGEnPjtcbn1cblxuLyoqXG4gKlxuICovXG5AQ29tcG9uZW50KHtcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGJ4LWRpYWxvZy1jb250ZW50IGRieEFjdGlvbiBbZGJ4QWN0aW9uSGFuZGxlcl09XCJoYW5kbGVTdWJtaXRWYWx1ZVwiIGNsYXNzPVwiZGJ4LWRpYWxvZy1jb250ZW50LXdpdGgtaGVhZGVyXCI+XG4gICAgICA8aDMgY2xhc3M9XCJkYngtZGlhbG9nLWNvbnRlbnQtaGVhZGVyXCI+e3sgaGVhZGVyIH19PC9oMz5cbiAgICAgIDxkYngtZGlhbG9nLWNvbnRlbnQtY2xvc2UgKGNsb3NlKT1cImNsb3NlKClcIj48L2RieC1kaWFsb2ctY29udGVudC1jbG9zZT5cbiAgICAgIDxkaXY+XG4gICAgICAgIDxkYngtZm9ybWx5IGRieEFjdGlvbkZvcm0gW2RieEZvcm1Tb3VyY2VdPVwiaW5pdGlhbFZhbHVlJFwiPjwvZGJ4LWZvcm1seT5cbiAgICAgICAgPGRieC1idXR0b24gZGJ4QWN0aW9uQnV0dG9uIFtidXR0b25EaXNwbGF5XT1cInN1Ym1pdEJ1dHRvbkNvbmZpZ1wiIFtidXR0b25TdHlsZV09XCJzdWJtaXRCdXR0b25Db25maWdcIiBbcmFpc2VkXT1cInRydWVcIj48L2RieC1idXR0b24+XG4gICAgICA8L2Rpdj5cbiAgICA8L2RieC1kaWFsb2ctY29udGVudD5cbiAgYCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgcHJvdmlkZXJzOiBbcHJvdmlkZUZvcm1seUNvbnRleHQoKV0sXG4gIGltcG9ydHM6IFtEYnhEaWFsb2dDb250ZW50RGlyZWN0aXZlLCBEYnhBY3Rpb25Nb2R1bGUsIERieEJ1dHRvbk1vZHVsZSwgRGJ4RGlhbG9nQ29udGVudENsb3NlQ29tcG9uZW50LCBEYnhGb3JtbHlDb21wb25lbnQsIERieEZvcm1Tb3VyY2VEaXJlY3RpdmUsIERieEFjdGlvbkZvcm1EaXJlY3RpdmUsIERieEZvcm1seUNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgRGJ4Rm9ybUFjdGlvbkRpYWxvZ0NvbXBvbmVudDxPPiBleHRlbmRzIEFic3RyYWN0RGlhbG9nRGlyZWN0aXZlPE8sIERieEZvcm1BY3Rpb25EaWFsb2dDb21wb25lbnRDb25maWc8Tz4+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgcHJpdmF0ZSByZWFkb25seSBfZmllbGRzU3ViID0gY2xlYW5TdWJzY3JpcHRpb24oKTtcblxuICByZWFkb25seSBjb250ZXh0ID0gaW5qZWN0KERieEZvcm1seUNvbnRleHQ8Tz4sIHsgc2VsZjogdHJ1ZSB9KTtcbiAgcmVhZG9ubHkgZmllbGRzJCA9IGFzT2JzZXJ2YWJsZUZyb21HZXR0ZXIodGhpcy5kYXRhLmZpZWxkcyk7XG4gIHJlYWRvbmx5IGluaXRpYWxWYWx1ZSQgPSBhc09ic2VydmFibGVGcm9tR2V0dGVyKHRoaXMuZGF0YS5pbml0aWFsVmFsdWUpO1xuXG4gIHJlYWRvbmx5IGhlYWRlciA9IHRoaXMuZGF0YS5oZWFkZXI7XG5cbiAgcmVhZG9ubHkgc3VibWl0QnV0dG9uQ29uZmlnID0ge1xuICAgIHRleHQ6ICdTdWJtaXQnLFxuICAgIC4uLnRoaXMuZGF0YS5zdWJtaXRCdXR0b25Db25maWdcbiAgfTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLl9maWVsZHNTdWIuc2V0U3ViKFxuICAgICAgdGhpcy5maWVsZHMkLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoKSkuc3Vic2NyaWJlKChmaWVsZHMpID0+IHtcbiAgICAgICAgdGhpcy5jb250ZXh0LmZpZWxkcyA9IGZpZWxkcztcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIHJlYWRvbmx5IGhhbmRsZVN1Ym1pdFZhbHVlOiBXb3JrVXNpbmdDb250ZXh0PE8+ID0gKHZhbHVlLCBjb250ZXh0KSA9PiB7XG4gICAgY29udGV4dC5zdWNjZXNzKCk7XG4gICAgdGhpcy5jbG9zZSh2YWx1ZSk7XG4gIH07XG5cbiAgc3RhdGljIG9wZW5EaWFsb2dXaXRoRm9ybTxPPihtYXREaWFsb2c6IE1hdERpYWxvZywgY29uZmlnOiBEYnhGb3JtQWN0aW9uRGlhbG9nQ29tcG9uZW50Q29uZmlnPE8+KTogTWF0RGlhbG9nUmVmPERieEZvcm1BY3Rpb25EaWFsb2dDb21wb25lbnQ8Tz4sIE1heWJlPE8+PiB7XG4gICAgY29uc3QgZGlhbG9nUmVmID0gbWF0RGlhbG9nLm9wZW4oRGJ4Rm9ybUFjdGlvbkRpYWxvZ0NvbXBvbmVudDxPPiwge1xuICAgICAgd2lkdGg6ICc5MHZ3JyxcbiAgICAgIG1heEhlaWdodDogJzMwMHB4JyxcbiAgICAgIG1heFdpZHRoOiAnNjAwcHgnLFxuICAgICAgLi4uY29uZmlnLmRpYWxvZyxcbiAgICAgIGRhdGE6IGNvbmZpZ1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIGRpYWxvZ1JlZjtcbiAgfVxufVxuIl19
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Directive, inject, input } from '@angular/core';
|
|
2
2
|
import { addSeconds, isPast } from 'date-fns';
|
|
3
3
|
import { of, combineLatest, exhaustMap, catchError, delay, filter, first, map, switchMap, distinctUntilChanged, shareReplay } from 'rxjs';
|
|
4
|
-
import { DbxActionContextStoreSourceInstance } from '@dereekb/dbx-core';
|
|
5
|
-
import { SubscriptionObject,
|
|
4
|
+
import { DbxActionContextStoreSourceInstance, cleanLockSet } from '@dereekb/dbx-core';
|
|
5
|
+
import { SubscriptionObject, asObservable, makeIsModifiedFunctionObservable } from '@dereekb/rxjs';
|
|
6
6
|
import { DbxFormState, DbxMutableForm } from '../../form/form';
|
|
7
7
|
import { toObservable } from '@angular/core/rxjs-interop';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
@@ -17,7 +17,17 @@ export const APP_ACTION_FORM_DISABLED_KEY = 'dbx_action_form';
|
|
|
17
17
|
export class DbxActionFormDirective {
|
|
18
18
|
form = inject((DbxMutableForm), { host: true });
|
|
19
19
|
source = inject((DbxActionContextStoreSourceInstance));
|
|
20
|
-
lockSet =
|
|
20
|
+
lockSet = cleanLockSet({
|
|
21
|
+
onDestroy: () => {
|
|
22
|
+
this.source.enable(APP_ACTION_FORM_DISABLED_KEY);
|
|
23
|
+
},
|
|
24
|
+
onLockSetDestroy: () => {
|
|
25
|
+
this._triggeredSub.destroy();
|
|
26
|
+
this._isCompleteSub.destroy();
|
|
27
|
+
this._isWorkingSub.destroy();
|
|
28
|
+
this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, false);
|
|
29
|
+
}
|
|
30
|
+
});
|
|
21
31
|
/**
|
|
22
32
|
* Whether or not to disable the form while the action is working.
|
|
23
33
|
*
|
|
@@ -124,15 +134,6 @@ export class DbxActionFormDirective {
|
|
|
124
134
|
this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, disable);
|
|
125
135
|
});
|
|
126
136
|
}
|
|
127
|
-
ngOnDestroy() {
|
|
128
|
-
this.source.enable(APP_ACTION_FORM_DISABLED_KEY);
|
|
129
|
-
this.lockSet.destroyOnNextUnlock(() => {
|
|
130
|
-
this._triggeredSub.destroy();
|
|
131
|
-
this._isCompleteSub.destroy();
|
|
132
|
-
this._isWorkingSub.destroy();
|
|
133
|
-
this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, false);
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
137
|
checkIsValidAndIsModified(value, overrides) {
|
|
137
138
|
const { isModifiedFunction: overrideIsModifiedFunction, isValidFunction: overrideIsValidFunction } = overrides ?? {};
|
|
138
139
|
const isValidFunctionObs = overrideIsValidFunction != null ? of(overrideIsValidFunction) : this.isValidFunction$;
|
|
@@ -164,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
164
165
|
standalone: true
|
|
165
166
|
}]
|
|
166
167
|
}], ctorParameters: () => [] });
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.action.directive.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-form/src/lib/form/action/form.action.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnInit, OnDestroy, inject, input } from '@angular/core';\nimport { addSeconds, isPast } from 'date-fns';\nimport { Observable, of, combineLatest, exhaustMap, catchError, delay, filter, first, map, switchMap, distinctUntilChanged, shareReplay } from 'rxjs';\nimport { DbxActionContextStoreSourceInstance, DbxActionValueGetterResult } from '@dereekb/dbx-core';\nimport { SubscriptionObject, LockSet, IsModifiedFunction, IsValidFunction, ObservableOrValue, asObservable, IsEqualFunction, makeIsModifiedFunctionObservable } from '@dereekb/rxjs';\nimport { DbxFormState, DbxMutableForm } from '../../form/form';\nimport { IsModified, IsValid, MapFunction, Maybe } from '@dereekb/util';\nimport { toObservable } from '@angular/core/rxjs-interop';\n\nexport const APP_ACTION_FORM_DISABLED_KEY = 'dbx_action_form';\n\nexport type DbxActionFormMapValueFunction<T, O> = MapFunction<T, ObservableOrValue<DbxActionValueGetterResult<O>>>;\n\n/**\n * Used with an action to bind a form to an action as it's value source.\n *\n * If the form has errors when the action is trigger, it will reject the action.\n *\n * If the source is not considered modified, the trigger will be ignored.\n */\n@Directive({\n  selector: '[dbxActionForm]',\n  standalone: true\n})\nexport class DbxActionFormDirective<T = object, O = T> implements OnInit, OnDestroy {\n  readonly form = inject(DbxMutableForm<T>, { host: true });\n  readonly source = inject(DbxActionContextStoreSourceInstance<O, unknown>);\n\n  readonly lockSet = new LockSet();\n\n  /**\n   * Whether or not to disable the form while the action is working.\n   *\n   * Defaults to true.\n   */\n  readonly dbxActionFormDisabledOnWorking = input<Maybe<boolean>>(true);\n\n  /**\n   * Optional validator that checks whether or not the value is\n   * ready to send before the context store is marked enabled.\n   */\n  readonly dbxActionFormIsValid = input<Maybe<IsValidFunction<T>>>();\n\n  /**\n   * Optional function that checks whether or not the value is still the same/equal.\n   */\n  readonly dbxActionFormIsEqual = input<Maybe<IsEqualFunction<T>>>();\n\n  /**\n   * Optional function that checks whether or not the value has been modified.\n   *\n   * If dbxActionFormIsEqual is provided, this will be ignored.\n   */\n  readonly dbxActionFormIsModified = input<Maybe<IsModifiedFunction<T>>>();\n\n  /**\n   * Optional function that maps the form's value to the source's value.\n   */\n  readonly dbxActionFormMapValue = input<Maybe<DbxActionFormMapValueFunction<T, O>>>();\n\n  readonly dbxActionFormDisabledOnWorking$ = toObservable(this.dbxActionFormDisabledOnWorking);\n\n  readonly isValidFunction$ = toObservable(this.dbxActionFormIsValid).pipe(\n    map((x) => x ?? (() => of(true))),\n    shareReplay(1)\n  );\n  readonly isModifiedFunction$: Observable<IsModifiedFunction<T>> = makeIsModifiedFunctionObservable({\n    isModified: toObservable(this.dbxActionFormIsModified),\n    isEqual: toObservable(this.dbxActionFormIsEqual)\n  }).pipe(shareReplay(1));\n\n  readonly mapValueFunction$: Observable<Maybe<DbxActionFormMapValueFunction<T, O>>> = toObservable(this.dbxActionFormMapValue);\n\n  private readonly _triggeredSub = new SubscriptionObject();\n  private readonly _isCompleteSub = new SubscriptionObject();\n  private readonly _isWorkingSub = new SubscriptionObject();\n\n  constructor() {\n    if (this.form.lockSet) {\n      this.lockSet.addChildLockSet(this.form.lockSet, 'form');\n    }\n\n    this.lockSet.addChildLockSet(this.source.lockSet, 'source');\n  }\n\n  ngOnInit(): void {\n    // Pass data from the form to the source when triggered.\n    this._triggeredSub.subscription = this.source.triggered$\n      .pipe(\n        switchMap(() =>\n          this.form.stream$.pipe(\n            first(),\n            exhaustMap((stream) => {\n              const { isComplete } = stream;\n              const doNothing = {}; // nothing, form not complete\n\n              let obs: Observable<DbxActionValueGetterResult<O>>;\n\n              if (isComplete) {\n                obs = this.form.getValue().pipe(\n                  first(),\n                  exhaustMap((value) =>\n                    this.preCheckReadyValue(value).pipe(\n                      first(),\n                      switchMap((canContinue) => {\n                        if (canContinue) {\n                          return this.readyValue(value).pipe(first());\n                        } else {\n                          return of(doNothing);\n                        }\n                      }),\n                      catchError((error) => of({ reject: error }))\n                    )\n                  )\n                );\n              } else {\n                obs = of(doNothing);\n              }\n\n              return obs;\n            })\n          )\n        )\n      )\n      .subscribe((result: DbxActionValueGetterResult<O>) => {\n        if (result.reject) {\n          this.source.reject(result.reject);\n        } else if (result.value != null) {\n          this.source.readyValue(result.value);\n        } else {\n          // value isn't ready\n        }\n      });\n\n    // Update the enabled/disabled state\n    this._isCompleteSub.subscription = this.form.stream$\n      .pipe(\n        delay(0),\n        filter((x) => x.state !== DbxFormState.INITIALIZING),\n        switchMap((event) => {\n          return this.form.getValue().pipe(\n            first(),\n            exhaustMap((value) => {\n              // Use both changes count and whether or not something was in the past to guage whether or not the item has been touched.\n              // Angular Form's untouched is whether or not focus has been lost but we can still receive value updates.\n              // More than a certain amount of updates implies that it is being typed into/used.\n              // 3 changes and 2 seconds are arbitrary values derived from guesses about any slow/late changes that may come from external directives for setup.\n              const isProbablyTouched = !event.untouched || ((event.changesCount ?? 0) > 3 && isPast(addSeconds(event.lastResetAt ?? new Date(), 2)));\n\n              // create overrides\n              const returnFalseFunction = () => of(false);\n\n              const runIsValidCheck = event.isComplete;\n              const isValidFunction: Maybe<IsValidFunction<T>> = runIsValidCheck ? undefined : returnFalseFunction;\n\n              const isConsideredModified = event.pristine === false && isProbablyTouched;\n              const isModifiedFunction: Maybe<IsModifiedFunction<T>> = isConsideredModified ? undefined : returnFalseFunction;\n\n              return this.checkIsValidAndIsModified(value, { isValidFunction, isModifiedFunction }).pipe(\n                map(([valid, modified]: [boolean, boolean]) => ({ valid, modified, value, event })),\n                first()\n              );\n            })\n          );\n        })\n      )\n      .subscribe(({ valid, modified /*, value, event */ }) => {\n        // console.log('x: ', value, event, valid, modified);\n\n        // Update Modified State\n        this.source.setIsModified(modified);\n\n        // Disable if the form is not yet complete/valid.\n        this.source.enable(APP_ACTION_FORM_DISABLED_KEY, valid);\n      });\n\n    // Watch the working state and disable form while working\n    this._isWorkingSub.subscription = combineLatest([this.source.isWorking$, this.dbxActionFormDisabledOnWorking$])\n      .pipe(\n        map(([isWorking, disableFormWhileWorking]: [boolean, Maybe<boolean>]) => disableFormWhileWorking !== false && isWorking),\n        distinctUntilChanged()\n      )\n      .subscribe((disable) => {\n        this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, disable);\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.source.enable(APP_ACTION_FORM_DISABLED_KEY);\n    this.lockSet.destroyOnNextUnlock(() => {\n      this._triggeredSub.destroy();\n      this._isCompleteSub.destroy();\n      this._isWorkingSub.destroy();\n      this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, false);\n    });\n  }\n\n  checkIsValidAndIsModified(value: T, overrides?: CheckValidAndModifiedOverrides<T>): Observable<[IsValid, IsModified]> {\n    const { isModifiedFunction: overrideIsModifiedFunction, isValidFunction: overrideIsValidFunction } = overrides ?? {};\n    const isValidFunctionObs = overrideIsValidFunction != null ? of(overrideIsValidFunction) : this.isValidFunction$;\n    const isModifiedFunctionObs = overrideIsModifiedFunction != null ? of(overrideIsModifiedFunction) : this.isModifiedFunction$;\n\n    return combineLatest([isValidFunctionObs, isModifiedFunctionObs]).pipe(\n      switchMap(([isValid, isModified]) => {\n        return combineLatest([isValid(value), isModified(value)]).pipe(map(([valid, modified]) => [valid, modified] as [boolean, boolean]));\n      })\n    );\n  }\n\n  protected preCheckReadyValue(value: T): Observable<[IsValid, IsModified]> {\n    return this.checkIsValidAndIsModified(value);\n  }\n\n  protected readyValue(value: T): Observable<DbxActionValueGetterResult<O>> {\n    return this.mapValueFunction$.pipe(\n      switchMap((mapFunction) => {\n        if (mapFunction) {\n          return asObservable(mapFunction(value));\n        } else {\n          return of({ value: value as unknown as O });\n        }\n      })\n    );\n  }\n}\n\ninterface CheckValidAndModifiedOverrides<T> {\n  isModifiedFunction?: Maybe<IsModifiedFunction<T>>;\n  isValidFunction?: Maybe<IsValidFunction<T>>;\n}\n"]}
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.action.directive.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-form/src/lib/form/action/form.action.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnInit, inject, input } from '@angular/core';\nimport { addSeconds, isPast } from 'date-fns';\nimport { Observable, of, combineLatest, exhaustMap, catchError, delay, filter, first, map, switchMap, distinctUntilChanged, shareReplay } from 'rxjs';\nimport { DbxActionContextStoreSourceInstance, DbxActionValueGetterResult, cleanLockSet } from '@dereekb/dbx-core';\nimport { SubscriptionObject, IsModifiedFunction, IsValidFunction, ObservableOrValue, asObservable, IsEqualFunction, makeIsModifiedFunctionObservable } from '@dereekb/rxjs';\nimport { DbxFormState, DbxMutableForm } from '../../form/form';\nimport { IsModified, IsValid, MapFunction, Maybe } from '@dereekb/util';\nimport { toObservable } from '@angular/core/rxjs-interop';\n\nexport const APP_ACTION_FORM_DISABLED_KEY = 'dbx_action_form';\n\nexport type DbxActionFormMapValueFunction<T, O> = MapFunction<T, ObservableOrValue<DbxActionValueGetterResult<O>>>;\n\n/**\n * Used with an action to bind a form to an action as it's value source.\n *\n * If the form has errors when the action is trigger, it will reject the action.\n *\n * If the source is not considered modified, the trigger will be ignored.\n */\n@Directive({\n  selector: '[dbxActionForm]',\n  standalone: true\n})\nexport class DbxActionFormDirective<T = object, O = T> implements OnInit {\n  readonly form = inject(DbxMutableForm<T>, { host: true });\n  readonly source = inject(DbxActionContextStoreSourceInstance<O, unknown>);\n\n  readonly lockSet = cleanLockSet({\n    onDestroy: () => {\n      this.source.enable(APP_ACTION_FORM_DISABLED_KEY);\n    },\n    onLockSetDestroy: () => {\n      this._triggeredSub.destroy();\n      this._isCompleteSub.destroy();\n      this._isWorkingSub.destroy();\n      this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, false);\n    }\n  });\n\n  /**\n   * Whether or not to disable the form while the action is working.\n   *\n   * Defaults to true.\n   */\n  readonly dbxActionFormDisabledOnWorking = input<Maybe<boolean>>(true);\n\n  /**\n   * Optional validator that checks whether or not the value is\n   * ready to send before the context store is marked enabled.\n   */\n  readonly dbxActionFormIsValid = input<Maybe<IsValidFunction<T>>>();\n\n  /**\n   * Optional function that checks whether or not the value is still the same/equal.\n   */\n  readonly dbxActionFormIsEqual = input<Maybe<IsEqualFunction<T>>>();\n\n  /**\n   * Optional function that checks whether or not the value has been modified.\n   *\n   * If dbxActionFormIsEqual is provided, this will be ignored.\n   */\n  readonly dbxActionFormIsModified = input<Maybe<IsModifiedFunction<T>>>();\n\n  /**\n   * Optional function that maps the form's value to the source's value.\n   */\n  readonly dbxActionFormMapValue = input<Maybe<DbxActionFormMapValueFunction<T, O>>>();\n\n  readonly dbxActionFormDisabledOnWorking$ = toObservable(this.dbxActionFormDisabledOnWorking);\n\n  readonly isValidFunction$ = toObservable(this.dbxActionFormIsValid).pipe(\n    map((x) => x ?? (() => of(true))),\n    shareReplay(1)\n  );\n  readonly isModifiedFunction$: Observable<IsModifiedFunction<T>> = makeIsModifiedFunctionObservable({\n    isModified: toObservable(this.dbxActionFormIsModified),\n    isEqual: toObservable(this.dbxActionFormIsEqual)\n  }).pipe(shareReplay(1));\n\n  readonly mapValueFunction$: Observable<Maybe<DbxActionFormMapValueFunction<T, O>>> = toObservable(this.dbxActionFormMapValue);\n\n  private readonly _triggeredSub = new SubscriptionObject();\n  private readonly _isCompleteSub = new SubscriptionObject();\n  private readonly _isWorkingSub = new SubscriptionObject();\n\n  constructor() {\n    if (this.form.lockSet) {\n      this.lockSet.addChildLockSet(this.form.lockSet, 'form');\n    }\n\n    this.lockSet.addChildLockSet(this.source.lockSet, 'source');\n  }\n\n  ngOnInit(): void {\n    // Pass data from the form to the source when triggered.\n    this._triggeredSub.subscription = this.source.triggered$\n      .pipe(\n        switchMap(() =>\n          this.form.stream$.pipe(\n            first(),\n            exhaustMap((stream) => {\n              const { isComplete } = stream;\n              const doNothing = {}; // nothing, form not complete\n\n              let obs: Observable<DbxActionValueGetterResult<O>>;\n\n              if (isComplete) {\n                obs = this.form.getValue().pipe(\n                  first(),\n                  exhaustMap((value) =>\n                    this.preCheckReadyValue(value).pipe(\n                      first(),\n                      switchMap((canContinue) => {\n                        if (canContinue) {\n                          return this.readyValue(value).pipe(first());\n                        } else {\n                          return of(doNothing);\n                        }\n                      }),\n                      catchError((error) => of({ reject: error }))\n                    )\n                  )\n                );\n              } else {\n                obs = of(doNothing);\n              }\n\n              return obs;\n            })\n          )\n        )\n      )\n      .subscribe((result: DbxActionValueGetterResult<O>) => {\n        if (result.reject) {\n          this.source.reject(result.reject);\n        } else if (result.value != null) {\n          this.source.readyValue(result.value);\n        } else {\n          // value isn't ready\n        }\n      });\n\n    // Update the enabled/disabled state\n    this._isCompleteSub.subscription = this.form.stream$\n      .pipe(\n        delay(0),\n        filter((x) => x.state !== DbxFormState.INITIALIZING),\n        switchMap((event) => {\n          return this.form.getValue().pipe(\n            first(),\n            exhaustMap((value) => {\n              // Use both changes count and whether or not something was in the past to guage whether or not the item has been touched.\n              // Angular Form's untouched is whether or not focus has been lost but we can still receive value updates.\n              // More than a certain amount of updates implies that it is being typed into/used.\n              // 3 changes and 2 seconds are arbitrary values derived from guesses about any slow/late changes that may come from external directives for setup.\n              const isProbablyTouched = !event.untouched || ((event.changesCount ?? 0) > 3 && isPast(addSeconds(event.lastResetAt ?? new Date(), 2)));\n\n              // create overrides\n              const returnFalseFunction = () => of(false);\n\n              const runIsValidCheck = event.isComplete;\n              const isValidFunction: Maybe<IsValidFunction<T>> = runIsValidCheck ? undefined : returnFalseFunction;\n\n              const isConsideredModified = event.pristine === false && isProbablyTouched;\n              const isModifiedFunction: Maybe<IsModifiedFunction<T>> = isConsideredModified ? undefined : returnFalseFunction;\n\n              return this.checkIsValidAndIsModified(value, { isValidFunction, isModifiedFunction }).pipe(\n                map(([valid, modified]: [boolean, boolean]) => ({ valid, modified, value, event })),\n                first()\n              );\n            })\n          );\n        })\n      )\n      .subscribe(({ valid, modified /*, value, event */ }) => {\n        // console.log('x: ', value, event, valid, modified);\n\n        // Update Modified State\n        this.source.setIsModified(modified);\n\n        // Disable if the form is not yet complete/valid.\n        this.source.enable(APP_ACTION_FORM_DISABLED_KEY, valid);\n      });\n\n    // Watch the working state and disable form while working\n    this._isWorkingSub.subscription = combineLatest([this.source.isWorking$, this.dbxActionFormDisabledOnWorking$])\n      .pipe(\n        map(([isWorking, disableFormWhileWorking]: [boolean, Maybe<boolean>]) => disableFormWhileWorking !== false && isWorking),\n        distinctUntilChanged()\n      )\n      .subscribe((disable) => {\n        this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, disable);\n      });\n  }\n\n  checkIsValidAndIsModified(value: T, overrides?: CheckValidAndModifiedOverrides<T>): Observable<[IsValid, IsModified]> {\n    const { isModifiedFunction: overrideIsModifiedFunction, isValidFunction: overrideIsValidFunction } = overrides ?? {};\n    const isValidFunctionObs = overrideIsValidFunction != null ? of(overrideIsValidFunction) : this.isValidFunction$;\n    const isModifiedFunctionObs = overrideIsModifiedFunction != null ? of(overrideIsModifiedFunction) : this.isModifiedFunction$;\n\n    return combineLatest([isValidFunctionObs, isModifiedFunctionObs]).pipe(\n      switchMap(([isValid, isModified]) => {\n        return combineLatest([isValid(value), isModified(value)]).pipe(map(([valid, modified]) => [valid, modified] as [boolean, boolean]));\n      })\n    );\n  }\n\n  protected preCheckReadyValue(value: T): Observable<[IsValid, IsModified]> {\n    return this.checkIsValidAndIsModified(value);\n  }\n\n  protected readyValue(value: T): Observable<DbxActionValueGetterResult<O>> {\n    return this.mapValueFunction$.pipe(\n      switchMap((mapFunction) => {\n        if (mapFunction) {\n          return asObservable(mapFunction(value));\n        } else {\n          return of({ value: value as unknown as O });\n        }\n      })\n    );\n  }\n}\n\ninterface CheckValidAndModifiedOverrides<T> {\n  isModifiedFunction?: Maybe<IsModifiedFunction<T>>;\n  isValidFunction?: Maybe<IsValidFunction<T>>;\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Directive, inject, output } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { cleanSubscription } from '@dereekb/dbx-core';
|
|
3
3
|
import { first, mergeMap, delay, map } from 'rxjs';
|
|
4
4
|
import { DbxForm } from '../form';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -8,11 +8,13 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
*
|
|
9
9
|
* Emits undefined when the form is incomplete, and the value when the form is complete.
|
|
10
10
|
*/
|
|
11
|
-
export class DbxFormValueChangeDirective
|
|
11
|
+
export class DbxFormValueChangeDirective {
|
|
12
12
|
form = inject((DbxForm), { host: true });
|
|
13
13
|
dbxFormValueChange = output();
|
|
14
|
+
_sub = cleanSubscription();
|
|
14
15
|
ngOnInit() {
|
|
15
|
-
|
|
16
|
+
// specifically call within ngOnInit to ensure first emission occurs after the form is initialized.
|
|
17
|
+
this._sub.setSub(this.form.stream$
|
|
16
18
|
.pipe(mergeMap((x) => this.form.getValue().pipe(first(), map((value) => ({ isComplete: x.isComplete, value })))), delay(0))
|
|
17
19
|
.subscribe(({ isComplete, value }) => {
|
|
18
20
|
if (isComplete) {
|
|
@@ -21,10 +23,10 @@ export class DbxFormValueChangeDirective extends AbstractSubscriptionDirective {
|
|
|
21
23
|
else {
|
|
22
24
|
this.dbxFormValueChange.emit(undefined);
|
|
23
25
|
}
|
|
24
|
-
});
|
|
26
|
+
}));
|
|
25
27
|
}
|
|
26
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormValueChangeDirective, deps:
|
|
27
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DbxFormValueChangeDirective, isStandalone: true, selector: "[dbxFormValueChange]", outputs: { dbxFormValueChange: "dbxFormValueChange" },
|
|
28
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormValueChangeDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
29
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DbxFormValueChangeDirective, isStandalone: true, selector: "[dbxFormValueChange]", outputs: { dbxFormValueChange: "dbxFormValueChange" }, ngImport: i0 });
|
|
28
30
|
}
|
|
29
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormValueChangeDirective, decorators: [{
|
|
30
32
|
type: Directive,
|
|
@@ -33,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
33
35
|
standalone: true
|
|
34
36
|
}]
|
|
35
37
|
}] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5jaGFuZ2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtL2lvL2Zvcm0uY2hhbmdlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFdEQsT0FBTyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNuRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sU0FBUyxDQUFDOztBQUVsQzs7OztHQUlHO0FBS0gsTUFBTSxPQUFPLDJCQUEyQjtJQUM3QixJQUFJLEdBQUcsTUFBTSxDQUFDLENBQUEsT0FBVSxDQUFBLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUUxQyxrQkFBa0IsR0FBRyxNQUFNLEVBQVksQ0FBQztJQUU5QixJQUFJLEdBQUcsaUJBQWlCLEVBQUUsQ0FBQztJQUU5QyxRQUFRO1FBQ04sbUdBQW1HO1FBQ25HLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUNkLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTzthQUNkLElBQUksQ0FDSCxRQUFRLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBSSxDQUN2QixLQUFLLEVBQUUsRUFDUCxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDLFVBQVUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQ3RELENBQ0YsRUFDRCxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQ1Q7YUFDQSxTQUFTLENBQUMsQ0FBQyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ25DLElBQUksVUFBVSxFQUFFLENBQUM7Z0JBQ2YsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN0QyxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUMxQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQ0wsQ0FBQztJQUNKLENBQUM7d0dBNUJVLDJCQUEyQjs0RkFBM0IsMkJBQTJCOzs0RkFBM0IsMkJBQTJCO2tCQUp2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgT25Jbml0LCBpbmplY3QsIG91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgY2xlYW5TdWJzY3JpcHRpb24gfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBmaXJzdCwgbWVyZ2VNYXAsIGRlbGF5LCBtYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IERieEZvcm0gfSBmcm9tICcuLi9mb3JtJztcblxuLyoqXG4gKiBVc2VkIHRvIHNlZSBmb3JtIHZhbHVlIGNoYW5nZXMuXG4gKlxuICogRW1pdHMgdW5kZWZpbmVkIHdoZW4gdGhlIGZvcm0gaXMgaW5jb21wbGV0ZSwgYW5kIHRoZSB2YWx1ZSB3aGVuIHRoZSBmb3JtIGlzIGNvbXBsZXRlLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZGJ4Rm9ybVZhbHVlQ2hhbmdlXScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRGJ4Rm9ybVZhbHVlQ2hhbmdlRGlyZWN0aXZlPFQ+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgcmVhZG9ubHkgZm9ybSA9IGluamVjdChEYnhGb3JtPFQ+LCB7IGhvc3Q6IHRydWUgfSk7XG5cbiAgcmVhZG9ubHkgZGJ4Rm9ybVZhbHVlQ2hhbmdlID0gb3V0cHV0PE1heWJlPFQ+PigpO1xuXG4gIHByb3RlY3RlZCByZWFkb25seSBfc3ViID0gY2xlYW5TdWJzY3JpcHRpb24oKTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAvLyBzcGVjaWZpY2FsbHkgY2FsbCB3aXRoaW4gbmdPbkluaXQgdG8gZW5zdXJlIGZpcnN0IGVtaXNzaW9uIG9jY3VycyBhZnRlciB0aGUgZm9ybSBpcyBpbml0aWFsaXplZC5cbiAgICB0aGlzLl9zdWIuc2V0U3ViKFxuICAgICAgdGhpcy5mb3JtLnN0cmVhbSRcbiAgICAgICAgLnBpcGUoXG4gICAgICAgICAgbWVyZ2VNYXAoKHgpID0+XG4gICAgICAgICAgICB0aGlzLmZvcm0uZ2V0VmFsdWUoKS5waXBlKFxuICAgICAgICAgICAgICBmaXJzdCgpLFxuICAgICAgICAgICAgICBtYXAoKHZhbHVlKSA9PiAoeyBpc0NvbXBsZXRlOiB4LmlzQ29tcGxldGUsIHZhbHVlIH0pKVxuICAgICAgICAgICAgKVxuICAgICAgICAgICksXG4gICAgICAgICAgZGVsYXkoMClcbiAgICAgICAgKVxuICAgICAgICAuc3Vic2NyaWJlKCh7IGlzQ29tcGxldGUsIHZhbHVlIH0pID0+IHtcbiAgICAgICAgICBpZiAoaXNDb21wbGV0ZSkge1xuICAgICAgICAgICAgdGhpcy5kYnhGb3JtVmFsdWVDaGFuZ2UuZW1pdCh2YWx1ZSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRoaXMuZGJ4Rm9ybVZhbHVlQ2hhbmdlLmVtaXQodW5kZWZpbmVkKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuIl19
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { distinctUntilChanged, filter, map, switchMap, combineLatest, EMPTY, exhaustMap, takeUntil, Subject, tap, shareReplay, throttleTime } from 'rxjs';
|
|
2
2
|
import { Directive, effect, inject, input } from '@angular/core';
|
|
3
|
-
import { AbstractSubscriptionDirective } from '@dereekb/dbx-core';
|
|
4
3
|
import { DbxFormState, DbxMutableForm } from '../form';
|
|
5
4
|
import { asObservable, cleanup, errorOnEmissionsInPeriod } from '@dereekb/rxjs';
|
|
5
|
+
import { cleanSubscription } from '@dereekb/dbx-core';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export function dbxFormSourceObservable(form, inputObs, modeObs) {
|
|
8
8
|
return dbxFormSourceObservableFromStream(form.stream$, inputObs, modeObs);
|
|
@@ -65,10 +65,11 @@ export function dbxFormSourceObservableFromStream(streamObs, inputObs, modeObs)
|
|
|
65
65
|
/**
|
|
66
66
|
* Used with a FormComponent to set the value based on the input value.
|
|
67
67
|
*/
|
|
68
|
-
export class DbxFormSourceDirective
|
|
68
|
+
export class DbxFormSourceDirective {
|
|
69
69
|
form = inject((DbxMutableForm), { host: true });
|
|
70
70
|
dbxFormSourceMode = input();
|
|
71
71
|
dbxFormSource = input();
|
|
72
|
+
_effectSub = cleanSubscription();
|
|
72
73
|
_setFormSourceObservableEffect = effect(() => {
|
|
73
74
|
const formSource = this.dbxFormSource();
|
|
74
75
|
const mode = this.dbxFormSourceMode() ?? 'reset';
|
|
@@ -78,12 +79,10 @@ export class DbxFormSourceDirective extends AbstractSubscriptionDirective {
|
|
|
78
79
|
this.form.setValue(x);
|
|
79
80
|
});
|
|
80
81
|
}
|
|
81
|
-
this.
|
|
82
|
-
}, {
|
|
83
|
-
|
|
84
|
-
});
|
|
85
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormSourceDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
86
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFormSourceDirective, isStandalone: true, selector: "[dbxFormSource]", inputs: { dbxFormSourceMode: { classPropertyName: "dbxFormSourceMode", publicName: "dbxFormSourceMode", isSignal: true, isRequired: false, transformFunction: null }, dbxFormSource: { classPropertyName: "dbxFormSource", publicName: "dbxFormSource", isSignal: true, isRequired: false, transformFunction: null } }, usesInheritance: true, ngImport: i0 });
|
|
82
|
+
this._effectSub.setSub(subscription);
|
|
83
|
+
}, { allowSignalWrites: true });
|
|
84
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormSourceDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
85
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFormSourceDirective, isStandalone: true, selector: "[dbxFormSource]", inputs: { dbxFormSourceMode: { classPropertyName: "dbxFormSourceMode", publicName: "dbxFormSourceMode", isSignal: true, isRequired: false, transformFunction: null }, dbxFormSource: { classPropertyName: "dbxFormSource", publicName: "dbxFormSource", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 });
|
|
87
86
|
}
|
|
88
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormSourceDirective, decorators: [{
|
|
89
88
|
type: Directive,
|
|
@@ -92,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
92
91
|
standalone: true
|
|
93
92
|
}]
|
|
94
93
|
}] });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.input.directive.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-form/src/lib/form/io/form.input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { distinctUntilChanged, filter, map, switchMap, combineLatest, Observable, EMPTY, exhaustMap, takeUntil, Subject, tap, shareReplay, throttleTime, Subscription } from 'rxjs';\nimport { Directive, OnDestroy, effect, inject, input } from '@angular/core';\nimport { AbstractSubscriptionDirective } from '@dereekb/dbx-core';\nimport { DbxFormState, DbxFormStateRef, DbxMutableForm } from '../form';\nimport { type Maybe } from '@dereekb/util';\nimport { asObservable, ObservableOrValue, cleanup, errorOnEmissionsInPeriod } from '@dereekb/rxjs';\n\nexport function dbxFormSourceObservable<T>(form: DbxMutableForm, inputObs: ObservableOrValue<T>, modeObs: Observable<DbxFormSourceDirectiveMode>): Observable<T> {\n  return dbxFormSourceObservableFromStream(form.stream$, inputObs, modeObs);\n}\n\nexport function dbxFormSourceObservableFromStream<T>(streamObs: Observable<DbxFormStateRef>, inputObs: ObservableOrValue<T>, modeObs: ObservableOrValue<DbxFormSourceDirectiveMode>): Observable<T> {\n  const value$ = asObservable(inputObs).pipe(shareReplay(1)); // catch/share the latest emission\n\n  const state$ = streamObs.pipe(\n    map((x) => x.state),\n    distinctUntilChanged()\n  );\n\n  const mode$ = asObservable(modeObs).pipe(distinctUntilChanged());\n\n  return combineLatest([mode$, value$]).pipe(\n    map((x) => x[0]),\n    distinctUntilChanged(),\n    switchMap((mode: DbxFormSourceDirectiveMode) => {\n      if (mode === 'reset') {\n        // reset only\n        return state$.pipe(\n          exhaustMap((state: DbxFormState) => {\n            if (state === DbxFormState.RESET) {\n              let firstValueSent = false;\n              const doneSubject = new Subject();\n\n              return combineLatest([value$, state$]).pipe(\n                map(([value, state]) => {\n                  if (!firstValueSent || state === DbxFormState.RESET) {\n                    return [value, true] as [T, boolean]; // always forward the first value.\n                  } else {\n                    return [value, false] as [T, boolean];\n                  }\n                }),\n                tap(([_, send]) => {\n                  firstValueSent = true;\n                  if (!send) {\n                    doneSubject.next(undefined);\n                  }\n                }),\n                filter(([_, send]) => send),\n                map(([value, _]) => value),\n                takeUntil(doneSubject),\n                cleanup(() => {\n                  doneSubject.complete();\n                })\n              );\n            } else {\n              return EMPTY;\n            }\n          })\n        );\n      } else {\n        // pass any updated value while not initializing.\n        return state$.pipe(\n          map((x) => x === DbxFormState.INITIALIZING),\n          distinctUntilChanged(),\n          switchMap((initializing: boolean) => {\n            if (initializing) {\n              return EMPTY;\n            } else {\n              let valueObs = value$;\n\n              if (mode === 'always') {\n                valueObs = valueObs.pipe(\n                  throttleTime(10, undefined, { leading: true, trailing: true }),\n                  errorOnEmissionsInPeriod({\n                    period: 1000,\n                    maxEmissionsPerPeriod: 50,\n                    onError: () => {\n                      console.error('dbxFormSourceObservableFromStream: Error thrown due to too many emissions. There may be an unintentional loop being triggered by dbxFormSource. Typically this can occur in cases where the dbxFormSource directive is used at the same time as dbxFormValueChange directive and the same value is being pushed.');\n                    }\n                  })\n                );\n              }\n\n              return valueObs;\n            }\n          })\n        );\n      }\n    })\n  );\n}\n\n/**\n * DbxFormSourceDirective modes that define when to copy data from the source.\n *\n * - reset: only copy data when the form is reset.\n * - always: always copy data when the data observable emits a value. Has a throttle of 20ms to prevent too many emissions. If emissions occur in a manner that appears to be a loop (more than 30 emissions in 1 second), then an error is thrown and warning printed to the console.\n * - every: equal to always, but has no throttle or error message warning.\n */\nexport type DbxFormSourceDirectiveMode = 'reset' | 'always' | 'every';\n\n/**\n * Used with a FormComponent to set the value based on the input value.\n */\n@Directive({\n  selector: '[dbxFormSource]',\n  standalone: true\n})\nexport class DbxFormSourceDirective<T = unknown> extends AbstractSubscriptionDirective implements OnDestroy {\n  readonly form = inject(DbxMutableForm<T>, { host: true });\n\n  readonly dbxFormSourceMode = input<Maybe<DbxFormSourceDirectiveMode>>();\n  readonly dbxFormSource = input<Maybe<ObservableOrValue<Maybe<Partial<T>>>>>();\n\n  protected readonly _setFormSourceObservableEffect = effect(\n    () => {\n      const formSource = this.dbxFormSource();\n      const mode: DbxFormSourceDirectiveMode = this.dbxFormSourceMode() ?? 'reset';\n\n      let subscription: Maybe<Subscription>;\n\n      if (formSource) {\n        subscription = dbxFormSourceObservableFromStream(this.form.stream$, formSource, mode).subscribe((x) => {\n          this.form.setValue(x);\n        });\n      }\n\n      this.sub = subscription;\n    },\n    {\n      allowSignalWrites: true\n    }\n  );\n}\n"]}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.input.directive.js","sourceRoot":"","sources":["../../../../../../../packages/dbx-form/src/lib/form/io/form.input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { distinctUntilChanged, filter, map, switchMap, combineLatest, Observable, EMPTY, exhaustMap, takeUntil, Subject, tap, shareReplay, throttleTime, Subscription } from 'rxjs';\nimport { Directive, effect, inject, input } from '@angular/core';\nimport { DbxFormState, DbxFormStateRef, DbxMutableForm } from '../form';\nimport { type Maybe } from '@dereekb/util';\nimport { asObservable, ObservableOrValue, cleanup, errorOnEmissionsInPeriod } from '@dereekb/rxjs';\nimport { cleanSubscription } from '@dereekb/dbx-core';\n\nexport function dbxFormSourceObservable<T>(form: DbxMutableForm, inputObs: ObservableOrValue<T>, modeObs: Observable<DbxFormSourceDirectiveMode>): Observable<T> {\n  return dbxFormSourceObservableFromStream(form.stream$, inputObs, modeObs);\n}\n\nexport function dbxFormSourceObservableFromStream<T>(streamObs: Observable<DbxFormStateRef>, inputObs: ObservableOrValue<T>, modeObs: ObservableOrValue<DbxFormSourceDirectiveMode>): Observable<T> {\n  const value$ = asObservable(inputObs).pipe(shareReplay(1)); // catch/share the latest emission\n\n  const state$ = streamObs.pipe(\n    map((x) => x.state),\n    distinctUntilChanged()\n  );\n\n  const mode$ = asObservable(modeObs).pipe(distinctUntilChanged());\n\n  return combineLatest([mode$, value$]).pipe(\n    map((x) => x[0]),\n    distinctUntilChanged(),\n    switchMap((mode: DbxFormSourceDirectiveMode) => {\n      if (mode === 'reset') {\n        // reset only\n        return state$.pipe(\n          exhaustMap((state: DbxFormState) => {\n            if (state === DbxFormState.RESET) {\n              let firstValueSent = false;\n              const doneSubject = new Subject();\n\n              return combineLatest([value$, state$]).pipe(\n                map(([value, state]) => {\n                  if (!firstValueSent || state === DbxFormState.RESET) {\n                    return [value, true] as [T, boolean]; // always forward the first value.\n                  } else {\n                    return [value, false] as [T, boolean];\n                  }\n                }),\n                tap(([_, send]) => {\n                  firstValueSent = true;\n                  if (!send) {\n                    doneSubject.next(undefined);\n                  }\n                }),\n                filter(([_, send]) => send),\n                map(([value, _]) => value),\n                takeUntil(doneSubject),\n                cleanup(() => {\n                  doneSubject.complete();\n                })\n              );\n            } else {\n              return EMPTY;\n            }\n          })\n        );\n      } else {\n        // pass any updated value while not initializing.\n        return state$.pipe(\n          map((x) => x === DbxFormState.INITIALIZING),\n          distinctUntilChanged(),\n          switchMap((initializing: boolean) => {\n            if (initializing) {\n              return EMPTY;\n            } else {\n              let valueObs = value$;\n\n              if (mode === 'always') {\n                valueObs = valueObs.pipe(\n                  throttleTime(10, undefined, { leading: true, trailing: true }),\n                  errorOnEmissionsInPeriod({\n                    period: 1000,\n                    maxEmissionsPerPeriod: 50,\n                    onError: () => {\n                      console.error('dbxFormSourceObservableFromStream: Error thrown due to too many emissions. There may be an unintentional loop being triggered by dbxFormSource. Typically this can occur in cases where the dbxFormSource directive is used at the same time as dbxFormValueChange directive and the same value is being pushed.');\n                    }\n                  })\n                );\n              }\n\n              return valueObs;\n            }\n          })\n        );\n      }\n    })\n  );\n}\n\n/**\n * DbxFormSourceDirective modes that define when to copy data from the source.\n *\n * - reset: only copy data when the form is reset.\n * - always: always copy data when the data observable emits a value. Has a throttle of 20ms to prevent too many emissions. If emissions occur in a manner that appears to be a loop (more than 30 emissions in 1 second), then an error is thrown and warning printed to the console.\n * - every: equal to always, but has no throttle or error message warning.\n */\nexport type DbxFormSourceDirectiveMode = 'reset' | 'always' | 'every';\n\n/**\n * Used with a FormComponent to set the value based on the input value.\n */\n@Directive({\n  selector: '[dbxFormSource]',\n  standalone: true\n})\nexport class DbxFormSourceDirective<T = unknown> {\n  readonly form = inject(DbxMutableForm<T>, { host: true });\n\n  readonly dbxFormSourceMode = input<Maybe<DbxFormSourceDirectiveMode>>();\n  readonly dbxFormSource = input<Maybe<ObservableOrValue<Maybe<Partial<T>>>>>();\n\n  protected readonly _effectSub = cleanSubscription();\n  protected readonly _setFormSourceObservableEffect = effect(\n    () => {\n      const formSource = this.dbxFormSource();\n      const mode: DbxFormSourceDirectiveMode = this.dbxFormSourceMode() ?? 'reset';\n\n      let subscription: Maybe<Subscription>;\n\n      if (formSource) {\n        subscription = dbxFormSourceObservableFromStream(this.form.stream$, formSource, mode).subscribe((x) => {\n          this.form.setValue(x);\n        });\n      }\n\n      this._effectSub.setSub(subscription);\n    },\n    { allowSignalWrites: true }\n  );\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Directive, inject, input } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { cleanSubscription } from '@dereekb/dbx-core';
|
|
3
3
|
import { DbxMutableForm } from '../../form/form';
|
|
4
4
|
import { filterMaybe, maybeValueFromObservableOrValue, valueFromFinishedLoadingState } from '@dereekb/rxjs';
|
|
5
5
|
import { dbxFormSourceObservableFromStream } from './form.input.directive';
|
|
@@ -11,20 +11,19 @@ const DEFAULT_DBX_FORM_LOADING_SOURCE_DIRECTIVE_MODE = 'reset';
|
|
|
11
11
|
*
|
|
12
12
|
* Only passes non-null values from the source.
|
|
13
13
|
*/
|
|
14
|
-
export class DbxFormLoadingSourceDirective
|
|
14
|
+
export class DbxFormLoadingSourceDirective {
|
|
15
15
|
form = inject((DbxMutableForm), { host: true });
|
|
16
16
|
dbxFormLoadingSourceMode = input(DEFAULT_DBX_FORM_LOADING_SOURCE_DIRECTIVE_MODE, { transform: (x) => x ?? DEFAULT_DBX_FORM_LOADING_SOURCE_DIRECTIVE_MODE });
|
|
17
17
|
dbxFormLoadingSource = input();
|
|
18
18
|
mode$ = toObservable(this.dbxFormLoadingSourceMode);
|
|
19
19
|
source$ = toObservable(this.dbxFormLoadingSource).pipe(maybeValueFromObservableOrValue(), filterMaybe(), valueFromFinishedLoadingState());
|
|
20
20
|
constructor() {
|
|
21
|
-
|
|
22
|
-
this.sub = dbxFormSourceObservableFromStream(this.form.stream$, this.source$, this.mode$).subscribe((x) => {
|
|
21
|
+
cleanSubscription(dbxFormSourceObservableFromStream(this.form.stream$, this.source$, this.mode$).subscribe((x) => {
|
|
23
22
|
this.form.setValue(x);
|
|
24
|
-
});
|
|
23
|
+
}));
|
|
25
24
|
}
|
|
26
25
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormLoadingSourceDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
27
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFormLoadingSourceDirective, isStandalone: true, selector: "[dbxFormLoadingSource]", inputs: { dbxFormLoadingSourceMode: { classPropertyName: "dbxFormLoadingSourceMode", publicName: "dbxFormLoadingSourceMode", isSignal: true, isRequired: false, transformFunction: null }, dbxFormLoadingSource: { classPropertyName: "dbxFormLoadingSource", publicName: "dbxFormLoadingSource", isSignal: true, isRequired: false, transformFunction: null } },
|
|
26
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: DbxFormLoadingSourceDirective, isStandalone: true, selector: "[dbxFormLoadingSource]", inputs: { dbxFormLoadingSourceMode: { classPropertyName: "dbxFormLoadingSourceMode", publicName: "dbxFormLoadingSourceMode", isSignal: true, isRequired: false, transformFunction: null }, dbxFormLoadingSource: { classPropertyName: "dbxFormLoadingSource", publicName: "dbxFormLoadingSource", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0 });
|
|
28
27
|
}
|
|
29
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormLoadingSourceDirective, decorators: [{
|
|
30
29
|
type: Directive,
|
|
@@ -33,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
33
32
|
standalone: true
|
|
34
33
|
}]
|
|
35
34
|
}], ctorParameters: () => [] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5sb2FkaW5nLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL3NyYy9saWIvZm9ybS9pby9mb3JtLmxvYWRpbmcuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDakQsT0FBTyxFQUF3QyxXQUFXLEVBQUUsK0JBQStCLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEosT0FBTyxFQUFFLGlDQUFpQyxFQUE4QixNQUFNLHdCQUF3QixDQUFDO0FBRXZHLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFFMUQsTUFBTSw4Q0FBOEMsR0FBK0IsT0FBTyxDQUFDO0FBRTNGOzs7O0dBSUc7QUFLSCxNQUFNLE9BQU8sNkJBQTZCO0lBQy9CLElBQUksR0FBRyxNQUFNLENBQUMsQ0FBQSxjQUFpQixDQUFBLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUVqRCx3QkFBd0IsR0FBRyxLQUFLLENBQWdFLDhDQUE4QyxFQUFFLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksOENBQThDLEVBQUUsQ0FBQyxDQUFDO0lBQzNOLG9CQUFvQixHQUFHLEtBQUssRUFBMkMsQ0FBQztJQUV4RSxLQUFLLEdBQUcsWUFBWSxDQUFDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO0lBQ3BELE9BQU8sR0FBeUIsWUFBWSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLElBQUksQ0FBQywrQkFBK0IsRUFBRSxFQUFFLFdBQVcsRUFBRSxFQUFFLDZCQUE2QixFQUFFLENBQUMsQ0FBQztJQUV6SztRQUNFLGlCQUFpQixDQUNmLGlDQUFpQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO1lBQzdGLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDSixDQUFDO3dHQWZVLDZCQUE2Qjs0RkFBN0IsNkJBQTZCOzs0RkFBN0IsNkJBQTZCO2tCQUp6QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0LCBpbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgY2xlYW5TdWJzY3JpcHRpb24gfSBmcm9tICdAZGVyZWVrYi9kYngtY29yZSc7XG5pbXBvcnQgeyBEYnhNdXRhYmxlRm9ybSB9IGZyb20gJy4uLy4uL2Zvcm0vZm9ybSc7XG5pbXBvcnQgeyBMb2FkaW5nU3RhdGUsIE1heWJlT2JzZXJ2YWJsZU9yVmFsdWUsIGZpbHRlck1heWJlLCBtYXliZVZhbHVlRnJvbU9ic2VydmFibGVPclZhbHVlLCB2YWx1ZUZyb21GaW5pc2hlZExvYWRpbmdTdGF0ZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgZGJ4Rm9ybVNvdXJjZU9ic2VydmFibGVGcm9tU3RyZWFtLCBEYnhGb3JtU291cmNlRGlyZWN0aXZlTW9kZSB9IGZyb20gJy4vZm9ybS5pbnB1dC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IHRvT2JzZXJ2YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcblxuY29uc3QgREVGQVVMVF9EQlhfRk9STV9MT0FESU5HX1NPVVJDRV9ESVJFQ1RJVkVfTU9ERTogRGJ4Rm9ybVNvdXJjZURpcmVjdGl2ZU1vZGUgPSAncmVzZXQnO1xuXG4vKipcbiAqIFVzZWQgd2l0aCBhIEZvcm1Db21wb25lbnQgdG8gc2V0IHRoZSB2YWx1ZSBmcm9tIGEgTG9hZGluZ1N0YXRlIHdoZW4gdGhlIHZhbHVlIGlzIGF2YWlsYWJsZS5cbiAqXG4gKiBPbmx5IHBhc3NlcyBub24tbnVsbCB2YWx1ZXMgZnJvbSB0aGUgc291cmNlLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZGJ4Rm9ybUxvYWRpbmdTb3VyY2VdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhGb3JtTG9hZGluZ1NvdXJjZURpcmVjdGl2ZTxUIGV4dGVuZHMgb2JqZWN0ID0gb2JqZWN0PiB7XG4gIHJlYWRvbmx5IGZvcm0gPSBpbmplY3QoRGJ4TXV0YWJsZUZvcm08VD4sIHsgaG9zdDogdHJ1ZSB9KTtcblxuICByZWFkb25seSBkYnhGb3JtTG9hZGluZ1NvdXJjZU1vZGUgPSBpbnB1dDxEYnhGb3JtU291cmNlRGlyZWN0aXZlTW9kZSwgTWF5YmU8RGJ4Rm9ybVNvdXJjZURpcmVjdGl2ZU1vZGU+PihERUZBVUxUX0RCWF9GT1JNX0xPQURJTkdfU09VUkNFX0RJUkVDVElWRV9NT0RFLCB7IHRyYW5zZm9ybTogKHgpID0+IHggPz8gREVGQVVMVF9EQlhfRk9STV9MT0FESU5HX1NPVVJDRV9ESVJFQ1RJVkVfTU9ERSB9KTtcbiAgcmVhZG9ubHkgZGJ4Rm9ybUxvYWRpbmdTb3VyY2UgPSBpbnB1dDxNYXliZU9ic2VydmFibGVPclZhbHVlPExvYWRpbmdTdGF0ZTxUPj4+KCk7XG5cbiAgcmVhZG9ubHkgbW9kZSQgPSB0b09ic2VydmFibGUodGhpcy5kYnhGb3JtTG9hZGluZ1NvdXJjZU1vZGUpO1xuICByZWFkb25seSBzb3VyY2UkOiBPYnNlcnZhYmxlPE1heWJlPFQ+PiA9IHRvT2JzZXJ2YWJsZSh0aGlzLmRieEZvcm1Mb2FkaW5nU291cmNlKS5waXBlKG1heWJlVmFsdWVGcm9tT2JzZXJ2YWJsZU9yVmFsdWUoKSwgZmlsdGVyTWF5YmUoKSwgdmFsdWVGcm9tRmluaXNoZWRMb2FkaW5nU3RhdGUoKSk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgY2xlYW5TdWJzY3JpcHRpb24oXG4gICAgICBkYnhGb3JtU291cmNlT2JzZXJ2YWJsZUZyb21TdHJlYW0odGhpcy5mb3JtLnN0cmVhbSQsIHRoaXMuc291cmNlJCwgdGhpcy5tb2RlJCkuc3Vic2NyaWJlKCh4KSA9PiB7XG4gICAgICAgIHRoaXMuZm9ybS5zZXRWYWx1ZSh4KTtcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { DbxInjectionComponent, cleanSubscription } from '@dereekb/dbx-core';
|
|
3
3
|
import { switchMapFilterMaybe } from '@dereekb/rxjs';
|
|
4
4
|
import { shareReplay, distinctUntilChanged, map } from 'rxjs';
|
|
5
5
|
import { ReactiveFormsModule } from '@angular/forms';
|
|
@@ -15,18 +15,18 @@ import * as i1 from "@angular/forms";
|
|
|
15
15
|
import * as i2 from "@angular/material/checkbox";
|
|
16
16
|
import * as i3 from "@angular/material/core";
|
|
17
17
|
import * as i4 from "@angular/material/icon";
|
|
18
|
-
export class DbxChecklistItemContentComponent
|
|
18
|
+
export class DbxChecklistItemContentComponent {
|
|
19
19
|
checklistItemFieldComponent = inject((DbxChecklistItemFieldComponent));
|
|
20
20
|
config = {
|
|
21
21
|
componentClass: this.checklistItemFieldComponent.componentClass,
|
|
22
22
|
init: (instance) => {
|
|
23
|
-
this.
|
|
23
|
+
cleanSubscription(this.checklistItemFieldComponent.displayContent$.subscribe((content) => {
|
|
24
24
|
instance.setDisplayContent(content);
|
|
25
|
-
});
|
|
25
|
+
}));
|
|
26
26
|
}
|
|
27
27
|
};
|
|
28
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxChecklistItemContentComponent, deps:
|
|
29
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DbxChecklistItemContentComponent, isStandalone: true, selector: "dbx-checklist-item-content-component",
|
|
28
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxChecklistItemContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
29
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DbxChecklistItemContentComponent, isStandalone: true, selector: "dbx-checklist-item-content-component", ngImport: i0, template: `
|
|
30
30
|
<dbx-injection [config]="config"></dbx-injection>
|
|
31
31
|
`, isInline: true, dependencies: [{ kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
32
32
|
}
|
|
@@ -74,6 +74,7 @@ export class DbxChecklistItemFieldComponent extends FieldType {
|
|
|
74
74
|
return this.checklistField.componentClass ?? DbxDefaultChecklistItemFieldDisplayComponent;
|
|
75
75
|
}
|
|
76
76
|
ngOnInit() {
|
|
77
|
+
// field prop is finally available here
|
|
77
78
|
this._displayContentObs.set(this.checklistField.displayContent);
|
|
78
79
|
}
|
|
79
80
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxChecklistItemFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -83,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
83
84
|
type: Component,
|
|
84
85
|
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ReactiveFormsModule, MatCheckboxModule, DbxAnchorComponent, MatRippleModule, MatIconModule, DbxChecklistItemContentComponent], template: "<div class=\"dbx-checklist-item-wrapper\" [formGroup]=\"formGroup\">\n @if (label) {\n <div class=\"dbx-checklist-item-label\">{{ label }}</div>\n }\n <div class=\"dbx-checklist-item\">\n <div class=\"dbx-checklist-item-check\">\n <mat-checkbox [formControlName]=\"formControlName\"></mat-checkbox>\n </div>\n <div class=\"dbx-checklist-item-content-wrapper\">\n <dbx-anchor [block]=\"true\" [anchor]=\"anchorSignal()\">\n <div class=\"dbx-checklist-item-content\" matRipple [matRippleDisabled]=\"rippleDisabledSignal()\">\n <dbx-checklist-item-content-component></dbx-checklist-item-content-component>\n <span class=\"spacer\"></span>\n @if (!rippleDisabledSignal()) {\n <mat-icon>navigate_next</mat-icon>\n }\n </div>\n </dbx-anchor>\n </div>\n </div>\n @if (description) {\n <div class=\"dbx-hint\">{{ description }}</div>\n }\n</div>\n" }]
|
|
85
86
|
}] });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checklist.item.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/src/lib/formly/field/checklist/checklist.item.field.component.ts","../../../../../../../../packages/dbx-form/src/lib/formly/field/checklist/checklist.item.field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, Type, inject, signal } from '@angular/core';\nimport { DbxInjectionComponentConfig, AbstractSubscriptionDirective, DbxInjectionComponent } from '@dereekb/dbx-core';\nimport { switchMapFilterMaybe } from '@dereekb/rxjs';\nimport { shareReplay, distinctUntilChanged, map, Observable } from 'rxjs';\nimport { ValidationErrors, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { FieldType, FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { ChecklistItemFieldDisplayComponent, ChecklistItemDisplayContent } from './checklist.item';\nimport { DbxDefaultChecklistItemFieldDisplayComponent } from './checklist.item.field.content.default.component';\nimport { type Maybe } from '@dereekb/util';\nimport { toSignal, toObservable } from '@angular/core/rxjs-interop';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatRippleModule } from '@angular/material/core';\nimport { MatIconModule } from '@angular/material/icon';\nimport { DbxAnchorComponent } from '@dereekb/dbx-web';\n\n@Component({\n  selector: 'dbx-checklist-item-content-component',\n  template: `\n    <dbx-injection [config]=\"config\"></dbx-injection>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [DbxInjectionComponent]\n})\nexport class DbxChecklistItemContentComponent<T = unknown> extends AbstractSubscriptionDirective {\n  readonly checklistItemFieldComponent = inject(DbxChecklistItemFieldComponent<T>);\n\n  readonly config: DbxInjectionComponentConfig<ChecklistItemFieldDisplayComponent<T>> = {\n    componentClass: this.checklistItemFieldComponent.componentClass,\n    init: (instance) => {\n      this.sub = this.checklistItemFieldComponent.displayContent$.subscribe((content: ChecklistItemDisplayContent<T>) => {\n        instance.setDisplayContent(content);\n      });\n    }\n  };\n}\n\nexport interface DbxChecklistItemFieldProps<T = unknown> extends FormlyFieldProps {\n  /**\n   * Observable used to retrieve content to display for the item.\n   */\n  readonly displayContent: Observable<ChecklistItemDisplayContent<T>>;\n  /**\n   * Custom component class to use by default.\n   */\n  readonly componentClass?: Type<ChecklistItemFieldDisplayComponent<T>>;\n}\n\n@Component({\n  templateUrl: 'checklist.item.field.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [ReactiveFormsModule, MatCheckboxModule, DbxAnchorComponent, MatRippleModule, MatIconModule, DbxChecklistItemContentComponent]\n})\nexport class DbxChecklistItemFieldComponent<T = unknown> extends FieldType<FieldTypeConfig<DbxChecklistItemFieldProps<T>>> implements OnInit {\n  private readonly _displayContentObs = signal<Maybe<Observable<ChecklistItemDisplayContent<T>>>>(undefined);\n\n  readonly displayContent$: Observable<ChecklistItemDisplayContent<T>> = toObservable(this._displayContentObs).pipe(switchMapFilterMaybe(), distinctUntilChanged(), shareReplay(1));\n\n  readonly anchor$ = this.displayContent$.pipe(\n    map((x: ChecklistItemDisplayContent<T>) => x.anchor),\n    shareReplay(1)\n  );\n\n  readonly rippleDisabled$ = this.displayContent$.pipe(\n    map((x: ChecklistItemDisplayContent<T>) => x.ripple === false || (x.ripple !== true && !x.anchor)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly anchorSignal = toSignal(this.anchor$);\n  readonly rippleDisabledSignal = toSignal(this.rippleDisabled$, { initialValue: false });\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get formControlName(): string {\n    return this.key as string;\n  }\n\n  get label(): Maybe<string> {\n    return this.props.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get required(): Maybe<boolean> {\n    return this.props.required;\n  }\n\n  get checklistField(): DbxChecklistItemFieldProps<T> {\n    return this.props;\n  }\n\n  get errors(): Maybe<ValidationErrors> {\n    return this.field.formControl?.errors;\n  }\n\n  get componentClass(): Type<ChecklistItemFieldDisplayComponent<T>> {\n    return this.checklistField.componentClass ?? DbxDefaultChecklistItemFieldDisplayComponent;\n  }\n\n  ngOnInit() {\n    this._displayContentObs.set(this.checklistField.displayContent);\n  }\n}\n","<div class=\"dbx-checklist-item-wrapper\" [formGroup]=\"formGroup\">\n  @if (label) {\n    <div class=\"dbx-checklist-item-label\">{{ label }}</div>\n  }\n  <div class=\"dbx-checklist-item\">\n    <div class=\"dbx-checklist-item-check\">\n      <mat-checkbox [formControlName]=\"formControlName\"></mat-checkbox>\n    </div>\n    <div class=\"dbx-checklist-item-content-wrapper\">\n      <dbx-anchor [block]=\"true\" [anchor]=\"anchorSignal()\">\n        <div class=\"dbx-checklist-item-content\" matRipple [matRippleDisabled]=\"rippleDisabledSignal()\">\n          <dbx-checklist-item-content-component></dbx-checklist-item-content-component>\n          <span class=\"spacer\"></span>\n          @if (!rippleDisabledSignal()) {\n            <mat-icon>navigate_next</mat-icon>\n          }\n        </div>\n      </dbx-anchor>\n    </div>\n  </div>\n  @if (description) {\n    <div class=\"dbx-hint\">{{ description }}</div>\n  }\n</div>\n"]}
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checklist.item.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/src/lib/formly/field/checklist/checklist.item.field.component.ts","../../../../../../../../packages/dbx-form/src/lib/formly/field/checklist/checklist.item.field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, Type, inject, signal } from '@angular/core';\nimport { DbxInjectionComponentConfig, DbxInjectionComponent, cleanSubscription } from '@dereekb/dbx-core';\nimport { switchMapFilterMaybe } from '@dereekb/rxjs';\nimport { shareReplay, distinctUntilChanged, map, Observable } from 'rxjs';\nimport { ValidationErrors, FormGroup, ReactiveFormsModule } from '@angular/forms';\nimport { FieldType, FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { ChecklistItemFieldDisplayComponent, ChecklistItemDisplayContent } from './checklist.item';\nimport { DbxDefaultChecklistItemFieldDisplayComponent } from './checklist.item.field.content.default.component';\nimport { type Maybe } from '@dereekb/util';\nimport { toSignal, toObservable } from '@angular/core/rxjs-interop';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatRippleModule } from '@angular/material/core';\nimport { MatIconModule } from '@angular/material/icon';\nimport { DbxAnchorComponent } from '@dereekb/dbx-web';\n\n@Component({\n  selector: 'dbx-checklist-item-content-component',\n  template: `\n    <dbx-injection [config]=\"config\"></dbx-injection>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [DbxInjectionComponent]\n})\nexport class DbxChecklistItemContentComponent<T = unknown> {\n  readonly checklistItemFieldComponent = inject(DbxChecklistItemFieldComponent<T>);\n\n  readonly config: DbxInjectionComponentConfig<ChecklistItemFieldDisplayComponent<T>> = {\n    componentClass: this.checklistItemFieldComponent.componentClass,\n    init: (instance) => {\n      cleanSubscription(\n        this.checklistItemFieldComponent.displayContent$.subscribe((content: ChecklistItemDisplayContent<T>) => {\n          instance.setDisplayContent(content);\n        })\n      );\n    }\n  };\n}\n\nexport interface DbxChecklistItemFieldProps<T = unknown> extends FormlyFieldProps {\n  /**\n   * Observable used to retrieve content to display for the item.\n   */\n  readonly displayContent: Observable<ChecklistItemDisplayContent<T>>;\n  /**\n   * Custom component class to use by default.\n   */\n  readonly componentClass?: Type<ChecklistItemFieldDisplayComponent<T>>;\n}\n\n@Component({\n  templateUrl: 'checklist.item.field.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [ReactiveFormsModule, MatCheckboxModule, DbxAnchorComponent, MatRippleModule, MatIconModule, DbxChecklistItemContentComponent]\n})\nexport class DbxChecklistItemFieldComponent<T = unknown> extends FieldType<FieldTypeConfig<DbxChecklistItemFieldProps<T>>> implements OnInit {\n  private readonly _displayContentObs = signal<Maybe<Observable<ChecklistItemDisplayContent<T>>>>(undefined);\n\n  readonly displayContent$: Observable<ChecklistItemDisplayContent<T>> = toObservable(this._displayContentObs).pipe(switchMapFilterMaybe(), distinctUntilChanged(), shareReplay(1));\n\n  readonly anchor$ = this.displayContent$.pipe(\n    map((x: ChecklistItemDisplayContent<T>) => x.anchor),\n    shareReplay(1)\n  );\n\n  readonly rippleDisabled$ = this.displayContent$.pipe(\n    map((x: ChecklistItemDisplayContent<T>) => x.ripple === false || (x.ripple !== true && !x.anchor)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly anchorSignal = toSignal(this.anchor$);\n  readonly rippleDisabledSignal = toSignal(this.rippleDisabled$, { initialValue: false });\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get formControlName(): string {\n    return this.key as string;\n  }\n\n  get label(): Maybe<string> {\n    return this.props.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get required(): Maybe<boolean> {\n    return this.props.required;\n  }\n\n  get checklistField(): DbxChecklistItemFieldProps<T> {\n    return this.props;\n  }\n\n  get errors(): Maybe<ValidationErrors> {\n    return this.field.formControl?.errors;\n  }\n\n  get componentClass(): Type<ChecklistItemFieldDisplayComponent<T>> {\n    return this.checklistField.componentClass ?? DbxDefaultChecklistItemFieldDisplayComponent;\n  }\n\n  ngOnInit() {\n    // field prop is finally available here\n    this._displayContentObs.set(this.checklistField.displayContent);\n  }\n}\n","<div class=\"dbx-checklist-item-wrapper\" [formGroup]=\"formGroup\">\n  @if (label) {\n    <div class=\"dbx-checklist-item-label\">{{ label }}</div>\n  }\n  <div class=\"dbx-checklist-item\">\n    <div class=\"dbx-checklist-item-check\">\n      <mat-checkbox [formControlName]=\"formControlName\"></mat-checkbox>\n    </div>\n    <div class=\"dbx-checklist-item-content-wrapper\">\n      <dbx-anchor [block]=\"true\" [anchor]=\"anchorSignal()\">\n        <div class=\"dbx-checklist-item-content\" matRipple [matRippleDisabled]=\"rippleDisabledSignal()\">\n          <dbx-checklist-item-content-component></dbx-checklist-item-content-component>\n          <span class=\"spacer\"></span>\n          @if (!rippleDisabledSignal()) {\n            <mat-icon>navigate_next</mat-icon>\n          }\n        </div>\n      </dbx-anchor>\n    </div>\n  </div>\n  @if (description) {\n    <div class=\"dbx-hint\">{{ description }}</div>\n  }\n</div>\n"]}
|
|
@@ -4,7 +4,7 @@ import { SimpleLoadingContext, SubscriptionObject } from '@dereekb/rxjs';
|
|
|
4
4
|
import { FieldWrapper } from '@ngx-formly/core';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
/**
|
|
7
|
-
* Adds a loading bar to help signify
|
|
7
|
+
* Adds a loading bar to help signify asynchronous work is occuring.
|
|
8
8
|
*
|
|
9
9
|
* By default shows loading during asynchronous validation of a field (FormControl status is "PENDING")
|
|
10
10
|
*/
|
|
@@ -42,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
42
42
|
standalone: true
|
|
43
43
|
}]
|
|
44
44
|
}] });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2luZy53cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL3NyYy9saWIvZm9ybWx5L2ZpZWxkL3dyYXBwZXIvd29ya2luZy53cmFwcGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekUsT0FBTyxFQUFFLFlBQVksRUFBcUIsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPbkU7Ozs7R0FJRztBQVlILE1BQU0sT0FBTyw4QkFBK0IsU0FBUSxZQUE0RDtJQUNyRyxHQUFHLEdBQUcsSUFBSSxrQkFBa0IsRUFBRSxDQUFDO0lBQy9CLGNBQWMsR0FBRyxJQUFJLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRTFELFFBQVE7UUFDTixJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsV0FBVyxFQUFFLGFBQWEsQ0FBQyxTQUFTLENBQUM7WUFDaEUsSUFBSSxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDLEtBQUssU0FBUyxDQUFDO1NBQzdELENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUM5QixJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ3JCLENBQUM7d0dBYlUsOEJBQThCOzRGQUE5Qiw4QkFBOEIsK0ZBVi9COzs7OztHQUtULDREQUNTLG1CQUFtQjs7NEZBSWxCLDhCQUE4QjtrQkFYMUMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUU7Ozs7O0dBS1Q7b0JBQ0QsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQzlCLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPbkluaXQsIE9uRGVzdHJveSwgQ29tcG9uZW50LCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4TG9hZGluZ0NvbXBvbmVudCB9IGZyb20gJ0BkZXJlZWtiL2RieC13ZWInO1xuaW1wb3J0IHsgU2ltcGxlTG9hZGluZ0NvbnRleHQsIFN1YnNjcmlwdGlvbk9iamVjdCB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgRmllbGRXcmFwcGVyLCBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuXG4vKipcbiAqIE5vIGNvbmZpZ3VyYWJsZSB2YWx1ZSBmb3Igbm93LlxuICovXG5leHBvcnQgdHlwZSBEYnhGb3JtV29ya2luZ1dyYXBwZXJDb25maWcgPSBvYmplY3Q7XG5cbi8qKlxuICogQWRkcyBhIGxvYWRpbmcgYmFyIHRvIGhlbHAgc2lnbmlmeSBhc3luY2hyb25vdXMgd29yayBpcyBvY2N1cmluZy5cbiAqXG4gKiBCeSBkZWZhdWx0IHNob3dzIGxvYWRpbmcgZHVyaW5nIGFzeW5jaHJvbm91cyB2YWxpZGF0aW9uIG9mIGEgZmllbGQgKEZvcm1Db250cm9sIHN0YXR1cyBpcyBcIlBFTkRJTkdcIilcbiAqL1xuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImRieC1mb3JtLXdvcmtpbmctd3JhcHBlclwiPlxuICAgICAgPG5nLWNvbnRhaW5lciAjZmllbGRDb21wb25lbnQ+PC9uZy1jb250YWluZXI+XG4gICAgICA8ZGJ4LWxvYWRpbmcgW2xpbmVhcl09XCJ0cnVlXCIgW2NvbnRleHRdPVwid29ya2luZ0NvbnRleHRcIj48L2RieC1sb2FkaW5nPlxuICAgIDwvZGl2PlxuICBgLFxuICBpbXBvcnRzOiBbRGJ4TG9hZGluZ0NvbXBvbmVudF0sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieEZvcm1Xb3JraW5nV3JhcHBlckNvbXBvbmVudCBleHRlbmRzIEZpZWxkV3JhcHBlcjxGb3JtbHlGaWVsZENvbmZpZzxEYnhGb3JtV29ya2luZ1dyYXBwZXJDb25maWc+PiBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgcmVhZG9ubHkgc3ViID0gbmV3IFN1YnNjcmlwdGlvbk9iamVjdCgpO1xuICByZWFkb25seSB3b3JraW5nQ29udGV4dCA9IG5ldyBTaW1wbGVMb2FkaW5nQ29udGV4dChmYWxzZSk7XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5zdWIuc3Vic2NyaXB0aW9uID0gdGhpcy5mb3JtQ29udHJvbD8uc3RhdHVzQ2hhbmdlcy5zdWJzY3JpYmUoe1xuICAgICAgbmV4dDogKHgpID0+IHRoaXMud29ya2luZ0NvbnRleHQuc2V0TG9hZGluZyh4ID09PSAnUEVORElORycpXG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLndvcmtpbmdDb250ZXh0LmRlc3Ryb3koKTtcbiAgICB0aGlzLnN1Yi5kZXN0cm95KCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
32
32
|
}
|
|
33
33
|
}]
|
|
34
34
|
}] });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLmZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZm9ybS9zZWFyY2guZm9ybS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbEQsT0FBTyxFQUFFLEdBQUcsRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUN2QyxPQUFPLEVBQUUsc0NBQXNDLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM3RSxPQUFPLEVBQUUsdUJBQXVCLEVBQStELE1BQU0sYUFBYSxDQUFDO0FBQ25ILE9BQU8sRUFBRSxtQ0FBbUMsRUFBRSwrQkFBK0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3BILE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7QUFjbEYsTUFBTSxPQUFPLDBCQUEyQixTQUFRLHNDQUFtRztJQUN4SSxNQUFNLEdBQUcsTUFBTSxFQUFVLENBQUM7SUFFMUIsT0FBTyxHQUFvQyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUMsQ0FBQyxDQUFDO0lBRTNHLGFBQWEsQ0FBQyxLQUFtQztRQUMvQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7d0dBUFUsMEJBQTBCOzRGQUExQiwwQkFBMEIsNEpBUDFCLCtCQUErQixFQUFFLGlEQUhsQzs7R0FFVCwyREFFUyxtQ0FBbUMsaUlBQUUsMkJBQTJCOzs0RkFNL0QsMEJBQTBCO2tCQVp0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFFBQVEsRUFBRTs7R0FFVDtvQkFDRCxTQUFTLEVBQUUsK0JBQStCLEVBQUU7b0JBQzVDLE9BQU8sRUFBRSxDQUFDLG1DQUFtQyxFQUFFLDJCQUEyQixDQUFDO29CQUMzRSxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNKLEtBQUssRUFBRSw4QkFBOEI7cUJBQ3RDO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1seUZpZWxkQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBtYXAsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEFic3RyYWN0Q29uZmlnQXN5bmNGb3JtbHlGb3JtRGlyZWN0aXZlIH0gZnJvbSAnLi4vZm9ybWx5LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBkYnhGb3JtU2VhcmNoRm9ybUZpZWxkcywgRGJ4Rm9ybVNlYXJjaEZvcm1GaWVsZHNDb25maWcsIERieEZvcm1TZWFyY2hGb3JtRmllbGRzVmFsdWUgfSBmcm9tICcuL2Zvcm0uZm9ybSc7XG5pbXBvcnQgeyBEYnhGb3JtbHlGb3JtQ29tcG9uZW50SW1wb3J0c01vZHVsZSwgZGJ4Rm9ybWx5Rm9ybUNvbXBvbmVudFByb3ZpZGVycyB9IGZyb20gJy4uL2Zvcm1seS5jb21wb25lbnQudGVtcGxhdGUnO1xuaW1wb3J0IHsgRGJ4Rm9ybVZhbHVlQ2hhbmdlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZm9ybS9pby9mb3JtLmNoYW5nZS5kaXJlY3RpdmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkYngtZm9ybS1zZWFyY2gtZm9ybScsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRieC1mb3JtbHkgKGRieEZvcm1WYWx1ZUNoYW5nZSk9XCJzZWFyY2hDaGFuZ2VkKCRldmVudClcIj48L2RieC1mb3JtbHk+XG4gIGAsXG4gIHByb3ZpZGVyczogZGJ4Rm9ybWx5Rm9ybUNvbXBvbmVudFByb3ZpZGVycygpLFxuICBpbXBvcnRzOiBbRGJ4Rm9ybWx5Rm9ybUNvbXBvbmVudEltcG9ydHNNb2R1bGUsIERieEZvcm1WYWx1ZUNoYW5nZURpcmVjdGl2ZV0sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGhvc3Q6IHtcbiAgICBjbGFzczogJ2QtYmxvY2sgZGJ4LWZvcm0tc2VhcmNoLWZvcm0nXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgRGJ4Rm9ybVNlYXJjaEZvcm1Db21wb25lbnQgZXh0ZW5kcyBBYnN0cmFjdENvbmZpZ0FzeW5jRm9ybWx5Rm9ybURpcmVjdGl2ZTxEYnhGb3JtU2VhcmNoRm9ybUZpZWxkc1ZhbHVlLCBEYnhGb3JtU2VhcmNoRm9ybUZpZWxkc0NvbmZpZz4ge1xuICByZWFkb25seSBzZWFyY2ggPSBvdXRwdXQ8c3RyaW5nPigpO1xuXG4gIHJlYWRvbmx5IGZpZWxkcyQ6IE9ic2VydmFibGU8Rm9ybWx5RmllbGRDb25maWdbXT4gPSB0aGlzLmN1cnJlbnRDb25maWckLnBpcGUobWFwKGRieEZvcm1TZWFyY2hGb3JtRmllbGRzKSk7XG5cbiAgc2VhcmNoQ2hhbmdlZCh2YWx1ZTogRGJ4Rm9ybVNlYXJjaEZvcm1GaWVsZHNWYWx1ZSkge1xuICAgIHRoaXMuc2VhcmNoLmVtaXQodmFsdWUuc2VhcmNoID8/ICcnKTtcbiAgfVxufVxuIl19
|