@dereekb/dbx-form 9.16.1 → 9.16.3

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,20 +1,34 @@
1
+ import { asObservable } from '@dereekb/rxjs';
2
+ import { map } from 'rxjs';
1
3
  import { formlyField, propsAndConfigForFieldConfig } from '../field';
2
4
  export function valueSelectionField(config) {
3
- const { key, native = false, selectAllOption: inputSelectAllOption } = config;
5
+ const { key, native = false, addClearOption = false, selectAllOption: inputSelectAllOption, options: inputOptions } = config;
4
6
  let selectAllOptionConfig;
5
7
  if (inputSelectAllOption) {
6
8
  selectAllOptionConfig = {
7
9
  selectAllOption: typeof inputSelectAllOption === 'boolean' ? 'Select All' : inputSelectAllOption
8
10
  };
9
11
  }
12
+ const options = addClearOption ? asObservable(inputOptions).pipe(map(addValueSelectionOptionFunction(typeof addClearOption === 'string' ? addClearOption : undefined))) : inputOptions;
10
13
  return formlyField({
11
14
  key,
12
15
  type: native ? 'native-select' : 'select',
13
16
  ...propsAndConfigForFieldConfig(config, {
14
- options: config.options,
17
+ options,
15
18
  multiple: config.multiple ?? false,
16
19
  ...selectAllOptionConfig
17
20
  })
18
21
  });
19
22
  }
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZmllbGQvc2VsZWN0aW9uL3NlbGVjdGlvbi5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQTBCLFdBQVcsRUFBc0IsNEJBQTRCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFvQmpILE1BQU0sVUFBVSxtQkFBbUIsQ0FBSSxNQUFvQztJQUN6RSxNQUFNLEVBQUUsR0FBRyxFQUFFLE1BQU0sR0FBRyxLQUFLLEVBQUUsZUFBZSxFQUFFLG9CQUFvQixFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQzlFLElBQUkscUJBQXlELENBQUM7SUFFOUQsSUFBSSxvQkFBb0IsRUFBRTtRQUN4QixxQkFBcUIsR0FBRztZQUN0QixlQUFlLEVBQUUsT0FBTyxvQkFBb0IsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUUsb0JBQStCO1NBQzdHLENBQUM7S0FDSDtJQUVELE9BQU8sV0FBVyxDQUFDO1FBQ2pCLEdBQUc7UUFDSCxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLFFBQVE7UUFDekMsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7WUFDdEMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPO1lBQ3ZCLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUSxJQUFJLEtBQUs7WUFDbEMsR0FBRyxxQkFBcUI7U0FDekIsQ0FBQztLQUNILENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlT3JWYWx1ZSB9IGZyb20gJ0BkZXJlZWtiL3J4anMnO1xuaW1wb3J0IHsgTWF5YmUgfSBmcm9tICdAZGVyZWVrYi91dGlsJztcbmltcG9ydCB7IEZvcm1seUZpZWxkQ29uZmlnIH0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQgeyBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnLCBmb3JtbHlGaWVsZCwgTGFiZWxlZEZpZWxkQ29uZmlnLCBwcm9wc0FuZENvbmZpZ0ZvckZpZWxkQ29uZmlnIH0gZnJvbSAnLi4vZmllbGQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFZhbHVlU2VsZWN0aW9uT3B0aW9uPFQ+IHtcbiAgdmFsdWU6IFQ7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbkZpZWxkQ29uZmlnPFQ+IGV4dGVuZHMgTGFiZWxlZEZpZWxkQ29uZmlnLCBEZXNjcmlwdGlvbkZpZWxkQ29uZmlnIHtcbiAgLyoqXG4gICAqIFdoZXRoZXIgb3Igbm90IHRvIHVzZSB0aGUgbmF0aXZlIHNlbGVjdC5cbiAgICpcbiAgICogQmUgc3VyZSB0byBpbXBvcnQgRm9ybWx5TWF0TmF0aXZlU2VsZWN0TW9kdWxlLlxuICAgKi9cbiAgbmF0aXZlPzogYm9vbGVhbjtcbiAgb3B0aW9uczogT2JzZXJ2YWJsZU9yVmFsdWU8VmFsdWVTZWxlY3Rpb25PcHRpb248VD5bXT47XG4gIG11bHRpcGxlPzogYm9vbGVhbjtcbiAgc2VsZWN0QWxsT3B0aW9uPzogdHJ1ZSB8IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHZhbHVlU2VsZWN0aW9uRmllbGQ8VD4oY29uZmlnOiBWYWx1ZVNlbGVjdGlvbkZpZWxkQ29uZmlnPFQ+KTogRm9ybWx5RmllbGRDb25maWcge1xuICBjb25zdCB7IGtleSwgbmF0aXZlID0gZmFsc2UsIHNlbGVjdEFsbE9wdGlvbjogaW5wdXRTZWxlY3RBbGxPcHRpb24gfSA9IGNvbmZpZztcbiAgbGV0IHNlbGVjdEFsbE9wdGlvbkNvbmZpZzogTWF5YmU8eyBzZWxlY3RBbGxPcHRpb246IHN0cmluZyB9PjtcblxuICBpZiAoaW5wdXRTZWxlY3RBbGxPcHRpb24pIHtcbiAgICBzZWxlY3RBbGxPcHRpb25Db25maWcgPSB7XG4gICAgICBzZWxlY3RBbGxPcHRpb246IHR5cGVvZiBpbnB1dFNlbGVjdEFsbE9wdGlvbiA9PT0gJ2Jvb2xlYW4nID8gJ1NlbGVjdCBBbGwnIDogKGlucHV0U2VsZWN0QWxsT3B0aW9uIGFzIHN0cmluZylcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIGZvcm1seUZpZWxkKHtcbiAgICBrZXksXG4gICAgdHlwZTogbmF0aXZlID8gJ25hdGl2ZS1zZWxlY3QnIDogJ3NlbGVjdCcsXG4gICAgLi4ucHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyhjb25maWcsIHtcbiAgICAgIG9wdGlvbnM6IGNvbmZpZy5vcHRpb25zLFxuICAgICAgbXVsdGlwbGU6IGNvbmZpZy5tdWx0aXBsZSA/PyBmYWxzZSxcbiAgICAgIC4uLnNlbGVjdEFsbE9wdGlvbkNvbmZpZ1xuICAgIH0pXG4gIH0pO1xufVxuIl19
23
+ export function addValueSelectionOptionFunction(label) {
24
+ return (options) => {
25
+ const hasClear = options.findIndex((x) => x.clear) !== -1;
26
+ if (hasClear) {
27
+ return options;
28
+ }
29
+ else {
30
+ return [{ label, clear: true }, ...options];
31
+ }
32
+ };
33
+ }
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZmllbGQvc2VsZWN0aW9uL3NlbGVjdGlvbi5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUdoRSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNCLE9BQU8sRUFBMEIsV0FBVyxFQUFzQiw0QkFBNEIsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQStCakgsTUFBTSxVQUFVLG1CQUFtQixDQUFJLE1BQW9DO0lBQ3pFLE1BQU0sRUFBRSxHQUFHLEVBQUUsTUFBTSxHQUFHLEtBQUssRUFBRSxjQUFjLEdBQUcsS0FBSyxFQUFFLGVBQWUsRUFBRSxvQkFBb0IsRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBQzdILElBQUkscUJBQXlELENBQUM7SUFFOUQsSUFBSSxvQkFBb0IsRUFBRTtRQUN4QixxQkFBcUIsR0FBRztZQUN0QixlQUFlLEVBQUUsT0FBTyxvQkFBb0IsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUUsb0JBQStCO1NBQzdHLENBQUM7S0FDSDtJQUVELE1BQU0sT0FBTyxHQUFHLGNBQWMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsK0JBQStCLENBQUMsT0FBTyxjQUFjLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDO0lBRXZMLE9BQU8sV0FBVyxDQUFDO1FBQ2pCLEdBQUc7UUFDSCxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLFFBQVE7UUFDekMsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7WUFDdEMsT0FBTztZQUNQLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUSxJQUFJLEtBQUs7WUFDbEMsR0FBRyxxQkFBcUI7U0FDekIsQ0FBQztLQUNILENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsK0JBQStCLENBQUksS0FBMEI7SUFDM0UsT0FBTyxDQUFDLE9BQWtDLEVBQUUsRUFBRTtRQUM1QyxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBRSxDQUErQixDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBRXpGLElBQUksUUFBUSxFQUFFO1lBQ1osT0FBTyxPQUFPLENBQUM7U0FDaEI7YUFBTTtZQUNMLE9BQU8sQ0FBQyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLEVBQUUsR0FBRyxPQUFPLENBQUMsQ0FBQztTQUM3QztJQUNILENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhc09ic2VydmFibGUsIE9ic2VydmFibGVPclZhbHVlIH0gZnJvbSAnQGRlcmVla2Ivcnhqcyc7XG5pbXBvcnQgeyBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRGVzY3JpcHRpb25GaWVsZENvbmZpZywgZm9ybWx5RmllbGQsIExhYmVsZWRGaWVsZENvbmZpZywgcHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyB9IGZyb20gJy4uL2ZpZWxkJztcblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZVNlbGVjdGlvbk9wdGlvbldpdGhWYWx1ZTxUPiB7XG4gIHZhbHVlOiBUO1xuICBsYWJlbDogc3RyaW5nO1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmFsdWVTZWxlY3Rpb25PcHRpb25DbGVhciB7XG4gIGxhYmVsPzogc3RyaW5nO1xuICBjbGVhcjogdHJ1ZTtcbn1cblxuZXhwb3J0IHR5cGUgVmFsdWVTZWxlY3Rpb25PcHRpb248VD4gPSBWYWx1ZVNlbGVjdGlvbk9wdGlvbldpdGhWYWx1ZTxUPiB8IFZhbHVlU2VsZWN0aW9uT3B0aW9uQ2xlYXI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmFsdWVTZWxlY3Rpb25GaWVsZENvbmZpZzxUPiBleHRlbmRzIExhYmVsZWRGaWVsZENvbmZpZywgRGVzY3JpcHRpb25GaWVsZENvbmZpZyB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0byB1c2UgdGhlIG5hdGl2ZSBzZWxlY3QuXG4gICAqXG4gICAqIEJlIHN1cmUgdG8gaW1wb3J0IEZvcm1seU1hdE5hdGl2ZVNlbGVjdE1vZHVsZS5cbiAgICovXG4gIG5hdGl2ZT86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBXaGV0aGVyIG9yIG5vdCB0byBhZGQgYSBjbGVhciBvcHRpb24gdG8gdGhlIGlucHV0IHZhbHVlcy4gSWYgdXNpbmcgYW4gb2JzZXJ2YWJsZSwgdGhpc1xuICAgKi9cbiAgYWRkQ2xlYXJPcHRpb24/OiBzdHJpbmcgfCBib29sZWFuO1xuICBvcHRpb25zOiBPYnNlcnZhYmxlT3JWYWx1ZTxWYWx1ZVNlbGVjdGlvbk9wdGlvbjxUPltdPjtcbiAgbXVsdGlwbGU/OiBib29sZWFuO1xuICBzZWxlY3RBbGxPcHRpb24/OiB0cnVlIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdmFsdWVTZWxlY3Rpb25GaWVsZDxUPihjb25maWc6IFZhbHVlU2VsZWN0aW9uRmllbGRDb25maWc8VD4pOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIGNvbnN0IHsga2V5LCBuYXRpdmUgPSBmYWxzZSwgYWRkQ2xlYXJPcHRpb24gPSBmYWxzZSwgc2VsZWN0QWxsT3B0aW9uOiBpbnB1dFNlbGVjdEFsbE9wdGlvbiwgb3B0aW9uczogaW5wdXRPcHRpb25zIH0gPSBjb25maWc7XG4gIGxldCBzZWxlY3RBbGxPcHRpb25Db25maWc6IE1heWJlPHsgc2VsZWN0QWxsT3B0aW9uOiBzdHJpbmcgfT47XG5cbiAgaWYgKGlucHV0U2VsZWN0QWxsT3B0aW9uKSB7XG4gICAgc2VsZWN0QWxsT3B0aW9uQ29uZmlnID0ge1xuICAgICAgc2VsZWN0QWxsT3B0aW9uOiB0eXBlb2YgaW5wdXRTZWxlY3RBbGxPcHRpb24gPT09ICdib29sZWFuJyA/ICdTZWxlY3QgQWxsJyA6IChpbnB1dFNlbGVjdEFsbE9wdGlvbiBhcyBzdHJpbmcpXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IG9wdGlvbnMgPSBhZGRDbGVhck9wdGlvbiA/IGFzT2JzZXJ2YWJsZShpbnB1dE9wdGlvbnMpLnBpcGUobWFwKGFkZFZhbHVlU2VsZWN0aW9uT3B0aW9uRnVuY3Rpb24odHlwZW9mIGFkZENsZWFyT3B0aW9uID09PSAnc3RyaW5nJyA/IGFkZENsZWFyT3B0aW9uIDogdW5kZWZpbmVkKSkpIDogaW5wdXRPcHRpb25zO1xuXG4gIHJldHVybiBmb3JtbHlGaWVsZCh7XG4gICAga2V5LFxuICAgIHR5cGU6IG5hdGl2ZSA/ICduYXRpdmUtc2VsZWN0JyA6ICdzZWxlY3QnLFxuICAgIC4uLnByb3BzQW5kQ29uZmlnRm9yRmllbGRDb25maWcoY29uZmlnLCB7XG4gICAgICBvcHRpb25zLFxuICAgICAgbXVsdGlwbGU6IGNvbmZpZy5tdWx0aXBsZSA/PyBmYWxzZSxcbiAgICAgIC4uLnNlbGVjdEFsbE9wdGlvbkNvbmZpZ1xuICAgIH0pXG4gIH0pO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYWRkVmFsdWVTZWxlY3Rpb25PcHRpb25GdW5jdGlvbjxUPihsYWJlbD86IHN0cmluZyB8IHVuZGVmaW5lZCk6IChvcHRpb25zOiBWYWx1ZVNlbGVjdGlvbk9wdGlvbjxUPltdKSA9PiBWYWx1ZVNlbGVjdGlvbk9wdGlvbjxUPltdIHtcbiAgcmV0dXJuIChvcHRpb25zOiBWYWx1ZVNlbGVjdGlvbk9wdGlvbjxUPltdKSA9PiB7XG4gICAgY29uc3QgaGFzQ2xlYXIgPSBvcHRpb25zLmZpbmRJbmRleCgoeCkgPT4gKHggYXMgVmFsdWVTZWxlY3Rpb25PcHRpb25DbGVhcikuY2xlYXIpICE9PSAtMTtcblxuICAgIGlmIChoYXNDbGVhcikge1xuICAgICAgcmV0dXJuIG9wdGlvbnM7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBbeyBsYWJlbCwgY2xlYXI6IHRydWUgfSwgLi4ub3B0aW9uc107XG4gICAgfVxuICB9O1xufVxuIl19
@@ -1,5 +1,5 @@
1
1
  import { Component } from '@angular/core';
