@dereekb/dbx-form 9.25.10 → 9.25.11

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.
@@ -1,4 +1,5 @@
1
1
  import { asObservable } from '@dereekb/rxjs';
2
+ import { convertMaybeToArray, firstValue } from '@dereekb/util';
2
3
  import { map } from 'rxjs';
3
4
  import { formlyField, propsAndConfigForFieldConfig } from '../field';
4
5
  export function valueSelectionField(config) {
@@ -10,15 +11,18 @@ export function valueSelectionField(config) {
10
11
  };
11
12
  }
12
13
  const options = addClearOption ? asObservable(inputOptions).pipe(map(addValueSelectionOptionFunction(typeof addClearOption === 'string' ? addClearOption : undefined))) : inputOptions;
14
+ let parsers = undefined;
15
+ parsers = config.multiple !== true ? [firstValue] : [convertMaybeToArray];
13
16
  return formlyField({
14
17
  key,
15
18
  type: native ? 'native-select' : 'select',
16
19
  ...propsAndConfigForFieldConfig(config, {
17
20
  ...materialFormField,
18
21
  options,
19
- multiple: config.multiple ?? false,
22
+ multiple: config.multiple,
20
23
  ...selectAllOptionConfig
21
- })
24
+ }),
25
+ parsers
22
26
  });
23
27
  }
24
28
  export function addValueSelectionOptionFunction(label) {
@@ -32,4 +36,4 @@ export function addValueSelectionOptionFunction(label) {
32
36
  }
33
37
  };
