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.
- package/charts/package.json +5 -0
- package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.interface.d.ts +23 -3
- package/dist/Atomic/FormElements/Input/Input.d.ts +1 -1
- package/dist/Atomic/FormElements/Input/types.d.ts +0 -5
- package/dist/Atomic/FormElements/InputMask3/InputMask3.interface.d.ts +0 -3
- package/dist/Atomic/FormElements/TagListToDropdown/TagListToDropdown.interface.d.ts +1 -1
- package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.interface.d.ts +4 -4
- package/dist/Atomic/UI/Alert/Alert.interface.d.ts +0 -2
- package/dist/Functions/sdk/runtime-sdk/transport.d.ts +2 -2
- package/dist/charts.cjs +927 -0
- package/dist/charts.cjs.map +7 -0
- package/dist/charts.d.ts +7 -0
- package/dist/charts.js +911 -0
- package/dist/charts.js.map +7 -0
- package/dist/form.cjs +1506 -1940
- package/dist/form.cjs.map +4 -4
- package/dist/form.js +1122 -1556
- package/dist/form.js.map +4 -4
- package/dist/hooks.cjs +8 -324
- package/dist/hooks.cjs.map +4 -4
- package/dist/hooks.js +8 -324
- package/dist/hooks.js.map +4 -4
- package/dist/index.cjs +2515 -9300
- package/dist/index.cjs.map +4 -4
- package/dist/index.js +2067 -8868
- package/dist/index.js.map +4 -4
- package/dist/layout.cjs +207 -6308
- package/dist/layout.cjs.map +4 -4
- package/dist/layout.js +202 -6303
- package/dist/layout.js.map +4 -4
- package/dist/presets.cjs +0 -643
- package/dist/presets.cjs.map +4 -4
- package/dist/presets.js +0 -633
- package/dist/presets.js.map +4 -4
- package/dist/ui.cjs +711 -7854
- package/dist/ui.cjs.map +4 -4
- package/dist/ui.d.ts +0 -5
- package/dist/ui.js +722 -7881
- package/dist/ui.js.map +4 -4
- package/dist/utils.cjs +4 -51
- package/dist/utils.cjs.map +3 -3
- package/dist/utils.js +4 -51
- package/dist/utils.js.map +3 -3
- package/package.json +16 -2
- package/dist/Atomic/FormElements/Dropdown/components/DropdownLoader.d.ts +0 -4
- package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN_old.d.ts +0 -11
- package/dist/Atomic/FormElements/NumericInput/NumericInput.d.ts +0 -36
- package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.d.ts +0 -2
- package/dist/Atomic/FormElements/RangeSlider/RangeSlider.d.ts +0 -19
- package/dist/Atomic/FormElements/SwitcherTagsDropdown/partial/States.d.ts +0 -5
- package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.d.ts +0 -17
- package/dist/Atomic/FormElements/VariantsListRadio/partials/VariantsListRadioItem.d.ts +0 -12
- package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.d.ts +0 -2
- package/dist/Atomic/FormElements/WidgetPseudoTable/partial/constructor.d.ts +0 -23
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.d.ts +0 -2
- package/dist/Atomic/FormElements/WidgetWithSwitchableRows/partial/constructor.d.ts +0 -38
- package/dist/Atomic/UI/AccordionTable/AccordionTable.d.ts +0 -10
- package/dist/Atomic/UI/AccordionText/AccordionText.d.ts +0 -8
- package/dist/Atomic/UI/Chart/partial/Chart.constants.d.ts +0 -78
- package/dist/Atomic/UI/Chart/partial/datasetSetters.d.ts +0 -13
- package/dist/Atomic/UI/Chart/partial/optionsConstructor.d.ts +0 -145
- package/dist/Atomic/UI/Chart/partial/optionsSetters.d.ts +0 -4
- package/dist/Atomic/UI/CircleProgressBar/CircleProgressBar.d.ts +0 -14
- package/dist/Atomic/UI/DynamicIcon/DynamicIcon.d.ts +0 -4
- package/dist/Atomic/UI/DynamicIcon/DynamicIcon.interface.d.ts +0 -6
- package/dist/Atomic/UI/DynamicIcon/index.d.ts +0 -3
- package/dist/Atomic/UI/ExampleChartIntegration/ExampleChartIntegration.d.ts +0 -2
- package/dist/Atomic/UI/ExampleChartIntegration/partial/utils.d.ts +0 -4
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion._test.d.ts +0 -1
- package/dist/Atomic/UI/MonoAccordion/MonoAccordion.d.ts +0 -12
- package/dist/Atomic/UI/PieChart/PieChart.d.ts +0 -8
- package/dist/Atomic/UI/Table/Partials/TdCell.d.ts +0 -13
- package/dist/Atomic/UI/Table/Partials/TdHeader.d.ts +0 -5
- package/dist/Atomic/UI/Table/Partials/TdRow.d.ts +0 -17
- package/dist/Atomic/UI/Table/Partials/TdTitle.d.ts +0 -5
- package/dist/Atomic/UI/Table/Table.d.ts +0 -9
- package/dist/Atomic/UI/Table/TdTypes/TdActions.d.ts +0 -6
- package/dist/Atomic/UI/Table/TdTypes/TdPriority.d.ts +0 -6
- package/dist/Atomic/UI/Table/TdTypes/TdRange.d.ts +0 -4
- package/dist/Atomic/UI/Table/TdTypes/TdWeight.d.ts +0 -7
- package/dist/Atomic/UI/WizardStepper/constructor.d.ts +0 -51
- package/dist/Classes/AbortableFetch.d.ts +0 -43
- package/dist/Classes/AnimatedHandler.d.ts +0 -4
- package/dist/Classes/RESTAPI/index.d.ts +0 -9
- package/dist/Classes/RESTAPI/partials/AbortableFetch.d.ts +0 -43
- package/dist/Classes/RESTAPI/partials/ApiBase.d.ts +0 -10
- package/dist/Classes/RESTAPI/partials/ApiRequestCreators.d.ts +0 -9
- package/dist/Classes/RESTAPI/partials/ApiUtils.d.ts +0 -12
- package/dist/Classes/RESTAPI/partials/CredentialsProcessing.d.ts +0 -24
- package/dist/Classes/RESTAPI/partials/Utils.d.ts +0 -4
- package/dist/Classes/RESTAPI/partials/_utils.d.ts +0 -9
- package/dist/Constants/index.constants.d.ts +0 -20
- package/dist/Functions/Portal.d.ts +0 -6
- package/dist/Functions/customEventListener.d.ts +0 -27
- package/dist/Functions/dateTime.d.ts +0 -95
- package/dist/Functions/fieldValueFormatters.d.ts +0 -19
- package/dist/Functions/hooks/useFormFieldsChangesManager.d.ts +0 -15
- package/dist/Functions/locale/createTranslator.d.ts +0 -3
- package/dist/Functions/operations.d.ts +0 -1
- package/dist/Functions/presets/inputMaskPresets.d.ts +0 -136
- package/dist/Functions/presets/inputPresets.d.ts +0 -16
- package/dist/Functions/presets/mobileKeyboardTypesPresets.d.ts +0 -17
- package/dist/Functions/schemas.d.ts +0 -3
- package/dist/Functions/useBodyScrollLock.d.ts +0 -2
- package/dist/Functions/useClickOutside.d.ts +0 -1
- package/dist/Functions/useDebounce.d.ts +0 -4
- package/dist/Functions/useFieldFocus.d.ts +0 -7
- package/dist/Functions/useFormTools/form-drivers/ArrayWithObjects.d.ts +0 -15
- package/dist/Functions/useFormTools/form-drivers/ObjectWithIterableObjects.d.ts +0 -12
- package/dist/Functions/useFormTools/form-drivers/ObjectWithNamedKeyObjects.d.ts +0 -15
- package/dist/Functions/useFormTools/functions/General.d.ts +0 -15
- package/dist/Functions/useFormTools/functions/RenderFields.d.ts +0 -7
- package/dist/Functions/useFormTools/functions/usePrevious.d.ts +0 -2
- package/dist/Functions/useFormTools/index.d.ts +0 -86
- package/dist/Functions/useInputHighlightError.d.ts +0 -12
- package/dist/Functions/useLocalStorage.d.ts +0 -2
- package/dist/Functions/useLocationParams.d.ts +0 -1
- package/dist/Functions/useMediaQuery.d.ts +0 -2
- package/dist/Functions/useMetaInfo.d.ts +0 -8
- package/dist/Functions/useMouseUpOutside.d.ts +0 -1
- package/dist/Functions/useOnlineStatus.d.ts +0 -2
- package/dist/Functions/usePasswordChecker.d.ts +0 -7
- package/dist/Functions/usePrevious.d.ts +0 -2
- package/dist/Functions/useResize.d.ts +0 -3
- package/dist/Functions/useScrollTo.d.ts +0 -2
- package/dist/Functions/useToggle.d.ts +0 -7
- package/dist/Functions/utils.d.ts +0 -40
- package/dist/Langs.d.ts +0 -179
- package/dist/Molecular/FormWithDependOn/FormWithDependOn.d.ts +0 -3
- 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 = {
|