@ng-formworks/core 18.5.2 → 19.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (59) hide show
  1. package/README.md +2 -1
  2. package/fesm2022/ng-formworks-core.mjs +130 -110
  3. package/fesm2022/ng-formworks-core.mjs.map +1 -1
  4. package/package.json +3 -3
  5. package/esm2022/lib/framework-library/framework-library.service.mjs +0 -172
  6. package/esm2022/lib/framework-library/framework.mjs +0 -15
  7. package/esm2022/lib/framework-library/no-framework.component.mjs +0 -17
  8. package/esm2022/lib/framework-library/no-framework.module.mjs +0 -27
  9. package/esm2022/lib/framework-library/no.framework.mjs +0 -19
  10. package/esm2022/lib/json-schema-form.component.mjs +0 -759
  11. package/esm2022/lib/json-schema-form.module.mjs +0 -26
  12. package/esm2022/lib/json-schema-form.service.mjs +0 -695
  13. package/esm2022/lib/locale/de-validation-messages.mjs +0 -60
  14. package/esm2022/lib/locale/en-validation-messages.mjs +0 -60
  15. package/esm2022/lib/locale/es-validation-messages.mjs +0 -57
  16. package/esm2022/lib/locale/fr-validation-messages.mjs +0 -60
  17. package/esm2022/lib/locale/index.mjs +0 -8
  18. package/esm2022/lib/locale/it-validation-messages.mjs +0 -60
  19. package/esm2022/lib/locale/pt-validation-messages.mjs +0 -60
  20. package/esm2022/lib/locale/zh-validation-messages.mjs +0 -60
  21. package/esm2022/lib/shared/convert-schema-to-draft6.function.mjs +0 -300
  22. package/esm2022/lib/shared/form-group.functions.mjs +0 -445
  23. package/esm2022/lib/shared/format-regex.constants.mjs +0 -54
  24. package/esm2022/lib/shared/index.mjs +0 -12
  25. package/esm2022/lib/shared/json-schema.functions.mjs +0 -784
  26. package/esm2022/lib/shared/json.validators.mjs +0 -884
  27. package/esm2022/lib/shared/jsonpointer.functions.mjs +0 -1026
  28. package/esm2022/lib/shared/layout.functions.mjs +0 -1158
  29. package/esm2022/lib/shared/merge-schemas.function.mjs +0 -345
  30. package/esm2022/lib/shared/utility.functions.mjs +0 -380
  31. package/esm2022/lib/shared/validator.functions.mjs +0 -584
  32. package/esm2022/lib/widget-library/add-reference.component.mjs +0 -58
  33. package/esm2022/lib/widget-library/button.component.mjs +0 -69
  34. package/esm2022/lib/widget-library/checkbox.component.mjs +0 -102
  35. package/esm2022/lib/widget-library/checkboxes.component.mjs +0 -145
  36. package/esm2022/lib/widget-library/file.component.mjs +0 -32
  37. package/esm2022/lib/widget-library/hidden.component.mjs +0 -51
  38. package/esm2022/lib/widget-library/index.mjs +0 -55
  39. package/esm2022/lib/widget-library/input.component.mjs +0 -116
  40. package/esm2022/lib/widget-library/message.component.mjs +0 -35
  41. package/esm2022/lib/widget-library/none.component.mjs +0 -20
  42. package/esm2022/lib/widget-library/number.component.mjs +0 -120
  43. package/esm2022/lib/widget-library/one-of.component.mjs +0 -32
  44. package/esm2022/lib/widget-library/orderable.directive.mjs +0 -120
  45. package/esm2022/lib/widget-library/radios.component.mjs +0 -151
  46. package/esm2022/lib/widget-library/root.component.mjs +0 -73
  47. package/esm2022/lib/widget-library/section.component.mjs +0 -196
  48. package/esm2022/lib/widget-library/select-framework.component.mjs +0 -44
  49. package/esm2022/lib/widget-library/select-widget.component.mjs +0 -42
  50. package/esm2022/lib/widget-library/select.component.mjs +0 -147
  51. package/esm2022/lib/widget-library/submit.component.mjs +0 -79
  52. package/esm2022/lib/widget-library/tab.component.mjs +0 -38
  53. package/esm2022/lib/widget-library/tabs.component.mjs +0 -106
  54. package/esm2022/lib/widget-library/template.component.mjs +0 -43
  55. package/esm2022/lib/widget-library/textarea.component.mjs +0 -101
  56. package/esm2022/lib/widget-library/widget-library.module.mjs +0 -42
  57. package/esm2022/lib/widget-library/widget-library.service.mjs +0 -226
  58. package/esm2022/ng-formworks-core.mjs +0 -5
  59. package/esm2022/public_api.mjs +0 -13