34
38
  }
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZmllbGQvc2VsZWN0aW9uL3NlbGVjdGlvbi5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUdoRSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNCLE9BQU8sRUFBMEIsV0FBVyxFQUErQyw0QkFBNEIsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQXNDMUksTUFBTSxVQUFVLG1CQUFtQixDQUFJLE1BQW9DO0lBQ3pFLE1BQU0sRUFBRSxHQUFHLEVBQUUsTUFBTSxHQUFHLEtBQUssRUFBRSxjQUFjLEdBQUcsS0FBSyxFQUFFLGVBQWUsRUFBRSxvQkFBb0IsRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQ2hKLElBQUkscUJBQXlELENBQUM7SUFFOUQsSUFBSSxvQkFBb0IsRUFBRTtRQUN4QixxQkFBcUIsR0FBRztZQUN0QixlQUFlLEVBQUUsT0FBTyxvQkFBb0IsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUUsb0JBQStCO1NBQzdHLENBQUM7S0FDSDtJQUVELE1BQU0sT0FBTyxHQUFHLGNBQWMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsK0JBQStCLENBQUMsT0FBTyxjQUFjLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDO0lBRXZMLE9BQU8sV0FBVyxDQUFDO1FBQ2pCLEdBQUc7UUFDSCxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLFFBQVE7UUFDekMsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7WUFDdEMsR0FBRyxpQkFBaUI7WUFDcEIsT0FBTztZQUNQLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUSxJQUFJLEtBQUs7WUFDbEMsR0FBRyxxQkFBcUI7U0FDekIsQ0FBQztLQUNILENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsK0JBQStCLENBQUksS0FBMEI7SUFDM0UsT0FBTyxDQUFDLE9BQWtDLEVBQUUsRUFBRTtRQUM1QyxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBRSxDQUErQixDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBRXpGLElBQUksUUFBUSxFQUFFO1lBQ1osT0FBTyxPQUFPLENBQUM7U0FDaEI7YUFBTTtZQUNMLE9BQU8sQ0FBQyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsQ0FBQztTQUM3QztJQUNILENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhc09ic2VydmFibGUsIE9ic2VydmFibGVPclZhbHVlIH0gZnJvbSAnQGRlcmVla2Ivcnhqcyc7XG5pbXBvcnQgeyBMYWJlbGVkVmFsdWUsIE1heWJlIH0gZnJvbSAnQGRlcmVla2IvdXRpbCc7XG5pbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnLCBmb3JtbHlGaWVsZCwgTGFiZWxlZEZpZWxkQ29uZmlnLCBNYXRlcmlhbEZvcm1GaWVsZENvbmZpZywgcHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyB9IGZyb20gJy4uL2ZpZWxkJztcblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbk9wdGlvbldpdGhWYWx1ZTxUPiBleHRlbmRzIExhYmVsZWRWYWx1ZTxUPiB7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbk9wdGlvbkNsZWFyIHtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGNsZWFyOiB0cnVlO1xufVxuXG5leHBvcnQgdHlwZSBWYWx1ZVNlbGVjdGlvbk9wdGlvbjxUPiA9IFZhbHVlU2VsZWN0aW9uT3B0aW9uV2l0aFZhbHVlPFQ+IHwgVmFsdWVTZWxlY3Rpb25PcHRpb25DbGVhcjtcblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbkZpZWxkQ29uZmlnPFQ+IGV4dGVuZHMgTGFiZWxlZEZpZWxkQ29uZmlnLCBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnLCBNYXRlcmlhbEZvcm1GaWVsZENvbmZpZyB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0byB1c2UgdGhlIG5hdGl2ZSBzZWxlY3QuXG4gICAqXG4gICAqIEJlIHN1cmUgdG8gaW1wb3J0IEZvcm1seU1hdE5hdGl2ZVNlbGVjdE1vZHVsZS5cbiAgICovXG4gIG5hdGl2ZT86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0byBhZGQgYSBjbGVhciBvcHRpb24gdG8gdGhlIGlucHV0IHZhbHVlcy4gSWYgdXNpbmcgYW4gb2JzZXJ2YWJsZSwgdGhpc1xuICAgKi9cbiAgYWRkQ2xlYXJPcHRpb24/OiBzdHJpbmcgfCBib29sZWFuO1xuICAvKipcbiAgICogVmFsdWVzIHRvIHNlbGVjdCBmcm9tLlxuICAgKi9cbiAgb3B0aW9uczogT2JzZXJ2YWJsZU9yVmFsdWU8VmFsdWVTZWxlY3Rpb25PcHRpb248VD5bXT47XG4gIC8qKlxuICAgKiBBbGxvdyBzZWxlY3RpbmcgbXVsdGlwbGUgdmFsdWVzIGFuZCByZXR1cm4gYW4gYXJyYXkuXG4gICAqL1xuICBtdWx0aXBsZT86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBUaGUgc2VsZWN0IGFsbCBvcHRpb24gY29uZmlndXJhdGlvbi5cbiAgICovXG4gIHNlbGVjdEFsbE9wdGlvbj86IHRydWUgfCBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB2YWx1ZVNlbGVjdGlvbkZpZWxkPFQ+KGNvbmZpZzogVmFsdWVTZWxlY3Rpb25GaWVsZENvbmZpZzxUPik6IEZvcm1seUZpZWxkQ29uZmlnIHtcbiAgY29uc3QgeyBrZXksIG5hdGl2ZSA9IGZhbHNlLCBhZGRDbGVhck9wdGlvbiA9IGZhbHNlLCBzZWxlY3RBbGxPcHRpb246IGlucHV0U2VsZWN0QWxsT3B0aW9uLCBvcHRpb25zOiBpbnB1dE9wdGlvbnMsIG1hdGVyaWFsRm9ybUZpZWxkIH0gPSBjb25maWc7XG4gIGxldCBzZWxlY3RBbGxPcHRpb25Db25maWc6IE1heWJlPHsgc2VsZWN0QWxsT3B0aW9uOiBzdHJpbmcgfT47XG5cbiAgaWYgKGlucHV0U2VsZWN0QWxsT3B0aW9uKSB7XG4gICAgc2VsZWN0QWxsT3B0aW9uQ29uZmlnID0ge1xuICAgICAgc2VsZWN0QWxsT3B0aW9uOiB0eXBlb2YgaW5wdXRTZWxlY3RBbGxPcHRpb24gPT09ICdib29sZWFuJyA/ICdTZWxlY3QgQWxsJyA6IChpbnB1dFNlbGVjdEFsbE9wdGlvbiBhcyBzdHJpbmcpXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IG9wdGlvbnMgPSBhZGRDbGVhck9wdGlvbiA/IGFzT2JzZXJ2YWJsZShpbnB1dE9wdGlvbnMpLnBpcGUobWFwKGFkZFZhbHVlU2VsZWN0aW9uT3B0aW9uRnVuY3Rpb24odHlwZW9mIGFkZENsZWFyT3B0aW9uID09PSAnc3RyaW5nJyA/IGFkZENsZWFyT3B0aW9uIDogdW5kZWZpbmVkKSkpIDogaW5wdXRPcHRpb25zO1xuXG4gIHJldHVybiBmb3JtbHlGaWVsZCh7XG4gICAga2V5LFxuICAgIHR5cGU6IG5hdGl2ZSA/ICduYXRpdmUtc2VsZWN0JyA6ICdzZWxlY3QnLFxuICAgIC4uLnByb3BzQW5kQ29uZmlnRm9yRmllbGRDb25maWcoY29uZmlnLCB7XG4gICAgICAuLi5tYXRlcmlhbEZvcm1GaWVsZCxcbiAgICAgIG9wdGlvbnMsXG4gICAgICBtdWx0aXBsZTogY29uZmlnLm11bHRpcGxlID8/IGZhbHNlLFxuICAgICAgLi4uc2VsZWN0QWxsT3B0aW9uQ29uZmlnXG4gICAgfSlcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhZGRWYWx1ZVNlbGVjdGlvbk9wdGlvbkZ1bmN0aW9uPFQ+KGxhYmVsPzogc3RyaW5nIHwgdW5kZWZpbmVkKTogKG9wdGlvbnM6IFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+W10pID0+IFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+W10ge1xuICByZXR1cm4gKG9wdGlvbnM6IFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+W10pID0+IHtcbiAgICBjb25zdCBoYXNDbGVhciA9IG9wdGlvbnMuZmluZEluZGV4KCh4KSA9PiAoeCBhcyBWYWx1ZVNlbGVjdGlvbk9wdGlvbkNsZWFyKS5jbGVhcikgIT09IC0xO1xuXG4gICAgaWYgKGhhc0NsZWFyKSB7XG4gICAgICByZXR1cm4gb3B0aW9ucztcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIFt7IGxhYmVsLCBjbGVhcjogdHJ1ZSB9LCAuLi5vcHRpb25zXTtcbiAgICB9XG4gIH07XG59XG4iXX0=
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZmllbGQvc2VsZWN0aW9uL3NlbGVjdGlvbi5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUNoRSxPQUFPLEVBQVcsbUJBQW1CLEVBQUUsVUFBVSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUU5RixPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNCLE9BQU8sRUFBMEIsV0FBVyxFQUFrRSw0QkFBNEIsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQXNDN0osTUFBTSxVQUFVLG1CQUFtQixDQUFJLE1BQW9DO0lBQ3pFLE1BQU0sRUFBRSxHQUFHLEVBQUUsTUFBTSxHQUFHLEtBQUssRUFBRSxjQUFjLEdBQUcsS0FBSyxFQUFFLGVBQWUsRUFBRSxvQkFBb0IsRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQ2hKLElBQUkscUJBQXlELENBQUM7SUFFOUQsSUFBSSxvQkFBb0IsRUFBRTtRQUN4QixxQkFBcUIsR0FBRztZQUN0QixlQUFlLEVBQUUsT0FBTyxvQkFBb0IsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUUsb0JBQStCO1NBQzdHLENBQUM7S0FDSDtJQUVELE1BQU0sT0FBTyxHQUFHLGNBQWMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsK0JBQStCLENBQUMsT0FBTyxjQUFjLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDO0lBQ3ZMLElBQUksT0FBTyxHQUFvQyxTQUFTLENBQUM7SUFFekQsT0FBTyxHQUFHLE1BQU0sQ0FBQyxRQUFRLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLG1CQUFtQixDQUFDLENBQUM7SUFFMUUsT0FBTyxXQUFXLENBQUM7UUFDakIsR0FBRztRQUNILElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsUUFBUTtRQUN6QyxHQUFHLDRCQUE0QixDQUFDLE1BQU0sRUFBRTtZQUN0QyxHQUFHLGlCQUFpQjtZQUNwQixPQUFPO1lBQ1AsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRO1lBQ3pCLEdBQUcscUJBQXFCO1NBQ3pCLENBQUM7UUFDRixPQUFPO0tBQ1IsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVELE1BQU0sVUFBVSwrQkFBK0IsQ0FBSSxLQUEwQjtJQUMzRSxPQUFPLENBQUMsT0FBa0MsRUFBRSxFQUFFO1FBQzVDLE1BQU0sUUFBUSxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFFLENBQStCLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFFekYsSUFBSSxRQUFRLEVBQUU7WUFDWixPQUFPLE9BQU8sQ0FBQztTQUNoQjthQUFNO1lBQ0wsT0FBTyxDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxDQUFDO1NBQzdDO0lBQ0gsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFzT2JzZXJ2YWJsZSwgT2JzZXJ2YWJsZU9yVmFsdWUgfSBmcm9tICdAZGVyZWVrYi9yeGpzJztcbmltcG9ydCB7IGFzQXJyYXksIGNvbnZlcnRNYXliZVRvQXJyYXksIGZpcnN0VmFsdWUsIExhYmVsZWRWYWx1ZSwgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IEZvcm1seUZpZWxkQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IERlc2NyaXB0aW9uRmllbGRDb25maWcsIGZvcm1seUZpZWxkLCBGb3JtbHlWYWx1ZVBhcnNlciwgTGFiZWxlZEZpZWxkQ29uZmlnLCBNYXRlcmlhbEZvcm1GaWVsZENvbmZpZywgcHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyB9IGZyb20gJy4uL2ZpZWxkJztcblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbk9wdGlvbldpdGhWYWx1ZTxUPiBleHRlbmRzIExhYmVsZWRWYWx1ZTxUPiB7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbk9wdGlvbkNsZWFyIHtcbiAgbGFiZWw/OiBzdHJpbmc7XG4gIGNsZWFyOiB0cnVlO1xufVxuXG5leHBvcnQgdHlwZSBWYWx1ZVNlbGVjdGlvbk9wdGlvbjxUPiA9IFZhbHVlU2VsZWN0aW9uT3B0aW9uV2l0aFZhbHVlPFQ+IHwgVmFsdWVTZWxlY3Rpb25PcHRpb25DbGVhcjtcblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbkZpZWxkQ29uZmlnPFQ+IGV4dGVuZHMgTGFiZWxlZEZpZWxkQ29uZmlnLCBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnLCBNYXRlcmlhbEZvcm1GaWVsZENvbmZpZyB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0byB1c2UgdGhlIG5hdGl2ZSBzZWxlY3QuXG4gICAqXG4gICAqIEJlIHN1cmUgdG8gaW1wb3J0IEZvcm1seU1hdE5hdGl2ZVNlbGVjdE1vZHVsZS5cbiAgICovXG4gIHJlYWRvbmx5IG5hdGl2ZT86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0byBhZGQgYSBjbGVhciBvcHRpb24gdG8gdGhlIGlucHV0IHZhbHVlcy5cbiAgICovXG4gIHJlYWRvbmx5IGFkZENsZWFyT3B0aW9uPzogc3RyaW5nIHwgYm9vbGVhbjtcbiAgLyoqXG4gICAqIFZhbHVlcyB0byBzZWxlY3QgZnJvbS5cbiAgICovXG4gIHJlYWRvbmx5IG9wdGlvbnM6IE9ic2VydmFibGVPclZhbHVlPFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+W10+O1xuICAvKipcbiAgICogQWxsb3cgc2VsZWN0aW5nIG11bHRpcGxlIHZhbHVlcyBhbmQgcmV0dXJuIGFuIGFycmF5LlxuICAgKi9cbiAgcmVhZG9ubHkgbXVsdGlwbGU/OiBib29sZWFuO1xuICAvKipcbiAgICogVGhlIHNlbGVjdCBhbGwgb3B0aW9uIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICByZWFkb25seSBzZWxlY3RBbGxPcHRpb24/OiB0cnVlIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdmFsdWVTZWxlY3Rpb25GaWVsZDxUPihjb25maWc6IFZhbHVlU2VsZWN0aW9uRmllbGRDb25maWc8VD4pOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIGNvbnN0IHsga2V5LCBuYXRpdmUgPSBmYWxzZSwgYWRkQ2xlYXJPcHRpb24gPSBmYWxzZSwgc2VsZWN0QWxsT3B0aW9uOiBpbnB1dFNlbGVjdEFsbE9wdGlvbiwgb3B0aW9uczogaW5wdXRPcHRpb25zLCBtYXRlcmlhbEZvcm1GaWVsZCB9ID0gY29uZmlnO1xuICBsZXQgc2VsZWN0QWxsT3B0aW9uQ29uZmlnOiBNYXliZTx7IHNlbGVjdEFsbE9wdGlvbjogc3RyaW5nIH0+O1xuXG4gIGlmIChpbnB1dFNlbGVjdEFsbE9wdGlvbikge1xuICAgIHNlbGVjdEFsbE9wdGlvbkNvbmZpZyA9IHtcbiAgICAgIHNlbGVjdEFsbE9wdGlvbjogdHlwZW9mIGlucHV0U2VsZWN0QWxsT3B0aW9uID09PSAnYm9vbGVhbicgPyAnU2VsZWN0IEFsbCcgOiAoaW5wdXRTZWxlY3RBbGxPcHRpb24gYXMgc3RyaW5nKVxuICAgIH07XG4gIH1cblxuICBjb25zdCBvcHRpb25zID0gYWRkQ2xlYXJPcHRpb24gPyBhc09ic2VydmFibGUoaW5wdXRPcHRpb25zKS5waXBlKG1hcChhZGRWYWx1ZVNlbGVjdGlvbk9wdGlvbkZ1bmN0aW9uKHR5cGVvZiBhZGRDbGVhck9wdGlvbiA9PT0gJ3N0cmluZycgPyBhZGRDbGVhck9wdGlvbiA6IHVuZGVmaW5lZCkpKSA6IGlucHV0T3B0aW9ucztcbiAgbGV0IHBhcnNlcnM6IEZvcm1seVZhbHVlUGFyc2VyW10gfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ7XG5cbiAgcGFyc2VycyA9IGNvbmZpZy5tdWx0aXBsZSAhPT0gdHJ1ZSA/IFtmaXJzdFZhbHVlXSA6IFtjb252ZXJ0TWF5YmVUb0FycmF5XTtcblxuICByZXR1cm4gZm9ybWx5RmllbGQoe1xuICAgIGtleSxcbiAgICB0eXBlOiBuYXRpdmUgPyAnbmF0aXZlLXNlbGVjdCcgOiAnc2VsZWN0JyxcbiAgICAuLi5wcm9wc0FuZENvbmZpZ0ZvckZpZWxkQ29uZmlnKGNvbmZpZywge1xuICAgICAgLi4ubWF0ZXJpYWxGb3JtRmllbGQsXG4gICAgICBvcHRpb25zLFxuICAgICAgbXVsdGlwbGU6IGNvbmZpZy5tdWx0aXBsZSxcbiAgICAgIC4uLnNlbGVjdEFsbE9wdGlvbkNvbmZpZ1xuICAgIH0pLFxuICAgIHBhcnNlcnNcbiAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhZGRWYWx1ZVNlbGVjdGlvbk9wdGlvbkZ1bmN0aW9uPFQ+KGxhYmVsPzogc3RyaW5nIHwgdW5kZWZpbmVkKTogKG9wdGlvbnM6IFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+W10pID0+IFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+W10ge1xuICByZXR1cm4gKG9wdGlvbnM6IFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+W10pID0+IHtcbiAgICBjb25zdCBoYXNDbGVhciA9IG9wdGlvbnMuZmluZEluZGV4KCh4KSA9PiAoeCBhcyBWYWx1ZVNlbGVjdGlvbk9wdGlvbkNsZWFyKS5jbGVhcikgIT09IC0xO1xuXG4gICAgaWYgKGhhc0NsZWFyKSB7XG4gICAgICByZXR1cm4gb3B0aW9ucztcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIFt7IGxhYmVsLCBjbGVhcjogdHJ1ZSB9LCAuLi5vcHRpb25zXTtcbiAgICB9XG4gIH07XG59XG4iXX0=
@@ -24,8 +24,8 @@ export class DbxFormlyContext {
24
24
  this._initialValue = new BehaviorSubject(undefined);
25
25
  this._disabled = new BehaviorSubject(undefined);
26
26
  this._delegate = new BehaviorSubject(undefined);
27
- this.fields$ = this._fields.pipe(filterMaybe());
28
- this.disabled$ = this._disabled.pipe(filterMaybe());
27
+ this.fields$ = this._fields.pipe(filterMaybe(), shareReplay(1));
28
+ this.disabled$ = this._disabled.pipe(filterMaybe(), shareReplay(1));
29
29
  this.stream$ = this._delegate.pipe(distinctUntilChanged(), switchMap((x) => (x ? x.stream$ : of(DbxFormlyContext.INITIAL_STATE))), shareReplay(1));
30
30
  }
