@dereekb/dbx-form 9.15.0 → 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.
- package/esm2020/lib/formly/field/value/text/text.additional.field.mjs +34 -24
- package/esm2020/lib/formly/field/value/text/text.address.field.mjs +55 -46
- package/fesm2015/dereekb-dbx-form.mjs +77 -81
- package/fesm2015/dereekb-dbx-form.mjs.map +1 -1
- package/fesm2020/dereekb-dbx-form.mjs +87 -68
- package/fesm2020/dereekb-dbx-form.mjs.map +1 -1
- package/lib/formly/field/value/text/text.additional.field.d.ts +16 -6
- package/lib/formly/field/value/text/text.address.field.d.ts +33 -5
- package/mapbox/package.json +4 -4
- package/package.json +3 -3
|
@@ -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 =
|
|
9
|
-
export const
|
|
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(
|
|
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
|
-
|
|
44
|
-
|
|
46
|
+
placeholder,
|
|
47
|
+
label,
|
|
48
|
+
autocomplete,
|
|
45
49
|
required,
|
|
46
|
-
|
|
47
|
-
maxLength: ADDRESS_CITY_MAX_LENGTH
|
|
50
|
+
maxLength
|
|
48
51
|
});
|
|
49
52
|
}
|
|
50
|
-
export function stateField(
|
|
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
|
-
|
|
54
|
-
|
|
58
|
+
placeholder,
|
|
59
|
+
label,
|
|
60
|
+
pattern,
|
|
61
|
+
autocomplete,
|
|
55
62
|
required,
|
|
56
|
-
|
|
57
|
-
maxLength: ADDRESS_STATE_MAX_LENGTH
|
|
63
|
+
maxLength
|
|
58
64
|
});
|
|
59
65
|
}
|
|
60
|
-
export function countryField(
|
|
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
|
-
|
|
64
|
-
|
|
71
|
+
placeholder,
|
|
72
|
+
label,
|
|
73
|
+
autocomplete,
|
|
65
74
|
required,
|
|
66
|
-
|
|
67
|
-
maxLength: ADDRESS_COUNTRY_MAX_LENGTH
|
|
75
|
+
maxLength
|
|
68
76
|
});
|
|
69
77
|
}
|
|
70
|
-
export function zipCodeField(
|
|
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
|
-
|
|
74
|
-
|
|
83
|
+
placeholder,
|
|
84
|
+
label,
|
|
85
|
+
autocomplete,
|
|
75
86
|
required,
|
|
76
|
-
|
|
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
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
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(
|
|
41
|
-
|
|
47
|
+
export function addressField(config = {}) {
|
|
48
|
+
const { key = 'address', header = 'Address', hint, required = false } = config;
|
|
49
|
+
return sectionWrapper({
|
|
50
|
+
...config,
|
|
42
51
|
key,
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
};
|
|
52
|
+
fieldGroup: addressFormlyFields(config),
|
|
53
|
+
required
|
|
54
|
+
}, {
|
|
55
|
+
...config,
|
|
56
|
+
header,
|
|
57
|
+
hint
|
|
58
|
+
});
|
|
51
59
|
}
|
|
52
|
-
export function addressListField(
|
|
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,
|
|
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"]}
|
|
@@ -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';
|
|
@@ -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 =
|
|
3411
|
-
const
|
|
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(
|
|
3439
|
-
|
|
3440
|
-
|
|
3441
|
-
|
|
3442
|
-
|
|
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
|
-
|
|
3445
|
-
maxLength: ADDRESS_CITY_MAX_LENGTH
|
|
3446
|
-
});
|
|
3446
|
+
maxLength }));
|
|
3447
3447
|
}
|
|
3448
|
-
function stateField(
|
|
3449
|
-
|
|
3450
|
-
|
|
3451
|
-
|
|
3452
|
-
|
|
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
|
-
|
|
3455
|
-
maxLength: ADDRESS_STATE_MAX_LENGTH
|
|
3456
|
-
});
|
|
3456
|
+
maxLength }));
|
|
3457
3457
|
}
|
|
3458
|
-
function countryField(
|
|
3459
|
-
|
|
3460
|
-
|
|
3461
|
-
|
|
3462
|
-
|
|
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
|
-
|
|
3465
|
-
maxLength: ADDRESS_COUNTRY_MAX_LENGTH
|
|
3466
|
-
});
|
|
3465
|
+
maxLength }));
|
|
3467
3466
|
}
|
|
3468
|
-
function zipCodeField(
|
|
3469
|
-
|
|
3470
|
-
|
|
3471
|
-
|
|
3472
|
-
|
|
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
|
-
|
|
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
|
|
3497
|
-
|
|
3498
|
-
|
|
3499
|
-
|
|
3500
|
-
|
|
3501
|
-
|
|
3502
|
-
|
|
3503
|
-
|
|
3504
|
-
|
|
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
|
|
3531
|
-
|
|
3532
|
-
|
|
3533
|
-
|
|
3534
|
-
|
|
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
|
-
|
|
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(
|
|
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
|