@dereekb/dbx-form 9.14.2 → 9.15.1

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,12 +1,13 @@
1
1
  import { Validators } from '@angular/forms';
2
2
  import { textField } from './text.field';
3
3
  import { validatorsForFieldConfig } from '../../field';
4
- import { LAT_LNG_PATTERN } from '@dereekb/util';
4
+ import { LAT_LNG_PATTERN, US_STATE_CODE_STRING_REGEX as US_STATE_CODE_REGEX } from '@dereekb/util';
5
5
  export const PHONE_LABEL_MAX_LENGTH = 100;
6
6
  export const ADDRESS_COUNTRY_MAX_LENGTH = 80;
7
7
  export const ADDRESS_CITY_MAX_LENGTH = 80;
8
- export const ADDRESS_STATE_MAX_LENGTH = 80;
9
- export const ADDRESS_ZIP_MAX_LENGTH = 20;
8
+ export const ADDRESS_STATE_MAX_LENGTH = 30;
9
+ export const ADDRESS_STATE_CODE_MAX_LENGTH = 2;
10
+ export const ADDRESS_ZIP_MAX_LENGTH = 11;
10
11
  export const LABEL_STRING_MAX_LENGTH = 100;
11
12
  export const SEARCH_STRING_MAX_LENGTH = 100;
12
13
  export function nameField({ key = 'name', label = 'Name', placeholder = 'John Doe', required = false, minLength, maxLength, attributes } = {}) {
@@ -37,44 +38,53 @@ export function emailField(config = {}) {
37
38
  };
38
39
  return emailFieldConfig;
39
40
  }