31
31
  destroy() {
@@ -41,7 +41,7 @@ export class DbxFormlyContext {
41
41
  if (delegate != null) {
42
42
  delegate.init({
43
43
  fields: this.fields$,
44
- initialDisabled: this._disabled.value,
44
+ initialDisabled: this.disabled,
45
45
  initialValue: this._initialValue.value
46
46
  });
47
47
  }
@@ -79,7 +79,8 @@ export class DbxFormlyContext {
79
79
  return this._disabled.asObservable();
80
80
  }
81
81
  setDisabled(key, disabled = true) {
82
- this._disabled.next(BooleanStringKeyArrayUtilityInstance.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled));
82
+ const nextDisabled = BooleanStringKeyArrayUtilityInstance.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled);
83
+ this._disabled.next(nextDisabled);
83
84
  if (this._delegate.value) {
84
85
  this._delegate.value.setDisabled(key, disabled);
85
86
  }
@@ -96,4 +97,4 @@ export class DbxFormlyContext {
96
97
  }
97
98
  }
98
99
  DbxFormlyContext.INITIAL_STATE = { isComplete: false, state: DbxFormState.INITIALIZING, status: 'PENDING' };
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly.context.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/src/lib/formly/formly.context.ts"],"names":[],"mappings":"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","sourcesContent":["import { Provider } from '@angular/core';\nimport { BehaviorSubject, Observable, of, switchMap, shareReplay, distinctUntilChanged } from 'rxjs';\nimport { DbxForm, DbxFormDisabledKey, DbxFormEvent, DbxFormState, DbxMutableForm, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm } from '../form/form';\nimport { FormlyFieldConfig } from '@ngx-formly/core';\nimport { LockSet, filterMaybe } from '@dereekb/rxjs';\nimport { BooleanStringKeyArray, BooleanStringKeyArrayUtilityInstance, Maybe } from '@dereekb/util';\n\nexport interface DbxFormlyInitialize<T> {\n  fields: Observable<FormlyFieldConfig[]>;\n  initialDisabled: BooleanStringKeyArray;\n  initialValue: Maybe<Partial<T>>;\n}\n\n/**\n * DbxFormlyContext delegate.\n *\n * This is usually the component or element that contains the form itself.\n */\nexport interface DbxFormlyContextDelegate<T = unknown> extends Omit<DbxMutableForm<T>, 'lockSet'> {\n  readonly stream$: Observable<DbxFormEvent>;\n  init(initialize: DbxFormlyInitialize<T>): void;\n}\n\n/**\n * Allows a directive to provide a formly context and form.\n */\nexport function provideFormlyContext(): Provider[] {\n  return [\n    {\n      provide: DbxFormlyContext,\n      useClass: DbxFormlyContext\n    },\n    ...provideDbxMutableForm(DbxFormlyContext)\n  ];\n}\n\n/**\n * DbxForm Instance that registers a delegate and manages the state of that form/delegate.\n */\nexport class DbxFormlyContext<T = unknown> implements DbxForm<T> {\n  private static INITIAL_STATE: DbxFormEvent = { isComplete: false, state: DbxFormState.INITIALIZING, status: 'PENDING' };\n\n  readonly lockSet = new LockSet();\n\n  private _fields = new BehaviorSubject<Maybe<FormlyFieldConfig[]>>(undefined);\n  private _initialValue = new BehaviorSubject<Maybe<Partial<T>>>(undefined);\n  private _disabled = new BehaviorSubject<BooleanStringKeyArray>(undefined);\n  private _delegate = new BehaviorSubject<Maybe<DbxFormlyContextDelegate<T>>>(undefined);\n\n  readonly fields$ = this._fields.pipe(filterMaybe());\n  readonly disabled$ = this._disabled.pipe(filterMaybe());\n  readonly stream$: Observable<DbxFormEvent> = this._delegate.pipe(\n    distinctUntilChanged(),\n    switchMap((x) => (x ? x.stream$ : of(DbxFormlyContext.INITIAL_STATE))),\n    shareReplay(1)\n  );\n\n  destroy(): void {\n    this.lockSet.destroyOnNextUnlock(() => {\n      this._fields.complete();\n      this._initialValue.complete();\n      this._disabled.complete();\n      this._delegate.complete();\n    });\n  }\n\n  setDelegate(delegate?: DbxFormlyContextDelegate<T>): void {\n    if (delegate !== this._delegate.value) {\n      if (delegate != null) {\n        delegate.init({\n          fields: this.fields$,\n          initialDisabled: this._disabled.value,\n          initialValue: this._initialValue.value\n        });\n      }\n\n      this._delegate.next(delegate);\n    }\n  }\n\n  clearDelegate(delegate: DbxFormlyContextDelegate<T>): void {\n    if (delegate === this._delegate.value) {\n      this.setDelegate(undefined);\n    }\n  }\n\n  get fields(): Maybe<FormlyFieldConfig[]> {\n    return this._fields.value;\n  }\n\n  set fields(fields: Maybe<FormlyFieldConfig[]>) {\n    this._fields.next(fields);\n  }\n\n  // MARK: FormComponent\n  getValue(): Observable<T> {\n    return this._delegate.pipe(\n      filterMaybe(),\n      switchMap((x) => x.getValue()),\n      shareReplay(1)\n    );\n  }\n\n  setValue(value: Partial<T>): void {\n    this._initialValue.next(value);\n\n    if (this._delegate.value) {\n      this._delegate.value.setValue(value);\n    }\n  }\n\n  isDisabled(): boolean {\n    return BooleanStringKeyArrayUtilityInstance.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    this._disabled.next(BooleanStringKeyArrayUtilityInstance.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled));\n\n    if (this._delegate.value) {\n      this._delegate.value.setDisabled(key, disabled);\n    }\n  }\n\n  resetForm(): void {\n    if (this._delegate.value) {\n      this._delegate.value.resetForm();\n    }\n  }\n\n  forceFormUpdate(): void {\n    if (this._delegate.value) {\n      this._delegate.value.forceFormUpdate();\n    }\n  }\n}\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly.context.js","sourceRoot":"","sources":["../../../../../../packages/dbx-form/src/lib/formly/formly.context.ts"],"names":[],"mappings":"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","sourcesContent":["import { Provider } from '@angular/core';\nimport { BehaviorSubject, Observable, of, switchMap, shareReplay, distinctUntilChanged } from 'rxjs';\nimport { DbxForm, DbxFormDisabledKey, DbxFormEvent, DbxFormState, DbxMutableForm, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm } from '../form/form';\nimport { FormlyFieldConfig } from '@ngx-formly/core';\nimport { LockSet, filterMaybe } from '@dereekb/rxjs';\nimport { BooleanStringKeyArray, BooleanStringKeyArrayUtilityInstance, Maybe } from '@dereekb/util';\n\nexport interface DbxFormlyInitialize<T> {\n  fields: Observable<FormlyFieldConfig[]>;\n  initialDisabled: BooleanStringKeyArray;\n  initialValue: Maybe<Partial<T>>;\n}\n\n/**\n * DbxFormlyContext delegate.\n *\n * This is usually the component or element that contains the form itself.\n */\nexport interface DbxFormlyContextDelegate<T = unknown> extends Omit<DbxMutableForm<T>, 'lockSet'> {\n  readonly stream$: Observable<DbxFormEvent>;\n  init(initialize: DbxFormlyInitialize<T>): void;\n}\n\n/**\n * Allows a directive to provide a formly context and form.\n */\nexport function provideFormlyContext(): Provider[] {\n  return [\n    {\n      provide: DbxFormlyContext,\n      useClass: DbxFormlyContext\n    },\n    ...provideDbxMutableForm(DbxFormlyContext)\n  ];\n}\n\n/**\n * DbxForm Instance that registers a delegate and manages the state of that form/delegate.\n */\nexport class DbxFormlyContext<T = unknown> implements DbxForm<T> {\n  private static INITIAL_STATE: DbxFormEvent = { isComplete: false, state: DbxFormState.INITIALIZING, status: 'PENDING' };\n\n  readonly lockSet = new LockSet();\n\n  private _fields = new BehaviorSubject<Maybe<FormlyFieldConfig[]>>(undefined);\n  private _initialValue = new BehaviorSubject<Maybe<Partial<T>>>(undefined);\n  private _disabled = new BehaviorSubject<BooleanStringKeyArray>(undefined);\n  private _delegate = new BehaviorSubject<Maybe<DbxFormlyContextDelegate<T>>>(undefined);\n\n  readonly fields$ = this._fields.pipe(filterMaybe(), shareReplay(1));\n  readonly disabled$ = this._disabled.pipe(filterMaybe(), shareReplay(1));\n  readonly stream$: Observable<DbxFormEvent> = this._delegate.pipe(\n    distinctUntilChanged(),\n    switchMap((x) => (x ? x.stream$ : of(DbxFormlyContext.INITIAL_STATE))),\n    shareReplay(1)\n  );\n\n  destroy(): void {\n    this.lockSet.destroyOnNextUnlock(() => {\n      this._fields.complete();\n      this._initialValue.complete();\n      this._disabled.complete();\n      this._delegate.complete();\n    });\n  }\n\n  setDelegate(delegate?: DbxFormlyContextDelegate<T>): void {\n    if (delegate !== this._delegate.value) {\n      if (delegate != null) {\n        delegate.init({\n          fields: this.fields$,\n          initialDisabled: this.disabled,\n          initialValue: this._initialValue.value\n        });\n      }\n\n      this._delegate.next(delegate);\n    }\n  }\n\n  clearDelegate(delegate: DbxFormlyContextDelegate<T>): void {\n    if (delegate === this._delegate.value) {\n      this.setDelegate(undefined);\n    }\n  }\n\n  get fields(): Maybe<FormlyFieldConfig[]> {\n    return this._fields.value;\n  }\n\n  set fields(fields: Maybe<FormlyFieldConfig[]>) {\n    this._fields.next(fields);\n  }\n\n  // MARK: FormComponent\n  getValue(): Observable<T> {\n    return this._delegate.pipe(\n      filterMaybe(),\n      switchMap((x) => x.getValue()),\n      shareReplay(1)\n    );\n  }\n\n  setValue(value: Partial<T>): void {\n    this._initialValue.next(value);\n\n    if (this._delegate.value) {\n      this._delegate.value.setValue(value);\n    }\n  }\n\n  isDisabled(): boolean {\n    return BooleanStringKeyArrayUtilityInstance.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 nextDisabled = BooleanStringKeyArrayUtilityInstance.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled);\n    this._disabled.next(nextDisabled);\n\n    if (this._delegate.value) {\n      this._delegate.value.setDisabled(key, disabled);\n    }\n  }\n\n  resetForm(): void {\n    if (this._delegate.value) {\n      this._delegate.value.resetForm();\n    }\n  }\n\n  forceFormUpdate(): void {\n    if (this._delegate.value) {\n      this._delegate.value.forceFormUpdate();\n    }\n  }\n}\n"]}
@@ -6,7 +6,7 @@ import { DbxFormState, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm } from '
6
6
  import { DbxFormlyContext } from './formly.context';
7
7
  import { cloneDeep } from 'lodash';
8
8
  import { scanCount, switchMapMaybeObs, SubscriptionObject } from '@dereekb/rxjs';
9
- import { BooleanStringKeyArrayUtilityInstance } from '@dereekb/util';
9
+ import { BooleanStringKeyArrayUtilityInstance, hasDifferentValues } from '@dereekb/util';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "./formly.context";
12
12
  import * as i2 from "@angular/forms";
@@ -25,6 +25,7 @@ export class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
25
25
  this._reset = new BehaviorSubject(new Date());
26
26
  this._forceUpdate = new Subject();
27
27
  this._disabledSub = new SubscriptionObject();
28
+ this._enforceDisabledSub = new SubscriptionObject();
28
29
  this.form = new FormGroup({});
29
30
  this.model = {};
30
31
  this.options = {};
@@ -82,8 +83,9 @@ export class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
82
83
  }
