@dereekb/dbx-form 12.6.21 → 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.
Files changed (25) hide show
  1. package/esm2022/lib/form/action/form.action.dialog.component.mjs +6 -10
  2. package/esm2022/lib/form/action/form.action.directive.mjs +14 -13
  3. package/esm2022/lib/form/io/form.change.directive.mjs +9 -7
  4. package/esm2022/lib/form/io/form.input.directive.mjs +8 -9
  5. package/esm2022/lib/form/io/form.loading.directive.mjs +6 -7
  6. package/esm2022/lib/formly/field/checklist/checklist.item.field.component.mjs +8 -7
  7. package/esm2022/lib/formly/field/wrapper/working.wrapper.component.mjs +2 -2
  8. package/esm2022/lib/formly/form/search.form.component.mjs +1 -1
  9. package/esm2022/lib/formly/formly.context.directive.mjs +1 -1
  10. package/esm2022/lib/formly/formly.directive.mjs +8 -13
  11. package/esm2022/lib/formly/formly.form.component.mjs +18 -19
  12. package/fesm2022/dereekb-dbx-form.mjs +61 -71
  13. package/fesm2022/dereekb-dbx-form.mjs.map +1 -1
  14. package/lib/form/action/form.action.dialog.component.d.ts +2 -3
  15. package/lib/form/action/form.action.directive.d.ts +4 -5
  16. package/lib/form/io/form.change.directive.d.ts +3 -3
  17. package/lib/form/io/form.input.directive.d.ts +2 -3
  18. package/lib/form/io/form.loading.directive.d.ts +1 -3
  19. package/lib/formly/field/checklist/checklist.item.field.component.d.ts +2 -2
  20. package/lib/formly/field/wrapper/working.wrapper.component.d.ts +1 -1
  21. package/lib/formly/form/search.form.component.d.ts +1 -2
  22. package/lib/formly/formly.context.directive.d.ts +1 -2
  23. package/lib/formly/formly.directive.d.ts +7 -9
  24. package/lib/formly/formly.form.component.d.ts +3 -4
  25. package/package.json +1 -1
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
20
20
  standalone: true
21
21
  }]
22
22
  }] });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LmNvbnRleHQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZm9ybWx5LmNvbnRleHQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQWEsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXRFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFFMUQ7O0dBRUc7QUFNSCxNQUFNLE9BQU8sK0JBQTZDLFNBQVEsZ0NBQW1DO0lBQzFGLE1BQU0sR0FBRyxLQUFLLENBQTZCLFNBQVMsRUFBRSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxDQUFDLENBQUM7SUFDcEYsT0FBTyxHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7d0dBRmxDLCtCQUErQjs0RkFBL0IsK0JBQStCLGdOQUgvQixvQkFBb0IsRUFBRTs7NEZBR3RCLCtCQUErQjtrQkFMM0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixTQUFTLEVBQUUsb0JBQW9CLEVBQUU7b0JBQ2pDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvcm1seUZpZWxkQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIE9uRGVzdHJveSwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHByb3ZpZGVGb3JtbHlDb250ZXh0IH0gZnJvbSAnLi9mb3JtbHkuY29udGV4dCc7XG5pbXBvcnQgeyBBYnN0cmFjdEFzeW5jRm9ybWx5Rm9ybURpcmVjdGl2ZSB9IGZyb20gJy4vZm9ybWx5LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyB0eXBlIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyB0b09ic2VydmFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5cbi8qKlxuICogUHJvdmlkZXMgYW4gRGJ4Rm9ybWx5Q29udGV4dCBhbmQgaGFzIGFuIGlucHV0IGZvciBmaWVsZHMuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tkYnhGb3JtbHlGaWVsZHNdJyxcbiAgcHJvdmlkZXJzOiBwcm92aWRlRm9ybWx5Q29udGV4dCgpLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIERieEZvcm1seUZpZWxkc0NvbnRleHREaXJlY3RpdmU8VCA9IHVua25vd24+IGV4dGVuZHMgQWJzdHJhY3RBc3luY0Zvcm1seUZvcm1EaXJlY3RpdmU8VD4gaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICByZWFkb25seSBmaWVsZHMgPSBpbnB1dDxNYXliZTxGb3JtbHlGaWVsZENvbmZpZ1tdPj4odW5kZWZpbmVkLCB7IGFsaWFzOiAnZGJ4Rm9ybWx5RmllbGRzJyB9KTtcbiAgcmVhZG9ubHkgZmllbGRzJCA9IHRvT2JzZXJ2YWJsZSh0aGlzLmZpZWxkcyk7XG59XG4iXX0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LmNvbnRleHQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZm9ybWx5LmNvbnRleHQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxnQ0FBZ0MsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXRFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFFMUQ7O0dBRUc7QUFNSCxNQUFNLE9BQU8sK0JBQTZDLFNBQVEsZ0NBQW1DO0lBQzFGLE1BQU0sR0FBRyxLQUFLLENBQTZCLFNBQVMsRUFBRSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxDQUFDLENBQUM7SUFDcEYsT0FBTyxHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7d0dBRmxDLCtCQUErQjs0RkFBL0IsK0JBQStCLGdOQUgvQixvQkFBb0IsRUFBRTs7NEZBR3RCLCtCQUErQjtrQkFMM0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixTQUFTLEVBQUUsb0JBQW9CLEVBQUU7b0JBQ2pDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvcm1seUZpZWxkQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBwcm92aWRlRm9ybWx5Q29udGV4dCB9IGZyb20gJy4vZm9ybWx5LmNvbnRleHQnO1xuaW1wb3J0IHsgQWJzdHJhY3RBc3luY0Zvcm1seUZvcm1EaXJlY3RpdmUgfSBmcm9tICcuL2Zvcm1seS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgdHlwZSBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgdG9PYnNlcnZhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuXG4vKipcbiAqIFByb3ZpZGVzIGFuIERieEZvcm1seUNvbnRleHQgYW5kIGhhcyBhbiBpbnB1dCBmb3IgZmllbGRzLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZGJ4Rm9ybWx5RmllbGRzXScsXG4gIHByb3ZpZGVyczogcHJvdmlkZUZvcm1seUNvbnRleHQoKSxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBEYnhGb3JtbHlGaWVsZHNDb250ZXh0RGlyZWN0aXZlPFQgPSB1bmtub3duPiBleHRlbmRzIEFic3RyYWN0QXN5bmNGb3JtbHlGb3JtRGlyZWN0aXZlPFQ+IHtcbiAgcmVhZG9ubHkgZmllbGRzID0gaW5wdXQ8TWF5YmU8Rm9ybWx5RmllbGRDb25maWdbXT4+KHVuZGVmaW5lZCwgeyBhbGlhczogJ2RieEZvcm1seUZpZWxkcycgfSk7XG4gIHJlYWRvbmx5IGZpZWxkcyQgPSB0b09ic2VydmFibGUodGhpcy5maWVsZHMpO1xufVxuIl19
@@ -1,8 +1,9 @@
1
- import { SubscriptionObject, filterMaybe, maybeValueFromObservableOrValue } from '@dereekb/rxjs';
1
+ import { filterMaybe, maybeValueFromObservableOrValue } from '@dereekb/rxjs';
2
2
  import { shareReplay, distinctUntilChanged } from 'rxjs';
3
3
  import { Directive, inject, input, effect } from '@angular/core';
4
4
  import { DbxFormlyContext } from './formly.context';
5
5
  import { toObservable } from '@angular/core/rxjs-interop';
6
+ import { cleanSubscription } from '@dereekb/dbx-core';
6
7
  import * as i0 from "@angular/core";
7
8
  /**
8
9
  * Abstract component for wrapping a DbxFormlyContext.
@@ -12,10 +13,7 @@ import * as i0 from "@angular/core";
12
13
  export class AbstractFormlyFormDirective {
13
14
  context = inject((DbxFormlyContext), { self: true });
14
15
  disabled = input(false);
15
- _setDisabledOnContext = effect(() => this.context.setDisabled(undefined, this.disabled()));
16
- ngOnDestroy() {
17
- this._setDisabledOnContext.destroy();
18
- }
16
+ _disabledEffect = effect(() => this.context.setDisabled(undefined, this.disabled()));
19
17
  // Utility Functions
20
18
  getValue() {
21
19
  return this.context.getValue();
@@ -55,15 +53,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
55
53
  * Abstract component for wrapping an asyncrhronously-configured form.
56
54
  */
57
55
  export class AbstractAsyncFormlyFormDirective extends AbstractFormlyFormDirective {
58
- _fieldsSub = new SubscriptionObject();
56
+ _fieldSub = cleanSubscription();
59
57
  ngOnInit() {
60
- this._fieldsSub.subscription = this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
58
+ // fields$ is only available after initialization.
59
+ this._fieldSub.setSub(this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
61
60
  this.context.fields = fields;
62
- });
63
- }
64
- ngOnDestroy() {
65
- super.ngOnDestroy();
66
- this._fieldsSub.destroy();
61
+ }));
67
62
  }
