intelicoreact 2.0.6 → 2.0.8

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 (130) hide show
  1. package/charts/package.json +5 -0
  2. package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.interface.d.ts +23 -3
  3. package/dist/Atomic/FormElements/Input/Input.d.ts +1 -1
  4. package/dist/Atomic/FormElements/Input/types.d.ts +0 -5
  5. package/dist/Atomic/FormElements/InputMask3/InputMask3.interface.d.ts +0 -3
  6. package/dist/Atomic/FormElements/TagListToDropdown/TagListToDropdown.interface.d.ts +1 -1
  7. package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.interface.d.ts +4 -4
  8. package/dist/Atomic/UI/Alert/Alert.interface.d.ts +0 -2
  9. package/dist/Functions/sdk/runtime-sdk/transport.d.ts +2 -2
  10. package/dist/charts.cjs +927 -0
  11. package/dist/charts.cjs.map +7 -0
  12. package/dist/charts.d.ts +7 -0
  13. package/dist/charts.js +911 -0
  14. package/dist/charts.js.map +7 -0
  15. package/dist/form.cjs +1506 -1940
  16. package/dist/form.cjs.map +4 -4
  17. package/dist/form.js +1122 -1556
  18. package/dist/form.js.map +4 -4
  19. package/dist/hooks.cjs +8 -324
  20. package/dist/hooks.cjs.map +4 -4
  21. package/dist/hooks.js +8 -324
  22. package/dist/hooks.js.map +4 -4
  23. package/dist/index.cjs +2515 -9300
  24. package/dist/index.cjs.map +4 -4
  25. package/dist/index.js +2067 -8868
  26. package/dist/index.js.map +4 -4
  27. package/dist/layout.cjs +207 -6308
  28. package/dist/layout.cjs.map +4 -4
  29. package/dist/layout.js +202 -6303
  30. package/dist/layout.js.map +4 -4
  31. package/dist/presets.cjs +0 -643
  32. package/dist/presets.cjs.map +4 -4
  33. package/dist/presets.js +0 -633
  34. package/dist/presets.js.map +4 -4
  35. package/dist/ui.cjs +711 -7854
  36. package/dist/ui.cjs.map +4 -4
  37. package/dist/ui.d.ts +0 -5
  38. package/dist/ui.js +722 -7881
  39. package/dist/ui.js.map +4 -4
  40. package/dist/utils.cjs +4 -51
  41. package/dist/utils.cjs.map +3 -3
  42. package/dist/utils.js +4 -51
  43. package/dist/utils.js.map +3 -3
  44. package/package.json +16 -2
  45. package/dist/Atomic/FormElements/Dropdown/components/DropdownLoader.d.ts +0 -4
  46. package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN_old.d.ts +0 -11
  47. package/dist/Atomic/FormElements/NumericInput/NumericInput.d.ts +0 -36
  48. package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.d.ts +0 -2
  49. package/dist/Atomic/FormElements/RangeSlider/RangeSlider.d.ts +0 -19
  50. package/dist/Atomic/FormElements/SwitcherTagsDropdown/partial/States.d.ts +0 -5
  51. package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.d.ts +0 -17
  52. package/dist/Atomic/FormElements/VariantsListRadio/partials/VariantsListRadioItem.d.ts +0 -12
  53. package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.d.ts +0 -2
  54. package/dist/Atomic/FormElements/WidgetPseudoTable/partial/constructor.d.ts +0 -23
  55. package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.d.ts +0 -2
  56. package/dist/Atomic/FormElements/WidgetWithSwitchableRows/partial/constructor.d.ts +0 -38
  57. package/dist/Atomic/UI/AccordionTable/AccordionTable.d.ts +0 -10
  58. package/dist/Atomic/UI/AccordionText/AccordionText.d.ts +0 -8
  59. package/dist/Atomic/UI/Chart/partial/Chart.constants.d.ts +0 -78
  60. package/dist/Atomic/UI/Chart/partial/datasetSetters.d.ts +0 -13
  61. package/dist/Atomic/UI/Chart/partial/optionsConstructor.d.ts +0 -145
  62. package/dist/Atomic/UI/Chart/partial/optionsSetters.d.ts +0 -4
  63. package/dist/Atomic/UI/CircleProgressBar/CircleProgressBar.d.ts +0 -14
  64. package/dist/Atomic/UI/DynamicIcon/DynamicIcon.d.ts +0 -4
  65. package/dist/Atomic/UI/DynamicIcon/DynamicIcon.interface.d.ts +0 -6
  66. package/dist/Atomic/UI/DynamicIcon/index.d.ts +0 -3
  67. package/dist/Atomic/UI/ExampleChartIntegration/ExampleChartIntegration.d.ts +0 -2
  68. package/dist/Atomic/UI/ExampleChartIntegration/partial/utils.d.ts +0 -4
  69. package/dist/Atomic/UI/MonoAccordion/MonoAccordion._test.d.ts +0 -1
  70. package/dist/Atomic/UI/MonoAccordion/MonoAccordion.d.ts +0 -12
  71. package/dist/Atomic/UI/PieChart/PieChart.d.ts +0 -8
  72. package/dist/Atomic/UI/Table/Partials/TdCell.d.ts +0 -13
  73. package/dist/Atomic/UI/Table/Partials/TdHeader.d.ts +0 -5
  74. package/dist/Atomic/UI/Table/Partials/TdRow.d.ts +0 -17
  75. package/dist/Atomic/UI/Table/Partials/TdTitle.d.ts +0 -5
  76. package/dist/Atomic/UI/Table/Table.d.ts +0 -9
  77. package/dist/Atomic/UI/Table/TdTypes/TdActions.d.ts +0 -6
  78. package/dist/Atomic/UI/Table/TdTypes/TdPriority.d.ts +0 -6
  79. package/dist/Atomic/UI/Table/TdTypes/TdRange.d.ts +0 -4
  80. package/dist/Atomic/UI/Table/TdTypes/TdWeight.d.ts +0 -7
  81. package/dist/Atomic/UI/WizardStepper/constructor.d.ts +0 -51
  82. package/dist/Classes/AbortableFetch.d.ts +0 -43
  83. package/dist/Classes/AnimatedHandler.d.ts +0 -4
  84. package/dist/Classes/RESTAPI/index.d.ts +0 -9
  85. package/dist/Classes/RESTAPI/partials/AbortableFetch.d.ts +0 -43
  86. package/dist/Classes/RESTAPI/partials/ApiBase.d.ts +0 -10
  87. package/dist/Classes/RESTAPI/partials/ApiRequestCreators.d.ts +0 -9
  88. package/dist/Classes/RESTAPI/partials/ApiUtils.d.ts +0 -12
  89. package/dist/Classes/RESTAPI/partials/CredentialsProcessing.d.ts +0 -24
  90. package/dist/Classes/RESTAPI/partials/Utils.d.ts +0 -4
  91. package/dist/Classes/RESTAPI/partials/_utils.d.ts +0 -9
  92. package/dist/Constants/index.constants.d.ts +0 -20
  93. package/dist/Functions/Portal.d.ts +0 -6
  94. package/dist/Functions/customEventListener.d.ts +0 -27
  95. package/dist/Functions/dateTime.d.ts +0 -95
  96. package/dist/Functions/fieldValueFormatters.d.ts +0 -19
  97. package/dist/Functions/hooks/useFormFieldsChangesManager.d.ts +0 -15
  98. package/dist/Functions/locale/createTranslator.d.ts +0 -3
  99. package/dist/Functions/operations.d.ts +0 -1
  100. package/dist/Functions/presets/inputMaskPresets.d.ts +0 -136
  101. package/dist/Functions/presets/inputPresets.d.ts +0 -16
  102. package/dist/Functions/presets/mobileKeyboardTypesPresets.d.ts +0 -17
  103. package/dist/Functions/schemas.d.ts +0 -3
  104. package/dist/Functions/useBodyScrollLock.d.ts +0 -2
  105. package/dist/Functions/useClickOutside.d.ts +0 -1
  106. package/dist/Functions/useDebounce.d.ts +0 -4
  107. package/dist/Functions/useFieldFocus.d.ts +0 -7
  108. package/dist/Functions/useFormTools/form-drivers/ArrayWithObjects.d.ts +0 -15
  109. package/dist/Functions/useFormTools/form-drivers/ObjectWithIterableObjects.d.ts +0 -12
  110. package/dist/Functions/useFormTools/form-drivers/ObjectWithNamedKeyObjects.d.ts +0 -15
  111. package/dist/Functions/useFormTools/functions/General.d.ts +0 -15
  112. package/dist/Functions/useFormTools/functions/RenderFields.d.ts +0 -7
  113. package/dist/Functions/useFormTools/functions/usePrevious.d.ts +0 -2
  114. package/dist/Functions/useFormTools/index.d.ts +0 -86
  115. package/dist/Functions/useInputHighlightError.d.ts +0 -12
  116. package/dist/Functions/useLocalStorage.d.ts +0 -2
  117. package/dist/Functions/useLocationParams.d.ts +0 -1
  118. package/dist/Functions/useMediaQuery.d.ts +0 -2
  119. package/dist/Functions/useMetaInfo.d.ts +0 -8
  120. package/dist/Functions/useMouseUpOutside.d.ts +0 -1
  121. package/dist/Functions/useOnlineStatus.d.ts +0 -2
  122. package/dist/Functions/usePasswordChecker.d.ts +0 -7
  123. package/dist/Functions/usePrevious.d.ts +0 -2
  124. package/dist/Functions/useResize.d.ts +0 -3
  125. package/dist/Functions/useScrollTo.d.ts +0 -2
  126. package/dist/Functions/useToggle.d.ts +0 -7
  127. package/dist/Functions/utils.d.ts +0 -40
  128. package/dist/Langs.d.ts +0 -179
  129. package/dist/Molecular/FormWithDependOn/FormWithDependOn.d.ts +0 -3
  130. package/dist/Molecular/FormWithDependOn/partials/_utils.d.ts +0 -8