83
84
  ngOnInit() {
84
85
  this.context.setDelegate(this);
85
- this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged()).subscribe((disabled) => {
86
- const isDisabled = BooleanStringKeyArrayUtilityInstance.isTrue(disabled);
86
+ const resyncDisabledState = () => {
87
+ const isDisabled = BooleanStringKeyArrayUtilityInstance.isTrue(this._disabled.value);
88
+ let change = false;
87
89
  if (this.form.disabled !== isDisabled) {
88
90
  if (isDisabled) {
89
91
  this.form.disable({ emitEvent: true });
@@ -91,7 +93,16 @@ export class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
91
93
  else {
92
94
  this.form.enable({ emitEvent: true });
93
95
  }
96
+ change = true;
94
97
  }
98
+ return change;
99
+ };
100
+ this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged(hasDifferentValues)).subscribe((disabled) => {
101
+ resyncDisabledState();
102
+ });
103
+ // NOTE: Form sometimes becomes undisabled somewhere/somehow. Re-enforce the disabled state where necessary.
104
+ this._enforceDisabledSub.subscription = this.form.statusChanges.pipe(throttleTime(50, undefined, { leading: true, trailing: true })).subscribe((change) => {
105
+ resyncDisabledState();
95
106
  });
96
107
  }
97
108
  ngOnDestroy() {
@@ -104,6 +115,7 @@ export class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
104
115
  this._forceUpdate.complete();
105
116
  this._disabled.complete();
106
117
  this._disabledSub.destroy();
118
+ this._enforceDisabledSub.destroy();
107
119
  });