68
63
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AbstractAsyncFormlyFormDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
69
64
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AbstractAsyncFormlyFormDirective, usesInheritance: true, ngImport: i0 });
@@ -81,4 +76,4 @@ export class AbstractConfigAsyncFormlyFormDirective extends AbstractAsyncFormlyF
81
76
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AbstractConfigAsyncFormlyFormDirective, decorators: [{
82
77
  type: Directive
83
78
  }] });
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL3NyYy9saWIvZm9ybWx5L2Zvcm1seS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLFdBQVcsRUFBMEIsK0JBQStCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekgsT0FBTyxFQUFjLFdBQVcsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVyRSxPQUFPLEVBQXFCLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUVwRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7O0FBRzFEOzs7O0dBSUc7QUFFSCxNQUFNLE9BQWdCLDJCQUEyQjtJQUN0QyxPQUFPLEdBQUcsTUFBTSxDQUFDLENBQUEsZ0JBQW1CLENBQUEsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBRXRELFFBQVEsR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7SUFDekIscUJBQXFCLEdBQUcsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBRTVHLFdBQVc7UUFDVCxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDdkMsQ0FBQztJQUVELG9CQUFvQjtJQUNwQixRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxRQUFRLENBQUMsS0FBaUI7UUFDeEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNwQixDQUFDO0lBRUQsV0FBVyxDQUFDLEdBQXdCLEVBQUUsUUFBa0I7UUFDdEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzFDLENBQUM7d0dBN0JtQiwyQkFBMkI7NEZBQTNCLDJCQUEyQjs7NEZBQTNCLDJCQUEyQjtrQkFEaEQsU0FBUzs7QUFpQ1Y7O0dBRUc7QUFFSCxNQUFNLE9BQWdCLCtCQUFtQyxTQUFRLDJCQUE4QjtJQUc3RixRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNwQyxDQUFDO3dHQUxtQiwrQkFBK0I7NEZBQS9CLCtCQUErQjs7NEZBQS9CLCtCQUErQjtrQkFEcEQsU0FBUzs7QUFTVjs7R0FFRztBQUVILE1BQU0sT0FBZ0IsZ0NBQW9DLFNBQVEsMkJBQThCO0lBTTdFLFVBQVUsR0FBRyxJQUFJLGtCQUFrQixFQUFFLENBQUM7SUFFdkQsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUM1RixJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRVEsV0FBVztRQUNsQixLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDcEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM1QixDQUFDO3dHQWpCbUIsZ0NBQWdDOzRGQUFoQyxnQ0FBZ0M7OzRGQUFoQyxnQ0FBZ0M7a0JBRHJELFNBQVM7O0FBc0JWLE1BQU0sT0FBZ0Isc0NBQTZDLFNBQVEsZ0NBQW1DO0lBQ25HLE1BQU0sR0FBRyxLQUFLLENBQTRCLFNBQVMsQ0FBQyxDQUFDO0lBRXJELGNBQWMsR0FBRyxZQUFZLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQywrQkFBK0IsRUFBRSxDQUFDLENBQUM7SUFDbkYsT0FBTyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO3dHQUp2RCxzQ0FBc0M7NEZBQXRDLHNDQUFzQzs7NEZBQXRDLHNDQUFzQztrQkFEM0QsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFN1YnNjcmlwdGlvbk9iamVjdCwgZmlsdGVyTWF5YmUsIE1heWJlT2JzZXJ2YWJsZU9yVmFsdWUsIG1heWJlVmFsdWVGcm9tT2JzZXJ2YWJsZU9yVmFsdWUgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IE9ic2VydmFibGUsIHNoYXJlUmVwbGF5LCBkaXN0aW5jdFVudGlsQ2hhbmdlZCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IE9uSW5pdCwgT25EZXN0cm95LCBEaXJlY3RpdmUsIGluamVjdCwgaW5wdXQsIGVmZmVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Rm9ybWx5Q29udGV4dCB9IGZyb20gJy4vZm9ybWx5LmNvbnRleHQnO1xuaW1wb3J0IHsgdHlwZSBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgdG9PYnNlcnZhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHsgRGJ4Rm9ybURpc2FibGVkS2V5IH0gZnJvbSAnLi4vZm9ybS9mb3JtJztcblxuLyoqXG4gKiBBYnN0cmFjdCBjb21wb25lbnQgZm9yIHdyYXBwaW5nIGEgRGJ4Rm9ybWx5Q29udGV4dC5cbiAqXG4gKiBUaGUgaW1wbGVtZW50aW5nIGNvbXBvbmVudCBzaG91bGQgdXNlIHByb3ZpZGVGb3JtbHlDb250ZXh0KCkgdG8gcHJvdmlkZSB0aGUgRGJ4Rm9ybWx5Q29udGV4dCBzcGVjaWZpYyB0byB0aGlzIGRpcmVjdGl2ZS4gVGhlIGNvbnRleHQgaXMgaW5qZWN0ZWQgdXNpbmcgb25seSBzZWxmLlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdEZvcm1seUZvcm1EaXJlY3RpdmU8VD4gaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICByZWFkb25seSBjb250ZXh0ID0gaW5qZWN0KERieEZvcm1seUNvbnRleHQ8VD4sIHsgc2VsZjogdHJ1ZSB9KTtcblxuICByZWFkb25seSBkaXNhYmxlZCA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgcHJpdmF0ZSByZWFkb25seSBfc2V0RGlzYWJsZWRPbkNvbnRleHQgPSBlZmZlY3QoKCkgPT4gdGhpcy5jb250ZXh0LnNldERpc2FibGVkKHVuZGVmaW5lZCwgdGhpcy5kaXNhYmxlZCgpKSk7XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5fc2V0RGlzYWJsZWRPbkNvbnRleHQuZGVzdHJveSgpO1xuICB9XG5cbiAgLy8gVXRpbGl0eSBGdW5jdGlvbnNcbiAgZ2V0VmFsdWUoKTogT2JzZXJ2YWJsZTxUPiB7XG4gICAgcmV0dXJuIHRoaXMuY29udGV4dC5nZXRWYWx1ZSgpO1xuICB9XG5cbiAgc2V0VmFsdWUodmFsdWU6IFBhcnRpYWw8VD4pOiB2b2lkIHtcbiAgICB0aGlzLmNvbnRleHQuc2V0VmFsdWUodmFsdWUpO1xuICB9XG5cbiAgcmVzZXRGb3JtKCk6IHZvaWQge1xuICAgIHRoaXMuY29udGV4dC5yZXNldEZvcm0oKTtcbiAgfVxuXG4gIGNsZWFyVmFsdWUoKTogdm9pZCB7XG4gICAgdGhpcy5zZXRWYWx1ZSh7fSk7XG4gIH1cblxuICBzZXREaXNhYmxlZChrZXk/OiBEYnhGb3JtRGlzYWJsZWRLZXksIGRpc2FibGVkPzogYm9vbGVhbik6IHZvaWQge1xuICAgIHRoaXMuY29udGV4dC5zZXREaXNhYmxlZChrZXksIGRpc2FibGVkKTtcbiAgfVxufVxuXG4vKipcbiAqIEFic3RyYWN0IGNvbXBvbmVudCBmb3Igd3JhcHBpbmcgYSBmb3JtLlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFN5bmNGb3JtbHlGb3JtRGlyZWN0aXZlPFQ+IGV4dGVuZHMgQWJzdHJhY3RGb3JtbHlGb3JtRGlyZWN0aXZlPFQ+IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBhYnN0cmFjdCBmaWVsZHM6IEZvcm1seUZpZWxkQ29uZmlnW107XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5jb250ZXh0LmZpZWxkcyA9IHRoaXMuZmllbGRzO1xuICB9XG59XG5cbi8qKlxuICogQWJzdHJhY3QgY29tcG9uZW50IGZvciB3cmFwcGluZyBhbiBhc3luY3Jocm9ub3VzbHktY29uZmlndXJlZCBmb3JtLlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdEFzeW5jRm9ybWx5Rm9ybURpcmVjdGl2ZTxUPiBleHRlbmRzIEFic3RyYWN0Rm9ybWx5Rm9ybURpcmVjdGl2ZTxUPiBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgLyoqXG4gICAqIFVzZWQgdG8gcHJvdmlkZSBmaWVsZHMgdG8gdGhlIGNvbnRleHQuXG4gICAqL1xuICBhYnN0cmFjdCByZWFkb25seSBmaWVsZHMkOiBPYnNlcnZhYmxlPE1heWJlPEZvcm1seUZpZWxkQ29uZmlnW10+PjtcblxuICBwcml2YXRlIHJlYWRvbmx5IF9maWVsZHNTdWIgPSBuZXcgU3Vic2NyaXB0aW9uT2JqZWN0KCk7XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fZmllbGRzU3ViLnN1YnNjcmlwdGlvbiA9IHRoaXMuZmllbGRzJC5waXBlKGRpc3RpbmN0VW50aWxDaGFuZ2VkKCkpLnN1YnNjcmliZSgoZmllbGRzKSA9PiB7XG4gICAgICB0aGlzLmNvbnRleHQuZmllbGRzID0gZmllbGRzO1xuICAgIH0pO1xuICB9XG5cbiAgb3ZlcnJpZGUgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgc3VwZXIubmdPbkRlc3Ryb3koKTtcbiAgICB0aGlzLl9maWVsZHNTdWIuZGVzdHJveSgpO1xuICB9XG59XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0Q29uZmlnQXN5bmNGb3JtbHlGb3JtRGlyZWN0aXZlPFQsIEM+IGV4dGVuZHMgQWJzdHJhY3RBc3luY0Zvcm1seUZvcm1EaXJlY3RpdmU8VD4gaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHJlYWRvbmx5IGNvbmZpZyA9IGlucHV0PE1heWJlT2JzZXJ2YWJsZU9yVmFsdWU8Qz4+KHVuZGVmaW5lZCk7XG5cbiAgcmVhZG9ubHkgY3VycmVudENvbmZpZyQgPSB0b09ic2VydmFibGUodGhpcy5jb25maWcpLnBpcGUobWF5YmVWYWx1ZUZyb21PYnNlcnZhYmxlT3JWYWx1ZSgpKTtcbiAgcmVhZG9ubHkgY29uZmlnJCA9IHRoaXMuY3VycmVudENvbmZpZyQucGlwZShmaWx0ZXJNYXliZSgpLCBzaGFyZVJlcGxheSgxKSk7XG59XG4iXX0=
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2RieC1mb3JtL3NyYy9saWIvZm9ybWx5L2Zvcm1seS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBMEIsK0JBQStCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckcsT0FBTyxFQUFjLFdBQVcsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVyRSxPQUFPLEVBQVUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRXBELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUUxRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFFdEQ7Ozs7R0FJRztBQUVILE1BQU0sT0FBZ0IsMkJBQTJCO0lBQ3RDLE9BQU8sR0FBRyxNQUFNLENBQUMsQ0FBQSxnQkFBbUIsQ0FBQSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7SUFFdEQsUUFBUSxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztJQUV2QixlQUFlLEdBQUcsTUFBTSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBRXhHLG9CQUFvQjtJQUNwQixRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxRQUFRLENBQUMsS0FBaUI7UUFDeEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELFNBQVM7UUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNwQixDQUFDO0lBRUQsV0FBVyxDQUFDLEdBQXdCLEVBQUUsUUFBa0I7UUFDdEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzFDLENBQUM7d0dBMUJtQiwyQkFBMkI7NEZBQTNCLDJCQUEyQjs7NEZBQTNCLDJCQUEyQjtrQkFEaEQsU0FBUzs7QUE4QlY7O0dBRUc7QUFFSCxNQUFNLE9BQWdCLCtCQUFtQyxTQUFRLDJCQUE4QjtJQUc3RixRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNwQyxDQUFDO3dHQUxtQiwrQkFBK0I7NEZBQS9CLCtCQUErQjs7NEZBQS9CLCtCQUErQjtrQkFEcEQsU0FBUzs7QUFTVjs7R0FFRztBQUVILE1BQU0sT0FBZ0IsZ0NBQW9DLFNBQVEsMkJBQThCO0lBTTNFLFNBQVMsR0FBRyxpQkFBaUIsRUFBRSxDQUFDO0lBRW5ELFFBQVE7UUFDTixrREFBa0Q7UUFDbEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQ25CLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRTtZQUM3RCxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUNKLENBQUM7d0dBZm1CLGdDQUFnQzs0RkFBaEMsZ0NBQWdDOzs0RkFBaEMsZ0NBQWdDO2tCQURyRCxTQUFTOztBQW9CVixNQUFNLE9BQWdCLHNDQUE2QyxTQUFRLGdDQUFtQztJQUNuRyxNQUFNLEdBQUcsS0FBSyxDQUE0QixTQUFTLENBQUMsQ0FBQztJQUVyRCxjQUFjLEdBQUcsWUFBWSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUMsK0JBQStCLEVBQUUsQ0FBQyxDQUFDO0lBQ25GLE9BQU8sR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzt3R0FKdkQsc0NBQXNDOzRGQUF0QyxzQ0FBc0M7OzRGQUF0QyxzQ0FBc0M7a0JBRDNELFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaWx0ZXJNYXliZSwgTWF5YmVPYnNlcnZhYmxlT3JWYWx1ZSwgbWF5YmVWYWx1ZUZyb21PYnNlcnZhYmxlT3JWYWx1ZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgc2hhcmVSZXBsYXksIGRpc3RpbmN0VW50aWxDaGFuZ2VkIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgT25Jbml0LCBEaXJlY3RpdmUsIGluamVjdCwgaW5wdXQsIGVmZmVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGJ4Rm9ybWx5Q29udGV4dCB9IGZyb20gJy4vZm9ybWx5LmNvbnRleHQnO1xuaW1wb3J0IHsgdHlwZSBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgdG9PYnNlcnZhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHsgRGJ4Rm9ybURpc2FibGVkS2V5IH0gZnJvbSAnLi4vZm9ybS9mb3JtJztcbmltcG9ydCB7IGNsZWFuU3Vic2NyaXB0aW9uIH0gZnJvbSAnQGRlcmVla2IvZGJ4LWNvcmUnO1xuXG4vKipcbiAqIEFic3RyYWN0IGNvbXBvbmVudCBmb3Igd3JhcHBpbmcgYSBEYnhGb3JtbHlDb250ZXh0LlxuICpcbiAqIFRoZSBpbXBsZW1lbnRpbmcgY29tcG9uZW50IHNob3VsZCB1c2UgcHJvdmlkZUZvcm1seUNvbnRleHQoKSB0byBwcm92aWRlIHRoZSBEYnhGb3JtbHlDb250ZXh0IHNwZWNpZmljIHRvIHRoaXMgZGlyZWN0aXZlLiBUaGUgY29udGV4dCBpcyBpbmplY3RlZCB1c2luZyBvbmx5IHNlbGYuXG4gKi9cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFic3RyYWN0Rm9ybWx5Rm9ybURpcmVjdGl2ZTxUPiB7XG4gIHJlYWRvbmx5IGNvbnRleHQgPSBpbmplY3QoRGJ4Rm9ybWx5Q29udGV4dDxUPiwgeyBzZWxmOiB0cnVlIH0pO1xuXG4gIHJlYWRvbmx5IGRpc2FibGVkID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gIHByb3RlY3RlZCByZWFkb25seSBfZGlzYWJsZWRFZmZlY3QgPSBlZmZlY3QoKCkgPT4gdGhpcy5jb250ZXh0LnNldERpc2FibGVkKHVuZGVmaW5lZCwgdGhpcy5kaXNhYmxlZCgpKSk7XG5cbiAgLy8gVXRpbGl0eSBGdW5jdGlvbnNcbiAgZ2V0VmFsdWUoKTogT2JzZXJ2YWJsZTxUPiB7XG4gICAgcmV0dXJuIHRoaXMuY29udGV4dC5nZXRWYWx1ZSgpO1xuICB9XG5cbiAgc2V0VmFsdWUodmFsdWU6IFBhcnRpYWw8VD4pOiB2b2lkIHtcbiAgICB0aGlzLmNvbnRleHQuc2V0VmFsdWUodmFsdWUpO1xuICB9XG5cbiAgcmVzZXRGb3JtKCk6IHZvaWQge1xuICAgIHRoaXMuY29udGV4dC5yZXNldEZvcm0oKTtcbiAgfVxuXG4gIGNsZWFyVmFsdWUoKTogdm9pZCB7XG4gICAgdGhpcy5zZXRWYWx1ZSh7fSk7XG4gIH1cblxuICBzZXREaXNhYmxlZChrZXk/OiBEYnhGb3JtRGlzYWJsZWRLZXksIGRpc2FibGVkPzogYm9vbGVhbik6IHZvaWQge1xuICAgIHRoaXMuY29udGV4dC5zZXREaXNhYmxlZChrZXksIGRpc2FibGVkKTtcbiAgfVxufVxuXG4vKipcbiAqIEFic3RyYWN0IGNvbXBvbmVudCBmb3Igd3JhcHBpbmcgYSBmb3JtLlxuICovXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFN5bmNGb3JtbHlGb3JtRGlyZWN0aXZlPFQ+IGV4dGVuZHMgQWJzdHJhY3RGb3JtbHlGb3JtRGlyZWN0aXZlPFQ+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgYWJzdHJhY3QgZmllbGRzOiBGb3JtbHlGaWVsZENvbmZpZ1tdO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuY29udGV4dC5maWVsZHMgPSB0aGlzLmZpZWxkcztcbiAgfVxufVxuXG4vKipcbiAqIEFic3RyYWN0IGNvbXBvbmVudCBmb3Igd3JhcHBpbmcgYW4gYXN5bmNyaHJvbm91c2x5LWNvbmZpZ3VyZWQgZm9ybS5cbiAqL1xuQERpcmVjdGl2ZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQWJzdHJhY3RBc3luY0Zvcm1seUZvcm1EaXJlY3RpdmU8VD4gZXh0ZW5kcyBBYnN0cmFjdEZvcm1seUZvcm1EaXJlY3RpdmU8VD4gaW1wbGVtZW50cyBPbkluaXQge1xuICAvKipcbiAgICogVXNlZCB0byBwcm92aWRlIGZpZWxkcyB0byB0aGUgY29udGV4dC5cbiAgICovXG4gIGFic3RyYWN0IHJlYWRvbmx5IGZpZWxkcyQ6IE9ic2VydmFibGU8TWF5YmU8Rm9ybWx5RmllbGRDb25maWdbXT4+O1xuXG4gIHByb3RlY3RlZCByZWFkb25seSBfZmllbGRTdWIgPSBjbGVhblN1YnNjcmlwdGlvbigpO1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIC8vIGZpZWxkcyQgaXMgb25seSBhdmFpbGFibGUgYWZ0ZXIgaW5pdGlhbGl6YXRpb24uXG4gICAgdGhpcy5fZmllbGRTdWIuc2V0U3ViKFxuICAgICAgdGhpcy5maWVsZHMkLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoKSkuc3Vic2NyaWJlKChmaWVsZHMpID0+IHtcbiAgICAgICAgdGhpcy5jb250ZXh0LmZpZWxkcyA9IGZpZWxkcztcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxufVxuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdENvbmZpZ0FzeW5jRm9ybWx5Rm9ybURpcmVjdGl2ZTxULCBDPiBleHRlbmRzIEFic3RyYWN0QXN5bmNGb3JtbHlGb3JtRGlyZWN0aXZlPFQ+IHtcbiAgcmVhZG9ubHkgY29uZmlnID0gaW5wdXQ8TWF5YmVPYnNlcnZhYmxlT3JWYWx1ZTxDPj4odW5kZWZpbmVkKTtcblxuICByZWFkb25seSBjdXJyZW50Q29uZmlnJCA9IHRvT2JzZXJ2YWJsZSh0aGlzLmNvbmZpZykucGlwZShtYXliZVZhbHVlRnJvbU9ic2VydmFibGVPclZhbHVlKCkpO1xuICByZWFkb25seSBjb25maWckID0gdGhpcy5jdXJyZW50Q29uZmlnJC5waXBlKGZpbHRlck1heWJlKCksIHNoYXJlUmVwbGF5KDEpKTtcbn1cbiJdfQ==
@@ -2,7 +2,7 @@ import { ChangeDetectionStrategy, Component, computed, inject, signal, viewChild
2
2
  import { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';
3
3
  import { FormlyForm, FormlyModule } from '@ngx-formly/core';
4
4
  import { distinctUntilChanged, map, throttleTime, startWith, BehaviorSubject, Subject, switchMap, shareReplay, of, scan, filter, timer, first, merge, delay } from 'rxjs';
5
- import { AbstractSubscriptionDirective } from '@dereekb/dbx-core';
5
+ import { cleanWithLockSet } from '@dereekb/dbx-core';
6
6
  import { DbxFormState, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm, toggleDisableFormControl } from '../form/form';
7
7
  import { DbxFormlyContext } from './formly.context';
8
8
  import { scanCount, switchMapFilterMaybe, SubscriptionObject } from '@dereekb/rxjs';
@@ -14,7 +14,7 @@ import * as i2 from "@ngx-formly/core";
14
14
  /**
15
15
  * Used for rending a form from a DbxFormlyContext.
16
16
  */
17
- export class DbxFormlyComponent extends AbstractSubscriptionDirective {
17
+ export class DbxFormlyComponent {
18
18
  _dbxFormlyContext = inject((DbxFormlyContext));
19
19
  formlyForm = viewChild(FormlyForm);
20
20
  _fields = new BehaviorSubject(undefined);
@@ -80,6 +80,18 @@ export class DbxFormlyComponent extends AbstractSubscriptionDirective {
80
80
  }))), shareReplay(1));
