@topvisor/ui 1.0.21-pinia-1 → 1.0.22-selectorRegion-pr

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 (173) hide show
  1. package/.chunks/core-Cb1K4rks.es.js +196 -0
  2. package/.chunks/core-Cb1K4rks.es.js.map +1 -0
  3. package/.chunks/core-DOD2Zduv.amd.js +2 -0
  4. package/.chunks/core-DOD2Zduv.amd.js.map +1 -0
  5. package/.chunks/{datepicker-BC31NE5M.es.js → datepicker-BbLOzQtp.es.js} +2 -2
  6. package/.chunks/datepicker-BbLOzQtp.es.js.map +1 -0
  7. package/.chunks/{datepicker-CVoT5EME.amd.js → datepicker-DNOnzVIz.amd.js} +2 -2
  8. package/.chunks/datepicker-DNOnzVIz.amd.js.map +1 -0
  9. package/.chunks/dialog_selectorRegions-BYAZLdbp.es.js +140 -0
  10. package/.chunks/dialog_selectorRegions-BYAZLdbp.es.js.map +1 -0
  11. package/.chunks/dialog_selectorRegions-D1YE2mYS.amd.js +2 -0
  12. package/.chunks/dialog_selectorRegions-D1YE2mYS.amd.js.map +1 -0
  13. package/.chunks/{utils-C5sf4bZh.es.js → dialogs.vue_vue_type_script_setup_true_lang-DtLpQTwi.es.js} +72 -144
  14. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-DtLpQTwi.es.js.map +1 -0
  15. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-xoE5yB6b.amd.js +2 -0
  16. package/.chunks/dialogs.vue_vue_type_script_setup_true_lang-xoE5yB6b.amd.js.map +1 -0
  17. package/.chunks/{forms-CxYSHZLL.amd.js → forms-Dv9L8-AZ.amd.js} +3 -3
  18. package/.chunks/forms-Dv9L8-AZ.amd.js.map +1 -0
  19. package/.chunks/{forms-CipZtprq.es.js → forms-LTK63Ugt.es.js} +28 -28
  20. package/.chunks/forms-LTK63Ugt.es.js.map +1 -0
  21. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-CT6O_7Qy.amd.js → listItem.vue_vue_type_script_setup_true_lang-COGiIcDO.amd.js} +2 -2
  22. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-COGiIcDO.amd.js.map +1 -0
  23. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-uNNJJ4S0.es.js → listItem.vue_vue_type_script_setup_true_lang-UC3o5oK5.es.js} +7 -7
  24. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-UC3o5oK5.es.js.map +1 -0
  25. package/.chunks/{menu.vue_vue_type_style_index_0_lang-DAI_WcXI.amd.js → menu.vue_vue_type_style_index_0_lang-BFmZ4tvs.amd.js} +2 -2
  26. package/.chunks/menu.vue_vue_type_style_index_0_lang-BFmZ4tvs.amd.js.map +1 -0
  27. package/.chunks/{menu.vue_vue_type_style_index_0_lang-fU3LbpR7.es.js → menu.vue_vue_type_style_index_0_lang-hQu5BJPe.es.js} +5 -5
  28. package/.chunks/menu.vue_vue_type_style_index_0_lang-hQu5BJPe.es.js.map +1 -0
  29. package/.chunks/{notice-uzdQ-t3s.amd.js → notice-BoZG4Mg1.amd.js} +2 -2
  30. package/.chunks/notice-BoZG4Mg1.amd.js.map +1 -0
  31. package/.chunks/{notice-cCZZtLLu.es.js → notice-CYutIom0.es.js} +2 -2
  32. package/.chunks/notice-CYutIom0.es.js.map +1 -0
  33. package/.chunks/page.vue_vue_type_script_setup_true_lang-B2wjrf5z.es.js +143 -0
  34. package/.chunks/page.vue_vue_type_script_setup_true_lang-B2wjrf5z.es.js.map +1 -0
  35. package/.chunks/page.vue_vue_type_script_setup_true_lang-CffDh-th.amd.js +2 -0
  36. package/.chunks/page.vue_vue_type_script_setup_true_lang-CffDh-th.amd.js.map +1 -0
  37. package/.chunks/{popup-Bwknq6xI.amd.js → popup-Cg9w4Vy-.amd.js} +2 -2
  38. package/.chunks/popup-Cg9w4Vy-.amd.js.map +1 -0
  39. package/.chunks/{popup-BvhY5oAD.es.js → popup-ec_xLrTA.es.js} +2 -2
  40. package/.chunks/popup-ec_xLrTA.es.js.map +1 -0
  41. package/.chunks/store-CX_6ZXhO.es.js.map +1 -1
  42. package/.chunks/store-esTid5oI.amd.js.map +1 -1
  43. package/.chunks/{utils-C2OmmJkw.es.js → utils-BRLYX_ZC.es.js} +3 -3
  44. package/.chunks/utils-BRLYX_ZC.es.js.map +1 -0
  45. package/.chunks/utils-COoE8KP7.es.js +79 -0
  46. package/.chunks/utils-COoE8KP7.es.js.map +1 -0
  47. package/.chunks/utils-GpKurv7L.amd.js +2 -0
  48. package/.chunks/utils-GpKurv7L.amd.js.map +1 -0
  49. package/.chunks/utils-z5wL437D.amd.js +2 -0
  50. package/.chunks/utils-z5wL437D.amd.js.map +1 -0
  51. package/README.md +82 -82
  52. package/assets/core.css +1 -1
  53. package/assets/dialog_selectorRegions.css +1 -0
  54. package/assets/forms.css +1 -1
  55. package/assets/formsExt.css +1 -1
  56. package/charts/charts.amd.js +1 -1
  57. package/charts/charts.amd.js.map +1 -1
  58. package/charts/charts.js +1 -1
  59. package/charts/charts.js.map +1 -1
  60. package/components/project/project.d.ts +1 -1
  61. package/components/project/selectorRegion/dialog_selectorRegions/dialog_selectorRegions.vue.d.ts +4 -0
  62. package/components/project/selectorRegion/dialog_selectorRegions/types.d.ts +26 -0
  63. package/components/project/selectorRegion/selectorRegion.d.ts +0 -12
  64. package/components/project/selectorRegion/selectorRegion.vue.d.ts +1 -3
  65. package/components/project/selectorRegion/utils/utils.d.ts +9 -0
  66. package/core/app.amd.js +1 -1
  67. package/core/app.amd.js.map +1 -1
  68. package/core/app.js +122 -310
  69. package/core/app.js.map +1 -1
  70. package/core/utils/string.d.ts +3 -1
  71. package/dialog/dialog.amd.js +1 -1
  72. package/dialog/dialog.amd.js.map +1 -1
  73. package/dialog/dialog.js +22 -155
  74. package/dialog/dialog.js.map +1 -1
  75. package/forms/forms.amd.js +1 -1
  76. package/forms/forms.js +1 -1
  77. package/forms/helpers.amd.js.map +1 -1
  78. package/forms/helpers.js.map +1 -1
  79. package/formsExt/formsExt.amd.js +1 -1
  80. package/formsExt/formsExt.amd.js.map +1 -1
  81. package/formsExt/formsExt.js +2 -2
  82. package/formsExt/formsExt.js.map +1 -1
  83. package/icomoon/Read Me.txt +7 -7
  84. package/icomoon/Topvisor icons.json +6259 -6259
  85. package/icomoon/demo-files/demo.css +158 -158
  86. package/icomoon/demo-files/demo.js +30 -30
  87. package/icomoon/demo.html +3558 -3558
  88. package/icomoon/fonts/Topvisor-2.svg +276 -276
  89. package/icomoon/style.css +780 -780
  90. package/jquery-ui.min.css +5 -5
  91. package/layout/layout.amd.js +1 -1
  92. package/layout/layout.amd.js.map +1 -1
  93. package/layout/layout.js +1 -1
  94. package/layout/layout.js.map +1 -1
  95. package/package.json +33 -33
  96. package/popup/popup.amd.js +1 -1
  97. package/popup/popup.amd.js.map +1 -1
  98. package/popup/popup.js +2 -2
  99. package/popup/popup.js.map +1 -1
  100. package/popup/worker.amd.js +1 -1
  101. package/popup/worker.amd.js.map +1 -1
  102. package/popup/worker.js +2 -2
  103. package/popup/worker.js.map +1 -1
  104. package/project/project.amd.js +1 -1
  105. package/project/project.amd.js.map +1 -1
  106. package/project/project.js +517 -515
  107. package/project/project.js.map +1 -1
  108. package/require/css.amd.js +12 -12
  109. package/tabs/tabs.amd.js.map +1 -1
  110. package/tabs/tabs.js.map +1 -1
  111. package/tabsView/tabsView.amd.js +1 -1
  112. package/tabsView/tabsView.amd.js.map +1 -1
  113. package/tabsView/tabsView.js +1 -1
  114. package/tabsView/tabsView.js.map +1 -1
  115. package/utils/check.amd.js.map +1 -1
  116. package/utils/check.js.map +1 -1
  117. package/utils/clipboard.amd.js +1 -1
  118. package/utils/clipboard.amd.js.map +1 -1
  119. package/utils/clipboard.js +1 -1
  120. package/utils/clipboard.js.map +1 -1
  121. package/utils/date.amd.js +1 -1
  122. package/utils/date.js +2 -2
  123. package/utils/device.amd.js +1 -1
  124. package/utils/device.js +4 -4
  125. package/utils/dom.amd.js.map +1 -1
  126. package/utils/dom.js.map +1 -1
  127. package/utils/image.amd.js.map +1 -1
  128. package/utils/image.js.map +1 -1
  129. package/utils/keyboard.amd.js.map +1 -1
  130. package/utils/keyboard.js.map +1 -1
  131. package/utils/lodash.amd.js +1 -1
  132. package/utils/lodash.js +3 -3
  133. package/utils/number.amd.js.map +1 -1
  134. package/utils/number.js.map +1 -1
  135. package/utils/price.amd.js +1 -1
  136. package/utils/price.amd.js.map +1 -1
  137. package/utils/price.js +4 -4
  138. package/utils/price.js.map +1 -1
  139. package/utils/route.amd.js.map +1 -1
  140. package/utils/route.js.map +1 -1
  141. package/utils/scroll.amd.js.map +1 -1
  142. package/utils/scroll.js.map +1 -1
  143. package/utils/searchers.amd.js +1 -1
  144. package/utils/searchers.amd.js.map +1 -1
  145. package/utils/searchers.js +16 -12
  146. package/utils/searchers.js.map +1 -1
  147. package/utils/string.amd.js +1 -1
  148. package/utils/string.amd.js.map +1 -1
  149. package/utils/string.js +1 -1
  150. package/utils/string.js.map +1 -1
  151. package/utils/system.amd.js.map +1 -1
  152. package/utils/system.js.map +1 -1
  153. package/utils/url.amd.js.map +1 -1
  154. package/utils/url.js.map +1 -1
  155. package/web-types.json +130 -130
  156. package/.chunks/datepicker-BC31NE5M.es.js.map +0 -1
  157. package/.chunks/datepicker-CVoT5EME.amd.js.map +0 -1
  158. package/.chunks/forms-CipZtprq.es.js.map +0 -1
  159. package/.chunks/forms-CxYSHZLL.amd.js.map +0 -1
  160. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-CT6O_7Qy.amd.js.map +0 -1
  161. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-uNNJJ4S0.es.js.map +0 -1
  162. package/.chunks/menu.vue_vue_type_style_index_0_lang-DAI_WcXI.amd.js.map +0 -1
  163. package/.chunks/menu.vue_vue_type_style_index_0_lang-fU3LbpR7.es.js.map +0 -1
  164. package/.chunks/notice-cCZZtLLu.es.js.map +0 -1
  165. package/.chunks/notice-uzdQ-t3s.amd.js.map +0 -1
  166. package/.chunks/popup-BvhY5oAD.es.js.map +0 -1
  167. package/.chunks/popup-Bwknq6xI.amd.js.map +0 -1
  168. package/.chunks/utils-BfdO2xlC.amd.js +0 -2
  169. package/.chunks/utils-BfdO2xlC.amd.js.map +0 -1
  170. package/.chunks/utils-C2OmmJkw.es.js.map +0 -1
  171. package/.chunks/utils-C3dsXIj9.amd.js +0 -2
  172. package/.chunks/utils-C3dsXIj9.amd.js.map +0 -1
  173. package/.chunks/utils-C5sf4bZh.es.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"string.amd.js","sources":["../../src/core/utils/string.ts"],"sourcesContent":["/**\r\n * Работа со строками\r\n * @packageDocumentation\r\n */\r\n\r\nimport { getDomainRegexp } from '@/core/utils/check';\r\nimport { useI18nLang } from '@/core/plugins/i18n';\r\n\r\n/**\r\n * Сгенерировать числовой хэш от строки для идентификатора\r\n */\r\nexport const genIntHash = (string: string): number => {\r\n\tstring += '';\r\n\r\n\tlet hash = 0;\r\n\tif (!string.length) return hash;\r\n\r\n\tfor (let i = 0; i < string.length; i++) {\r\n\t\tconst char = string.charCodeAt(i);\r\n\t\thash = ((hash << 5) - hash) + char;\r\n\t\thash = hash & hash;\r\n\t}\r\n\r\n\tif (hash < 0) hash *= -1;\r\n\r\n\treturn hash;\r\n};\r\n\r\n/**\r\n * Проверить что переданная строка является URL\r\n */\r\nexport const isUrl = (url: string): boolean => {\r\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\r\n};\r\n\r\n/**\r\n * Добавляет пробелы между разрядами если требуется\r\n * @param nStr строка с числом\r\n */\r\nexport const addCommasWhite = (n: number | string): string => {\r\n\tlet nStr = n + '';\r\n\r\n\tnStr = nStr.replace('-', '–');\r\n\r\n\tlet x = nStr.split('.');\r\n\tlet x1 = x[0];\r\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\r\n\r\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\r\n\r\n\tconst rgx = /(\\d+)(\\d{3})/;\r\n\twhile (rgx.test(x1)) {\r\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\r\n\t}\r\n\treturn x1 + x2;\r\n};\r\n\r\n/**\r\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\r\n */\r\nexport const nl2br = (str: string): string => {\r\n\tif (str === undefined) return '';\r\n\r\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\r\n};\r\n\r\n/**\r\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\r\n * @param number\r\n * @param precision - точность, количество знаков после запятой\r\n * @param dimension - размерность, по умолчанию 1000\r\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\r\n */\r\nexport const numberWithWord = (number: number, precision = 2, dimension = 1000, suffix = ''): string => {\r\n\tconst k = Math.pow(10, precision);\r\n\r\n\tlet numberStr = String(number);\r\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\r\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\r\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\r\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\r\n\t} else if (Math.abs(number) > dimension) {\r\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\r\n\t}\r\n\r\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\r\n\r\n\treturn numberStr;\r\n};\r\n\r\n/**\r\n * Обрезать текст под три точки\r\n * @param string\r\n * @param max_length - максимальное количество символов текста, остальное обрежеться\r\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\r\n */\r\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\r\n\tif (string == undefined) return '';\r\n\r\n\tstring += '';\r\n\tif (max_length == undefined || string.length <= max_length) return string;\r\n\r\n\tif (pos === 0) {\r\n\t\tstring = string.substr(string.length - max_length, max_length);\r\n\t\tstring = '...' + string;\r\n\t} else if (pos === 1) {\r\n\t\tconst string1 = string.substr(0, max_length / 2);\r\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\r\n\t\tstring = string1 + '...' + string2;\r\n\t} else if (pos === 2) {\r\n\t\tstring = string.substr(0, max_length);\r\n\t\tstring = string + '...';\r\n\t}\r\n\r\n\treturn string;\r\n};\r\n\r\n/**\r\n * Сгенерировать строку текста для вывода количества в разном склонении\r\n * @param num\r\n * @param ending0 - родительный падеж, множ. число (10 модулей)\r\n * @param ending1 - именительный падеж, ед. число (1 модуль)\r\n * @param ending2 - винительный падеж, множ. число (3 модуля)\r\n */\r\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\r\n\t// склонение по множественному числу\r\n\tif (useI18nLang().value === 'en') {\r\n\t\tif (num === 1) {\r\n\t\t\treturn ending1;\r\n\t\t} else {\r\n\t\t\treturn ending0;\r\n\t\t}\r\n\t}\r\n\r\n\tconst num100 = num % 100;\r\n\tconst num10 = num % 10;\r\n\r\n\tif (num100 >= 5 && num100 <= 20) {\r\n\t\treturn ending0;\r\n\t} else if (num10 === 0) {\r\n\t\treturn ending0;\r\n\t} else if (num10 === 1) {\r\n\t\treturn ending1;\r\n\t} else if (num10 >= 2 && num10 <= 4) {\r\n\t\treturn ending2;\r\n\t} else if (num10 >= 5 && num10 <= 9) {\r\n\t\treturn ending0;\r\n\t} else {\r\n\t\treturn ending2;\r\n\t}\r\n};\r\n\r\n/**\r\n * Перевести строку в родительный падеж\r\n */\r\nexport const toRoditPadej = (str: string): string => {\r\n\tif (useI18nLang().value != 'ru' || str == '') return str;\r\n\r\n\tconst str_array = str.split(' ');\r\n\r\n\t$.map(str_array, function (str, index) {\r\n\t\tstr = str + 'а';\r\n\t\tstr = str.replace('оа', 'о');\r\n\t\tstr = str.replace('аяа', 'ой');\r\n\t\tstr = str.replace('шийа', 'шого');\r\n\t\tstr = str.replace('ыйа', 'ого');\r\n\t\tstr = str.replace('йа', 'я');\r\n\t\tstr = str.replace('ьа', 'я');\r\n\t\tstr = str.replace('яа', 'и');\r\n\t\tstr = str.replace('оваа', 'овой');\r\n\t\tstr = str.replace('аа', 'ы');\r\n\t\tstr = str.replace('кия', 'кого');\r\n\t\tstr = str.replace('каи', 'кой');\r\n\r\n\t\tstr_array[index] = str;\r\n\t});\r\n\r\n\tstr = str_array.join(' ');\r\n\r\n\treturn str;\r\n};\r\n\r\n/**\r\n * Транслитерация текста\r\n */\r\nexport const rusToLatin = (str: string): string => {\r\n\tconst ru: { [index: string]: string } = {\r\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\r\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\r\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\r\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\r\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\r\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\r\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\r\n\t};\r\n\r\n\tconst str_array = str.split(' ');\r\n\r\n\t$.map(str_array, function (str, index) {\r\n\t\tconst newStr: string[] = [];\r\n\t\tfor (let i = 0; i < str.length; ++i) {\r\n\t\t\tnewStr.push(\r\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\r\n\t\t\t\t\treturn match.toUpperCase();\r\n\t\t\t\t}),\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tstr_array[index] = newStr.join('');\r\n\t});\r\n\r\n\tstr = str_array.join(' ');\r\n\r\n\treturn str;\r\n};\r\n\r\n/**\r\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&amp;`)\r\n */\r\nexport const htmlspecialchars = (str: string): string => {\r\n\tif (typeof (str) == 'string') {\r\n\t\tstr = str\r\n\t\t\t.replace(/&/g, '&amp;')\r\n\t\t\t.replace(/</g, '&lt;')\r\n\t\t\t.replace(/>/g, '&gt;')\r\n\t\t\t.replace(/\"/g, '&quot;')\r\n\t\t\t.replace(/'/g, '&#039;');\r\n\t}\r\n\treturn str;\r\n};\r\n\r\n/**\r\n * Выделить нужное в тексте желтым цветом\r\n * поиск происходит по строке fieldFilter.values[0]\r\n */\r\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\r\n\tlet regExp: RegExp | null = null;\r\n\r\n\tswitch (fieldFilter.operator) {\r\n\t\tcase 'CONTAINS':\r\n\t\tcase 'REGEXP':\r\n\t\t\ttry {\r\n\t\t\t\tlet regExpString = fieldFilter.values[0];\r\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\r\n\r\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\r\n\t\t\t} catch (exception) {\r\n\t\t\t\treturn text;\r\n\t\t\t}\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\r\n\r\n\treturn text;\r\n};\r\n\r\n/**\r\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\r\n */\r\nexport const camelToSnakeCase = (str: string): string | undefined => {\r\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\r\n};\r\n\r\n/**\r\n * Получить url изображения флага, по коду страны (RU, GB)\r\n */\r\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\r\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\r\n\treturn `/controller/file/?src=${urlImage}`;\r\n};\r\n\r\n/**\r\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\r\n *\r\n * Для email ставиться префикс `mailto:`\r\n */\r\nexport const addLinkTags = (text: string): string => {\r\n\tconst domainRegexp = getDomainRegexp();\r\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\r\n\r\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\r\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\r\n\r\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\r\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\r\n\r\n\ttext = text.replaceAll('√http', 'http');\r\n\ttext = text.replaceAll('√', 'http://');\r\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\r\n\r\n\treturn text;\r\n};\r\n\r\n/**\r\n * Перевести первую букву строки в верхний регистр\r\n */\r\nexport const toCapitalize = (str: string): string => {\r\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\r\n};\r\n\r\n/**\r\n * Получить случайную строку\r\n */\r\nexport const getRandomHash = (length: number = 20): string => {\r\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\r\n\r\n\tlet result = '';\r\n\tfor (let i = 0; i < length; i++) {\r\n\t\tresult += l[Math.floor(Math.random() * l.length)];\r\n\t}\r\n\r\n\treturn result;\r\n};\r\n"],"names":["genIntHash","string","hash","i","isUrl","url","addCommasWhite","n","nStr","x1","x","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","numberStr","k","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","forms","num100","num10","toRoditPadej","str2","str_array","index","rusToLatin","ru","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExpString","regExp","camelToSnakeCase","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","utils_check","regexpMailto","afterDomainRegexp","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":"2IAWa,MAAAA,EAAAC,GAAA,eAIZ,GAAA,CAAAA,EAAA,OAAA,OAAAC,EAEA,QAAAC,EAAA,EAAAA,EAAAF,EAAA,OAAAE,IAAA,sCAGCD,EAAAA,EAAAA,CAAc,CAGf,OAAAA,EAAA,IAAAA,GAAA,IAEAA,CACD,EAKaE,EAAAC,GACZ,0CAAA,KAAAA,CAAA,EAOYC,EAAAC,GAAA,CACZ,IAAAC,EAAAD,EAAA,2CAKAE,EAAAC,EAAA,CAAA,EACAC,EAAAD,EAAA,OAAA,EAAA,IAAAA,EAAA,CAAA,EAAA,GAEA,GAAAD,EAAA,QAAA,OAAA,EAAA,EAAA,QAAA,EAAA,OAAAD,yBAGA,KAAAI,EAAA,KAAAH,CAAA,oCAID,EAKaI,EAAAC,GACZA,IAAA,OAAA,mCAYYC,EAAA,CAAAC,EAAAC,EAAA,EAAAC,EAAA,IAAAC,EAAA,KAAA,wBAGZ,IAAAC,EAAA,OAAAJ,CAAA,EACA,OAAA,KAAA,IAAAA,CAAA,EAAA,KAAA,IAAAE,EAAA,CAAA,6DAC0F,KAAA,IAAAF,CAAA,EAAA,KAAA,IAAAE,EAAA,CAAA,6EAIzFE,EAAA,KAAA,MAAAJ,EAAAE,EAAAG,CAAA,EAAAA,EAAA,YAAAF,EAAA,mDAKDC,CACD,EAQOE,EAAA,CAAArB,EAAAsB,EAAAC,EAAA,IAAA,CACN,GAAAvB,GAAA,KAAA,MAAA,GAGA,SAAAsB,GAAA,MAAAtB,EAAA,QAAAsB,EAAA,OAAAtB,EAEA,GAAAuB,IAAA,EACCvB,EAAAA,EAAA,OAAAA,EAAA,OAAAsB,EAAAA,CAAA,EACAtB,EAAA,MAAAA,UAAiBuB,IAAA,EAAA,CAEjB,MAAAC,EAAAxB,EAAA,OAAA,EAAAsB,EAAA,CAAA,0CAEAtB,EAAAwB,EAAA,MAAAC,CAA2B,MAAAF,IAAA,oBAG3BvB,EAAAA,EAAA,OAGD,OAAAA,CACD,EASO0B,EAAA,CAAAC,EAAAC,EAAAC,EAAAC,IAAA,CAEN,GAAAC,EAAA,YAAA,EAAA,QAAA,KACC,OAAAJ,IAAA,EACCE,EAEAD,EAIF,MAAAI,EAAAL,EAAA,IACAM,EAAAN,EAAA,uBAGQM,IAAA,EAAPL,EAEOK,IAAA,EAEPJ,aAEAC,aAEAF,EAEAE,CAEF,EAKaI,EAAArB,GAAA,CACZ,GAAAkB,EAAA,YAAA,EAAA,OAAA,MAAAlB,GAAA,GAAA,OAAAA,oDAKCsB,EAAAA,EAAA,4QAaAC,EAAAC,CAAA,EAAAF,CAAmB,CAAA,EAGpBtB,EAAAuB,EAAA,KAAA,GAAA,EAEAvB,CACD,EAKayB,EAAAzB,GAAA,6MAQI,EAAA,6DAOf,QAAAX,EAAA,EAAAA,EAAAiC,EAAA,OAAA,EAAAjC,SACQqC,EAAAJ,EAAAjC,CAAA,CAAA,GAAAqC,EAAAJ,EAAAjC,CAAA,EAAA,YAAA,CAAA,GAAA,MAAAiC,EAAAjC,CAAA,GAAAqC,EAAAJ,EAAAjC,CAAA,EAAA,YAAA,CAAA,EAAA,QAAA,OAAA,SAAAsC,EAAA,CAEL,OAAAA,EAAA,YAAA,oBAK8B,CAAA,EAGlC3B,EAAAuB,EAAA,KAAA,GAAA,EAEAvB,CACD,EAKa4B,EAAA5B,IACZ,OAAAA,GAAA,WACCA,EAAAA,EAAA,QAAA,KAAA,OAAA,EAAA,QAAA,KAAA,MAAA,EAAA,QAAA,KAAA,MAAA,EAAA,QAAA,KAAA,QAAA,EAAA,QAAA,KAAA,QAAA,GAODA,GAOY6B,EAAA,CAAAC,EAAAC,IAAA,+BAGkB,IAAA,WACxB,IAAA,SAEJ,GAAA,mBAECA,EAAA,UAAA,WAAAC,EAAAA,EAAA,QAAA,cAAA,MAAA,GAEAC,EAAA,IAAA,OAAA,IAAAD,EAAA,IAAA,IAAA,QAEA,OAAAF,CAAO,MAGR,iDAKFA,CACD,EAKaI,EAAAlC,GAAA,+IAEb,EAKamC,EAAAC,GAEZ,sEAAA,GAQYC,EAAAP,GAAA,CACZ,MAAAQ,EAAAC,EAAA,gBAAA,wCAGAC,EAAA,IAAA,OAAA,iCAAAF,CAAA,GAAAG,CAAA,IAAA,KAAA,mFAGA,MAAAC,EAAA,IAAA,OAAA,6BAAAJ,CAAA,GAAAG,CAAA,IAAA,KAAA,yLAOAX,CACD,EAKaa,EAAA3C,GACZA,EAAA,OAAA,CAAA,EAAA,YAAA,EAAAA,EAAA,MAAA,CAAA,EAMY4C,EAAA,CAAAC,EAAA,KAAA,mFAIZ,QAAAxD,EAAA,EAAAA,EAAAwD,EAAAxD,IACCyD,GAAA,EAAA,KAAA,MAAA,KAAA,OAAA,EAAA,EAAA,MAAA,CAAA,EAGD,OAAAA,CACD"}