108
120
  }
109
121
  // MARK: Delegate
@@ -179,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
179
191
  }
180
192
  }]
181
193
  }], ctorParameters: function () { return [{ type: i1.DbxFormlyContext }]; } });
182
- //# 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 { Component, OnDestroy, OnInit } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { FormlyFieldConfig, FormlyFormOptions } from '@ngx-formly/core';\nimport { distinctUntilChanged, map, throttleTime, startWith, BehaviorSubject, Observable, Subject, switchMap, shareReplay, of, scan, filter, timer, first } from 'rxjs';\nimport { AbstractSubscriptionDirective } from '@dereekb/dbx-core';\nimport { DbxForm, DbxFormDisabledKey, DbxFormEvent, DbxFormState, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm } from '../form/form';\nimport { DbxFormlyContext, DbxFormlyContextDelegate, DbxFormlyInitialize } from './formly.context';\nimport { cloneDeep } from 'lodash';\nimport { scanCount, switchMapMaybeObs, SubscriptionObject } from '@dereekb/rxjs';\nimport { BooleanStringKeyArray, BooleanStringKeyArrayUtilityInstance, Maybe } from '@dereekb/util';\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\" [fields]=\"(fields$ | async) ?? []\" [model]=\"model\"></formly-form>\n    </form>\n  `,\n  providers: provideDbxMutableForm(DbxFormlyFormComponent),\n  host: {\n    class: 'dbx-formly'\n  }\n})\nexport class DbxFormlyFormComponent<T> extends AbstractSubscriptionDirective implements DbxForm, DbxFormlyContextDelegate<T>, OnInit, OnDestroy {\n  private _fields = new BehaviorSubject<Maybe<Observable<FormlyFieldConfig[]>>>(undefined);\n  private _events = new BehaviorSubject<DbxFormEvent>({ isComplete: false, state: DbxFormState.INITIALIZING, status: 'PENDING' });\n  private _disabled = new BehaviorSubject<BooleanStringKeyArray>(undefined);\n\n  private _reset = new BehaviorSubject<Date>(new Date());\n  private _forceUpdate = new Subject<void>();\n\n  private _disabledSub = new SubscriptionObject();\n\n  form = new FormGroup({});\n  model: T = {} as T;\n  options: FormlyFormOptions = {};\n\n  readonly fields$ = this._fields.pipe(switchMapMaybeObs(), 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  constructor(private readonly context: DbxFormlyContext<T>) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.context.setDelegate(this);\n\n    this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged()).subscribe((disabled) => {\n      const isDisabled = BooleanStringKeyArrayUtilityInstance.isTrue(disabled);\n\n      if (this.form.disabled !== isDisabled) {\n        if (isDisabled) {\n          this.form.disable({ emitEvent: true });\n        } else {\n          this.form.enable({ emitEvent: true });\n        }\n      }\n    });\n  }\n\n  override ngOnDestroy(): void {\n    this.context.lockSet.onNextUnlock(() => {\n      super.ngOnDestroy();\n      this.context.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    });\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    // console.log('set value: ', value);\n    this.model = cloneDeep(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 BooleanStringKeyArrayUtilityInstance.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    this._disabled.next(BooleanStringKeyArrayUtilityInstance.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled));\n  }\n\n  // MARK: Update\n  forceFormUpdate(): void {\n    this._forceUpdate.next();\n  }\n}\n"]}
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 { Component, OnDestroy, OnInit } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { FormlyFieldConfig, FormlyFormOptions } from '@ngx-formly/core';\nimport { distinctUntilChanged, map, throttleTime, startWith, BehaviorSubject, Observable, Subject, switchMap, shareReplay, of, scan, filter, timer, first } from 'rxjs';\nimport { AbstractSubscriptionDirective } from '@dereekb/dbx-core';\nimport { DbxForm, DbxFormDisabledKey, DbxFormEvent, DbxFormState, DEFAULT_FORM_DISABLED_KEY, provideDbxMutableForm } from '../form/form';\nimport { DbxFormlyContext, DbxFormlyContextDelegate, DbxFormlyInitialize } from './formly.context';\nimport { cloneDeep } from 'lodash';\nimport { scanCount, switchMapMaybeObs, SubscriptionObject } from '@dereekb/rxjs';\nimport { BooleanStringKeyArray, BooleanStringKeyArrayUtilityInstance, hasDifferentValues, Maybe } from '@dereekb/util';\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\" [fields]=\"(fields$ | async) ?? []\" [model]=\"model\"></formly-form>\n    </form>\n  `,\n  providers: provideDbxMutableForm(DbxFormlyFormComponent),\n  host: {\n    class: 'dbx-formly'\n  }\n})\nexport class DbxFormlyFormComponent<T> extends AbstractSubscriptionDirective implements DbxForm, DbxFormlyContextDelegate<T>, OnInit, OnDestroy {\n  private _fields = new BehaviorSubject<Maybe<Observable<FormlyFieldConfig[]>>>(undefined);\n  private _events = new BehaviorSubject<DbxFormEvent>({ isComplete: false, state: DbxFormState.INITIALIZING, status: 'PENDING' });\n  private _disabled = new BehaviorSubject<BooleanStringKeyArray>(undefined);\n\n  private _reset = new BehaviorSubject<Date>(new Date());\n  private _forceUpdate = new Subject<void>();\n\n  private _disabledSub = new SubscriptionObject();\n  private _enforceDisabledSub = new SubscriptionObject();\n\n  readonly form = new FormGroup({});\n\n  model: T = {} as T;\n  options: FormlyFormOptions = {};\n\n  readonly fields$ = this._fields.pipe(switchMapMaybeObs(), 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  constructor(private readonly context: DbxFormlyContext<T>) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.context.setDelegate(this);\n\n    const resyncDisabledState = () => {\n      const isDisabled = BooleanStringKeyArrayUtilityInstance.isTrue(this._disabled.value);\n      let change = false;\n\n      if (this.form.disabled !== isDisabled) {\n        if (isDisabled) {\n          this.form.disable({ emitEvent: true });\n        } else {\n          this.form.enable({ emitEvent: true });\n        }\n\n        change = true;\n      }\n\n      return change;\n    };\n\n    this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged(hasDifferentValues)).subscribe((disabled) => {\n      resyncDisabledState();\n    });\n\n    // NOTE: Form sometimes becomes undisabled somewhere/somehow. Re-enforce the disabled state where necessary.\n    this._enforceDisabledSub.subscription = this.form.statusChanges.pipe(throttleTime(50, undefined, { leading: true, trailing: true })).subscribe((change) => {\n      resyncDisabledState();\n    });\n  }\n\n  override ngOnDestroy(): void {\n    this.context.lockSet.onNextUnlock(() => {\n      super.ngOnDestroy();\n      this.context.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    // console.log('set value: ', value);\n    this.model = cloneDeep(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 BooleanStringKeyArrayUtilityInstance.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    this._disabled.next(BooleanStringKeyArrayUtilityInstance.set(this.disabled, key ?? DEFAULT_FORM_DISABLED_KEY, disabled));\n  }\n\n  // MARK: Update\n  forceFormUpdate(): void {\n    this._forceUpdate.next();\n  }\n}\n"]}
@@ -26,7 +26,7 @@ import * as i1$1 from '@angular/material/button';
26
26
  import { MatButtonModule } from '@angular/material/button';