81
81
  _fieldsSignal = toSignal(this.fields$, { initialValue: undefined });
82
82
  fieldsSignal = computed(() => this._fieldsSignal() ?? []);
83
+ constructor() {
84
+ cleanWithLockSet(this._dbxFormlyContext.lockSet, () => {
85
+ this._dbxFormlyContext.clearDelegate(this);
86
+ this._events.complete();
87
+ this._fields.complete();
88
+ this._reset.complete();
89
+ this._forceUpdate.complete();
90
+ this._disabled.complete();
91
+ this._disabledSub.destroy();
92
+ this._enforceDisabledSub.destroy();
93
+ });
94
+ }
83
95
  ngOnInit() {
84
96
  this._dbxFormlyContext.setDelegate(this);
85
97
  const resyncDisabledState = () => {
@@ -102,19 +114,6 @@ export class DbxFormlyComponent extends AbstractSubscriptionDirective {
102
114
  resyncDisabledState();
103
115
  });
104
116
  }
105
- ngOnDestroy() {
106
- this._dbxFormlyContext.lockSet.onNextUnlock(() => {
107
- super.ngOnDestroy();
108
- this._dbxFormlyContext.clearDelegate(this);
109
- this._events.complete();
110
- this._fields.complete();
111
- this._reset.complete();
112
- this._forceUpdate.complete();
113
- this._disabled.complete();
114
- this._disabledSub.destroy();
115
- this._enforceDisabledSub.destroy();
116
- });
117
- }
118
117
  // MARK: Delegate