2
- import { getValueFromGetter } from '@dereekb/util';
2
+ import { asDecisionFunction, cachedGetter, getValueFromGetter, makeGetter } from '@dereekb/util';
3
3
  import { FieldArrayType } from '@ngx-formly/core';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
@@ -9,12 +9,30 @@ import * as i4 from "@angular/cdk/drag-drop";
9
9
  import * as i5 from "@dereekb/dbx-web";
10
10
  import * as i6 from "@ngx-formly/core";
11
11
  export class DbxFormRepeatArrayTypeComponent extends FieldArrayType {
12
+ constructor() {
13
+ super(...arguments);
14
+ this._labelForField = cachedGetter(() => {
15
+ const input = this.repeatArrayField.labelForField;
16
+ if (typeof input === 'function') {
17
+ return input;
18
+ }
19
+ else {
20
+ return makeGetter(input ?? '');
21
+ }
22
+ });
23
+ this._allowRemove = cachedGetter(() => {
24
+ return asDecisionFunction(this.field.props.allowRemove, true);
25
+ });
26
+ }
12
27
  get repeatArrayField() {
13
28
  return this.field.props;
14
29
  }
15
30
  get label() {
16
31
  return this.field.props.label ?? this.field.key;
17
32
  }
33
+ get description() {
34
+ return this.field.props.description;
35
+ }
18
36
  get addText() {
19
37
  return this.repeatArrayField.addText ?? 'Add';
20
38
  }
@@ -27,7 +45,24 @@ export class DbxFormRepeatArrayTypeComponent extends FieldArrayType {
27
45
  get count() {
28
46
  return this.field.fieldGroup?.length ?? 0;
29
47
  }
30
- get canAdd() {
48
+ get disableRearrange() {
49
+ return Boolean(this.field.props.disableRearrange);
50
+ }
51
+ get allowAdd() {
52
+ return this.field.props.allowAdd ?? true;
53
+ }
54
+ allowRemove(i) {
55
+ const array = this.model;
56
+ const value = array[i];
57
+ return this._allowRemove()({
58
+ i,
59
+ value
60
+ });
61
+ }
62
+ get addItemDisabled() {
63
+ return !this.canAddItem;
64
+ }
65
+ get canAddItem() {
31
66
  const max = this.max;
32
67
  if (max == null) {
33
68
  return true;
@@ -63,68 +98,74 @@ export class DbxFormRepeatArrayTypeComponent extends FieldArrayType {
63
98
  drop(event) {
64
99
  this.swapIndexes(event.previousIndex, event.currentIndex);
65
100
  }
66
- labelForItem(field) {
67
- return getValueFromGetter(this.repeatArrayField.labelForField ?? '', field);
101
+ labelForItem(fieldConfig, i) {
102
+ const array = this.model;
103
+ const value = array[i];
104
+ return getValueFromGetter(this._labelForField(), {
105
+ i,
106
+ value,
107
+ fieldConfig
108
+ });
68
109
  }
69
110
  }
70
111
  DbxFormRepeatArrayTypeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormRepeatArrayTypeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
71
112
  DbxFormRepeatArrayTypeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DbxFormRepeatArrayTypeComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: `
72
113
  <div class="dbx-form-repeat-array">
73
- <dbx-subsection [header]="label">
114
+ <dbx-subsection [header]="label" [hint]="description">
74
115
  <!-- Fields -->
75
- <div class="dbx-form-repeat-array-fields" cdkDropList (cdkDropListDropped)="drop($event)">
116
+ <div class="dbx-form-repeat-array-fields" cdkDropList [cdkDropListDisabled]="disableRearrange" (cdkDropListDropped)="drop($event)">
76
117
  <div class="dbx-form-repeat-array-field" cdkDrag cdkDragLockAxis="y" *ngFor="let field of field.fieldGroup; let i = index; let last = last">
77
- <div class="example-custom-placeholder" *cdkDragPlaceholder></div>
78
- <dbx-bar>
79
- <button cdkDragHandle mat-flat-button><mat-icon>drag_handle</mat-icon></button>
118
+ <div class="dbx-form-repeat-array-drag-placeholder" *cdkDragPlaceholder></div>
119
+ <dbx-bar class="dbx-bar-fixed-height">
120
+ <button *ngIf="!disableRearrange" cdkDragHandle mat-flat-button><mat-icon>drag_handle</mat-icon></button>
80
121
  <dbx-button-spacer></dbx-button-spacer>
81
122
  <h4>
82
123
  <span class="repeat-array-number">{{ i + 1 }}</span>
83
- <span>{{ labelForItem(field) }}</span>
124
+ <span>{{ labelForItem(field, i) }}</span>
84
125
  </h4>
85
126
  <span class="dbx-spacer"></span>
86
- <button mat-flat-button color="warn" (click)="remove(i)">{{ removeText }}</button>
127
+ <dbx-button *ngIf="allowRemove(i)" color="warn" [text]="removeText" (buttonClick)="remove(i)"></dbx-button>
87
128
  </dbx-bar>
88
129
  <formly-field class="dbx-form-repeat-array-field-content" [field]="field"></formly-field>
89
130
  </div>
90
131
  </div>
91
132
  <!-- Add Button -->
92
133
  <div class="dbx-form-repeat-array-footer">
93
- <button *ngIf="canAdd" mat-raised-button (click)="add()">{{ addText }}</button>
134
+ <dbx-button *ngIf="allowAdd" [raised]="true" [disabled]="addItemDisabled" [text]="addText" (buttonClick)="add()"></dbx-button>
94
135
  </div>
95
136
  </dbx-subsection>
96
137
  </div>
97
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i4.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: i4.CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }, { kind: "component", type: i5.DbxSubSectionComponent, selector: "dbx-subsection" }, { kind: "directive", type: i5.DbxBarDirective, selector: "dbx-bar,[dbxBar]", inputs: ["color"] }, { kind: "directive", type: i5.DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "component", type: i6.FormlyField, selector: "formly-field", inputs: ["field"] }] });
138
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i4.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: i4.CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }, { kind: "component", type: i5.DbxSubSectionComponent, selector: "dbx-subsection" }, { kind: "directive", type: i5.DbxBarDirective, selector: "dbx-bar,[dbxBar]", inputs: ["color"] }, { kind: "component", type: i5.DbxButtonComponent, selector: "dbx-button", inputs: ["type", "raised", "stroked", "flat", "color", "customButtonColor", "customTextColor", "customSpinnerColor"] }, { kind: "directive", type: i5.DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "component", type: i6.FormlyField, selector: "formly-field", inputs: ["field"] }] });
98
139
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormRepeatArrayTypeComponent, decorators: [{
99
140
  type: Component,
100
141
  args: [{
101
142
  template: `
102
143
  <div class="dbx-form-repeat-array">
103
- <dbx-subsection [header]="label">
144
+ <dbx-subsection [header]="label" [hint]="description">
104
145
  <!-- Fields -->
105
- <div class="dbx-form-repeat-array-fields" cdkDropList (cdkDropListDropped)="drop($event)">
146
+ <div class="dbx-form-repeat-array-fields" cdkDropList [cdkDropListDisabled]="disableRearrange" (cdkDropListDropped)="drop($event)">
106
147
  <div class="dbx-form-repeat-array-field" cdkDrag cdkDragLockAxis="y" *ngFor="let field of field.fieldGroup; let i = index; let last = last">
107
- <div class="example-custom-placeholder" *cdkDragPlaceholder></div>
108
- <dbx-bar>
109
- <button cdkDragHandle mat-flat-button><mat-icon>drag_handle</mat-icon></button>
148
+ <div class="dbx-form-repeat-array-drag-placeholder" *cdkDragPlaceholder></div>
149
+ <dbx-bar class="dbx-bar-fixed-height">
150
+ <button *ngIf="!disableRearrange" cdkDragHandle mat-flat-button><mat-icon>drag_handle</mat-icon></button>
110
151
  <dbx-button-spacer></dbx-button-spacer>
111
152
  <h4>
112
153
  <span class="repeat-array-number">{{ i + 1 }}</span>
113
- <span>{{ labelForItem(field) }}</span>
154
+ <span>{{ labelForItem(field, i) }}</span>
114
155
  </h4>
115
156
  <span class="dbx-spacer"></span>
116
- <button mat-flat-button color="warn" (click)="remove(i)">{{ removeText }}</button>
157
+ <dbx-button *ngIf="allowRemove(i)" color="warn" [text]="removeText" (buttonClick)="remove(i)"></dbx-button>
117
158
  </dbx-bar>
118
159
  <formly-field class="dbx-form-repeat-array-field-content" [field]="field"></formly-field>
119
160
  </div>
120
161
  </div>
121
162
  <!-- Add Button -->
122
163
  <div class="dbx-form-repeat-array-footer">
123
- <button *ngIf="canAdd" mat-raised-button (click)="add()">{{ addText }}</button>
164
+ <dbx-button *ngIf="allowAdd" [raised]="true" [disabled]="addItemDisabled" [text]="addText" (buttonClick)="add()"></dbx-button>
124
165
  </div>
125
166
  </dbx-subsection>
126
167
  </div>
127
168
  `
128
169
  }]
129
170
  }] });
130
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXkuZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZmllbGQvdmFsdWUvYXJyYXkvYXJyYXkuZmllbGQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFvQixrQkFBa0IsRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUM1RSxPQUFPLEVBQXdCLGNBQWMsRUFBdUMsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7Ozs7QUFxQzdHLE1BQU0sT0FBTywrQkFBZ0MsU0FBUSxjQUE4RDtJQUNqSCxJQUFJLGdCQUFnQjtRQUNsQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQWMsQ0FBQztJQUM5RCxDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxJQUFJLEtBQUssQ0FBQztJQUNoRCxDQUFDO0lBRUQsSUFBSSxVQUFVO1FBQ1osT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxJQUFJLFFBQVEsQ0FBQztJQUN0RCxDQUFDO0lBRUQsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLEVBQUUsTUFBTSxJQUFJLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQsSUFBSSxNQUFNO1FBQ1IsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQztRQUVyQixJQUFJLEdBQUcsSUFBSSxJQUFJLEVBQUU7WUFDZixPQUFPLElBQUksQ0FBQztTQUNiO2FBQU07WUFDTCxPQUFPLElBQUksQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxNQUFNLENBQUMsS0FBYTtRQUNsQixJQUFJLEtBQUssS0FBSyxDQUFDLEVBQUU7WUFDZixPQUFPO1NBQ1I7UUFFRCxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRSxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVELFFBQVEsQ0FBQyxLQUFhO1FBQ3BCLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsV0FBVyxDQUFDLFlBQW9CLEVBQUUsV0FBbUI7UUFDbkQsTUFBTSxLQUFLLEdBQWMsSUFBSSxDQUFDLEtBQUssQ0FBQztRQUNwQyxNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDLENBQUM7UUFFeEMsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNoQixPQUFPO1NBQ1I7UUFFRCxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQzFCLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxFQUFFLFdBQVcsRUFBRSxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQzFELElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDbkMsQ0FBQztJQUVELElBQUksQ0FBQyxLQUEyQjtRQUM5QixJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxhQUFhLEVBQUUsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxZQUFZLENBQUMsS0FBd0I7UUFDbkMsT0FBTyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxJQUFJLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUM5RSxDQUFDOzs0SEF2RVUsK0JBQStCO2dIQUEvQiwrQkFBK0IsMkVBNUJoQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EwQlQ7MkZBRVUsK0JBQStCO2tCQTdCM0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBMEJUO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2RrRHJhZ0Ryb3AgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcbmltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmFjdG9yeVdpdGhJbnB1dCwgZ2V0VmFsdWVGcm9tR2V0dGVyLCBNYXliZSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRmllbGRBcnJheVR5cGVDb25maWcsIEZpZWxkQXJyYXlUeXBlLCBGb3JtbHlGaWVsZENvbmZpZywgRm9ybWx5RmllbGRQcm9wcyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERieEZvcm1SZXBlYXRBcnJheUNvbmZpZyBleHRlbmRzIEZvcm1seUZpZWxkUHJvcHMge1xuICBsYWJlbEZvckZpZWxkPzogc3RyaW5nIHwgRmFjdG9yeVdpdGhJbnB1dDxzdHJpbmcsIEZvcm1seUZpZWxkQ29uZmlnPjtcbiAgYWRkVGV4dD86IHN0cmluZztcbiAgcmVtb3ZlVGV4dD86IHN0cmluZztcbn1cblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImRieC1mb3JtLXJlcGVhdC1hcnJheVwiPlxuICAgICAgPGRieC1zdWJzZWN0aW9uIFtoZWFkZXJdPVwibGFiZWxcIj5cbiAgICAgICAgPCEtLSBGaWVsZHMgLS0+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJkYngtZm9ybS1yZXBlYXQtYXJyYXktZmllbGRzXCIgY2RrRHJvcExpc3QgKGNka0Ryb3BMaXN0RHJvcHBlZCk9XCJkcm9wKCRldmVudClcIj5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwiZGJ4LWZvcm0tcmVwZWF0LWFycmF5LWZpZWxkXCIgY2RrRHJhZyBjZGtEcmFnTG9ja0F4aXM9XCJ5XCIgKm5nRm9yPVwibGV0IGZpZWxkIG9mIGZpZWxkLmZpZWxkR3JvdXA7IGxldCBpID0gaW5kZXg7IGxldCBsYXN0ID0gbGFzdFwiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImV4YW1wbGUtY3VzdG9tLXBsYWNlaG9sZGVyXCIgKmNka0RyYWdQbGFjZWhvbGRlcj48L2Rpdj5cbiAgICAgICAgICAgIDxkYngtYmFyPlxuICAgICAgICAgICAgICA8YnV0dG9uIGNka0RyYWdIYW5kbGUgbWF0LWZsYXQtYnV0dG9uPjxtYXQtaWNvbj5kcmFnX2hhbmRsZTwvbWF0LWljb24+PC9idXR0b24+XG4gICAgICAgICAgICAgIDxkYngtYnV0dG9uLXNwYWNlcj48L2RieC1idXR0b24tc3BhY2VyPlxuICAgICAgICAgICAgICA8aDQ+XG4gICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJyZXBlYXQtYXJyYXktbnVtYmVyXCI+e3sgaSArIDEgfX08L3NwYW4+XG4gICAgICAgICAgICAgICAgPHNwYW4+e3sgbGFiZWxGb3JJdGVtKGZpZWxkKSB9fTwvc3Bhbj5cbiAgICAgICAgICAgICAgPC9oND5cbiAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJkYngtc3BhY2VyXCI+PC9zcGFuPlxuICAgICAgICAgICAgICA8YnV0dG9uIG1hdC1mbGF0LWJ1dHRvbiBjb2xvcj1cIndhcm5cIiAoY2xpY2spPVwicmVtb3ZlKGkpXCI+e3sgcmVtb3ZlVGV4dCB9fTwvYnV0dG9uPlxuICAgICAgICAgICAgPC9kYngtYmFyPlxuICAgICAgICAgICAgPGZvcm1seS1maWVsZCBjbGFzcz1cImRieC1mb3JtLXJlcGVhdC1hcnJheS1maWVsZC1jb250ZW50XCIgW2ZpZWxkXT1cImZpZWxkXCI+PC9mb3JtbHktZmllbGQ+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8IS0tIEFkZCBCdXR0b24gLS0+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJkYngtZm9ybS1yZXBlYXQtYXJyYXktZm9vdGVyXCI+XG4gICAgICAgICAgPGJ1dHRvbiAqbmdJZj1cImNhbkFkZFwiIG1hdC1yYWlzZWQtYnV0dG9uIChjbGljayk9XCJhZGQoKVwiPnt7IGFkZFRleHQgfX08L2J1dHRvbj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2RieC1zdWJzZWN0aW9uPlxuICAgIDwvZGl2PlxuICBgXG59KVxuZXhwb3J0IGNsYXNzIERieEZvcm1SZXBlYXRBcnJheVR5cGVDb21wb25lbnQgZXh0ZW5kcyBGaWVsZEFycmF5VHlwZTxGaWVsZEFycmF5VHlwZUNvbmZpZzxEYnhGb3JtUmVwZWF0QXJyYXlDb25maWc+PiB7XG4gIGdldCByZXBlYXRBcnJheUZpZWxkKCk6IERieEZvcm1SZXBlYXRBcnJheUNvbmZpZyB7XG4gICAgcmV0dXJuIHRoaXMuZmllbGQucHJvcHM7XG4gIH1cblxuICBnZXQgbGFiZWwoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5maWVsZC5wcm9wcy5sYWJlbCA/PyAodGhpcy5maWVsZC5rZXkgYXMgc3RyaW5nKTtcbiAgfVxuXG4gIGdldCBhZGRUZXh0KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMucmVwZWF0QXJyYXlGaWVsZC5hZGRUZXh0ID8/ICdBZGQnO1xuICB9XG5cbiAgZ2V0IHJlbW92ZVRleHQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5yZXBlYXRBcnJheUZpZWxkLnJlbW92ZVRleHQgPz8gJ1JlbW92ZSc7XG4gIH1cblxuICBnZXQgbWF4KCk6IE1heWJlPG51bWJlcj4ge1xuICAgIHJldHVybiB0aGlzLmZpZWxkLnByb3BzLm1heExlbmd0aDtcbiAgfVxuXG4gIGdldCBjb3VudCgpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLmZpZWxkLmZpZWxkR3JvdXA/Lmxlbmd0aCA/PyAwO1xuICB9XG5cbiAgZ2V0IGNhbkFkZCgpOiBib29sZWFuIHtcbiAgICBjb25zdCBtYXggPSB0aGlzLm1heDtcblxuICAgIGlmIChtYXggPT0gbnVsbCkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiB0aGlzLmNvdW50IDwgbWF4O1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBNb3ZlcyB0aGUgdGFyZ2V0IGluZGV4IHVwIG9uZSB2YWx1ZS5cbiAgICpcbiAgICogQHBhcmFtIGluZGV4XG4gICAqL1xuICBtb3ZlVXAoaW5kZXg6IG51bWJlcikge1xuICAgIGlmIChpbmRleCA9PT0gMCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMuc3dhcEluZGV4ZXMoaW5kZXgsIGluZGV4IC0gMSk7XG4gIH1cblxuICBtb3ZlRG93bihpbmRleDogbnVtYmVyKSB7XG4gICAgdGhpcy5zd2FwSW5kZXhlcyhpbmRleCwgaW5kZXggKyAxKTtcbiAgfVxuXG4gIHN3YXBJbmRleGVzKGN1cnJlbnRJbmRleDogbnVtYmVyLCB0YXJnZXRJbmRleDogbnVtYmVyKSB7XG4gICAgY29uc3QgYXJyYXk6IHVua25vd25bXSA9IHRoaXMubW9kZWw7XG4gICAgY29uc3QgdGFyZ2V0VmFsdWUgPSBhcnJheVtjdXJyZW50SW5kZXhdO1xuXG4gICAgaWYgKCF0YXJnZXRWYWx1ZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMucmVtb3ZlKGN1cnJlbnRJbmRleCk7XG4gICAgdGhpcy5hZGQodGFyZ2V0SW5kZXgsIHRhcmdldFZhbHVlLCB7IG1hcmtBc0RpcnR5OiB0cnVlIH0pO1xuICAgIHRoaXMuZm9ybUNvbnRyb2wubWFya0FzVG91Y2hlZCgpO1xuICB9XG5cbiAgZHJvcChldmVudDogQ2RrRHJhZ0Ryb3A8dW5rbm93bj4pIHtcbiAgICB0aGlzLnN3YXBJbmRleGVzKGV2ZW50LnByZXZpb3VzSW5kZXgsIGV2ZW50LmN1cnJlbnRJbmRleCk7XG4gIH1cblxuICBsYWJlbEZvckl0ZW0oZmllbGQ6IEZvcm1seUZpZWxkQ29uZmlnKTogc3RyaW5nIHtcbiAgICByZXR1cm4gZ2V0VmFsdWVGcm9tR2V0dGVyKHRoaXMucmVwZWF0QXJyYXlGaWVsZC5sYWJlbEZvckZpZWxkID8/ICcnLCBmaWVsZCk7XG4gIH1cbn1cbiJdfQ==
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"array.field.component.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/array/array.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop } from '@angular/cdk/drag-drop';\nimport { Component, OnInit } from '@angular/core';\nimport { asDecisionFunction, asGetter, cachedGetter, DecisionFunction, FactoryWithInput, FactoryWithRequiredInput, Getter, getValueFromGetter, IndexRef, makeGetter, Maybe } from '@dereekb/util';\nimport { FieldArrayTypeConfig, FieldArrayType, FormlyFieldConfig, FormlyFieldProps } from '@ngx-formly/core';\n\nexport interface DbxFormRepeatArrayPair<T = unknown> extends IndexRef {\n  value: T;\n}\n\nexport interface DbxFormRepeatArrayFieldConfigPair<T = unknown> extends DbxFormRepeatArrayPair<T> {\n  fieldConfig: FormlyFieldConfig;\n}\n\nexport interface DbxFormRepeatArrayConfig<T = unknown> extends Pick<FormlyFieldProps, 'maxLength' | 'label' | 'description'> {\n  labelForField?: string | FactoryWithRequiredInput<string, DbxFormRepeatArrayFieldConfigPair<T>>;\n  /**\n   * Text for the add button.\n   */\n  addText?: string;\n  /**\n   * Text for the remove button.\n   */\n  removeText?: string;\n  /**\n   * Whethe or not to disable rearranging items.\n   *\n   * False by default.\n   */\n  disableRearrange?: boolean;\n  /**\n   * Wether or not to show the add button.\n   *\n   * True by default.\n   */\n  allowAdd?: boolean;\n  /**\n   * Whether or not to allow removing items. Can optionally pass a decision function that decides whether or not a specific item can be removed.\n   */\n  allowRemove?: boolean | DecisionFunction<DbxFormRepeatArrayPair<T>>;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-form-repeat-array\">\n      <dbx-subsection [header]=\"label\" [hint]=\"description\">\n        <!-- Fields -->\n        <div class=\"dbx-form-repeat-array-fields\" cdkDropList [cdkDropListDisabled]=\"disableRearrange\" (cdkDropListDropped)=\"drop($event)\">\n          <div class=\"dbx-form-repeat-array-field\" cdkDrag cdkDragLockAxis=\"y\" *ngFor=\"let field of field.fieldGroup; let i = index; let last = last\">\n            <div class=\"dbx-form-repeat-array-drag-placeholder\" *cdkDragPlaceholder></div>\n            <dbx-bar class=\"dbx-bar-fixed-height\">\n              <button *ngIf=\"!disableRearrange\" cdkDragHandle mat-flat-button><mat-icon>drag_handle</mat-icon></button>\n              <dbx-button-spacer></dbx-button-spacer>\n              <h4>\n                <span class=\"repeat-array-number\">{{ i + 1 }}</span>\n                <span>{{ labelForItem(field, i) }}</span>\n              </h4>\n              <span class=\"dbx-spacer\"></span>\n              <dbx-button *ngIf=\"allowRemove(i)\" color=\"warn\" [text]=\"removeText\" (buttonClick)=\"remove(i)\"></dbx-button>\n            </dbx-bar>\n            <formly-field class=\"dbx-form-repeat-array-field-content\" [field]=\"field\"></formly-field>\n          </div>\n        </div>\n        <!-- Add Button -->\n        <div class=\"dbx-form-repeat-array-footer\">\n          <dbx-button *ngIf=\"allowAdd\" [raised]=\"true\" [disabled]=\"addItemDisabled\" [text]=\"addText\" (buttonClick)=\"add()\"></dbx-button>\n        </div>\n      </dbx-subsection>\n    </div>\n  `\n})\nexport class DbxFormRepeatArrayTypeComponent<T = unknown> extends FieldArrayType<FieldArrayTypeConfig<DbxFormRepeatArrayConfig>> {\n  private _labelForField = cachedGetter(() => {\n    const input = this.repeatArrayField.labelForField;\n\n    if (typeof input === 'function') {\n      return input;\n    } else {\n      return makeGetter(input ?? '');\n    }\n  });\n\n  private _allowRemove: Getter<DecisionFunction<DbxFormRepeatArrayPair<T>>> = cachedGetter(() => {\n    return asDecisionFunction(this.field.props.allowRemove, true);\n  });\n\n  get repeatArrayField(): DbxFormRepeatArrayConfig {\n    return this.field.props;\n  }\n\n  get label(): string {\n    return this.field.props.label ?? (this.field.key as string);\n  }\n\n  get description(): Maybe<string> {\n    return this.field.props.description;\n  }\n\n  get addText(): string {\n    return this.repeatArrayField.addText ?? 'Add';\n  }\n\n  get removeText(): string {\n    return this.repeatArrayField.removeText ?? 'Remove';\n  }\n\n  get max(): Maybe<number> {\n    return this.field.props.maxLength;\n  }\n\n  get count(): number {\n    return this.field.fieldGroup?.length ?? 0;\n  }\n\n  get disableRearrange(): boolean {\n    return Boolean(this.field.props.disableRearrange);\n  }\n\n  get allowAdd(): boolean {\n    return this.field.props.allowAdd ?? true;\n  }\n\n  allowRemove(i: number) {\n    const array: unknown[] = this.model;\n    const value = array[i] as T;\n    return this._allowRemove()({\n      i,\n      value\n    });\n  }\n\n  get addItemDisabled() {\n    return !this.canAddItem;\n  }\n\n  get canAddItem(): boolean {\n    const max = this.max;\n\n    if (max == null) {\n      return true;\n    } else {\n      return this.count < max;\n    }\n  }\n\n  /**\n   * Moves the target index up one value.\n   *\n   * @param index\n   */\n  moveUp(index: number) {\n    if (index === 0) {\n      return;\n    }\n\n    this.swapIndexes(index, index - 1);\n  }\n\n  moveDown(index: number) {\n    this.swapIndexes(index, index + 1);\n  }\n\n  swapIndexes(currentIndex: number, targetIndex: number) {\n    const array: unknown[] = this.model;\n    const targetValue = array[currentIndex];\n\n    if (!targetValue) {\n      return;\n    }\n\n    this.remove(currentIndex);\n    this.add(targetIndex, targetValue, { markAsDirty: true });\n    this.formControl.markAsTouched();\n  }\n\n  drop(event: CdkDragDrop<unknown>) {\n    this.swapIndexes(event.previousIndex, event.currentIndex);\n  }\n\n  labelForItem(fieldConfig: FormlyFieldConfig, i: number): string {\n    const array: unknown[] = this.model;\n    const value = array[i] as T;\n\n    return getValueFromGetter(this._labelForField(), {\n      i,\n      value,\n      fieldConfig\n    });\n  }\n}\n"]}
@@ -1,19 +1,24 @@
1
1
  import { asArray } from '@dereekb/util';
2
2
  import { formlyField, propsAndConfigForFieldConfig } from '../../field';
3
3
  export function repeatArrayField(config) {
4
- const { key, repeatFieldGroup, maxLength, addText, removeText, labelForField } = config;
4
+ const { key, label, description, repeatFieldGroup, maxLength, addText, removeText, labelForField, disableRearrange, allowAdd, allowRemove } = config;
5
5
  return formlyField({
6
6
  key,
7
7
  type: 'repeatarray',
8
8
  ...propsAndConfigForFieldConfig(config, {
9
+ label,
10
+ description,
9
11
  maxLength,
10
12
  labelForField,
11
13
  addText,
12
- removeText
14
+ removeText,
15
+ disableRearrange,
16
+ allowAdd,
17
+ allowRemove
13
18
  }),
14
19
  fieldArray: {
15
20
  fieldGroup: asArray(repeatFieldGroup)
16
21
  }
17
22
  });
18
23
  }
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXkuZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9zcmMvbGliL2Zvcm1seS9maWVsZC92YWx1ZS9hcnJheS9hcnJheS5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWdCLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV0RCxPQUFPLEVBQWUsV0FBVyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBU3JGLE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxNQUE4QjtJQUM3RCxNQUFNLEVBQUUsR0FBRyxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUV4RixPQUFPLFdBQVcsQ0FBQztRQUNqQixHQUFHO1FBQ0gsSUFBSSxFQUFFLGFBQWE7UUFDbkIsR0FBRyw0QkFBNEIsQ0FBQyxNQUFNLEVBQUU7WUFDdEMsU0FBUztZQUNULGFBQWE7WUFDYixPQUFPO1lBQ1AsVUFBVTtTQUNYLENBQUM7UUFDRixVQUFVLEVBQUU7WUFDVixVQUFVLEVBQUUsT0FBTyxDQUFDLGdCQUFnQixDQUFDO1NBQ3RDO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFycmF5T3JWYWx1ZSwgYXNBcnJheSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IEZpZWxkQ29uZmlnLCBmb3JtbHlGaWVsZCwgcHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyB9IGZyb20gJy4uLy4uL2ZpZWxkJztcbmltcG9ydCB7IERieEZvcm1SZXBlYXRBcnJheUNvbmZpZyB9IGZyb20gJy4vYXJyYXkuZmllbGQuY29tcG9uZW50JztcblxuZXhwb3J0IGludGVyZmFjZSBSZXBlYXRBcnJheUZpZWxkQ29uZmlnIGV4dGVuZHMgRGJ4Rm9ybVJlcGVhdEFycmF5Q29uZmlnLCBGaWVsZENvbmZpZyB7XG4gIGxhYmVsPzogc3RyaW5nO1xuICByZXBlYXRGaWVsZEdyb3VwOiBBcnJheU9yVmFsdWU8Rm9ybWx5RmllbGRDb25maWc+O1xuICBtYXhMZW5ndGg/OiBudW1iZXI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZXBlYXRBcnJheUZpZWxkKGNvbmZpZzogUmVwZWF0QXJyYXlGaWVsZENvbmZpZykge1xuICBjb25zdCB7IGtleSwgcmVwZWF0RmllbGRHcm91cCwgbWF4TGVuZ3RoLCBhZGRUZXh0LCByZW1vdmVUZXh0LCBsYWJlbEZvckZpZWxkIH0gPSBjb25maWc7XG5cbiAgcmV0dXJuIGZvcm1seUZpZWxkKHtcbiAgICBrZXksXG4gICAgdHlwZTogJ3JlcGVhdGFycmF5JyxcbiAgICAuLi5wcm9wc0FuZENvbmZpZ0ZvckZpZWxkQ29uZmlnKGNvbmZpZywge1xuICAgICAgbWF4TGVuZ3RoLFxuICAgICAgbGFiZWxGb3JGaWVsZCxcbiAgICAgIGFkZFRleHQsXG4gICAgICByZW1vdmVUZXh0XG4gICAgfSksXG4gICAgZmllbGRBcnJheToge1xuICAgICAgZmllbGRHcm91cDogYXNBcnJheShyZXBlYXRGaWVsZEdyb3VwKVxuICAgIH1cbiAgfSk7XG59XG4iXX0=
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyYXkuZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9kYngtZm9ybS9zcmMvbGliL2Zvcm1seS9maWVsZC92YWx1ZS9hcnJheS9hcnJheS5maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWdCLE9BQU8sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV0RCxPQUFPLEVBQWUsV0FBVyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBT3JGLE1BQU0sVUFBVSxnQkFBZ0IsQ0FBYyxNQUFpQztJQUM3RSxNQUFNLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFckosT0FBTyxXQUFXLENBQUM7UUFDakIsR0FBRztRQUNILElBQUksRUFBRSxhQUFhO1FBQ25CLEdBQUcsNEJBQTRCLENBQUMsTUFBTSxFQUFFO1lBQ3RDLEtBQUs7WUFDTCxXQUFXO1lBQ1gsU0FBUztZQUNULGFBQWE7WUFDYixPQUFPO1lBQ1AsVUFBVTtZQUNWLGdCQUFnQjtZQUNoQixRQUFRO1lBQ1IsV0FBVztTQUNaLENBQUM7UUFDRixVQUFVLEVBQUU7WUFDVixVQUFVLEVBQUUsT0FBTyxDQUFDLGdCQUFnQixDQUFDO1NBQ3RDO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFycmF5T3JWYWx1ZSwgYXNBcnJheSB9IGZyb20gJ0BkZXJlZWtiL3V0aWwnO1xuaW1wb3J0IHsgRm9ybWx5RmllbGRDb25maWcgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IEZpZWxkQ29uZmlnLCBmb3JtbHlGaWVsZCwgcHJvcHNBbmRDb25maWdGb3JGaWVsZENvbmZpZyB9IGZyb20gJy4uLy4uL2ZpZWxkJztcbmltcG9ydCB7IERieEZvcm1SZXBlYXRBcnJheUNvbmZpZyB9IGZyb20gJy4vYXJyYXkuZmllbGQuY29tcG9uZW50JztcblxuZXhwb3J0IGludGVyZmFjZSBSZXBlYXRBcnJheUZpZWxkQ29uZmlnPFQgPSB1bmtub3duPiBleHRlbmRzIERieEZvcm1SZXBlYXRBcnJheUNvbmZpZzxUPiwgRmllbGRDb25maWcge1xuICByZXBlYXRGaWVsZEdyb3VwOiBBcnJheU9yVmFsdWU8Rm9ybWx5RmllbGRDb25maWc+O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcmVwZWF0QXJyYXlGaWVsZDxUID0gdW5rbm93bj4oY29uZmlnOiBSZXBlYXRBcnJheUZpZWxkQ29uZmlnPFQ+KSB7XG4gIGNvbnN0IHsga2V5LCBsYWJlbCwgZGVzY3JpcHRpb24sIHJlcGVhdEZpZWxkR3JvdXAsIG1heExlbmd0aCwgYWRkVGV4dCwgcmVtb3ZlVGV4dCwgbGFiZWxGb3JGaWVsZCwgZGlzYWJsZVJlYXJyYW5nZSwgYWxsb3dBZGQsIGFsbG93UmVtb3ZlIH0gPSBjb25maWc7XG5cbiAgcmV0dXJuIGZvcm1seUZpZWxkKHtcbiAgICBrZXksXG4gICAgdHlwZTogJ3JlcGVhdGFycmF5JyxcbiAgICAuLi5wcm9wc0FuZENvbmZpZ0ZvckZpZWxkQ29uZmlnKGNvbmZpZywge1xuICAgICAgbGFiZWwsXG4gICAgICBkZXNjcmlwdGlvbixcbiAgICAgIG1heExlbmd0aCxcbiAgICAgIGxhYmVsRm9yRmllbGQsXG4gICAgICBhZGRUZXh0LFxuICAgICAgcmVtb3ZlVGV4dCxcbiAgICAgIGRpc2FibGVSZWFycmFuZ2UsXG4gICAgICBhbGxvd0FkZCxcbiAgICAgIGFsbG93UmVtb3ZlXG4gICAgfSksXG4gICAgZmllbGRBcnJheToge1xuICAgICAgZmllbGRHcm91cDogYXNBcnJheShyZXBlYXRGaWVsZEdyb3VwKVxuICAgIH1cbiAgfSk7XG59XG4iXX0=
@@ -6,8 +6,10 @@ import { ADDRESS_CITY_MAX_LENGTH, ADDRESS_STATE_CODE_MAX_LENGTH, ADDRESS_STATE_M
6
6
  export const PHONE_LABEL_MAX_LENGTH = 100;
7
7
  export const LABEL_STRING_MAX_LENGTH = 100;
8
8
  export const SEARCH_STRING_MAX_LENGTH = 100;
9
- export function nameField({ key = 'name', label = 'Name', placeholder = 'John Doe', required = false, minLength, maxLength, attributes } = {}) {
9
+ export function nameField(config = {}) {
10
+ const { key = 'name', label = 'Name', placeholder = 'John Doe', required = false, minLength, maxLength, attributes } = config;
10
11
  return textField({
12
+ ...config,
11
13
  key,
12
14
  label,
13
15
  placeholder,
@@ -47,7 +49,7 @@ export function cityField(config = {}) {
47
49
  });
48
50
  }
49
51
  export function stateField(config = {}) {
50
- const { asCode = false, pattern = asCode ? US_STATE_CODE_STRING_REGEX : undefined, key = 'state', placeholder = '', label = 'State', autocomplete = 'state', maxLength = asCode ? ADDRESS_STATE_CODE_MAX_LENGTH : ADDRESS_STATE_MAX_LENGTH, required = false } = config;
52
+ const { asCode = false, pattern = asCode ? US_STATE_CODE_STRING_REGEX : undefined, key = 'state', placeholder = '', label = 'State', autocomplete = 'state', maxLength = asCode ? ADDRESS_STATE_CODE_MAX_LENGTH : ADDRESS_STATE_MAX_LENGTH, transform, required = false } = config;
51
53
  return textField({
52
54
  ...config,
53
55
  key,
@@ -58,7 +60,8 @@ export function stateField(config = {}) {
58
60
  required,
59
61
  maxLength,
60
62
  transform: {
61
- toUppercase: true
63
+ ...transform,
64
+ toUppercase: asCode || transform?.toUppercase
62
65
  }
63
66
  });
64
67
  }
@@ -106,4 +109,4 @@ export function latLngTextField({ key = 'latLng' } = {}) {
106
109
  };
107
110
  return field;
108
111
  }
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.additional.field.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/text/text.additional.field.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormlyFieldConfig } from '@ngx-formly/core';\nimport { Validators, AbstractControl } from '@angular/forms';\nimport { TextFieldConfig, textField } from './text.field';\nimport { LabeledFieldConfig, DescriptionFieldConfig, validatorsForFieldConfig } from '../../field';\nimport { LAT_LNG_PATTERN, US_STATE_CODE_STRING_REGEX, ZIP_CODE_STRING_REGEX } from '@dereekb/util';\nimport { ADDRESS_CITY_MAX_LENGTH, ADDRESS_STATE_CODE_MAX_LENGTH, ADDRESS_STATE_MAX_LENGTH, ADDRESS_COUNTRY_MAX_LENGTH, ADDRESS_ZIP_MAX_LENGTH } from '@dereekb/model';\n\nexport const PHONE_LABEL_MAX_LENGTH = 100;\n\nexport const LABEL_STRING_MAX_LENGTH = 100;\nexport const SEARCH_STRING_MAX_LENGTH = 100;\n\nexport function nameField({ key = 'name', label = 'Name', placeholder = 'John Doe', required = false, minLength, maxLength, attributes }: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  return textField({\n    key,\n    label,\n    placeholder,\n    required,\n    minLength,\n    maxLength,\n    attributes\n  });\n}\n\nexport interface EmailFieldConfig extends Partial<LabeledFieldConfig>, DescriptionFieldConfig {\n  rows?: number;\n}\n\nexport function emailField(config: EmailFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'email', label = 'Email Address', placeholder = 'you@example.com' } = config;\n  const emailFieldConfig = textField({\n    ...config,\n    key,\n    label,\n    placeholder,\n    inputType: 'email'\n  });\n\n  emailFieldConfig.validators = {\n    email: {\n      expression: (c: AbstractControl) => !Validators.email(c),\n      message: () => `Not a valid email address.`\n    }\n  };\n\n  return emailFieldConfig;\n}\n\nexport type CityFieldConfig = Partial<TextFieldConfig>;\n\nexport function cityField(config: CityFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'city', placeholder = '', label = 'City', autocomplete = 'city', maxLength = ADDRESS_CITY_MAX_LENGTH, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    autocomplete,\n    required,\n    maxLength\n  });\n}\n\nexport interface StateFieldConfig extends Partial<TextFieldConfig> {\n  asCode?: boolean;\n}\n\nexport function stateField(config: StateFieldConfig = {}): FormlyFieldConfig {\n  const { asCode = false, pattern = asCode ? US_STATE_CODE_STRING_REGEX : undefined, key = 'state', placeholder = '', label = 'State', autocomplete = 'state', maxLength = asCode ? ADDRESS_STATE_CODE_MAX_LENGTH : ADDRESS_STATE_MAX_LENGTH, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    pattern,\n    autocomplete,\n    required,\n    maxLength,\n    transform: {\n      toUppercase: true\n    }\n  });\n}\n\nexport type CountryFieldConfig = Partial<TextFieldConfig>;\n\nexport function countryField(config: CountryFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'country', placeholder = '', label = 'Country', autocomplete = 'country', maxLength = ADDRESS_COUNTRY_MAX_LENGTH, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    autocomplete,\n    required,\n    maxLength\n  });\n}\n\nexport type ZipCodeFieldConfig = Partial<TextFieldConfig>;\n\nexport function zipCodeField(config: ZipCodeFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'zip', placeholder = '', label = 'Zip Code', autocomplete = 'postal-code', pattern = ZIP_CODE_STRING_REGEX, maxLength = ADDRESS_ZIP_MAX_LENGTH, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    pattern,\n    autocomplete,\n    required,\n    maxLength\n  });\n}\n\nexport const DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER = '12.345,-67.8910';\nexport const DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE = `Invalid/unknown coordinates`;\n\nexport function latLngTextField({ key = 'latLng' }: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  const field = {\n    ...textField({\n      key,\n      label: 'Coordinates',\n      placeholder: DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER,\n      pattern: LAT_LNG_PATTERN,\n      autocomplete: false\n    }),\n    ...validatorsForFieldConfig({\n      messages: {\n        pattern: DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE\n      }\n    })\n  };\n\n  return field;\n}\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.additional.field.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/text/text.additional.field.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormlyFieldConfig } from '@ngx-formly/core';\nimport { Validators, AbstractControl } from '@angular/forms';\nimport { TextFieldConfig, textField } from './text.field';\nimport { LabeledFieldConfig, DescriptionFieldConfig, validatorsForFieldConfig } from '../../field';\nimport { LAT_LNG_PATTERN, US_STATE_CODE_STRING_REGEX, ZIP_CODE_STRING_REGEX } from '@dereekb/util';\nimport { ADDRESS_CITY_MAX_LENGTH, ADDRESS_STATE_CODE_MAX_LENGTH, ADDRESS_STATE_MAX_LENGTH, ADDRESS_COUNTRY_MAX_LENGTH, ADDRESS_ZIP_MAX_LENGTH } from '@dereekb/model';\n\nexport const PHONE_LABEL_MAX_LENGTH = 100;\n\nexport const LABEL_STRING_MAX_LENGTH = 100;\nexport const SEARCH_STRING_MAX_LENGTH = 100;\n\nexport function nameField(config: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  const { key = 'name', label = 'Name', placeholder = 'John Doe', required = false, minLength, maxLength, attributes } = config;\n\n  return textField({\n    ...config,\n    key,\n    label,\n    placeholder,\n    required,\n    minLength,\n    maxLength,\n    attributes\n  });\n}\n\nexport interface EmailFieldConfig extends Partial<LabeledFieldConfig>, DescriptionFieldConfig {\n  rows?: number;\n}\n\nexport function emailField(config: EmailFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'email', label = 'Email Address', placeholder = 'you@example.com' } = config;\n  const emailFieldConfig = textField({\n    ...config,\n    key,\n    label,\n    placeholder,\n    inputType: 'email'\n  });\n\n  emailFieldConfig.validators = {\n    email: {\n      expression: (c: AbstractControl) => !Validators.email(c),\n      message: () => `Not a valid email address.`\n    }\n  };\n\n  return emailFieldConfig;\n}\n\nexport type CityFieldConfig = Partial<TextFieldConfig>;\n\nexport function cityField(config: CityFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'city', placeholder = '', label = 'City', autocomplete = 'city', maxLength = ADDRESS_CITY_MAX_LENGTH, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    autocomplete,\n    required,\n    maxLength\n  });\n}\n\nexport interface StateFieldConfig extends Partial<TextFieldConfig> {\n  asCode?: boolean;\n}\n\nexport function stateField(config: StateFieldConfig = {}): FormlyFieldConfig {\n  const { asCode = false, pattern = asCode ? US_STATE_CODE_STRING_REGEX : undefined, key = 'state', placeholder = '', label = 'State', autocomplete = 'state', maxLength = asCode ? ADDRESS_STATE_CODE_MAX_LENGTH : ADDRESS_STATE_MAX_LENGTH, transform, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    pattern,\n    autocomplete,\n    required,\n    maxLength,\n    transform: {\n      ...transform,\n      toUppercase: asCode || transform?.toUppercase\n    }\n  });\n}\n\nexport type CountryFieldConfig = Partial<TextFieldConfig>;\n\nexport function countryField(config: CountryFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'country', placeholder = '', label = 'Country', autocomplete = 'country', maxLength = ADDRESS_COUNTRY_MAX_LENGTH, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    autocomplete,\n    required,\n    maxLength\n  });\n}\n\nexport type ZipCodeFieldConfig = Partial<TextFieldConfig>;\n\nexport function zipCodeField(config: ZipCodeFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'zip', placeholder = '', label = 'Zip Code', autocomplete = 'postal-code', pattern = ZIP_CODE_STRING_REGEX, maxLength = ADDRESS_ZIP_MAX_LENGTH, required = false } = config;\n  return textField({\n    ...config,\n    key,\n    placeholder,\n    label,\n    pattern,\n    autocomplete,\n    required,\n    maxLength\n  });\n}\n\nexport const DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER = '12.345,-67.8910';\nexport const DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE = `Invalid/unknown coordinates`;\n\nexport function latLngTextField({ key = 'latLng' }: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  const field = {\n    ...textField({\n      key,\n      label: 'Coordinates',\n      placeholder: DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER,\n      pattern: LAT_LNG_PATTERN,\n      autocomplete: false\n    }),\n    ...validatorsForFieldConfig({\n      messages: {\n        pattern: DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE\n      }\n    })\n  };\n\n  return field;\n}\n"]}