27
27
  import * as i3$2 from '@angular/flex-layout/flex';
28
28
  import { FlexLayoutModule } from '@angular/flex-layout';
29
- import { objectIsEmpty, mergeObjectsFunction, filterFromPOJOFunction, mergeObjects, filterFromPOJO, asArray, objectHasNoKeys, addPlusPrefixToNumber, convertMaybeToArray, isSelectedDecisionFunctionFactory, readKeysFrom, hasDifferentValues, makeValuesGroupMap, separateValues, filterUniqueValues, searchStringFilterFunction, caseInsensitiveFilterByIndexOfDecisionFactory, sortByStringFunction, mergeIntoArray, lastValue, arrayToMap, setContainsAllValues, addToSetCopy, setsAreEquivalent, filterMaybeValues, mergeArrays, cachedGetter, makeGetter, asDecisionFunction, getValueFromGetter, asGetter, isISO8601DayStringStart, mapIdentityFunction, MS_IN_MINUTE, isMonthDaySlashDate, HAS_WEBSITE_DOMAIN_NAME_REGEX, KeyValueTypleValueFilter, valuesFromPOJO, allObjectsAreEqual, isNumberDivisibleBy, nearestDivisibleValues, isE164PhoneNumber as isE164PhoneNumber$1, isValidPhoneExtensionNumber, e164PhoneNumberExtensionPair, mapMaybeFunction, transformNumberFunction, concatArrays, e164PhoneNumberFromE164PhoneNumberExtensionPair, transformStringFunction, US_STATE_CODE_STRING_REGEX, ZIP_CODE_STRING_REGEX, LAT_LNG_PATTERN, BooleanStringKeyArrayUtilityInstance, capitalizeFirstLetter } from '@dereekb/util';
29
+ import { objectIsEmpty, mergeObjectsFunction, filterFromPOJOFunction, mergeObjects, filterFromPOJO, asArray, objectHasNoKeys, addPlusPrefixToNumber, convertMaybeToArray, isSelectedDecisionFunctionFactory, readKeysFrom, hasDifferentValues, makeValuesGroupMap, separateValues, filterUniqueValues, searchStringFilterFunction, caseInsensitiveFilterByIndexOfDecisionFactory, sortByStringFunction, mergeIntoArray, lastValue, arrayToMap, setContainsAllValues, addToSetCopy, setsAreEquivalent, filterMaybeValues, mergeArrays, firstValue, cachedGetter, makeGetter, asDecisionFunction, getValueFromGetter, asGetter, isISO8601DayStringStart, mapIdentityFunction, MS_IN_MINUTE, isMonthDaySlashDate, HAS_WEBSITE_DOMAIN_NAME_REGEX, KeyValueTypleValueFilter, valuesFromPOJO, allObjectsAreEqual, isNumberDivisibleBy, nearestDivisibleValues, isE164PhoneNumber as isE164PhoneNumber$1, isValidPhoneExtensionNumber, e164PhoneNumberExtensionPair, mapMaybeFunction, transformNumberFunction, concatArrays, e164PhoneNumberFromE164PhoneNumberExtensionPair, transformStringFunction, US_STATE_CODE_STRING_REGEX, ZIP_CODE_STRING_REGEX, LAT_LNG_PATTERN, BooleanStringKeyArrayUtilityInstance, capitalizeFirstLetter } from '@dereekb/util';
30
30
  import * as i2$2 from '@angular/material/slide-toggle';