119
118
  init(initialize) {
120
119
  this._fields.next(initialize.fields);
@@ -165,8 +164,8 @@ export class DbxFormlyComponent extends AbstractSubscriptionDirective {
165
164
  forceFormUpdate() {
166
165
  this._forceUpdate.next();
167
166
  }
168
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormlyComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
169
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxFormlyComponent, isStandalone: true, selector: "dbx-formly", host: { classAttribute: "dbx-formly" }, providers: provideDbxMutableForm(DbxFormlyComponent), viewQueries: [{ propertyName: "formlyForm", first: true, predicate: FormlyForm, descendants: true, isSignal: true }], exportAs: ["formly"], usesInheritance: true, ngImport: i0, template: `
167
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormlyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
168
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxFormlyComponent, isStandalone: true, selector: "dbx-formly", host: { classAttribute: "dbx-formly" }, providers: provideDbxMutableForm(DbxFormlyComponent), viewQueries: [{ propertyName: "formlyForm", first: true, predicate: FormlyForm, descendants: true, isSignal: true }], exportAs: ["formly"], ngImport: i0, template: `
170
169
  <form [formGroup]="form" class="dbx-formly">
171
170
  <formly-form [form]="form" [options]="options" [fields]="fieldsSignal()" [model]="modelSignal()"></formly-form>
172
171
  </form>
@@ -190,5 +189,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
190
189
  changeDetection: ChangeDetectionStrategy.OnPush,
191
190
  standalone: true
192
191
  }]
