@topvisor/ui 1.0.11-fix-genDate → 1.0.12

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 (132) hide show
  1. package/.chunks/datepicker-4Pv7WbOy.amd.js +248 -0
  2. package/.chunks/datepicker-4Pv7WbOy.amd.js.map +1 -0
  3. package/.chunks/datepicker-DDso1VCq.es.js +290 -0
  4. package/.chunks/datepicker-DDso1VCq.es.js.map +1 -0
  5. package/.chunks/{forms-6Z3p_rjQ.es.js → forms-Dm3JmuO3.es.js} +5 -5
  6. package/.chunks/forms-Dm3JmuO3.es.js.map +1 -0
  7. package/.chunks/{forms-VHBOI0dh.amd.js → forms-JhDIERVr.amd.js} +3 -3
  8. package/.chunks/forms-JhDIERVr.amd.js.map +1 -0
  9. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-vJr-aboH.amd.js → listItem.vue_vue_type_script_setup_true_lang-DPLgssbE.amd.js} +2 -2
  10. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DPLgssbE.amd.js.map +1 -0
  11. package/.chunks/{listItem.vue_vue_type_script_setup_true_lang-D5L98ivn.es.js → listItem.vue_vue_type_script_setup_true_lang-DsTNQnlk.es.js} +2 -2
  12. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-DsTNQnlk.es.js.map +1 -0
  13. package/.chunks/{menu.vue_vue_type_style_index_0_lang-KS0ds5K9.es.js → menu.vue_vue_type_style_index_0_lang-86OJDcnB.es.js} +2 -2
  14. package/.chunks/menu.vue_vue_type_style_index_0_lang-86OJDcnB.es.js.map +1 -0
  15. package/.chunks/{menu.vue_vue_type_style_index_0_lang-CIdtKoU3.amd.js → menu.vue_vue_type_style_index_0_lang-DkiaQwIJ.amd.js} +2 -2
  16. package/.chunks/menu.vue_vue_type_style_index_0_lang-DkiaQwIJ.amd.js.map +1 -0
  17. package/.chunks/{notice-CbblAkRb.amd.js → notice-BPxrLH4a.amd.js} +2 -2
  18. package/.chunks/notice-BPxrLH4a.amd.js.map +1 -0
  19. package/.chunks/{notice-CPsMulgd.es.js → notice-CTd0Zf-U.es.js} +2 -2
  20. package/.chunks/notice-CTd0Zf-U.es.js.map +1 -0
  21. package/.chunks/{popup-DiC5JWsJ.amd.js → popup-BXBFCWHU.amd.js} +448 -448
  22. package/.chunks/popup-BXBFCWHU.amd.js.map +1 -0
  23. package/.chunks/{popup-Wzy_7sXf.es.js → popup-DXuKsMuU.es.js} +491 -491
  24. package/.chunks/popup-DXuKsMuU.es.js.map +1 -0
  25. package/.chunks/store-CX_6ZXhO.es.js.map +1 -1
  26. package/.chunks/store-esTid5oI.amd.js.map +1 -1
  27. package/README.md +86 -86
  28. package/assets/core.css +1 -1
  29. package/assets/forms.css +1 -1
  30. package/assets/themes/dark.css +1 -1
  31. package/assets/themes/light.css +1 -1
  32. package/charts/charts.amd.js +1 -1
  33. package/charts/charts.amd.js.map +1 -1
  34. package/charts/charts.js +1 -1
  35. package/charts/charts.js.map +1 -1
  36. package/components/core/dialog/types.d.ts +2 -0
  37. package/core/app.amd.js +1 -1
  38. package/core/app.amd.js.map +1 -1
  39. package/core/app.js +3 -3
  40. package/core/app.js.map +1 -1
  41. package/core/utils/route.d.ts +2 -2
  42. package/core/utils/scroll.d.ts +14 -1
  43. package/forms/forms.amd.js +1 -1
  44. package/forms/forms.js +1 -1
  45. package/forms/helpers.amd.js.map +1 -1
  46. package/forms/helpers.js.map +1 -1
  47. package/formsExt/formsExt.amd.js +1 -1
  48. package/formsExt/formsExt.amd.js.map +1 -1
  49. package/formsExt/formsExt.js +2 -2
  50. package/formsExt/formsExt.js.map +1 -1
  51. package/icomoon/Read Me.txt +7 -7
  52. package/icomoon/Topvisor icons.json +5845 -5845
  53. package/icomoon/demo-files/demo.css +161 -161
  54. package/icomoon/demo-files/demo.js +30 -30
  55. package/icomoon/demo.html +3379 -3379
  56. package/icomoon/fonts/Topvisor-2.svg +263 -263
  57. package/icomoon/style.css +740 -740
  58. package/package.json +33 -33
  59. package/popup/popup.amd.js +1 -1
  60. package/popup/popup.amd.js.map +1 -1
  61. package/popup/popup.js +2 -2
  62. package/popup/popup.js.map +1 -1
  63. package/popup/worker.amd.js +1 -1
  64. package/popup/worker.amd.js.map +1 -1
  65. package/popup/worker.js +2 -2
  66. package/popup/worker.js.map +1 -1
  67. package/project/project.amd.js +1 -1
  68. package/project/project.amd.js.map +1 -1
  69. package/project/project.js +3 -3
  70. package/project/project.js.map +1 -1
  71. package/require/css.amd.js +12 -12
  72. package/tabs/tabs.amd.js.map +1 -1
  73. package/tabs/tabs.js.map +1 -1
  74. package/tabsView/tabsView.amd.js +1 -1
  75. package/tabsView/tabsView.amd.js.map +1 -1
  76. package/tabsView/tabsView.js +1 -1
  77. package/tabsView/tabsView.js.map +1 -1
  78. package/utils/check.amd.js +1 -1
  79. package/utils/check.amd.js.map +1 -1
  80. package/utils/check.js +1 -1
  81. package/utils/check.js.map +1 -1
  82. package/utils/clipboard.amd.js.map +1 -1
  83. package/utils/clipboard.js.map +1 -1
  84. package/utils/date.amd.js +1 -1
  85. package/utils/date.js +1 -1
  86. package/utils/device.amd.js +1 -1
  87. package/utils/device.js +1 -1
  88. package/utils/dom.amd.js.map +1 -1
  89. package/utils/dom.js.map +1 -1
  90. package/utils/image.amd.js.map +1 -1
  91. package/utils/image.js.map +1 -1
  92. package/utils/keyboard.amd.js.map +1 -1
  93. package/utils/keyboard.js.map +1 -1
  94. package/utils/lodash.amd.js +1 -1
  95. package/utils/lodash.js +1 -1
  96. package/utils/number.amd.js.map +1 -1
  97. package/utils/number.js.map +1 -1
  98. package/utils/price.amd.js +1 -1
  99. package/utils/price.amd.js.map +1 -1
  100. package/utils/price.js +1 -1
  101. package/utils/price.js.map +1 -1
  102. package/utils/route.amd.js.map +1 -1
  103. package/utils/route.js.map +1 -1
  104. package/utils/scroll.amd.js +1 -1
  105. package/utils/scroll.amd.js.map +1 -1
  106. package/utils/scroll.js +19 -7
  107. package/utils/scroll.js.map +1 -1
  108. package/utils/searchers.amd.js.map +1 -1
  109. package/utils/searchers.js.map +1 -1
  110. package/utils/string.amd.js +1 -1
  111. package/utils/string.amd.js.map +1 -1
  112. package/utils/string.js +1 -1
  113. package/utils/string.js.map +1 -1
  114. package/utils/system.amd.js.map +1 -1
  115. package/utils/system.js.map +1 -1
  116. package/utils/url.amd.js.map +1 -1
  117. package/utils/url.js.map +1 -1
  118. package/web-types.json +89 -89
  119. package/.chunks/datepicker-BLzgmRwE.amd.js +0 -248
  120. package/.chunks/datepicker-BLzgmRwE.amd.js.map +0 -1
  121. package/.chunks/datepicker-C0DMEWk5.es.js +0 -290
  122. package/.chunks/datepicker-C0DMEWk5.es.js.map +0 -1
  123. package/.chunks/forms-6Z3p_rjQ.es.js.map +0 -1
  124. package/.chunks/forms-VHBOI0dh.amd.js.map +0 -1
  125. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-D5L98ivn.es.js.map +0 -1
  126. package/.chunks/listItem.vue_vue_type_script_setup_true_lang-vJr-aboH.amd.js.map +0 -1
  127. package/.chunks/menu.vue_vue_type_style_index_0_lang-CIdtKoU3.amd.js.map +0 -1
  128. package/.chunks/menu.vue_vue_type_style_index_0_lang-KS0ds5K9.es.js.map +0 -1
  129. package/.chunks/notice-CPsMulgd.es.js.map +0 -1
  130. package/.chunks/notice-CbblAkRb.amd.js.map +0 -1
  131. package/.chunks/popup-DiC5JWsJ.amd.js.map +0 -1
  132. package/.chunks/popup-Wzy_7sXf.es.js.map +0 -1