31
31
  import { MatSlideToggleModule } from '@angular/material/slide-toggle';
32
32
  import * as i2$3 from '@angular/flex-layout/extended';
@@ -3110,7 +3110,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
3110
3110
  }] });
3111
3111
 
3112
3112
  function valueSelectionField(config) {
3113
- var _a;
3114
3113
  const { key, native = false, addClearOption = false, selectAllOption: inputSelectAllOption, options: inputOptions, materialFormField } = config;
3115
3114
  let selectAllOptionConfig;
3116
3115
  if (inputSelectAllOption) {
@@ -3119,7 +3118,9 @@ function valueSelectionField(config) {
3119
3118
  };
3120
3119
  }
3121
3120
  const options = addClearOption ? asObservable(inputOptions).pipe(map(addValueSelectionOptionFunction(typeof addClearOption === 'string' ? addClearOption : undefined))) : inputOptions;
3122
- return formlyField(Object.assign({ key, type: native ? 'native-select' : 'select' }, propsAndConfigForFieldConfig(config, Object.assign(Object.assign(Object.assign({}, materialFormField), { options, multiple: (_a = config.multiple) !== null && _a !== void 0 ? _a : false }), selectAllOptionConfig))));
3121
+ let parsers = undefined;
3122
+ parsers = config.multiple !== true ? [firstValue] : [convertMaybeToArray];
3123
+ return formlyField(Object.assign(Object.assign({ key, type: native ? 'native-select' : 'select' }, propsAndConfigForFieldConfig(config, Object.assign(Object.assign(Object.assign({}, materialFormField), { options, multiple: config.multiple }), selectAllOptionConfig))), { parsers }));
3123
3124
  }