193
- }] });
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly.form.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/src/lib/formly/formly.form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnDestroy, OnInit, computed, inject, signal, viewChild } from '@angular/core';\nimport { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { FormlyFieldConfig, FormlyForm, FormlyFormOptions, FormlyModule } from '@ngx-formly/core';\nimport { distinctUntilChanged, map, throttleTime, startWith, BehaviorSubject, Observable, Subject, switchMap, shareReplay, of, scan, filter, timer, first, merge, delay } from 'rxjs';\nimport { AbstractSubscriptionDirective } from '@dereekb/dbx-core';\nimport { DbxForm, DbxFormDisabledKey, DbxFormEvent, DbxFormState, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm, toggleDisableFormControl } from '../form/form';\nimport { DbxFormlyContext, DbxFormlyContextDelegate, DbxFormlyInitialize } from './formly.context';\nimport { scanCount, switchMapFilterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { BooleanStringKeyArray, BooleanStringKeyArrayUtility, iterablesAreSetEquivalent, type Maybe } from '@dereekb/util';\nimport { toSignal } from '@angular/core/rxjs-interop';\n\nexport interface DbxFormlyFormState {\n  changesSinceLastResetCount: number;\n  isFormValid: boolean;\n  isFormDisabled: boolean;\n}\n\n/**\n * Used for rending a form from a DbxFormlyContext.\n */\n@Component({\n  selector: 'dbx-formly',\n  exportAs: 'formly',\n  template: `\n    <form [formGroup]=\"form\" class=\"dbx-formly\">\n      <formly-form [form]=\"form\" [options]=\"options\" [fields]=\"fieldsSignal()\" [model]=\"modelSignal()\"></formly-form>\n    </form>\n  `,\n  host: {\n    class: 'dbx-formly'\n  },\n  providers: provideDbxMutableForm(DbxFormlyComponent),\n  imports: [FormsModule, ReactiveFormsModule, FormlyModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxFormlyComponent<T> extends AbstractSubscriptionDirective implements DbxForm, DbxFormlyContextDelegate<T>, OnInit, OnDestroy {\n  private readonly _dbxFormlyContext = inject(DbxFormlyContext<T>);\n\n  readonly formlyForm = viewChild(FormlyForm);\n\n  private readonly _fields = new BehaviorSubject<Maybe<Observable<FormlyFieldConfig[]>>>(undefined);\n  private readonly _events = new BehaviorSubject<DbxFormEvent>({ isComplete: false, state: DbxFormState.INITIALIZING, status: 'PENDING' });\n  private readonly _disabled = new BehaviorSubject<BooleanStringKeyArray>(undefined);\n\n  private readonly _reset = new BehaviorSubject<Date>(new Date());\n  private readonly _forceUpdate = new Subject<void>();\n\n  private readonly _disabledSub = new SubscriptionObject();\n  private readonly _enforceDisabledSub = new SubscriptionObject();\n\n  readonly form = new FormGroup({});\n  readonly modelSignal = signal<T>({} as T);\n\n  readonly options: FormlyFormOptions = {};\n\n  readonly fields$ = this._fields.pipe(switchMapFilterMaybe(), distinctUntilChanged(), shareReplay(1));\n\n  readonly stream$: Observable<DbxFormEvent> = this._reset.pipe(\n    switchMap((lastResetAt) =>\n      this.form.valueChanges.pipe(\n        startWith(0),\n        distinctUntilChanged(),\n        throttleTime(50, undefined, { leading: true, trailing: true }),\n        scanCount(-1),\n        // update on validation changes too. Does not count towards changes since last reset.\n        switchMap((changesSinceLastReset) => this.form.statusChanges.pipe(startWith(this.form.status), distinctUntilChanged()).pipe(map(() => changesSinceLastReset))),\n        map((changesSinceLastResetCount: number) => ({\n          changesSinceLastResetCount,\n          isFormValid: this.form.status !== 'PENDING' && this.form.valid,\n          isFormDisabled: this.form.disabled\n        })),\n        scan(\n          (acc: DbxFormlyFormState, next: DbxFormlyFormState) => {\n            // Pass forward valid if next was a disabled change/check, which changes angular form's isValid value.\n            // If it was valid prior, then it should be valid now, unless we just reset, in which case it might not be valid.\n            const valid = next.isFormValid || (next.isFormDisabled && acc.isFormValid && acc.changesSinceLastResetCount > 0);\n\n            return {\n              changesSinceLastResetCount: next.changesSinceLastResetCount,\n              isFormValid: valid,\n              isFormDisabled: next.isFormDisabled\n            };\n          },\n          {\n            changesSinceLastResetCount: 0,\n            isFormValid: false,\n            isFormDisabled: false\n          }\n        ),\n        switchMap(({ changesSinceLastResetCount, isFormValid, isFormDisabled }) => {\n          const nextState = () => {\n            const isReset = changesSinceLastResetCount <= 1; // first emission after reset is the first value.\n            const complete = isFormValid;\n\n            const nextState: DbxFormEvent = {\n              isComplete: complete,\n              state: isReset ? DbxFormState.RESET : DbxFormState.USED,\n              status: this.form.status,\n              untouched: this.form.untouched,\n              pristine: this.form.pristine,\n              changesCount: changesSinceLastResetCount,\n              lastResetAt,\n              disabled: this.disabled,\n              isDisabled: isFormDisabled\n            };\n\n            return nextState;\n          };\n\n          const state = nextState();\n\n          if (isFormValid && this.form.untouched) {\n            return timer(150, 200).pipe(\n              // every 200 ms check if the form is now marked touched, then push a new state\n              filter(() => this.form.touched),\n              map(() => nextState()),\n              // only push the new state once\n              first(),\n              // send the first value immediately\n              startWith(state)\n            );\n          } else {\n            return of(state);\n          }\n        })\n      )\n    ),\n    shareReplay(1)\n  );\n\n  private readonly _fieldsSignal = toSignal(this.fields$, { initialValue: undefined });\n  readonly fieldsSignal = computed(() => this._fieldsSignal() ?? []);\n\n  ngOnInit(): void {\n    this._dbxFormlyContext.setDelegate(this);\n\n    const resyncDisabledState = () => {\n      const isDisabled = BooleanStringKeyArrayUtility.isTrue(this._disabled.value);\n      let change = false;\n\n      if (this.form.disabled !== isDisabled) {\n        toggleDisableFormControl(this.form, isDisabled, { emitEvent: true });\n        change = true;\n      }\n\n      return change;\n    };\n\n    this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged(iterablesAreSetEquivalent)).subscribe(() => {\n      resyncDisabledState();\n    });\n\n    // NOTE: Form sometimes becomes undisabled somewhere/somehow. Re-enforce the disabled state where necessary.\n    this._enforceDisabledSub.subscription = merge([\n      this._reset.pipe(\n        map(() => 'RESET'),\n        delay(50)\n      ),\n      this.form.statusChanges.pipe(throttleTime(50, undefined, { leading: true, trailing: true }))\n    ]).subscribe((change) => {\n      resyncDisabledState();\n    });\n  }\n\n  override ngOnDestroy(): void {\n    this._dbxFormlyContext.lockSet.onNextUnlock(() => {\n      super.ngOnDestroy();\n      this._dbxFormlyContext.clearDelegate(this);\n      this._events.complete();\n      this._fields.complete();\n      this._reset.complete();\n      this._forceUpdate.complete();\n      this._disabled.complete();\n      this._disabledSub.destroy();\n      this._enforceDisabledSub.destroy();\n    });\n  }\n\n  // MARK: Delegate\n  init(initialize: DbxFormlyInitialize<T>): void {\n    this._fields.next(initialize.fields);\n    this._disabled.next(initialize.initialDisabled);\n  }\n\n  getValue(): Observable<T> {\n    return of(this.form.value as T);\n  }\n\n  setValue(value: T): void {\n    this.modelSignal.set(structuredClone(value) as T);\n\n    if (this.options.updateInitialValue) {\n      this.options.updateInitialValue();\n      this.options.resetModel?.();\n    }\n\n    // Re-mark as untouched and pristine.\n    this.form.markAsUntouched();\n    this.form.markAsPristine();\n\n    // After updating the value, if the form is still untouched mark it as pristine again.\n    // Sometimes the values get marked as changed and break pristine before a user has time to interact.\n    setTimeout(() => {\n      if (this.form.untouched) {\n        this.form.markAsPristine();\n      }\n    }, 500);\n\n    // ping reset\n    this.resetForm();\n  }\n\n  resetForm(): void {\n    if (this.options.resetModel) {\n      this.options.resetModel();\n    }\n\n    this._reset.next(new Date());\n  }\n\n  get isDisabled(): boolean {\n    return BooleanStringKeyArrayUtility.isTrue(this.disabled);\n  }\n\n  get disabled(): BooleanStringKeyArray {\n    return this._disabled.value;\n  }\n\n  getDisabled(): Observable<BooleanStringKeyArray> {\n    return this._disabled.asObservable();\n  }\n\n  setDisabled(key?: DbxFormDisabledKey, disabled = true): void {\n    const next = BooleanStringKeyArrayUtility.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled);\n    this._disabled.next(next);\n  }\n\n  // MARK: Update\n  forceFormUpdate(): void {\n    this._forceUpdate.next();\n  }\n}\n"]}
192
+ }], ctorParameters: () => [] });
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly.form.component.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/src/lib/formly/formly.form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit, computed, inject, signal, viewChild } from '@angular/core';\nimport { FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { FormlyFieldConfig, FormlyForm, FormlyFormOptions, FormlyModule } from '@ngx-formly/core';\nimport { distinctUntilChanged, map, throttleTime, startWith, BehaviorSubject, Observable, Subject, switchMap, shareReplay, of, scan, filter, timer, first, merge, delay } from 'rxjs';\nimport { cleanWithLockSet } from '@dereekb/dbx-core';\nimport { DbxForm, DbxFormDisabledKey, DbxFormEvent, DbxFormState, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm, toggleDisableFormControl } from '../form/form';\nimport { DbxFormlyContext, DbxFormlyContextDelegate, DbxFormlyInitialize } from './formly.context';\nimport { scanCount, switchMapFilterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { BooleanStringKeyArray, BooleanStringKeyArrayUtility, iterablesAreSetEquivalent, type Maybe } from '@dereekb/util';\nimport { toSignal } from '@angular/core/rxjs-interop';\n\nexport interface DbxFormlyFormState {\n  changesSinceLastResetCount: number;\n  isFormValid: boolean;\n  isFormDisabled: boolean;\n}\n\n/**\n * Used for rending a form from a DbxFormlyContext.\n */\n@Component({\n  selector: 'dbx-formly',\n  exportAs: 'formly',\n  template: `\n    <form [formGroup]=\"form\" class=\"dbx-formly\">\n      <formly-form [form]=\"form\" [options]=\"options\" [fields]=\"fieldsSignal()\" [model]=\"modelSignal()\"></formly-form>\n    </form>\n  `,\n  host: {\n    class: 'dbx-formly'\n  },\n  providers: provideDbxMutableForm(DbxFormlyComponent),\n  imports: [FormsModule, ReactiveFormsModule, FormlyModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true\n})\nexport class DbxFormlyComponent<T> implements DbxForm, DbxFormlyContextDelegate<T>, OnInit {\n  private readonly _dbxFormlyContext = inject(DbxFormlyContext<T>);\n\n  readonly formlyForm = viewChild(FormlyForm);\n\n  private readonly _fields = new BehaviorSubject<Maybe<Observable<FormlyFieldConfig[]>>>(undefined);\n  private readonly _events = new BehaviorSubject<DbxFormEvent>({ isComplete: false, state: DbxFormState.INITIALIZING, status: 'PENDING' });\n  private readonly _disabled = new BehaviorSubject<BooleanStringKeyArray>(undefined);\n\n  private readonly _reset = new BehaviorSubject<Date>(new Date());\n  private readonly _forceUpdate = new Subject<void>();\n\n  private readonly _disabledSub = new SubscriptionObject();\n  private readonly _enforceDisabledSub = new SubscriptionObject();\n\n  readonly form = new FormGroup({});\n  readonly modelSignal = signal<T>({} as T);\n\n  readonly options: FormlyFormOptions = {};\n\n  readonly fields$ = this._fields.pipe(switchMapFilterMaybe(), distinctUntilChanged(), shareReplay(1));\n\n  readonly stream$: Observable<DbxFormEvent> = this._reset.pipe(\n    switchMap((lastResetAt) =>\n      this.form.valueChanges.pipe(\n        startWith(0),\n        distinctUntilChanged(),\n        throttleTime(50, undefined, { leading: true, trailing: true }),\n        scanCount(-1),\n        // update on validation changes too. Does not count towards changes since last reset.\n        switchMap((changesSinceLastReset) => this.form.statusChanges.pipe(startWith(this.form.status), distinctUntilChanged()).pipe(map(() => changesSinceLastReset))),\n        map((changesSinceLastResetCount: number) => ({\n          changesSinceLastResetCount,\n          isFormValid: this.form.status !== 'PENDING' && this.form.valid,\n          isFormDisabled: this.form.disabled\n        })),\n        scan(\n          (acc: DbxFormlyFormState, next: DbxFormlyFormState) => {\n            // Pass forward valid if next was a disabled change/check, which changes angular form's isValid value.\n            // If it was valid prior, then it should be valid now, unless we just reset, in which case it might not be valid.\n            const valid = next.isFormValid || (next.isFormDisabled && acc.isFormValid && acc.changesSinceLastResetCount > 0);\n\n            return {\n              changesSinceLastResetCount: next.changesSinceLastResetCount,\n              isFormValid: valid,\n              isFormDisabled: next.isFormDisabled\n            };\n          },\n          {\n            changesSinceLastResetCount: 0,\n            isFormValid: false,\n            isFormDisabled: false\n          }\n        ),\n        switchMap(({ changesSinceLastResetCount, isFormValid, isFormDisabled }) => {\n          const nextState = () => {\n            const isReset = changesSinceLastResetCount <= 1; // first emission after reset is the first value.\n            const complete = isFormValid;\n\n            const nextState: DbxFormEvent = {\n              isComplete: complete,\n              state: isReset ? DbxFormState.RESET : DbxFormState.USED,\n              status: this.form.status,\n              untouched: this.form.untouched,\n              pristine: this.form.pristine,\n              changesCount: changesSinceLastResetCount,\n              lastResetAt,\n              disabled: this.disabled,\n              isDisabled: isFormDisabled\n            };\n\n            return nextState;\n          };\n\n          const state = nextState();\n\n          if (isFormValid && this.form.untouched) {\n            return timer(150, 200).pipe(\n              // every 200 ms check if the form is now marked touched, then push a new state\n              filter(() => this.form.touched),\n              map(() => nextState()),\n              // only push the new state once\n              first(),\n              // send the first value immediately\n              startWith(state)\n            );\n          } else {\n            return of(state);\n          }\n        })\n      )\n    ),\n    shareReplay(1)\n  );\n\n  private readonly _fieldsSignal = toSignal(this.fields$, { initialValue: undefined });\n\n  readonly fieldsSignal = computed(() => this._fieldsSignal() ?? []);\n\n  constructor() {\n    cleanWithLockSet(this._dbxFormlyContext.lockSet, () => {\n      this._dbxFormlyContext.clearDelegate(this);\n      this._events.complete();\n      this._fields.complete();\n      this._reset.complete();\n      this._forceUpdate.complete();\n      this._disabled.complete();\n      this._disabledSub.destroy();\n      this._enforceDisabledSub.destroy();\n    });\n  }\n\n  ngOnInit(): void {\n    this._dbxFormlyContext.setDelegate(this);\n\n    const resyncDisabledState = () => {\n      const isDisabled = BooleanStringKeyArrayUtility.isTrue(this._disabled.value);\n      let change = false;\n\n      if (this.form.disabled !== isDisabled) {\n        toggleDisableFormControl(this.form, isDisabled, { emitEvent: true });\n        change = true;\n      }\n\n      return change;\n    };\n\n    this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged(iterablesAreSetEquivalent)).subscribe(() => {\n      resyncDisabledState();\n    });\n\n    // NOTE: Form sometimes becomes undisabled somewhere/somehow. Re-enforce the disabled state where necessary.\n    this._enforceDisabledSub.subscription = merge([\n      this._reset.pipe(\n        map(() => 'RESET'),\n        delay(50)\n      ),\n      this.form.statusChanges.pipe(throttleTime(50, undefined, { leading: true, trailing: true }))\n    ]).subscribe((change) => {\n      resyncDisabledState();\n    });\n  }\n\n  // MARK: Delegate\n  init(initialize: DbxFormlyInitialize<T>): void {\n    this._fields.next(initialize.fields);\n    this._disabled.next(initialize.initialDisabled);\n  }\n\n  getValue(): Observable<T> {\n    return of(this.form.value as T);\n  }\n\n  setValue(value: T): void {\n    this.modelSignal.set(structuredClone(value) as T);\n\n    if (this.options.updateInitialValue) {\n      this.options.updateInitialValue();\n      this.options.resetModel?.();\n    }\n\n    // Re-mark as untouched and pristine.\n    this.form.markAsUntouched();\n    this.form.markAsPristine();\n\n    // After updating the value, if the form is still untouched mark it as pristine again.\n    // Sometimes the values get marked as changed and break pristine before a user has time to interact.\n    setTimeout(() => {\n      if (this.form.untouched) {\n        this.form.markAsPristine();\n      }\n    }, 500);\n\n    // ping reset\n    this.resetForm();\n  }\n\n  resetForm(): void {\n    if (this.options.resetModel) {\n      this.options.resetModel();\n    }\n\n    this._reset.next(new Date());\n  }\n\n  get isDisabled(): boolean {\n    return BooleanStringKeyArrayUtility.isTrue(this.disabled);\n  }\n\n  get disabled(): BooleanStringKeyArray {\n    return this._disabled.value;\n  }\n\n  getDisabled(): Observable<BooleanStringKeyArray> {\n    return this._disabled.asObservable();\n  }\n\n  setDisabled(key?: DbxFormDisabledKey, disabled = true): void {\n    const next = BooleanStringKeyArrayUtility.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled);\n    this._disabled.next(next);\n  }\n\n  // MARK: Update\n  forceFormUpdate(): void {\n    this._forceUpdate.next();\n  }\n}\n"]}
@@ -5,8 +5,8 @@ import { DbxActionTransitionSafetyDirective, AbstractDialogDirective, DbxDialogC
5
5
  import { isPast, addSeconds, startOfDay, addMinutes, addDays, isBefore } from 'date-fns';
6
6
  import { map, of, shareReplay, switchMap, first, exhaustMap, catchError, delay, filter, combineLatest, distinctUntilChanged, BehaviorSubject, Subject, startWith, throttleTime, scan, timer, merge, tap, takeUntil, EMPTY, mergeMap, debounceTime, skip, combineLatestWith, interval } from 'rxjs';
7
7
  import * as i2 from '@dereekb/dbx-core';
8
- import { DbxActionContextStoreSourceInstance, AbstractSubscriptionDirective, DbxInjectionComponent, mergeDbxInjectionComponentConfigs, GetValuePipe, DateDistancePipe, TimeDistancePipe } from '@dereekb/dbx-core';
9
- import { LockSet, makeIsModifiedFunctionObservable, SubscriptionObject, asObservable, filterMaybe, switchMapFilterMaybe, scanCount, cleanup, errorOnEmissionsInPeriod, asObservableFromGetter, maybeValueFromObservableOrValue, valueFromFinishedLoadingState, switchMapMaybeDefault, SimpleLoadingContext, distinctUntilHasDifferentValues, startWithBeginLoading, mapLoadingStateResults, successResult, listLoadingStateContext, mapIsListLoadingStateWithEmptyValue, loadingStateContext, isLoadingStateInLoadingState, isLoadingStateWithDefinedValue, isLoadingStateLoading, beginLoading, mapLoadingStateValueWithOperator, skipFirstMaybe, asyncPusherCache } from '@dereekb/rxjs';
8
+ import { DbxActionContextStoreSourceInstance, cleanLockSet, cleanWithLockSet, cleanSubscription, DbxInjectionComponent, mergeDbxInjectionComponentConfigs, GetValuePipe, DateDistancePipe, TimeDistancePipe } from '@dereekb/dbx-core';
9
+ import { makeIsModifiedFunctionObservable, SubscriptionObject, asObservable, LockSet, filterMaybe, switchMapFilterMaybe, scanCount, cleanup, errorOnEmissionsInPeriod, asObservableFromGetter, maybeValueFromObservableOrValue, valueFromFinishedLoadingState, switchMapMaybeDefault, SimpleLoadingContext, distinctUntilHasDifferentValues, startWithBeginLoading, mapLoadingStateResults, successResult, listLoadingStateContext, mapIsListLoadingStateWithEmptyValue, loadingStateContext, isLoadingStateInLoadingState, isLoadingStateWithDefinedValue, isLoadingStateLoading, beginLoading, mapLoadingStateValueWithOperator, skipFirstMaybe, asyncPusherCache } from '@dereekb/rxjs';
10
10
  import { toObservable, toSignal } from '@angular/core/rxjs-interop';
11
11
  import { BooleanStringKeyArrayUtility, iterablesAreSetEquivalent, objectIsEmpty, mergeObjectsFunction, filterFromPOJOFunction, mergeObjects, filterFromPOJO, asArray, objectHasNoKeys, addPlusPrefixToNumber, convertMaybeToArray, isSelectedDecisionFunctionFactory, readKeysFrom, hasDifferentValues, makeValuesGroupMap, separateValues, filterUniqueValues, searchStringFilterFunction, caseInsensitiveFilterByIndexOfDecisionFactory, sortByStringFunction, mergeArraysIntoArray, lastValue, arrayToMap, setContainsAllValues, addToSetCopy, setsAreEquivalent, filterMaybeArrayValues, mergeArrays, firstValue, cachedGetter, makeGetter, asDecisionFunction, getValueFromGetter, asGetter, dateFromMinuteOfDay, dateToMinuteOfDay, isISO8601DayStringStart, mapIdentityFunction, MS_IN_MINUTE, isMonthDaySlashDate, HAS_WEBSITE_DOMAIN_NAME_REGEX, KeyValueTypleValueFilter, valuesFromPOJO, allObjectsAreEqual, isNumberDivisibleBy, nearestDivisibleValues, isE164PhoneNumber as isE164PhoneNumber$1, isValidPhoneExtensionNumber, e164PhoneNumberExtensionPair, isWebsiteUrlWithPrefix, websiteUrlDetails, mapMaybeFunction, transformNumberFunction, concatArrays, DOLLAR_AMOUNT_PRECISION, e164PhoneNumberFromE164PhoneNumberExtensionPair, transformStringFunction, US_STATE_CODE_STRING_REGEX, ZIP_CODE_STRING_REGEX, LAT_LNG_PATTERN, capitalizeFirstLetter } from '@dereekb/util';
12
12
  import * as i1 from '@angular/forms';
@@ -111,7 +111,17 @@ const APP_ACTION_FORM_DISABLED_KEY = 'dbx_action_form';
111
111
  class DbxActionFormDirective {
112
112
  form = inject((DbxMutableForm), { host: true });
113
113
  source = inject((DbxActionContextStoreSourceInstance));
114
- lockSet = new LockSet();
114
+ lockSet = cleanLockSet({
115
+ onDestroy: () => {
116
+ this.source.enable(APP_ACTION_FORM_DISABLED_KEY);
117
+ },
118
+ onLockSetDestroy: () => {
119
+ this._triggeredSub.destroy();
120
+ this._isCompleteSub.destroy();
121
+ this._isWorkingSub.destroy();
122
+ this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, false);
123
+ }
124
+ });
115
125
  /**
116
126
  * Whether or not to disable the form while the action is working.
117
127
  *
@@ -218,15 +228,6 @@ class DbxActionFormDirective {
218
228
  this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, disable);
219
229
  });
220
230
  }
221
- ngOnDestroy() {
222
- this.source.enable(APP_ACTION_FORM_DISABLED_KEY);
223
- this.lockSet.destroyOnNextUnlock(() => {
224
- this._triggeredSub.destroy();
225
- this._isCompleteSub.destroy();
226
- this._isWorkingSub.destroy();
227
- this.form.setDisabled(APP_ACTION_FORM_DISABLED_KEY, false);
228
- });
229
- }
230
231
  checkIsValidAndIsModified(value, overrides) {
231
232
  const { isModifiedFunction: overrideIsModifiedFunction, isValidFunction: overrideIsValidFunction } = overrides ?? {};
232
233
  const isValidFunctionObs = overrideIsValidFunction != null ? of(overrideIsValidFunction) : this.isValidFunction$;
@@ -414,7 +415,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
414
415
  /**
415
416
  * Used for rending a form from a DbxFormlyContext.
416
417
  */
417
- class DbxFormlyComponent extends AbstractSubscriptionDirective {
418
+ class DbxFormlyComponent {
418
419
  _dbxFormlyContext = inject((DbxFormlyContext));
419
420
  formlyForm = viewChild(FormlyForm);
420
421
  _fields = new BehaviorSubject(undefined);
@@ -480,6 +481,18 @@ class DbxFormlyComponent extends AbstractSubscriptionDirective {
480
481
  }))), shareReplay(1));
481
482
  _fieldsSignal = toSignal(this.fields$, { initialValue: undefined });
482
483
  fieldsSignal = computed(() => this._fieldsSignal() ?? []);
484
+ constructor() {
485
+ cleanWithLockSet(this._dbxFormlyContext.lockSet, () => {
486
+ this._dbxFormlyContext.clearDelegate(this);
487
+ this._events.complete();
488
+ this._fields.complete();
489
+ this._reset.complete();
490
+ this._forceUpdate.complete();
491
+ this._disabled.complete();
492
+ this._disabledSub.destroy();
493
+ this._enforceDisabledSub.destroy();
494
+ });
495
+ }
483
496
  ngOnInit() {
484
497
  this._dbxFormlyContext.setDelegate(this);
485
498
  const resyncDisabledState = () => {
@@ -502,19 +515,6 @@ class DbxFormlyComponent extends AbstractSubscriptionDirective {
502
515
  resyncDisabledState();
503
516
  });
504
517
  }
505
- ngOnDestroy() {
506
- this._dbxFormlyContext.lockSet.onNextUnlock(() => {
507
- super.ngOnDestroy();
508
- this._dbxFormlyContext.clearDelegate(this);
509
- this._events.complete();
510
- this._fields.complete();
511
- this._reset.complete();
512
- this._forceUpdate.complete();
513
- this._disabled.complete();
514
- this._disabledSub.destroy();
515
- this._enforceDisabledSub.destroy();
516
- });
517
- }
518
518
  // MARK: Delegate
519
519
  init(initialize) {
520
520
  this._fields.next(initialize.fields);
@@ -565,8 +565,8 @@ class DbxFormlyComponent extends AbstractSubscriptionDirective {
565
565
  forceFormUpdate() {
566
566
  this._forceUpdate.next();
567
567
  }
568
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormlyComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
569
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxFormlyComponent, isStandalone: true, selector: "dbx-formly", host: { classAttribute: "dbx-formly" }, providers: provideDbxMutableForm(DbxFormlyComponent), viewQueries: [{ propertyName: "formlyForm", first: true, predicate: FormlyForm, descendants: true, isSignal: true }], exportAs: ["formly"], usesInheritance: true, ngImport: i0, template: `
568
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormlyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
569
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.13", type: DbxFormlyComponent, isStandalone: true, selector: "dbx-formly", host: { classAttribute: "dbx-formly" }, providers: provideDbxMutableForm(DbxFormlyComponent), viewQueries: [{ propertyName: "formlyForm", first: true, predicate: FormlyForm, descendants: true, isSignal: true }], exportAs: ["formly"], ngImport: i0, template: `
570
570
  <form [formGroup]="form" class="dbx-formly">
571
571
  <formly-form [form]="form" [options]="options" [fields]="fieldsSignal()" [model]="modelSignal()"></formly-form>
572
572
  </form>
@@ -590,7 +590,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
590
590
  changeDetection: ChangeDetectionStrategy.OnPush,
591
591
  standalone: true
592
592
  }]
593
- }] });
593
+ }], ctorParameters: () => [] });
594
594
 
595
595
  function dbxFormSourceObservable(form, inputObs, modeObs) {
596
596
  return dbxFormSourceObservableFromStream(form.stream$, inputObs, modeObs);
@@ -653,10 +653,11 @@ function dbxFormSourceObservableFromStream(streamObs, inputObs, modeObs) {
653
653
  /**
654
654
  * Used with a FormComponent to set the value based on the input value.
655
655
  */
656
- class DbxFormSourceDirective extends AbstractSubscriptionDirective {
656
+ class DbxFormSourceDirective {
657
657
  form = inject((DbxMutableForm), { host: true });
658
658
  dbxFormSourceMode = input();
659
659
  dbxFormSource = input();
660
+ _effectSub = cleanSubscription();
660
661
  _setFormSourceObservableEffect = effect(() => {
661
662
  const formSource = this.dbxFormSource();
662
663
  const mode = this.dbxFormSourceMode() ?? 'reset';
@@ -666,12 +667,10 @@ class DbxFormSourceDirective extends AbstractSubscriptionDirective {
666
667
  this.form.setValue(x);
667
668
  });
668
669
  }
669
- this.sub = subscription;
670
- }, {
671
- allowSignalWrites: true
672
- });
673
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormSourceDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
674
- 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 });
670
+ this._effectSub.setSub(subscription);
671
+ }, { allowSignalWrites: true });
672
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormSourceDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
673
+ 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 });
675
674
  }