package/utils/dom.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"dom.js","sources":["../../src/core/utils/dom.ts"],"sourcesContent":["/**\n * Работа с Document Object Model (DOM)\n * @packageDocumentation\n */\n\n/**\n * Создать элемент\n * @param tagName\n * @param attrs - атрибуты\n * @param elsChildrens\n * @returns - созданный элемент\n */\nexport function genEl(tagName: string, attrs?: Record<string, string>, ...elsChildrens: HTMLElement[] | string[]): HTMLElement {\n\tconst el: any = document.createElement(tagName);\n\n\tfor (const name in attrs) {\n\t\tif (name.indexOf('on') === 0) {\n\t\t\t// events\n\t\t\tel[name] = attrs[name];\n\t\t} else {\n\t\t\tel.setAttribute(name, attrs[name]);\n\t\t}\n\t}\n\n\telsChildrens.forEach((elChildren: HTMLElement | string) => {\n\t\tif (typeof (elChildren) === 'string') {\n\t\t\tel.insertAdjacentHTML('beforeend', elChildren);\n\t\t} else {\n\t\t\tel.append(elChildren);\n\t\t}\n\t});\n\n\treturn el;\n}\n\n/**\n * Проверить видимость элемента\n * @param el\n * @returns - вернет true, если элемент считается видимым\n */\nexport function isVisible(el?: HTMLElement): boolean {\n\tif (!el) {\n\t\treturn false;\n\t}\n\n\tconst boundingClientRect = el.getBoundingClientRect();\n\treturn !!(boundingClientRect.width || boundingClientRect.height);\n}\n\n/**\n * Получить координаты элемента относительно документа\n * @param el\n * @returns - координаты элемента относительно документа\n */\nexport function offset(el: HTMLElement): { top: number, left: number } {\n\tconst boundingClientRect = el.getBoundingClientRect();\n\n\treturn {\n\t\ttop: boundingClientRect.top + window.scrollY,\n\t\tleft: boundingClientRect.left + window.scrollX,\n\t};\n}\n\n/**\n * Получить значение css свойства элемента\n * @param el\n * @param property - имя свойства\n * @return - значение css стиля\n */\nexport function css(el: HTMLElement, property: string): string {\n\treturn window.getComputedStyle(el).getPropertyValue(property);\n}\n\n/**\n * Обернуть элемент и вернуть только что созданный элемент\n * @param el - элемент, который требуется обернуть\n * @param tagName - имя тега элемента, в который треубется обернуть элемент\n */\nexport function wrap(el: HTMLElement, tagName: string): HTMLElement {\n\tconst elWrapper = document.createElement(tagName);\n\tel.after(elWrapper);\n\n\telWrapper.append(el);\n\n\treturn elWrapper;\n}\n\n/**\n * Найти и вернуть первый видимый элемент\n * @param el - корневой элемент поиска\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\n */\nexport function querySelectorVisible(el: HTMLElement, selectors: string): HTMLElement | null {\n\treturn querySelectorAllArray(el, selectors).find(isVisible) || null;\n}\n\n/**\n * Найти и вернуть последний видимый элемент\n * @param el - корневой элемент поиска\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\n */\nexport function querySelectorVisibleLast(el: HTMLElement, selectors: string): HTMLElement | null {\n\treturn querySelectorAllArray(el, selectors).findLast(isVisible) || null;\n}\n\n/**\n * Найти видимые элементы\n * @param el - корневой элемент поиска\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\n */\nexport function querySelectorAllVisible(el: HTMLElement | Document, selectors: string): HTMLElement[] {\n\treturn querySelectorAllArray(el, selectors).filter(isVisible);\n}\n\n/**\n * Найти элементы и вернуть в виде массива\n * @param el - корневой элемент поиска\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\n */\nexport function querySelectorAllArray(el: HTMLElement | Document, selectors: string): HTMLElement[] {\n\tif (!el) {\n\t\treturn [];\n\t}\n\n\treturn [...el.querySelectorAll(selectors)] as HTMLElement[];\n}\n\n/**\n * Хранилище данных элемента\n * @param el\n * @param contextName - контекст, обычно используется имя компонента\n * @param contextData - установить объект с данными, предыдущие данные будут заменены, установите null для удаления данных\n * @returns - вернет объект контекста или undefined, если данные контекста не найдены\n */\nexport function storage(\n\tel?: HTMLElement & { topData?: any },\n\tcontextName: string = 'common',\n\tcontextData: object | null | undefined = undefined,\n): any | undefined {\n\tif (!el) {\n\t\treturn;\n\t}\n\n\tif (!el.topData) {\n\t\tel.topData = {};\n\t}\n\n\tif (contextData) {\n\t\tel.topData[contextName] = contextData;\n\t}\n\n\tif (contextData === null) {\n\t\tdelete el.topData[contextName];\n\t}\n\n\treturn el.topData[contextName];\n}\n\n/**\n * Очистить хранилище элемента\n */\nexport function storageClear(el?: HTMLElement & { topData?: any }): void {\n\tif (!el) {\n\t\treturn;\n\t}\n\n\tdelete el.topData;\n}\n\nexport default {\n\tgenEl,\n\tisVisible,\n\toffset,\n\tcss,\n\twrap,\n\tquerySelectorVisible,\n\tquerySelectorVisibleLast,\n\tquerySelectorAllVisible,\n\tquerySelectorAllArray,\n\tstorage,\n\tstorageClear,\n};\n"],"names":["genEl","tagName","attrs","elsChildrens","el","name","elChildren","isVisible","boundingClientRect","offset","css","property","wrap","elWrapper","querySelectorVisible","selectors","querySelectorAllArray","querySelectorVisibleLast","querySelectorAllVisible","storage","contextName","contextData","storageClear","DOM"],"mappings":"AAYgB,SAAAA,EAAMC,GAAiBC,MAAmCC,GAAqD;AACxH,QAAAC,IAAU,SAAS,cAAcH,CAAO;AAE9C,aAAWI,KAAQH;AAClB,IAAIG,EAAK,QAAQ,IAAI,MAAM,IAEvBD,EAAAC,CAAI,IAAIH,EAAMG,CAAI,IAErBD,EAAG,aAAaC,GAAMH,EAAMG,CAAI,CAAC;AAItB,SAAAF,EAAA,QAAQ,CAACG,MAAqC;AACtD,IAAA,OAAQA,KAAgB,WACxBF,EAAA,mBAAmB,aAAaE,CAAU,IAE7CF,EAAG,OAAOE,CAAU;AAAA,EACrB,CACA,GAEMF;AACR;AAOO,SAASG,EAAUH,GAA2B;AACpD,MAAI,CAACA;AACG,WAAA;AAGF,QAAAI,IAAqBJ,EAAG;AAC9B,SAAO,CAAC,EAAEI,EAAmB,SAASA,EAAmB;AAC1D;AAOO,SAASC,EAAOL,GAAgD;AAChE,QAAAI,IAAqBJ,EAAG;AAEvB,SAAA;AAAA,IACN,KAAKI,EAAmB,MAAM,OAAO;AAAA,IACrC,MAAMA,EAAmB,OAAO,OAAO;AAAA,EAAA;AAEzC;AAQgB,SAAAE,EAAIN,GAAiBO,GAA0B;AAC9D,SAAO,OAAO,iBAAiBP,CAAE,EAAE,iBAAiBO,CAAQ;AAC7D;AAOgB,SAAAC,EAAKR,GAAiBH,GAA8B;AAC7D,QAAAY,IAAY,SAAS,cAAcZ,CAAO;AAChD,SAAAG,EAAG,MAAMS,CAAS,GAElBA,EAAU,OAAOT,CAAE,GAEZS;AACR;AAOgB,SAAAC,EAAqBV,GAAiBW,GAAuC;AAC5F,SAAOC,EAAsBZ,GAAIW,CAAS,EAAE,KAAKR,CAAS,KAAK;AAChE;AAOgB,SAAAU,EAAyBb,GAAiBW,GAAuC;AAChG,SAAOC,EAAsBZ,GAAIW,CAAS,EAAE,SAASR,CAAS,KAAK;AACpE;AAOgB,SAAAW,EAAwBd,GAA4BW,GAAkC;AACrG,SAAOC,EAAsBZ,GAAIW,CAAS,EAAE,OAAOR,CAAS;AAC7D;AAOgB,SAAAS,EAAsBZ,GAA4BW,GAAkC;AACnG,SAAKX,IAIE,CAAC,GAAGA,EAAG,iBAAiBW,CAAS,CAAC,IAHjC;AAIT;AASO,SAASI,EACff,GACAgB,IAAsB,UACtBC,IAAyC,QACvB;AAClB,MAAKjB;AAID,WAACA,EAAG,YACPA,EAAG,UAAU,KAGViB,MACAjB,EAAA,QAAQgB,CAAW,IAAIC,IAGvBA,MAAgB,QACZ,OAAAjB,EAAG,QAAQgB,CAAW,GAGvBhB,EAAG,QAAQgB,CAAW;AAC9B;AAKO,SAASE,EAAalB,GAA4C;AACxE,EAAKA,KAIL,OAAOA,EAAG;AACX;AAEA,MAAemB,IAAA;AAAA,EACd,OAAAvB;AAAA,EACA,WAAAO;AAAA,EACA,QAAAE;AAAA,EACA,KAAAC;AAAA,EACA,MAAAE;AAAA,EACA,sBAAAE;AAAA,EACA,0BAAAG;AAAA,EACA,yBAAAC;AAAA,EACA,uBAAAF;AAAA,EACA,SAAAG;AAAA,EACA,cAAAG;AACD;"}
1
+ {"version":3,"file":"dom.js","sources":["../../src/core/utils/dom.ts"],"sourcesContent":["/**\r\n * Работа с Document Object Model (DOM)\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Создать элемент\r\n * @param tagName\r\n * @param attrs - атрибуты\r\n * @param elsChildrens\r\n * @returns - созданный элемент\r\n */\r\nexport function genEl(tagName: string, attrs?: Record<string, string>, ...elsChildrens: HTMLElement[] | string[]): HTMLElement {\r\n\tconst el: any = document.createElement(tagName);\r\n\r\n\tfor (const name in attrs) {\r\n\t\tif (name.indexOf('on') === 0) {\r\n\t\t\t// events\r\n\t\t\tel[name] = attrs[name];\r\n\t\t} else {\r\n\t\t\tel.setAttribute(name, attrs[name]);\r\n\t\t}\r\n\t}\r\n\r\n\telsChildrens.forEach((elChildren: HTMLElement | string) => {\r\n\t\tif (typeof (elChildren) === 'string') {\r\n\t\t\tel.insertAdjacentHTML('beforeend', elChildren);\r\n\t\t} else {\r\n\t\t\tel.append(elChildren);\r\n\t\t}\r\n\t});\r\n\r\n\treturn el;\r\n}\r\n\r\n/**\r\n * Проверить видимость элемента\r\n * @param el\r\n * @returns - вернет true, если элемент считается видимым\r\n */\r\nexport function isVisible(el?: HTMLElement): boolean {\r\n\tif (!el) {\r\n\t\treturn false;\r\n\t}\r\n\r\n\tconst boundingClientRect = el.getBoundingClientRect();\r\n\treturn !!(boundingClientRect.width || boundingClientRect.height);\r\n}\r\n\r\n/**\r\n * Получить координаты элемента относительно документа\r\n * @param el\r\n * @returns - координаты элемента относительно документа\r\n */\r\nexport function offset(el: HTMLElement): { top: number, left: number } {\r\n\tconst boundingClientRect = el.getBoundingClientRect();\r\n\r\n\treturn {\r\n\t\ttop: boundingClientRect.top + window.scrollY,\r\n\t\tleft: boundingClientRect.left + window.scrollX,\r\n\t};\r\n}\r\n\r\n/**\r\n * Получить значение css свойства элемента\r\n * @param el\r\n * @param property - имя свойства\r\n * @return - значение css стиля\r\n */\r\nexport function css(el: HTMLElement, property: string): string {\r\n\treturn window.getComputedStyle(el).getPropertyValue(property);\r\n}\r\n\r\n/**\r\n * Обернуть элемент и вернуть только что созданный элемент\r\n * @param el - элемент, который требуется обернуть\r\n * @param tagName - имя тега элемента, в который треубется обернуть элемент\r\n */\r\nexport function wrap(el: HTMLElement, tagName: string): HTMLElement {\r\n\tconst elWrapper = document.createElement(tagName);\r\n\tel.after(elWrapper);\r\n\r\n\telWrapper.append(el);\r\n\r\n\treturn elWrapper;\r\n}\r\n\r\n/**\r\n * Найти и вернуть первый видимый элемент\r\n * @param el - корневой элемент поиска\r\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\r\n */\r\nexport function querySelectorVisible(el: HTMLElement, selectors: string): HTMLElement | null {\r\n\treturn querySelectorAllArray(el, selectors).find(isVisible) || null;\r\n}\r\n\r\n/**\r\n * Найти и вернуть последний видимый элемент\r\n * @param el - корневой элемент поиска\r\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\r\n */\r\nexport function querySelectorVisibleLast(el: HTMLElement, selectors: string): HTMLElement | null {\r\n\treturn querySelectorAllArray(el, selectors).findLast(isVisible) || null;\r\n}\r\n\r\n/**\r\n * Найти видимые элементы\r\n * @param el - корневой элемент поиска\r\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\r\n */\r\nexport function querySelectorAllVisible(el: HTMLElement | Document, selectors: string): HTMLElement[] {\r\n\treturn querySelectorAllArray(el, selectors).filter(isVisible);\r\n}\r\n\r\n/**\r\n * Найти элементы и вернуть в виде массива\r\n * @param el - корневой элемент поиска\r\n * @param selectors - см. параметр selectors в Document.querySelectorAll()\r\n */\r\nexport function querySelectorAllArray(el: HTMLElement | Document, selectors: string): HTMLElement[] {\r\n\tif (!el) {\r\n\t\treturn [];\r\n\t}\r\n\r\n\treturn [...el.querySelectorAll(selectors)] as HTMLElement[];\r\n}\r\n\r\n/**\r\n * Хранилище данных элемента\r\n * @param el\r\n * @param contextName - контекст, обычно используется имя компонента\r\n * @param contextData - установить объект с данными, предыдущие данные будут заменены, установите null для удаления данных\r\n * @returns - вернет объект контекста или undefined, если данные контекста не найдены\r\n */\r\nexport function storage(\r\n\tel?: HTMLElement & { topData?: any },\r\n\tcontextName: string = 'common',\r\n\tcontextData: object | null | undefined = undefined,\r\n): any | undefined {\r\n\tif (!el) {\r\n\t\treturn;\r\n\t}\r\n\r\n\tif (!el.topData) {\r\n\t\tel.topData = {};\r\n\t}\r\n\r\n\tif (contextData) {\r\n\t\tel.topData[contextName] = contextData;\r\n\t}\r\n\r\n\tif (contextData === null) {\r\n\t\tdelete el.topData[contextName];\r\n\t}\r\n\r\n\treturn el.topData[contextName];\r\n}\r\n\r\n/**\r\n * Очистить хранилище элемента\r\n */\r\nexport function storageClear(el?: HTMLElement & { topData?: any }): void {\r\n\tif (!el) {\r\n\t\treturn;\r\n\t}\r\n\r\n\tdelete el.topData;\r\n}\r\n\r\nexport default {\r\n\tgenEl,\r\n\tisVisible,\r\n\toffset,\r\n\tcss,\r\n\twrap,\r\n\tquerySelectorVisible,\r\n\tquerySelectorVisibleLast,\r\n\tquerySelectorAllVisible,\r\n\tquerySelectorAllArray,\r\n\tstorage,\r\n\tstorageClear,\r\n};\r\n"],"names":["genEl","tagName","attrs","elsChildrens","el","name","elChildren","isVisible","boundingClientRect","offset","css","property","wrap","elWrapper","querySelectorVisible","selectors","querySelectorAllArray","querySelectorVisibleLast","querySelectorAllVisible","storage","contextName","contextData","storageClear","DOM"],"mappings":"AAYgB,SAAAA,EAAMC,GAAiBC,MAAmCC,GAAqD;AACxH,QAAAC,IAAU,SAAS,cAAcH,CAAO;AAE9C,aAAWI,KAAQH;AAClB,IAAIG,EAAK,QAAQ,IAAI,MAAM,IAEvBD,EAAAC,CAAI,IAAIH,EAAMG,CAAI,IAErBD,EAAG,aAAaC,GAAMH,EAAMG,CAAI,CAAC;AAItB,SAAAF,EAAA,QAAQ,CAACG,MAAqC;AACtD,IAAA,OAAQA,KAAgB,WACxBF,EAAA,mBAAmB,aAAaE,CAAU,IAE7CF,EAAG,OAAOE,CAAU;AAAA,EACrB,CACA,GAEMF;AACR;AAOO,SAASG,EAAUH,GAA2B;AACpD,MAAI,CAACA;AACG,WAAA;AAGF,QAAAI,IAAqBJ,EAAG;AAC9B,SAAO,CAAC,EAAEI,EAAmB,SAASA,EAAmB;AAC1D;AAOO,SAASC,EAAOL,GAAgD;AAChE,QAAAI,IAAqBJ,EAAG;AAEvB,SAAA;AAAA,IACN,KAAKI,EAAmB,MAAM,OAAO;AAAA,IACrC,MAAMA,EAAmB,OAAO,OAAO;AAAA,EAAA;AAEzC;AAQgB,SAAAE,EAAIN,GAAiBO,GAA0B;AAC9D,SAAO,OAAO,iBAAiBP,CAAE,EAAE,iBAAiBO,CAAQ;AAC7D;AAOgB,SAAAC,EAAKR,GAAiBH,GAA8B;AAC7D,QAAAY,IAAY,SAAS,cAAcZ,CAAO;AAChD,SAAAG,EAAG,MAAMS,CAAS,GAElBA,EAAU,OAAOT,CAAE,GAEZS;AACR;AAOgB,SAAAC,EAAqBV,GAAiBW,GAAuC;AAC5F,SAAOC,EAAsBZ,GAAIW,CAAS,EAAE,KAAKR,CAAS,KAAK;AAChE;AAOgB,SAAAU,EAAyBb,GAAiBW,GAAuC;AAChG,SAAOC,EAAsBZ,GAAIW,CAAS,EAAE,SAASR,CAAS,KAAK;AACpE;AAOgB,SAAAW,EAAwBd,GAA4BW,GAAkC;AACrG,SAAOC,EAAsBZ,GAAIW,CAAS,EAAE,OAAOR,CAAS;AAC7D;AAOgB,SAAAS,EAAsBZ,GAA4BW,GAAkC;AACnG,SAAKX,IAIE,CAAC,GAAGA,EAAG,iBAAiBW,CAAS,CAAC,IAHjC;AAIT;AASO,SAASI,EACff,GACAgB,IAAsB,UACtBC,IAAyC,QACvB;AAClB,MAAKjB;AAID,WAACA,EAAG,YACPA,EAAG,UAAU,KAGViB,MACAjB,EAAA,QAAQgB,CAAW,IAAIC,IAGvBA,MAAgB,QACZ,OAAAjB,EAAG,QAAQgB,CAAW,GAGvBhB,EAAG,QAAQgB,CAAW;AAC9B;AAKO,SAASE,EAAalB,GAA4C;AACxE,EAAKA,KAIL,OAAOA,EAAG;AACX;AAEA,MAAemB,IAAA;AAAA,EACd,OAAAvB;AAAA,EACA,WAAAO;AAAA,EACA,QAAAE;AAAA,EACA,KAAAC;AAAA,EACA,MAAAE;AAAA,EACA,sBAAAE;AAAA,EACA,0BAAAG;AAAA,EACA,yBAAAC;AAAA,EACA,uBAAAF;AAAA,EACA,SAAAG;AAAA,EACA,cAAAG;AACD;"}
@@ -1 +1 @@
1
- {"version":3,"file":"image.amd.js","sources":["../../src/core/utils/image.ts"],"sourcesContent":["/**\n * Работа с изображениями\n * @packageDocumentation\n */\n\nimport punycode from 'punycode';\n\n/**\n * Скачать изображение, переданное в виде строки\n * @param imageStr - адресс картинки\n * @param imageName - имя файла при загрузке, по умолчанию download\n */\nexport const downloadImageFromString = (imageStr: string, imageName: string = 'download'): void => {\n\tconst a = document.createElement('a');\n\ta.download = imageName;\n\ta.href = imageStr;\n\ta.click();\n};\n\n/**\n * Сгенерировать html картинку с фавиконкой сайта\n * @param url - адрес сайта\n * @param isBig - если true, картинка будет 120px, иначе 32px\n */\nexport const genFaviconImgHtml = (url: string, isBig: boolean): string => {\n\tlet size = 32;\n\tif (isBig) size = 120;\n\n\turl = url.replace(/^\\w+:\\/\\/|^www\\.|\\/.*/g, '');\n\turl = punycode.toASCII(url);\n\n\tconst onloadAttr = `\n\t\tonload=\"\n\t\t\tvar that = this;\n\t\t\t$.ajax({\n\t\t\t\ttype:'get',\n\t\t\t\turl:this.src,\n\t\t\t\tsuccess:function(res){ if(res.length > 100) that.className='top-favicon'; },\n\t\t\t\terror:function(){ }\n\t\t\t});\n\t\t\"\n\t`;\n\n\t//\treturn '<img src=\"https://www.google.com/s2/favicons?domain=' + url + '\" class=\"top-favicon empty\"> ' + onloadAttr + '>';\n\treturn '<img src=\"https://favicon.yandex.net/favicon/' + url + '?size=' + size + '\" class=\"top-favicon empty\" ' + onloadAttr + ' alt=\"\">';\n};\n"],"names":["downloadImageFromString","imageStr","imageName","a","genFaviconImgHtml","url","isBig","size"],"mappings":"kIAYO,MAAAA,EAAA,CAAAC,EAAAC,EAAA,aAAA,qCAENC,EAAA,SAAAD,EACAC,EAAA,KAAAF,EACAE,EAAA,MAAA,GAQYC,EAAA,CAAAC,EAAAC,IAAA,CACZ,IAAAC,EAAA,GACA,OAAAD,IAAAC,EAAA,sEAkBA,gDAAAF,EAAA,SAAAE,EAAA;;;;;;;;;;GAAA,UACD"}
1
+ {"version":3,"file":"image.amd.js","sources":["../../src/core/utils/image.ts"],"sourcesContent":["/**\r\n * Работа с изображениями\r\n * @packageDocumentation\r\n */\r\n\r\nimport punycode from 'punycode';\r\n\r\n/**\r\n * Скачать изображение, переданное в виде строки\r\n * @param imageStr - адресс картинки\r\n * @param imageName - имя файла при загрузке, по умолчанию download\r\n */\r\nexport const downloadImageFromString = (imageStr: string, imageName: string = 'download'): void => {\r\n\tconst a = document.createElement('a');\r\n\ta.download = imageName;\r\n\ta.href = imageStr;\r\n\ta.click();\r\n};\r\n\r\n/**\r\n * Сгенерировать html картинку с фавиконкой сайта\r\n * @param url - адрес сайта\r\n * @param isBig - если true, картинка будет 120px, иначе 32px\r\n */\r\nexport const genFaviconImgHtml = (url: string, isBig: boolean): string => {\r\n\tlet size = 32;\r\n\tif (isBig) size = 120;\r\n\r\n\turl = url.replace(/^\\w+:\\/\\/|^www\\.|\\/.*/g, '');\r\n\turl = punycode.toASCII(url);\r\n\r\n\tconst onloadAttr = `\r\n\t\tonload=\"\r\n\t\t\tvar that = this;\r\n\t\t\t$.ajax({\r\n\t\t\t\ttype:'get',\r\n\t\t\t\turl:this.src,\r\n\t\t\t\tsuccess:function(res){ if(res.length > 100) that.className='top-favicon'; },\r\n\t\t\t\terror:function(){ }\r\n\t\t\t});\r\n\t\t\"\r\n\t`;\r\n\r\n\t//\treturn '<img src=\"https://www.google.com/s2/favicons?domain=' + url + '\" class=\"top-favicon empty\"> ' + onloadAttr + '>';\r\n\treturn '<img src=\"https://favicon.yandex.net/favicon/' + url + '?size=' + size + '\" class=\"top-favicon empty\" ' + onloadAttr + ' alt=\"\">';\r\n};\r\n"],"names":["downloadImageFromString","imageStr","imageName","a","genFaviconImgHtml","url","isBig","size"],"mappings":"kIAYO,MAAAA,EAAA,CAAAC,EAAAC,EAAA,aAAA,qCAENC,EAAA,SAAAD,EACAC,EAAA,KAAAF,EACAE,EAAA,MAAA,GAQYC,EAAA,CAAAC,EAAAC,IAAA,CACZ,IAAAC,EAAA,GACA,OAAAD,IAAAC,EAAA,sEAkBA,gDAAAF,EAAA,SAAAE,EAAA;;;;;;;;;;GAAA,UACD"}
@@ -1 +1 @@
1
- {"version":3,"file":"image.js","sources":["../../src/core/utils/image.ts"],"sourcesContent":["/**\n * Работа с изображениями\n * @packageDocumentation\n */\n\nimport punycode from 'punycode';\n\n/**\n * Скачать изображение, переданное в виде строки\n * @param imageStr - адресс картинки\n * @param imageName - имя файла при загрузке, по умолчанию download\n */\nexport const downloadImageFromString = (imageStr: string, imageName: string = 'download'): void => {\n\tconst a = document.createElement('a');\n\ta.download = imageName;\n\ta.href = imageStr;\n\ta.click();\n};\n\n/**\n * Сгенерировать html картинку с фавиконкой сайта\n * @param url - адрес сайта\n * @param isBig - если true, картинка будет 120px, иначе 32px\n */\nexport const genFaviconImgHtml = (url: string, isBig: boolean): string => {\n\tlet size = 32;\n\tif (isBig) size = 120;\n\n\turl = url.replace(/^\\w+:\\/\\/|^www\\.|\\/.*/g, '');\n\turl = punycode.toASCII(url);\n\n\tconst onloadAttr = `\n\t\tonload=\"\n\t\t\tvar that = this;\n\t\t\t$.ajax({\n\t\t\t\ttype:'get',\n\t\t\t\turl:this.src,\n\t\t\t\tsuccess:function(res){ if(res.length > 100) that.className='top-favicon'; },\n\t\t\t\terror:function(){ }\n\t\t\t});\n\t\t\"\n\t`;\n\n\t//\treturn '<img src=\"https://www.google.com/s2/favicons?domain=' + url + '\" class=\"top-favicon empty\"> ' + onloadAttr + '>';\n\treturn '<img src=\"https://favicon.yandex.net/favicon/' + url + '?size=' + size + '\" class=\"top-favicon empty\" ' + onloadAttr + ' alt=\"\">';\n};\n"],"names":["downloadImageFromString","imageStr","imageName","a","genFaviconImgHtml","url","isBig","size","punycode"],"mappings":";AAYO,MAAMA,IAA0B,CAACC,GAAkBC,IAAoB,eAAqB;AAC5F,QAAAC,IAAI,SAAS,cAAc,GAAG;AACpC,EAAAA,EAAE,WAAWD,GACbC,EAAE,OAAOF,GACTE,EAAE,MAAM;AACT,GAOaC,IAAoB,CAACC,GAAaC,MAA2B;AACzE,MAAIC,IAAO;AACX,SAAID,MAAcC,IAAA,MAEZF,IAAAA,EAAI,QAAQ,0BAA0B,EAAE,GACxCA,IAAAG,EAAS,QAAQH,CAAG,GAenB,kDAAkDA,IAAM,WAAWE,IAAO,iCAb9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAa4G;AAChI;"}
1
+ {"version":3,"file":"image.js","sources":["../../src/core/utils/image.ts"],"sourcesContent":["/**\r\n * Работа с изображениями\r\n * @packageDocumentation\r\n */\r\n\r\nimport punycode from 'punycode';\r\n\r\n/**\r\n * Скачать изображение, переданное в виде строки\r\n * @param imageStr - адресс картинки\r\n * @param imageName - имя файла при загрузке, по умолчанию download\r\n */\r\nexport const downloadImageFromString = (imageStr: string, imageName: string = 'download'): void => {\r\n\tconst a = document.createElement('a');\r\n\ta.download = imageName;\r\n\ta.href = imageStr;\r\n\ta.click();\r\n};\r\n\r\n/**\r\n * Сгенерировать html картинку с фавиконкой сайта\r\n * @param url - адрес сайта\r\n * @param isBig - если true, картинка будет 120px, иначе 32px\r\n */\r\nexport const genFaviconImgHtml = (url: string, isBig: boolean): string => {\r\n\tlet size = 32;\r\n\tif (isBig) size = 120;\r\n\r\n\turl = url.replace(/^\\w+:\\/\\/|^www\\.|\\/.*/g, '');\r\n\turl = punycode.toASCII(url);\r\n\r\n\tconst onloadAttr = `\r\n\t\tonload=\"\r\n\t\t\tvar that = this;\r\n\t\t\t$.ajax({\r\n\t\t\t\ttype:'get',\r\n\t\t\t\turl:this.src,\r\n\t\t\t\tsuccess:function(res){ if(res.length > 100) that.className='top-favicon'; },\r\n\t\t\t\terror:function(){ }\r\n\t\t\t});\r\n\t\t\"\r\n\t`;\r\n\r\n\t//\treturn '<img src=\"https://www.google.com/s2/favicons?domain=' + url + '\" class=\"top-favicon empty\"> ' + onloadAttr + '>';\r\n\treturn '<img src=\"https://favicon.yandex.net/favicon/' + url + '?size=' + size + '\" class=\"top-favicon empty\" ' + onloadAttr + ' alt=\"\">';\r\n};\r\n"],"names":["downloadImageFromString","imageStr","imageName","a","genFaviconImgHtml","url","isBig","size","punycode"],"mappings":";AAYO,MAAMA,IAA0B,CAACC,GAAkBC,IAAoB,eAAqB;AAC5F,QAAAC,IAAI,SAAS,cAAc,GAAG;AACpC,EAAAA,EAAE,WAAWD,GACbC,EAAE,OAAOF,GACTE,EAAE,MAAM;AACT,GAOaC,IAAoB,CAACC,GAAaC,MAA2B;AACzE,MAAIC,IAAO;AACX,SAAID,MAAcC,IAAA,MAEZF,IAAAA,EAAI,QAAQ,0BAA0B,EAAE,GACxCA,IAAAG,EAAS,QAAQH,CAAG,GAenB,kDAAkDA,IAAM,WAAWE,IAAO,iCAb9D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAa4G;AAChI;"}
@@ -1 +1 @@
1
- {"version":3,"file":"keyboard.amd.js","sources":["../../src/core/utils/keyboard.ts"],"sourcesContent":["/**\n * Утилиты для работы с устройствами ввода\n * @packageDocumentation\n */\n\n/**\n * Перевод строки в другую раскладку\n */\nexport const invertKeyboardLayout = (string: string): string => {\n\tconst a1 = 'qwertyuiop[]asdfghjkl;\\'zxcvbnm,./QWERTYUIOP{}ASDFGHJKL;\"ZXCVBNM<>?';\n\tconst a2 = 'йцукенгшщзхъфывапролджэячсмитьбю.ЙЦУКЕНГШЩЗХЪФЫВАПРОЛДжЭЯЧСМИТЬБЮ,';\n\tlet indexFinded: number;\n\n\tconst chars: Array<string> = string.split('');\n\tchars.forEach((char: string, index: number) => {\n\t\tindexFinded = a1.indexOf(char);\n\t\tif (indexFinded !== -1) {\n\t\t\tchars[index] = a2[indexFinded];\n\t\t} else {\n\t\t\tindexFinded = a2.indexOf(char);\n\t\t\tif (indexFinded !== -1) {\n\t\t\t\tchars[index] = a1[indexFinded];\n\t\t\t}\n\t\t}\n\t});\n\tstring = chars.join('');\n\n\treturn string;\n};\n"],"names":["invertKeyboardLayout","string","a1","a2","indexFinded"],"mappings":"yFAQa,MAAAA,EAAAC,GAAA,CACZ,MAAAC,EAAA,qEACAC,EAAA,uIAMCC,IAAA,6BAICA,IAAA,gBAGD,CAAA,gBAKF"}
1
+ {"version":3,"file":"keyboard.amd.js","sources":["../../src/core/utils/keyboard.ts"],"sourcesContent":["/**\r\n * Утилиты для работы с устройствами ввода\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Перевод строки в другую раскладку\r\n */\r\nexport const invertKeyboardLayout = (string: string): string => {\r\n\tconst a1 = 'qwertyuiop[]asdfghjkl;\\'zxcvbnm,./QWERTYUIOP{}ASDFGHJKL;\"ZXCVBNM<>?';\r\n\tconst a2 = 'йцукенгшщзхъфывапролджэячсмитьбю.ЙЦУКЕНГШЩЗХЪФЫВАПРОЛДжЭЯЧСМИТЬБЮ,';\r\n\tlet indexFinded: number;\r\n\r\n\tconst chars: Array<string> = string.split('');\r\n\tchars.forEach((char: string, index: number) => {\r\n\t\tindexFinded = a1.indexOf(char);\r\n\t\tif (indexFinded !== -1) {\r\n\t\t\tchars[index] = a2[indexFinded];\r\n\t\t} else {\r\n\t\t\tindexFinded = a2.indexOf(char);\r\n\t\t\tif (indexFinded !== -1) {\r\n\t\t\t\tchars[index] = a1[indexFinded];\r\n\t\t\t}\r\n\t\t}\r\n\t});\r\n\tstring = chars.join('');\r\n\r\n\treturn string;\r\n};\r\n"],"names":["invertKeyboardLayout","string","a1","a2","indexFinded"],"mappings":"yFAQa,MAAAA,EAAAC,GAAA,CACZ,MAAAC,EAAA,qEACAC,EAAA,uIAMCC,IAAA,6BAICA,IAAA,gBAGD,CAAA,gBAKF"}
@@ -1 +1 @@
1
- {"version":3,"file":"keyboard.js","sources":["../../src/core/utils/keyboard.ts"],"sourcesContent":["/**\n * Утилиты для работы с устройствами ввода\n * @packageDocumentation\n */\n\n/**\n * Перевод строки в другую раскладку\n */\nexport const invertKeyboardLayout = (string: string): string => {\n\tconst a1 = 'qwertyuiop[]asdfghjkl;\\'zxcvbnm,./QWERTYUIOP{}ASDFGHJKL;\"ZXCVBNM<>?';\n\tconst a2 = 'йцукенгшщзхъфывапролджэячсмитьбю.ЙЦУКЕНГШЩЗХЪФЫВАПРОЛДжЭЯЧСМИТЬБЮ,';\n\tlet indexFinded: number;\n\n\tconst chars: Array<string> = string.split('');\n\tchars.forEach((char: string, index: number) => {\n\t\tindexFinded = a1.indexOf(char);\n\t\tif (indexFinded !== -1) {\n\t\t\tchars[index] = a2[indexFinded];\n\t\t} else {\n\t\t\tindexFinded = a2.indexOf(char);\n\t\t\tif (indexFinded !== -1) {\n\t\t\t\tchars[index] = a1[indexFinded];\n\t\t\t}\n\t\t}\n\t});\n\tstring = chars.join('');\n\n\treturn string;\n};\n"],"names":["invertKeyboardLayout","string","a1","a2","indexFinded","chars","char","index"],"mappings":"AAQa,MAAAA,IAAuB,CAACC,MAA2B;AAC/D,QAAMC,IAAK,sEACLC,IAAK;AACP,MAAAC;AAEE,QAAAC,IAAuBJ,EAAO,MAAM,EAAE;AACtC,SAAAI,EAAA,QAAQ,CAACC,GAAcC,MAAkB;AAChC,IAAAH,IAAAF,EAAG,QAAQI,CAAI,GACzBF,MAAgB,KACbC,EAAAE,CAAK,IAAIJ,EAAGC,CAAW,KAEfA,IAAAD,EAAG,QAAQG,CAAI,GACzBF,MAAgB,OACbC,EAAAE,CAAK,IAAIL,EAAGE,CAAW;AAAA,EAE/B,CACA,GACQH,IAAAI,EAAM,KAAK,EAAE,GAEfJ;AACR;"}
1
+ {"version":3,"file":"keyboard.js","sources":["../../src/core/utils/keyboard.ts"],"sourcesContent":["/**\r\n * Утилиты для работы с устройствами ввода\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Перевод строки в другую раскладку\r\n */\r\nexport const invertKeyboardLayout = (string: string): string => {\r\n\tconst a1 = 'qwertyuiop[]asdfghjkl;\\'zxcvbnm,./QWERTYUIOP{}ASDFGHJKL;\"ZXCVBNM<>?';\r\n\tconst a2 = 'йцукенгшщзхъфывапролджэячсмитьбю.ЙЦУКЕНГШЩЗХЪФЫВАПРОЛДжЭЯЧСМИТЬБЮ,';\r\n\tlet indexFinded: number;\r\n\r\n\tconst chars: Array<string> = string.split('');\r\n\tchars.forEach((char: string, index: number) => {\r\n\t\tindexFinded = a1.indexOf(char);\r\n\t\tif (indexFinded !== -1) {\r\n\t\t\tchars[index] = a2[indexFinded];\r\n\t\t} else {\r\n\t\t\tindexFinded = a2.indexOf(char);\r\n\t\t\tif (indexFinded !== -1) {\r\n\t\t\t\tchars[index] = a1[indexFinded];\r\n\t\t\t}\r\n\t\t}\r\n\t});\r\n\tstring = chars.join('');\r\n\r\n\treturn string;\r\n};\r\n"],"names":["invertKeyboardLayout","string","a1","a2","indexFinded","chars","char","index"],"mappings":"AAQa,MAAAA,IAAuB,CAACC,MAA2B;AAC/D,QAAMC,IAAK,sEACLC,IAAK;AACP,MAAAC;AAEE,QAAAC,IAAuBJ,EAAO,MAAM,EAAE;AACtC,SAAAI,EAAA,QAAQ,CAACC,GAAcC,MAAkB;AAChC,IAAAH,IAAAF,EAAG,QAAQI,CAAI,GACzBF,MAAgB,KACbC,EAAAE,CAAK,IAAIJ,EAAGC,CAAW,KAEfA,IAAAD,EAAG,QAAQG,CAAI,GACzBF,MAAgB,OACbC,EAAAE,CAAK,IAAIL,EAAGE,CAAW;AAAA,EAE/B,CACA,GACQH,IAAAI,EAAM,KAAK,EAAE,GAEfJ;AACR;"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/forms-VHBOI0dh.amd"],function(u,e,n){"use strict";if(typeof i>"u")var i=window.Vue;e.cloneDeep=n.cloneDeep,e.debounce=n.debounce,e.memoize=n.memoize,e.merge=n.merge,e.throttle=n.throttle,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","../.chunks/forms-JhDIERVr.amd"],function(u,e,n){"use strict";if(typeof i>"u")var i=window.Vue;e.cloneDeep=n.cloneDeep,e.debounce=n.debounce,e.memoize=n.memoize,e.merge=n.merge,e.throttle=n.throttle,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=lodash.amd.js.map
package/utils/lodash.js CHANGED
@@ -1,4 +1,4 @@
1
- import { L as s, s as a, M as m, O as r, N as t } from "../.chunks/forms-6Z3p_rjQ.es.js";
1
+ import { L as s, s as a, M as m, O as r, N as t } from "../.chunks/forms-Dm3JmuO3.es.js";
2
2
  export {
3
3
  s as cloneDeep,
4
4
  a as debounce,
@@ -1 +1 @@
1
- {"version":3,"file":"number.amd.js","sources":["../../src/core/utils/number.ts"],"sourcesContent":["/**\n * Работа с числами\n * @packageDocumentation\n */\n\n/**\n * Посчитать процент от числа (сколько процентов составляет part от full)\n * @param part - первое число\n * @param full - второе число\n * @param precision - точность (колличество знаков после запятой)\n */\nexport const percentOfNumber = (part: '--' | number, full: number = 100, precision: number = 0): '--' | number => {\n\tif (part === '--') return part;\n\n\tlet percent = (full * 1) ? part / full : 0;\n\tpercent *= 100;\n\n\t// если десятичные знаки не выводятся и число при округлении может дать ноль, то округляем в большую сторону\n\tif (!precision && percent < 1) {\n\t\tpercent = Math.round(percent * (Math.pow(10, 2))) / (Math.pow(10, 2));\n\t} else {\n\t\tpercent = Math.round(percent * (Math.pow(10, precision))) / (Math.pow(10, precision));\n\t}\n\n\treturn percent;\n};\n"],"names":["percentOfNumber","part","full","precision","percent"],"mappings":"yFAWO,MAAAA,EAAA,CAAAC,EAAAC,EAAA,IAAAC,EAAA,IAAA,CACN,GAAAF,IAAA,KAAA,OAAAA,EAEA,IAAAG,EAAAF,EAAA,EAAAD,EAAAC,EAAA,gBAIA,CAAAC,GAAAC,EAAA,+FAOD"}
1
+ {"version":3,"file":"number.amd.js","sources":["../../src/core/utils/number.ts"],"sourcesContent":["/**\r\n * Работа с числами\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Посчитать процент от числа (сколько процентов составляет part от full)\r\n * @param part - первое число\r\n * @param full - второе число\r\n * @param precision - точность (колличество знаков после запятой)\r\n */\r\nexport const percentOfNumber = (part: '--' | number, full: number = 100, precision: number = 0): '--' | number => {\r\n\tif (part === '--') return part;\r\n\r\n\tlet percent = (full * 1) ? part / full : 0;\r\n\tpercent *= 100;\r\n\r\n\t// если десятичные знаки не выводятся и число при округлении может дать ноль, то округляем в большую сторону\r\n\tif (!precision && percent < 1) {\r\n\t\tpercent = Math.round(percent * (Math.pow(10, 2))) / (Math.pow(10, 2));\r\n\t} else {\r\n\t\tpercent = Math.round(percent * (Math.pow(10, precision))) / (Math.pow(10, precision));\r\n\t}\r\n\r\n\treturn percent;\r\n};\r\n"],"names":["percentOfNumber","part","full","precision","percent"],"mappings":"yFAWO,MAAAA,EAAA,CAAAC,EAAAC,EAAA,IAAAC,EAAA,IAAA,CACN,GAAAF,IAAA,KAAA,OAAAA,EAEA,IAAAG,EAAAF,EAAA,EAAAD,EAAAC,EAAA,gBAIA,CAAAC,GAAAC,EAAA,+FAOD"}
@@ -1 +1 @@
1
- {"version":3,"file":"number.js","sources":["../../src/core/utils/number.ts"],"sourcesContent":["/**\n * Работа с числами\n * @packageDocumentation\n */\n\n/**\n * Посчитать процент от числа (сколько процентов составляет part от full)\n * @param part - первое число\n * @param full - второе число\n * @param precision - точность (колличество знаков после запятой)\n */\nexport const percentOfNumber = (part: '--' | number, full: number = 100, precision: number = 0): '--' | number => {\n\tif (part === '--') return part;\n\n\tlet percent = (full * 1) ? part / full : 0;\n\tpercent *= 100;\n\n\t// если десятичные знаки не выводятся и число при округлении может дать ноль, то округляем в большую сторону\n\tif (!precision && percent < 1) {\n\t\tpercent = Math.round(percent * (Math.pow(10, 2))) / (Math.pow(10, 2));\n\t} else {\n\t\tpercent = Math.round(percent * (Math.pow(10, precision))) / (Math.pow(10, precision));\n\t}\n\n\treturn percent;\n};\n"],"names":["percentOfNumber","part","full","precision","percent"],"mappings":"AAWO,MAAMA,IAAkB,CAACC,GAAqBC,IAAe,KAAKC,IAAoB,MAAqB;AAC7G,MAAAF,MAAS,KAAa,QAAAA;AAE1B,MAAIG,IAAWF,IAAO,IAAKD,IAAOC,IAAO;AAC9B,SAAAE,KAAA,KAGP,CAACD,KAAaC,IAAU,IAC3BA,IAAU,KAAK,MAAMA,IAAW,KAAK,IAAI,IAAI,CAAC,CAAE,IAAK,KAAK,IAAI,IAAI,CAAC,IAEnEA,IAAU,KAAK,MAAMA,IAAW,KAAK,IAAI,IAAID,CAAS,CAAE,IAAK,KAAK,IAAI,IAAIA,CAAS,GAG7EC;AACR;"}
1
+ {"version":3,"file":"number.js","sources":["../../src/core/utils/number.ts"],"sourcesContent":["/**\r\n * Работа с числами\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Посчитать процент от числа (сколько процентов составляет part от full)\r\n * @param part - первое число\r\n * @param full - второе число\r\n * @param precision - точность (колличество знаков после запятой)\r\n */\r\nexport const percentOfNumber = (part: '--' | number, full: number = 100, precision: number = 0): '--' | number => {\r\n\tif (part === '--') return part;\r\n\r\n\tlet percent = (full * 1) ? part / full : 0;\r\n\tpercent *= 100;\r\n\r\n\t// если десятичные знаки не выводятся и число при округлении может дать ноль, то округляем в большую сторону\r\n\tif (!precision && percent < 1) {\r\n\t\tpercent = Math.round(percent * (Math.pow(10, 2))) / (Math.pow(10, 2));\r\n\t} else {\r\n\t\tpercent = Math.round(percent * (Math.pow(10, precision))) / (Math.pow(10, precision));\r\n\t}\r\n\r\n\treturn percent;\r\n};\r\n"],"names":["percentOfNumber","part","full","precision","percent"],"mappings":"AAWO,MAAMA,IAAkB,CAACC,GAAqBC,IAAe,KAAKC,IAAoB,MAAqB;AAC7G,MAAAF,MAAS,KAAa,QAAAA;AAE1B,MAAIG,IAAWF,IAAO,IAAKD,IAAOC,IAAO;AAC9B,SAAAE,KAAA,KAGP,CAACD,KAAaC,IAAU,IAC3BA,IAAU,KAAK,MAAMA,IAAW,KAAK,IAAI,IAAI,CAAC,CAAE,IAAK,KAAK,IAAI,IAAI,CAAC,IAEnEA,IAAU,KAAK,MAAMA,IAAW,KAAK,IAAI,IAAID,CAAS,CAAE,IAAK,KAAK,IAAI,IAAIA,CAAS,GAG7EC;AACR;"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","../.chunks/forms-VHBOI0dh.amd"],function(a,t,i){"use strict";if(typeof n>"u")var n=window.Vue;const u=(c,e,o=i.Core.state.currency)=>{e=e??i.useI18nLang().value;let r=c.toLocaleString(e,{style:"currency",currency:o,maximumFractionDigits:2});return r=r.replace(",","."),r};t.genPrice=u,Object.defineProperty(t,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","../.chunks/forms-JhDIERVr.amd"],function(a,t,i){"use strict";if(typeof n>"u")var n=window.Vue;const u=(c,e,o=i.Core.state.currency)=>{e=e??i.useI18nLang().value;let r=c.toLocaleString(e,{style:"currency",currency:o,maximumFractionDigits:2});return r=r.replace(",","."),r};t.genPrice=u,Object.defineProperty(t,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=price.amd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"price.amd.js","sources":["../../src/core/utils/price.ts"],"sourcesContent":["/**\n * Работа с ценами\n * @packageDocumentation\n */\n\nimport type { Lang } from '@/core/plugins/i18n';\nimport { useI18nLang } from '@/core/plugins/i18n';\nimport Core from '@/core/core/core';\n\n/**\n * Сгенерировать строку с суммой и валютой\n * @param sum - сумма\n * @param lang - язык, берётся из профиля, если не задано\n * @param currency - валюта, берётся из профиля, если не задано\n * @returns строка с языкозависимым представлением числа sum и знаком валюты\n */\nexport const genPrice = (sum: number, lang?: Lang, currency: typeof Core.state.currency = Core.state.currency): string => {\n\tlang = lang ?? useI18nLang().value;\n\n\tlet sumStr = sum.toLocaleString(lang, { style: 'currency', currency, maximumFractionDigits: 2 });\n\tsumStr = sumStr.replace(',', '.');\n\n\treturn sumStr;\n};\n"],"names":["genPrice","sum","lang","currency","forms"],"mappings":"2HAgBO,MAAAA,EAAA,CAAAC,EAAAC,EAAAC,EAAAC,EAAA,KAAA,MAAA,WAAA,yIAOP"}
1
+ {"version":3,"file":"price.amd.js","sources":["../../src/core/utils/price.ts"],"sourcesContent":["/**\r\n * Работа с ценами\r\n * @packageDocumentation\r\n */\r\n\r\nimport type { Lang } from '@/core/plugins/i18n';\r\nimport { useI18nLang } from '@/core/plugins/i18n';\r\nimport Core from '@/core/core/core';\r\n\r\n/**\r\n * Сгенерировать строку с суммой и валютой\r\n * @param sum - сумма\r\n * @param lang - язык, берётся из профиля, если не задано\r\n * @param currency - валюта, берётся из профиля, если не задано\r\n * @returns строка с языкозависимым представлением числа sum и знаком валюты\r\n */\r\nexport const genPrice = (sum: number, lang?: Lang, currency: typeof Core.state.currency = Core.state.currency): string => {\r\n\tlang = lang ?? useI18nLang().value;\r\n\r\n\tlet sumStr = sum.toLocaleString(lang, { style: 'currency', currency, maximumFractionDigits: 2 });\r\n\tsumStr = sumStr.replace(',', '.');\r\n\r\n\treturn sumStr;\r\n};\r\n"],"names":["genPrice","sum","lang","currency","forms"],"mappings":"2HAgBO,MAAAA,EAAA,CAAAC,EAAAC,EAAAC,EAAAC,EAAA,KAAA,MAAA,WAAA,yIAOP"}
package/utils/price.js CHANGED
@@ -1,4 +1,4 @@
1
- import { u as o, C as s } from "../.chunks/forms-6Z3p_rjQ.es.js";
1
+ import { u as o, C as s } from "../.chunks/forms-Dm3JmuO3.es.js";
2
2
  const a = (t, e, c = s.state.currency) => {
3
3
  e = e ?? o().value;
4
4
  let r = t.toLocaleString(e, { style: "currency", currency: c, maximumFractionDigits: 2 });
@@ -1 +1 @@
1
- {"version":3,"file":"price.js","sources":["../../src/core/utils/price.ts"],"sourcesContent":["/**\n * Работа с ценами\n * @packageDocumentation\n */\n\nimport type { Lang } from '@/core/plugins/i18n';\nimport { useI18nLang } from '@/core/plugins/i18n';\nimport Core from '@/core/core/core';\n\n/**\n * Сгенерировать строку с суммой и валютой\n * @param sum - сумма\n * @param lang - язык, берётся из профиля, если не задано\n * @param currency - валюта, берётся из профиля, если не задано\n * @returns строка с языкозависимым представлением числа sum и знаком валюты\n */\nexport const genPrice = (sum: number, lang?: Lang, currency: typeof Core.state.currency = Core.state.currency): string => {\n\tlang = lang ?? useI18nLang().value;\n\n\tlet sumStr = sum.toLocaleString(lang, { style: 'currency', currency, maximumFractionDigits: 2 });\n\tsumStr = sumStr.replace(',', '.');\n\n\treturn sumStr;\n};\n"],"names":["genPrice","sum","lang","currency","Core","useI18nLang","sumStr"],"mappings":";AAgBO,MAAMA,IAAW,CAACC,GAAaC,GAAaC,IAAuCC,EAAK,MAAM,aAAqB;AAClH,EAAAF,IAAAA,KAAQG,EAAc,EAAA;AAEzB,MAAAC,IAASL,EAAI,eAAeC,GAAM,EAAE,OAAO,YAAY,UAAAC,GAAU,uBAAuB,EAAG,CAAA;AACtF,SAAAG,IAAAA,EAAO,QAAQ,KAAK,GAAG,GAEzBA;AACR;"}
1
+ {"version":3,"file":"price.js","sources":["../../src/core/utils/price.ts"],"sourcesContent":["/**\r\n * Работа с ценами\r\n * @packageDocumentation\r\n */\r\n\r\nimport type { Lang } from '@/core/plugins/i18n';\r\nimport { useI18nLang } from '@/core/plugins/i18n';\r\nimport Core from '@/core/core/core';\r\n\r\n/**\r\n * Сгенерировать строку с суммой и валютой\r\n * @param sum - сумма\r\n * @param lang - язык, берётся из профиля, если не задано\r\n * @param currency - валюта, берётся из профиля, если не задано\r\n * @returns строка с языкозависимым представлением числа sum и знаком валюты\r\n */\r\nexport const genPrice = (sum: number, lang?: Lang, currency: typeof Core.state.currency = Core.state.currency): string => {\r\n\tlang = lang ?? useI18nLang().value;\r\n\r\n\tlet sumStr = sum.toLocaleString(lang, { style: 'currency', currency, maximumFractionDigits: 2 });\r\n\tsumStr = sumStr.replace(',', '.');\r\n\r\n\treturn sumStr;\r\n};\r\n"],"names":["genPrice","sum","lang","currency","Core","useI18nLang","sumStr"],"mappings":";AAgBO,MAAMA,IAAW,CAACC,GAAaC,GAAaC,IAAuCC,EAAK,MAAM,aAAqB;AAClH,EAAAF,IAAAA,KAAQG,EAAc,EAAA;AAEzB,MAAAC,IAASL,EAAI,eAAeC,GAAM,EAAE,OAAO,YAAY,UAAAC,GAAU,uBAAuB,EAAG,CAAA;AACtF,SAAAG,IAAAA,EAAO,QAAQ,KAAK,GAAG,GAEzBA;AACR;"}
@@ -1 +1 @@
1
- {"version":3,"file":"route.amd.js","sources":["../../src/core/utils/route.ts"],"sourcesContent":["/**\n * Управление навигацией страницы, работа с hash параметрами страницы\n * @packageDocumentation\n */\n\n/**\n * Получить значение хэш параметра страницы\n */\nexport const getHash = function (name: string, locationHash: string = location.hash): string {\n\tconst re = new RegExp('[#?&]' + name + '=([^&]*)');\n\tconst value = locationHash.match(re);\n\tif (!value || value.length != 2) return '';\n\n\tvalue[1] = decodeURIComponent(value[1]);\n\tvalue[1] = value[1].replace(/\\+/g, ' ');\n\n\treturn value[1];\n};\n\n/**\n * Установить значение в хэш параметр страницы\n */\nexport const setHash = function (name: string, value: string | null, replaceState: boolean = true): void {\n\tlet hash = genHash(name, value);\n\tif (hash == '#') hash = '';\n\n\tif (replaceState) {\n\t\thistorySetState(true, hash);\n\t} else {\n\t\tlocation.hash = hash;\n\t}\n};\n\n/**\n * Удалить значение из хэш параметра страницы\n */\nexport const delHash = function (name: string, value: string, replaceState: boolean = true): void {\n\tsetHash(name, null, replaceState);\n};\n\n/**\n * Сгенерировать новое значение для хэш параметра страницы с указанным параметром\n */\nexport const genHash = function (name: string, value: string | null, locationHash: string = location.hash): string {\n\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\n\n\tlocationHash = locationHash.replace(re, '');\n\n\tif (value !== null) {\n\t\tvalue = (value + '').replace(' ', '%20');\n\t\tlocationHash = locationHash.replace(re, '&' + name + '=' + value);\n\n\t\tif (locationHash.indexOf('&' + name + '=') == -1) locationHash += '&' + name + '=' + value;\n\t}\n\n\tlocationHash = locationHash.replace(/&+/g, '&');\n\tlocationHash = locationHash.replace(/&$/, '');\n\n\tlocationHash = '#' + locationHash;\n\tlocationHash = locationHash.replace(/^#+/, '#');\n\n\t// hash страницы не должен быть пустым, чтобы не перекидывало к верху страницы\n\tlocationHash = locationHash.replace(/^#:-\\)/, '#');\n\tif ((locationHash == '' || locationHash == '#') && location.hash) locationHash = '#:-)';\n\n\treturn locationHash;\n};\n\n/**\n * Установить значения в хэш параметр страницы\n */\nexport const setHashs = function (data: Map<string, string> | object | any, replaceState: boolean): void {\n\tif (data instanceof Map) data = Object.fromEntries(data);\n\n\tif (replaceState === undefined) replaceState = true;\n\tlet hash = location.hash;\n\n\tfor (const name in data) {\n\t\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\n\t\thash = hash.replace(re, '');\n\n\t\tif (data[name] !== null) {\n\t\t\tdata[name] = (data[name] + '').replace(' ', '%20');\n\t\t\thash += '&' + name + '=' + data[name];\n\t\t}\n\t}\n\n\thash = hash.replace(/&+/g, '&');\n\thash = hash.replace(/^(#)?&|&$/g, '$1');\n\thash = '#' + hash;\n\thash = hash.replace(/^#+/, '#');\n\n\tif (replaceState) {\n\t\tif (hash == '#') hash = '.';\n\t\thistorySetState(true, hash);\n\t} else {\n\t\tlocation.hash = hash;\n\t}\n};\n\n/**\n * Установть позицию в истории вкладки браузера\n *\n * @see history.replaceState\n * @see history.pushState\n *\n * @todo Мешает SPA сайта, вместо него использовать historyPushState() из @/component/vue/app/spa\n */\nexport const historySetState = (replace: boolean = false, hash: string): void => {\n\tif (replace) {\n\t\thistory.replaceState(null, '', hash);\n\t} else {\n\t\thistory.pushState(null, '', hash);\n\t}\n};\n"],"names":["getHash","name","locationHash","re","value","setHash","replaceState","historySetState","hash","delHash","genHash","setHashs","data","replace"],"mappings":"yFAQO,MAAAA,EAAA,SAAAC,EAAAC,EAAA,SAAA,KAAA,CACN,MAAAC,EAAA,IAAA,OAAA,QAAAF,EAAA,UAAA,eAEA,MAAA,CAAAG,GAAAA,EAAA,QAAA,EAAA,IAEAA,EAAA,CAAA,EAAA,mBAAAA,EAAA,CAAA,CAAA,EACAA,EAAA,CAAA,EAAAA,EAAA,CAAA,EAAA,QAAA,MAAA,GAAA,EAEAA,EAAA,CAAA,IAMMC,EAAA,SAAAJ,EAAAG,EAAAE,EAAA,GAAA,+BAKLC,EAAA,GAAAC,CAAA,EAEA,SAAA,KAAAA,GAOKC,EAAA,SAAAR,EAAAG,EAAAE,EAAA,GAAA,cAOAI,EAAA,SAAAT,EAAAG,EAAAF,EAAA,SAAA,KAAA,CACN,MAAAC,EAAA,IAAA,OAAA,KAAAF,EAAA,SAAA,GAAA,2BAIAG,IAAA,OACCA,GAAAA,EAAA,IAAA,QAAA,IAAA,KAAA,EACAF,EAAAA,EAAA,QAAAC,EAAA,IAAAF,EAAA,IAAAG,CAAA,0FAQDF,EAAA,IAAAA,oDAKAA,GAAA,IAAAA,GAAA,MAAA,SAAA,OAAAA,EAAA,WAQYS,EAAA,SAAAC,EAAAN,EAAA,CACZM,aAAA,MAAAA,EAAA,OAAA,YAAAA,CAAA,sBAGA,IAAAJ,EAAA,SAAA,KAEA,UAAAP,KAAAW,EAAA,CACC,MAAAT,EAAA,IAAA,OAAA,KAAAF,EAAA,SAAA,GAAA,oBAGAW,EAAAX,CAAA,IAAA,OACCW,EAAAX,CAAA,GAAAW,EAAAX,CAAA,EAAA,IAAA,QAAA,IAAA,KAAA,EACAO,GAAA,IAAAP,EAAA,IAAAW,EAAAX,CAAA,yDAMFO,EAAA,IAAAA,4CAKCD,EAAA,GAAAC,CAAA,GAEA,SAAA,KAAAA,GAYKD,EAAA,CAAAM,EAAA,GAAAL,IAAA,+DAMP"}
1
+ {"version":3,"file":"route.amd.js","sources":["../../src/core/utils/route.ts"],"sourcesContent":["/**\r\n * Управление навигацией страницы, работа с hash параметрами страницы\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Получить значение хэш параметра страницы\r\n */\r\nexport const getHash = function (name: string, locationHash: string = location.hash): string {\r\n\tconst re = new RegExp('[#?&]' + name + '=([^&]*)');\r\n\tconst value = locationHash.match(re);\r\n\tif (!value || value.length != 2) return '';\r\n\r\n\tvalue[1] = decodeURIComponent(value[1]);\r\n\tvalue[1] = value[1].replace(/\\+/g, ' ');\r\n\r\n\treturn value[1];\r\n};\r\n\r\n/**\r\n * Установить значение в хэш параметр страницы\r\n */\r\nexport const setHash = function (name: string, value: string | number | null, replaceState: boolean = true): void {\r\n\tlet hash = genHash(name, value);\r\n\tif (hash == '#') hash = '';\r\n\r\n\tif (replaceState) {\r\n\t\thistorySetState(true, hash);\r\n\t} else {\r\n\t\tlocation.hash = hash;\r\n\t}\r\n};\r\n\r\n/**\r\n * Удалить значение из хэш параметра страницы\r\n */\r\nexport const delHash = function (name: string, value: string, replaceState: boolean = true): void {\r\n\tsetHash(name, null, replaceState);\r\n};\r\n\r\n/**\r\n * Сгенерировать новое значение для хэш параметра страницы с указанным параметром\r\n */\r\nexport const genHash = function (name: string, value: string | number | null, locationHash: string = location.hash): string {\r\n\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\r\n\r\n\tlocationHash = locationHash.replace(re, '');\r\n\r\n\tif (value !== null) {\r\n\t\tvalue = (value + '').replace(' ', '%20');\r\n\t\tlocationHash = locationHash.replace(re, '&' + name + '=' + value);\r\n\r\n\t\tif (locationHash.indexOf('&' + name + '=') == -1) locationHash += '&' + name + '=' + value;\r\n\t}\r\n\r\n\tlocationHash = locationHash.replace(/&+/g, '&');\r\n\tlocationHash = locationHash.replace(/&$/, '');\r\n\r\n\tlocationHash = '#' + locationHash;\r\n\tlocationHash = locationHash.replace(/^#+/, '#');\r\n\r\n\t// hash страницы не должен быть пустым, чтобы не перекидывало к верху страницы\r\n\tlocationHash = locationHash.replace(/^#:-\\)/, '#');\r\n\tif ((locationHash == '' || locationHash == '#') && location.hash) locationHash = '#:-)';\r\n\r\n\treturn locationHash;\r\n};\r\n\r\n/**\r\n * Установить значения в хэш параметр страницы\r\n */\r\nexport const setHashs = function (data: Map<string, string> | object | any, replaceState: boolean): void {\r\n\tif (data instanceof Map) data = Object.fromEntries(data);\r\n\r\n\tif (replaceState === undefined) replaceState = true;\r\n\tlet hash = location.hash;\r\n\r\n\tfor (const name in data) {\r\n\t\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\r\n\t\thash = hash.replace(re, '');\r\n\r\n\t\tif (data[name] !== null) {\r\n\t\t\tdata[name] = (data[name] + '').replace(' ', '%20');\r\n\t\t\thash += '&' + name + '=' + data[name];\r\n\t\t}\r\n\t}\r\n\r\n\thash = hash.replace(/&+/g, '&');\r\n\thash = hash.replace(/^(#)?&|&$/g, '$1');\r\n\thash = '#' + hash;\r\n\thash = hash.replace(/^#+/, '#');\r\n\r\n\tif (replaceState) {\r\n\t\tif (hash == '#') hash = '.';\r\n\t\thistorySetState(true, hash);\r\n\t} else {\r\n\t\tlocation.hash = hash;\r\n\t}\r\n};\r\n\r\n/**\r\n * Установть позицию в истории вкладки браузера\r\n *\r\n * @see history.replaceState\r\n * @see history.pushState\r\n *\r\n * @todo Мешает SPA сайта, вместо него использовать historyPushState() из @/component/vue/app/spa\r\n */\r\nexport const historySetState = (replace: boolean = false, hash: string): void => {\r\n\tif (replace) {\r\n\t\thistory.replaceState(null, '', hash);\r\n\t} else {\r\n\t\thistory.pushState(null, '', hash);\r\n\t}\r\n};\r\n"],"names":["getHash","name","locationHash","re","value","setHash","replaceState","historySetState","hash","delHash","genHash","setHashs","data","replace"],"mappings":"yFAQO,MAAAA,EAAA,SAAAC,EAAAC,EAAA,SAAA,KAAA,CACN,MAAAC,EAAA,IAAA,OAAA,QAAAF,EAAA,UAAA,eAEA,MAAA,CAAAG,GAAAA,EAAA,QAAA,EAAA,IAEAA,EAAA,CAAA,EAAA,mBAAAA,EAAA,CAAA,CAAA,EACAA,EAAA,CAAA,EAAAA,EAAA,CAAA,EAAA,QAAA,MAAA,GAAA,EAEAA,EAAA,CAAA,IAMMC,EAAA,SAAAJ,EAAAG,EAAAE,EAAA,GAAA,+BAKLC,EAAA,GAAAC,CAAA,EAEA,SAAA,KAAAA,GAOKC,EAAA,SAAAR,EAAAG,EAAAE,EAAA,GAAA,cAOAI,EAAA,SAAAT,EAAAG,EAAAF,EAAA,SAAA,KAAA,CACN,MAAAC,EAAA,IAAA,OAAA,KAAAF,EAAA,SAAA,GAAA,2BAIAG,IAAA,OACCA,GAAAA,EAAA,IAAA,QAAA,IAAA,KAAA,EACAF,EAAAA,EAAA,QAAAC,EAAA,IAAAF,EAAA,IAAAG,CAAA,0FAQDF,EAAA,IAAAA,oDAKAA,GAAA,IAAAA,GAAA,MAAA,SAAA,OAAAA,EAAA,WAQYS,EAAA,SAAAC,EAAAN,EAAA,CACZM,aAAA,MAAAA,EAAA,OAAA,YAAAA,CAAA,sBAGA,IAAAJ,EAAA,SAAA,KAEA,UAAAP,KAAAW,EAAA,CACC,MAAAT,EAAA,IAAA,OAAA,KAAAF,EAAA,SAAA,GAAA,oBAGAW,EAAAX,CAAA,IAAA,OACCW,EAAAX,CAAA,GAAAW,EAAAX,CAAA,EAAA,IAAA,QAAA,IAAA,KAAA,EACAO,GAAA,IAAAP,EAAA,IAAAW,EAAAX,CAAA,yDAMFO,EAAA,IAAAA,4CAKCD,EAAA,GAAAC,CAAA,GAEA,SAAA,KAAAA,GAYKD,EAAA,CAAAM,EAAA,GAAAL,IAAA,+DAMP"}
@@ -1 +1 @@
1
- {"version":3,"file":"route.js","sources":["../../src/core/utils/route.ts"],"sourcesContent":["/**\n * Управление навигацией страницы, работа с hash параметрами страницы\n * @packageDocumentation\n */\n\n/**\n * Получить значение хэш параметра страницы\n */\nexport const getHash = function (name: string, locationHash: string = location.hash): string {\n\tconst re = new RegExp('[#?&]' + name + '=([^&]*)');\n\tconst value = locationHash.match(re);\n\tif (!value || value.length != 2) return '';\n\n\tvalue[1] = decodeURIComponent(value[1]);\n\tvalue[1] = value[1].replace(/\\+/g, ' ');\n\n\treturn value[1];\n};\n\n/**\n * Установить значение в хэш параметр страницы\n */\nexport const setHash = function (name: string, value: string | null, replaceState: boolean = true): void {\n\tlet hash = genHash(name, value);\n\tif (hash == '#') hash = '';\n\n\tif (replaceState) {\n\t\thistorySetState(true, hash);\n\t} else {\n\t\tlocation.hash = hash;\n\t}\n};\n\n/**\n * Удалить значение из хэш параметра страницы\n */\nexport const delHash = function (name: string, value: string, replaceState: boolean = true): void {\n\tsetHash(name, null, replaceState);\n};\n\n/**\n * Сгенерировать новое значение для хэш параметра страницы с указанным параметром\n */\nexport const genHash = function (name: string, value: string | null, locationHash: string = location.hash): string {\n\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\n\n\tlocationHash = locationHash.replace(re, '');\n\n\tif (value !== null) {\n\t\tvalue = (value + '').replace(' ', '%20');\n\t\tlocationHash = locationHash.replace(re, '&' + name + '=' + value);\n\n\t\tif (locationHash.indexOf('&' + name + '=') == -1) locationHash += '&' + name + '=' + value;\n\t}\n\n\tlocationHash = locationHash.replace(/&+/g, '&');\n\tlocationHash = locationHash.replace(/&$/, '');\n\n\tlocationHash = '#' + locationHash;\n\tlocationHash = locationHash.replace(/^#+/, '#');\n\n\t// hash страницы не должен быть пустым, чтобы не перекидывало к верху страницы\n\tlocationHash = locationHash.replace(/^#:-\\)/, '#');\n\tif ((locationHash == '' || locationHash == '#') && location.hash) locationHash = '#:-)';\n\n\treturn locationHash;\n};\n\n/**\n * Установить значения в хэш параметр страницы\n */\nexport const setHashs = function (data: Map<string, string> | object | any, replaceState: boolean): void {\n\tif (data instanceof Map) data = Object.fromEntries(data);\n\n\tif (replaceState === undefined) replaceState = true;\n\tlet hash = location.hash;\n\n\tfor (const name in data) {\n\t\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\n\t\thash = hash.replace(re, '');\n\n\t\tif (data[name] !== null) {\n\t\t\tdata[name] = (data[name] + '').replace(' ', '%20');\n\t\t\thash += '&' + name + '=' + data[name];\n\t\t}\n\t}\n\n\thash = hash.replace(/&+/g, '&');\n\thash = hash.replace(/^(#)?&|&$/g, '$1');\n\thash = '#' + hash;\n\thash = hash.replace(/^#+/, '#');\n\n\tif (replaceState) {\n\t\tif (hash == '#') hash = '.';\n\t\thistorySetState(true, hash);\n\t} else {\n\t\tlocation.hash = hash;\n\t}\n};\n\n/**\n * Установть позицию в истории вкладки браузера\n *\n * @see history.replaceState\n * @see history.pushState\n *\n * @todo Мешает SPA сайта, вместо него использовать historyPushState() из @/component/vue/app/spa\n */\nexport const historySetState = (replace: boolean = false, hash: string): void => {\n\tif (replace) {\n\t\thistory.replaceState(null, '', hash);\n\t} else {\n\t\thistory.pushState(null, '', hash);\n\t}\n};\n"],"names":["getHash","name","locationHash","re","value","setHash","replaceState","hash","genHash","historySetState","delHash","setHashs","data","replace"],"mappings":"AAQO,MAAMA,IAAU,SAAUC,GAAcC,IAAuB,SAAS,MAAc;AAC5F,QAAMC,IAAK,IAAI,OAAO,UAAUF,IAAO,UAAU,GAC3CG,IAAQF,EAAa,MAAMC,CAAE;AACnC,SAAI,CAACC,KAASA,EAAM,UAAU,IAAU,MAExCA,EAAM,CAAC,IAAI,mBAAmBA,EAAM,CAAC,CAAC,GACtCA,EAAM,CAAC,IAAIA,EAAM,CAAC,EAAE,QAAQ,OAAO,GAAG,GAE/BA,EAAM,CAAC;AACf,GAKaC,IAAU,SAAUJ,GAAcG,GAAsBE,IAAwB,IAAY;AACpG,MAAAC,IAAOC,EAAQP,GAAMG,CAAK;AAC1B,EAAAG,KAAQ,QAAYA,IAAA,KAEpBD,IACHG,EAAgB,IAAMF,CAAI,IAE1B,SAAS,OAAOA;AAElB,GAKaG,IAAU,SAAUT,GAAcG,GAAeE,IAAwB,IAAY;AACzF,EAAAD,EAAAJ,GAAM,MAAMK,CAAY;AACjC,GAKaE,IAAU,SAAUP,GAAcG,GAAsBF,IAAuB,SAAS,MAAc;AAClH,QAAMC,IAAK,IAAI,OAAO,OAAOF,IAAO,UAAU,GAAG;AAElC,SAAAC,IAAAA,EAAa,QAAQC,GAAI,EAAE,GAEtCC,MAAU,SACbA,KAASA,IAAQ,IAAI,QAAQ,KAAK,KAAK,GACvCF,IAAeA,EAAa,QAAQC,GAAI,MAAMF,IAAO,MAAMG,CAAK,GAE5DF,EAAa,QAAQ,MAAMD,IAAO,GAAG,KAAK,OAAIC,KAAgB,MAAMD,IAAO,MAAMG,KAGvEF,IAAAA,EAAa,QAAQ,OAAO,GAAG,GAC/BA,IAAAA,EAAa,QAAQ,MAAM,EAAE,GAE5CA,IAAe,MAAMA,GACNA,IAAAA,EAAa,QAAQ,OAAO,GAAG,GAG/BA,IAAAA,EAAa,QAAQ,UAAU,GAAG,IAC5CA,KAAgB,MAAMA,KAAgB,QAAQ,SAAS,SAAqBA,IAAA,SAE1EA;AACR,GAKaS,IAAW,SAAUC,GAA0CN,GAA6B;AACxG,EAAIM,aAAgB,QAAYA,IAAA,OAAO,YAAYA,CAAI,IAEnDN,MAAiB,WAA0BA,IAAA;AAC/C,MAAIC,IAAO,SAAS;AAEpB,aAAWN,KAAQW,GAAM;AACxB,UAAMT,IAAK,IAAI,OAAO,OAAOF,IAAO,UAAU,GAAG;AAC1C,IAAAM,IAAAA,EAAK,QAAQJ,GAAI,EAAE,GAEtBS,EAAKX,CAAI,MAAM,SACbW,EAAAX,CAAI,KAAKW,EAAKX,CAAI,IAAI,IAAI,QAAQ,KAAK,KAAK,GACjDM,KAAQ,MAAMN,IAAO,MAAMW,EAAKX,CAAI;AAAA,EAEtC;AAEO,EAAAM,IAAAA,EAAK,QAAQ,OAAO,GAAG,GACvBA,IAAAA,EAAK,QAAQ,cAAc,IAAI,GACtCA,IAAO,MAAMA,GACNA,IAAAA,EAAK,QAAQ,OAAO,GAAG,GAE1BD,KACCC,KAAQ,QAAYA,IAAA,MACxBE,EAAgB,IAAMF,CAAI,KAE1B,SAAS,OAAOA;AAElB,GAUaE,IAAkB,CAACI,IAAmB,IAAON,MAAuB;AAChF,EAAIM,IACK,QAAA,aAAa,MAAM,IAAIN,CAAI,IAE3B,QAAA,UAAU,MAAM,IAAIA,CAAI;AAElC;"}
1
+ {"version":3,"file":"route.js","sources":["../../src/core/utils/route.ts"],"sourcesContent":["/**\r\n * Управление навигацией страницы, работа с hash параметрами страницы\r\n * @packageDocumentation\r\n */\r\n\r\n/**\r\n * Получить значение хэш параметра страницы\r\n */\r\nexport const getHash = function (name: string, locationHash: string = location.hash): string {\r\n\tconst re = new RegExp('[#?&]' + name + '=([^&]*)');\r\n\tconst value = locationHash.match(re);\r\n\tif (!value || value.length != 2) return '';\r\n\r\n\tvalue[1] = decodeURIComponent(value[1]);\r\n\tvalue[1] = value[1].replace(/\\+/g, ' ');\r\n\r\n\treturn value[1];\r\n};\r\n\r\n/**\r\n * Установить значение в хэш параметр страницы\r\n */\r\nexport const setHash = function (name: string, value: string | number | null, replaceState: boolean = true): void {\r\n\tlet hash = genHash(name, value);\r\n\tif (hash == '#') hash = '';\r\n\r\n\tif (replaceState) {\r\n\t\thistorySetState(true, hash);\r\n\t} else {\r\n\t\tlocation.hash = hash;\r\n\t}\r\n};\r\n\r\n/**\r\n * Удалить значение из хэш параметра страницы\r\n */\r\nexport const delHash = function (name: string, value: string, replaceState: boolean = true): void {\r\n\tsetHash(name, null, replaceState);\r\n};\r\n\r\n/**\r\n * Сгенерировать новое значение для хэш параметра страницы с указанным параметром\r\n */\r\nexport const genHash = function (name: string, value: string | number | null, locationHash: string = location.hash): string {\r\n\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\r\n\r\n\tlocationHash = locationHash.replace(re, '');\r\n\r\n\tif (value !== null) {\r\n\t\tvalue = (value + '').replace(' ', '%20');\r\n\t\tlocationHash = locationHash.replace(re, '&' + name + '=' + value);\r\n\r\n\t\tif (locationHash.indexOf('&' + name + '=') == -1) locationHash += '&' + name + '=' + value;\r\n\t}\r\n\r\n\tlocationHash = locationHash.replace(/&+/g, '&');\r\n\tlocationHash = locationHash.replace(/&$/, '');\r\n\r\n\tlocationHash = '#' + locationHash;\r\n\tlocationHash = locationHash.replace(/^#+/, '#');\r\n\r\n\t// hash страницы не должен быть пустым, чтобы не перекидывало к верху страницы\r\n\tlocationHash = locationHash.replace(/^#:-\\)/, '#');\r\n\tif ((locationHash == '' || locationHash == '#') && location.hash) locationHash = '#:-)';\r\n\r\n\treturn locationHash;\r\n};\r\n\r\n/**\r\n * Установить значения в хэш параметр страницы\r\n */\r\nexport const setHashs = function (data: Map<string, string> | object | any, replaceState: boolean): void {\r\n\tif (data instanceof Map) data = Object.fromEntries(data);\r\n\r\n\tif (replaceState === undefined) replaceState = true;\r\n\tlet hash = location.hash;\r\n\r\n\tfor (const name in data) {\r\n\t\tconst re = new RegExp('&?' + name + '=[^&]*', 'g');\r\n\t\thash = hash.replace(re, '');\r\n\r\n\t\tif (data[name] !== null) {\r\n\t\t\tdata[name] = (data[name] + '').replace(' ', '%20');\r\n\t\t\thash += '&' + name + '=' + data[name];\r\n\t\t}\r\n\t}\r\n\r\n\thash = hash.replace(/&+/g, '&');\r\n\thash = hash.replace(/^(#)?&|&$/g, '$1');\r\n\thash = '#' + hash;\r\n\thash = hash.replace(/^#+/, '#');\r\n\r\n\tif (replaceState) {\r\n\t\tif (hash == '#') hash = '.';\r\n\t\thistorySetState(true, hash);\r\n\t} else {\r\n\t\tlocation.hash = hash;\r\n\t}\r\n};\r\n\r\n/**\r\n * Установть позицию в истории вкладки браузера\r\n *\r\n * @see history.replaceState\r\n * @see history.pushState\r\n *\r\n * @todo Мешает SPA сайта, вместо него использовать historyPushState() из @/component/vue/app/spa\r\n */\r\nexport const historySetState = (replace: boolean = false, hash: string): void => {\r\n\tif (replace) {\r\n\t\thistory.replaceState(null, '', hash);\r\n\t} else {\r\n\t\thistory.pushState(null, '', hash);\r\n\t}\r\n};\r\n"],"names":["getHash","name","locationHash","re","value","setHash","replaceState","hash","genHash","historySetState","delHash","setHashs","data","replace"],"mappings":"AAQO,MAAMA,IAAU,SAAUC,GAAcC,IAAuB,SAAS,MAAc;AAC5F,QAAMC,IAAK,IAAI,OAAO,UAAUF,IAAO,UAAU,GAC3CG,IAAQF,EAAa,MAAMC,CAAE;AACnC,SAAI,CAACC,KAASA,EAAM,UAAU,IAAU,MAExCA,EAAM,CAAC,IAAI,mBAAmBA,EAAM,CAAC,CAAC,GACtCA,EAAM,CAAC,IAAIA,EAAM,CAAC,EAAE,QAAQ,OAAO,GAAG,GAE/BA,EAAM,CAAC;AACf,GAKaC,IAAU,SAAUJ,GAAcG,GAA+BE,IAAwB,IAAY;AAC7G,MAAAC,IAAOC,EAAQP,GAAMG,CAAK;AAC1B,EAAAG,KAAQ,QAAYA,IAAA,KAEpBD,IACHG,EAAgB,IAAMF,CAAI,IAE1B,SAAS,OAAOA;AAElB,GAKaG,IAAU,SAAUT,GAAcG,GAAeE,IAAwB,IAAY;AACzF,EAAAD,EAAAJ,GAAM,MAAMK,CAAY;AACjC,GAKaE,IAAU,SAAUP,GAAcG,GAA+BF,IAAuB,SAAS,MAAc;AAC3H,QAAMC,IAAK,IAAI,OAAO,OAAOF,IAAO,UAAU,GAAG;AAElC,SAAAC,IAAAA,EAAa,QAAQC,GAAI,EAAE,GAEtCC,MAAU,SACbA,KAASA,IAAQ,IAAI,QAAQ,KAAK,KAAK,GACvCF,IAAeA,EAAa,QAAQC,GAAI,MAAMF,IAAO,MAAMG,CAAK,GAE5DF,EAAa,QAAQ,MAAMD,IAAO,GAAG,KAAK,OAAIC,KAAgB,MAAMD,IAAO,MAAMG,KAGvEF,IAAAA,EAAa,QAAQ,OAAO,GAAG,GAC/BA,IAAAA,EAAa,QAAQ,MAAM,EAAE,GAE5CA,IAAe,MAAMA,GACNA,IAAAA,EAAa,QAAQ,OAAO,GAAG,GAG/BA,IAAAA,EAAa,QAAQ,UAAU,GAAG,IAC5CA,KAAgB,MAAMA,KAAgB,QAAQ,SAAS,SAAqBA,IAAA,SAE1EA;AACR,GAKaS,IAAW,SAAUC,GAA0CN,GAA6B;AACxG,EAAIM,aAAgB,QAAYA,IAAA,OAAO,YAAYA,CAAI,IAEnDN,MAAiB,WAA0BA,IAAA;AAC/C,MAAIC,IAAO,SAAS;AAEpB,aAAWN,KAAQW,GAAM;AACxB,UAAMT,IAAK,IAAI,OAAO,OAAOF,IAAO,UAAU,GAAG;AAC1C,IAAAM,IAAAA,EAAK,QAAQJ,GAAI,EAAE,GAEtBS,EAAKX,CAAI,MAAM,SACbW,EAAAX,CAAI,KAAKW,EAAKX,CAAI,IAAI,IAAI,QAAQ,KAAK,KAAK,GACjDM,KAAQ,MAAMN,IAAO,MAAMW,EAAKX,CAAI;AAAA,EAEtC;AAEO,EAAAM,IAAAA,EAAK,QAAQ,OAAO,GAAG,GACvBA,IAAAA,EAAK,QAAQ,cAAc,IAAI,GACtCA,IAAO,MAAMA,GACNA,IAAAA,EAAK,QAAQ,OAAO,GAAG,GAE1BD,KACCC,KAAQ,QAAYA,IAAA,MACxBE,EAAgB,IAAMF,CAAI,KAE1B,SAAS,OAAOA;AAElB,GAUaE,IAAkB,CAACI,IAAmB,IAAON,MAAuB;AAChF,EAAIM,IACK,QAAA,aAAa,MAAM,IAAIN,CAAI,IAE3B,QAAA,UAAU,MAAM,IAAIA,CAAI;AAElC;"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","./dom.amd"],function(f,o,c){"use strict";if(typeof i>"u")var i=window.Vue;const l=t=>{if(!t||!t.parentElement)return;if(window.dialogs){const s=t.closest(".ui-dialog");s!=null&&s.getBoundingClientRect()&&(s==null?void 0:s.getBoundingClientRect().bottom)>document.documentElement.clientHeight&&setTimeout(window.dialogs.onWindowResize)}const e=t.scrollHeight>t.offsetHeight;if(e?(t.parentElement.classList.add("has_scroll_container"),t.classList.add("has_scroll")):(t.parentElement.classList.remove("has_scroll_container"),t.classList.remove("has_scroll")),e){const s=c.offset(t).top-c.offset(t.parentElement).top;t.style.setProperty("--scroll-offset-top",s+"px");const n=t.offsetHeight;t.style.setProperty("--scroll-height",n+"px"),t.scrollTop>0?t.classList.add("has_scroll-started"):t.classList.remove("has_scroll-started"),t.scrollTop>=t.scrollHeight-t.offsetHeight?t.classList.add("has_scroll-finished"):t.classList.remove("has_scroll-finished")}},a=()=>r(),r=(t=document.documentElement)=>{const e=t.clientHeight,s=t.scrollHeight,n=t.scrollTop;if(s&&n&&e){const d=s-e;return Math.floor(n/d*100)}return 100};o.amountScrolled=a,o.genHasScroll=l,o.getScrollPercent=r,Object.defineProperty(o,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","./dom.amd"],function(u,s,i){"use strict";if(typeof d>"u")var d=window.Vue;const n=t=>{if(!t||!t.parentElement)return;if(window.dialogs){const e=t.closest(".ui-dialog");e!=null&&e.getBoundingClientRect()&&(e==null?void 0:e.getBoundingClientRect().bottom)>document.documentElement.clientHeight&&setTimeout(window.dialogs.onWindowResize)}const o=t.scrollHeight>t.offsetHeight;if(o?(t.parentElement.classList.add("has_scroll_container"),t.classList.add("has_scroll")):(t.parentElement.classList.remove("has_scroll_container"),t.classList.remove("has_scroll")),o){const e=i.offset(t).top-i.offset(t.parentElement).top;t.style.setProperty("--scroll-offset-top",e+"px");const r=t.offsetHeight;t.style.setProperty("--scroll-height",r+"px"),t.scrollTop>0?t.classList.add("has_scroll-started"):t.classList.remove("has_scroll-started"),t.scrollTop>=t.scrollHeight-t.offsetHeight?t.classList.add("has_scroll-finished"):t.classList.remove("has_scroll-finished")}};let c;window.ResizeObserver&&(c=new ResizeObserver(t=>n(t[0].target)));const l=t=>{if(!t)return;if(Array.isArray(t)){t.forEach(e=>l(e));return}const o=t;o.dataset.scrollShadowInited||(o.dataset.scrollShadowInited="true",o.onscroll=()=>n(o),c&&c.observe(o))},f=()=>a(),a=(t=document.documentElement)=>{const o=t.clientHeight,e=t.scrollHeight,r=t.scrollTop;if(e&&r&&o){const h=e-o;return Math.floor(r/h*100)}return 100};s.amountScrolled=f,s.connectScrollShadow=l,s.genHasScroll=n,s.getScrollPercent=a,Object.defineProperty(s,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=scroll.amd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"scroll.amd.js","sources":["../../src/core/utils/scroll.ts"],"sourcesContent":["/**\n * Информация о скролле, фичи для скролла\n * @packageDocumentation\n */\n\nimport { offset } from '@/core/utils/dom';\n\n/**\n * Добавление модификатора тени при скролле\n */\nexport const genHasScroll = (el: HTMLElement): void => {\n\tif (!el) return;\n\tif (!el.parentElement) return;\n\n\t// Диалоги не вынесены в UI\n\tif (window['dialogs']) {\n\t\tconst elDialog = el.closest('.ui-dialog');\n\t\tif (elDialog?.getBoundingClientRect() && elDialog?.getBoundingClientRect().bottom > document.documentElement.clientHeight) {\n\t\t\tsetTimeout(window['dialogs'].onWindowResize);\n\t\t}\n\t}\n\n\tconst hasScroll = (el.scrollHeight > el.offsetHeight);\n\tif (hasScroll) {\n\t\tel.parentElement.classList.add('has_scroll_container');\n\t\tel.classList.add('has_scroll');\n\t} else {\n\t\tel.parentElement.classList.remove('has_scroll_container');\n\t\tel.classList.remove('has_scroll');\n\t}\n\n\tif (hasScroll) {\n\t\tconst top: number = offset(el).top - offset(el.parentElement).top;\n\t\tel.style.setProperty('--scroll-offset-top', top + 'px');\n\n\t\tconst height = el.offsetHeight;\n\t\tel.style.setProperty('--scroll-height', height + 'px');\n\n\t\tif (el.scrollTop > 0) {\n\t\t\tel.classList.add('has_scroll-started');\n\t\t} else {\n\t\t\tel.classList.remove('has_scroll-started');\n\t\t}\n\n\t\tif (el.scrollTop >= el.scrollHeight - el.offsetHeight) {\n\t\t\tel.classList.add('has_scroll-finished');\n\t\t} else {\n\t\t\tel.classList.remove('has_scroll-finished');\n\t\t}\n\t}\n};\n\n/**\n * Посчитать глубину скролла (процент на сколько проскроллена страница)\n *\n * @deprecated\n */\nexport const amountScrolled = (): number => {\n\treturn getScrollPercent();\n};\n\n/**\n * Получить прогресс скролла в процентах\n */\nexport const getScrollPercent = (el: HTMLElement = document.documentElement): number => {\n\tconst clientHeight = el.clientHeight;\n\tconst scrollHeight = el.scrollHeight;\n\tconst scrollTop = el.scrollTop;\n\n\tif (scrollHeight && scrollTop && clientHeight) {\n\t\tconst trackLength = scrollHeight - clientHeight;\n\n\t\treturn Math.floor(scrollTop / trackLength * 100);\n\t}\n\n\treturn 100;\n};\n"],"names":["genHasScroll","el","elDialog","top","utils_dom","height","amountScrolled","getScrollPercent","clientHeight","scrollHeight","scrollTop","trackLength"],"mappings":"uGAUa,MAAAA,EAAAC,GAAA,CAEZ,GADA,CAAAA,GACA,CAAAA,EAAA,cAAA,OAGA,GAAA,OAAA,QAAA,iCAECC,GAAA,MAAAA,EAAA,0BAAAA,GAAA,YAAAA,EAAA,wBAAA,QAAA,SAAA,gBAAA,wRAeA,MAAAC,EAAAC,EAAA,OAAAH,CAAA,EAAA,IAAAG,EAAA,OAAAH,EAAA,aAAA,EAAA,IACAA,EAAA,MAAA,YAAA,sBAAAE,EAAA,IAAA,EAEA,MAAAE,EAAAJ,EAAA,aACAA,EAAA,MAAA,YAAA,kBAAAI,EAAA,IAAA,EAEAJ,EAAA,UAAA,iFAMAA,EAAA,WAAAA,EAAA,aAAAA,EAAA,gGAaKK,EAAA,QAOAC,EAAA,CAAAN,EAAA,SAAA,kBAAA,CACN,MAAAO,EAAAP,EAAA,aACAQ,EAAAR,EAAA,aACAS,EAAAT,EAAA,UAEA,GAAAQ,GAAAC,GAAAF,EAAA,CACC,MAAAG,EAAAF,EAAAD,uCAMF"}
1
+ {"version":3,"file":"scroll.amd.js","sources":["../../src/core/utils/scroll.ts"],"sourcesContent":["/**\r\n * Информация о скролле, фичи для скролла\r\n * @packageDocumentation\r\n */\r\n\r\nimport { offset } from '@/core/utils/dom';\r\n\r\n/**\r\n * Добавить классы модификаторов тени в зависимости от скролла элемента\r\n *\r\n * @todo Сделать приватной\r\n */\r\nexport const genHasScroll = (el: HTMLElement): void => {\r\n\tif (!el) return;\r\n\tif (!el.parentElement) return;\r\n\r\n\t// Диалоги не вынесены в UI\r\n\tif (window['dialogs']) {\r\n\t\tconst elDialog = el.closest('.ui-dialog');\r\n\t\tif (elDialog?.getBoundingClientRect() && elDialog?.getBoundingClientRect().bottom > document.documentElement.clientHeight) {\r\n\t\t\tsetTimeout(window['dialogs'].onWindowResize);\r\n\t\t}\r\n\t}\r\n\r\n\tconst hasScroll = (el.scrollHeight > el.offsetHeight);\r\n\tif (hasScroll) {\r\n\t\tel.parentElement.classList.add('has_scroll_container');\r\n\t\tel.classList.add('has_scroll');\r\n\t} else {\r\n\t\tel.parentElement.classList.remove('has_scroll_container');\r\n\t\tel.classList.remove('has_scroll');\r\n\t}\r\n\r\n\tif (hasScroll) {\r\n\t\tconst top: number = offset(el).top - offset(el.parentElement).top;\r\n\t\tel.style.setProperty('--scroll-offset-top', top + 'px');\r\n\r\n\t\tconst height = el.offsetHeight;\r\n\t\tel.style.setProperty('--scroll-height', height + 'px');\r\n\r\n\t\tif (el.scrollTop > 0) {\r\n\t\t\tel.classList.add('has_scroll-started');\r\n\t\t} else {\r\n\t\t\tel.classList.remove('has_scroll-started');\r\n\t\t}\r\n\r\n\t\tif (el.scrollTop >= el.scrollHeight - el.offsetHeight) {\r\n\t\t\tel.classList.add('has_scroll-finished');\r\n\t\t} else {\r\n\t\t\tel.classList.remove('has_scroll-finished');\r\n\t\t}\r\n\t}\r\n};\r\n\r\nlet scrollShadowResizeObserver: ResizeObserver;\r\nif (window.ResizeObserver) {\r\n\tscrollShadowResizeObserver = new ResizeObserver((entry) => genHasScroll(entry[0].target as HTMLElement));\r\n}\r\n\r\n/**\r\n * Добавить отображение тени при появления скролла у элемента\r\n *\r\n * Будут добавоены события для усатновки модификаторов тени в зависимости от скролла элемента\r\n *\r\n * Модификаторы:\r\n * - top-scrollShadow\r\n * - top-scrollShadow-started\r\n * - top-scrollShadow-finished\r\n */\r\nexport const connectScrollShadow = (els: HTMLElement | HTMLElement[]) => {\r\n\tif (!els) return;\r\n\r\n\tif (Array.isArray(els)) {\r\n\t\tels.forEach((el) => connectScrollShadow(el));\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tconst el = els;\r\n\r\n\tif (el.dataset.scrollShadowInited) return;\r\n\tel.dataset.scrollShadowInited = 'true';\r\n\r\n\tel.onscroll = () => genHasScroll(el);\r\n\r\n\tif (scrollShadowResizeObserver) scrollShadowResizeObserver.observe(el);\r\n};\r\n\r\n/**\r\n * Посчитать глубину скролла (процент на сколько проскроллена страница)\r\n *\r\n * @deprecated\r\n */\r\nexport const amountScrolled = (): number => {\r\n\treturn getScrollPercent();\r\n};\r\n\r\n/**\r\n * Получить прогресс скролла в процентах\r\n */\r\nexport const getScrollPercent = (el: HTMLElement = document.documentElement): number => {\r\n\tconst clientHeight = el.clientHeight;\r\n\tconst scrollHeight = el.scrollHeight;\r\n\tconst scrollTop = el.scrollTop;\r\n\r\n\tif (scrollHeight && scrollTop && clientHeight) {\r\n\t\tconst trackLength = scrollHeight - clientHeight;\r\n\r\n\t\treturn Math.floor(scrollTop / trackLength * 100);\r\n\t}\r\n\r\n\treturn 100;\r\n};\r\n"],"names":["genHasScroll","el","elDialog","top","utils_dom","height","scrollShadowResizeObserver","entry","connectScrollShadow","els","el2","amountScrolled","getScrollPercent","clientHeight","scrollHeight","scrollTop","trackLength"],"mappings":"uGAYa,MAAAA,EAAAC,GAAA,CAEZ,GADA,CAAAA,GACA,CAAAA,EAAA,cAAA,OAGA,GAAA,OAAA,QAAA,iCAECC,GAAA,MAAAA,EAAA,0BAAAA,GAAA,YAAAA,EAAA,wBAAA,QAAA,SAAA,gBAAA,wRAeA,MAAAC,EAAAC,EAAA,OAAAH,CAAA,EAAA,IAAAG,EAAA,OAAAH,EAAA,aAAA,EAAA,IACAA,EAAA,MAAA,YAAA,sBAAAE,EAAA,IAAA,EAEA,MAAAE,EAAAJ,EAAA,aACAA,EAAA,MAAA,YAAA,kBAAAI,EAAA,IAAA,EAEAJ,EAAA,UAAA,iFAMAA,EAAA,WAAAA,EAAA,aAAAA,EAAA,gGAQF,IAAAK,0BAECA,EAAA,IAAA,eAAAC,GAAAP,EAAAO,EAAA,CAAA,EAAA,MAAA,CAAA,GAaY,MAAAC,EAAAC,GAAA,CACZ,GAAA,CAAAA,EAAA,OAEA,GAAA,MAAA,QAAAA,CAAA,EAAA,CACCA,EAAA,QAAAC,GAAAF,EAAAE,CAAA,CAAA,EAEA,OAGD,MAAAT,EAAAQ,EAEAR,EAAA,QAAA,qBACAA,EAAA,QAAA,mBAAA,6CAYMU,EAAA,QAOAC,EAAA,CAAAX,EAAA,SAAA,kBAAA,CACN,MAAAY,EAAAZ,EAAA,aACAa,EAAAb,EAAA,aACAc,EAAAd,EAAA,UAEA,GAAAa,GAAAC,GAAAF,EAAA,CACC,MAAAG,EAAAF,EAAAD,uCAMF"}
package/utils/scroll.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { offset as c } from "./dom.js";
2
- const l = (t) => {
2
+ const n = (t) => {
3
3
  if (!t || !t.parentElement) return;
4
4
  if (window.dialogs) {
5
5
  const s = t.closest(".ui-dialog");
@@ -12,17 +12,29 @@ const l = (t) => {
12
12
  const e = t.offsetHeight;
13
13
  t.style.setProperty("--scroll-height", e + "px"), t.scrollTop > 0 ? t.classList.add("has_scroll-started") : t.classList.remove("has_scroll-started"), t.scrollTop >= t.scrollHeight - t.offsetHeight ? t.classList.add("has_scroll-finished") : t.classList.remove("has_scroll-finished");
14
14
  }
15
- }, a = () => n(), n = (t = document.documentElement) => {
15
+ };
16
+ let r;
17
+ window.ResizeObserver && (r = new ResizeObserver((t) => n(t[0].target)));
18
+ const l = (t) => {
19
+ if (!t) return;
20
+ if (Array.isArray(t)) {
21
+ t.forEach((s) => l(s));
22
+ return;
23
+ }
24
+ const o = t;
25
+ o.dataset.scrollShadowInited || (o.dataset.scrollShadowInited = "true", o.onscroll = () => n(o), r && r.observe(o));
26
+ }, h = () => a(), a = (t = document.documentElement) => {
16
27
  const o = t.clientHeight, s = t.scrollHeight, e = t.scrollTop;
17
28
  if (s && e && o) {
18
- const r = s - o;
19
- return Math.floor(e / r * 100);
29
+ const i = s - o;
30
+ return Math.floor(e / i * 100);
20
31
  }
21
32
  return 100;
22
33
  };
23
34
  export {
24
- a as amountScrolled,
25
- l as genHasScroll,
26
- n as getScrollPercent
35
+ h as amountScrolled,
36
+ l as connectScrollShadow,
37
+ n as genHasScroll,
38
+ a as getScrollPercent
27
39
  };
28
40
  //# sourceMappingURL=scroll.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"scroll.js","sources":["../../src/core/utils/scroll.ts"],"sourcesContent":["/**\n * Информация о скролле, фичи для скролла\n * @packageDocumentation\n */\n\nimport { offset } from '@/core/utils/dom';\n\n/**\n * Добавление модификатора тени при скролле\n */\nexport const genHasScroll = (el: HTMLElement): void => {\n\tif (!el) return;\n\tif (!el.parentElement) return;\n\n\t// Диалоги не вынесены в UI\n\tif (window['dialogs']) {\n\t\tconst elDialog = el.closest('.ui-dialog');\n\t\tif (elDialog?.getBoundingClientRect() && elDialog?.getBoundingClientRect().bottom > document.documentElement.clientHeight) {\n\t\t\tsetTimeout(window['dialogs'].onWindowResize);\n\t\t}\n\t}\n\n\tconst hasScroll = (el.scrollHeight > el.offsetHeight);\n\tif (hasScroll) {\n\t\tel.parentElement.classList.add('has_scroll_container');\n\t\tel.classList.add('has_scroll');\n\t} else {\n\t\tel.parentElement.classList.remove('has_scroll_container');\n\t\tel.classList.remove('has_scroll');\n\t}\n\n\tif (hasScroll) {\n\t\tconst top: number = offset(el).top - offset(el.parentElement).top;\n\t\tel.style.setProperty('--scroll-offset-top', top + 'px');\n\n\t\tconst height = el.offsetHeight;\n\t\tel.style.setProperty('--scroll-height', height + 'px');\n\n\t\tif (el.scrollTop > 0) {\n\t\t\tel.classList.add('has_scroll-started');\n\t\t} else {\n\t\t\tel.classList.remove('has_scroll-started');\n\t\t}\n\n\t\tif (el.scrollTop >= el.scrollHeight - el.offsetHeight) {\n\t\t\tel.classList.add('has_scroll-finished');\n\t\t} else {\n\t\t\tel.classList.remove('has_scroll-finished');\n\t\t}\n\t}\n};\n\n/**\n * Посчитать глубину скролла (процент на сколько проскроллена страница)\n *\n * @deprecated\n */\nexport const amountScrolled = (): number => {\n\treturn getScrollPercent();\n};\n\n/**\n * Получить прогресс скролла в процентах\n */\nexport const getScrollPercent = (el: HTMLElement = document.documentElement): number => {\n\tconst clientHeight = el.clientHeight;\n\tconst scrollHeight = el.scrollHeight;\n\tconst scrollTop = el.scrollTop;\n\n\tif (scrollHeight && scrollTop && clientHeight) {\n\t\tconst trackLength = scrollHeight - clientHeight;\n\n\t\treturn Math.floor(scrollTop / trackLength * 100);\n\t}\n\n\treturn 100;\n};\n"],"names":["genHasScroll","el","elDialog","hasScroll","top","offset","height","amountScrolled","getScrollPercent","clientHeight","scrollHeight","scrollTop","trackLength"],"mappings":";AAUa,MAAAA,IAAe,CAACC,MAA0B;AAElD,MADA,CAACA,KACD,CAACA,EAAG,cAAe;AAGnB,MAAA,OAAO,SAAY;AAChB,UAAAC,IAAWD,EAAG,QAAQ,YAAY;AACpC,IAAAC,KAAA,QAAAA,EAAU,4BAA2BA,KAAA,gBAAAA,EAAU,wBAAwB,UAAS,SAAS,gBAAgB,gBACjG,WAAA,OAAO,QAAW,cAAc;AAAA,EAE7C;AAEM,QAAAC,IAAaF,EAAG,eAAeA,EAAG;AASxC,MARIE,KACAF,EAAA,cAAc,UAAU,IAAI,sBAAsB,GAClDA,EAAA,UAAU,IAAI,YAAY,MAE1BA,EAAA,cAAc,UAAU,OAAO,sBAAsB,GACrDA,EAAA,UAAU,OAAO,YAAY,IAG7BE,GAAW;AACR,UAAAC,IAAcC,EAAOJ,CAAE,EAAE,MAAMI,EAAOJ,EAAG,aAAa,EAAE;AAC9D,IAAAA,EAAG,MAAM,YAAY,uBAAuBG,IAAM,IAAI;AAEtD,UAAME,IAASL,EAAG;AAClB,IAAAA,EAAG,MAAM,YAAY,mBAAmBK,IAAS,IAAI,GAEjDL,EAAG,YAAY,IACfA,EAAA,UAAU,IAAI,oBAAoB,IAElCA,EAAA,UAAU,OAAO,oBAAoB,GAGrCA,EAAG,aAAaA,EAAG,eAAeA,EAAG,eACrCA,EAAA,UAAU,IAAI,qBAAqB,IAEnCA,EAAA,UAAU,OAAO,qBAAqB;AAAA,EAE3C;AACD,GAOaM,IAAiB,MACtBC,EAAiB,GAMZA,IAAmB,CAACP,IAAkB,SAAS,oBAA4B;AACvF,QAAMQ,IAAeR,EAAG,cAClBS,IAAeT,EAAG,cAClBU,IAAYV,EAAG;AAEjB,MAAAS,KAAgBC,KAAaF,GAAc;AAC9C,UAAMG,IAAcF,IAAeD;AAEnC,WAAO,KAAK,MAAME,IAAYC,IAAc,GAAG;AAAA,EAChD;AAEO,SAAA;AACR;"}
1
+ {"version":3,"file":"scroll.js","sources":["../../src/core/utils/scroll.ts"],"sourcesContent":["/**\r\n * Информация о скролле, фичи для скролла\r\n * @packageDocumentation\r\n */\r\n\r\nimport { offset } from '@/core/utils/dom';\r\n\r\n/**\r\n * Добавить классы модификаторов тени в зависимости от скролла элемента\r\n *\r\n * @todo Сделать приватной\r\n */\r\nexport const genHasScroll = (el: HTMLElement): void => {\r\n\tif (!el) return;\r\n\tif (!el.parentElement) return;\r\n\r\n\t// Диалоги не вынесены в UI\r\n\tif (window['dialogs']) {\r\n\t\tconst elDialog = el.closest('.ui-dialog');\r\n\t\tif (elDialog?.getBoundingClientRect() && elDialog?.getBoundingClientRect().bottom > document.documentElement.clientHeight) {\r\n\t\t\tsetTimeout(window['dialogs'].onWindowResize);\r\n\t\t}\r\n\t}\r\n\r\n\tconst hasScroll = (el.scrollHeight > el.offsetHeight);\r\n\tif (hasScroll) {\r\n\t\tel.parentElement.classList.add('has_scroll_container');\r\n\t\tel.classList.add('has_scroll');\r\n\t} else {\r\n\t\tel.parentElement.classList.remove('has_scroll_container');\r\n\t\tel.classList.remove('has_scroll');\r\n\t}\r\n\r\n\tif (hasScroll) {\r\n\t\tconst top: number = offset(el).top - offset(el.parentElement).top;\r\n\t\tel.style.setProperty('--scroll-offset-top', top + 'px');\r\n\r\n\t\tconst height = el.offsetHeight;\r\n\t\tel.style.setProperty('--scroll-height', height + 'px');\r\n\r\n\t\tif (el.scrollTop > 0) {\r\n\t\t\tel.classList.add('has_scroll-started');\r\n\t\t} else {\r\n\t\t\tel.classList.remove('has_scroll-started');\r\n\t\t}\r\n\r\n\t\tif (el.scrollTop >= el.scrollHeight - el.offsetHeight) {\r\n\t\t\tel.classList.add('has_scroll-finished');\r\n\t\t} else {\r\n\t\t\tel.classList.remove('has_scroll-finished');\r\n\t\t}\r\n\t}\r\n};\r\n\r\nlet scrollShadowResizeObserver: ResizeObserver;\r\nif (window.ResizeObserver) {\r\n\tscrollShadowResizeObserver = new ResizeObserver((entry) => genHasScroll(entry[0].target as HTMLElement));\r\n}\r\n\r\n/**\r\n * Добавить отображение тени при появления скролла у элемента\r\n *\r\n * Будут добавоены события для усатновки модификаторов тени в зависимости от скролла элемента\r\n *\r\n * Модификаторы:\r\n * - top-scrollShadow\r\n * - top-scrollShadow-started\r\n * - top-scrollShadow-finished\r\n */\r\nexport const connectScrollShadow = (els: HTMLElement | HTMLElement[]) => {\r\n\tif (!els) return;\r\n\r\n\tif (Array.isArray(els)) {\r\n\t\tels.forEach((el) => connectScrollShadow(el));\r\n\r\n\t\treturn;\r\n\t}\r\n\r\n\tconst el = els;\r\n\r\n\tif (el.dataset.scrollShadowInited) return;\r\n\tel.dataset.scrollShadowInited = 'true';\r\n\r\n\tel.onscroll = () => genHasScroll(el);\r\n\r\n\tif (scrollShadowResizeObserver) scrollShadowResizeObserver.observe(el);\r\n};\r\n\r\n/**\r\n * Посчитать глубину скролла (процент на сколько проскроллена страница)\r\n *\r\n * @deprecated\r\n */\r\nexport const amountScrolled = (): number => {\r\n\treturn getScrollPercent();\r\n};\r\n\r\n/**\r\n * Получить прогресс скролла в процентах\r\n */\r\nexport const getScrollPercent = (el: HTMLElement = document.documentElement): number => {\r\n\tconst clientHeight = el.clientHeight;\r\n\tconst scrollHeight = el.scrollHeight;\r\n\tconst scrollTop = el.scrollTop;\r\n\r\n\tif (scrollHeight && scrollTop && clientHeight) {\r\n\t\tconst trackLength = scrollHeight - clientHeight;\r\n\r\n\t\treturn Math.floor(scrollTop / trackLength * 100);\r\n\t}\r\n\r\n\treturn 100;\r\n};\r\n"],"names":["genHasScroll","el","elDialog","hasScroll","top","offset","height","scrollShadowResizeObserver","entry","connectScrollShadow","els","amountScrolled","getScrollPercent","clientHeight","scrollHeight","scrollTop","trackLength"],"mappings":";AAYa,MAAAA,IAAe,CAACC,MAA0B;AAElD,MADA,CAACA,KACD,CAACA,EAAG,cAAe;AAGnB,MAAA,OAAO,SAAY;AAChB,UAAAC,IAAWD,EAAG,QAAQ,YAAY;AACpC,IAAAC,KAAA,QAAAA,EAAU,4BAA2BA,KAAA,gBAAAA,EAAU,wBAAwB,UAAS,SAAS,gBAAgB,gBACjG,WAAA,OAAO,QAAW,cAAc;AAAA,EAE7C;AAEM,QAAAC,IAAaF,EAAG,eAAeA,EAAG;AASxC,MARIE,KACAF,EAAA,cAAc,UAAU,IAAI,sBAAsB,GAClDA,EAAA,UAAU,IAAI,YAAY,MAE1BA,EAAA,cAAc,UAAU,OAAO,sBAAsB,GACrDA,EAAA,UAAU,OAAO,YAAY,IAG7BE,GAAW;AACR,UAAAC,IAAcC,EAAOJ,CAAE,EAAE,MAAMI,EAAOJ,EAAG,aAAa,EAAE;AAC9D,IAAAA,EAAG,MAAM,YAAY,uBAAuBG,IAAM,IAAI;AAEtD,UAAME,IAASL,EAAG;AAClB,IAAAA,EAAG,MAAM,YAAY,mBAAmBK,IAAS,IAAI,GAEjDL,EAAG,YAAY,IACfA,EAAA,UAAU,IAAI,oBAAoB,IAElCA,EAAA,UAAU,OAAO,oBAAoB,GAGrCA,EAAG,aAAaA,EAAG,eAAeA,EAAG,eACrCA,EAAA,UAAU,IAAI,qBAAqB,IAEnCA,EAAA,UAAU,OAAO,qBAAqB;AAAA,EAE3C;AACD;AAEA,IAAIM;AACA,OAAO,mBACmBA,IAAA,IAAI,eAAe,CAACC,MAAUR,EAAaQ,EAAM,CAAC,EAAE,MAAqB,CAAC;AAa3F,MAAAC,IAAsB,CAACC,MAAqC;AACxE,MAAI,CAACA,EAAK;AAEN,MAAA,MAAM,QAAQA,CAAG,GAAG;AACvB,IAAAA,EAAI,QAAQ,CAACT,MAAOQ,EAAoBR,CAAE,CAAC;AAE3C;AAAA,EACD;AAEA,QAAMA,IAAKS;AAEP,EAAAT,EAAG,QAAQ,uBACfA,EAAG,QAAQ,qBAAqB,QAE7BA,EAAA,WAAW,MAAMD,EAAaC,CAAE,GAE/BM,KAAuDA,EAAA,QAAQN,CAAE;AACtE,GAOaU,IAAiB,MACtBC,EAAiB,GAMZA,IAAmB,CAACX,IAAkB,SAAS,oBAA4B;AACvF,QAAMY,IAAeZ,EAAG,cAClBa,IAAeb,EAAG,cAClBc,IAAYd,EAAG;AAEjB,MAAAa,KAAgBC,KAAaF,GAAc;AAC9C,UAAMG,IAAcF,IAAeD;AAEnC,WAAO,KAAK,MAAME,IAAYC,IAAc,GAAG;AAAA,EAChD;AAEO,SAAA;AACR;"}
@@ -1 +1 @@
1
- {"version":3,"file":"searchers.amd.js","sources":["../../src/core/utils/searchers.ts"],"sourcesContent":["/**\n * Вспомогательный класс для работы с разными Поисковиками\n */\nexport const searchersNames = {\n\t0: 'Yandex',\n\t20: 'Yandex.com',\n\t21: 'Yandex.com.tr',\n\t1: 'Google',\n\t2: 'go.Mail',\n\t4: 'YouTube',\n\t5: 'Bing',\n\t6: 'Yahoo',\n\t7: 'Seznam',\n\t8: 'AppStore',\n\t9: 'GooglePlay',\n\t101: 'VK',\n\t102: 'Facebook',\n\t103: 'Twitter',\n};\n\n/**\n * Получить иконку ПС\n * @param searcherKey - цифра или строка с цифрой обозначающая ПС. Если null вернется иконка с глобусом\n */\nexport const getSearcherGIcon = (searcherKey: number | string | null): string => {\n\tlet icon = '';\n\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\n\n\tswitch (searcherKey) {\n\t\tcase 0:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 20:\n\t\tcase 21:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 1:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 3:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 4:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 5:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 6:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 7:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 8:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 9:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase null:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t}\n\n\treturn icon;\n};\n\n/**\n * Получить иконку устройства (ПК, планшет, смартфон)\n */\nexport const getDeviceGIcon = (device: number | string): string => {\n\tlet icon = '';\n\n\tif (typeof device === 'string') device = Number(device);\n\n\tswitch (device % 10) {\n\t\tcase 0:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 1:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t}\n\n\treturn icon;\n};\n\n/**\n * Получить иконку языка\n */\nexport const getLangLabel = (searcherKey: number | string, lang: string) => {\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\n\n\tswitch (searcherKey * 1) {\n\t\tcase 1:\n\t\tcase 4:\n\t\tcase 5:\n\t\tcase 6:\n\t\tcase 8:\n\t\tcase 9:\n\t\t\treturn lang;\n\t}\n\n\treturn '';\n};\n\n/**\n * Сгенерировать заголовок типа частоты\n */\nexport const genVolumeLabel = (label: string, searcherKey: 0 | 1, volumeType: 1 | 2 | 3 | 5 | 6): string => {\n\tswitch (searcherKey * 1) {\n\t\t// Яндекс\n\t\tcase 0:\n\t\t\tswitch (volumeType * 1) {\n\t\t\t\tcase 2:\n\t\t\t\t\tlabel = `\"${label}\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 3:\n\t\t\t\t\tlabel = `\"!${label}\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 5:\n\t\t\t\t\tlabel = `\"[${label}]\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 6:\n\t\t\t\t\tlabel = `\"[!${label}]\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\tbreak;\n\t\t// Google\n\t\tcase 1:\n\t\t\tlabel = `[${label}]`;\n\n\t\t\tbreak;\n\t}\n\n\treturn label;\n};\n\n/**\n * Проверить значение частоты, вернуть правильное значение частоты\n */\nexport const prepareVolumeType = (searcherKey: number, volumeType: number): number => {\n\t// по умолчанию выбрана сама точная частота\n\tif (volumeType === null) volumeType = 6;\n\n\tswitch (searcherKey) {\n\t\tcase 1:\n\t\t\tvolumeType = 3;\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\tvolumeType = 2;\n\n\t\t\tbreak;\n\t\tcase 5:\n\t\t\tif (volumeType > 1) volumeType = 1;\n\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tif (![1, 2, 3, 5, 6].includes(volumeType)) volumeType = 3;\n\t}\n\n\treturn volumeType;\n};\n"],"names":["searchersNames","getSearcherGIcon","searcherKey","icon","getDeviceGIcon","device","getLangLabel","lang","genVolumeLabel","label","volumeType","prepareVolumeType"],"mappings":"yFAGO,MAAAA,EAAA,mLAqBMC,EAAAC,GAAA,CACZ,IAAAC,EAAA,GAIA,OAFA,OAAAD,GAAA,WAAAA,EAAA,OAAAA,CAAA,GAEAA,EAAA,CAAqB,IAAA,SAInB,cACI,IAAA,UAIJ,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,KAAA,WAIA,gBASUE,EAAAC,GAAA,CACZ,IAAAF,EAAA,UAEA,OAAAE,GAAA,WAAAA,EAAA,OAAAA,CAAA,SAEqB,IAAA,SAInB,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,gBASUC,EAAA,CAAAJ,EAAAK,IAAA,QACZ,OAAAL,GAAA,WAAAA,EAAA,OAAAA,CAAA,2CAOM,IAAA,sBAWAM,EAAA,CAAAC,EAAAP,EAAAQ,IAAA,aACmB,IAAA,eAGC,IAAA,cAItB,MAAA,IAAA,eAIA,MAAA,IAAA,gBAIA,MAAA,IAAA,iBAIA,MAEF,MAAA,IAAA,cAKA,gBASUC,EAAA,CAAAT,EAAAQ,IAAA,CAIZ,uBAAAR,EAAA,CAAqB,IAAA,OAInB,MAAA,IAAA,OAIA,MAAA,IAAA,cAIA,qDAMH"}
1
+ {"version":3,"file":"searchers.amd.js","sources":["../../src/core/utils/searchers.ts"],"sourcesContent":["/**\r\n * Вспомогательный класс для работы с разными Поисковиками\r\n */\r\nexport const searchersNames = {\r\n\t0: 'Yandex',\r\n\t20: 'Yandex.com',\r\n\t21: 'Yandex.com.tr',\r\n\t1: 'Google',\r\n\t2: 'go.Mail',\r\n\t4: 'YouTube',\r\n\t5: 'Bing',\r\n\t6: 'Yahoo',\r\n\t7: 'Seznam',\r\n\t8: 'AppStore',\r\n\t9: 'GooglePlay',\r\n\t101: 'VK',\r\n\t102: 'Facebook',\r\n\t103: 'Twitter',\r\n};\r\n\r\n/**\r\n * Получить иконку ПС\r\n * @param searcherKey - цифра или строка с цифрой обозначающая ПС. Если null вернется иконка с глобусом\r\n */\r\nexport const getSearcherGIcon = (searcherKey: number | string | null): string => {\r\n\tlet icon = '';\r\n\r\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\r\n\r\n\tswitch (searcherKey) {\r\n\t\tcase 0:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 20:\r\n\t\tcase 21:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 1:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 2:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 3:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 4:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 5:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 6:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 7:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 8:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 9:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase null:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\treturn icon;\r\n};\r\n\r\n/**\r\n * Получить иконку устройства (ПК, планшет, смартфон)\r\n */\r\nexport const getDeviceGIcon = (device: number | string): string => {\r\n\tlet icon = '';\r\n\r\n\tif (typeof device === 'string') device = Number(device);\r\n\r\n\tswitch (device % 10) {\r\n\t\tcase 0:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 1:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 2:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\treturn icon;\r\n};\r\n\r\n/**\r\n * Получить иконку языка\r\n */\r\nexport const getLangLabel = (searcherKey: number | string, lang: string) => {\r\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\r\n\r\n\tswitch (searcherKey * 1) {\r\n\t\tcase 1:\r\n\t\tcase 4:\r\n\t\tcase 5:\r\n\t\tcase 6:\r\n\t\tcase 8:\r\n\t\tcase 9:\r\n\t\t\treturn lang;\r\n\t}\r\n\r\n\treturn '';\r\n};\r\n\r\n/**\r\n * Сгенерировать заголовок типа частоты\r\n */\r\nexport const genVolumeLabel = (label: string, searcherKey: 0 | 1, volumeType: 1 | 2 | 3 | 5 | 6): string => {\r\n\tswitch (searcherKey * 1) {\r\n\t\t// Яндекс\r\n\t\tcase 0:\r\n\t\t\tswitch (volumeType * 1) {\r\n\t\t\t\tcase 2:\r\n\t\t\t\t\tlabel = `\"${label}\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 3:\r\n\t\t\t\t\tlabel = `\"!${label}\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 5:\r\n\t\t\t\t\tlabel = `\"[${label}]\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 6:\r\n\t\t\t\t\tlabel = `\"[!${label}]\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tbreak;\r\n\t\t// Google\r\n\t\tcase 1:\r\n\t\t\tlabel = `[${label}]`;\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\treturn label;\r\n};\r\n\r\n/**\r\n * Проверить значение частоты, вернуть правильное значение частоты\r\n */\r\nexport const prepareVolumeType = (searcherKey: number, volumeType: number): number => {\r\n\t// по умолчанию выбрана сама точная частота\r\n\tif (volumeType === null) volumeType = 6;\r\n\r\n\tswitch (searcherKey) {\r\n\t\tcase 1:\r\n\t\t\tvolumeType = 3;\r\n\r\n\t\t\tbreak;\r\n\t\tcase 2:\r\n\t\t\tvolumeType = 2;\r\n\r\n\t\t\tbreak;\r\n\t\tcase 5:\r\n\t\t\tif (volumeType > 1) volumeType = 1;\r\n\r\n\t\t\tbreak;\r\n\t\tdefault:\r\n\t\t\tif (![1, 2, 3, 5, 6].includes(volumeType)) volumeType = 3;\r\n\t}\r\n\r\n\treturn volumeType;\r\n};\r\n"],"names":["searchersNames","getSearcherGIcon","searcherKey","icon","getDeviceGIcon","device","getLangLabel","lang","genVolumeLabel","label","volumeType","prepareVolumeType"],"mappings":"yFAGO,MAAAA,EAAA,mLAqBMC,EAAAC,GAAA,CACZ,IAAAC,EAAA,GAIA,OAFA,OAAAD,GAAA,WAAAA,EAAA,OAAAA,CAAA,GAEAA,EAAA,CAAqB,IAAA,SAInB,cACI,IAAA,UAIJ,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,MAAA,KAAA,WAIA,gBASUE,EAAAC,GAAA,CACZ,IAAAF,EAAA,UAEA,OAAAE,GAAA,WAAAA,EAAA,OAAAA,CAAA,SAEqB,IAAA,SAInB,MAAA,IAAA,SAIA,MAAA,IAAA,SAIA,gBASUC,EAAA,CAAAJ,EAAAK,IAAA,QACZ,OAAAL,GAAA,WAAAA,EAAA,OAAAA,CAAA,2CAOM,IAAA,sBAWAM,EAAA,CAAAC,EAAAP,EAAAQ,IAAA,aACmB,IAAA,eAGC,IAAA,cAItB,MAAA,IAAA,eAIA,MAAA,IAAA,gBAIA,MAAA,IAAA,iBAIA,MAEF,MAAA,IAAA,cAKA,gBASUC,EAAA,CAAAT,EAAAQ,IAAA,CAIZ,uBAAAR,EAAA,CAAqB,IAAA,OAInB,MAAA,IAAA,OAIA,MAAA,IAAA,cAIA,qDAMH"}
@@ -1 +1 @@
1
- {"version":3,"file":"searchers.js","sources":["../../src/core/utils/searchers.ts"],"sourcesContent":["/**\n * Вспомогательный класс для работы с разными Поисковиками\n */\nexport const searchersNames = {\n\t0: 'Yandex',\n\t20: 'Yandex.com',\n\t21: 'Yandex.com.tr',\n\t1: 'Google',\n\t2: 'go.Mail',\n\t4: 'YouTube',\n\t5: 'Bing',\n\t6: 'Yahoo',\n\t7: 'Seznam',\n\t8: 'AppStore',\n\t9: 'GooglePlay',\n\t101: 'VK',\n\t102: 'Facebook',\n\t103: 'Twitter',\n};\n\n/**\n * Получить иконку ПС\n * @param searcherKey - цифра или строка с цифрой обозначающая ПС. Если null вернется иконка с глобусом\n */\nexport const getSearcherGIcon = (searcherKey: number | string | null): string => {\n\tlet icon = '';\n\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\n\n\tswitch (searcherKey) {\n\t\tcase 0:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 20:\n\t\tcase 21:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 1:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 3:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 4:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 5:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 6:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 7:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 8:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 9:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase null:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t}\n\n\treturn icon;\n};\n\n/**\n * Получить иконку устройства (ПК, планшет, смартфон)\n */\nexport const getDeviceGIcon = (device: number | string): string => {\n\tlet icon = '';\n\n\tif (typeof device === 'string') device = Number(device);\n\n\tswitch (device % 10) {\n\t\tcase 0:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 1:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\ticon = '';\n\n\t\t\tbreak;\n\t}\n\n\treturn icon;\n};\n\n/**\n * Получить иконку языка\n */\nexport const getLangLabel = (searcherKey: number | string, lang: string) => {\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\n\n\tswitch (searcherKey * 1) {\n\t\tcase 1:\n\t\tcase 4:\n\t\tcase 5:\n\t\tcase 6:\n\t\tcase 8:\n\t\tcase 9:\n\t\t\treturn lang;\n\t}\n\n\treturn '';\n};\n\n/**\n * Сгенерировать заголовок типа частоты\n */\nexport const genVolumeLabel = (label: string, searcherKey: 0 | 1, volumeType: 1 | 2 | 3 | 5 | 6): string => {\n\tswitch (searcherKey * 1) {\n\t\t// Яндекс\n\t\tcase 0:\n\t\t\tswitch (volumeType * 1) {\n\t\t\t\tcase 2:\n\t\t\t\t\tlabel = `\"${label}\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 3:\n\t\t\t\t\tlabel = `\"!${label}\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 5:\n\t\t\t\t\tlabel = `\"[${label}]\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t\tcase 6:\n\t\t\t\t\tlabel = `\"[!${label}]\"`;\n\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\tbreak;\n\t\t// Google\n\t\tcase 1:\n\t\t\tlabel = `[${label}]`;\n\n\t\t\tbreak;\n\t}\n\n\treturn label;\n};\n\n/**\n * Проверить значение частоты, вернуть правильное значение частоты\n */\nexport const prepareVolumeType = (searcherKey: number, volumeType: number): number => {\n\t// по умолчанию выбрана сама точная частота\n\tif (volumeType === null) volumeType = 6;\n\n\tswitch (searcherKey) {\n\t\tcase 1:\n\t\t\tvolumeType = 3;\n\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\tvolumeType = 2;\n\n\t\t\tbreak;\n\t\tcase 5:\n\t\t\tif (volumeType > 1) volumeType = 1;\n\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tif (![1, 2, 3, 5, 6].includes(volumeType)) volumeType = 3;\n\t}\n\n\treturn volumeType;\n};\n"],"names":["searchersNames","getSearcherGIcon","searcherKey","icon","getDeviceGIcon","device","getLangLabel","lang","genVolumeLabel","label","volumeType","prepareVolumeType"],"mappings":"AAGO,MAAMA,IAAiB;AAAA,EAC7B,GAAG;AAAA,EACH,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AACN,GAMaC,IAAmB,CAACC,MAAgD;AAChF,MAAIC,IAAO;AAIX,UAFI,OAAOD,KAAgB,aAAUA,IAAc,OAAOA,CAAW,IAE7DA,GAAa;AAAA,IACpB,KAAK;AACG,MAAAC,IAAA;AAEP;AAAA,IACD,KAAK;AAAA,IACL,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,EACF;AAEO,SAAAA;AACR,GAKaC,IAAiB,CAACC,MAAoC;AAClE,MAAIF,IAAO;AAIX,UAFI,OAAOE,KAAW,aAAUA,IAAS,OAAOA,CAAM,IAE9CA,IAAS,IAAI;AAAA,IACpB,KAAK;AACG,MAAAF,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,EACF;AAEO,SAAAA;AACR,GAKaG,IAAe,CAACJ,GAA8BK,MAAiB;AAG3E,UAFI,OAAOL,KAAgB,aAAUA,IAAc,OAAOA,CAAW,IAE7DA,IAAc,GAAG;AAAA,IACxB,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACG,aAAAK;AAAA,EACT;AAEO,SAAA;AACR,GAKaC,IAAiB,CAACC,GAAeP,GAAoBQ,MAA0C;AAC3G,UAAQR,IAAc,GAAG;AAAA,IAExB,KAAK;AACJ,cAAQQ,IAAa,GAAG;AAAA,QACvB,KAAK;AACJ,UAAAD,IAAQ,IAAIA,CAAK;AAEjB;AAAA,QACD,KAAK;AACJ,UAAAA,IAAQ,KAAKA,CAAK;AAElB;AAAA,QACD,KAAK;AACJ,UAAAA,IAAQ,KAAKA,CAAK;AAElB;AAAA,QACD,KAAK;AACJ,UAAAA,IAAQ,MAAMA,CAAK;AAEnB;AAAA,MACF;AACA;AAAA,IAED,KAAK;AACJ,MAAAA,IAAQ,IAAIA,CAAK;AAEjB;AAAA,EACF;AAEO,SAAAA;AACR,GAKaE,IAAoB,CAACT,GAAqBQ,MAA+B;AAIrF,UAFIA,MAAe,SAAmBA,IAAA,IAE9BR,GAAa;AAAA,IACpB,KAAK;AACS,MAAAQ,IAAA;AAEb;AAAA,IACD,KAAK;AACS,MAAAA,IAAA;AAEb;AAAA,IACD,KAAK;AACA,MAAAA,IAAa,MAAgBA,IAAA;AAEjC;AAAA,IACD;AACK,MAAC,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,EAAE,SAASA,CAAU,MAAgBA,IAAA;AAAA,EAC1D;AAEO,SAAAA;AACR;"}
1
+ {"version":3,"file":"searchers.js","sources":["../../src/core/utils/searchers.ts"],"sourcesContent":["/**\r\n * Вспомогательный класс для работы с разными Поисковиками\r\n */\r\nexport const searchersNames = {\r\n\t0: 'Yandex',\r\n\t20: 'Yandex.com',\r\n\t21: 'Yandex.com.tr',\r\n\t1: 'Google',\r\n\t2: 'go.Mail',\r\n\t4: 'YouTube',\r\n\t5: 'Bing',\r\n\t6: 'Yahoo',\r\n\t7: 'Seznam',\r\n\t8: 'AppStore',\r\n\t9: 'GooglePlay',\r\n\t101: 'VK',\r\n\t102: 'Facebook',\r\n\t103: 'Twitter',\r\n};\r\n\r\n/**\r\n * Получить иконку ПС\r\n * @param searcherKey - цифра или строка с цифрой обозначающая ПС. Если null вернется иконка с глобусом\r\n */\r\nexport const getSearcherGIcon = (searcherKey: number | string | null): string => {\r\n\tlet icon = '';\r\n\r\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\r\n\r\n\tswitch (searcherKey) {\r\n\t\tcase 0:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 20:\r\n\t\tcase 21:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 1:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 2:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 3:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 4:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 5:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 6:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 7:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 8:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 9:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase null:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\treturn icon;\r\n};\r\n\r\n/**\r\n * Получить иконку устройства (ПК, планшет, смартфон)\r\n */\r\nexport const getDeviceGIcon = (device: number | string): string => {\r\n\tlet icon = '';\r\n\r\n\tif (typeof device === 'string') device = Number(device);\r\n\r\n\tswitch (device % 10) {\r\n\t\tcase 0:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 1:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t\tcase 2:\r\n\t\t\ticon = '';\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\treturn icon;\r\n};\r\n\r\n/**\r\n * Получить иконку языка\r\n */\r\nexport const getLangLabel = (searcherKey: number | string, lang: string) => {\r\n\tif (typeof searcherKey === 'string') searcherKey = Number(searcherKey);\r\n\r\n\tswitch (searcherKey * 1) {\r\n\t\tcase 1:\r\n\t\tcase 4:\r\n\t\tcase 5:\r\n\t\tcase 6:\r\n\t\tcase 8:\r\n\t\tcase 9:\r\n\t\t\treturn lang;\r\n\t}\r\n\r\n\treturn '';\r\n};\r\n\r\n/**\r\n * Сгенерировать заголовок типа частоты\r\n */\r\nexport const genVolumeLabel = (label: string, searcherKey: 0 | 1, volumeType: 1 | 2 | 3 | 5 | 6): string => {\r\n\tswitch (searcherKey * 1) {\r\n\t\t// Яндекс\r\n\t\tcase 0:\r\n\t\t\tswitch (volumeType * 1) {\r\n\t\t\t\tcase 2:\r\n\t\t\t\t\tlabel = `\"${label}\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 3:\r\n\t\t\t\t\tlabel = `\"!${label}\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 5:\r\n\t\t\t\t\tlabel = `\"[${label}]\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 6:\r\n\t\t\t\t\tlabel = `\"[!${label}]\"`;\r\n\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tbreak;\r\n\t\t// Google\r\n\t\tcase 1:\r\n\t\t\tlabel = `[${label}]`;\r\n\r\n\t\t\tbreak;\r\n\t}\r\n\r\n\treturn label;\r\n};\r\n\r\n/**\r\n * Проверить значение частоты, вернуть правильное значение частоты\r\n */\r\nexport const prepareVolumeType = (searcherKey: number, volumeType: number): number => {\r\n\t// по умолчанию выбрана сама точная частота\r\n\tif (volumeType === null) volumeType = 6;\r\n\r\n\tswitch (searcherKey) {\r\n\t\tcase 1:\r\n\t\t\tvolumeType = 3;\r\n\r\n\t\t\tbreak;\r\n\t\tcase 2:\r\n\t\t\tvolumeType = 2;\r\n\r\n\t\t\tbreak;\r\n\t\tcase 5:\r\n\t\t\tif (volumeType > 1) volumeType = 1;\r\n\r\n\t\t\tbreak;\r\n\t\tdefault:\r\n\t\t\tif (![1, 2, 3, 5, 6].includes(volumeType)) volumeType = 3;\r\n\t}\r\n\r\n\treturn volumeType;\r\n};\r\n"],"names":["searchersNames","getSearcherGIcon","searcherKey","icon","getDeviceGIcon","device","getLangLabel","lang","genVolumeLabel","label","volumeType","prepareVolumeType"],"mappings":"AAGO,MAAMA,IAAiB;AAAA,EAC7B,GAAG;AAAA,EACH,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AACN,GAMaC,IAAmB,CAACC,MAAgD;AAChF,MAAIC,IAAO;AAIX,UAFI,OAAOD,KAAgB,aAAUA,IAAc,OAAOA,CAAW,IAE7DA,GAAa;AAAA,IACpB,KAAK;AACG,MAAAC,IAAA;AAEP;AAAA,IACD,KAAK;AAAA,IACL,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,EACF;AAEO,SAAAA;AACR,GAKaC,IAAiB,CAACC,MAAoC;AAClE,MAAIF,IAAO;AAIX,UAFI,OAAOE,KAAW,aAAUA,IAAS,OAAOA,CAAM,IAE9CA,IAAS,IAAI;AAAA,IACpB,KAAK;AACG,MAAAF,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,IACD,KAAK;AACG,MAAAA,IAAA;AAEP;AAAA,EACF;AAEO,SAAAA;AACR,GAKaG,IAAe,CAACJ,GAA8BK,MAAiB;AAG3E,UAFI,OAAOL,KAAgB,aAAUA,IAAc,OAAOA,CAAW,IAE7DA,IAAc,GAAG;AAAA,IACxB,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AAAA,IACL,KAAK;AACG,aAAAK;AAAA,EACT;AAEO,SAAA;AACR,GAKaC,IAAiB,CAACC,GAAeP,GAAoBQ,MAA0C;AAC3G,UAAQR,IAAc,GAAG;AAAA,IAExB,KAAK;AACJ,cAAQQ,IAAa,GAAG;AAAA,QACvB,KAAK;AACJ,UAAAD,IAAQ,IAAIA,CAAK;AAEjB;AAAA,QACD,KAAK;AACJ,UAAAA,IAAQ,KAAKA,CAAK;AAElB;AAAA,QACD,KAAK;AACJ,UAAAA,IAAQ,KAAKA,CAAK;AAElB;AAAA,QACD,KAAK;AACJ,UAAAA,IAAQ,MAAMA,CAAK;AAEnB;AAAA,MACF;AACA;AAAA,IAED,KAAK;AACJ,MAAAA,IAAQ,IAAIA,CAAK;AAEjB;AAAA,EACF;AAEO,SAAAA;AACR,GAKaE,IAAoB,CAACT,GAAqBQ,MAA+B;AAIrF,UAFIA,MAAe,SAAmBA,IAAA,IAE9BR,GAAa;AAAA,IACpB,KAAK;AACS,MAAAQ,IAAA;AAEb;AAAA,IACD,KAAK;AACS,MAAAA,IAAA;AAEb;AAAA,IACD,KAAK;AACA,MAAAA,IAAa,MAAgBA,IAAA;AAEjC;AAAA,IACD;AACK,MAAC,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,EAAE,SAASA,CAAU,MAAgBA,IAAA;AAAA,EAC1D;AAEO,SAAAA;AACR;"}
@@ -1,2 +1,2 @@
1
- define(["require","exports","./check.amd","../.chunks/forms-VHBOI0dh.amd"],function(j,c,i,u){"use strict";if(typeof p>"u")var p=window.Vue;const h=e=>{e+="";let l=0;if(!e.length)return l;for(let a=0;a<e.length;a++){const n=e.charCodeAt(a);l=(l<<5)-l+n,l=l&l}return l<0&&(l*=-1),l},s=e=>/^\w+:\/\/([\w-]+\.)+[\w-]+(:\d+)?(\/|$)/.test(e),f=e=>{e+="",e=e.replace("-","–");let l=e.split("."),a=l[0],n=l.length>1?"."+l[1]:"";if(a.replace(/[+–]/,"").length<=4)return e;const o=/(\d+)(\d{3})/;for(;o.test(a);)a=a.replace(o,"$1 $2");return a+n},d=e=>e===void 0?"":e.replace(/\r\n|\r|\n/g,"<br>"),g=(e,l=2,a=1e3,n="")=>{const o=Math.pow(10,l);let r=String(e);return Math.abs(e)>Math.pow(a,3)?r=Math.round(e/Math.pow(a,3)*o)/o+" <small>G"+n+"</small>":Math.abs(e)>Math.pow(a,2)?r=Math.round(e/Math.pow(a,2)*o)/o+" <small>M"+n+"</small>":Math.abs(e)>a&&(r=Math.round(e/a*o)/o+" <small>K"+n+"</small>"),r=r.replace(/^(-?\d+)(\d{3})/,"$1 $2"),r},m=(e,l,a=1)=>{if(e==null)return"";if(e+="",l==null||e.length<=l)return e;if(a===0)e=e.substr(e.length-l,l),e="..."+e;else if(a===1){const n=e.substr(0,l/2),o=e.substr(e.length-l/2,Math.ceil(l/2));e=n+"..."+o}else a===2&&(e=e.substr(0,l),e=e+"...");return e},w=(e,l,a,n)=>{if(u.useI18nLang().value==="en")return e===1?a:l;const o=e%100,r=e%10;return o>=5&&o<=20||r===0?l:r===1?a:r>=2&&r<=4?n:r>=5&&r<=9?l:n},b=e=>{if(u.useI18nLang().value!="ru"||e=="")return e;const l=e.split(" ");return $.map(l,function(a,n){a=a+"а",a=a.replace("оа","о"),a=a.replace("аяа","ой"),a=a.replace("шийа","шого"),a=a.replace("ыйа","ого"),a=a.replace("йа","я"),a=a.replace("ьа","я"),a=a.replace("яа","и"),a=a.replace("оваа","овой"),a=a.replace("аа","ы"),a=a.replace("кия","кого"),a=a.replace("каи","кой"),l[n]=a}),e=l.join(" "),e},C=e=>{const l={а:"a",б:"b",в:"v",г:"g",д:"d",е:"e",ё:"e",ж:"j",з:"z",и:"i",й:"i",к:"k",л:"l",м:"m",н:"n",о:"o",п:"p",р:"r",с:"s",т:"t",у:"u",ф:"f",х:"h",ц:"c",ч:"ch",ш:"sh",щ:"shch",ъ:"",ы:"y",ь:"",э:"e",ю:"u",я:"ya"},a=e.split(" ");return $.map(a,function(n,o){const r=[];for(let t=0;t<n.length;++t)r.push(l[n[t]]||l[n[t].toLowerCase()]==null&&n[t]||l[n[t].toLowerCase()].replace(/^(.)/,function(A){return A.toUpperCase()}));a[o]=r.join("")}),e=a.join(" "),e},M=e=>(typeof e=="string"&&(e=e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#039;")),e),k=(e,l)=>{let a=null;switch(l.operator){case"CONTAINS":case"REGEXP":try{let n=l.values[0];l.operator!="REGEXP"&&(n=n.replace(/([()\[\]])/g,"\\$1")),a=new RegExp("("+n+")","gi")}catch{return e}break}return e=e.replace(a,'<b class="found">$1</b>'),e},y=e=>{var l;return(l=e.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g))==null?void 0:l.map(a=>a.toLowerCase()).join("_")},v=e=>`/controller/file/?src=${"/cloud/common/flags/"+e.toUpperCase()+".svg"}`,L=e=>{const l=i.getDomainRegexp(),a="(([\\/?\\w&=%+#;:-]*(\\.\\w+)?))*",n=new RegExp(`(^|[\\s>(),])([a-z0-9а-яё_.]+@${l}${a})`,"gui");e=e.replace(n,'$1<a href="mailto:$2" target="_blank" rel="noopener">↑[$2]↓</a>');const o=new RegExp(`(^|[\\s>(),])(https?://)?(${l}${a})`,"gui");return e=e.replace(o,'$1<a href="√$2$3" target="_blank" rel="nofollow noopener">$2$3</a>'),e=e.replaceAll("√http","http"),e=e.replaceAll("√","http://"),e=e.replaceAll(/(↑\[|]↓)/g,""),e},R=e=>e.charAt(0).toUpperCase()+e.slice(1),E=(e=20)=>{const l="AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890";let a="";for(let n=0;n<e;n++)a+=l[Math.floor(Math.random()*l.length)];return a};c.addCommasWhite=f,c.addLinkTags=L,c.camelToSnakeCase=y,c.ellipsis=m,c.genFlagLinkByCountryCode=v,c.genIntHash=h,c.getRandomHash=E,c.highlightHtml=k,c.htmlspecialchars=M,c.isUrl=s,c.nl2br=d,c.numberEnding=w,c.numberWithWord=g,c.rusToLatin=C,c.toCapitalize=R,c.toRoditPadej=b,Object.defineProperty(c,Symbol.toStringTag,{value:"Module"})});
1
+ define(["require","exports","./check.amd","../.chunks/forms-JhDIERVr.amd"],function(j,c,i,u){"use strict";if(typeof p>"u")var p=window.Vue;const h=e=>{e+="";let l=0;if(!e.length)return l;for(let a=0;a<e.length;a++){const n=e.charCodeAt(a);l=(l<<5)-l+n,l=l&l}return l<0&&(l*=-1),l},s=e=>/^\w+:\/\/([\w-]+\.)+[\w-]+(:\d+)?(\/|$)/.test(e),f=e=>{e+="",e=e.replace("-","–");let l=e.split("."),a=l[0],n=l.length>1?"."+l[1]:"";if(a.replace(/[+–]/,"").length<=4)return e;const o=/(\d+)(\d{3})/;for(;o.test(a);)a=a.replace(o,"$1 $2");return a+n},d=e=>e===void 0?"":e.replace(/\r\n|\r|\n/g,"<br>"),g=(e,l=2,a=1e3,n="")=>{const o=Math.pow(10,l);let r=String(e);return Math.abs(e)>Math.pow(a,3)?r=Math.round(e/Math.pow(a,3)*o)/o+" <small>G"+n+"</small>":Math.abs(e)>Math.pow(a,2)?r=Math.round(e/Math.pow(a,2)*o)/o+" <small>M"+n+"</small>":Math.abs(e)>a&&(r=Math.round(e/a*o)/o+" <small>K"+n+"</small>"),r=r.replace(/^(-?\d+)(\d{3})/,"$1 $2"),r},m=(e,l,a=1)=>{if(e==null)return"";if(e+="",l==null||e.length<=l)return e;if(a===0)e=e.substr(e.length-l,l),e="..."+e;else if(a===1){const n=e.substr(0,l/2),o=e.substr(e.length-l/2,Math.ceil(l/2));e=n+"..."+o}else a===2&&(e=e.substr(0,l),e=e+"...");return e},w=(e,l,a,n)=>{if(u.useI18nLang().value==="en")return e===1?a:l;const o=e%100,r=e%10;return o>=5&&o<=20||r===0?l:r===1?a:r>=2&&r<=4?n:r>=5&&r<=9?l:n},b=e=>{if(u.useI18nLang().value!="ru"||e=="")return e;const l=e.split(" ");return $.map(l,function(a,n){a=a+"а",a=a.replace("оа","о"),a=a.replace("аяа","ой"),a=a.replace("шийа","шого"),a=a.replace("ыйа","ого"),a=a.replace("йа","я"),a=a.replace("ьа","я"),a=a.replace("яа","и"),a=a.replace("оваа","овой"),a=a.replace("аа","ы"),a=a.replace("кия","кого"),a=a.replace("каи","кой"),l[n]=a}),e=l.join(" "),e},C=e=>{const l={а:"a",б:"b",в:"v",г:"g",д:"d",е:"e",ё:"e",ж:"j",з:"z",и:"i",й:"i",к:"k",л:"l",м:"m",н:"n",о:"o",п:"p",р:"r",с:"s",т:"t",у:"u",ф:"f",х:"h",ц:"c",ч:"ch",ш:"sh",щ:"shch",ъ:"",ы:"y",ь:"",э:"e",ю:"u",я:"ya"},a=e.split(" ");return $.map(a,function(n,o){const r=[];for(let t=0;t<n.length;++t)r.push(l[n[t]]||l[n[t].toLowerCase()]==null&&n[t]||l[n[t].toLowerCase()].replace(/^(.)/,function(A){return A.toUpperCase()}));a[o]=r.join("")}),e=a.join(" "),e},M=e=>(typeof e=="string"&&(e=e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#039;")),e),k=(e,l)=>{let a=null;switch(l.operator){case"CONTAINS":case"REGEXP":try{let n=l.values[0];l.operator!="REGEXP"&&(n=n.replace(/([()\[\]])/g,"\\$1")),a=new RegExp("("+n+")","gi")}catch{return e}break}return e=e.replace(a,'<b class="found">$1</b>'),e},y=e=>{var l;return(l=e.match(/[A-Z]{2,}(?=[A-Z][a-z]+[0-9]*|\b)|[A-Z]?[a-z]+[0-9]*|[A-Z]|[0-9]+/g))==null?void 0:l.map(a=>a.toLowerCase()).join("_")},v=e=>`/controller/file/?src=${"/cloud/common/flags/"+e.toUpperCase()+".svg"}`,L=e=>{const l=i.getDomainRegexp(),a="(([\\/?\\w&=%+#;:-]*(\\.\\w+)?))*",n=new RegExp(`(^|[\\s>(),])([a-z0-9а-яё_.]+@${l}${a})`,"gui");e=e.replace(n,'$1<a href="mailto:$2" target="_blank" rel="noopener">↑[$2]↓</a>');const o=new RegExp(`(^|[\\s>(),])(https?://)?(${l}${a})`,"gui");return e=e.replace(o,'$1<a href="√$2$3" target="_blank" rel="nofollow noopener">$2$3</a>'),e=e.replaceAll("√http","http"),e=e.replaceAll("√","http://"),e=e.replaceAll(/(↑\[|]↓)/g,""),e},R=e=>e.charAt(0).toUpperCase()+e.slice(1),E=(e=20)=>{const l="AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz1234567890";let a="";for(let n=0;n<e;n++)a+=l[Math.floor(Math.random()*l.length)];return a};c.addCommasWhite=f,c.addLinkTags=L,c.camelToSnakeCase=y,c.ellipsis=m,c.genFlagLinkByCountryCode=v,c.genIntHash=h,c.getRandomHash=E,c.highlightHtml=k,c.htmlspecialchars=M,c.isUrl=s,c.nl2br=d,c.numberEnding=w,c.numberWithWord=g,c.rusToLatin=C,c.toCapitalize=R,c.toRoditPadej=b,Object.defineProperty(c,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=string.amd.js.map
@@ -1 +1 @@
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 = (nStr: string): string => {\n\tnStr += '';\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 изображения флага, по коду страны (RU, GB)\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","nStr","x1","x","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","numberStr","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","forms","num100","num10","toRoditPadej","str2","str_array","index","rusToLatin","newStr","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExp","regExpString","camelToSnakeCase","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","utils_check","afterDomainRegexp","regexpMailto","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":"2IAWa,MAAAA,EAAAC,GAAA,OAGZ,IAAAC,EAAA,wBAGA,QAAAC,EAAA,EAAAA,EAAAF,EAAA,OAAAE,IAAA,sCAGCD,EAAAA,EAAAA,yBAWWE,EAAAC,GACZ,0CAAA,KAAAA,CAAA,EAOYC,EAAAC,GAAA,+CAMZC,EAAAC,EAAA,CAAA,EACAC,EAAAD,EAAA,OAAA,EAAA,IAAAA,EAAA,CAAA,EAAA,GAEA,GAAAD,EAAA,QAAA,OAAA,EAAA,EAAA,QAAA,EAAA,OAAAD,EAEA,MAAAI,EAAA,eACA,KAAAA,EAAA,KAAAH,CAAA,0BAGA,OAAAA,EAAAE,GAMYE,EAAAC,iDAaAC,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,uKAkBpFG,EAAA,CAAAnB,EAAAoB,EAAAC,EAAA,IAAA,qBAIN,SAAAD,GAAA,MAAApB,EAAA,QAAAoB,EAAA,OAAApB,EAEA,GAAAqB,IAAA,EACCrB,EAAAA,EAAA,OAAAA,EAAA,OAAAoB,EAAAA,CAAA,EACApB,EAAA,MAAAA,UAAiBqB,IAAA,EAAA,CAEjB,MAAAC,EAAAtB,EAAA,OAAA,EAAAoB,EAAA,CAAA,0CAEApB,EAAAsB,EAAA,MAAAC,CAA2B,MAAAF,IAAA,oBAG3BrB,EAAAA,EAAA,iBAaKwB,EAAA,CAAAC,EAAAC,EAAAC,EAAAC,IAAA,CAEN,GAAAC,EAAA,YAAA,EAAA,QAAA,KACC,OAAAJ,IAAA,MAOD,MAAAK,EAAAL,EAAA,IACAM,EAAAN,EAAA,uBAGQM,IAAA,IAEAA,IAAA,iCAeIC,EAAApB,GAAA,CACZ,GAAAiB,EAAA,YAAA,EAAA,OAAA,MAAAjB,GAAA,GAAA,OAAAA,oDAKCqB,EAAAA,EAAA,4QAaAC,EAAAC,CAAA,EAAAF,CAAmB,CAAA,mBAWRG,EAAAxB,GAAA,mNAQc,8CAMzB,MAAAyB,EAAA,CAAA,EACA,QAAAnC,EAAA,EAAAA,EAAA+B,EAAA,OAAA,EAAA/B,sGAGG,OAAAoC,EAAA,YAAA,CAAyB,CAAA,CACzB,iBAI8B,CAAA,mBAWtBC,EAAA3B,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,MAcW4B,EAAA,CAAAC,EAAAC,IAAA,CACZ,IAAAC,EAAA,uCAGM,IAAA,SAEJ,GAAA,mBAECD,EAAA,UAAA,WAAAE,EAAAA,EAAA,QAAA,cAAA,MAAA,GAEAD,EAAA,IAAA,OAAA,IAAAC,EAAA,IAAA,IAAA,iBAKD,yDAWUC,EAAAjC,GAAA,iJAOAkC,EAAAC,GAEZ,sEAAA,GAQYC,EAAAP,GAAA,CACZ,MAAAQ,EAAAC,EAAA,gBAAA,EACAC,EAAA,oCAEAC,EAAA,IAAA,OAAA,iCAAAH,CAAA,GAAAE,CAAA,IAAA,KAAA,EACAV,EAAAA,EAAA,QAAAW,EAAA,iEAAA,EAEA,MAAAC,EAAA,IAAA,OAAA,6BAAAJ,CAAA,GAAAE,CAAA,IAAA,KAAA,EACA,OAAAV,EAAAA,EAAA,QAAAY,EAAA,oEAAA,iGAYYC,EAAA1C,GACZA,EAAA,OAAA,CAAA,EAAA,YAAA,EAAAA,EAAA,MAAA,CAAA,EAMY2C,EAAA,CAAAC,EAAA,KAAA,CACZ,MAAA,EAAA,iEAEA,IAAAC,EAAA,GACA,QAAAvD,EAAA,EAAAA,EAAAsD,EAAAtD,IACCuD,GAAA,EAAA,KAAA,MAAA,KAAA,OAAA,EAAA,EAAA,MAAA,CAAA,UAIF"}
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 = (nStr: string): string => {\r\n\tnStr += '';\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","nStr","x1","x","x2","rgx","nl2br","str","numberWithWord","number","precision","dimension","suffix","numberStr","ellipsis","max_length","pos","string1","string2","numberEnding","num","ending0","ending1","ending2","forms","num100","num10","toRoditPadej","str2","str_array","index","rusToLatin","newStr","match","htmlspecialchars","highlightHtml","text","fieldFilter","regExp","regExpString","camelToSnakeCase","genFlagLinkByCountryCode","countryCode","addLinkTags","domainRegexp","utils_check","afterDomainRegexp","regexpMailto","regexpLink","toCapitalize","getRandomHash","length","result"],"mappings":"2IAWa,MAAAA,EAAAC,GAAA,OAGZ,IAAAC,EAAA,wBAGA,QAAAC,EAAA,EAAAA,EAAAF,EAAA,OAAAE,IAAA,sCAGCD,EAAAA,EAAAA,yBAWWE,EAAAC,GACZ,0CAAA,KAAAA,CAAA,EAOYC,EAAAC,GAAA,+CAMZC,EAAAC,EAAA,CAAA,EACAC,EAAAD,EAAA,OAAA,EAAA,IAAAA,EAAA,CAAA,EAAA,GAEA,GAAAD,EAAA,QAAA,OAAA,EAAA,EAAA,QAAA,EAAA,OAAAD,EAEA,MAAAI,EAAA,eACA,KAAAA,EAAA,KAAAH,CAAA,0BAGA,OAAAA,EAAAE,GAMYE,EAAAC,iDAaAC,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,uKAkBpFG,EAAA,CAAAnB,EAAAoB,EAAAC,EAAA,IAAA,qBAIN,SAAAD,GAAA,MAAApB,EAAA,QAAAoB,EAAA,OAAApB,EAEA,GAAAqB,IAAA,EACCrB,EAAAA,EAAA,OAAAA,EAAA,OAAAoB,EAAAA,CAAA,EACApB,EAAA,MAAAA,UAAiBqB,IAAA,EAAA,CAEjB,MAAAC,EAAAtB,EAAA,OAAA,EAAAoB,EAAA,CAAA,0CAEApB,EAAAsB,EAAA,MAAAC,CAA2B,MAAAF,IAAA,oBAG3BrB,EAAAA,EAAA,iBAaKwB,EAAA,CAAAC,EAAAC,EAAAC,EAAAC,IAAA,CAEN,GAAAC,EAAA,YAAA,EAAA,QAAA,KACC,OAAAJ,IAAA,MAOD,MAAAK,EAAAL,EAAA,IACAM,EAAAN,EAAA,uBAGQM,IAAA,IAEAA,IAAA,iCAeIC,EAAApB,GAAA,CACZ,GAAAiB,EAAA,YAAA,EAAA,OAAA,MAAAjB,GAAA,GAAA,OAAAA,oDAKCqB,EAAAA,EAAA,4QAaAC,EAAAC,CAAA,EAAAF,CAAmB,CAAA,mBAWRG,EAAAxB,GAAA,mNAQc,8CAMzB,MAAAyB,EAAA,CAAA,EACA,QAAAnC,EAAA,EAAAA,EAAA+B,EAAA,OAAA,EAAA/B,sGAGG,OAAAoC,EAAA,YAAA,CAAyB,CAAA,CACzB,iBAI8B,CAAA,mBAWtBC,EAAA3B,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,MAcW4B,EAAA,CAAAC,EAAAC,IAAA,CACZ,IAAAC,EAAA,uCAGM,IAAA,SAEJ,GAAA,mBAECD,EAAA,UAAA,WAAAE,EAAAA,EAAA,QAAA,cAAA,MAAA,GAEAD,EAAA,IAAA,OAAA,IAAAC,EAAA,IAAA,IAAA,iBAKD,yDAWUC,EAAAjC,GAAA,iJAOAkC,EAAAC,GAEZ,sEAAA,GAQYC,EAAAP,GAAA,CACZ,MAAAQ,EAAAC,EAAA,gBAAA,EACAC,EAAA,oCAEAC,EAAA,IAAA,OAAA,iCAAAH,CAAA,GAAAE,CAAA,IAAA,KAAA,EACAV,EAAAA,EAAA,QAAAW,EAAA,iEAAA,EAEA,MAAAC,EAAA,IAAA,OAAA,6BAAAJ,CAAA,GAAAE,CAAA,IAAA,KAAA,EACA,OAAAV,EAAAA,EAAA,QAAAY,EAAA,oEAAA,iGAYYC,EAAA1C,GACZA,EAAA,OAAA,CAAA,EAAA,YAAA,EAAAA,EAAA,MAAA,CAAA,EAMY2C,EAAA,CAAAC,EAAA,KAAA,CACZ,MAAA,EAAA,iEAEA,IAAAC,EAAA,GACA,QAAAvD,EAAA,EAAAA,EAAAsD,EAAAtD,IACCuD,GAAA,EAAA,KAAA,MAAA,KAAA,OAAA,EAAA,EAAA,MAAA,CAAA,UAIF"}
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-6Z3p_rjQ.es.js";
2
+ import { u as n } from "../.chunks/forms-Dm3JmuO3.es.js";
3
3
  const i = (e) => {
4
4
  e += "";
5
5
  let l = 0;