@@ -1,584 +0,0 @@
1
- import { from, Observable } from 'rxjs';
2
- /**
3
- * '_executeValidators' utility function
4
- *
5
- * Validates a control against an array of validators, and returns
6
- * an array of the same length containing a combination of error messages
7
- * (from invalid validators) and null values (from valid validators)
8
- *
9
- * // { AbstractControl } control - control to validate
10
- * // { IValidatorFn[] } validators - array of validators
11
- * // { boolean } invert - invert?
12
- * // { PlainObject[] } - array of nulls and error message
13
- */
14
- export function _executeValidators(control, validators, invert = false) {
15
- return validators.map(validator => validator(control, invert));
16
- }
17
- /**
18
- * '_executeAsyncValidators' utility function
19
- *
20
- * Validates a control against an array of async validators, and returns
21
- * an array of observabe results of the same length containing a combination of
22
- * error messages (from invalid validators) and null values (from valid ones)
23
- *
24
- * // { AbstractControl } control - control to validate
25
- * // { AsyncIValidatorFn[] } validators - array of async validators
26
- * // { boolean } invert - invert?
27
- * // - array of observable nulls and error message
28
- */
29
- export function _executeAsyncValidators(control, validators, invert = false) {
30
- return validators.map(validator => validator(control, invert));
31
- }
32
- /**
33
- * '_mergeObjects' utility function
34
- *
35
- * Recursively Merges one or more objects into a single object with combined keys.
36
- * Automatically detects and ignores null and undefined inputs.
37
- * Also detects duplicated boolean 'not' keys and XORs their values.
38
- *
39
- * // { PlainObject[] } objects - one or more objects to merge
40
- * // { PlainObject } - merged object
41
- */
42
- export function _mergeObjects(...objects) {
43
- const mergedObject = {};
44
- for (const currentObject of objects) {
45
- if (isObject(currentObject)) {
46
- for (const key of Object.keys(currentObject)) {
47
- const currentValue = currentObject[key];
48
- const mergedValue = mergedObject[key];
49
- mergedObject[key] = !isDefined(mergedValue) ? currentValue :
50
- key === 'not' && isBoolean(mergedValue, 'strict') &&
51
- isBoolean(currentValue, 'strict') ? xor(mergedValue, currentValue) :
52
- getType(mergedValue) === 'object' && getType(currentValue) === 'object' ?
53
- _mergeObjects(mergedValue, currentValue) :
54
- currentValue;
55
- }
56
- }
57
- }
58
- return mergedObject;
59
- }
60
- /**
61
- * '_mergeErrors' utility function
62
- *
63
- * Merges an array of objects.
64
- * Used for combining the validator errors returned from 'executeValidators'
65
- *
66
- * // { PlainObject[] } arrayOfErrors - array of objects
67
- * // { PlainObject } - merged object, or null if no usable input objectcs
68
- */
69
- export function _mergeErrors(arrayOfErrors) {
70
- const mergedErrors = _mergeObjects(...arrayOfErrors);
71
- return isEmpty(mergedErrors) ? null : mergedErrors;
72
- }
73
- /**
74
- * 'isDefined' utility function
75
- *
76
- * Checks if a variable contains a value of any type.
77
- * Returns true even for otherwise 'falsey' values of 0, '', and false.
78
- *
79
- * // value - the value to check
80
- * // { boolean } - false if undefined or null, otherwise true
81
- */
82
- export function isDefined(value) {
83
- return value !== undefined && value !== null;
84
- }
85
- /**
86
- * 'hasValue' utility function
87
- *
88
- * Checks if a variable contains a value.
89
- * Returs false for null, undefined, or a zero-length strng, '',
90
- * otherwise returns true.
91
- * (Stricter than 'isDefined' because it also returns false for '',
92
- * though it stil returns true for otherwise 'falsey' values 0 and false.)
93
- *
94
- * // value - the value to check
95
- * // { boolean } - false if undefined, null, or '', otherwise true
96
- */
97
- export function hasValue(value) {
98
- return value !== undefined && value !== null && value !== '';
99
- }
100
- /**
101
- * 'isEmpty' utility function
102
- *
103
- * Similar to !hasValue, but also returns true for empty arrays and objects.
104
- *
105
- * // value - the value to check
106
- * // { boolean } - false if undefined, null, or '', otherwise true
107
- */
108
- export function isEmpty(value) {
109
- if (isArray(value)) {
110
- return !value.length;
111
- }
112
- if (isObject(value)) {
113
- return !Object.keys(value).length;
114
- }
115
- return value === undefined || value === null || value === '';
116
- }
117
- /**
118
- * 'isString' utility function
119
- *
120
- * Checks if a value is a string.
121
- *
122
- * // value - the value to check
123
- * // { boolean } - true if string, false if not
124
- */
125
- export function isString(value) {
126
- return typeof value === 'string';
127
- }
128
- /**
129
- * 'isNumber' utility function
130
- *
131
- * Checks if a value is a regular number, numeric string, or JavaScript Date.
132
- *
133
- * // value - the value to check
134
- * // { any = false } strict - if truthy, also checks JavaScript tyoe
135
- * // { boolean } - true if number, false if not
136
- */
137
- export function isNumber(value, strict = false) {
138
- if (strict && typeof value !== 'number') {
139
- return false;
140
- }
141
- return !isNaN(value) && value !== value / 0;
142
- }
143
- /**
144
- * 'isInteger' utility function
145
- *
146
- * Checks if a value is an integer.
147
- *
148
- * // value - the value to check
149
- * // { any = false } strict - if truthy, also checks JavaScript tyoe
150
- * // {boolean } - true if number, false if not
151
- */
152
- export function isInteger(value, strict = false) {
153
- if (strict && typeof value !== 'number') {
154
- return false;
155
- }
156
- return !isNaN(value) && value !== value / 0 && value % 1 === 0;
157
- }
158
- /**
159
- * 'isBoolean' utility function
160
- *
161
- * Checks if a value is a boolean.
162
- *
163
- * // value - the value to check
164
- * // { any = null } option - if 'strict', also checks JavaScript type
165
- * if TRUE or FALSE, checks only for that value
166
- * // { boolean } - true if boolean, false if not
167
- */
168
- export function isBoolean(value, option = null) {
169
- if (option === 'strict') {
170
- return value === true || value === false;
171
- }
172
- if (option === true) {
173
- return value === true || value === 1 || value === 'true' || value === '1';
174
- }
175
- if (option === false) {
176
- return value === false || value === 0 || value === 'false' || value === '0';
177
- }
178
- return value === true || value === 1 || value === 'true' || value === '1' ||
179
- value === false || value === 0 || value === 'false' || value === '0';
180
- }
181
- export function isFunction(item) {
182
- return typeof item === 'function';
183
- }
184
- export function isObject(item) {
185
- return item !== null && typeof item === 'object';
186
- }
187
- export function isArray(item) {
188
- return Array.isArray(item);
189
- }
190
- export function isDate(item) {
191
- return !!item && Object.prototype.toString.call(item) === '[object Date]';
192
- }
193
- export function isMap(item) {
194
- return !!item && Object.prototype.toString.call(item) === '[object Map]';
195
- }
196
- export function isSet(item) {
197
- return !!item && Object.prototype.toString.call(item) === '[object Set]';
198
- }
199
- export function isSymbol(item) {
200
- return typeof item === 'symbol';
201
- }
202
- /**
203
- * 'getType' function
204
- *
205
- * Detects the JSON Schema Type of a value.
206
- * By default, detects numbers and integers even if formatted as strings.
207
- * (So all integers are also numbers, and any number may also be a string.)
208
- * However, it only detects true boolean values (to detect boolean values
209
- * in non-boolean formats, use isBoolean() instead).
210
- *
211
- * If passed a second optional parameter of 'strict', it will only detect
212
- * numbers and integers if they are formatted as JavaScript numbers.
213
- *
214
- * Examples:
215
- * getType('10.5') = 'number'
216
- * getType(10.5) = 'number'
217
- * getType('10') = 'integer'
218
- * getType(10) = 'integer'
219
- * getType('true') = 'string'
220
- * getType(true) = 'boolean'
221
- * getType(null) = 'null'
222
- * getType({ }) = 'object'
223
- * getType([]) = 'array'
224
- *
225
- * getType('10.5', 'strict') = 'string'
226
- * getType(10.5, 'strict') = 'number'
227
- * getType('10', 'strict') = 'string'
228
- * getType(10, 'strict') = 'integer'
229
- * getType('true', 'strict') = 'string'
230
- * getType(true, 'strict') = 'boolean'
231
- *
232
- * // value - value to check
233
- * // { any = false } strict - if truthy, also checks JavaScript tyoe
234
- * // { SchemaType }
235
- */
236
- export function getType(value, strict = false) {
237
- if (!isDefined(value)) {
238
- return 'null';
239
- }
240
- if (isArray(value)) {
241
- return 'array';
242
- }
243
- if (isObject(value)) {
244
- return 'object';
245
- }
246
- if (isBoolean(value, 'strict')) {
247
- return 'boolean';
248
- }
249
- if (isInteger(value, strict)) {
250
- return 'integer';
251
- }
252
- if (isNumber(value, strict)) {
253
- return 'number';
254
- }
255
- if (isString(value) || (!strict && isDate(value))) {
256
- return 'string';
257
- }
258
- return null;
259
- }
260
- /**
261
- * 'isType' function
262
- *
263
- * Checks wether an input (probably string) value contains data of
264
- * a specified JSON Schema type
265
- *
266
- * // { PrimitiveValue } value - value to check
267
- * // { SchemaPrimitiveType } type - type to check
268
- * // { boolean }
269
- */
270
- export function isType(value, type) {
271
- switch (type) {
272
- case 'string':
273
- return isString(value) || isDate(value);
274
- case 'number':
275
- return isNumber(value);
276
- case 'integer':
277
- return isInteger(value);
278
- case 'boolean':
279
- return isBoolean(value);
280
- case 'null':
281
- return !hasValue(value);
282
- default:
283
- console.error(`isType error: "${type}" is not a recognized type.`);
284
- return null;
285
- }
286
- }
287
- /**
288
- * 'isPrimitive' function
289
- *
290
- * Checks wether an input value is a JavaScript primitive type:
291
- * string, number, boolean, or null.
292
- *
293
- * // value - value to check
294
- * // { boolean }
295
- */
296
- export function isPrimitive(value) {
297
- return (isString(value) || isNumber(value) ||
298
- isBoolean(value, 'strict') || value === null);
299
- }
300
- /**
301
- *
302
- * @param date
303
- * @returns {string}
304
- * exmaple:
305
- * toDateString('2018-01-01') = '2018-01-01'
306
- * toDateString('2018-01-30T00:00:00.000Z') = '2018-01-30'
307
- */
308
- export const toIsoString = (date) => {
309
- const day = date.getDate();
310
- const month = date.getMonth() + 1;
311
- const year = date.getFullYear();
312
- return `${year}-${month < 10 ? '0' + month : month}-${day < 10 ? '0' + day : day}`;
313
- };
314
- /**
315
- * 'toJavaScriptType' function
316
- *
317
- * Converts an input (probably string) value to a JavaScript primitive type -
318
- * 'string', 'number', 'boolean', or 'null' - before storing in a JSON object.
319
- *
320
- * Does not coerce values (other than null), and only converts the types
321
- * of values that would otherwise be valid.
322
- *
323
- * If the optional third parameter 'strictIntegers' is TRUE, and the
324
- * JSON Schema type 'integer' is specified, it also verifies the input value
325
- * is an integer and, if it is, returns it as a JaveScript number.
326
- * If 'strictIntegers' is FALSE (or not set) the type 'integer' is treated
327
- * exactly the same as 'number', and allows decimals.
328
- *
329
- * Valid Examples:
330
- * toJavaScriptType('10', 'number' ) = 10 // '10' is a number
331
- * toJavaScriptType('10', 'integer') = 10 // '10' is also an integer
332
- * toJavaScriptType( 10, 'integer') = 10 // 10 is still an integer
333
- * toJavaScriptType( 10, 'string' ) = '10' // 10 can be made into a string
334
- * toJavaScriptType('10.5', 'number' ) = 10.5 // '10.5' is a number
335
- *
336
- * Invalid Examples:
337
- * toJavaScriptType('10.5', 'integer') = null // '10.5' is not an integer
338
- * toJavaScriptType( 10.5, 'integer') = null // 10.5 is still not an integer
339
- *
340
- * // { PrimitiveValue } value - value to convert
341
- * // { SchemaPrimitiveType | SchemaPrimitiveType[] } types - types to convert to
342
- * // { boolean = false } strictIntegers - if FALSE, treat integers as numbers
343
- * // { PrimitiveValue }
344
- */
345
- export function toJavaScriptType(value, types, strictIntegers = true) {
346
- if (!isDefined(value)) {
347
- return null;
348
- }
349
- if (isString(types)) {
350
- types = [types];
351
- }
352
- if (strictIntegers && inArray('integer', types)) {
353
- if (isInteger(value, 'strict')) {
354
- return value;
355
- }
356
- if (isInteger(value)) {
357
- return parseInt(value, 10);
358
- }
359
- }
360
- if (inArray('number', types) || (!strictIntegers && inArray('integer', types))) {
361
- if (isNumber(value, 'strict')) {
362
- return value;
363
- }
364
- if (isNumber(value)) {
365
- return parseFloat(value);
366
- }
367
- }
368
- if (inArray('string', types)) {
369
- if (isString(value)) {
370
- return value;
371
- }
372
- // If value is a date, and types includes 'string',
373
- // convert the date to a string
374
- if (isDate(value)) {
375
- return toIsoString(value);
376
- }
377
- if (isNumber(value)) {
378
- return value.toString();
379
- }
380
- }
381
- // If value is a date, and types includes 'integer' or 'number',
382
- // but not 'string', convert the date to a number
383
- if (isDate(value) && (inArray('integer', types) || inArray('number', types))) {
384
- return value.getTime();
385
- }
386
- if (inArray('boolean', types)) {
387
- if (isBoolean(value, true)) {
388
- return true;
389
- }
390
- if (isBoolean(value, false)) {
391
- return false;
392
- }
393
- }
394
- return null;
395
- }
396
- /**
397
- * 'toSchemaType' function
398
- *
399
- * Converts an input (probably string) value to the "best" JavaScript
400
- * equivalent available from an allowed list of JSON Schema types, which may
401
- * contain 'string', 'number', 'integer', 'boolean', and/or 'null'.
402
- * If necssary, it does progressively agressive type coersion.
403
- * It will not return null unless null is in the list of allowed types.
404
- *
405
- * Number conversion examples:
406
- * toSchemaType('10', ['number','integer','string']) = 10 // integer
407
- * toSchemaType('10', ['number','string']) = 10 // number
408
- * toSchemaType('10', ['string']) = '10' // string
409
- * toSchemaType('10.5', ['number','integer','string']) = 10.5 // number
410
- * toSchemaType('10.5', ['integer','string']) = '10.5' // string
411
- * toSchemaType('10.5', ['integer']) = 10 // integer
412
- * toSchemaType(10.5, ['null','boolean','string']) = '10.5' // string
413
- * toSchemaType(10.5, ['null','boolean']) = true // boolean
414
- *
415
- * String conversion examples:
416
- * toSchemaType('1.5x', ['boolean','number','integer','string']) = '1.5x' // string
417
- * toSchemaType('1.5x', ['boolean','number','integer']) = '1.5' // number
418
- * toSchemaType('1.5x', ['boolean','integer']) = '1' // integer
419
- * toSchemaType('1.5x', ['boolean']) = true // boolean
420
- * toSchemaType('xyz', ['number','integer','boolean','null']) = true // boolean
421
- * toSchemaType('xyz', ['number','integer','null']) = null // null
422
- * toSchemaType('xyz', ['number','integer']) = 0 // number
423
- *
424
- * Boolean conversion examples:
425
- * toSchemaType('1', ['integer','number','string','boolean']) = 1 // integer
426
- * toSchemaType('1', ['number','string','boolean']) = 1 // number
427
- * toSchemaType('1', ['string','boolean']) = '1' // string
428
- * toSchemaType('1', ['boolean']) = true // boolean
429
- * toSchemaType('true', ['number','string','boolean']) = 'true' // string
430
- * toSchemaType('true', ['boolean']) = true // boolean
431
- * toSchemaType('true', ['number']) = 0 // number
432
- * toSchemaType(true, ['number','string','boolean']) = true // boolean
433
- * toSchemaType(true, ['number','string']) = 'true' // string
434
- * toSchemaType(true, ['number']) = 1 // number
435
- *
436
- * // { PrimitiveValue } value - value to convert
437
- * // { SchemaPrimitiveType | SchemaPrimitiveType[] } types - allowed types to convert to
438
- * // { PrimitiveValue }
439
- */
440
- export function toSchemaType(value, types) {
441
- if (!isArray(types)) {
442
- types = [types];
443
- }
444
- if (types.includes('null') && !hasValue(value)) {
445
- return null;
446
- }
447
- if (types.includes('boolean') && !isBoolean(value, 'strict')) {
448
- return value;
449
- }
450
- if (types.includes('integer')) {
451
- const testValue = toJavaScriptType(value, 'integer');
452
- if (testValue !== null) {
453
- return +testValue;
454
- }
455
- }
456
- if (types.includes('number')) {
457
- const testValue = toJavaScriptType(value, 'number');
458
- if (testValue !== null) {
459
- return +testValue;
460
- }
461
- }
462
- if ((isString(value) || isNumber(value, 'strict')) &&
463
- types.includes('string')) { // Convert number to string
464
- return toJavaScriptType(value, 'string');
465
- }
466
- if (types.includes('boolean') && isBoolean(value)) {
467
- return toJavaScriptType(value, 'boolean');
468
- }
469
- if (types.includes('string')) { // Convert null & boolean to string
470
- if (value === null) {
471
- return '';
472
- }
473
- const testValue = toJavaScriptType(value, 'string');
474
- if (testValue !== null) {
475
- return testValue;
476
- }
477
- }
478
- if ((types.includes('number') ||
479
- types.includes('integer'))) {
480
- if (value === true) {
481
- return 1;
482
- } // Convert boolean & null to number
483
- if (value === false || value === null || value === '') {
484
- return 0;
485
- }
486
- }
487
- if (types.includes('number')) { // Convert mixed string to number
488
- const testValue = parseFloat(value);
489
- if (!!testValue) {
490
- return testValue;
491
- }
492
- }
493
- if (types.includes('integer')) { // Convert string or number to integer
494
- const testValue = parseInt(value, 10);
495
- if (!!testValue) {
496
- return testValue;
497
- }
498
- }
499
- if (types.includes('boolean')) { // Convert anything to boolean
500
- return !!value;
501
- }
502
- if ((types.includes('number') ||
503
- types.includes('integer')) && !types.includes('null')) {
504
- return 0; // If null not allowed, return 0 for non-convertable values
505
- }
506
- }
507
- /**
508
- * 'isPromise' function
509
- *
510
- * // object
511
- * // { boolean }
512
- */
513
- export function isPromise(object) {
514
- return !!object && typeof object.then === 'function';
515
- }
516
- /**
517
- * 'isObservable' function
518
- *
519
- * // object
520
- * // { boolean }
521
- */
522
- export function isObservable(object) {
523
- return !!object && typeof object.subscribe === 'function';
524
- }
525
- /**
526
- * '_toPromise' function
527
- *
528
- * // { object } object
529
- * // { Promise<any> }
530
- */
531
- export function _toPromise(object) {
532
- return isPromise(object) ? object : object.toPromise();
533
- }
534
- /**
535
- * 'toObservable' function
536
- *
537
- * // { object } object
538
- * // { Observable<any> }
539
- */
540
- export function toObservable(object) {
541
- const observable = isPromise(object) ? from(object) : object;
542
- if (isObservable(observable)) {
543
- return observable;
544
- }
545
- console.error('toObservable error: Expected validator to return Promise or Observable.');
546
- return new Observable();
547
- }
548
- /**
549
- * 'inArray' function
550
- *
551
- * Searches an array for an item, or one of a list of items, and returns true
552
- * as soon as a match is found, or false if no match.
553
- *
554
- * If the optional third parameter allIn is set to TRUE, and the item to find
555
- * is an array, then the function returns true only if all elements from item
556
- * are found in the array list, and false if any element is not found. If the
557
- * item to find is not an array, setting allIn to TRUE has no effect.
558
- *
559
- * // { any|any[] } item - the item to search for
560
- * // array - the array to search
561
- * // { boolean = false } allIn - if TRUE, all items must be in array
562
- * // { boolean } - true if item(s) in array, false otherwise
563
- */
564
- export function inArray(item, array, allIn = false) {
565
- if (!isDefined(item) || !isArray(array)) {
566
- return false;
567
- }
568
- return isArray(item) ?
569
- item[allIn ? 'every' : 'some'](subItem => array.includes(subItem)) :
570
- array.includes(item);
571
- }
572
- /**
573
- * 'xor' utility function - exclusive or
574
- *
575
- * Returns true if exactly one of two values is truthy.
576
- *
577
- * // value1 - first value to check
578
- * // value2 - second value to check
579
- * // { boolean } - true if exactly one input value is truthy, false if not
580
- */
581
- export function xor(value1, value2) {
582
- return (!!value1 && !value2) || (!value1 && !!value2);
583
- }
584
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validator.functions.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-core/src/lib/shared/validator.functions.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl } from '@angular/forms';\r\nimport { from, Observable } from 'rxjs';\r\n\r\n/**\r\n * Validator utility function library:\r\n *\r\n * Validator and error utilities:\r\n *   _executeValidators, _executeAsyncValidators, _mergeObjects, _mergeErrors\r\n *\r\n * Individual value checking:\r\n *   isDefined, hasValue, isEmpty\r\n *\r\n * Individual type checking:\r\n *   isString, isNumber, isInteger, isBoolean, isFunction, isObject, isArray,\r\n *   isMap, isSet, isPromise, isObservable\r\n *\r\n * Multiple type checking and fixing:\r\n *   getType, isType, isPrimitive, toJavaScriptType, toSchemaType,\r\n *   _toPromise, toObservable\r\n *\r\n * Utility functions:\r\n *   inArray, xor\r\n *\r\n * Typescript types and interfaces:\r\n *   SchemaPrimitiveType, SchemaType, JavaScriptPrimitiveType, JavaScriptType,\r\n *   PrimitiveValue, PlainObject, IValidatorFn, AsyncIValidatorFn\r\n *\r\n * Note: 'IValidatorFn' is short for 'invertable validator function',\r\n *   which is a validator functions that accepts an optional second\r\n *   argument which, if set to TRUE, causes the validator to perform\r\n *   the opposite of its original function.\r\n */\r\n\r\nexport type SchemaPrimitiveType =\r\n  'string' | 'number' | 'integer' | 'boolean' | 'null';\r\nexport type SchemaType =\r\n  'string' | 'number' | 'integer' | 'boolean' | 'null' | 'object' | 'array';\r\nexport type JavaScriptPrimitiveType =\r\n  'string' | 'number' | 'boolean' | 'null' | 'undefined';\r\nexport type JavaScriptType =\r\n  'string' | 'number' | 'boolean' | 'null' | 'undefined' | 'object' | 'array' |\r\n  'map' | 'set' | 'arguments' | 'date' | 'error' | 'function' | 'json' |\r\n  'math' | 'regexp'; // Note: this list is incomplete\r\nexport type PrimitiveValue = string | number | boolean | null | undefined;\r\nexport interface PlainObject { [k: string]: any; }\r\n\r\nexport type IValidatorFn = (c: AbstractControl, i?: boolean) => PlainObject;\r\nexport type AsyncIValidatorFn = (c: AbstractControl, i?: boolean) => any;\r\n\r\n/**\r\n * '_executeValidators' utility function\r\n *\r\n * Validates a control against an array of validators, and returns\r\n * an array of the same length containing a combination of error messages\r\n * (from invalid validators) and null values (from valid validators)\r\n *\r\n * //  { AbstractControl } control - control to validate\r\n * //  { IValidatorFn[] } validators - array of validators\r\n * //  { boolean } invert - invert?\r\n * // { PlainObject[] } - array of nulls and error message\r\n */\r\nexport function _executeValidators(control, validators, invert = false) {\r\n  return validators.map(validator => validator(control, invert));\r\n}\r\n\r\n/**\r\n * '_executeAsyncValidators' utility function\r\n *\r\n * Validates a control against an array of async validators, and returns\r\n * an array of observabe results of the same length containing a combination of\r\n * error messages (from invalid validators) and null values (from valid ones)\r\n *\r\n * //  { AbstractControl } control - control to validate\r\n * //  { AsyncIValidatorFn[] } validators - array of async validators\r\n * //  { boolean } invert - invert?\r\n * //  - array of observable nulls and error message\r\n */\r\nexport function _executeAsyncValidators(control, validators, invert = false) {\r\n  return validators.map(validator => validator(control, invert));\r\n}\r\n\r\n/**\r\n * '_mergeObjects' utility function\r\n *\r\n * Recursively Merges one or more objects into a single object with combined keys.\r\n * Automatically detects and ignores null and undefined inputs.\r\n * Also detects duplicated boolean 'not' keys and XORs their values.\r\n *\r\n * //  { PlainObject[] } objects - one or more objects to merge\r\n * // { PlainObject } - merged object\r\n */\r\nexport function _mergeObjects(...objects) {\r\n  const mergedObject: PlainObject = { };\r\n  for (const currentObject of objects) {\r\n    if (isObject(currentObject)) {\r\n      for (const key of Object.keys(currentObject)) {\r\n        const currentValue = currentObject[key];\r\n        const mergedValue = mergedObject[key];\r\n        mergedObject[key] = !isDefined(mergedValue) ? currentValue :\r\n          key === 'not' && isBoolean(mergedValue, 'strict') &&\r\n            isBoolean(currentValue, 'strict') ? xor(mergedValue, currentValue) :\r\n          getType(mergedValue) === 'object' && getType(currentValue) === 'object' ?\r\n            _mergeObjects(mergedValue, currentValue) :\r\n            currentValue;\r\n      }\r\n    }\r\n  }\r\n  return mergedObject;\r\n}\r\n\r\n/**\r\n * '_mergeErrors' utility function\r\n *\r\n * Merges an array of objects.\r\n * Used for combining the validator errors returned from 'executeValidators'\r\n *\r\n * //  { PlainObject[] } arrayOfErrors - array of objects\r\n * // { PlainObject } - merged object, or null if no usable input objectcs\r\n */\r\nexport function _mergeErrors(arrayOfErrors) {\r\n  const mergedErrors = _mergeObjects(...arrayOfErrors);\r\n  return isEmpty(mergedErrors) ? null : mergedErrors;\r\n}\r\n\r\n/**\r\n * 'isDefined' utility function\r\n *\r\n * Checks if a variable contains a value of any type.\r\n * Returns true even for otherwise 'falsey' values of 0, '', and false.\r\n *\r\n * //   value - the value to check\r\n * // { boolean } - false if undefined or null, otherwise true\r\n */\r\nexport function isDefined(value) {\r\n  return value !== undefined && value !== null;\r\n}\r\n\r\n/**\r\n * 'hasValue' utility function\r\n *\r\n * Checks if a variable contains a value.\r\n * Returs false for null, undefined, or a zero-length strng, '',\r\n * otherwise returns true.\r\n * (Stricter than 'isDefined' because it also returns false for '',\r\n * though it stil returns true for otherwise 'falsey' values 0 and false.)\r\n *\r\n * //   value - the value to check\r\n * // { boolean } - false if undefined, null, or '', otherwise true\r\n */\r\nexport function hasValue(value) {\r\n  return value !== undefined && value !== null && value !== '';\r\n}\r\n\r\n/**\r\n * 'isEmpty' utility function\r\n *\r\n * Similar to !hasValue, but also returns true for empty arrays and objects.\r\n *\r\n * //   value - the value to check\r\n * // { boolean } - false if undefined, null, or '', otherwise true\r\n */\r\nexport function isEmpty(value) {\r\n  if (isArray(value)) { return !value.length; }\r\n  if (isObject(value)) { return !Object.keys(value).length; }\r\n  return value === undefined || value === null || value === '';\r\n}\r\n\r\n/**\r\n * 'isString' utility function\r\n *\r\n * Checks if a value is a string.\r\n *\r\n * //   value - the value to check\r\n * // { boolean } - true if string, false if not\r\n */\r\nexport function isString(value) {\r\n  return typeof value === 'string';\r\n}\r\n\r\n/**\r\n * 'isNumber' utility function\r\n *\r\n * Checks if a value is a regular number, numeric string, or JavaScript Date.\r\n *\r\n * //   value - the value to check\r\n * //  { any = false } strict - if truthy, also checks JavaScript tyoe\r\n * // { boolean } - true if number, false if not\r\n */\r\nexport function isNumber(value, strict: any = false) {\r\n  if (strict && typeof value !== 'number') { return false; }\r\n  return !isNaN(value) && value !== value / 0;\r\n}\r\n\r\n/**\r\n * 'isInteger' utility function\r\n *\r\n * Checks if a value is an integer.\r\n *\r\n * //   value - the value to check\r\n * //  { any = false } strict - if truthy, also checks JavaScript tyoe\r\n * // {boolean } - true if number, false if not\r\n */\r\nexport function isInteger(value, strict: any = false) {\r\n  if (strict && typeof value !== 'number') { return false; }\r\n  return !isNaN(value) &&  value !== value / 0 && value % 1 === 0;\r\n}\r\n\r\n/**\r\n * 'isBoolean' utility function\r\n *\r\n * Checks if a value is a boolean.\r\n *\r\n * //   value - the value to check\r\n * //  { any = null } option - if 'strict', also checks JavaScript type\r\n *                              if TRUE or FALSE, checks only for that value\r\n * // { boolean } - true if boolean, false if not\r\n */\r\nexport function isBoolean(value, option: any = null) {\r\n  if (option === 'strict') { return value === true || value === false; }\r\n  if (option === true) {\r\n    return value === true || value === 1 || value === 'true' || value === '1';\r\n  }\r\n  if (option === false) {\r\n    return value === false || value === 0 || value === 'false' || value === '0';\r\n  }\r\n  return value === true || value === 1 || value === 'true' || value === '1' ||\r\n    value === false || value === 0 || value === 'false' || value === '0';\r\n}\r\n\r\nexport function isFunction(item: any): boolean {\r\n  return typeof item === 'function';\r\n}\r\n\r\nexport function isObject(item: any): boolean {\r\n  return item !== null && typeof item === 'object';\r\n}\r\n\r\nexport function isArray(item: any): boolean {\r\n  return Array.isArray(item);\r\n}\r\n\r\nexport function isDate(item: any): boolean {\r\n  return !!item && Object.prototype.toString.call(item) === '[object Date]';\r\n}\r\n\r\nexport function isMap(item: any): boolean {\r\n  return !!item && Object.prototype.toString.call(item) === '[object Map]';\r\n}\r\n\r\nexport function isSet(item: any): boolean {\r\n  return !!item && Object.prototype.toString.call(item) === '[object Set]';\r\n}\r\n\r\nexport function isSymbol(item: any): boolean {\r\n  return typeof item === 'symbol';\r\n}\r\n\r\n/**\r\n * 'getType' function\r\n *\r\n * Detects the JSON Schema Type of a value.\r\n * By default, detects numbers and integers even if formatted as strings.\r\n * (So all integers are also numbers, and any number may also be a string.)\r\n * However, it only detects true boolean values (to detect boolean values\r\n * in non-boolean formats, use isBoolean() instead).\r\n *\r\n * If passed a second optional parameter of 'strict', it will only detect\r\n * numbers and integers if they are formatted as JavaScript numbers.\r\n *\r\n * Examples:\r\n * getType('10.5') = 'number'\r\n * getType(10.5) = 'number'\r\n * getType('10') = 'integer'\r\n * getType(10) = 'integer'\r\n * getType('true') = 'string'\r\n * getType(true) = 'boolean'\r\n * getType(null) = 'null'\r\n * getType({ }) = 'object'\r\n * getType([]) = 'array'\r\n *\r\n * getType('10.5', 'strict') = 'string'\r\n * getType(10.5, 'strict') = 'number'\r\n * getType('10', 'strict') = 'string'\r\n * getType(10, 'strict') = 'integer'\r\n * getType('true', 'strict') = 'string'\r\n * getType(true, 'strict') = 'boolean'\r\n *\r\n * //   value - value to check\r\n * //  { any = false } strict - if truthy, also checks JavaScript tyoe\r\n * // { SchemaType }\r\n */\r\nexport function getType(value, strict: any = false) {\r\n  if (!isDefined(value)) { return 'null'; }\r\n  if (isArray(value)) { return 'array'; }\r\n  if (isObject(value)) { return 'object'; }\r\n  if (isBoolean(value, 'strict')) { return 'boolean'; }\r\n  if (isInteger(value, strict)) { return 'integer'; }\r\n  if (isNumber(value, strict)) { return 'number'; }\r\n  if (isString(value) || (!strict && isDate(value))) { return 'string'; }\r\n  return null;\r\n}\r\n\r\n/**\r\n * 'isType' function\r\n *\r\n * Checks wether an input (probably string) value contains data of\r\n * a specified JSON Schema type\r\n *\r\n * //  { PrimitiveValue } value - value to check\r\n * //  { SchemaPrimitiveType } type - type to check\r\n * // { boolean }\r\n */\r\nexport function isType(value, type) {\r\n  switch (type) {\r\n    case 'string':\r\n      return isString(value) || isDate(value);\r\n    case 'number':\r\n      return isNumber(value);\r\n    case 'integer':\r\n      return isInteger(value);\r\n    case 'boolean':\r\n      return isBoolean(value);\r\n    case 'null':\r\n      return !hasValue(value);\r\n    default:\r\n      console.error(`isType error: \"${type}\" is not a recognized type.`);\r\n      return null;\r\n  }\r\n}\r\n\r\n/**\r\n * 'isPrimitive' function\r\n *\r\n * Checks wether an input value is a JavaScript primitive type:\r\n * string, number, boolean, or null.\r\n *\r\n * //   value - value to check\r\n * // { boolean }\r\n */\r\nexport function isPrimitive(value) {\r\n  return (isString(value) || isNumber(value) ||\r\n    isBoolean(value, 'strict') || value === null);\r\n}\r\n\r\n/**\r\n * \r\n * @param date \r\n * @returns {string}\r\n * exmaple:\r\n * toDateString('2018-01-01') = '2018-01-01'\r\n * toDateString('2018-01-30T00:00:00.000Z') = '2018-01-30'\r\n */\r\nexport const toIsoString = (date: Date) => {\r\n  const day = date.getDate();\r\n  const month = date.getMonth() + 1;\r\n  const year = date.getFullYear();\r\n  return `${year}-${month < 10 ? '0' + month : month}-${day < 10 ? '0' + day : day}`;\r\n}\r\n\r\n/**\r\n * 'toJavaScriptType' function\r\n *\r\n * Converts an input (probably string) value to a JavaScript primitive type -\r\n * 'string', 'number', 'boolean', or 'null' - before storing in a JSON object.\r\n *\r\n * Does not coerce values (other than null), and only converts the types\r\n * of values that would otherwise be valid.\r\n *\r\n * If the optional third parameter 'strictIntegers' is TRUE, and the\r\n * JSON Schema type 'integer' is specified, it also verifies the input value\r\n * is an integer and, if it is, returns it as a JaveScript number.\r\n * If 'strictIntegers' is FALSE (or not set) the type 'integer' is treated\r\n * exactly the same as 'number', and allows decimals.\r\n *\r\n * Valid Examples:\r\n * toJavaScriptType('10',   'number' ) = 10   // '10'   is a number\r\n * toJavaScriptType('10',   'integer') = 10   // '10'   is also an integer\r\n * toJavaScriptType( 10,    'integer') = 10   //  10    is still an integer\r\n * toJavaScriptType( 10,    'string' ) = '10' //  10    can be made into a string\r\n * toJavaScriptType('10.5', 'number' ) = 10.5 // '10.5' is a number\r\n *\r\n * Invalid Examples:\r\n * toJavaScriptType('10.5', 'integer') = null // '10.5' is not an integer\r\n * toJavaScriptType( 10.5,  'integer') = null //  10.5  is still not an integer\r\n *\r\n * //  { PrimitiveValue } value - value to convert\r\n * //  { SchemaPrimitiveType | SchemaPrimitiveType[] } types - types to convert to\r\n * //  { boolean = false } strictIntegers - if FALSE, treat integers as numbers\r\n * // { PrimitiveValue }\r\n */\r\nexport function toJavaScriptType(value, types, strictIntegers = true)  {\r\n  if (!isDefined(value)) { return null; }\r\n  if (isString(types)) { types = [types]; }\r\n  if (strictIntegers && inArray('integer', types)) {\r\n    if (isInteger(value, 'strict')) { return value; }\r\n    if (isInteger(value)) { return parseInt(value, 10); }\r\n  }\r\n  if (inArray('number', types) || (!strictIntegers && inArray('integer', types))) {\r\n    if (isNumber(value, 'strict')) { return value; }\r\n    if (isNumber(value)) { return parseFloat(value); }\r\n  }\r\n  if (inArray('string', types)) {\r\n    if (isString(value)) { return value; }\r\n    // If value is a date, and types includes 'string',\r\n    // convert the date to a string\r\n    if (isDate(value)) { return toIsoString(value); }\r\n    if (isNumber(value)) { return value.toString(); }\r\n  }\r\n  // If value is a date, and types includes 'integer' or 'number',\r\n  // but not 'string', convert the date to a number\r\n  if (isDate(value) && (inArray('integer', types) || inArray('number', types))) {\r\n    return value.getTime();\r\n  }\r\n  if (inArray('boolean', types)) {\r\n    if (isBoolean(value, true)) { return true; }\r\n    if (isBoolean(value, false)) { return false; }\r\n  }\r\n  return null;\r\n}\r\n\r\n/**\r\n * 'toSchemaType' function\r\n *\r\n * Converts an input (probably string) value to the \"best\" JavaScript\r\n * equivalent available from an allowed list of JSON Schema types, which may\r\n * contain 'string', 'number', 'integer', 'boolean', and/or 'null'.\r\n * If necssary, it does progressively agressive type coersion.\r\n * It will not return null unless null is in the list of allowed types.\r\n *\r\n * Number conversion examples:\r\n * toSchemaType('10', ['number','integer','string']) = 10 // integer\r\n * toSchemaType('10', ['number','string']) = 10 // number\r\n * toSchemaType('10', ['string']) = '10' // string\r\n * toSchemaType('10.5', ['number','integer','string']) = 10.5 // number\r\n * toSchemaType('10.5', ['integer','string']) = '10.5' // string\r\n * toSchemaType('10.5', ['integer']) = 10 // integer\r\n * toSchemaType(10.5, ['null','boolean','string']) = '10.5' // string\r\n * toSchemaType(10.5, ['null','boolean']) = true // boolean\r\n *\r\n * String conversion examples:\r\n * toSchemaType('1.5x', ['boolean','number','integer','string']) = '1.5x' // string\r\n * toSchemaType('1.5x', ['boolean','number','integer']) = '1.5' // number\r\n * toSchemaType('1.5x', ['boolean','integer']) = '1' // integer\r\n * toSchemaType('1.5x', ['boolean']) = true // boolean\r\n * toSchemaType('xyz', ['number','integer','boolean','null']) = true // boolean\r\n * toSchemaType('xyz', ['number','integer','null']) = null // null\r\n * toSchemaType('xyz', ['number','integer']) = 0 // number\r\n *\r\n * Boolean conversion examples:\r\n * toSchemaType('1', ['integer','number','string','boolean']) = 1 // integer\r\n * toSchemaType('1', ['number','string','boolean']) = 1 // number\r\n * toSchemaType('1', ['string','boolean']) = '1' // string\r\n * toSchemaType('1', ['boolean']) = true // boolean\r\n * toSchemaType('true', ['number','string','boolean']) = 'true' // string\r\n * toSchemaType('true', ['boolean']) = true // boolean\r\n * toSchemaType('true', ['number']) = 0 // number\r\n * toSchemaType(true, ['number','string','boolean']) = true // boolean\r\n * toSchemaType(true, ['number','string']) = 'true' // string\r\n * toSchemaType(true, ['number']) = 1 // number\r\n *\r\n * //  { PrimitiveValue } value - value to convert\r\n * //  { SchemaPrimitiveType | SchemaPrimitiveType[] } types - allowed types to convert to\r\n * // { PrimitiveValue }\r\n */\r\nexport function toSchemaType(value, types) {\r\n  if (!isArray(<SchemaPrimitiveType>types)) {\r\n    types = <SchemaPrimitiveType[]>[types];\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('null') && !hasValue(value)) {\r\n    return null;\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('boolean') && !isBoolean(value, 'strict')) {\r\n    return value;\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('integer')) {\r\n    const testValue = toJavaScriptType(value, 'integer');\r\n    if (testValue !== null) { return +testValue; }\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('number')) {\r\n    const testValue = toJavaScriptType(value, 'number');\r\n    if (testValue !== null) { return +testValue; }\r\n  }\r\n  if (\r\n    (isString(value) || isNumber(value, 'strict')) &&\r\n    (<SchemaPrimitiveType[]>types).includes('string')\r\n  ) { // Convert number to string\r\n    return toJavaScriptType(value, 'string');\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('boolean') && isBoolean(value)) {\r\n    return toJavaScriptType(value, 'boolean');\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('string')) { // Convert null & boolean to string\r\n    if (value === null) { return ''; }\r\n    const testValue = toJavaScriptType(value, 'string');\r\n    if (testValue !== null) { return testValue; }\r\n  }\r\n  if ((\r\n    (<SchemaPrimitiveType[]>types).includes('number') ||\r\n    (<SchemaPrimitiveType[]>types).includes('integer'))\r\n  ) {\r\n    if (value === true) { return 1; } // Convert boolean & null to number\r\n    if (value === false || value === null || value === '') { return 0; }\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('number')) { // Convert mixed string to number\r\n    const testValue = parseFloat(<string>value);\r\n    if (!!testValue) { return testValue; }\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('integer')) { // Convert string or number to integer\r\n    const testValue = parseInt(<string>value, 10);\r\n    if (!!testValue) { return testValue; }\r\n  }\r\n  if ((<SchemaPrimitiveType[]>types).includes('boolean')) { // Convert anything to boolean\r\n    return !!value;\r\n  }\r\n  if ((\r\n      (<SchemaPrimitiveType[]>types).includes('number') ||\r\n      (<SchemaPrimitiveType[]>types).includes('integer')\r\n    ) && !(<SchemaPrimitiveType[]>types).includes('null')\r\n  ) {\r\n    return 0; // If null not allowed, return 0 for non-convertable values\r\n  }\r\n}\r\n\r\n/**\r\n * 'isPromise' function\r\n *\r\n * //   object\r\n * // { boolean }\r\n */\r\nexport function isPromise(object): object is Promise<any> {\r\n  return !!object && typeof object.then === 'function';\r\n}\r\n\r\n/**\r\n * 'isObservable' function\r\n *\r\n * //   object\r\n * // { boolean }\r\n */\r\nexport function isObservable(object): object is Observable<any> {\r\n  return !!object && typeof object.subscribe === 'function';\r\n}\r\n\r\n/**\r\n * '_toPromise' function\r\n *\r\n * //  { object } object\r\n * // { Promise<any> }\r\n */\r\nexport function _toPromise(object): Promise<any> {\r\n  return isPromise(object) ? object : object.toPromise();\r\n}\r\n\r\n/**\r\n * 'toObservable' function\r\n *\r\n * //  { object } object\r\n * // { Observable<any> }\r\n */\r\nexport function toObservable(object): Observable<any> {\r\n  const observable = isPromise(object) ? from(object) : object;\r\n  if (isObservable(observable)) { return observable; }\r\n  console.error('toObservable error: Expected validator to return Promise or Observable.');\r\n  return new Observable();\r\n}\r\n\r\n/**\r\n * 'inArray' function\r\n *\r\n * Searches an array for an item, or one of a list of items, and returns true\r\n * as soon as a match is found, or false if no match.\r\n *\r\n * If the optional third parameter allIn is set to TRUE, and the item to find\r\n * is an array, then the function returns true only if all elements from item\r\n * are found in the array list, and false if any element is not found. If the\r\n * item to find is not an array, setting allIn to TRUE has no effect.\r\n *\r\n * //  { any|any[] } item - the item to search for\r\n * //   array - the array to search\r\n * //  { boolean = false } allIn - if TRUE, all items must be in array\r\n * // { boolean } - true if item(s) in array, false otherwise\r\n */\r\nexport function inArray(item, array, allIn = false) {\r\n  if (!isDefined(item) || !isArray(array)) { return false; }\r\n  return isArray(item) ?\r\n    item[allIn ? 'every' : 'some'](subItem => array.includes(subItem)) :\r\n    array.includes(item);\r\n}\r\n\r\n/**\r\n * 'xor' utility function - exclusive or\r\n *\r\n * Returns true if exactly one of two values is truthy.\r\n *\r\n * //   value1 - first value to check\r\n * //   value2 - second value to check\r\n * // { boolean } - true if exactly one input value is truthy, false if not\r\n */\r\nexport function xor(value1, value2) {\r\n  return (!!value1 && !value2) || (!value1 && !!value2);\r\n}\r\n"]}