676
675
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormSourceDirective, decorators: [{
677
676
  type: Directive,
@@ -685,7 +684,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
685
684
  *
686
685
  */
687
686
  class DbxFormActionDialogComponent extends AbstractDialogDirective {
688
- _fieldsSub = new SubscriptionObject();
687
+ _fieldsSub = cleanSubscription();
689
688
  context = inject((DbxFormlyContext), { self: true });
690
689
  fields$ = asObservableFromGetter(this.data.fields);
691
690
  initialValue$ = asObservableFromGetter(this.data.initialValue);
@@ -695,14 +694,9 @@ class DbxFormActionDialogComponent extends AbstractDialogDirective {
695
694
  ...this.data.submitButtonConfig
696
695
  };
697
696
  ngOnInit() {
698
- super.ngOnInit();
699
- this._fieldsSub.subscription = this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
697
+ this._fieldsSub.setSub(this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
700
698
  this.context.fields = fields;
701
- });
702
- }
703
- ngOnDestroy() {
704
- super.ngOnDestroy();
705
- this._fieldsSub.destroy();
699
+ }));
706
700
  }
707
701
  handleSubmitValue = (value, context) => {
708
702
  context.success();
@@ -755,20 +749,19 @@ const DEFAULT_DBX_FORM_LOADING_SOURCE_DIRECTIVE_MODE = 'reset';
755
749
  *
756
750
  * Only passes non-null values from the source.
757
751
  */
758
- class DbxFormLoadingSourceDirective extends AbstractSubscriptionDirective {
752
+ class DbxFormLoadingSourceDirective {
759
753
  form = inject((DbxMutableForm), { host: true });
760
754
  dbxFormLoadingSourceMode = input(DEFAULT_DBX_FORM_LOADING_SOURCE_DIRECTIVE_MODE, { transform: (x) => x ?? DEFAULT_DBX_FORM_LOADING_SOURCE_DIRECTIVE_MODE });
761
755
  dbxFormLoadingSource = input();
762
756
  mode$ = toObservable(this.dbxFormLoadingSourceMode);
763
757
  source$ = toObservable(this.dbxFormLoadingSource).pipe(maybeValueFromObservableOrValue(), filterMaybe(), valueFromFinishedLoadingState());
764
758
  constructor() {
765
- super();
766
- this.sub = dbxFormSourceObservableFromStream(this.form.stream$, this.source$, this.mode$).subscribe((x) => {
759
+ cleanSubscription(dbxFormSourceObservableFromStream(this.form.stream$, this.source$, this.mode$).subscribe((x) => {
767
760
  this.form.setValue(x);
768
- });
761
+ }));
769
762
  }
770
763
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormLoadingSourceDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
771
- 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 } }, usesInheritance: true, ngImport: i0 });
764
+ 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 });
772
765
  }