3124
3125
  function addValueSelectionOptionFunction(label) {
3125
3126
  return (options) => {
@@ -5551,8 +5552,8 @@ class DbxFormlyContext {
5551
5552
  this._initialValue = new BehaviorSubject(undefined);
5552
5553
  this._disabled = new BehaviorSubject(undefined);
5553
5554
  this._delegate = new BehaviorSubject(undefined);
5554
- this.fields$ = this._fields.pipe(filterMaybe());
5555
- this.disabled$ = this._disabled.pipe(filterMaybe());
5555
+ this.fields$ = this._fields.pipe(filterMaybe(), shareReplay(1));
5556
+ this.disabled$ = this._disabled.pipe(filterMaybe(), shareReplay(1));
5556
5557
  this.stream$ = this._delegate.pipe(distinctUntilChanged(), switchMap((x) => (x ? x.stream$ : of(DbxFormlyContext.INITIAL_STATE))), shareReplay(1));
5557
5558
  }
5558
5559
  destroy() {
@@ -5568,7 +5569,7 @@ class DbxFormlyContext {
5568
5569
  if (delegate != null) {
5569
5570
  delegate.init({
5570
5571
  fields: this.fields$,
5571
- initialDisabled: this._disabled.value,
5572
+ initialDisabled: this.disabled,
5572
5573
  initialValue: this._initialValue.value
5573
5574
  });
5574
5575
  }
@@ -5606,7 +5607,8 @@ class DbxFormlyContext {
5606
5607
  return this._disabled.asObservable();
5607
5608
  }
5608
5609
  setDisabled(key, disabled = true) {
5609
- this._disabled.next(BooleanStringKeyArrayUtilityInstance.set(this.disabled, key !== null && key !== void 0 ? key : DEFAULT_FORM_DISABLED_KEY, disabled));
5610
+ const nextDisabled = BooleanStringKeyArrayUtilityInstance.set(this.disabled, key !== null && key !== void 0 ? key : DEFAULT_FORM_DISABLED_KEY, disabled);
5611
+ this._disabled.next(nextDisabled);
5610
5612
  if (this._delegate.value) {
5611
5613
  this._delegate.value.setDisabled(key, disabled);
5612
5614
  }
@@ -5752,6 +5754,7 @@ class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
5752
5754
  this._reset = new BehaviorSubject(new Date());
5753
5755
  this._forceUpdate = new Subject();
5754
5756
  this._disabledSub = new SubscriptionObject();
5757
+ this._enforceDisabledSub = new SubscriptionObject();
5755
5758
  this.form = new FormGroup({});
5756
5759
  this.model = {};
5757
5760
  this.options = {};
@@ -5809,8 +5812,9 @@ class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
5809
5812
  }
5810
5813
  ngOnInit() {
5811
5814
  this.context.setDelegate(this);
5812
- this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged()).subscribe((disabled) => {
5813
- const isDisabled = BooleanStringKeyArrayUtilityInstance.isTrue(disabled);
5815
+ const resyncDisabledState = () => {
5816
+ const isDisabled = BooleanStringKeyArrayUtilityInstance.isTrue(this._disabled.value);
5817
+ let change = false;
5814
5818
  if (this.form.disabled !== isDisabled) {
5815
5819
  if (isDisabled) {
5816
5820
  this.form.disable({ emitEvent: true });
@@ -5818,7 +5822,16 @@ class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
5818
5822
  else {
5819
5823
  this.form.enable({ emitEvent: true });
5820
5824
  }
5825
+ change = true;
5821
5826
  }
5827
+ return change;
5828
+ };
5829
+ this._disabledSub.subscription = this._disabled.pipe(distinctUntilChanged(hasDifferentValues)).subscribe((disabled) => {
5830
+ resyncDisabledState();
5831
+ });
5832
+ // NOTE: Form sometimes becomes undisabled somewhere/somehow. Re-enforce the disabled state where necessary.
5833
+ this._enforceDisabledSub.subscription = this.form.statusChanges.pipe(throttleTime(50, undefined, { leading: true, trailing: true })).subscribe((change) => {
5834
+ resyncDisabledState();
5822
5835
  });
5823
5836
  }
5824
5837
  ngOnDestroy() {
@@ -5831,6 +5844,7 @@ class DbxFormlyFormComponent extends AbstractSubscriptionDirective {
5831
5844
  this._forceUpdate.complete();
5832
5845
  this._disabled.complete();
5833
5846
  this._disabledSub.destroy();
5847
+ this._enforceDisabledSub.destroy();
5834
5848
  });
5835
5849
  }
5836
5850
  // MARK: Delegate