1
+ {"version":3,"file":"string.amd.js","sources":["../../src/core/utils/string.ts"],"sourcesContent":["/**\n * Работа со строками\n * @packageDocumentation\n */\n\nimport { getDomainRegexp } from '@/core/utils/check';\nimport { useI18nLang } from '@/core/plugins/i18n';\n\n/**\n * Сгенерировать числовой хэш от строки для идентификатора\n */\nexport const genIntHash = (string: string): number => {\n\tstring += '';\n\n\tlet hash = 0;\n\tif (!string.length) return hash;\n\n\tfor (let i = 0; i < string.length; i++) {\n\t\tconst char = string.charCodeAt(i);\n\t\thash = ((hash << 5) - hash) + char;\n\t\thash = hash & hash;\n\t}\n\n\tif (hash < 0) hash *= -1;\n\n\treturn hash;\n};\n\n/**\n * Проверить что переданная строка является URL\n */\nexport const isUrl = (url: string): boolean => {\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\n};\n\n/**\n * Добавляет пробелы между разрядами если требуется\n * @param nStr строка с числом\n */\nexport const addCommasWhite = (n: number | string): string => {\n\tlet nStr = n + '';\n\n\tnStr = nStr.replace('-', '–');\n\n\tlet x = nStr.split('.');\n\tlet x1 = x[0];\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\n\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\n\n\tconst rgx = /(\\d+)(\\d{3})/;\n\twhile (rgx.test(x1)) {\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\n\t}\n\treturn x1 + x2;\n};\n\n/**\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\n */\nexport const nl2br = (str: string): string => {\n\tif (str === undefined) return '';\n\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\n};\n\n/**\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\n * @param number\n * @param precision - точность, количество знаков после запятой\n * @param dimension - размерность, по умолчанию 1000\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\n */\nexport const numberWithWord = (number: number, precision = 2, dimension = 1000, suffix = ''): string => {\n\tconst k = Math.pow(10, precision);\n\n\tlet numberStr = String(number);\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\n\t} else if (Math.abs(number) > dimension) {\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\n\t}\n\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\n\n\treturn numberStr;\n};\n\n/**\n * Обрезать текст под три точки\n * @param string\n * @param max_length - максимальное количество символов текста, остальное обрежеться\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\n */\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\n\tif (string == undefined) return '';\n\n\tstring += '';\n\tif (max_length == undefined || string.length <= max_length) return string;\n\n\tif (pos === 0) {\n\t\tstring = string.substr(string.length - max_length, max_length);\n\t\tstring = '...' + string;\n\t} else if (pos === 1) {\n\t\tconst string1 = string.substr(0, max_length / 2);\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\n\t\tstring = string1 + '...' + string2;\n\t} else if (pos === 2) {\n\t\tstring = string.substr(0, max_length);\n\t\tstring = string + '...';\n\t}\n\n\treturn string;\n};\n\n/**\n * Сгенерировать строку текста для вывода количества в разном склонении\n * @param num\n * @param ending0 - родительный падеж, множ. число (10 модулей)\n * @param ending1 - именительный падеж, ед. число (1 модуль)\n * @param ending2 - винительный падеж, множ. число (3 модуля)\n */\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\n\t// склонение по множественному числу\n\tif (useI18nLang().value === 'en') {\n\t\tif (num === 1) {\n\t\t\treturn ending1;\n\t\t} else {\n\t\t\treturn ending0;\n\t\t}\n\t}\n\n\tconst num100 = num % 100;\n\tconst num10 = num % 10;\n\n\tif (num100 >= 5 && num100 <= 20) {\n\t\treturn ending0;\n\t} else if (num10 === 0) {\n\t\treturn ending0;\n\t} else if (num10 === 1) {\n\t\treturn ending1;\n\t} else if (num10 >= 2 && num10 <= 4) {\n\t\treturn ending2;\n\t} else if (num10 >= 5 && num10 <= 9) {\n\t\treturn ending0;\n\t} else {\n\t\treturn ending2;\n\t}\n};\n\n/**\n * Перевести строку в родительный падеж\n */\nexport const toRoditPadej = (str: string): string => {\n\tif (useI18nLang().value != 'ru' || str == '') return str;\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tstr = str + 'а';\n\t\tstr = str.replace('оа', 'о');\n\t\tstr = str.replace('аяа', 'ой');\n\t\tstr = str.replace('шийа', 'шого');\n\t\tstr = str.replace('ыйа', 'ого');\n\t\tstr = str.replace('йа', 'я');\n\t\tstr = str.replace('ьа', 'я');\n\t\tstr = str.replace('яа', 'и');\n\t\tstr = str.replace('оваа', 'овой');\n\t\tstr = str.replace('аа', 'ы');\n\t\tstr = str.replace('кия', 'кого');\n\t\tstr = str.replace('каи', 'кой');\n\n\t\tstr_array[index] = str;\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Транслитерация текста\n */\nexport const rusToLatin = (str: string): string => {\n\tconst ru: { [index: string]: string } = {\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\n\t};\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tconst newStr: string[] = [];\n\t\tfor (let i = 0; i < str.length; ++i) {\n\t\t\tnewStr.push(\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\n\t\t\t\t\treturn match.toUpperCase();\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\tstr_array[index] = newStr.join('');\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&amp;`)\n */\nexport const htmlspecialchars = (str: string): string => {\n\tif (typeof (str) == 'string') {\n\t\tstr = str\n\t\t\t.replace(/&/g, '&amp;')\n\t\t\t.replace(/</g, '&lt;')\n\t\t\t.replace(/>/g, '&gt;')\n\t\t\t.replace(/\"/g, '&quot;')\n\t\t\t.replace(/'/g, '&#039;');\n\t}\n\treturn str;\n};\n\n/**\n * Выделить нужное в тексте желтым цветом\n * поиск происходит по строке fieldFilter.values[0]\n */\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\n\tlet regExp: RegExp | null = null;\n\n\tswitch (fieldFilter.operator) {\n\t\tcase 'CONTAINS':\n\t\tcase 'REGEXP':\n\t\t\ttry {\n\t\t\t\tlet regExpString = fieldFilter.values[0];\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\n\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\n\t\t\t} catch (exception) {\n\t\t\t\treturn text;\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\n\n\treturn text;\n};\n\n/**\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\n */\nexport const camelToSnakeCase = (str: string): string | undefined => {\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\n};\n\n/**\n * Получить url изображения флага, по коду страны по стандарту ISO 3166-1 alpha-2\n *\n * @todo Опубликовать в CDN или брать c публичного CDN\n */\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\n\treturn `/controller/file/?src=${urlImage}`;\n};\n\n/**\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\n *\n * Для email ставиться префикс `mailto:`\n */\nexport const addLinkTags = (text: string): string => {\n\tconst domainRegexp = getDomainRegexp();\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\n\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\n\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\n\n\ttext = text.replaceAll('√http', 'http');\n\ttext = text.replaceAll('√', 'http://');\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\n\n\treturn text;\n};\n\n/**\n * Перевести первую букву строки в верхний регистр\n */\nexport const toCapitalize = (str: string): string => {\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\n};\n\n/**\n * Получить случайную строку\n */\nexport const getRandomHash = (length: number = 20): string => {\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\n\n\tlet result = '';\n\tfor (let i = 0; i < length; i++) {\n\t\tresult += l[Math.floor(Math.random() * l.length)];\n\t}\n\n\treturn result;\n};\n"],"names":["genIntHash","string","hash","i","isUrl","url","addCommasWhite","n","nStr","x1","x","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","numberStr","k","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","forms","num100","num10","toRoditPadej","str2","str_array","index","rusToLatin","ru","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExpString","regExp","camelToSnakeCase","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","utils_check","regexpMailto","afterDomainRegexp","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":"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"}
package/utils/string.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { getDomainRegexp as u } from "./check.js";
2
- import { u as n } from "../.chunks/forms-CipZtprq.es.js";
2
+ import { a as n } from "../.chunks/forms-LTK63Ugt.es.js";
3
3
  const i = (e) => {
4
4
  e += "";
5
5
  let l = 0;
@@ -1 +1 @@
1
- {"version":3,"file":"string.js","sources":["../../src/core/utils/string.ts"],"sourcesContent":["/**\r\n * Работа со строками\r\n * @packageDocumentation\r\n */\r\n\r\nimport { getDomainRegexp } from '@/core/utils/check';\r\nimport { useI18nLang } from '@/core/plugins/i18n';\r\n\r\n/**\r\n * Сгенерировать числовой хэш от строки для идентификатора\r\n */\r\nexport const genIntHash = (string: string): number => {\r\n\tstring += '';\r\n\r\n\tlet hash = 0;\r\n\tif (!string.length) return hash;\r\n\r\n\tfor (let i = 0; i < string.length; i++) {\r\n\t\tconst char = string.charCodeAt(i);\r\n\t\thash = ((hash << 5) - hash) + char;\r\n\t\thash = hash & hash;\r\n\t}\r\n\r\n\tif (hash < 0) hash *= -1;\r\n\r\n\treturn hash;\r\n};\r\n\r\n/**\r\n * Проверить что переданная строка является URL\r\n */\r\nexport const isUrl = (url: string): boolean => {\r\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\r\n};\r\n\r\n/**\r\n * Добавляет пробелы между разрядами если требуется\r\n * @param nStr строка с числом\r\n */\r\nexport const addCommasWhite = (n: number | string): string => {\r\n\tlet nStr = n + '';\r\n\r\n\tnStr = nStr.replace('-', '–');\r\n\r\n\tlet x = nStr.split('.');\r\n\tlet x1 = x[0];\r\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\r\n\r\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\r\n\r\n\tconst rgx = /(\\d+)(\\d{3})/;\r\n\twhile (rgx.test(x1)) {\r\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\r\n\t}\r\n\treturn x1 + x2;\r\n};\r\n\r\n/**\r\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\r\n */\r\nexport const nl2br = (str: string): string => {\r\n\tif (str === undefined) return '';\r\n\r\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\r\n};\r\n\r\n/**\r\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\r\n * @param number\r\n * @param precision - точность, количество знаков после запятой\r\n * @param dimension - размерность, по умолчанию 1000\r\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\r\n */\r\nexport const numberWithWord = (number: number, precision = 2, dimension = 1000, suffix = ''): string => {\r\n\tconst k = Math.pow(10, precision);\r\n\r\n\tlet numberStr = String(number);\r\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\r\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\r\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\r\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\r\n\t} else if (Math.abs(number) > dimension) {\r\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\r\n\t}\r\n\r\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\r\n\r\n\treturn numberStr;\r\n};\r\n\r\n/**\r\n * Обрезать текст под три точки\r\n * @param string\r\n * @param max_length - максимальное количество символов текста, остальное обрежеться\r\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\r\n */\r\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\r\n\tif (string == undefined) return '';\r\n\r\n\tstring += '';\r\n\tif (max_length == undefined || string.length <= max_length) return string;\r\n\r\n\tif (pos === 0) {\r\n\t\tstring = string.substr(string.length - max_length, max_length);\r\n\t\tstring = '...' + string;\r\n\t} else if (pos === 1) {\r\n\t\tconst string1 = string.substr(0, max_length / 2);\r\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\r\n\t\tstring = string1 + '...' + string2;\r\n\t} else if (pos === 2) {\r\n\t\tstring = string.substr(0, max_length);\r\n\t\tstring = string + '...';\r\n\t}\r\n\r\n\treturn string;\r\n};\r\n\r\n/**\r\n * Сгенерировать строку текста для вывода количества в разном склонении\r\n * @param num\r\n * @param ending0 - родительный падеж, множ. число (10 модулей)\r\n * @param ending1 - именительный падеж, ед. число (1 модуль)\r\n * @param ending2 - винительный падеж, множ. число (3 модуля)\r\n */\r\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\r\n\t// склонение по множественному числу\r\n\tif (useI18nLang().value === 'en') {\r\n\t\tif (num === 1) {\r\n\t\t\treturn ending1;\r\n\t\t} else {\r\n\t\t\treturn ending0;\r\n\t\t}\r\n\t}\r\n\r\n\tconst num100 = num % 100;\r\n\tconst num10 = num % 10;\r\n\r\n\tif (num100 >= 5 && num100 <= 20) {\r\n\t\treturn ending0;\r\n\t} else if (num10 === 0) {\r\n\t\treturn ending0;\r\n\t} else if (num10 === 1) {\r\n\t\treturn ending1;\r\n\t} else if (num10 >= 2 && num10 <= 4) {\r\n\t\treturn ending2;\r\n\t} else if (num10 >= 5 && num10 <= 9) {\r\n\t\treturn ending0;\r\n\t} else {\r\n\t\treturn ending2;\r\n\t}\r\n};\r\n\r\n/**\r\n * Перевести строку в родительный падеж\r\n */\r\nexport const toRoditPadej = (str: string): string => {\r\n\tif (useI18nLang().value != 'ru' || str == '') return str;\r\n\r\n\tconst str_array = str.split(' ');\r\n\r\n\t$.map(str_array, function (str, index) {\r\n\t\tstr = str + 'а';\r\n\t\tstr = str.replace('оа', 'о');\r\n\t\tstr = str.replace('аяа', 'ой');\r\n\t\tstr = str.replace('шийа', 'шого');\r\n\t\tstr = str.replace('ыйа', 'ого');\r\n\t\tstr = str.replace('йа', 'я');\r\n\t\tstr = str.replace('ьа', 'я');\r\n\t\tstr = str.replace('яа', 'и');\r\n\t\tstr = str.replace('оваа', 'овой');\r\n\t\tstr = str.replace('аа', 'ы');\r\n\t\tstr = str.replace('кия', 'кого');\r\n\t\tstr = str.replace('каи', 'кой');\r\n\r\n\t\tstr_array[index] = str;\r\n\t});\r\n\r\n\tstr = str_array.join(' ');\r\n\r\n\treturn str;\r\n};\r\n\r\n/**\r\n * Транслитерация текста\r\n */\r\nexport const rusToLatin = (str: string): string => {\r\n\tconst ru: { [index: string]: string } = {\r\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\r\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\r\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\r\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\r\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\r\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\r\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\r\n\t};\r\n\r\n\tconst str_array = str.split(' ');\r\n\r\n\t$.map(str_array, function (str, index) {\r\n\t\tconst newStr: string[] = [];\r\n\t\tfor (let i = 0; i < str.length; ++i) {\r\n\t\t\tnewStr.push(\r\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\r\n\t\t\t\t\treturn match.toUpperCase();\r\n\t\t\t\t}),\r\n\t\t\t);\r\n\t\t}\r\n\r\n\t\tstr_array[index] = newStr.join('');\r\n\t});\r\n\r\n\tstr = str_array.join(' ');\r\n\r\n\treturn str;\r\n};\r\n\r\n/**\r\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&amp;`)\r\n */\r\nexport const htmlspecialchars = (str: string): string => {\r\n\tif (typeof (str) == 'string') {\r\n\t\tstr = str\r\n\t\t\t.replace(/&/g, '&amp;')\r\n\t\t\t.replace(/</g, '&lt;')\r\n\t\t\t.replace(/>/g, '&gt;')\r\n\t\t\t.replace(/\"/g, '&quot;')\r\n\t\t\t.replace(/'/g, '&#039;');\r\n\t}\r\n\treturn str;\r\n};\r\n\r\n/**\r\n * Выделить нужное в тексте желтым цветом\r\n * поиск происходит по строке fieldFilter.values[0]\r\n */\r\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\r\n\tlet regExp: RegExp | null = null;\r\n\r\n\tswitch (fieldFilter.operator) {\r\n\t\tcase 'CONTAINS':\r\n\t\tcase 'REGEXP':\r\n\t\t\ttry {\r\n\t\t\t\tlet regExpString = fieldFilter.values[0];\r\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\r\n\r\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\r\n\t\t\t} catch (exception) {\r\n\t\t\t\treturn text;\r\n\t\t\t}\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\r\n\r\n\treturn text;\r\n};\r\n\r\n/**\r\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\r\n */\r\nexport const camelToSnakeCase = (str: string): string | undefined => {\r\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\r\n};\r\n\r\n/**\r\n * Получить url изображения флага, по коду страны (RU, GB)\r\n */\r\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\r\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\r\n\treturn `/controller/file/?src=${urlImage}`;\r\n};\r\n\r\n/**\r\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\r\n *\r\n * Для email ставиться префикс `mailto:`\r\n */\r\nexport const addLinkTags = (text: string): string => {\r\n\tconst domainRegexp = getDomainRegexp();\r\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\r\n\r\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\r\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\r\n\r\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\r\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\r\n\r\n\ttext = text.replaceAll('√http', 'http');\r\n\ttext = text.replaceAll('√', 'http://');\r\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\r\n\r\n\treturn text;\r\n};\r\n\r\n/**\r\n * Перевести первую букву строки в верхний регистр\r\n */\r\nexport const toCapitalize = (str: string): string => {\r\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\r\n};\r\n\r\n/**\r\n * Получить случайную строку\r\n */\r\nexport const getRandomHash = (length: number = 20): string => {\r\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\r\n\r\n\tlet result = '';\r\n\tfor (let i = 0; i < length; i++) {\r\n\t\tresult += l[Math.floor(Math.random() * l.length)];\r\n\t}\r\n\r\n\treturn result;\r\n};\r\n"],"names":["genIntHash","string","hash","i","char","isUrl","url","addCommasWhite","n","nStr","x","x1","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","k","numberStr","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","useI18nLang","num100","num10","toRoditPadej","str_array","index","rusToLatin","ru","newStr","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExp","regExpString","camelToSnakeCase","_a","token","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","getDomainRegexp","afterDomainRegexp","regexpMailto","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":";;AAWa,MAAAA,IAAa,CAACC,MAA2B;AAC3C,EAAAA,KAAA;AAEV,MAAIC,IAAO;AACP,MAAA,CAACD,EAAO,OAAe,QAAAC;AAE3B,WAASC,IAAI,GAAGA,IAAIF,EAAO,QAAQE,KAAK;AACjC,UAAAC,IAAOH,EAAO,WAAWE,CAAC;AACvB,IAAAD,KAAAA,KAAQ,KAAKA,IAAQE,GAC9BF,IAAOA,IAAOA;AAAA,EAAA;AAGX,SAAAA,IAAO,MAAWA,KAAA,KAEfA;AACR,GAKaG,IAAQ,CAACC,MACd,0CAA0C,KAAKA,CAAG,GAO7CC,IAAiB,CAACC,MAA+B;AAC7D,MAAIC,IAAOD,IAAI;AAER,EAAAC,IAAAA,EAAK,QAAQ,KAAK,GAAG;AAExB,MAAAC,IAAID,EAAK,MAAM,GAAG,GAClBE,IAAKD,EAAE,CAAC,GACRE,IAAMF,EAAE,SAAS,IAAM,MAAMA,EAAE,CAAC,IAAK;AAEzC,MAAIC,EAAG,QAAQ,QAAQ,EAAE,EAAE,UAAU,EAAU,QAAAF;AAE/C,QAAMI,IAAM;AACL,SAAAA,EAAI,KAAKF,CAAE;AACZ,IAAAA,IAAAA,EAAG,QAAQE,GAAK,OAAiB;AAEvC,SAAOF,IAAKC;AACb,GAKaE,IAAQ,CAACC,MACjBA,MAAQ,SAAkB,KAEvBA,EAAI,QAAQ,eAAe,MAAM,GAU5BC,IAAiB,CAACC,GAAgBC,IAAY,GAAGC,IAAY,KAAMC,IAAS,OAAe;AACvG,QAAMC,IAAI,KAAK,IAAI,IAAIH,CAAS;AAE5B,MAAAI,IAAY,OAAOL,CAAM;AACzB,SAAA,KAAK,IAAIA,CAAM,IAAI,KAAK,IAAIE,GAAW,CAAC,IAC3CG,IAAY,KAAK,MAAML,IAAS,KAAK,IAAIE,GAAW,CAAC,IAAIE,CAAC,IAAIA,IAAI,cAAcD,IAAS,aAC/E,KAAK,IAAIH,CAAM,IAAI,KAAK,IAAIE,GAAW,CAAC,IAClDG,IAAY,KAAK,MAAML,IAAS,KAAK,IAAIE,GAAW,CAAC,IAAIE,CAAC,IAAIA,IAAI,cAAcD,IAAS,aAC/E,KAAK,IAAIH,CAAM,IAAIE,MACjBG,IAAA,KAAK,MAAML,IAASE,IAAYE,CAAC,IAAIA,IAAI,cAAcD,IAAS,aAGjEE,IAAAA,EAAU,QAAQ,mBAAmB,OAAO,GAEjDA;AACR,GAQaC,IAAW,CAACtB,GAAgBuB,GAAoBC,IAAiB,MAAc;AACvF,MAAAxB,KAAU,KAAkB,QAAA;AAGhC,MADUA,KAAA,IACNuB,KAAc,QAAavB,EAAO,UAAUuB,EAAmB,QAAAvB;AAEnE,MAAIwB,MAAQ;AACX,IAAAxB,IAASA,EAAO,OAAOA,EAAO,SAASuB,GAAYA,CAAU,GAC7DvB,IAAS,QAAQA;AAAA,WACPwB,MAAQ,GAAG;AACrB,UAAMC,IAAUzB,EAAO,OAAO,GAAGuB,IAAa,CAAC,GACzCG,IAAU1B,EAAO,OAAOA,EAAO,SAASuB,IAAa,GAAG,KAAK,KAAKA,IAAa,CAAC,CAAC;AACvF,IAAAvB,IAASyB,IAAU,QAAQC;AAAA,EAAA,MAC5B,CAAWF,MAAQ,MACTxB,IAAAA,EAAO,OAAO,GAAGuB,CAAU,GACpCvB,IAASA,IAAS;AAGZ,SAAAA;AACR,GASa2B,IAAe,CAACC,GAAaC,GAAiBC,GAAiBC,MAA4B;AAEnG,MAAAC,EAAA,EAAc,UAAU;AAC3B,WAAIJ,MAAQ,IACJE,IAEAD;AAIT,QAAMI,IAASL,IAAM,KACfM,IAAQN,IAAM;AAEhB,SAAAK,KAAU,KAAKA,KAAU,MAElBC,MAAU,IADbL,IAGGK,MAAU,IACbJ,IACGI,KAAS,KAAKA,KAAS,IAC1BH,IACGG,KAAS,KAAKA,KAAS,IAC1BL,IAEAE;AAET,GAKaI,IAAe,CAACrB,MAAwB;AACpD,MAAIkB,EAAc,EAAA,SAAS,QAAQlB,KAAO,GAAW,QAAAA;AAE/C,QAAAsB,IAAYtB,EAAI,MAAM,GAAG;AAE/B,WAAE,IAAIsB,GAAW,SAAUtB,GAAKuB,GAAO;AACtCvB,IAAAA,IAAMA,IAAM,KACZA,IAAMA,EAAI,QAAQ,MAAM,GAAG,GAC3BA,IAAMA,EAAI,QAAQ,OAAO,IAAI,GAC7BA,IAAMA,EAAI,QAAQ,QAAQ,MAAM,GAChCA,IAAMA,EAAI,QAAQ,OAAO,KAAK,GAC9BA,IAAMA,EAAI,QAAQ,MAAM,GAAG,GAC3BA,IAAMA,EAAI,QAAQ,MAAM,GAAG,GAC3BA,IAAMA,EAAI,QAAQ,MAAM,GAAG,GAC3BA,IAAMA,EAAI,QAAQ,QAAQ,MAAM,GAChCA,IAAMA,EAAI,QAAQ,MAAM,GAAG,GAC3BA,IAAMA,EAAI,QAAQ,OAAO,MAAM,GAC/BA,IAAMA,EAAI,QAAQ,OAAO,KAAK,GAE9BsB,EAAUC,CAAK,IAAIvB;AAAAA,EAAA,CACnB,GAEKA,IAAAsB,EAAU,KAAK,GAAG,GAEjBtB;AACR,GAKawB,IAAa,CAACxB,MAAwB;AAClD,QAAMyB,IAAkC;AAAA,IACvC,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAC7C,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAC7C,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAC7C,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAC7C,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,IAC7C,GAAK;AAAA,IAAM,GAAK;AAAA,IAAQ,GAAK;AAAA,IAAI,GAAK;AAAA,IAAK,GAAK;AAAA,IAChD,GAAK;AAAA,IAAK,GAAK;AAAA,IAAK,GAAK;AAAA,EAC1B,GAEMH,IAAYtB,EAAI,MAAM,GAAG;AAE/B,WAAE,IAAIsB,GAAW,SAAUtB,GAAKuB,GAAO;AACtC,UAAMG,IAAmB,CAAC;AAC1B,aAAStC,IAAI,GAAGA,IAAIY,EAAI,QAAQ,EAAEZ;AAC1B,MAAAsC,EAAA;AAAA,QACND,EAAGzB,EAAIZ,CAAC,CAAC,KAAKqC,EAAGzB,EAAIZ,CAAC,EAAE,YAAa,CAAA,KAAK,QAAaY,EAAIZ,CAAC,KAAKqC,EAAGzB,EAAIZ,CAAC,EAAE,YAAa,CAAA,EAAE,QAAQ,QAAQ,SAAUuC,GAAO;AAC1H,iBAAOA,EAAM,YAAY;AAAA,QACzB,CAAA;AAAA,MACF;AAGD,IAAAL,EAAUC,CAAK,IAAIG,EAAO,KAAK,EAAE;AAAA,EAAA,CACjC,GAEK1B,IAAAsB,EAAU,KAAK,GAAG,GAEjBtB;AACR,GAKa4B,IAAmB,CAAC5B,OAC5B,OAAQA,KAAQ,aACnBA,IAAMA,EACJ,QAAQ,MAAM,OAAO,EACrB,QAAQ,MAAM,MAAM,EACpB,QAAQ,MAAM,MAAM,EACpB,QAAQ,MAAM,QAAQ,EACtB,QAAQ,MAAM,QAAQ,IAElBA,IAOK6B,IAAgB,CAACC,GAAcC,MAA+E;AAC1H,MAAIC,IAAwB;AAE5B,UAAQD,EAAY,UAAU;AAAA,IAC7B,KAAK;AAAA,IACL,KAAK;AACA,UAAA;AACC,YAAAE,IAAeF,EAAY,OAAO,CAAC;AACvC,QAAIA,EAAY,YAAY,iBAAyBE,EAAa,QAAQ,eAAe,MAAM,IAE/FD,IAAS,IAAI,OAAO,MAAMC,IAAe,KAAK,IAAI;AAAA,cAC/B;AACZ,eAAAH;AAAA,MAAA;AAGR;AAAA,EAAA;AAGK,SAAAA,IAAAA,EAAK,QAAQE,GAAS,yBAAyB,GAE/CF;AACR,GAKaI,IAAmB,CAAClC,MAAoC;;AAC7D,UAAAmC,IAAAnC,EAAI,MAAM,oEAAoE,MAA9E,gBAAAmC,EAAiF,IAAI,CAASC,MAAAA,EAAM,YAAY,GAAG,KAAK;AAChI,GAKaC,IAA2B,CAACC,MAEjC,yBADU,yBAAyBA,EAAY,YAAgB,IAAA,MAC9B,IAQ5BC,IAAc,CAACT,MAAyB;AACpD,QAAMU,IAAeC,EAAgB,GAC/BC,IAAoB,qCAEpBC,IAAe,IAAI,OAAO,iCAAiCH,CAAY,GAAGE,CAAiB,KAAK,KAAK;AACpG,EAAAZ,IAAAA,EAAK,QAAQa,GAAc,iEAAiE;AAE7F,QAAAC,IAAa,IAAI,OAAO,6BAA+BJ,CAAY,GAAGE,CAAiB,KAAK,KAAK;AAChG,SAAAZ,IAAAA,EAAK,QAAQc,GAAY,oEAAoE,GAE7Fd,IAAAA,EAAK,WAAW,SAAS,MAAM,GAC/BA,IAAAA,EAAK,WAAW,KAAK,SAAS,GAC9BA,IAAAA,EAAK,WAAW,aAAa,EAAE,GAE/BA;AACR,GAKae,IAAe,CAAC7C,MACrBA,EAAI,OAAO,CAAC,EAAE,gBAAgBA,EAAI,MAAM,CAAC,GAMpC8C,IAAgB,CAACC,IAAiB,OAAe;AAC7D,QAAM,IAAI;AAEV,MAAIC,IAAS;AACb,WAAS5D,IAAI,GAAGA,IAAI2D,GAAQ3D;AACjB,IAAA4D,KAAA,EAAE,KAAK,MAAM,KAAK,OAAW,IAAA,EAAE,MAAM,CAAC;AAG1C,SAAAA;AACR;"}
1
+ {"version":3,"file":"string.js","sources":["../../src/core/utils/string.ts"],"sourcesContent":["/**\n * Работа со строками\n * @packageDocumentation\n */\n\nimport { getDomainRegexp } from '@/core/utils/check';\nimport { useI18nLang } from '@/core/plugins/i18n';\n\n/**\n * Сгенерировать числовой хэш от строки для идентификатора\n */\nexport const genIntHash = (string: string): number => {\n\tstring += '';\n\n\tlet hash = 0;\n\tif (!string.length) return hash;\n\n\tfor (let i = 0; i < string.length; i++) {\n\t\tconst char = string.charCodeAt(i);\n\t\thash = ((hash << 5) - hash) + char;\n\t\thash = hash & hash;\n\t}\n\n\tif (hash < 0) hash *= -1;\n\n\treturn hash;\n};\n\n/**\n * Проверить что переданная строка является URL\n */\nexport const isUrl = (url: string): boolean => {\n\treturn /^\\w+:\\/\\/([\\w-]+\\.)+[\\w-]+(:\\d+)?(\\/|$)/.test(url);\n};\n\n/**\n * Добавляет пробелы между разрядами если требуется\n * @param nStr строка с числом\n */\nexport const addCommasWhite = (n: number | string): string => {\n\tlet nStr = n + '';\n\n\tnStr = nStr.replace('-', '–');\n\n\tlet x = nStr.split('.');\n\tlet x1 = x[0];\n\tlet x2 = (x.length > 1) ? ('.' + x[1]) : '';\n\n\tif (x1.replace(/[+–]/, '').length <= 4) return nStr;\n\n\tconst rgx = /(\\d+)(\\d{3})/;\n\twhile (rgx.test(x1)) {\n\t\tx1 = x1.replace(rgx, '$1' + ' ' + '$2');\n\t}\n\treturn x1 + x2;\n};\n\n/**\n * Вставляет HTML-код разрыва строки перед каждым переводом строки\n */\nexport const nl2br = (str: string): string => {\n\tif (str === undefined) return '';\n\n\treturn str.replace(/\\r\\n|\\r|\\n/g, '<br>');\n};\n\n/**\n * Перевести число без деситичной приставки в число с деситичной приставкой степеней тысячи (с параметрами по умолчанию 1255 -> '1.26 K')\n * @param number\n * @param precision - точность, количество знаков после запятой\n * @param dimension - размерность, по умолчанию 1000\n * @param suffix - суффикс к десятичной приставке (по умолчанию выводится латинская заглавная буква)\n */\nexport const numberWithWord = (number: number, precision = 2, dimension = 1000, suffix = ''): string => {\n\tconst k = Math.pow(10, precision);\n\n\tlet numberStr = String(number);\n\tif (Math.abs(number) > Math.pow(dimension, 3)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 3) * k) / k + ' <small>G' + suffix + '</small>';\n\t} else if (Math.abs(number) > Math.pow(dimension, 2)) {\n\t\tnumberStr = Math.round(number / Math.pow(dimension, 2) * k) / k + ' <small>M' + suffix + '</small>';\n\t} else if (Math.abs(number) > dimension) {\n\t\tnumberStr = Math.round(number / dimension * k) / k + ' <small>K' + suffix + '</small>';\n\t}\n\n\tnumberStr = numberStr.replace(/^(-?\\d+)(\\d{3})/, '$1 $2');\n\n\treturn numberStr;\n};\n\n/**\n * Обрезать текст под три точки\n * @param string\n * @param max_length - максимальное количество символов текста, остальное обрежеться\n * @param pos - область обрезки 0-начало | 1-середина | 2-конец строки\n */\nexport const ellipsis = (string: string, max_length: number, pos: 0 | 1 | 2 = 1): string => {\n\tif (string == undefined) return '';\n\n\tstring += '';\n\tif (max_length == undefined || string.length <= max_length) return string;\n\n\tif (pos === 0) {\n\t\tstring = string.substr(string.length - max_length, max_length);\n\t\tstring = '...' + string;\n\t} else if (pos === 1) {\n\t\tconst string1 = string.substr(0, max_length / 2);\n\t\tconst string2 = string.substr(string.length - max_length / 2, Math.ceil(max_length / 2));\n\t\tstring = string1 + '...' + string2;\n\t} else if (pos === 2) {\n\t\tstring = string.substr(0, max_length);\n\t\tstring = string + '...';\n\t}\n\n\treturn string;\n};\n\n/**\n * Сгенерировать строку текста для вывода количества в разном склонении\n * @param num\n * @param ending0 - родительный падеж, множ. число (10 модулей)\n * @param ending1 - именительный падеж, ед. число (1 модуль)\n * @param ending2 - винительный падеж, множ. число (3 модуля)\n */\nexport const numberEnding = (num: number, ending0: string, ending1: string, ending2: string): string => {\n\t// склонение по множественному числу\n\tif (useI18nLang().value === 'en') {\n\t\tif (num === 1) {\n\t\t\treturn ending1;\n\t\t} else {\n\t\t\treturn ending0;\n\t\t}\n\t}\n\n\tconst num100 = num % 100;\n\tconst num10 = num % 10;\n\n\tif (num100 >= 5 && num100 <= 20) {\n\t\treturn ending0;\n\t} else if (num10 === 0) {\n\t\treturn ending0;\n\t} else if (num10 === 1) {\n\t\treturn ending1;\n\t} else if (num10 >= 2 && num10 <= 4) {\n\t\treturn ending2;\n\t} else if (num10 >= 5 && num10 <= 9) {\n\t\treturn ending0;\n\t} else {\n\t\treturn ending2;\n\t}\n};\n\n/**\n * Перевести строку в родительный падеж\n */\nexport const toRoditPadej = (str: string): string => {\n\tif (useI18nLang().value != 'ru' || str == '') return str;\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tstr = str + 'а';\n\t\tstr = str.replace('оа', 'о');\n\t\tstr = str.replace('аяа', 'ой');\n\t\tstr = str.replace('шийа', 'шого');\n\t\tstr = str.replace('ыйа', 'ого');\n\t\tstr = str.replace('йа', 'я');\n\t\tstr = str.replace('ьа', 'я');\n\t\tstr = str.replace('яа', 'и');\n\t\tstr = str.replace('оваа', 'овой');\n\t\tstr = str.replace('аа', 'ы');\n\t\tstr = str.replace('кия', 'кого');\n\t\tstr = str.replace('каи', 'кой');\n\n\t\tstr_array[index] = str;\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Транслитерация текста\n */\nexport const rusToLatin = (str: string): string => {\n\tconst ru: { [index: string]: string } = {\n\t\t'а': 'a', 'б': 'b', 'в': 'v', 'г': 'g', 'д': 'd',\n\t\t'е': 'e', 'ё': 'e', 'ж': 'j', 'з': 'z', 'и': 'i',\n\t\t'й': 'i', 'к': 'k', 'л': 'l', 'м': 'm', 'н': 'n',\n\t\t'о': 'o', 'п': 'p', 'р': 'r', 'с': 's', 'т': 't',\n\t\t'у': 'u', 'ф': 'f', 'х': 'h', 'ц': 'c', 'ч': 'ch',\n\t\t'ш': 'sh', 'щ': 'shch', 'ъ': '', 'ы': 'y', 'ь': '',\n\t\t'э': 'e', 'ю': 'u', 'я': 'ya',\n\t};\n\n\tconst str_array = str.split(' ');\n\n\t$.map(str_array, function (str, index) {\n\t\tconst newStr: string[] = [];\n\t\tfor (let i = 0; i < str.length; ++i) {\n\t\t\tnewStr.push(\n\t\t\t\tru[str[i]] || ru[str[i].toLowerCase()] == undefined && str[i] || ru[str[i].toLowerCase()].replace(/^(.)/, function (match) {\n\t\t\t\t\treturn match.toUpperCase();\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\tstr_array[index] = newStr.join('');\n\t});\n\n\tstr = str_array.join(' ');\n\n\treturn str;\n};\n\n/**\n * Замена html-символов (`&`, `<`, `>`, `\"`, `'`) на имена литер (`&` -> `&amp;`)\n */\nexport const htmlspecialchars = (str: string): string => {\n\tif (typeof (str) == 'string') {\n\t\tstr = str\n\t\t\t.replace(/&/g, '&amp;')\n\t\t\t.replace(/</g, '&lt;')\n\t\t\t.replace(/>/g, '&gt;')\n\t\t\t.replace(/\"/g, '&quot;')\n\t\t\t.replace(/'/g, '&#039;');\n\t}\n\treturn str;\n};\n\n/**\n * Выделить нужное в тексте желтым цветом\n * поиск происходит по строке fieldFilter.values[0]\n */\nexport const highlightHtml = (text: string, fieldFilter: { operator: 'CONTAINS' | 'REGEXP', values: string[] }): string => {\n\tlet regExp: RegExp | null = null;\n\n\tswitch (fieldFilter.operator) {\n\t\tcase 'CONTAINS':\n\t\tcase 'REGEXP':\n\t\t\ttry {\n\t\t\t\tlet regExpString = fieldFilter.values[0];\n\t\t\t\tif (fieldFilter.operator != 'REGEXP') regExpString = regExpString.replace(/([()\\[\\]])/g, '\\\\$1');\n\n\t\t\t\tregExp = new RegExp('(' + regExpString + ')', 'gi');\n\t\t\t} catch (exception) {\n\t\t\t\treturn text;\n\t\t\t}\n\n\t\t\tbreak;\n\t}\n\n\ttext = text.replace(regExp!, '<b class=\"found\">$1</b>');\n\n\treturn text;\n};\n\n/**\n * Пример: logHTTPCodesHundreds => log_http_codes_hundreds\n */\nexport const camelToSnakeCase = (str: string): string | undefined => {\n\treturn str.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g)?.map(token => token.toLowerCase()).join('_');\n};\n\n/**\n * Получить url изображения флага, по коду страны по стандарту ISO 3166-1 alpha-2\n *\n * @todo Опубликовать в CDN или брать c публичного CDN\n */\nexport const genFlagLinkByCountryCode = (countryCode: string) => {\n\tconst urlImage = '/cloud/common/flags/' + countryCode.toUpperCase() + '.svg';\n\treturn `/controller/file/?src=${urlImage}`;\n};\n\n/**\n * Обернуть все ссылки и email в тексте в html-тег `<a>`.\n *\n * Для email ставиться префикс `mailto:`\n */\nexport const addLinkTags = (text: string): string => {\n\tconst domainRegexp = getDomainRegexp();\n\tconst afterDomainRegexp = '(([\\\\/?\\\\w&=%+#;:-]*(\\\\.\\\\w+)?))*';\n\n\tconst regexpMailto = new RegExp(`(^|[\\\\s>(),])([a-z0-9а-яё_.]+@${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpMailto, `$1<a href=\"mailto:$2\" target=\"_blank\" rel=\"noopener\">↑[$2]↓</a>`);\n\n\tconst regexpLink = new RegExp(`(^|[\\\\s>(),])(https?:\\/\\/)?(${domainRegexp}${afterDomainRegexp})`, 'gui');\n\ttext = text.replace(regexpLink, `$1<a href=\"√$2$3\" target=\"_blank\" rel=\"nofollow noopener\">$2$3</a>`);\n\n\ttext = text.replaceAll('√http', 'http');\n\ttext = text.replaceAll('√', 'http://');\n\ttext = text.replaceAll(/(↑\\[|]↓)/g, '');\n\n\treturn text;\n};\n\n/**\n * Перевести первую букву строки в верхний регистр\n */\nexport const toCapitalize = (str: string): string => {\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\n};\n\n/**\n * Получить случайную строку\n */\nexport const getRandomHash = (length: number = 20): string => {\n\tconst l = 'AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890';\n\n\tlet result = '';\n\tfor (let i = 0; i < length; i++) {\n\t\tresult += l[Math.floor(Math.random() * l.length)];\n\t}\n\n\treturn result;\n};\n"],"names":["genIntHash","string","hash","i","char","isUrl","url","addCommasWhite","n","nStr","x","x1","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","k","numberStr","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","useI18nLang","num100","num10","toRoditPadej","str_array","index","rusToLatin","ru","newStr","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExp","regExpString","camelToSnakeCase","_a","token","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","getDomainRegexp","afterDomainRegexp","regexpMailto","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"system.amd.js","sources":["../../src/core/utils/system.ts"],"sourcesContent":["/**\r\n * Системные утилиты\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Ждать, пока условие истинно\r\n *\r\n * @param condition - функция, вычисляющая значение\r\n * @param period - период в мс между выполнениями condition()\r\n * @param timeout - максмальное время ожидания в мс\r\n */\r\nexport const waitWhile = (condition: Function, period: number = 10, timeout = 30_000) => {\r\n\tif (!condition()) return;\r\n\r\n\treturn new Promise<void>((resolve, reject) => {\r\n\t\tconst timerTimeout = setTimeout(() => {\r\n\t\t\tclearInterval(timer);\r\n\r\n\t\t\treject('Condition is no resolve: timeout');\r\n\t\t}, timeout);\r\n\r\n\t\tconst timer = setInterval(() => {\r\n\t\t\tif (!condition()) {\r\n\t\t\t\tclearTimeout(timerTimeout);\r\n\t\t\t\tclearInterval(timer);\r\n\r\n\t\t\t\tresolve();\r\n\t\t\t}\r\n\t\t}, period);\r\n\t});\r\n};\r\n\r\n/**\r\n * Приостановить выполнение кода\r\n *\r\n * @param delay - длительность паузы в мс\r\n */\r\nexport const sleep = (delay: number) => {\r\n\treturn new Promise<void>((resolve) => {\r\n\t\tsetTimeout(() => {\r\n\t\t\tresolve();\r\n\t\t}, delay);\r\n\t});\r\n};\r\n\r\n/**\r\n * Приостановить выполнение кода пока условие истинно\r\n * @param condition - функция, вычисляющая значение\r\n * @param delay - время задержки в мс\r\n * @param period - период в мс между выполнениями condition()\r\n */\r\nexport const sleepWhile = (condition: Function, delay: number = 300, period: number = 10) => {\r\n\tif (!condition()) return;\r\n\r\n\treturn new Promise<void>(resolve => {\r\n\t\tconst timerDelay = setTimeout(() => {\r\n\t\t\tclearInterval(timer);\r\n\r\n\t\t\tresolve();\r\n\t\t}, delay);\r\n\r\n\t\tconst timer = setInterval(() => {\r\n\t\t\tif (!condition()) {\r\n\t\t\t\tclearTimeout(timerDelay);\r\n\t\t\t\tclearInterval(timer);\r\n\r\n\t\t\t\tresolve();\r\n\t\t\t}\r\n\t\t}, period);\r\n\t});\r\n};\r\n"],"names":["waitWhile","condition","period","timeout","timerTimeout","timer","resolve","sleep","delay","sleepWhile","timerDelay"],"mappings":"yFAYO,MAAAA,EAAA,CAAAC,EAAAC,EAAA,GAAAC,EAAA,MAAA,CACN,GAAAF,EAAA,6BAGC,MAAAG,EAAA,WAAA,IAAA,4DAMAC,EAAA,YAAA,IAAA,CACCJ,EAAA,qCAICK,EAAA,MAEO,CAAA,CAEX,EAOaC,EAAAC,GACZ,IAAA,QAAAF,GAAA,iBAEEA,EAAA,KACO,CAAA,EAUHG,EAAA,CAAAR,EAAAO,EAAA,IAAAN,EAAA,KAAA,CACN,GAAAD,EAAA,EAEA,OAAA,IAAA,QAAAK,GAAA,CACC,MAAAI,EAAA,WAAA,IAAA,kBAGCJ,EAAA,MAGDD,EAAA,YAAA,IAAA,CACCJ,EAAA,qCAICK,EAAA,MAEO,CAAA,CAEX"}
1
+ {"version":3,"file":"system.amd.js","sources":["../../src/core/utils/system.ts"],"sourcesContent":["/**\n * Системные утилиты\n * @packageDocumentation\n */\n\n/**\n * Ждать, пока условие истинно\n *\n * @param condition - функция, вычисляющая значение\n * @param period - период в мс между выполнениями condition()\n * @param timeout - максмальное время ожидания в мс\n */\nexport const waitWhile = (condition: Function, period: number = 10, timeout = 30_000) => {\n\tif (!condition()) return;\n\n\treturn new Promise<void>((resolve, reject) => {\n\t\tconst timerTimeout = setTimeout(() => {\n\t\t\tclearInterval(timer);\n\n\t\t\treject('Condition is no resolve: timeout');\n\t\t}, timeout);\n\n\t\tconst timer = setInterval(() => {\n\t\t\tif (!condition()) {\n\t\t\t\tclearTimeout(timerTimeout);\n\t\t\t\tclearInterval(timer);\n\n\t\t\t\tresolve();\n\t\t\t}\n\t\t}, period);\n\t});\n};\n\n/**\n * Приостановить выполнение кода\n *\n * @param delay - длительность паузы в мс\n */\nexport const sleep = (delay: number) => {\n\treturn new Promise<void>((resolve) => {\n\t\tsetTimeout(() => {\n\t\t\tresolve();\n\t\t}, delay);\n\t});\n};\n\n/**\n * Приостановить выполнение кода пока условие истинно\n * @param condition - функция, вычисляющая значение\n * @param delay - время задержки в мс\n * @param period - период в мс между выполнениями condition()\n */\nexport const sleepWhile = (condition: Function, delay: number = 300, period: number = 10) => {\n\tif (!condition()) return;\n\n\treturn new Promise<void>(resolve => {\n\t\tconst timerDelay = setTimeout(() => {\n\t\t\tclearInterval(timer);\n\n\t\t\tresolve();\n\t\t}, delay);\n\n\t\tconst timer = setInterval(() => {\n\t\t\tif (!condition()) {\n\t\t\t\tclearTimeout(timerDelay);\n\t\t\t\tclearInterval(timer);\n\n\t\t\t\tresolve();\n\t\t\t}\n\t\t}, period);\n\t});\n};\n"],"names":["waitWhile","condition","period","timeout","timerTimeout","timer","resolve","sleep","delay","sleepWhile","timerDelay"],"mappings":"yFAYO,MAAAA,EAAA,CAAAC,EAAAC,EAAA,GAAAC,EAAA,MAAA,CACN,GAAAF,EAAA,6BAGC,MAAAG,EAAA,WAAA,IAAA,4DAMAC,EAAA,YAAA,IAAA,CACCJ,EAAA,qCAICK,EAAA,MAEO,CAAA,CAEX,EAOaC,EAAAC,GACZ,IAAA,QAAAF,GAAA,iBAEEA,EAAA,KACO,CAAA,EAUHG,EAAA,CAAAR,EAAAO,EAAA,IAAAN,EAAA,KAAA,CACN,GAAAD,EAAA,EAEA,OAAA,IAAA,QAAAK,GAAA,CACC,MAAAI,EAAA,WAAA,IAAA,kBAGCJ,EAAA,MAGDD,EAAA,YAAA,IAAA,CACCJ,EAAA,qCAICK,EAAA,MAEO,CAAA,CAEX"}
@@ -1 +1 @@
1
- {"version":3,"file":"system.js","sources":["../../src/core/utils/system.ts"],"sourcesContent":["/**\r\n * Системные утилиты\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Ждать, пока условие истинно\r\n *\r\n * @param condition - функция, вычисляющая значение\r\n * @param period - период в мс между выполнениями condition()\r\n * @param timeout - максмальное время ожидания в мс\r\n */\r\nexport const waitWhile = (condition: Function, period: number = 10, timeout = 30_000) => {\r\n\tif (!condition()) return;\r\n\r\n\treturn new Promise<void>((resolve, reject) => {\r\n\t\tconst timerTimeout = setTimeout(() => {\r\n\t\t\tclearInterval(timer);\r\n\r\n\t\t\treject('Condition is no resolve: timeout');\r\n\t\t}, timeout);\r\n\r\n\t\tconst timer = setInterval(() => {\r\n\t\t\tif (!condition()) {\r\n\t\t\t\tclearTimeout(timerTimeout);\r\n\t\t\t\tclearInterval(timer);\r\n\r\n\t\t\t\tresolve();\r\n\t\t\t}\r\n\t\t}, period);\r\n\t});\r\n};\r\n\r\n/**\r\n * Приостановить выполнение кода\r\n *\r\n * @param delay - длительность паузы в мс\r\n */\r\nexport const sleep = (delay: number) => {\r\n\treturn new Promise<void>((resolve) => {\r\n\t\tsetTimeout(() => {\r\n\t\t\tresolve();\r\n\t\t}, delay);\r\n\t});\r\n};\r\n\r\n/**\r\n * Приостановить выполнение кода пока условие истинно\r\n * @param condition - функция, вычисляющая значение\r\n * @param delay - время задержки в мс\r\n * @param period - период в мс между выполнениями condition()\r\n */\r\nexport const sleepWhile = (condition: Function, delay: number = 300, period: number = 10) => {\r\n\tif (!condition()) return;\r\n\r\n\treturn new Promise<void>(resolve => {\r\n\t\tconst timerDelay = setTimeout(() => {\r\n\t\t\tclearInterval(timer);\r\n\r\n\t\t\tresolve();\r\n\t\t}, delay);\r\n\r\n\t\tconst timer = setInterval(() => {\r\n\t\t\tif (!condition()) {\r\n\t\t\t\tclearTimeout(timerDelay);\r\n\t\t\t\tclearInterval(timer);\r\n\r\n\t\t\t\tresolve();\r\n\t\t\t}\r\n\t\t}, period);\r\n\t});\r\n};\r\n"],"names":["waitWhile","condition","period","timeout","resolve","reject","timerTimeout","timer","sleep","delay","sleepWhile","timerDelay"],"mappings":"AAYO,MAAMA,IAAY,CAACC,GAAqBC,IAAiB,IAAIC,IAAU,QAAW;AACpF,MAACF;AAEL,WAAO,IAAI,QAAc,CAACG,GAASC,MAAW;AACvC,YAAAC,IAAe,WAAW,MAAM;AACrC,sBAAcC,CAAK,GAEnBF,EAAO,kCAAkC;AAAA,SACvCF,CAAO,GAEJI,IAAQ,YAAY,MAAM;AAC3B,QAACN,QACJ,aAAaK,CAAY,GACzB,cAAcC,CAAK,GAEXH,EAAA;AAAA,SAEPF,CAAM;AAAA,IAAA,CACT;AACF,GAOaM,IAAQ,CAACC,MACd,IAAI,QAAc,CAACL,MAAY;AACrC,aAAW,MAAM;AACR,IAAAA,EAAA;AAAA,KACNK,CAAK;AAAA,CACR,GASWC,IAAa,CAACT,GAAqBQ,IAAgB,KAAKP,IAAiB,OAAO;AACxF,MAACD;AAEE,WAAA,IAAI,QAAc,CAAWG,MAAA;AAC7B,YAAAO,IAAa,WAAW,MAAM;AACnC,sBAAcJ,CAAK,GAEXH,EAAA;AAAA,SACNK,CAAK,GAEFF,IAAQ,YAAY,MAAM;AAC3B,QAACN,QACJ,aAAaU,CAAU,GACvB,cAAcJ,CAAK,GAEXH,EAAA;AAAA,SAEPF,CAAM;AAAA,IAAA,CACT;AACF;"}
1
+ {"version":3,"file":"system.js","sources":["../../src/core/utils/system.ts"],"sourcesContent":["/**\n * Системные утилиты\n * @packageDocumentation\n */\n\n/**\n * Ждать, пока условие истинно\n *\n * @param condition - функция, вычисляющая значение\n * @param period - период в мс между выполнениями condition()\n * @param timeout - максмальное время ожидания в мс\n */\nexport const waitWhile = (condition: Function, period: number = 10, timeout = 30_000) => {\n\tif (!condition()) return;\n\n\treturn new Promise<void>((resolve, reject) => {\n\t\tconst timerTimeout = setTimeout(() => {\n\t\t\tclearInterval(timer);\n\n\t\t\treject('Condition is no resolve: timeout');\n\t\t}, timeout);\n\n\t\tconst timer = setInterval(() => {\n\t\t\tif (!condition()) {\n\t\t\t\tclearTimeout(timerTimeout);\n\t\t\t\tclearInterval(timer);\n\n\t\t\t\tresolve();\n\t\t\t}\n\t\t}, period);\n\t});\n};\n\n/**\n * Приостановить выполнение кода\n *\n * @param delay - длительность паузы в мс\n */\nexport const sleep = (delay: number) => {\n\treturn new Promise<void>((resolve) => {\n\t\tsetTimeout(() => {\n\t\t\tresolve();\n\t\t}, delay);\n\t});\n};\n\n/**\n * Приостановить выполнение кода пока условие истинно\n * @param condition - функция, вычисляющая значение\n * @param delay - время задержки в мс\n * @param period - период в мс между выполнениями condition()\n */\nexport const sleepWhile = (condition: Function, delay: number = 300, period: number = 10) => {\n\tif (!condition()) return;\n\n\treturn new Promise<void>(resolve => {\n\t\tconst timerDelay = setTimeout(() => {\n\t\t\tclearInterval(timer);\n\n\t\t\tresolve();\n\t\t}, delay);\n\n\t\tconst timer = setInterval(() => {\n\t\t\tif (!condition()) {\n\t\t\t\tclearTimeout(timerDelay);\n\t\t\t\tclearInterval(timer);\n\n\t\t\t\tresolve();\n\t\t\t}\n\t\t}, period);\n\t});\n};\n"],"names":["waitWhile","condition","period","timeout","resolve","reject","timerTimeout","timer","sleep","delay","sleepWhile","timerDelay"],"mappings":"AAYO,MAAMA,IAAY,CAACC,GAAqBC,IAAiB,IAAIC,IAAU,QAAW;AACpF,MAACF;AAEL,WAAO,IAAI,QAAc,CAACG,GAASC,MAAW;AACvC,YAAAC,IAAe,WAAW,MAAM;AACrC,sBAAcC,CAAK,GAEnBF,EAAO,kCAAkC;AAAA,SACvCF,CAAO,GAEJI,IAAQ,YAAY,MAAM;AAC3B,QAACN,QACJ,aAAaK,CAAY,GACzB,cAAcC,CAAK,GAEXH,EAAA;AAAA,SAEPF,CAAM;AAAA,IAAA,CACT;AACF,GAOaM,IAAQ,CAACC,MACd,IAAI,QAAc,CAACL,MAAY;AACrC,aAAW,MAAM;AACR,IAAAA,EAAA;AAAA,KACNK,CAAK;AAAA,CACR,GASWC,IAAa,CAACT,GAAqBQ,IAAgB,KAAKP,IAAiB,OAAO;AACxF,MAACD;AAEE,WAAA,IAAI,QAAc,CAAWG,MAAA;AAC7B,YAAAO,IAAa,WAAW,MAAM;AACnC,sBAAcJ,CAAK,GAEXH,EAAA;AAAA,SACNK,CAAK,GAEFF,IAAQ,YAAY,MAAM;AAC3B,QAACN,QACJ,aAAaU,CAAU,GACvB,cAAcJ,CAAK,GAEXH,EAAA;AAAA,SAEPF,CAAM;AAAA,IAAA,CACT;AACF;"}
@@ -1 +1 @@
1
- {"version":3,"file":"url.amd.js","sources":["../../src/core/utils/url.ts"],"sourcesContent":["/**\r\n * Работа с урлами\r\n * @packageDocumentation\r\n */\r\n\r\nimport punycode from 'punycode';\r\n\r\n/**\r\n * Раскодировать все не ASCII символы в домене URL\r\n * @param url - домен в ASCII формате\r\n * @return домен в Unicode формате\r\n */\r\nexport const fromPuny = (url: string = ''): string => {\r\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\r\n\r\n\tif (url.indexOf('xn--') === -1) return url;\r\n\tif (url.indexOf('/') === -1) return punycode.toUnicode(url);\r\n\r\n\tconst host = getHost(url);\r\n\r\n\tlet hostNormal = host.toLowerCase();\r\n\thostNormal = punycode.toUnicode(hostNormal);\r\n\r\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Закодировать все не ASCII символы в домене URL\r\n * @param url - домен в Unicode формате\r\n * @return домен в ASCII формате\r\n */\r\nexport const toPuny = (url: string): string => {\r\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\r\n\r\n\tif (url.indexOf('/') === -1) return punycode.toASCII(url);\r\n\r\n\tconst host = getHost(url);\r\n\r\n\tlet hostNormal = host.toLowerCase();\r\n\thostNormal = punycode.toASCII(hostNormal);\r\n\r\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Получить имя хоста из URL\r\n */\r\nexport const getHost = (url: string): string => {\r\n\treturn url.replace(/(?:^\\w+:\\/\\/)?([^:/]+).*/i, '$1');\r\n};\r\n\r\n/**\r\n * Привести url к стандартному виду (не в пуникоде и хост в нижнем регистре)\r\n */\r\nexport const normalize = (url: string): string => {\r\n\turl = fromPuny(url);\r\n\turl = hostToLowerCase(url);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Перевести в url имя хоста в нижний регистр\r\n */\r\nexport const hostToLowerCase = (url: string): string => {\r\n\tconst host = getHost(url);\r\n\tconst hostNormal = host.toLowerCase();\r\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Получить закодированную строку\r\n */\r\nexport const encode = (string: string): string => { return escape(utf8Encode(string)); };\r\n\r\n/**\r\n * Раскодировать строку, полученную функцией encode\r\n */\r\nexport const decode = (string: string): string => { return utf8Decode(unescape(string)); };\r\n\r\nconst utf8Encode = (string: string): string => {\r\n\tstring = string.replace(/\\r\\n/g, '\\n');\r\n\tlet utftext = '';\r\n\r\n\tfor (let n = 0; n < string.length; n++) {\r\n\t\tconst c = string.charCodeAt(n);\r\n\r\n\t\tif (c < 128) {\r\n\t\t\tutftext += String.fromCharCode(c);\r\n\t\t} else if ((c > 127) && (c < 2048)) {\r\n\t\t\tutftext += String.fromCharCode((c >> 6) | 192);\r\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\r\n\t\t} else {\r\n\t\t\tutftext += String.fromCharCode((c >> 12) | 224);\r\n\t\t\tutftext += String.fromCharCode(((c >> 6) & 63) | 128);\r\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\r\n\t\t}\r\n\t}\r\n\r\n\treturn utftext;\r\n};\r\n\r\n/**\r\n * private method for UTF-8 decoding\r\n */\r\nconst utf8Decode = (utftext: string): string => {\r\n\tlet string = '';\r\n\tlet i = 0;\r\n\tlet c = 0,\r\n\t\tc1 = 0,\r\n\t\tc2 = 0;\r\n\r\n\twhile (i < utftext.length) {\r\n\t\tc = utftext.charCodeAt(i);\r\n\r\n\t\tif (c < 128) {\r\n\t\t\tstring += String.fromCharCode(c);\r\n\t\t\ti++;\r\n\t\t} else if ((c > 191) && (c < 224)) {\r\n\t\t\tc2 = utftext.charCodeAt(i + 1);\r\n\t\t\tstring += String.fromCharCode(((c & 31) << 6) | (c2 & 63));\r\n\t\t\ti += 2;\r\n\t\t} else {\r\n\t\t\tc2 = utftext.charCodeAt(i + 1);\r\n\t\t\tlet c3 = utftext.charCodeAt(i + 2);\r\n\t\t\tstring += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));\r\n\t\t\ti += 3;\r\n\t\t}\r\n\t}\r\n\r\n\treturn string;\r\n};\r\n"],"names":["fromPuny","url","punycode_es6","host","getHost","hostNormal","toPuny","normalize","hostToLowerCase","encode","string","utf8Encode","decode","utf8Decode","n","c","utftext","c2","i"],"mappings":"kIAYa,MAAAA,EAAA,CAAAC,EAAA,KAAA,IACZA,EAAAA,EAAA,QAAA,UAAA,GAAA,EAAA,KAAA,kCAGA,GAAAA,EAAA,QAAA,GAAA,IAAA,GAAA,OAAAC,EAAA,SAAA,UAAAD,CAAA,EAEA,MAAAE,EAAAC,EAAAH,CAAA,EAEA,IAAAI,EAAAF,EAAA,YAAA,EACA,OAAAE,EAAAH,EAAA,SAAA,UAAAG,CAAA,EAEAF,IAAAE,IAAAJ,EAAAA,EAAA,QAAAE,EAAAE,CAAA,GAEAJ,CACD,EAOaK,EAAAL,GAAA,CAGZ,GAFAA,EAAAA,EAAA,QAAA,UAAA,GAAA,EAAA,KAAA,EAEAA,EAAA,QAAA,GAAA,IAAA,GAAA,OAAAC,EAAA,SAAA,QAAAD,CAAA,EAEA,MAAAE,EAAAC,EAAAH,CAAA,EAEA,IAAAI,EAAAF,EAAA,YAAA,EACA,OAAAE,EAAAH,EAAA,SAAA,QAAAG,CAAA,EAEAF,IAAAE,IAAAJ,EAAAA,EAAA,QAAAE,EAAAE,CAAA,GAEAJ,CACD,EAKaG,EAAAH,+CAOAM,EAAAN,IACZA,EAAAD,EAAAC,CAAA,EACAA,EAAAO,EAAAP,CAAA,EAEAA,GAMYO,EAAAP,GAAA,CACZ,MAAAE,EAAAC,EAAAH,CAAA,EACAI,EAAAF,EAAA,YAAA,EACA,OAAAA,IAAAE,IAAAJ,EAAAA,EAAA,QAAAE,EAAAE,CAAA,GAEAJ,CACD,EAKaQ,EAAAC,GAAuC,OAAAC,EAAAD,CAAA,CAAA,EAKvCE,EAAAF,GAAuCG,EAAA,SAAAH,CAAA,CAAA,EAEpDC,EAAAD,GAAA;YAIC,QAAAI,EAAA,EAAAA,EAAAJ,EAAA,OAAAI,IAAA,yBAGCC,EAAA,IACCC,GAAA,OAAA,aAAAD,CAAA,uHAMAC,GAAA,OAAA,aAAAD,GAAA,EAAA,GAAA,GAAA,mCAED,CAGD,OAAAC,GAMDH,EAAAG,GAAA,cAGCD,EAAA,EAAAE,EAAA,EAIA,KAAAC,EAAAF,EAAA,QAGC,GAFAD,EAAAC,EAAA,WAAAE,CAAA,EAEAH,EAAA,IACCL,GAAA,OAAA,aAAAK,CAAA,EACAG,6CAGAR,GAAA,OAAA,cAAAK,EAAA,KAAA,EAAAE,EAAA,EAAA,WACK,mGAKA,CAIP,OAAAP"}
1
+ {"version":3,"file":"url.amd.js","sources":["../../src/core/utils/url.ts"],"sourcesContent":["/**\n * Работа с урлами\n * @packageDocumentation\n */\n\nimport punycode from 'punycode';\n\n/**\n * Раскодировать все не ASCII символы в домене URL\n * @param url - домен в ASCII формате\n * @return домен в Unicode формате\n */\nexport const fromPuny = (url: string = ''): string => {\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\n\n\tif (url.indexOf('xn--') === -1) return url;\n\tif (url.indexOf('/') === -1) return punycode.toUnicode(url);\n\n\tconst host = getHost(url);\n\n\tlet hostNormal = host.toLowerCase();\n\thostNormal = punycode.toUnicode(hostNormal);\n\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\n\n\treturn url;\n};\n\n/**\n * Закодировать все не ASCII символы в домене URL\n * @param url - домен в Unicode формате\n * @return домен в ASCII формате\n */\nexport const toPuny = (url: string): string => {\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\n\n\tif (url.indexOf('/') === -1) return punycode.toASCII(url);\n\n\tconst host = getHost(url);\n\n\tlet hostNormal = host.toLowerCase();\n\thostNormal = punycode.toASCII(hostNormal);\n\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\n\n\treturn url;\n};\n\n/**\n * Получить имя хоста из URL\n */\nexport const getHost = (url: string): string => {\n\treturn url.replace(/(?:^\\w+:\\/\\/)?([^:/]+).*/i, '$1');\n};\n\n/**\n * Привести url к стандартному виду (не в пуникоде и хост в нижнем регистре)\n */\nexport const normalize = (url: string): string => {\n\turl = fromPuny(url);\n\turl = hostToLowerCase(url);\n\n\treturn url;\n};\n\n/**\n * Перевести в url имя хоста в нижний регистр\n */\nexport const hostToLowerCase = (url: string): string => {\n\tconst host = getHost(url);\n\tconst hostNormal = host.toLowerCase();\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\n\n\treturn url;\n};\n\n/**\n * Получить закодированную строку\n */\nexport const encode = (string: string): string => { return escape(utf8Encode(string)); };\n\n/**\n * Раскодировать строку, полученную функцией encode\n */\nexport const decode = (string: string): string => { return utf8Decode(unescape(string)); };\n\nconst utf8Encode = (string: string): string => {\n\tstring = string.replace(/\\r\\n/g, '\\n');\n\tlet utftext = '';\n\n\tfor (let n = 0; n < string.length; n++) {\n\t\tconst c = string.charCodeAt(n);\n\n\t\tif (c < 128) {\n\t\t\tutftext += String.fromCharCode(c);\n\t\t} else if ((c > 127) && (c < 2048)) {\n\t\t\tutftext += String.fromCharCode((c >> 6) | 192);\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\n\t\t} else {\n\t\t\tutftext += String.fromCharCode((c >> 12) | 224);\n\t\t\tutftext += String.fromCharCode(((c >> 6) & 63) | 128);\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\n\t\t}\n\t}\n\n\treturn utftext;\n};\n\n/**\n * private method for UTF-8 decoding\n */\nconst utf8Decode = (utftext: string): string => {\n\tlet string = '';\n\tlet i = 0;\n\tlet c = 0,\n\t\tc1 = 0,\n\t\tc2 = 0;\n\n\twhile (i < utftext.length) {\n\t\tc = utftext.charCodeAt(i);\n\n\t\tif (c < 128) {\n\t\t\tstring += String.fromCharCode(c);\n\t\t\ti++;\n\t\t} else if ((c > 191) && (c < 224)) {\n\t\t\tc2 = utftext.charCodeAt(i + 1);\n\t\t\tstring += String.fromCharCode(((c & 31) << 6) | (c2 & 63));\n\t\t\ti += 2;\n\t\t} else {\n\t\t\tc2 = utftext.charCodeAt(i + 1);\n\t\t\tlet c3 = utftext.charCodeAt(i + 2);\n\t\t\tstring += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));\n\t\t\ti += 3;\n\t\t}\n\t}\n\n\treturn string;\n};\n"],"names":["fromPuny","url","punycode_es6","host","getHost","hostNormal","toPuny","normalize","hostToLowerCase","encode","string","utf8Encode","decode","utf8Decode","n","c","utftext","c2","i"],"mappings":"kIAYa,MAAAA,EAAA,CAAAC,EAAA,KAAA,IACZA,EAAAA,EAAA,QAAA,UAAA,GAAA,EAAA,KAAA,kCAGA,GAAAA,EAAA,QAAA,GAAA,IAAA,GAAA,OAAAC,EAAA,SAAA,UAAAD,CAAA,EAEA,MAAAE,EAAAC,EAAAH,CAAA,EAEA,IAAAI,EAAAF,EAAA,YAAA,EACA,OAAAE,EAAAH,EAAA,SAAA,UAAAG,CAAA,EAEAF,IAAAE,IAAAJ,EAAAA,EAAA,QAAAE,EAAAE,CAAA,GAEAJ,CACD,EAOaK,EAAAL,GAAA,CAGZ,GAFAA,EAAAA,EAAA,QAAA,UAAA,GAAA,EAAA,KAAA,EAEAA,EAAA,QAAA,GAAA,IAAA,GAAA,OAAAC,EAAA,SAAA,QAAAD,CAAA,EAEA,MAAAE,EAAAC,EAAAH,CAAA,EAEA,IAAAI,EAAAF,EAAA,YAAA,EACA,OAAAE,EAAAH,EAAA,SAAA,QAAAG,CAAA,EAEAF,IAAAE,IAAAJ,EAAAA,EAAA,QAAAE,EAAAE,CAAA,GAEAJ,CACD,EAKaG,EAAAH,+CAOAM,EAAAN,IACZA,EAAAD,EAAAC,CAAA,EACAA,EAAAO,EAAAP,CAAA,EAEAA,GAMYO,EAAAP,GAAA,CACZ,MAAAE,EAAAC,EAAAH,CAAA,EACAI,EAAAF,EAAA,YAAA,EACA,OAAAA,IAAAE,IAAAJ,EAAAA,EAAA,QAAAE,EAAAE,CAAA,GAEAJ,CACD,EAKaQ,EAAAC,GAAuC,OAAAC,EAAAD,CAAA,CAAA,EAKvCE,EAAAF,GAAuCG,EAAA,SAAAH,CAAA,CAAA,EAEpDC,EAAAD,GAAA;YAIC,QAAAI,EAAA,EAAAA,EAAAJ,EAAA,OAAAI,IAAA,yBAGCC,EAAA,IACCC,GAAA,OAAA,aAAAD,CAAA,uHAMAC,GAAA,OAAA,aAAAD,GAAA,EAAA,GAAA,GAAA,mCAED,CAGD,OAAAC,GAMDH,EAAAG,GAAA,cAGCD,EAAA,EAAAE,EAAA,EAIA,KAAAC,EAAAF,EAAA,QAGC,GAFAD,EAAAC,EAAA,WAAAE,CAAA,EAEAH,EAAA,IACCL,GAAA,OAAA,aAAAK,CAAA,EACAG,6CAGAR,GAAA,OAAA,cAAAK,EAAA,KAAA,EAAAE,EAAA,EAAA,WACK,mGAKA,CAIP,OAAAP"}
package/utils/url.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"url.js","sources":["../../src/core/utils/url.ts"],"sourcesContent":["/**\r\n * Работа с урлами\r\n * @packageDocumentation\r\n */\r\n\r\nimport punycode from 'punycode';\r\n\r\n/**\r\n * Раскодировать все не ASCII символы в домене URL\r\n * @param url - домен в ASCII формате\r\n * @return домен в Unicode формате\r\n */\r\nexport const fromPuny = (url: string = ''): string => {\r\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\r\n\r\n\tif (url.indexOf('xn--') === -1) return url;\r\n\tif (url.indexOf('/') === -1) return punycode.toUnicode(url);\r\n\r\n\tconst host = getHost(url);\r\n\r\n\tlet hostNormal = host.toLowerCase();\r\n\thostNormal = punycode.toUnicode(hostNormal);\r\n\r\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Закодировать все не ASCII символы в домене URL\r\n * @param url - домен в Unicode формате\r\n * @return домен в ASCII формате\r\n */\r\nexport const toPuny = (url: string): string => {\r\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\r\n\r\n\tif (url.indexOf('/') === -1) return punycode.toASCII(url);\r\n\r\n\tconst host = getHost(url);\r\n\r\n\tlet hostNormal = host.toLowerCase();\r\n\thostNormal = punycode.toASCII(hostNormal);\r\n\r\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Получить имя хоста из URL\r\n */\r\nexport const getHost = (url: string): string => {\r\n\treturn url.replace(/(?:^\\w+:\\/\\/)?([^:/]+).*/i, '$1');\r\n};\r\n\r\n/**\r\n * Привести url к стандартному виду (не в пуникоде и хост в нижнем регистре)\r\n */\r\nexport const normalize = (url: string): string => {\r\n\turl = fromPuny(url);\r\n\turl = hostToLowerCase(url);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Перевести в url имя хоста в нижний регистр\r\n */\r\nexport const hostToLowerCase = (url: string): string => {\r\n\tconst host = getHost(url);\r\n\tconst hostNormal = host.toLowerCase();\r\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\r\n\r\n\treturn url;\r\n};\r\n\r\n/**\r\n * Получить закодированную строку\r\n */\r\nexport const encode = (string: string): string => { return escape(utf8Encode(string)); };\r\n\r\n/**\r\n * Раскодировать строку, полученную функцией encode\r\n */\r\nexport const decode = (string: string): string => { return utf8Decode(unescape(string)); };\r\n\r\nconst utf8Encode = (string: string): string => {\r\n\tstring = string.replace(/\\r\\n/g, '\\n');\r\n\tlet utftext = '';\r\n\r\n\tfor (let n = 0; n < string.length; n++) {\r\n\t\tconst c = string.charCodeAt(n);\r\n\r\n\t\tif (c < 128) {\r\n\t\t\tutftext += String.fromCharCode(c);\r\n\t\t} else if ((c > 127) && (c < 2048)) {\r\n\t\t\tutftext += String.fromCharCode((c >> 6) | 192);\r\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\r\n\t\t} else {\r\n\t\t\tutftext += String.fromCharCode((c >> 12) | 224);\r\n\t\t\tutftext += String.fromCharCode(((c >> 6) & 63) | 128);\r\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\r\n\t\t}\r\n\t}\r\n\r\n\treturn utftext;\r\n};\r\n\r\n/**\r\n * private method for UTF-8 decoding\r\n */\r\nconst utf8Decode = (utftext: string): string => {\r\n\tlet string = '';\r\n\tlet i = 0;\r\n\tlet c = 0,\r\n\t\tc1 = 0,\r\n\t\tc2 = 0;\r\n\r\n\twhile (i < utftext.length) {\r\n\t\tc = utftext.charCodeAt(i);\r\n\r\n\t\tif (c < 128) {\r\n\t\t\tstring += String.fromCharCode(c);\r\n\t\t\ti++;\r\n\t\t} else if ((c > 191) && (c < 224)) {\r\n\t\t\tc2 = utftext.charCodeAt(i + 1);\r\n\t\t\tstring += String.fromCharCode(((c & 31) << 6) | (c2 & 63));\r\n\t\t\ti += 2;\r\n\t\t} else {\r\n\t\t\tc2 = utftext.charCodeAt(i + 1);\r\n\t\t\tlet c3 = utftext.charCodeAt(i + 2);\r\n\t\t\tstring += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));\r\n\t\t\ti += 3;\r\n\t\t}\r\n\t}\r\n\r\n\treturn string;\r\n};\r\n"],"names":["fromPuny","url","punycode","host","getHost","hostNormal","toPuny","normalize","hostToLowerCase","encode","string","utf8Encode","decode","utf8Decode","utftext","n","c","i","c2","c3"],"mappings":";AAYa,MAAAA,IAAW,CAACC,IAAc,OAAe;AAGrD,MAFAA,IAAMA,EAAI,QAAQ,WAAW,GAAG,EAAE,KAAK,GAEnCA,EAAI,QAAQ,MAAM,MAAM,GAAW,QAAAA;AACnC,MAAAA,EAAI,QAAQ,GAAG,MAAM,GAAW,QAAAC,EAAS,UAAUD,CAAG;AAEpD,QAAAE,IAAOC,EAAQH,CAAG;AAEpB,MAAAI,IAAaF,EAAK,YAAY;AACrB,SAAAE,IAAAH,EAAS,UAAUG,CAAU,GAEtCF,MAASE,MAAYJ,IAAMA,EAAI,QAAQE,GAAME,CAAU,IAEpDJ;AACR,GAOaK,IAAS,CAACL,MAAwB;AAG1C,MAFJA,IAAMA,EAAI,QAAQ,WAAW,GAAG,EAAE,KAAK,GAEnCA,EAAI,QAAQ,GAAG,MAAM,GAAW,QAAAC,EAAS,QAAQD,CAAG;AAElD,QAAAE,IAAOC,EAAQH,CAAG;AAEpB,MAAAI,IAAaF,EAAK,YAAY;AACrB,SAAAE,IAAAH,EAAS,QAAQG,CAAU,GAEpCF,MAASE,MAAYJ,IAAMA,EAAI,QAAQE,GAAME,CAAU,IAEpDJ;AACR,GAKaG,IAAU,CAACH,MAChBA,EAAI,QAAQ,6BAA6B,IAAI,GAMxCM,IAAY,CAACN,OACzBA,IAAMD,EAASC,CAAG,GAClBA,IAAMO,EAAgBP,CAAG,GAElBA,IAMKO,IAAkB,CAACP,MAAwB;AACjD,QAAAE,IAAOC,EAAQH,CAAG,GAClBI,IAAaF,EAAK,YAAY;AACpC,SAAIA,MAASE,MAAYJ,IAAMA,EAAI,QAAQE,GAAME,CAAU,IAEpDJ;AACR,GAKaQ,IAAS,CAACC,MAAoC,OAAOC,EAAWD,CAAM,CAAC,GAKvEE,IAAS,CAACF,MAAoCG,EAAW,SAASH,CAAM,CAAC,GAEhFC,IAAa,CAACD,MAA2B;AACrC,EAAAA,IAAAA,EAAO,QAAQ,SAAS;AAAA,CAAI;AACrC,MAAII,IAAU;AAEd,WAASC,IAAI,GAAGA,IAAIL,EAAO,QAAQK,KAAK;AACjC,UAAAC,IAAIN,EAAO,WAAWK,CAAC;AAE7B,IAAIC,IAAI,MACIF,KAAA,OAAO,aAAaE,CAAC,IACrBA,IAAI,OAASA,IAAI,QAC5BF,KAAW,OAAO,aAAcE,KAAK,IAAK,GAAG,GAC7CF,KAAW,OAAO,aAAcE,IAAI,KAAM,GAAG,MAE7CF,KAAW,OAAO,aAAcE,KAAK,KAAM,GAAG,GAC9CF,KAAW,OAAO,aAAeE,KAAK,IAAK,KAAM,GAAG,GACpDF,KAAW,OAAO,aAAcE,IAAI,KAAM,GAAG;AAAA,EAC9C;AAGM,SAAAF;AACR,GAKMD,IAAa,CAACC,MAA4B;AAC/C,MAAIJ,IAAS,IACTO,IAAI,GACJD,IAAI,GAEPE,IAAK;AAEC,SAAAD,IAAIH,EAAQ;AAGlB,QAFIE,IAAAF,EAAQ,WAAWG,CAAC,GAEpBD,IAAI;AACG,MAAAN,KAAA,OAAO,aAAaM,CAAC,GAC/BC;AAAA,aACWD,IAAI,OAASA,IAAI;AACvB,MAAAE,IAAAJ,EAAQ,WAAWG,IAAI,CAAC,GAC7BP,KAAU,OAAO,cAAeM,IAAI,OAAO,IAAME,IAAK,EAAG,GACpDD,KAAA;AAAA,SACC;AACD,MAAAC,IAAAJ,EAAQ,WAAWG,IAAI,CAAC;AAC7B,UAAIE,IAAKL,EAAQ,WAAWG,IAAI,CAAC;AACvB,MAAAP,KAAA,OAAO,cAAeM,IAAI,OAAO,MAAQE,IAAK,OAAO,IAAMC,IAAK,EAAG,GACxEF,KAAA;AAAA,IAAA;AAIA,SAAAP;AACR;"}
1
+ {"version":3,"file":"url.js","sources":["../../src/core/utils/url.ts"],"sourcesContent":["/**\n * Работа с урлами\n * @packageDocumentation\n */\n\nimport punycode from 'punycode';\n\n/**\n * Раскодировать все не ASCII символы в домене URL\n * @param url - домен в ASCII формате\n * @return домен в Unicode формате\n */\nexport const fromPuny = (url: string = ''): string => {\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\n\n\tif (url.indexOf('xn--') === -1) return url;\n\tif (url.indexOf('/') === -1) return punycode.toUnicode(url);\n\n\tconst host = getHost(url);\n\n\tlet hostNormal = host.toLowerCase();\n\thostNormal = punycode.toUnicode(hostNormal);\n\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\n\n\treturn url;\n};\n\n/**\n * Закодировать все не ASCII символы в домене URL\n * @param url - домен в Unicode формате\n * @return домен в ASCII формате\n */\nexport const toPuny = (url: string): string => {\n\turl = url.replace(/[\\r\\n]/g, ' ').trim();\n\n\tif (url.indexOf('/') === -1) return punycode.toASCII(url);\n\n\tconst host = getHost(url);\n\n\tlet hostNormal = host.toLowerCase();\n\thostNormal = punycode.toASCII(hostNormal);\n\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\n\n\treturn url;\n};\n\n/**\n * Получить имя хоста из URL\n */\nexport const getHost = (url: string): string => {\n\treturn url.replace(/(?:^\\w+:\\/\\/)?([^:/]+).*/i, '$1');\n};\n\n/**\n * Привести url к стандартному виду (не в пуникоде и хост в нижнем регистре)\n */\nexport const normalize = (url: string): string => {\n\turl = fromPuny(url);\n\turl = hostToLowerCase(url);\n\n\treturn url;\n};\n\n/**\n * Перевести в url имя хоста в нижний регистр\n */\nexport const hostToLowerCase = (url: string): string => {\n\tconst host = getHost(url);\n\tconst hostNormal = host.toLowerCase();\n\tif (host !== hostNormal) url = url.replace(host, hostNormal);\n\n\treturn url;\n};\n\n/**\n * Получить закодированную строку\n */\nexport const encode = (string: string): string => { return escape(utf8Encode(string)); };\n\n/**\n * Раскодировать строку, полученную функцией encode\n */\nexport const decode = (string: string): string => { return utf8Decode(unescape(string)); };\n\nconst utf8Encode = (string: string): string => {\n\tstring = string.replace(/\\r\\n/g, '\\n');\n\tlet utftext = '';\n\n\tfor (let n = 0; n < string.length; n++) {\n\t\tconst c = string.charCodeAt(n);\n\n\t\tif (c < 128) {\n\t\t\tutftext += String.fromCharCode(c);\n\t\t} else if ((c > 127) && (c < 2048)) {\n\t\t\tutftext += String.fromCharCode((c >> 6) | 192);\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\n\t\t} else {\n\t\t\tutftext += String.fromCharCode((c >> 12) | 224);\n\t\t\tutftext += String.fromCharCode(((c >> 6) & 63) | 128);\n\t\t\tutftext += String.fromCharCode((c & 63) | 128);\n\t\t}\n\t}\n\n\treturn utftext;\n};\n\n/**\n * private method for UTF-8 decoding\n */\nconst utf8Decode = (utftext: string): string => {\n\tlet string = '';\n\tlet i = 0;\n\tlet c = 0,\n\t\tc1 = 0,\n\t\tc2 = 0;\n\n\twhile (i < utftext.length) {\n\t\tc = utftext.charCodeAt(i);\n\n\t\tif (c < 128) {\n\t\t\tstring += String.fromCharCode(c);\n\t\t\ti++;\n\t\t} else if ((c > 191) && (c < 224)) {\n\t\t\tc2 = utftext.charCodeAt(i + 1);\n\t\t\tstring += String.fromCharCode(((c & 31) << 6) | (c2 & 63));\n\t\t\ti += 2;\n\t\t} else {\n\t\t\tc2 = utftext.charCodeAt(i + 1);\n\t\t\tlet c3 = utftext.charCodeAt(i + 2);\n\t\t\tstring += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));\n\t\t\ti += 3;\n\t\t}\n\t}\n\n\treturn string;\n};\n"],"names":["fromPuny","url","punycode","host","getHost","hostNormal","toPuny","normalize","hostToLowerCase","encode","string","utf8Encode","decode","utf8Decode","utftext","n","c","i","c2","c3"],"mappings":";AAYa,MAAAA,IAAW,CAACC,IAAc,OAAe;AAGrD,MAFAA,IAAMA,EAAI,QAAQ,WAAW,GAAG,EAAE,KAAK,GAEnCA,EAAI,QAAQ,MAAM,MAAM,GAAW,QAAAA;AACnC,MAAAA,EAAI,QAAQ,GAAG,MAAM,GAAW,QAAAC,EAAS,UAAUD,CAAG;AAEpD,QAAAE,IAAOC,EAAQH,CAAG;AAEpB,MAAAI,IAAaF,EAAK,YAAY;AACrB,SAAAE,IAAAH,EAAS,UAAUG,CAAU,GAEtCF,MAASE,MAAYJ,IAAMA,EAAI,QAAQE,GAAME,CAAU,IAEpDJ;AACR,GAOaK,IAAS,CAACL,MAAwB;AAG1C,MAFJA,IAAMA,EAAI,QAAQ,WAAW,GAAG,EAAE,KAAK,GAEnCA,EAAI,QAAQ,GAAG,MAAM,GAAW,QAAAC,EAAS,QAAQD,CAAG;AAElD,QAAAE,IAAOC,EAAQH,CAAG;AAEpB,MAAAI,IAAaF,EAAK,YAAY;AACrB,SAAAE,IAAAH,EAAS,QAAQG,CAAU,GAEpCF,MAASE,MAAYJ,IAAMA,EAAI,QAAQE,GAAME,CAAU,IAEpDJ;AACR,GAKaG,IAAU,CAACH,MAChBA,EAAI,QAAQ,6BAA6B,IAAI,GAMxCM,IAAY,CAACN,OACzBA,IAAMD,EAASC,CAAG,GAClBA,IAAMO,EAAgBP,CAAG,GAElBA,IAMKO,IAAkB,CAACP,MAAwB;AACjD,QAAAE,IAAOC,EAAQH,CAAG,GAClBI,IAAaF,EAAK,YAAY;AACpC,SAAIA,MAASE,MAAYJ,IAAMA,EAAI,QAAQE,GAAME,CAAU,IAEpDJ;AACR,GAKaQ,IAAS,CAACC,MAAoC,OAAOC,EAAWD,CAAM,CAAC,GAKvEE,IAAS,CAACF,MAAoCG,EAAW,SAASH,CAAM,CAAC,GAEhFC,IAAa,CAACD,MAA2B;AACrC,EAAAA,IAAAA,EAAO,QAAQ,SAAS;AAAA,CAAI;AACrC,MAAII,IAAU;AAEd,WAASC,IAAI,GAAGA,IAAIL,EAAO,QAAQK,KAAK;AACjC,UAAAC,IAAIN,EAAO,WAAWK,CAAC;AAE7B,IAAIC,IAAI,MACIF,KAAA,OAAO,aAAaE,CAAC,IACrBA,IAAI,OAASA,IAAI,QAC5BF,KAAW,OAAO,aAAcE,KAAK,IAAK,GAAG,GAC7CF,KAAW,OAAO,aAAcE,IAAI,KAAM,GAAG,MAE7CF,KAAW,OAAO,aAAcE,KAAK,KAAM,GAAG,GAC9CF,KAAW,OAAO,aAAeE,KAAK,IAAK,KAAM,GAAG,GACpDF,KAAW,OAAO,aAAcE,IAAI,KAAM,GAAG;AAAA,EAC9C;AAGM,SAAAF;AACR,GAKMD,IAAa,CAACC,MAA4B;AAC/C,MAAIJ,IAAS,IACTO,IAAI,GACJD,IAAI,GAEPE,IAAK;AAEC,SAAAD,IAAIH,EAAQ;AAGlB,QAFIE,IAAAF,EAAQ,WAAWG,CAAC,GAEpBD,IAAI;AACG,MAAAN,KAAA,OAAO,aAAaM,CAAC,GAC/BC;AAAA,aACWD,IAAI,OAASA,IAAI;AACvB,MAAAE,IAAAJ,EAAQ,WAAWG,IAAI,CAAC,GAC7BP,KAAU,OAAO,cAAeM,IAAI,OAAO,IAAME,IAAK,EAAG,GACpDD,KAAA;AAAA,SACC;AACD,MAAAC,IAAAJ,EAAQ,WAAWG,IAAI,CAAC;AAC7B,UAAIE,IAAKL,EAAQ,WAAWG,IAAI,CAAC;AACvB,MAAAP,KAAA,OAAO,cAAeM,IAAI,OAAO,MAAQE,IAAK,OAAO,IAAMC,IAAK,EAAG,GACxEF,KAAA;AAAA,IAAA;AAIA,SAAAP;AACR;"}
package/web-types.json CHANGED
@@ -1,130 +1,130 @@
1
- {
2
- "name": "@topvisor/ui",
3
- "version": "1.0.0",
4
- "js-types-syntax": "typescript",
5
- "description-markup": "markdown",
6
- "contributions": {
7
- "html": {
8
- "vue-directives": [
9
- {
10
- "name": "top-data",
11
- "source": {
12
- "module": "@topvisor/ui/core/directives/data",
13
- "symbol": "default"
14
- },
15
- "description": "Сохранить данные в элементе",
16
- "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-data--docs",
17
- "argument": {
18
- "name": "name",
19
- "description": "Имя для сохранения данных"
20
- },
21
- "attribute-value": {
22
- "kind": "plain",
23
- "type": "object"
24
- }
25
- },
26
- {
27
- "name": "top-focus",
28
- "source": {
29
- "module": "@topvisor/ui/core/directives/focus",
30
- "symbol": "default"
31
- },
32
- "modifiers": [
33
- {
34
- "name": "onupdate",
35
- "description": "Выполнять фокусировку при динамической установке значения",
36
- "type": "boolean"
37
- }
38
- ],
39
- "description": "Фокусировка на элементе сразу после его отображения",
40
- "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-focus--docs",
41
- "attribute-value": {
42
- "kind": "plain",
43
- "type": "boolean",
44
- "default": true
45
- }
46
- },
47
- {
48
- "name": "top-scroll-into-view",
49
- "source": {
50
- "module": "@topvisor/ui/core/directives/scrollIntoView",
51
- "symbol": "default"
52
- },
53
- "modifiers": [
54
- {
55
- "name": "immediate",
56
- "description": "При использовании скролл будет произведен сразу, иначе скролл будет произведен при после смены видимости элемента, например через v-show",
57
- "type": "boolean"
58
- }
59
- ],
60
- "description": "Произвести автоскролл к элементу",
61
- "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-scrollIntoView--docs",
62
- "attribute-value": {
63
- "kind": "plain",
64
- "type": "object"
65
- }
66
- },
67
- {
68
- "name": "top-scroll-shadow",
69
- "source": {
70
- "module": "@topvisor/ui/core/directives/scrollShadow",
71
- "symbol": "default"
72
- },
73
- "description": "Добавить отображение тени при появлении скролла у элемента",
74
- "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-scrollshadow--docs",
75
- "attribute-value": {
76
- "kind": "plain",
77
- "type": "object"
78
- }
79
- },
80
- {
81
- "name": "top-sticky",
82
- "source": {
83
- "module": "@topvisor/ui/core/directives/sticky",
84
- "symbol": "default"
85
- },
86
- "description": "Добавлять элементу класс-модификатор, если он перейдет в режим sticky",
87
- "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-sticky--docs",
88
- "modifiers": [
89
- {
90
- "name": "bottom",
91
- "description": "Когда область видимости будет ниже элемента, дополнительный класс удалится",
92
- "type": "boolean"
93
- }
94
- ],
95
- "attribute-value": {
96
- "kind": "plain",
97
- "type": "string",
98
- "default": "top-sticky"
99
- }
100
- },
101
- {
102
- "name": "top-swim-up",
103
- "source": {
104
- "module": "@topvisor/ui/core/directives/swimUp",
105
- "symbol": "default"
106
- },
107
- "description": "Реализует анимацию подплытия блоков при скролле",
108
- "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-swimup--docs",
109
- "attribute-value": {
110
- "kind": "plain",
111
- "type": "object"
112
- }
113
- },
114
- {
115
- "name": "top-tooltip",
116
- "source": {
117
- "module": "@topvisor/ui/core/directives/tooltip",
118
- "symbol": "default"
119
- },
120
- "description": "Добавление всплывающей подсказки к элементу",
121
- "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-tooltip--docs",
122
- "attribute-value": {
123
- "kind": "expression",
124
- "type": "object"
125
- }
126
- }
127
- ]
128
- }
129
- }
130
- }
1
+ {
2
+ "name": "@topvisor/ui",
3
+ "version": "1.0.0",
4
+ "js-types-syntax": "typescript",
5
+ "description-markup": "markdown",
6
+ "contributions": {
7
+ "html": {
8
+ "vue-directives": [
9
+ {
10
+ "name": "top-data",
11
+ "source": {
12
+ "module": "@topvisor/ui/core/directives/data",
13
+ "symbol": "default"
14
+ },
15
+ "description": "Сохранить данные в элементе",
16
+ "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-data--docs",
17
+ "argument": {
18
+ "name": "name",
19
+ "description": "Имя для сохранения данных"
20
+ },
21
+ "attribute-value": {
22
+ "kind": "plain",
23
+ "type": "object"
24
+ }
25
+ },
26
+ {
27
+ "name": "top-focus",
28
+ "source": {
29
+ "module": "@topvisor/ui/core/directives/focus",
30
+ "symbol": "default"
31
+ },
32
+ "modifiers": [
33
+ {
34
+ "name": "onupdate",
35
+ "description": "Выполнять фокусировку при динамической установке значения",
36
+ "type": "boolean"
37
+ }
38
+ ],
39
+ "description": "Фокусировка на элементе сразу после его отображения",
40
+ "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-focus--docs",
41
+ "attribute-value": {
42
+ "kind": "plain",
43
+ "type": "boolean",
44
+ "default": true
45
+ }
46
+ },
47
+ {
48
+ "name": "top-scroll-into-view",
49
+ "source": {
50
+ "module": "@topvisor/ui/core/directives/scrollIntoView",
51
+ "symbol": "default"
52
+ },
53
+ "modifiers": [
54
+ {
55
+ "name": "immediate",
56
+ "description": "При использовании скролл будет произведен сразу, иначе скролл будет произведен при после смены видимости элемента, например через v-show",
57
+ "type": "boolean"
58
+ }
59
+ ],
60
+ "description": "Произвести автоскролл к элементу",
61
+ "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-scrollIntoView--docs",
62
+ "attribute-value": {
63
+ "kind": "plain",
64
+ "type": "object"
65
+ }
66
+ },
67
+ {
68
+ "name": "top-scroll-shadow",
69
+ "source": {
70
+ "module": "@topvisor/ui/core/directives/scrollShadow",
71
+ "symbol": "default"
72
+ },
73
+ "description": "Добавить отображение тени при появлении скролла у элемента",
74
+ "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-scrollshadow--docs",
75
+ "attribute-value": {
76
+ "kind": "plain",
77
+ "type": "object"
78
+ }
79
+ },
80
+ {
81
+ "name": "top-sticky",
82
+ "source": {
83
+ "module": "@topvisor/ui/core/directives/sticky",
84
+ "symbol": "default"
85
+ },
86
+ "description": "Добавлять элементу класс-модификатор, если он перейдет в режим sticky",
87
+ "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-sticky--docs",
88
+ "modifiers": [
89
+ {
90
+ "name": "bottom",
91
+ "description": "Когда область видимости будет ниже элемента, дополнительный класс удалится",
92
+ "type": "boolean"
93
+ }
94
+ ],
95
+ "attribute-value": {
96
+ "kind": "plain",
97
+ "type": "string",
98
+ "default": "top-sticky"
99
+ }
100
+ },
101
+ {
102
+ "name": "top-swim-up",
103
+ "source": {
104
+ "module": "@topvisor/ui/core/directives/swimUp",
105
+ "symbol": "default"
106
+ },
107
+ "description": "Реализует анимацию подплытия блоков при скролле",
108
+ "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-swimup--docs",
109
+ "attribute-value": {
110
+ "kind": "plain",
111
+ "type": "object"
112
+ }
113
+ },
114
+ {
115
+ "name": "top-tooltip",
116
+ "source": {
117
+ "module": "@topvisor/ui/core/directives/tooltip",
118
+ "symbol": "default"
119
+ },
120
+ "description": "Добавление всплывающей подсказки к элементу",
121
+ "doc-url": "https://ui.topvisor.com/?path=/docs/core-directives-tooltip--docs",
122
+ "attribute-value": {
123
+ "kind": "expression",
124
+ "type": "object"
125
+ }
126
+ }
127
+ ]
128
+ }
129
+ }
130
+ }
@@ -1 +0,0 @@
1
- {"version":3,"file":"datepicker-BC31NE5M.es.js","sources":["../../src/components/forms/inputDate/datepicker.ts"],"sourcesContent":["import { toRef, watch } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport { dateFormat } from '@/core/utils/date';\r\n\r\nimport css from '@/components/forms/inputDate/datepicker.css?inline';\r\n\r\nCore.insertStyleToPage(css);\r\n\r\nconst $ = (el: HTMLInputElement) => {\r\n\tif (!Core.$?.ui?.datepicker) {\r\n\t\tconsole.info('Для работы datepicker требуется глобальная загрузка jQuery UI Datepicker');\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tCore.$.datepicker.setDefaults({\r\n\t\tdateFormat: Core.state.dateFormat.toLowerCase().replace('m', 'mm').replace('y', 'yy').replace('d', 'dd'),\r\n\t});\r\n\r\n\treturn Core.$(el);\r\n};\r\n\r\nexport function connectDatepicker(el: HTMLInputElement, options: any) {\r\n\treturn $(el)?.datepicker(options);\r\n}\r\n\r\nlet dateFormatted;\r\nlet delimiter: string;\r\nlet dateNumbersCount: number;\r\nlet delimitersIndexes: number[];\r\n\r\nwatch(toRef(Core.state.dateFormat), () => {\r\n\t// генерация отформатированной даты, извлечение из нее разделителей и их индексов\r\n\tdateFormatted = dateFormat('2000-01-01');\r\n\tdelimiter = dateFormatted.match(/\\D/)?.[0] ?? '-';\r\n\tdateNumbersCount = dateFormatted.replace(/\\D+/g, '').length;\r\n\tdelimitersIndexes = [];\r\n\r\n\tfor (let i = 0; i < dateFormatted.length; i++) {\r\n\t\tif (dateFormatted[i] === delimiter) {\r\n\t\t\tdelimitersIndexes.push(i);\r\n\t\t}\r\n\t}\r\n}, { immediate: true });\r\n\r\n/**\r\n * Автоформат при вводе в поле с датой\r\n */\r\nexport function oninput(e: any) {\r\n\tlet selectionPos = e.target.selectionEnd;\r\n\tlet value = e.target.value;\r\n\r\n\t// разбить занчение на две половины - до и после каретки\r\n\t// удалить все символы, кроме цифр\r\n\tlet valueChunkLeft = value.substring(0, selectionPos).replace(/\\D+/g, '');\r\n\tlet valueChunkRight = value.substring(selectionPos).replace(/\\D+/g, '');\r\n\r\n\tlet extraNumbersCount = valueChunkLeft.length + valueChunkRight.length - dateNumbersCount;\r\n\tif (extraNumbersCount > 0) {\r\n\t\t// // количество цифр больше требуемого - удалить лишние\r\n\t\tvalueChunkLeft = valueChunkLeft.substring(0, dateNumbersCount);\r\n\r\n\t\tconst valueChunkRightMaxLength = dateNumbersCount - valueChunkLeft.length;\r\n\t\tvalueChunkRight = valueChunkRight.substring(valueChunkRight.length - valueChunkRightMaxLength);\r\n\t} else if (extraNumbersCount < 0) {\r\n\t\t// количество цифр меньше требуемого - добавить 0\r\n\t\tif (e.inputType === 'deleteContentForward') {\r\n\t\t\t// нажатие на delete - добавить к левой части для правильного позиционирования каретки\r\n\t\t\tvalueChunkLeft += '0'.repeat(-extraNumbersCount);\r\n\t\t} else {\r\n\t\t\tvalueChunkRight = '0'.repeat(-extraNumbersCount) + valueChunkRight;\r\n\t\t}\r\n\t}\r\n\r\n\tselectionPos = valueChunkLeft.length;\r\n\tvalue = valueChunkLeft + valueChunkRight;\r\n\r\n\t// вставить разделители\r\n\tfor (let i = 0; i < delimitersIndexes.length; i++) {\r\n\t\tconst delimiterIndex = delimitersIndexes[i];\r\n\r\n\t\tvalue = value.substring(0, delimiterIndex) + delimiter + value.substring(delimiterIndex);\r\n\r\n\t\t// сдвинуть каретку, если разделитель вставлен левее ее\r\n\t\tif (selectionPos >= delimiterIndex) {\r\n\t\t\tselectionPos++;\r\n\t\t}\r\n\t}\r\n\r\n\t// нажатие на backspace - если слева символ разделителя, перенести каретку за него\r\n\tif (e.inputType === 'deleteContentBackward' && value[selectionPos - 1] === delimiter) {\r\n\t\tselectionPos--;\r\n\t}\r\n\r\n\t// если значение изменилось - вставить его и переместить каретку\r\n\tif (value !== e.target.value) {\r\n\t\te.target.value = value;\r\n\t\te.target.selectionStart = selectionPos;\r\n\t\te.target.selectionEnd = selectionPos;\r\n\t}\r\n}\r\n"],"names":["Core","css","$","el","_b","_a","connectDatepicker","options","dateFormatted","delimiter","dateNumbersCount","delimitersIndexes","watch","toRef","dateFormat","i","oninput","e","selectionPos","value","valueChunkLeft","valueChunkRight","extraNumbersCount","valueChunkRightMaxLength","delimiterIndex"],"mappings":";;;AAMAA,EAAK,kBAAkBC,CAAG;AAE1B,MAAMC,IAAI,CAACC,MAAyB;;AACnC,MAAI,GAACC,KAAAC,IAAAL,EAAK,MAAL,gBAAAK,EAAQ,OAAR,QAAAD,EAAY,aAAY;AAC5B,YAAQ,KAAK,0EAA0E;AAEvF;AAAA,EAAA;AAGI,SAAAJ,EAAA,EAAE,WAAW,YAAY;AAAA,IAC7B,YAAYA,EAAK,MAAM,WAAW,YAAA,EAAc,QAAQ,KAAK,IAAI,EAAE,QAAQ,KAAK,IAAI,EAAE,QAAQ,KAAK,IAAI;AAAA,EAAA,CACvG,GAEMA,EAAK,EAAEG,CAAE;AACjB;AAEgB,SAAAG,EAAkBH,GAAsBI,GAAc;;AACrE,UAAOF,IAAAH,EAAEC,CAAE,MAAJ,gBAAAE,EAAO,WAAWE;AAC1B;AAEA,IAAIC,GACAC,GACAC,GACAC;AAEJC,EAAMC,EAAMb,EAAK,MAAM,UAAU,GAAG,MAAM;;AAEzC,EAAAQ,IAAgBM,EAAW,YAAY,GACvCL,MAAYJ,IAAAG,EAAc,MAAM,IAAI,MAAxB,gBAAAH,EAA4B,OAAM,KAC9CK,IAAmBF,EAAc,QAAQ,QAAQ,EAAE,EAAE,QACrDG,IAAoB,CAAC;AAErB,WAASI,IAAI,GAAGA,IAAIP,EAAc,QAAQO;AACrC,IAAAP,EAAcO,CAAC,MAAMN,KACxBE,EAAkB,KAAKI,CAAC;AAG3B,GAAG,EAAE,WAAW,IAAM;AAKf,SAASC,EAAQC,GAAQ;AAC3B,MAAAC,IAAeD,EAAE,OAAO,cACxBE,IAAQF,EAAE,OAAO,OAIjBG,IAAiBD,EAAM,UAAU,GAAGD,CAAY,EAAE,QAAQ,QAAQ,EAAE,GACpEG,IAAkBF,EAAM,UAAUD,CAAY,EAAE,QAAQ,QAAQ,EAAE,GAElEI,IAAoBF,EAAe,SAASC,EAAgB,SAASX;AACzE,MAAIY,IAAoB,GAAG;AAET,IAAAF,IAAAA,EAAe,UAAU,GAAGV,CAAgB;AAEvD,UAAAa,IAA2Bb,IAAmBU,EAAe;AACnE,IAAAC,IAAkBA,EAAgB,UAAUA,EAAgB,SAASE,CAAwB;AAAA,EAAA,MAC9F,CAAWD,IAAoB,MAE1BL,EAAE,cAAc,yBAEDG,KAAA,IAAI,OAAO,CAACE,CAAiB,IAE/CD,IAAkB,IAAI,OAAO,CAACC,CAAiB,IAAID;AAIrD,EAAAH,IAAeE,EAAe,QAC9BD,IAAQC,IAAiBC;AAGzB,WAASN,IAAI,GAAGA,IAAIJ,EAAkB,QAAQI,KAAK;AAC5C,UAAAS,IAAiBb,EAAkBI,CAAC;AAElC,IAAAI,IAAAA,EAAM,UAAU,GAAGK,CAAc,IAAIf,IAAYU,EAAM,UAAUK,CAAc,GAGnFN,KAAgBM,KACnBN;AAAA,EACD;AAID,EAAID,EAAE,cAAc,2BAA2BE,EAAMD,IAAe,CAAC,MAAMT,KAC1ES,KAIGC,MAAUF,EAAE,OAAO,UACtBA,EAAE,OAAO,QAAQE,GACjBF,EAAE,OAAO,iBAAiBC,GAC1BD,EAAE,OAAO,eAAeC;AAE1B;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"datepicker-CVoT5EME.amd.js","sources":["../../src/components/forms/inputDate/datepicker.ts"],"sourcesContent":["import { toRef, watch } from 'vue';\r\nimport Core from '@/core/core/core';\r\nimport { dateFormat } from '@/core/utils/date';\r\n\r\nimport css from '@/components/forms/inputDate/datepicker.css?inline';\r\n\r\nCore.insertStyleToPage(css);\r\n\r\nconst $ = (el: HTMLInputElement) => {\r\n\tif (!Core.$?.ui?.datepicker) {\r\n\t\tconsole.info('Для работы datepicker требуется глобальная загрузка jQuery UI Datepicker');\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tCore.$.datepicker.setDefaults({\r\n\t\tdateFormat: Core.state.dateFormat.toLowerCase().replace('m', 'mm').replace('y', 'yy').replace('d', 'dd'),\r\n\t});\r\n\r\n\treturn Core.$(el);\r\n};\r\n\r\nexport function connectDatepicker(el: HTMLInputElement, options: any) {\r\n\treturn $(el)?.datepicker(options);\r\n}\r\n\r\nlet dateFormatted;\r\nlet delimiter: string;\r\nlet dateNumbersCount: number;\r\nlet delimitersIndexes: number[];\r\n\r\nwatch(toRef(Core.state.dateFormat), () => {\r\n\t// генерация отформатированной даты, извлечение из нее разделителей и их индексов\r\n\tdateFormatted = dateFormat('2000-01-01');\r\n\tdelimiter = dateFormatted.match(/\\D/)?.[0] ?? '-';\r\n\tdateNumbersCount = dateFormatted.replace(/\\D+/g, '').length;\r\n\tdelimitersIndexes = [];\r\n\r\n\tfor (let i = 0; i < dateFormatted.length; i++) {\r\n\t\tif (dateFormatted[i] === delimiter) {\r\n\t\t\tdelimitersIndexes.push(i);\r\n\t\t}\r\n\t}\r\n}, { immediate: true });\r\n\r\n/**\r\n * Автоформат при вводе в поле с датой\r\n */\r\nexport function oninput(e: any) {\r\n\tlet selectionPos = e.target.selectionEnd;\r\n\tlet value = e.target.value;\r\n\r\n\t// разбить занчение на две половины - до и после каретки\r\n\t// удалить все символы, кроме цифр\r\n\tlet valueChunkLeft = value.substring(0, selectionPos).replace(/\\D+/g, '');\r\n\tlet valueChunkRight = value.substring(selectionPos).replace(/\\D+/g, '');\r\n\r\n\tlet extraNumbersCount = valueChunkLeft.length + valueChunkRight.length - dateNumbersCount;\r\n\tif (extraNumbersCount > 0) {\r\n\t\t// // количество цифр больше требуемого - удалить лишние\r\n\t\tvalueChunkLeft = valueChunkLeft.substring(0, dateNumbersCount);\r\n\r\n\t\tconst valueChunkRightMaxLength = dateNumbersCount - valueChunkLeft.length;\r\n\t\tvalueChunkRight = valueChunkRight.substring(valueChunkRight.length - valueChunkRightMaxLength);\r\n\t} else if (extraNumbersCount < 0) {\r\n\t\t// количество цифр меньше требуемого - добавить 0\r\n\t\tif (e.inputType === 'deleteContentForward') {\r\n\t\t\t// нажатие на delete - добавить к левой части для правильного позиционирования каретки\r\n\t\t\tvalueChunkLeft += '0'.repeat(-extraNumbersCount);\r\n\t\t} else {\r\n\t\t\tvalueChunkRight = '0'.repeat(-extraNumbersCount) + valueChunkRight;\r\n\t\t}\r\n\t}\r\n\r\n\tselectionPos = valueChunkLeft.length;\r\n\tvalue = valueChunkLeft + valueChunkRight;\r\n\r\n\t// вставить разделители\r\n\tfor (let i = 0; i < delimitersIndexes.length; i++) {\r\n\t\tconst delimiterIndex = delimitersIndexes[i];\r\n\r\n\t\tvalue = value.substring(0, delimiterIndex) + delimiter + value.substring(delimiterIndex);\r\n\r\n\t\t// сдвинуть каретку, если разделитель вставлен левее ее\r\n\t\tif (selectionPos >= delimiterIndex) {\r\n\t\t\tselectionPos++;\r\n\t\t}\r\n\t}\r\n\r\n\t// нажатие на backspace - если слева символ разделителя, перенести каретку за него\r\n\tif (e.inputType === 'deleteContentBackward' && value[selectionPos - 1] === delimiter) {\r\n\t\tselectionPos--;\r\n\t}\r\n\r\n\t// если значение изменилось - вставить его и переместить каретку\r\n\tif (value !== e.target.value) {\r\n\t\te.target.value = value;\r\n\t\te.target.selectionStart = selectionPos;\r\n\t\te.target.selectionEnd = selectionPos;\r\n\t}\r\n}\r\n"],"names":["Core","$","el","forms","connectDatepicker","options","dateFormatted","delimiter","dateNumbersCount","delimitersIndexes","watch","_a","i","selectionPos","e","value","valueChunkLeft","valueChunkRight","extraNumbersCount","valueChunkRightMaxLength","delimiterIndex"],"mappings":"0HAMAA,EAAAA,KAAAA,83HAAAA,EAEA,MAAAC,EAAAC,GAAA,uEAEE,QAAA,KAAA,0EAAA,QAEA,CAGD,OAAAC,EAAA,KAAA,EAAA,WAAA,YAAA,CAA8B,WAAAA,EAAA,KAAA,MAAA,WAAA,YAAA,EAAA,QAAA,IAAA,IAAA,EAAA,QAAA,IAAA,IAAA,EAAA,QAAA,IAAA,IAAA,CAC0E,CAAA,EAGxGA,EAAA,KAAA,EAAAD,CAAA,GAGe,SAAAE,EAAAF,EAAAG,EAAA,kDAEhB,CAEA,IAAAC,EACAC,EACAC,EACAC,EAEAC,EAAAA,MAAAA,EAAAA,MAAAA,EAAAA,KAAAA,MAAAA,UAAAA,EAAAA,IAAAA,OAECJ,EAAAH,EAAA,WAAA,YAAA,EACAI,IAAAI,EAAAL,EAAA,MAAA,IAAA,IAAA,YAAAK,EAAA,KAAA,uCAIA,QAAAC,EAAA,EAAAA,EAAAN,EAAA,OAAAM,IACCN,EAAAM,CAAA,IAAAL,GACCE,EAAA,KAAAG,CAAA,CAGH,EAAA,CAAA,UAAA,EAAA,CAAA,gBAMC,IAAAC,EAAAC,EAAA,OAAA,aACAC,EAAAD,EAAA,OAAA,MAIAE,EAAAD,EAAA,UAAA,EAAAF,CAAA,EAAA,QAAA,OAAA,EAAA,EACAI,EAAAF,EAAA,UAAAF,CAAA,EAAA,QAAA,OAAA,EAAA,wBAGA,GAAAK,EAAA,EAAA,oBAIC,MAAAC,EAAAX,EAAAQ,EAAA,gCAC6F,MAAAE,EAAA,IAG7FJ,EAAA,YAAA,6DAQDD,EAAAG,EAAA,OACAD,EAAAC,EAAAC,EAGA,QAAAL,EAAA,EAAAA,EAAAH,EAAA,OAAAG,IAAA,CACC,MAAAQ,EAAAX,EAAAG,CAAA,EAEAG,EAAAA,EAAA,UAAA,EAAAK,CAAA,EAAAb,EAAAQ,EAAA,UAAAK,CAAA,EAGAP,GAAAO,GACCP,GACD,CAIDC,EAAA,YAAA,yBAAAC,EAAAF,EAAA,CAAA,IAAAN,GACCM,yBAKAC,EAAA,OAAA,MAAAC,EACAD,EAAA,OAAA,eAAAD,EACAC,EAAA,OAAA,aAAAD,EAEF"}