package/dist/presets.js CHANGED
@@ -148,641 +148,8 @@ var MASK_PRESETS = {
148
148
  ABA_PRESET
149
149
  };
150
150
 
151
- // src/Constants/index.constants.js
152
- var KEYBOARD_SERVICE_KEYS = [
153
- "Escape",
154
- "F1",
155
- "F2",
156
- "F3",
157
- "F4",
158
- "F5",
159
- "F6",
160
- "F7",
161
- "F8",
162
- "F9",
163
- "F10",
164
- "F11",
165
- "F12",
166
- "Tab",
167
- "CapsLock",
168
- "Shift",
169
- "Control",
170
- "Meta",
171
- "Option",
172
- "Alt",
173
- "ContextMenu",
174
- "ArrowLeft",
175
- "ArrowRight",
176
- "ArrowUp",
177
- "ArrowDown",
178
- "NumLock",
179
- "Backspace",
180
- "Delete",
181
- "Enter",
182
- "Return",
183
- "Insert",
184
- "Home",
185
- "End",
186
- "PageUp",
187
- "PageDown",
188
- "PrintScreen",
189
- "ScrollLock",
190
- "Pause"
191
- ];
192
- var MAX_PHONE_LENGTH = 10;
193
- var MAX_NAME_LENGTH = 128;
194
- var DEFAULT_DATE_MASK_NO_VALUE_SYMBOL = "_";
195
- var DEFAULT_COLORS = [
196
- "#D9C1FF",
197
- "#FFBAF0",
198
- "#FFB8CE",
199
- "#FFC3A2",
200
- "#FFDB7C",
201
- "#F9F871",
202
- "#C3FCF1",
203
- "#F6F2CB",
204
- "#E0F8D1",
205
- "#B1DFFB",
206
- "#8DECFE",
207
- "#76F7ED",
208
- "#8AFEC8"
209
- ];
210
- var KEYBOARD_KEY_CODES = {
211
- Backspace: 8,
212
- Delete: 46,
213
- ARROW_LEFT: 37,
214
- ARROW_RIGHT: 39
215
- };
216
- var OS = {
217
- iOS: "iOS",
218
- Android: "Android",
219
- WP: "Windows Phone",
220
- Linux: "Linux",
221
- Windows: "Windows",
222
- MacOS: "MacOS",
223
- Unknown: "unknown"
224
- };
225
-
226
- // src/Functions/utils.js
227
- import { useEffect } from "react";
228
- import moment from "moment-timezone";
229
- var uuid = () => Date.now().toString(36) + Math.random().toString(36).substring(2);
230
- var getIsOnlyAnObject = (input) => {
231
- return typeof input === "object" && // "отбивает" примитивы и функции
232
- input instanceof Object && // "отбивает" null
233
- !Array.isArray(input) && // "отбивает" массивы
234
- !(input instanceof Set) && // "отбивает" сеты
235
- !(input instanceof Map);
236
- };
237
- var handleObjectChange = (updateObject, updateFunction) => (data, prop = "", isNumber) => {
238
- let value;
239
- if (data?.target) {
240
- value = data.target.type === "checkbox" ? data.target.checked : data.target.value;
241
- } else value = data;
242
- value = isNumber ? Number(value) : value;
243
- const props = prop.split(".");
244
- const currentObject = props.reduce((res, chapter, index) => {
245
- if (props.length !== index + 1) res = res[chapter];
246
- return res;
247
- }, updateObject);
248
- currentObject[props.pop()] = value;
249
- updateFunction();
250
- };
251
- var useOutsideToggle = (ref, setOut, open) => {
252
- function handleClickOutside(event) {
253
- if (ref.current && !ref.current.contains(event.target)) {
254
- setOut(open);
255
- }
256
- }
257
- useEffect(() => {
258
- document.addEventListener("mouseup", handleClickOutside);
259
- return () => {
260
- document.removeEventListener("mouseup", handleClickOutside);
261
- };
262
- }, [ref]);
263
- };
264
- var clone = (input) => {
265
- if (input === null || typeof input !== "object") return input;
266
- const data = input instanceof Array ? [] : {};
267
- for (const i in input) data[i] = clone(input[i]);
268
- return data;
269
- };
270
- var getResponseClone = async (res) => await (typeof res?.clone === "function" ? res.clone() : clone(res));
271
- function transformUTCTimeToLocal(date, format = "YYYY-MM-DD HH:mm:ss") {
272
- if (!date) return;
273
- const utcDate = moment.utc(date).toDate();
274
- return moment(utcDate, format).local().format(format);
275
- }
276
- function transformLocalTimeToUTC(date, format = "YYYY-MM-DD HH:mm:ss") {
277
- if (!date) return;
278
- return moment(date, format).utc().format(format);
279
- }
280
- function transformUTCHoursToLocal(time, format = "HH:mm:ss") {
281
- if (!time) return;
282
- const splitedTime = time.split(":");
283
- const offset = moment().utcOffset();
284
- let HH = Number(splitedTime[0]);
285
- let mm = Number(splitedTime[1]);
286
- const ss = splitedTime[2];
287
- mm = mm + offset;
288
- while (mm > 59) {
289
- mm -= 60;
290
- HH += 1;
291
- }
292
- if (HH > 23) HH -= 24;
293
- while (mm < 0) {
294
- mm += 60;
295
- HH -= 1;
296
- }
297
- if (HH < 0) HH += 24;
298
- return `${HH}:${mm}:${ss}`;
299
- }
300
- function transformDateOrTimeOrTogetherToFormat(data, outputFormat = "HH:mm", additional) {
301
- const ERROR_VALUE = "Invalid date";
302
- const ERROR_MESSGE = `Invalid input data for ${outputFormat} format`;
303
- const { parseFormat, isReturnAsMomentInstance } = getIsOnlyAnObject(
304
- additional
305
- ) ? additional : {};
306
- if (typeof data !== "string" && typeof data !== "number") {
307
- return isReturnAsMomentInstance ? moment("error") : ERROR_MESSGE;
308
- }
309
- const momentArgs = [
310
- data,
311
- ...!Number.isNaN(Number(data)) || typeof parseFormat === "string" ? [] : [parseFormat]
312
- ];
313
- const momentInstance = (() => {
314
- let instance = moment(...momentArgs);
315
- if (instance.format(outputFormat) !== ERROR_VALUE) return instance;
316
- else if (/^\d\d.\d\d/.test(data)) {
317
- instance = moment();
318
- const symbols = data.split("");
319
- const timeArr = symbols.reduce(
320
- (acc, symbol, idx) => {
321
- if (Number.isNaN(Number(symbol))) {
322
- if (acc.group) acc.result.push(acc.group);
323
- acc.group = "";
324
- } else acc.group = `${acc.group}${symbol}`;
325
- if (idx === symbols.length - 1 && acc.group)
326
- acc.result.push(acc.group);
327
- return acc;
328
- },
329
- { result: [], group: "" }
330
- ).result.reverse();
331
- instance.hours(Number(timeArr.pop()));
332
- instance.minutes(Number(timeArr.pop()));
333
- instance.seconds(timeArr.length ? Number(timeArr.pop()) : 0);
334
- instance.milliseconds(timeArr.length ? Number(timeArr.pop()) : 0);
335
- } else instance = moment("error");
336
- return instance;
337
- })();
338
- if (isReturnAsMomentInstance) return momentInstance;
339
- const output = momentInstance.format(outputFormat);
340
- return output === ERROR_VALUE ? ERROR_MESSGE : output;
341
- }
342
- function transformDateOrTimeOrTogetherToFormattedLocal(data, outputFormat = "HH:mm", additional) {
343
- const ERROR_VALUE = "Invalid date";
344
- const ERROR_MESSGE = `Invalid input data for ${outputFormat} format`;
345
- if (additional && !getIsOnlyAnObject(additional)) {
346
- throw new Error(
347
- "Bad additional [transformDateOrTimeOrTogetherToFormattedLocal]"
348
- );
349
- }
350
- const compositeAdditional = {
351
- ...additional || {},
352
- isReturnAsMomentInstance: true
353
- };
354
- const date = transformDateOrTimeOrTogetherToFormat(
355
- data,
356
- outputFormat,
357
- compositeAdditional
358
- );
359
- const dateWithLocale = date.add(moment().utcOffset(), "minutes");
360
- const output = dateWithLocale.format(outputFormat);
361
- return output === ERROR_VALUE ? ERROR_MESSGE : output;
362
- }
363
- var omitKeys = (obj = {}, keys = []) => keys.reduce((acc, key) => {
364
- const { [key]: omit, ...rest } = acc;
365
- return rest;
366
- }, obj);
367
- var logout = () => {
368
- window.localStorage.removeItem("accessToken");
369
- window.localStorage.removeItem("tokenExpires");
370
- window.location.reload();
371
- };
372
- var getStyles = (el, prop) => {
373
- if (!el) return null;
374
- if (!prop) return window.getComputedStyle(el);
375
- return window.getComputedStyle(el).getPropertyValue(prop);
376
- };
377
- var getColorById = (id, colors) => {
378
- if (!id) return "#FF7D00";
379
- const idToArr = Array.from(id);
380
- const colorsArr = colors && colors.length > 0 ? colors : DEFAULT_COLORS;
381
- let number = idToArr.reduce((acc, item) => {
382
- if (Number(item)) {
383
- return acc + Number(item);
384
- }
385
- return acc;
386
- }, 0);
387
- while (number >= colorsArr.length) {
388
- number -= colorsArr.length;
389
- }
390
- return colorsArr[number];
391
- };
392
- var debounce = (fn, ms) => {
393
- let id = null;
394
- return (...args) => {
395
- clearTimeout(id);
396
- id = setTimeout(() => {
397
- clearTimeout(id);
398
- fn(...args);
399
- }, ms);
400
- };
401
- };
402
- var throttle = (fn, ms) => {
403
- let id = null;
404
- return (...args) => {
405
- if (id) return;
406
- fn(...args);
407
- id = setTimeout(() => {
408
- clearTimeout(id);
409
- id = null;
410
- }, ms);
411
- };
412
- };
413
- var addBitDepthPoints = (value, step = 3) => {
414
- const isFraction = value?.includes(".");
415
- const valueBeforeDot = isFraction ? value?.slice(0, value?.indexOf(".")) : value;
416
- const intPart = valueBeforeDot.split("").reverse().reduce(
417
- (acc, item, idx) => idx % step === 0 && idx !== 0 ? [...acc, ",", item] : [...acc, item],
418
- []
419
- ).reverse().join("");
420
- return isFraction ? intPart + value?.slice(value?.indexOf(".")) : intPart;
421
- };
422
- var changeMeta = (key, items = []) => {
423
- const defaultMeta = items.find((i) => i.key === "default");
424
- if (key) {
425
- const item = items.find((i) => i.key === key);
426
- document.title = item?.title ?? defaultMeta?.title;
427
- document.querySelector('meta[name="description"]').setAttribute("content", item?.description ?? defaultMeta?.description);
428
- }
429
- };
430
- var firstLetterCapital = (str) => typeof str === "string" ? `${str.charAt(0).toUpperCase()}${str.slice(1)}` : str;
431
- var capitalized = firstLetterCapital;
432
- var checkedRef = (ref) => ref ? typeof ref === "function" ? (node) => ref(node) : ref : null;
433
- function downloadEmulation(data, filename, type = "image/*") {
434
- const file = new Blob([data], { type });
435
- if (window.navigator.msSaveOrOpenBlob)
436
- window.navigator.msSaveOrOpenBlob(file, filename);
437
- else {
438
- const a = document.createElement("a"), url = URL.createObjectURL(file);
439
- a.href = url;
440
- a.download = filename;
441
- document.body.appendChild(a);
442
- a.click();
443
- setTimeout(() => {
444
- document.body.removeChild(a);
445
- window.URL.revokeObjectURL(url);
446
- }, 0);
447
- }
448
- }
449
- var downloadFile = async ({ url, name, type = null }) => {
450
- const response = await fetch(url).then(async (res) => ({
451
- data: await res.blob(),
452
- type: type ?? res.headers.get("content-type")
453
- }));
454
- downloadEmulation(response.data, name, response.type);
455
- };
456
- var compare = (first, second, keys = []) => {
457
- if (typeof first !== typeof second) return false;
458
- if (Array.isArray(first) !== Array.isArray(second)) return false;
459
- if (!(first instanceof Object)) return first === second;
460
- const getComparationStructure = (data) => {
461
- if (typeof data === "function") return data.toString();
462
- if (!(data instanceof Object)) return data;
463
- return Object.entries(data).sort((a, b) => a[0].localeCompare(b[0])).map(([key, value]) => [key, getComparationStructure(data[key])]);
464
- };
465
- const structureForComparingOfFirst = getComparationStructure(first);
466
- const structureForComparingOfSecond = getComparationStructure(second);
467
- return JSON.stringify(structureForComparingOfFirst) === JSON.stringify(structureForComparingOfSecond);
468
- };
469
- var setCarretToEnd = (input) => {
470
- setTimeout(() => {
471
- const tmp = input.value;
472
- input.value = "";
473
- input.value = tmp;
474
- }, 10);
475
- };
476
- var compareAlphabetical = (a, b, key = "label") => {
477
- let item1 = a?.[key];
478
- let item2 = b?.[key];
479
- if (typeof item1 !== "string" || typeof item2 !== "string") return 0;
480
- item1 = item1?.toLowerCase();
481
- item2 = item2?.toLowerCase();
482
- if (item1 < item2) {
483
- return -1;
484
- }
485
- if (item1 > item2) {
486
- return 1;
487
- }
488
- return 0;
489
- };
490
- var getBase64 = (file) => {
491
- if (file) {
492
- return new Promise(function(resolve, reject) {
493
- const reader = new FileReader();
494
- reader.readAsDataURL(file);
495
- reader.onload = () => resolve(reader.result);
496
- reader.onerror = (error) => reject("Error: ", error);
497
- });
498
- }
499
- };
500
- var renderFileSize = (bytes, decimals = 2) => {
501
- if (!Number(bytes)) return "0 Bytes";
502
- const k = 1024;
503
- const dm = decimals < 0 ? 0 : decimals;
504
- const sizes = ["Bytes", "KB", "MB", "GB"];
505
- const i = Math.floor(Math.log(bytes) / Math.log(k));
506
- return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`;
507
- };
508
- var getUniqueFileExtensions = (extListString) => {
509
- const extArray = extListString?.split(",").map((ext) => ext.trim().toUpperCase());
510
- const uniqueExts = [...new Set(extArray)];
511
- return uniqueExts.join(", ");
512
- };
513
- var getOS = () => {
514
- let userAgent = window.navigator.userAgent, platform = window.navigator?.userAgentData?.platform || window.navigator.platform, macosPlatforms = ["Macintosh", "MacIntel", "MacPPC", "Mac68K"], windowsPlatforms = ["Win32", "Win64", "Windows", "WinCE"], iosPlatforms = ["iPhone", "iPad", "iPod"], os = OS.Unknown;
515
- if (macosPlatforms.indexOf(platform) !== -1) {
516
- os = OS.MacOS;
517
- } else if (iosPlatforms.indexOf(platform) !== -1) {
518
- os = OS.iOS;
519
- } else if (windowsPlatforms.indexOf(platform) !== -1) {
520
- os = OS.Windows;
521
- } else if (/Android/.test(userAgent)) {
522
- os = OS.Android;
523
- } else if (/Linux/.test(platform)) {
524
- os = OS.Linux;
525
- }
526
- return os;
527
- };
528
- String.prototype.longerThan = function(compareWith) {
529
- return this?.length > compareWith?.length;
530
- };
531
- String.prototype.lastIndexEqualsTo = function(index) {
532
- return this?.length - 1 === index;
533
- };
534
- var getCorrectTestId = ({ testId = "", withTier = true }) => testId && testId !== void 0 ? `${withTier ? "-" : ""}${testId}` : "";
535
-
536
151
  // src/Functions/fieldValueFormatters.js
537
152
  var getSafelyValue = (value) => value !== void 0 && value !== null ? value?.toString?.() || "" : "";
538
- var intlNumbersFormatter = (inputValue, settings = {}) => {
539
- const safelyInputValue = getSafelyValue(inputValue);
540
- const previousValue = safelyInputValue.slice(0, -1);
541
- const lastSym = safelyInputValue.slice(-1);
542
- const value = lastSym === "." ? previousValue : safelyInputValue;
543
- if (Number.isNaN(Number(value)) || !getSafelyValue(value)) return "";
544
- const {
545
- // локаль, даже региональная, влияет на отображение знаков и формата.
546
- locale = "en-US",
547
- // percent || currency(default case) || decimal(просто число) влияет на ТИП обработки.
548
- withSymbol,
549
- //группировка запятыми поразрядно.
550
- useGrouping = true,
551
- //!!работает только при withSymbol: 'currency' !! влияет на то, как именно будет выглядет формат валюты.
552
- currency = {},
553
- //сколько знаков после точки, и всегда ли они будут.
554
- // !!если поставить isAlwaysRender: true, но не дать центов, то будет 100.00
555
- fractionDigits = {}
556
- } = settings;
557
- const { currencyType = "USD", currencyDisplay: inputCurrencyDisplay } = currency;
558
- let currencyDisplay;
559
- switch (inputCurrencyDisplay) {
560
- case "name":
561
- currencyDisplay = "name";
562
- break;
563
- case "code":
564
- currencyDisplay = "code";
565
- break;
566
- case "narrowSymbol":
567
- currencyDisplay = "narrowSymbol";
568
- break;
569
- default:
570
- currencyDisplay = "symbol";
571
- }
572
- let numberStyle;
573
- switch (withSymbol) {
574
- case "percent":
575
- numberStyle = "percent";
576
- break;
577
- case "currency":
578
- numberStyle = "currency";
579
- break;
580
- default:
581
- numberStyle = "decimal";
582
- break;
583
- }
584
- const {
585
- quantity,
586
- isRenderAlways = false,
587
- minimumFractionDigits: inputMinimumFractionDigits,
588
- maximumFractionDigits: inputMaximumFractionDigits,
589
- conditionallyMinimumFractionDigits
590
- } = fractionDigits;
591
- const dotIndex = safelyInputValue?.indexOf(".");
592
- const afterDot = dotIndex !== -1 ? safelyInputValue.slice(dotIndex + 1) : "";
593
- const minimumFractionDigits = (() => {
594
- if (typeof inputMinimumFractionDigits === "number")
595
- return inputMinimumFractionDigits;
596
- if (typeof conditionallyMinimumFractionDigits === "number") {
597
- return afterDot && lastSym !== "." ? conditionallyMinimumFractionDigits : 0;
598
- }
599
- return afterDot && lastSym !== "." ? safelyInputValue.slice(dotIndex).length - 1 : isRenderAlways ? quantity : 0;
600
- })();
601
- const priceSettings = {
602
- useGrouping,
603
- //группировка разрядов
604
- style: numberStyle,
605
- //тип форматирования (валюта или число). decimal - без знака валюты
606
- currency: currencyType,
607
- //валюта
608
- currencyDisplay,
609
- //валюта в виде символа
610
- //минимально не надо отображать центы, если их нет, иначе всегда будет .00
611
- minimumFractionDigits,
612
- //! Важно! Если придет велью с количеством дробных разрядов БОЛЬШИМ
613
- //! чем указано в (inputMaximumFractionDigits ?? quantity) - округлит по правилам округления
614
- //максимально отображать 2 цифры после запятой, если центы всё же есть
615
- maximumFractionDigits: inputMaximumFractionDigits ?? quantity
616
- };
617
- let output;
618
- try {
619
- output = new Intl.NumberFormat(locale, priceSettings).format(value);
620
- } catch (e) {
621
- output = value;
622
- console.warn("Intl.NumberFormat error", e);
623
- }
624
- return lastSym === "." ? output + lastSym : output;
625
- };
626
- var formatOnlyNumbers = (value) => getSafelyValue(value).replace(/\D/g, "");
627
- var formatToRemoveComa = (value) => getSafelyValue(value).replace(/,/g, "");
628
- var formatToAddBitDepthPoints = (value, settings) => intlNumbersFormatter(getSafelyValue(value), {
629
- fractionDigits: {
630
- quantity: settings?.type === "int" ? 0 : settings?.decimalPlaces
631
- }
632
- });
633
- var formatToPriceWithUSD = (value) => {
634
- if (isNaN(Number(value))) return value;
635
- return intlNumbersFormatter(getSafelyValue(value), {
636
- withSymbol: "currency",
637
- currency: { currencyType: "USD" },
638
- fractionDigits: { quantity: 2, conditionallyMinimumFractionDigits: 2 }
639
- });
640
- };
641
- var formatToPriceWithCurrency = (value, currencyCode, symbolPosition = "before") => {
642
- if (isNaN(Number(value))) return value;
643
- return intlNumbersFormatter(getSafelyValue(value), {
644
- withSymbol: "currency",
645
- currency: { currencyType: currencyCode },
646
- fractionDigits: { quantity: 2, conditionallyMinimumFractionDigits: 2 }
647
- });
648
- };
649
- var formatAsPercentage = (value, settings) => {
650
- const {
651
- isCommonPercentageSymbol = true,
652
- decimalPlaces = 2,
653
- beforeValueSymbol = "",
654
- afterValueSymbol = "",
655
- isGlueSameRangesTogether = false,
656
- // ? Тут удобный ф-л, поэтому иной раз удобно обработать обычный диапазан (НЕ проценты).
657
- // ? Добавил возможность выпиливать значек процентов.
658
- // todo(VL) - вообще правильно заренеймить (formatAsDiapason), а добавление процентов сделать как опцию,
659
- // todo(VL) - но как обычно нет времени, нужно будет перечекать по всем проектам где тянется со старым неймингом
660
- isUseAsSimpleDiapason = false
661
- } = getIsOnlyAnObject(settings) ? settings : {};
662
- let safelyInputValue;
663
- const checkValue = (value2) => getSafelyValue(value2) || "0";
664
- const transform = (valueAsSting) => {
665
- const processedValue = valueAsSting.replace(/,/g, ".");
666
- if (Number.isNaN(Number(processedValue))) return processedValue;
667
- return `${intlNumbersFormatter(getSafelyValue(Number(processedValue)), {
668
- fractionDigits: {
669
- quantity: decimalPlaces,
670
- minimumFractionDigits: decimalPlaces
671
- }
672
- })}`;
673
- };
674
- if (getIsOnlyAnObject(value)) {
675
- safelyInputValue = {
676
- from: checkValue(value.from),
677
- to: checkValue(value.to)
678
- };
679
- } else {
680
- safelyInputValue = checkValue(value);
681
- if (safelyInputValue.includes(" - ")) {
682
- const valuesArr = safelyInputValue.split(" - ").map((partOfValue) => partOfValue.trim());
683
- safelyInputValue = {
684
- from: checkValue(valuesArr[0]),
685
- to: checkValue(valuesArr[1])
686
- };
687
- } else {
688
- return `${beforeValueSymbol}${transform(safelyInputValue)}${afterValueSymbol}${isUseAsSimpleDiapason ? "" : "%"}`;
689
- }
690
- }
691
- if (safelyInputValue.from === safelyInputValue.to && !!isGlueSameRangesTogether) {
692
- return `${beforeValueSymbol}${transform(safelyInputValue.from)}${afterValueSymbol}${isUseAsSimpleDiapason ? "" : "%"}`;
693
- }
694
- if (isCommonPercentageSymbol)
695
- return `${beforeValueSymbol}${transform(safelyInputValue.from)} - ${transform(
696
- safelyInputValue.to
697
- )}${afterValueSymbol}${isUseAsSimpleDiapason ? "" : "%"}`;
698
- else
699
- return `${beforeValueSymbol}${transform(safelyInputValue.from)}${isUseAsSimpleDiapason ? "" : "%"} - ${transform(
700
- safelyInputValue.to
701
- )}${isUseAsSimpleDiapason ? "" : "%"}${afterValueSymbol}`;
702
- };
703
- var formatToOnlyASCIICodeText = (text) => getSafelyValue(text).replace(/[^\x00-\x7F]+/g, "");
704
- var formatNumberValueToMask = (inputValue, settings) => {
705
- const safelyInputValue = getSafelyValue(inputValue);
706
- const {
707
- mask = "XXX-XXX-XXXX",
708
- valueSymbol = "X",
709
- isReturnAdvanced = false
710
- } = settings || {};
711
- const processing = mask.split("").reduce(
712
- (acc, item) => {
713
- if (acc.value.length) ++acc.cursorPosition;
714
- acc.newValue.push(
715
- item === valueSymbol && acc.value.length ? acc.value.shift() : item
716
- );
717
- return acc;
718
- },
719
- {
720
- value: safelyInputValue.split("").filter((sym) => /[0-9]/g.test(sym)),
721
- newValue: [],
722
- cursorPosition: 0
723
- }
724
- );
725
- return isReturnAdvanced ? {
726
- value: processing.newValue.join(""),
727
- cursorPosition: processing.cursorPosition
728
- } : processing.newValue.join("");
729
- };
730
- var formatToLimitLength = (inputValue, limit) => {
731
- const value = getSafelyValue(inputValue);
732
- return limit && typeof limit === "number" && !Number.isNaN(limit) && value?.length > limit ? value.substr(0, limit) : value;
733
- };
734
- var formatToHex = ({ inputValue, withSharp }) => {
735
- const value = getSafelyValue(inputValue);
736
- if (withSharp) return `#${value.replace(/[^a-f0-9]/gi, "")}`;
737
- return `${value.replace(/[^#a-f0-9]/gi, "")}`;
738
- };
739
- function formatToReplaceAllWhiteSpace(str) {
740
- const value = getSafelyValue(str);
741
- return value.replace(/\s+/g, "");
742
- }
743
- var filterFloat = (inputValue, decimalPlaces) => {
744
- const replaser = (input) => ("" + input).replace(/[^\.\d]/g, "");
745
- const value = getSafelyValue(inputValue);
746
- const safelyDecimalPlaces = (() => {
747
- if (decimalPlaces === null) return decimalPlaces;
748
- const DEFAULT_VALUE = 2;
749
- const isNumber = typeof decimalPlaces === "number" || typeof decimalPlaces === "string" && !Number.isNaN(+decimalPlaces);
750
- return isNumber ? Number((+decimalPlaces).toFixed()) : DEFAULT_VALUE;
751
- })();
752
- if (value.length === 1 && (value[0] === "." || value[0] === ",")) return "0.";
753
- let output = ("" + value)?.replace(/,/g, ".");
754
- if (value.length > 1 && value[0] === "0" && value[1] !== "." && value[0] !== ",") output = value.slice(1);
755
- const previousValue = "" + output.slice(0, -1);
756
- const lastSym = "" + output.slice(-1);
757
- if (lastSym === "." && previousValue.includes(".")) output = previousValue;
758
- if (typeof safelyDecimalPlaces === "number") {
759
- if (!safelyDecimalPlaces && lastSym === ".") return replaser(previousValue);
760
- if (previousValue.includes(".") && previousValue.indexOf(".") + 1 + safelyDecimalPlaces === previousValue?.length) {
761
- return replaser(previousValue);
762
- }
763
- }
764
- return replaser(output);
765
- };
766
- var filterNumeric = (value, settings) => {
767
- value = getSafelyValue(value)?.replace(/,/g, "");
768
- const { type = "float", decimalPlaces } = settings || {};
769
- const executor = type === "float" ? filterFloat : formatOnlyNumbers;
770
- return executor(getSafelyValue(value), decimalPlaces);
771
- };
772
- var formatToHideValuePartially = (value, settings) => {
773
- const {
774
- showSymbolsCount = 4,
775
- isVisibleFromFront = false,
776
- isCutOutWhiteSpaces = true
777
- } = settings || {};
778
- const safelyValue = getSafelyValue(value);
779
- const newValue = isCutOutWhiteSpaces ? safelyValue.replace(/\s/g, "") : safelyValue;
780
- if (newValue.length <= showSymbolsCount) return newValue;
781
- const hide = (val) => val.split("").map(() => "*").join("");
782
- const visiblePart = isVisibleFromFront ? newValue.slice(0, showSymbolsCount) : newValue.slice(-1 * showSymbolsCount);
783
- const hiddenPart = isVisibleFromFront ? newValue.slice(showSymbolsCount) : newValue.slice(0, -1 * showSymbolsCount);
784
- return isVisibleFromFront ? `${visiblePart}${hide(hiddenPart)}` : `${hide(hiddenPart)}${visiblePart}`;
785
- };
786
153
 
787
154
  // src/Functions/presets/inputPresets.js
788
155
  var NAME_SYMBOLS_EXCLUDER = {