773
766
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormLoadingSourceDirective, decorators: [{
774
767
  type: Directive,
@@ -783,11 +776,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
783
776
  *
784
777
  * Emits undefined when the form is incomplete, and the value when the form is complete.
785
778
  */
786
- class DbxFormValueChangeDirective extends AbstractSubscriptionDirective {
779
+ class DbxFormValueChangeDirective {
787
780
  form = inject((DbxForm), { host: true });
788
781
  dbxFormValueChange = output();
782
+ _sub = cleanSubscription();
789
783
  ngOnInit() {
790
- this.sub = this.form.stream$
784
+ // specifically call within ngOnInit to ensure first emission occurs after the form is initialized.
785
+ this._sub.setSub(this.form.stream$
791
786
  .pipe(mergeMap((x) => this.form.getValue().pipe(first(), map((value) => ({ isComplete: x.isComplete, value })))), delay(0))
792
787
  .subscribe(({ isComplete, value }) => {
793
788
  if (isComplete) {
@@ -796,10 +791,10 @@ class DbxFormValueChangeDirective extends AbstractSubscriptionDirective {
796
791
  else {
797
792
  this.dbxFormValueChange.emit(undefined);
798
793
  }
799
- });
794
+ }));
800
795
  }
801
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormValueChangeDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
802
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DbxFormValueChangeDirective, isStandalone: true, selector: "[dbxFormValueChange]", outputs: { dbxFormValueChange: "dbxFormValueChange" }, usesInheritance: true, ngImport: i0 });
796
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormValueChangeDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
797
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: DbxFormValueChangeDirective, isStandalone: true, selector: "[dbxFormValueChange]", outputs: { dbxFormValueChange: "dbxFormValueChange" }, ngImport: i0 });
803
798
  }