40
- export function cityField({ key = 'city', required = false } = {}) {
41
+ export function cityField(config = {}) {
42
+ const { key = 'city', placeholder = '', label = 'City', autocomplete = 'city', maxLength = ADDRESS_CITY_MAX_LENGTH, required = false } = config;
41
43
  return textField({
44
+ ...config,
42
45
  key,
43
- label: 'City',
44
- placeholder: '',
46
+ placeholder,
47
+ label,
48
+ autocomplete,
45
49
  required,
46
- autocomplete: 'city',
47
- maxLength: ADDRESS_CITY_MAX_LENGTH
50
+ maxLength
48
51
  });
49
52
  }
50
- export function stateField({ key = 'state', required = false } = {}) {
53
+ export function stateField(config = {}) {
54
+ const { asCode = false, pattern = asCode ? US_STATE_CODE_REGEX : undefined, key = 'state', placeholder = '', label = 'State', autocomplete = 'state', maxLength = asCode ? ADDRESS_STATE_CODE_MAX_LENGTH : ADDRESS_STATE_MAX_LENGTH, required = false } = config;
51
55
  return textField({
56
+ ...config,
52
57
  key,
53
- label: 'State',
54
- placeholder: '',
58
+ placeholder,
59
+ label,
60
+ pattern,
61
+ autocomplete,
55
62
  required,
56
- autocomplete: 'state',
57
- maxLength: ADDRESS_STATE_MAX_LENGTH
63
+ maxLength
58
64
  });
59
65
  }
60
- export function countryField({ key = 'country', required = false } = {}) {
66
+ export function countryField(config = {}) {
67
+ const { key = 'country', placeholder = '', label = 'Country', autocomplete = 'country', maxLength = ADDRESS_COUNTRY_MAX_LENGTH, required = false } = config;
61
68
  return textField({
69
+ ...config,
62
70
  key,
63
- label: 'Country',
64
- placeholder: '',
71
+ placeholder,
72
+ label,
73
+ autocomplete,
65
74
  required,
66
- autocomplete: 'country',
67
- maxLength: ADDRESS_COUNTRY_MAX_LENGTH
75
+ maxLength
68
76
  });
69
77
  }
70
- export function zipCodeField({ key = 'zip', required = false } = {}) {
78
+ export function zipCodeField(config = {}) {
79
+ const { key = 'zip', placeholder = '', label = 'Zip Code', autocomplete = 'postal-code', maxLength = ADDRESS_ZIP_MAX_LENGTH, required = false } = config;
71
80
  return textField({
81
+ ...config,
72
82
  key,
73
- label: 'Zip Code',
74
- placeholder: '',
83
+ placeholder,
84
+ label,
85
+ autocomplete,
75
86
  required,
76
- autocomplete: 'postal-code',
77
- maxLength: ADDRESS_ZIP_MAX_LENGTH
87
+ maxLength
78
88
  });
79
89
  }
80
90
  export const DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER = '12.345,-67.8910';
@@ -96,4 +106,4 @@ export function latLngTextField({ key = 'latLng' } = {}) {
96
106
  };
97
107
  return field;
98
108
  }
99
- //# 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 } from '@dereekb/util';\n\nexport const PHONE_LABEL_MAX_LENGTH = 100;\n\nexport const ADDRESS_COUNTRY_MAX_LENGTH = 80;\nexport const ADDRESS_CITY_MAX_LENGTH = 80;\nexport const ADDRESS_STATE_MAX_LENGTH = 80;\nexport const ADDRESS_ZIP_MAX_LENGTH = 20;\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 function cityField({ key = 'city', required = false }: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  return textField({\n    key,\n    label: 'City',\n    placeholder: '',\n    required,\n    autocomplete: 'city',\n    maxLength: ADDRESS_CITY_MAX_LENGTH\n  });\n}\n\nexport function stateField({ key = 'state', required = false }: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  return textField({\n    key,\n    label: 'State',\n    placeholder: '',\n    required,\n    autocomplete: 'state',\n    maxLength: ADDRESS_STATE_MAX_LENGTH\n  });\n}\n\nexport function countryField({ key = 'country', required = false }: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  return textField({\n    key,\n    label: 'Country',\n    placeholder: '',\n    required,\n    autocomplete: 'country',\n    maxLength: ADDRESS_COUNTRY_MAX_LENGTH\n  });\n}\n\nexport function zipCodeField({ key = 'zip', required = false }: Partial<TextFieldConfig> = {}): FormlyFieldConfig {\n  return textField({\n    key,\n    label: 'Zip Code',\n    placeholder: '',\n    required,\n    autocomplete: 'postal-code',\n    maxLength: ADDRESS_ZIP_MAX_LENGTH\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"]}
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 as US_STATE_CODE_REGEX } from '@dereekb/util';\n\nexport const PHONE_LABEL_MAX_LENGTH = 100;\n\nexport const ADDRESS_COUNTRY_MAX_LENGTH = 80;\nexport const ADDRESS_CITY_MAX_LENGTH = 80;\nexport const ADDRESS_STATE_MAX_LENGTH = 30;\nexport const ADDRESS_STATE_CODE_MAX_LENGTH = 2;\nexport const ADDRESS_ZIP_MAX_LENGTH = 11;\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 interface CityFieldConfig extends 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_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  });\n}\n\nexport interface CountryFieldConfig extends 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 interface ZipCodeFieldConfig extends Partial<TextFieldConfig> {}\n\nexport function zipCodeField(config: ZipCodeFieldConfig = {}): FormlyFieldConfig {\n  const { key = 'zip', placeholder = '', label = 'Zip Code', autocomplete = 'postal-code', maxLength = ADDRESS_ZIP_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 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"]}
@@ -1,55 +1,64 @@
1
1
  import { textField } from './text.field';
2
2
  import { cityField, countryField, stateField, zipCodeField } from './text.additional.field';
3
- import { flexLayoutWrapper } from '../../wrapper/wrapper';
3
+ import { flexLayoutWrapper, sectionWrapper } from '../../wrapper/wrapper';
4
4
  import { repeatArrayField } from '../array/array.field';
5
5
  export const ADDRESS_LINE_MAX_LENGTH = 100;
6
- export function addressFormlyFields() {
7
- return [
8
- textField({
9
- key: 'line1',
10
- label: 'Line 1',
11
- placeholder: '',
12
- required: false,
13
- autocomplete: 'address-line1',
14
- maxLength: ADDRESS_LINE_MAX_LENGTH
15
- }),
16
- textField({
17
- key: 'line2',
18
- label: 'Line 2',
19
- placeholder: '',
20
- required: false,
21
- autocomplete: 'address-line2',
22
- maxLength: ADDRESS_LINE_MAX_LENGTH
23
- }),
24
- flexLayoutWrapper([
25
- {
26
- field: cityField({})
27
- },
28
- {
29
- field: stateField({})
30
- },
31
- {
32
- field: zipCodeField({})
33
- },
34
- {
35
- field: countryField({})
36
- }
37
- ], { size: 1, relative: true })
6
+ export function addressLineField(config = {}) {
7
+ const { line = 1 } = config;
8
+ const lineCode = Math.min(1, line);
9
+ const { key = `line${lineCode}`, placeholder = '', label = line ? `Line ${line}` : 'Street', autocomplete = `address-line${lineCode}`, maxLength = ADDRESS_LINE_MAX_LENGTH, required = false } = config;
10
+ return textField({
11
+ ...config,
12
+ key,
13
+ placeholder,
14
+ label,
15
+ autocomplete,
16
+ required,
17
+ maxLength
18
+ });
19
+ }
20
+ export function addressFormlyFields(config = {}) {
21
+ const { includeLine2 = true, includeCountry = true } = config;
22
+ const singleLineFields = [
23
+ {
24
+ field: cityField(config.cityField)
25
+ },
26
+ {
27
+ field: stateField(config.stateField)
28
+ },
29
+ {
30
+ field: zipCodeField(config.zipCodeField)
31
+ }
38
32
  ];
33
+ if (includeCountry) {
34
+ singleLineFields.push({
35
+ field: countryField(config.countryField)
36
+ });
37
+ }
38
+ let lines;
39
+ if (includeLine2) {
40
+ lines = [addressLineField({ ...config.line1Field, line: 1 }), addressLineField({ ...config.line2Field, line: 2 })];
41
+ }
42
+ else {
43
+ lines = [addressLineField({ ...config.line1Field, line: 0 })];
44
+ }
45
+ return [...lines, flexLayoutWrapper(singleLineFields, { size: 1, relative: true })];
39
46
  }
40
- export function addressField({ key = 'address', required = false } = {}) {
41
- return {
47
+ export function addressField(config = {}) {
48
+ const { key = 'address', header = 'Address', hint, required = false } = config;
49
+ return sectionWrapper({
50
+ ...config,
42
51
  key,
43
- wrappers: ['section'],
44
- props: {
45
- label: 'Address',
46
- placeholder: '',
47
- required
48
- },
49
- fieldGroup: addressFormlyFields()
50
- };
52
+ fieldGroup: addressFormlyFields(config),
53
+ required
54
+ }, {
55
+ ...config,
56
+ header,
57
+ hint
58
+ });
51
59
  }
52
- export function addressListField({ key = 'addresses', required = false, maxAddresses = 6 } = {}) {
60
+ export function addressListField(config = {}) {
61
+ const { key = 'addresses', required = false, maxAddresses = 6 } = config;
53
62
  return repeatArrayField({
54
63
  key,
55
64
  required,
@@ -58,7 +67,7 @@ export function addressListField({ key = 'addresses', required = false, maxAddre
58
67
  addText: 'Add Address',
59
68
  removeText: 'Remove Address',
60
69
  maxLength: maxAddresses,
61
- repeatFieldGroup: addressFormlyFields()
70
+ repeatFieldGroup: addressFormlyFields(config)
62
71
  });
63
72
  }
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5hZGRyZXNzLmZpZWxkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZGJ4LWZvcm0vc3JjL2xpYi9mb3JtbHkvZmllbGQvdmFsdWUvdGV4dC90ZXh0LmFkZHJlc3MuZmllbGQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUN6QyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDNUYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFMUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFeEQsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsR0FBRyxDQUFDO0FBRTNDLE1BQU0sVUFBVSxtQkFBbUI7SUFDakMsT0FBTztRQUNMLFNBQVMsQ0FBQztZQUNSLEdBQUcsRUFBRSxPQUFPO1lBQ1osS0FBSyxFQUFFLFFBQVE7WUFDZixXQUFXLEVBQUUsRUFBRTtZQUNmLFFBQVEsRUFBRSxLQUFLO1lBQ2YsWUFBWSxFQUFFLGVBQWU7WUFDN0IsU0FBUyxFQUFFLHVCQUF1QjtTQUNuQyxDQUFDO1FBQ0YsU0FBUyxDQUFDO1lBQ1IsR0FBRyxFQUFFLE9BQU87WUFDWixLQUFLLEVBQUUsUUFBUTtZQUNmLFdBQVcsRUFBRSxFQUFFO1lBQ2YsUUFBUSxFQUFFLEtBQUs7WUFDZixZQUFZLEVBQUUsZUFBZTtZQUM3QixTQUFTLEVBQUUsdUJBQXVCO1NBQ25DLENBQUM7UUFDRixpQkFBaUIsQ0FDZjtZQUNFO2dCQUNFLEtBQUssRUFBRSxTQUFTLENBQUMsRUFBRSxDQUFDO2FBQ3JCO1lBQ0Q7Z0JBQ0UsS0FBSyxFQUFFLFVBQVUsQ0FBQyxFQUFFLENBQUM7YUFDdEI7WUFDRDtnQkFDRSxLQUFLLEVBQUUsWUFBWSxDQUFDLEVBQUUsQ0FBQzthQUN4QjtZQUNEO2dCQUNFLEtBQUssRUFBRSxZQUFZLENBQUMsRUFBRSxDQUFDO2FBQ3hCO1NBQ0YsRUFDRCxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxDQUM1QjtLQUNGLENBQUM7QUFDSixDQUFDO0FBSUQsTUFBTSxVQUFVLFlBQVksQ0FBQyxFQUFFLEdBQUcsR0FBRyxTQUFTLEVBQUUsUUFBUSxHQUFHLEtBQUssS0FBa0MsRUFBRTtJQUNsRyxPQUFPO1FBQ0wsR0FBRztRQUNILFFBQVEsRUFBRSxDQUFDLFNBQVMsQ0FBQztRQUNyQixLQUFLLEVBQUU7WUFDTCxLQUFLLEVBQUUsU0FBUztZQUNoQixXQUFXLEVBQUUsRUFBRTtZQUNmLFFBQVE7U0FDVDtRQUNELFVBQVUsRUFBRSxtQkFBbUIsRUFBRTtLQUNsQyxDQUFDO0FBQ0osQ0FBQztBQU1ELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxFQUFFLEdBQUcsR0FBRyxXQUFXLEVBQUUsUUFBUSxHQUFHLEtBQUssRUFBRSxZQUFZLEdBQUcsQ0FBQyxLQUFzQyxFQUFFO0lBQzlILE9BQU8sZ0JBQWdCLENBQUM7UUFDdEIsR0FBRztRQUNILFFBQVE7UUFDUixLQUFLLEVBQUUsV0FBVztRQUNsQixhQUFhLEVBQUUsU0FBUztRQUN4QixPQUFPLEVBQUUsYUFBYTtRQUN0QixVQUFVLEVBQUUsZ0JBQWdCO1FBQzVCLFNBQVMsRUFBRSxZQUFZO1FBQ3ZCLGdCQUFnQixFQUFFLG1CQUFtQixFQUFFO0tBQ3hDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JtbHlGaWVsZENvbmZpZyB9IGZyb20gJ0BuZ3gtZm9ybWx5L2NvcmUnO1xuaW1wb3J0IHsgdGV4dEZpZWxkIH0gZnJvbSAnLi90ZXh0LmZpZWxkJztcbmltcG9ydCB7IGNpdHlGaWVsZCwgY291bnRyeUZpZWxkLCBzdGF0ZUZpZWxkLCB6aXBDb2RlRmllbGQgfSBmcm9tICcuL3RleHQuYWRkaXRpb25hbC5maWVsZCc7XG5pbXBvcnQgeyBmbGV4TGF5b3V0V3JhcHBlciB9IGZyb20gJy4uLy4uL3dyYXBwZXIvd3JhcHBlcic7XG5pbXBvcnQgeyBGaWVsZENvbmZpZyB9IGZyb20gJy4uLy4uL2ZpZWxkJztcbmltcG9ydCB7IHJlcGVhdEFycmF5RmllbGQgfSBmcm9tICcuLi9hcnJheS9hcnJheS5maWVsZCc7XG5cbmV4cG9ydCBjb25zdCBBRERSRVNTX0xJTkVfTUFYX0xFTkdUSCA9IDEwMDtcblxuZXhwb3J0IGZ1bmN0aW9uIGFkZHJlc3NGb3JtbHlGaWVsZHMoKTogRm9ybWx5RmllbGRDb25maWdbXSB7XG4gIHJldHVybiBbXG4gICAgdGV4dEZpZWxkKHtcbiAgICAgIGtleTogJ2xpbmUxJyxcbiAgICAgIGxhYmVsOiAnTGluZSAxJyxcbiAgICAgIHBsYWNlaG9sZGVyOiAnJyxcbiAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgIGF1dG9jb21wbGV0ZTogJ2FkZHJlc3MtbGluZTEnLFxuICAgICAgbWF4TGVuZ3RoOiBBRERSRVNTX0xJTkVfTUFYX0xFTkdUSFxuICAgIH0pLFxuICAgIHRleHRGaWVsZCh7XG4gICAgICBrZXk6ICdsaW5lMicsXG4gICAgICBsYWJlbDogJ0xpbmUgMicsXG4gICAgICBwbGFjZWhvbGRlcjogJycsXG4gICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICBhdXRvY29tcGxldGU6ICdhZGRyZXNzLWxpbmUyJyxcbiAgICAgIG1heExlbmd0aDogQUREUkVTU19MSU5FX01BWF9MRU5HVEhcbiAgICB9KSxcbiAgICBmbGV4TGF5b3V0V3JhcHBlcihcbiAgICAgIFtcbiAgICAgICAge1xuICAgICAgICAgIGZpZWxkOiBjaXR5RmllbGQoe30pXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICBmaWVsZDogc3RhdGVGaWVsZCh7fSlcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgIGZpZWxkOiB6aXBDb2RlRmllbGQoe30pXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICBmaWVsZDogY291bnRyeUZpZWxkKHt9KVxuICAgICAgICB9XG4gICAgICBdLFxuICAgICAgeyBzaXplOiAxLCByZWxhdGl2ZTogdHJ1ZSB9XG4gICAgKVxuICBdO1xufVxuXG5leHBvcnQgdHlwZSBBZGRyZXNzRmllbGRDb25maWcgPSBGaWVsZENvbmZpZztcblxuZXhwb3J0IGZ1bmN0aW9uIGFkZHJlc3NGaWVsZCh7IGtleSA9ICdhZGRyZXNzJywgcmVxdWlyZWQgPSBmYWxzZSB9OiBQYXJ0aWFsPEFkZHJlc3NGaWVsZENvbmZpZz4gPSB7fSk6IEZvcm1seUZpZWxkQ29uZmlnIHtcbiAgcmV0dXJuIHtcbiAgICBrZXksXG4gICAgd3JhcHBlcnM6IFsnc2VjdGlvbiddLFxuICAgIHByb3BzOiB7XG4gICAgICBsYWJlbDogJ0FkZHJlc3MnLFxuICAgICAgcGxhY2Vob2xkZXI6ICcnLFxuICAgICAgcmVxdWlyZWRcbiAgICB9LFxuICAgIGZpZWxkR3JvdXA6IGFkZHJlc3NGb3JtbHlGaWVsZHMoKVxuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkZHJlc3NMaXN0RmllbGRDb25maWcgZXh0ZW5kcyBGaWVsZENvbmZpZyB7XG4gIG1heEFkZHJlc3Nlcz86IG51bWJlcjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFkZHJlc3NMaXN0RmllbGQoeyBrZXkgPSAnYWRkcmVzc2VzJywgcmVxdWlyZWQgPSBmYWxzZSwgbWF4QWRkcmVzc2VzID0gNiB9OiBQYXJ0aWFsPEFkZHJlc3NMaXN0RmllbGRDb25maWc+ID0ge30pOiBGb3JtbHlGaWVsZENvbmZpZyB7XG4gIHJldHVybiByZXBlYXRBcnJheUZpZWxkKHtcbiAgICBrZXksXG4gICAgcmVxdWlyZWQsXG4gICAgbGFiZWw6ICdBZGRyZXNzZXMnLFxuICAgIGxhYmVsRm9yRmllbGQ6ICdBZGRyZXNzJyxcbiAgICBhZGRUZXh0OiAnQWRkIEFkZHJlc3MnLFxuICAgIHJlbW92ZVRleHQ6ICdSZW1vdmUgQWRkcmVzcycsXG4gICAgbWF4TGVuZ3RoOiBtYXhBZGRyZXNzZXMsXG4gICAgcmVwZWF0RmllbGRHcm91cDogYWRkcmVzc0Zvcm1seUZpZWxkcygpXG4gIH0pO1xufVxuIl19
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text.address.field.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/text/text.address.field.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormlyFieldConfig } from '@ngx-formly/core';\nimport { textField, TextFieldConfig } from './text.field';\nimport { cityField, CityFieldConfig, countryField, CountryFieldConfig, stateField, StateFieldConfig, zipCodeField, ZipCodeFieldConfig } from './text.additional.field';\nimport { flexLayoutWrapper, sectionWrapper } from '../../wrapper/wrapper';\nimport { FieldConfig } from '../../field';\nimport { repeatArrayField } from '../array/array.field';\nimport { DbxFormSectionConfig } from '../../wrapper/section.wrapper.component';\n\nexport const ADDRESS_LINE_MAX_LENGTH = 100;\n\nexport interface AddressFormlyFieldsConfig {\n  line1Field?: CityFieldConfig;\n  line2Field?: CityFieldConfig;\n  cityField?: CityFieldConfig;\n  stateField?: StateFieldConfig;\n  zipCodeField?: ZipCodeFieldConfig;\n  countryField?: CountryFieldConfig;\n  /**\n   * Whether or not to include the second address line.\n   *\n   * True by default.\n   */\n  includeLine2?: boolean;\n  /**\n   * Whether or not to include the country.\n   *\n   * True by default.\n   */\n  includeCountry?: boolean;\n}\n\nexport interface AddressLineFieldConfig extends Partial<TextFieldConfig> {\n  line?: 0 | 1 | 2;\n}\n\nexport function addressLineField(config: AddressLineFieldConfig = {}): FormlyFieldConfig {\n  const { line = 1 } = config;\n  const lineCode = Math.min(1, line);\n  const { key = `line${lineCode}`, placeholder = '', label = line ? `Line ${line}` : 'Street', autocomplete = `address-line${lineCode}`, maxLength = ADDRESS_LINE_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 function addressFormlyFields(config: AddressFormlyFieldsConfig = {}): FormlyFieldConfig[] {\n  const { includeLine2 = true, includeCountry = true } = config;\n\n  const singleLineFields = [\n    {\n      field: cityField(config.cityField)\n    },\n    {\n      field: stateField(config.stateField)\n    },\n    {\n      field: zipCodeField(config.zipCodeField)\n    }\n  ];\n\n  if (includeCountry) {\n    singleLineFields.push({\n      field: countryField(config.countryField)\n    });\n  }\n\n  let lines: FormlyFieldConfig[];\n\n  if (includeLine2) {\n    lines = [addressLineField({ ...config.line1Field, line: 1 }), addressLineField({ ...config.line2Field, line: 2 })];\n  } else {\n    lines = [addressLineField({ ...config.line1Field, line: 0 })];\n  }\n\n  return [...lines, flexLayoutWrapper(singleLineFields, { size: 1, relative: true })];\n}\n\nexport interface AddressFieldConfig extends FieldConfig, DbxFormSectionConfig, AddressFormlyFieldsConfig {}\n\nexport function addressField(config: Partial<AddressFieldConfig> = {}): FormlyFieldConfig {\n  const { key = 'address', header = 'Address', hint, required = false } = config;\n\n  return sectionWrapper(\n    {\n      ...config,\n      key,\n      fieldGroup: addressFormlyFields(config),\n      required\n    },\n    {\n      ...config,\n      header,\n      hint\n    }\n  );\n}\n\nexport interface AddressListFieldConfig extends FieldConfig, AddressFormlyFieldsConfig {\n  maxAddresses?: number;\n}\n\nexport function addressListField(config: Partial<AddressListFieldConfig> = {}): FormlyFieldConfig {\n  const { key = 'addresses', required = false, maxAddresses = 6 } = config;\n  return repeatArrayField({\n    key,\n    required,\n    label: 'Addresses',\n    labelForField: 'Address',\n    addText: 'Add Address',\n    removeText: 'Remove Address',\n    maxLength: maxAddresses,\n    repeatFieldGroup: addressFormlyFields(config)\n  });\n}\n"]}
@@ -15,7 +15,7 @@ DbxFormSectionWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
15
15
  <dbx-section [header]="header" [hint]="hint">
16
16
  <ng-container #fieldComponent></ng-container>
17
17
  </dbx-section>
18
- `, isInline: true, dependencies: [{ kind: "component", type: i1.DbxSectionComponent, selector: "dbx-section", inputs: ["elevated"] }] });
18
+ `, isInline: true, dependencies: [{ kind: "component", type: i1.DbxSectionComponent, selector: "dbx-section", inputs: ["elevate"] }] });
19
19
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormSectionWrapperComponent, decorators: [{
20
20
  type: Component,
21
21
  args: [{
@@ -26,7 +26,7 @@ import * as i1$2 from '@angular/material/button';
26
26
  import { MatButtonModule } from '@angular/material/button';
27
27
  import * as i3$3 from '@angular/flex-layout/flex';
28
28
  import { FlexLayoutModule } from '@angular/flex-layout';
29
- import { objectIsEmpty, mergeObjectsFunction, filterFromPOJOFunction, mergeObjects, filterFromPOJO, asArray, objectHasNoKeys, addPlusPrefixToNumber, convertMaybeToArray, makeValuesGroupMap, findUnique, searchStringFilterFunction, caseInsensitiveFilterByIndexOfDecisionFactory, mergeIntoArray, lastValue, separateValues, arrayToMap, getValueFromGetter, dateFromLogicalDate, WEBSITE_DOMAIN_NAME_REGEX, KeyValueTypleValueFilter, valuesFromPOJO, allObjectsAreEqual, isNumberDivisibleBy, nearestDivisibleValues, LAT_LNG_PATTERN, capitalizeFirstLetter, BooleanStringKeyArrayUtilityInstance } from '@dereekb/util';
29
+ import { objectIsEmpty, mergeObjectsFunction, filterFromPOJOFunction, mergeObjects, filterFromPOJO, asArray, objectHasNoKeys, addPlusPrefixToNumber, convertMaybeToArray, makeValuesGroupMap, findUnique, searchStringFilterFunction, caseInsensitiveFilterByIndexOfDecisionFactory, mergeIntoArray, lastValue, separateValues, arrayToMap, getValueFromGetter, dateFromLogicalDate, WEBSITE_DOMAIN_NAME_REGEX, KeyValueTypleValueFilter, valuesFromPOJO, allObjectsAreEqual, isNumberDivisibleBy, nearestDivisibleValues, US_STATE_CODE_STRING_REGEX, LAT_LNG_PATTERN, capitalizeFirstLetter, BooleanStringKeyArrayUtilityInstance } from '@dereekb/util';
30
30
  import * as i2$1 from '@angular/material/slide-toggle';
31
31
  import { MatSlideToggleModule } from '@angular/material/slide-toggle';
32
32
  import * as i2$2 from '@angular/flex-layout/extended';
@@ -668,7 +668,7 @@ DbxFormSectionWrapperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
668
668
  <dbx-section [header]="header" [hint]="hint">
669
669
  <ng-container #fieldComponent></ng-container>
670
670
  </dbx-section>
671
- `, isInline: true, dependencies: [{ kind: "component", type: i1$1.DbxSectionComponent, selector: "dbx-section", inputs: ["elevated"] }] });
671
+ `, isInline: true, dependencies: [{ kind: "component", type: i1$1.DbxSectionComponent, selector: "dbx-section", inputs: ["elevate"] }] });
672
672
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DbxFormSectionWrapperComponent, decorators: [{
673
673
  type: Component,
674
674
  args: [{
@@ -3407,8 +3407,9 @@ function phoneListField(repeatConfig = {}) {
3407
3407
  const PHONE_LABEL_MAX_LENGTH = 100;
3408
3408
  const ADDRESS_COUNTRY_MAX_LENGTH = 80;
3409
3409
  const ADDRESS_CITY_MAX_LENGTH = 80;
3410
- const ADDRESS_STATE_MAX_LENGTH = 80;
3411
- const ADDRESS_ZIP_MAX_LENGTH = 20;
3410
+ const ADDRESS_STATE_MAX_LENGTH = 30;
3411
+ const ADDRESS_STATE_CODE_MAX_LENGTH = 2;
3412
+ const ADDRESS_ZIP_MAX_LENGTH = 11;
3412
3413
  const LABEL_STRING_MAX_LENGTH = 100;
3413
3414
  const SEARCH_STRING_MAX_LENGTH = 100;
3414
3415
  function nameField({ key = 'name', label = 'Name', placeholder = 'John Doe', required = false, minLength, maxLength, attributes } = {}) {
@@ -3435,45 +3436,42 @@ function emailField(config = {}) {
3435
3436
  };
3436
3437
  return emailFieldConfig;
3437
3438
  }
3438
- function cityField({ key = 'city', required = false } = {}) {
3439
- return textField({
3440
- key,
3441
- label: 'City',
3442
- placeholder: '',
3439
+ function cityField(config = {}) {
3440
+ const { key = 'city', placeholder = '', label = 'City', autocomplete = 'city', maxLength = ADDRESS_CITY_MAX_LENGTH, required = false } = config;
3441
+ return textField(Object.assign(Object.assign({}, config), { key,
3442
+ placeholder,
3443
+ label,
3444
+ autocomplete,
3443
3445
  required,
3444
- autocomplete: 'city',
3445
- maxLength: ADDRESS_CITY_MAX_LENGTH
3446
- });
3446
+ maxLength }));
3447
3447
  }
3448
- function stateField({ key = 'state', required = false } = {}) {
3449
- return textField({
3450
- key,
3451
- label: 'State',
3452
- placeholder: '',
3448
+ function stateField(config = {}) {
3449
+ 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;
3450
+ return textField(Object.assign(Object.assign({}, config), { key,
3451
+ placeholder,
3452
+ label,
3453
+ pattern,
3454
+ autocomplete,
3453
3455
  required,
3454
- autocomplete: 'state',
3455
- maxLength: ADDRESS_STATE_MAX_LENGTH
3456
- });
3456
+ maxLength }));
3457
3457
  }
3458
- function countryField({ key = 'country', required = false } = {}) {
3459
- return textField({
3460
- key,
3461
- label: 'Country',
3462
- placeholder: '',
3458
+ function countryField(config = {}) {
3459
+ const { key = 'country', placeholder = '', label = 'Country', autocomplete = 'country', maxLength = ADDRESS_COUNTRY_MAX_LENGTH, required = false } = config;
3460
+ return textField(Object.assign(Object.assign({}, config), { key,
3461
+ placeholder,
3462
+ label,
3463
+ autocomplete,
3463
3464
  required,
3464
- autocomplete: 'country',
3465
- maxLength: ADDRESS_COUNTRY_MAX_LENGTH
3466
- });
3465
+ maxLength }));
3467
3466
  }
3468
- function zipCodeField({ key = 'zip', required = false } = {}) {
3469
- return textField({
3470
- key,
3471
- label: 'Zip Code',
3472
- placeholder: '',
3467
+ function zipCodeField(config = {}) {
3468
+ const { key = 'zip', placeholder = '', label = 'Zip Code', autocomplete = 'postal-code', maxLength = ADDRESS_ZIP_MAX_LENGTH, required = false } = config;
3469
+ return textField(Object.assign(Object.assign({}, config), { key,
3470
+ placeholder,
3471
+ label,
3472
+ autocomplete,
3473
3473
  required,
3474
- autocomplete: 'postal-code',
3475
- maxLength: ADDRESS_ZIP_MAX_LENGTH
3476
- });
3474
+ maxLength }));
3477
3475
  }
3478
3476
  const DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER = '12.345,-67.8910';
3479
3477
  const DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE = `Invalid/unknown coordinates`;
@@ -3493,53 +3491,51 @@ function latLngTextField({ key = 'latLng' } = {}) {
3493
3491
  }
3494
3492
 
3495
3493
  const ADDRESS_LINE_MAX_LENGTH = 100;
3496
- function addressFormlyFields() {
3497
- return [
3498
- textField({
3499
- key: 'line1',
3500
- label: 'Line 1',
3501
- placeholder: '',
3502
- required: false,
3503
- autocomplete: 'address-line1',
3504
- maxLength: ADDRESS_LINE_MAX_LENGTH
3505
- }),
3506
- textField({
3507
- key: 'line2',
3508
- label: 'Line 2',
3509
- placeholder: '',
3510
- required: false,
3511
- autocomplete: 'address-line2',
3512
- maxLength: ADDRESS_LINE_MAX_LENGTH
3513
- }),
3514
- flexLayoutWrapper([
3515
- {
3516
- field: cityField({})
3517
- },
3518
- {
3519
- field: stateField({})
3520
- },
3521
- {
3522
- field: zipCodeField({})
3523
- },
3524
- {
3525
- field: countryField({})
3526
- }
3527
- ], { size: 1, relative: true })
3528
- ];
3494
+ function addressLineField(config = {}) {
3495
+ const { line = 1 } = config;
3496
+ const lineCode = Math.min(1, line);
3497
+ const { key = `line${lineCode}`, placeholder = '', label = line ? `Line ${line}` : 'Street', autocomplete = `address-line${lineCode}`, maxLength = ADDRESS_LINE_MAX_LENGTH, required = false } = config;
3498
+ return textField(Object.assign(Object.assign({}, config), { key,
3499
+ placeholder,
3500
+ label,
3501
+ autocomplete,
3502
+ required,
3503
+ maxLength }));
3529
3504
  }
3530
- function addressField({ key = 'address', required = false } = {}) {
3531
- return {
3532
- key,
3533
- wrappers: ['section'],
3534
- props: {
3535
- label: 'Address',
3536
- placeholder: '',
3537
- required
3505
+ function addressFormlyFields(config = {}) {
3506
+ const { includeLine2 = true, includeCountry = true } = config;
3507
+ const singleLineFields = [
3508
+ {
3509
+ field: cityField(config.cityField)
3538
3510
  },
3539
- fieldGroup: addressFormlyFields()
3540
- };
3511
+ {
3512
+ field: stateField(config.stateField)
3513
+ },
3514
+ {
3515
+ field: zipCodeField(config.zipCodeField)
3516
+ }
3517
+ ];
3518
+ if (includeCountry) {
3519
+ singleLineFields.push({
3520
+ field: countryField(config.countryField)
3521
+ });
3522
+ }
3523
+ let lines;
3524
+ if (includeLine2) {
3525
+ lines = [addressLineField(Object.assign(Object.assign({}, config.line1Field), { line: 1 })), addressLineField(Object.assign(Object.assign({}, config.line2Field), { line: 2 }))];
3526
+ }
3527
+ else {
3528
+ lines = [addressLineField(Object.assign(Object.assign({}, config.line1Field), { line: 0 }))];
3529
+ }
3530
+ return [...lines, flexLayoutWrapper(singleLineFields, { size: 1, relative: true })];
3531
+ }
3532
+ function addressField(config = {}) {
3533
+ const { key = 'address', header = 'Address', hint, required = false } = config;
3534
+ return sectionWrapper(Object.assign(Object.assign({}, config), { key, fieldGroup: addressFormlyFields(config), required }), Object.assign(Object.assign({}, config), { header,
3535
+ hint }));
3541
3536
  }
3542
- function addressListField({ key = 'addresses', required = false, maxAddresses = 6 } = {}) {
3537
+ function addressListField(config = {}) {
3538
+ const { key = 'addresses', required = false, maxAddresses = 6 } = config;
3543
3539
  return repeatArrayField({
3544
3540
  key,
3545
3541
  required,
@@ -3548,7 +3544,7 @@ function addressListField({ key = 'addresses', required = false, maxAddresses =
3548
3544
  addText: 'Add Address',
3549
3545
  removeText: 'Remove Address',
3550
3546
  maxLength: maxAddresses,
3551
- repeatFieldGroup: addressFormlyFields()
3547
+ repeatFieldGroup: addressFormlyFields(config)
3552
3548
  });
3553
3549
  }
3554
3550
 
@@ -4192,5 +4188,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
4192
4188
  * Generated bundle index. Do not edit.
4193
4189
  */
4194
4190
 
4195
- export { ADDRESS_CITY_MAX_LENGTH, ADDRESS_COUNTRY_MAX_LENGTH, ADDRESS_LINE_MAX_LENGTH, ADDRESS_STATE_MAX_LENGTH, ADDRESS_ZIP_MAX_LENGTH, APP_ACTION_FORM_DISABLED_KEY, AUTO_TOUCH_WRAPPER_KEY, AbstractAsyncFormlyFormDirective, AbstractConfigAsyncFormlyFormDirective, AbstractDbxPickableItemFieldDirective, AbstractDbxSearchableFieldDisplayDirective, AbstractDbxSearchableValueFieldDirective, AbstractFormExpandableSectionWrapperDirective, AbstractFormlyFormDirective, AbstractSyncFormlyFormDirective, AutoTouchFieldWrapperComponent, ChecklistItemFieldDataSetBuilder, DBX_SEARCHABLE_FIELD_COMPONENT_DATA_TOKEN, DEFAULT_FORM_DISABLED_KEY, DEFAULT_HAS_VALUE_FN, DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE, DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER, DEFAULT_PREFERRED_COUNTRIES, DISPLAY_FOR_TIMEZONE_STRING_VALUE, DbxActionFormDirective, DbxActionFormSafetyDirective, DbxChecklistItemContentComponent, DbxChecklistItemFieldComponent, DbxDateTimeFieldComponent, DbxDateTimeFieldTimeMode, DbxDefaultChecklistItemFieldDisplayComponent, DbxDefaultSearchableFieldDisplayComponent, DbxForm, DbxFormActionModule, DbxFormActionTransitionModule, DbxFormComponentFieldComponent, DbxFormExpandWrapperComponent, DbxFormExtensionModule, DbxFormFlexWrapperComponent, DbxFormFormlyArrayFieldModule, DbxFormFormlyBooleanFieldModule, DbxFormFormlyChecklistItemFieldModule, DbxFormFormlyComponentFieldModule, DbxFormFormlyDateFieldModule, DbxFormFormlyFieldModule, DbxFormFormlyNumberFieldModule, DbxFormFormlyPhoneFieldModule, DbxFormFormlyPickableFieldModule, DbxFormFormlySearchableFieldModule, DbxFormFormlySelectionModule, DbxFormFormlyTextEditorFieldModule, DbxFormFormlyTextFieldModule, DbxFormFormlyValueModule, DbxFormFormlyWrapperModule, DbxFormInfoWrapperComponent, DbxFormIoModule, DbxFormLayoutModule, DbxFormLoadingSourceDirective, DbxFormModule, DbxFormRepeatArrayTypeComponent, DbxFormSectionWrapperComponent, DbxFormSourceDirective, DbxFormSpacerComponent, DbxFormState, DbxFormSubsectionWrapperComponent, DbxFormToggleWrapperComponent, DbxFormValueChangesDirective, DbxFormWorkingWrapperComponent, DbxFormlyContext, DbxFormlyFieldsContextDirective, DbxFormlyFormComponent, DbxFormlyModule, DbxMutableForm, DbxPhoneFieldComponent, DbxPickableChipListFieldComponent, DbxPickableListFieldComponent, DbxPickableListFieldItemListComponent, DbxPickableListFieldItemListViewComponent, DbxPickableListFieldItemListViewItemComponent, DbxSearchableChipFieldComponent, DbxSearchableFieldAutocompleteItemComponent, DbxSearchableTextFieldComponent, DbxTextEditorFieldComponent, EXPANDABLE_WRAPPER_KEY, FIELD_VALUES_ARE_EQUAL_VALIDATION_KEY, FIELD_VALUE_IS_AVAILABLE_ERROR_VALIDATION_KEY, FIELD_VALUE_IS_AVAILABLE_VALIDATION_KEY, FLEX_WRAPPER_KEY, INFO_WRAPPER_KEY, INVALID_PHONE_NUMBER_MESSAGE, IS_DIVISIBLE_BY_VALIDATION_KEY, LABEL_STRING_MAX_LENGTH, MAX_LENGTH_VALIDATION_MESSAGE, MAX_VALIDATION_MESSAGE, MIN_LENGTH_VALIDATION_MESSAGE, MIN_VALIDATION_MESSAGE, PHONE_LABEL_MAX_LENGTH, REQUIRED_VALIDATION_MESSAGE, SEARCH_STRING_MAX_LENGTH, SECTION_WRAPPER_KEY, STYLE_WRAPPER_KEY, SUBSECTION_WRAPPER_KEY, TAKE_NEXT_UPCOMING_TIME_CONFIG_OBS, TOGGLE_WRAPPER_KEY, WORKING_WRAPPER_KEY, addWrapperToFormlyFieldConfig, addressField, addressFormlyFields, addressListField, autoTouchWrapper, checkIsFieldFlexLayoutGroupFieldConfig, checkboxField, checklistItemField, chipTextField, cityField, componentField, countryField, dateTimeField, dbxFormSourceObservable, defaultValidationMessages, disableFormlyFieldAutofillAttributes, emailField, expandWrapper, fieldValueIsAvailableValidator, fieldValuesAreEqualValidator, filterPartialPotentialFieldConfigValuesFromObject, filterPickableItemFieldValuesByLabel, filterPickableItemFieldValuesByLabelFilterFunction, flexLayoutWrapper, formlyField, hiddenField, infoWrapper, isDivisibleBy, isDomain, isInRange, isTruthy, latLngTextField, makeMetaFilterSearchableFieldValueDisplayFn, maxLengthValidationMessage, maxValidationMessage, mergePropsValueObjects, minLengthValidationMessage, minValidationMessage, nameField, numberField, partialPotentialFieldConfigKeys, partialPotentialFieldConfigKeysFilter, phoneAndLabelSectionField, phoneField, phoneListField, pickableItemChipField, pickableItemListField, propsForFieldConfig, propsValueForFieldConfig, provideDbxForm, provideDbxMutableForm, provideFormlyContext, repeatArrayField, searchableChipField, searchableStringChipField, searchableTextField, sectionWrapper, sortPickableItemsByLabel, stateField, styleWrapper, subsectionWrapper, textAreaField, textEditorField, textField, textIsAvailableField, textPasswordField, textPasswordWithVerifyFieldGroup, textVerifyPasswordField, timeOnlyField, timezoneStringField, timezoneStringSearchFunction, toggleField, toggleWrapper, usernamePasswordLoginFields, validatorsForFieldConfig, valueSelectionField, workingWrapper, wrappedPhoneAndLabelField, zipCodeField };
4191
+ export { ADDRESS_CITY_MAX_LENGTH, ADDRESS_COUNTRY_MAX_LENGTH, ADDRESS_LINE_MAX_LENGTH, ADDRESS_STATE_CODE_MAX_LENGTH, ADDRESS_STATE_MAX_LENGTH, ADDRESS_ZIP_MAX_LENGTH, APP_ACTION_FORM_DISABLED_KEY, AUTO_TOUCH_WRAPPER_KEY, AbstractAsyncFormlyFormDirective, AbstractConfigAsyncFormlyFormDirective, AbstractDbxPickableItemFieldDirective, AbstractDbxSearchableFieldDisplayDirective, AbstractDbxSearchableValueFieldDirective, AbstractFormExpandableSectionWrapperDirective, AbstractFormlyFormDirective, AbstractSyncFormlyFormDirective, AutoTouchFieldWrapperComponent, ChecklistItemFieldDataSetBuilder, DBX_SEARCHABLE_FIELD_COMPONENT_DATA_TOKEN, DEFAULT_FORM_DISABLED_KEY, DEFAULT_HAS_VALUE_FN, DEFAULT_LAT_LNG_TEXT_FIELD_PATTERN_MESSAGE, DEFAULT_LAT_LNG_TEXT_FIELD_PLACEHOLDER, DEFAULT_PREFERRED_COUNTRIES, DISPLAY_FOR_TIMEZONE_STRING_VALUE, DbxActionFormDirective, DbxActionFormSafetyDirective, DbxChecklistItemContentComponent, DbxChecklistItemFieldComponent, DbxDateTimeFieldComponent, DbxDateTimeFieldTimeMode, DbxDefaultChecklistItemFieldDisplayComponent, DbxDefaultSearchableFieldDisplayComponent, DbxForm, DbxFormActionModule, DbxFormActionTransitionModule, DbxFormComponentFieldComponent, DbxFormExpandWrapperComponent, DbxFormExtensionModule, DbxFormFlexWrapperComponent, DbxFormFormlyArrayFieldModule, DbxFormFormlyBooleanFieldModule, DbxFormFormlyChecklistItemFieldModule, DbxFormFormlyComponentFieldModule, DbxFormFormlyDateFieldModule, DbxFormFormlyFieldModule, DbxFormFormlyNumberFieldModule, DbxFormFormlyPhoneFieldModule, DbxFormFormlyPickableFieldModule, DbxFormFormlySearchableFieldModule, DbxFormFormlySelectionModule, DbxFormFormlyTextEditorFieldModule, DbxFormFormlyTextFieldModule, DbxFormFormlyValueModule, DbxFormFormlyWrapperModule, DbxFormInfoWrapperComponent, DbxFormIoModule, DbxFormLayoutModule, DbxFormLoadingSourceDirective, DbxFormModule, DbxFormRepeatArrayTypeComponent, DbxFormSectionWrapperComponent, DbxFormSourceDirective, DbxFormSpacerComponent, DbxFormState, DbxFormSubsectionWrapperComponent, DbxFormToggleWrapperComponent, DbxFormValueChangesDirective, DbxFormWorkingWrapperComponent, DbxFormlyContext, DbxFormlyFieldsContextDirective, DbxFormlyFormComponent, DbxFormlyModule, DbxMutableForm, DbxPhoneFieldComponent, DbxPickableChipListFieldComponent, DbxPickableListFieldComponent, DbxPickableListFieldItemListComponent, DbxPickableListFieldItemListViewComponent, DbxPickableListFieldItemListViewItemComponent, DbxSearchableChipFieldComponent, DbxSearchableFieldAutocompleteItemComponent, DbxSearchableTextFieldComponent, DbxTextEditorFieldComponent, EXPANDABLE_WRAPPER_KEY, FIELD_VALUES_ARE_EQUAL_VALIDATION_KEY, FIELD_VALUE_IS_AVAILABLE_ERROR_VALIDATION_KEY, FIELD_VALUE_IS_AVAILABLE_VALIDATION_KEY, FLEX_WRAPPER_KEY, INFO_WRAPPER_KEY, INVALID_PHONE_NUMBER_MESSAGE, IS_DIVISIBLE_BY_VALIDATION_KEY, LABEL_STRING_MAX_LENGTH, MAX_LENGTH_VALIDATION_MESSAGE, MAX_VALIDATION_MESSAGE, MIN_LENGTH_VALIDATION_MESSAGE, MIN_VALIDATION_MESSAGE, PHONE_LABEL_MAX_LENGTH, REQUIRED_VALIDATION_MESSAGE, SEARCH_STRING_MAX_LENGTH, SECTION_WRAPPER_KEY, STYLE_WRAPPER_KEY, SUBSECTION_WRAPPER_KEY, TAKE_NEXT_UPCOMING_TIME_CONFIG_OBS, TOGGLE_WRAPPER_KEY, WORKING_WRAPPER_KEY, addWrapperToFormlyFieldConfig, addressField, addressFormlyFields, addressLineField, addressListField, autoTouchWrapper, checkIsFieldFlexLayoutGroupFieldConfig, checkboxField, checklistItemField, chipTextField, cityField, componentField, countryField, dateTimeField, dbxFormSourceObservable, defaultValidationMessages, disableFormlyFieldAutofillAttributes, emailField, expandWrapper, fieldValueIsAvailableValidator, fieldValuesAreEqualValidator, filterPartialPotentialFieldConfigValuesFromObject, filterPickableItemFieldValuesByLabel, filterPickableItemFieldValuesByLabelFilterFunction, flexLayoutWrapper, formlyField, hiddenField, infoWrapper, isDivisibleBy, isDomain, isInRange, isTruthy, latLngTextField, makeMetaFilterSearchableFieldValueDisplayFn, maxLengthValidationMessage, maxValidationMessage, mergePropsValueObjects, minLengthValidationMessage, minValidationMessage, nameField, numberField, partialPotentialFieldConfigKeys, partialPotentialFieldConfigKeysFilter, phoneAndLabelSectionField, phoneField, phoneListField, pickableItemChipField, pickableItemListField, propsForFieldConfig, propsValueForFieldConfig, provideDbxForm, provideDbxMutableForm, provideFormlyContext, repeatArrayField, searchableChipField, searchableStringChipField, searchableTextField, sectionWrapper, sortPickableItemsByLabel, stateField, styleWrapper, subsectionWrapper, textAreaField, textEditorField, textField, textIsAvailableField, textPasswordField, textPasswordWithVerifyFieldGroup, textVerifyPasswordField, timeOnlyField, timezoneStringField, timezoneStringSearchFunction, toggleField, toggleWrapper, usernamePasswordLoginFields, validatorsForFieldConfig, valueSelectionField, workingWrapper, wrappedPhoneAndLabelField, zipCodeField };
4196
4192
  //# sourceMappingURL=dereekb-dbx-form.mjs.map