804
799
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxFormValueChangeDirective, decorators: [{
805
800
  type: Directive,
@@ -925,18 +920,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
925
920
  }]
926
921
  }] });
927
922
 
928
- class DbxChecklistItemContentComponent extends AbstractSubscriptionDirective {
923
+ class DbxChecklistItemContentComponent {
929
924
  checklistItemFieldComponent = inject((DbxChecklistItemFieldComponent));
930
925
  config = {
931
926
  componentClass: this.checklistItemFieldComponent.componentClass,
932
927
  init: (instance) => {
933
- this.sub = this.checklistItemFieldComponent.displayContent$.subscribe((content) => {
928
+ cleanSubscription(this.checklistItemFieldComponent.displayContent$.subscribe((content) => {
934
929
  instance.setDisplayContent(content);
935
- });
930
+ }));
936
931
  }
937
932
  };
938
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxChecklistItemContentComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
939
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DbxChecklistItemContentComponent, isStandalone: true, selector: "dbx-checklist-item-content-component", usesInheritance: true, ngImport: i0, template: `
933
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxChecklistItemContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
934
+ 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: `
940
935
  <dbx-injection [config]="config"></dbx-injection>
941
936
  `, isInline: true, dependencies: [{ kind: "component", type: DbxInjectionComponent, selector: "dbx-injection, [dbxInjection], [dbx-injection]", inputs: ["config", "template"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
942
937
  }
@@ -984,6 +979,7 @@ class DbxChecklistItemFieldComponent extends FieldType {
984
979
  return this.checklistField.componentClass ?? DbxDefaultChecklistItemFieldDisplayComponent;
985
980
  }
986
981
  ngOnInit() {
982
+ // field prop is finally available here
987
983
  this._displayContentObs.set(this.checklistField.displayContent);
988
984
  }
989
985
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DbxChecklistItemFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
@@ -1328,7 +1324,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
1328
1324
  }] });
1329
1325
 
1330
1326
  /**
1331
- * Adds a loading bar to help signify asynchronos work is occuring.
1327
+ * Adds a loading bar to help signify asynchronous work is occuring.
1332
1328
  *
1333
1329
  * By default shows loading during asynchronous validation of a field (FormControl status is "PENDING")
1334
1330
  */
@@ -6226,10 +6222,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
6226
6222
  class AbstractFormlyFormDirective {
6227
6223
  context = inject((DbxFormlyContext), { self: true });
6228
6224
  disabled = input(false);
6229
- _setDisabledOnContext = effect(() => this.context.setDisabled(undefined, this.disabled()));
6230
- ngOnDestroy() {
6231
- this._setDisabledOnContext.destroy();
6232
- }
6225
+ _disabledEffect = effect(() => this.context.setDisabled(undefined, this.disabled()));
6233
6226
  // Utility Functions
6234
6227
  getValue() {
6235
6228
  return this.context.getValue();
@@ -6269,15 +6262,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
6269
6262
  * Abstract component for wrapping an asyncrhronously-configured form.
6270
6263
  */
6271
6264
  class AbstractAsyncFormlyFormDirective extends AbstractFormlyFormDirective {
6272
- _fieldsSub = new SubscriptionObject();
6265
+ _fieldSub = cleanSubscription();
6273
6266
  ngOnInit() {
6274
- this._fieldsSub.subscription = this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
6267
+ // fields$ is only available after initialization.
6268
+ this._fieldSub.setSub(this.fields$.pipe(distinctUntilChanged()).subscribe((fields) => {
6275
6269
  this.context.fields = fields;
6276
- });
6277
- }
6278
- ngOnDestroy() {
6279
- super.ngOnDestroy();
6280
- this._fieldsSub.destroy();
6270
+ }));
6281
6271
  }
6282
6272
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AbstractAsyncFormlyFormDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
6283
6273
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AbstractAsyncFormlyFormDirective, usesInheritance: true, ngImport: i0 });