@homecode/ui 4.18.16 → 4.18.18

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 (331) hide show
  1. package/dist/esm/index.js +83 -2
  2. package/dist/esm/node_modules/style-inject/dist/style-inject.es.js +28 -2
  3. package/dist/esm/src/components/AssistiveText/AssistiveText.js +10 -2
  4. package/dist/esm/src/components/AssistiveText/AssistiveText.styl.js +7 -2
  5. package/dist/esm/src/components/Button/Button.helpers.js +12 -2
  6. package/dist/esm/src/components/Button/Button.js +38 -2
  7. package/dist/esm/src/components/Button/Button.styl.js +7 -2
  8. package/dist/esm/src/components/ButtonGroup/ButtonGroup.js +10 -2
  9. package/dist/esm/src/components/ButtonGroup/ButtonGroup.styl.js +7 -2
  10. package/dist/esm/src/components/Calendar/Calendar.helpers.js +65 -2
  11. package/dist/esm/src/components/Calendar/Calendar.js +66 -2
  12. package/dist/esm/src/components/Calendar/Calendar.styl.js +7 -2
  13. package/dist/esm/src/components/Checkbox/Checkbox.js +48 -2
  14. package/dist/esm/src/components/Checkbox/Checkbox.styl.js +7 -2
  15. package/dist/esm/src/components/Container/Container.js +12 -2
  16. package/dist/esm/src/components/Container/Container.styl.js +7 -2
  17. package/dist/esm/src/components/DatePicker/DatePicker.helpers.js +31 -2
  18. package/dist/esm/src/components/DatePicker/DatePicker.js +47 -2
  19. package/dist/esm/src/components/DatePicker/DatePicker.styl.js +7 -2
  20. package/dist/esm/src/components/DatePickerInput/DatePickerInput.js +20 -2
  21. package/dist/esm/src/components/DatePickerInput/DatePickerInput.styl.js +7 -2
  22. package/dist/esm/src/components/DateTime/DateTime.js +17 -2
  23. package/dist/esm/src/components/Draggable/Draggable.js +136 -2
  24. package/dist/esm/src/components/Draggable/Draggable.styl.js +7 -2
  25. package/dist/esm/src/components/Expand/Expand.js +24 -2
  26. package/dist/esm/src/components/Expand/Expand.styl.js +7 -2
  27. package/dist/esm/src/components/Form/Form.helpers.js +42 -2
  28. package/dist/esm/src/components/Form/Form.js +286 -2
  29. package/dist/esm/src/components/Form/Form.styl.js +7 -2
  30. package/dist/esm/src/components/Form/Form.types.js +0 -1
  31. package/dist/esm/src/components/Form/SubmitButtons/SubmitButtons.js +8 -2
  32. package/dist/esm/src/components/Form/SubmitButtons/SubmitButtons.styl.js +7 -2
  33. package/dist/esm/src/components/Form/Validator.js +24 -6
  34. package/dist/esm/src/components/Gallery/Dots/Dots.js +9 -2
  35. package/dist/esm/src/components/Gallery/Dots/Dots.styl.js +7 -2
  36. package/dist/esm/src/components/Gallery/Gallery.js +180 -2
  37. package/dist/esm/src/components/Gallery/Gallery.styl.js +7 -2
  38. package/dist/esm/src/components/Heading/Heading.js +37 -2
  39. package/dist/esm/src/components/Heading/Heading.styl.js +7 -2
  40. package/dist/esm/src/components/Icon/Icon.js +27 -2
  41. package/dist/esm/src/components/Icon/Icon.styl.js +7 -2
  42. package/dist/esm/src/components/Icon/icons/avatar.svg.js +15 -2
  43. package/dist/esm/src/components/Icon/icons/brokenImage.svg.js +15 -2
  44. package/dist/esm/src/components/Icon/icons/check.svg.js +19 -2
  45. package/dist/esm/src/components/Icon/icons/chevronDown.svg.js +20 -2
  46. package/dist/esm/src/components/Icon/icons/chevronLeft.svg.js +20 -2
  47. package/dist/esm/src/components/Icon/icons/chevronRight.svg.js +20 -2
  48. package/dist/esm/src/components/Icon/icons/chevronUp.svg.js +20 -2
  49. package/dist/esm/src/components/Icon/icons/close.svg.js +15 -2
  50. package/dist/esm/src/components/Icon/icons/colors.svg.js +60 -2
  51. package/dist/esm/src/components/Icon/icons/copy.svg.js +15 -2
  52. package/dist/esm/src/components/Icon/icons/delete.svg.js +15 -2
  53. package/dist/esm/src/components/Icon/icons/draft.svg.js +15 -2
  54. package/dist/esm/src/components/Icon/icons/edit.svg.js +15 -2
  55. package/dist/esm/src/components/Icon/icons/email.svg.js +15 -2
  56. package/dist/esm/src/components/Icon/icons/externalLink.svg.js +15 -2
  57. package/dist/esm/src/components/Icon/icons/eye.svg.js +15 -2
  58. package/dist/esm/src/components/Icon/icons/fullscreen.svg.js +15 -2
  59. package/dist/esm/src/components/Icon/icons/fullscreenExit.svg.js +15 -2
  60. package/dist/esm/src/components/Icon/icons/function.svg.js +15 -2
  61. package/dist/esm/src/components/Icon/icons/gear.svg.js +21 -2
  62. package/dist/esm/src/components/Icon/icons/group.svg.js +15 -2
  63. package/dist/esm/src/components/Icon/icons/history.svg.js +17 -2
  64. package/dist/esm/src/components/Icon/icons/home.svg.js +19 -2
  65. package/dist/esm/src/components/Icon/icons/index.js +46 -2
  66. package/dist/esm/src/components/Icon/icons/instagram.svg.js +15 -2
  67. package/dist/esm/src/components/Icon/icons/link.svg.js +15 -2
  68. package/dist/esm/src/components/Icon/icons/loader.svg.js +45 -2
  69. package/dist/esm/src/components/Icon/icons/menu.svg.js +18 -2
  70. package/dist/esm/src/components/Icon/icons/mic.svg.js +15 -2
  71. package/dist/esm/src/components/Icon/icons/minus.svg.js +15 -2
  72. package/dist/esm/src/components/Icon/icons/moreHorizontal.svg.js +15 -2
  73. package/dist/esm/src/components/Icon/icons/moreVertical.svg.js +15 -2
  74. package/dist/esm/src/components/Icon/icons/output.svg.js +15 -2
  75. package/dist/esm/src/components/Icon/icons/plus.svg.js +15 -2
  76. package/dist/esm/src/components/Icon/icons/redo.svg.js +15 -2
  77. package/dist/esm/src/components/Icon/icons/requiredStar.svg.js +15 -2
  78. package/dist/esm/src/components/Icon/icons/save.svg.js +17 -2
  79. package/dist/esm/src/components/Icon/icons/send.svg.js +16 -2
  80. package/dist/esm/src/components/Icon/icons/settings.svg.js +52 -2
  81. package/dist/esm/src/components/Icon/icons/shoppingBag.svg.js +17 -2
  82. package/dist/esm/src/components/Icon/icons/table.svg.js +15 -2
  83. package/dist/esm/src/components/Icon/icons/telegram.svg.js +19 -2
  84. package/dist/esm/src/components/Icon/icons/undo.svg.js +15 -2
  85. package/dist/esm/src/components/Input/Input.js +345 -2
  86. package/dist/esm/src/components/Input/Input.styl.js +7 -2
  87. package/dist/esm/src/components/InputFile/InputFile.js +295 -2
  88. package/dist/esm/src/components/InputFile/InputFile.styl.js +7 -2
  89. package/dist/esm/src/components/InputFile/InputFile.types.js +0 -1
  90. package/dist/esm/src/components/InputFile/Item/Item.js +18 -2
  91. package/dist/esm/src/components/InputFile/Item/Item.styl.js +7 -2
  92. package/dist/esm/src/components/Label/Label.constants.json.js +8 -2
  93. package/dist/esm/src/components/Label/Label.helpers.js +35 -2
  94. package/dist/esm/src/components/Label/Label.js +58 -2
  95. package/dist/esm/src/components/Label/Label.styl.js +7 -2
  96. package/dist/esm/src/components/Lazy/Lazy.js +65 -2
  97. package/dist/esm/src/components/LightBox/LightBox.js +28 -2
  98. package/dist/esm/src/components/LightBox/LightBox.styl.js +7 -2
  99. package/dist/esm/src/components/Notifications/Notifications.constants.json.js +6 -2
  100. package/dist/esm/src/components/Notifications/Notifications.js +67 -2
  101. package/dist/esm/src/components/Notifications/Notifications.styl.js +7 -2
  102. package/dist/esm/src/components/Notifications/store.js +62 -2
  103. package/dist/esm/src/components/Paranja/Paranja.js +14 -2
  104. package/dist/esm/src/components/Paranja/Paranja.styl.js +7 -2
  105. package/dist/esm/src/components/Popup/Popup.helpers.js +31 -2
  106. package/dist/esm/src/components/Popup/Popup.js +397 -2
  107. package/dist/esm/src/components/Popup/Popup.styl.js +7 -2
  108. package/dist/esm/src/components/PopupMenu/PopupMenu.js +15 -2
  109. package/dist/esm/src/components/PopupMenu/PopupMenu.styl.js +7 -2
  110. package/dist/esm/src/components/Portal/Portal.js +19 -2
  111. package/dist/esm/src/components/RequiredStar/RequiredStar.js +12 -2
  112. package/dist/esm/src/components/RequiredStar/RequiredStar.styl.js +7 -2
  113. package/dist/esm/src/components/Router/Link/Link.js +61 -2
  114. package/dist/esm/src/components/Router/Link/Link.styl.js +7 -2
  115. package/dist/esm/src/components/Router/Redirect.js +12 -2
  116. package/dist/esm/src/components/Router/Route.js +4 -2
  117. package/dist/esm/src/components/Router/Router.helpers.js +33 -2
  118. package/dist/esm/src/components/Router/Router.js +68 -2
  119. package/dist/esm/src/components/Router/context.js +5 -2
  120. package/dist/esm/src/components/Router/store.js +55 -2
  121. package/dist/esm/src/components/Scroll/Scroll.js +274 -2
  122. package/dist/esm/src/components/Scroll/Scroll.styl.js +7 -2
  123. package/dist/esm/src/components/Select/Select.helpers.js +37 -2
  124. package/dist/esm/src/components/Select/Select.js +585 -2
  125. package/dist/esm/src/components/Select/Select.styl.js +7 -2
  126. package/dist/esm/src/components/Spinner/Spinner.js +11 -2
  127. package/dist/esm/src/components/Spinner/Spinner.styl.js +7 -2
  128. package/dist/esm/src/components/Spinner/spinner.svg.js +24 -2
  129. package/dist/esm/src/components/Table/Table.js +24 -2
  130. package/dist/esm/src/components/Table/Table.styl.js +7 -2
  131. package/dist/esm/src/components/Tabs/Tabs.js +43 -2
  132. package/dist/esm/src/components/Tabs/Tabs.styl.js +7 -2
  133. package/dist/esm/src/components/Text/Text.js +44 -2
  134. package/dist/esm/src/components/Text/Text.styl.js +7 -2
  135. package/dist/esm/src/components/Theme/Theme.defaults.js +50 -2
  136. package/dist/esm/src/components/Theme/Theme.helpers.js +67 -2
  137. package/dist/esm/src/components/Theme/Theme.js +13 -2
  138. package/dist/esm/src/components/VH/VH.js +33 -2
  139. package/dist/esm/src/components/Virtualized/List/List.js +124 -2
  140. package/dist/esm/src/components/Virtualized/List/List.styl.js +7 -2
  141. package/dist/esm/src/components/Virtualized/List/ListScroll.js +21 -2
  142. package/dist/esm/src/components/Virtualized/List/ListScroll.styl.js +7 -2
  143. package/dist/esm/src/components/Virtualized/Virtualized.helpers.js +14 -2
  144. package/dist/esm/src/components/Virtualized/Virtualized.js +200 -2
  145. package/dist/esm/src/components/Virtualized/Virtualized.styl.js +7 -2
  146. package/dist/esm/src/components/Virtualized/Virtualized.types.js +0 -1
  147. package/dist/esm/src/services/i18n.js +68 -2
  148. package/dist/esm/src/tools/array.js +60 -2
  149. package/dist/esm/src/tools/config.js +9 -2
  150. package/dist/esm/src/tools/date.js +11 -2
  151. package/dist/esm/src/tools/debounce.js +11 -2
  152. package/dist/esm/src/tools/dom.js +46 -2
  153. package/dist/esm/src/tools/env.js +3 -2
  154. package/dist/esm/src/tools/file.js +11 -2
  155. package/dist/esm/src/tools/localStorage.js +31 -2
  156. package/dist/esm/src/tools/number.js +27 -2
  157. package/dist/esm/src/tools/object.js +5 -2
  158. package/dist/esm/src/tools/queryParams.js +20 -2
  159. package/dist/esm/src/tools/rangeMap.js +3 -2
  160. package/dist/esm/src/tools/resizeObserver.js +68 -2
  161. package/dist/esm/src/tools/scroll.js +41 -2
  162. package/dist/esm/src/tools/string.js +7 -2
  163. package/dist/esm/src/tools/throttle.js +30 -2
  164. package/dist/esm/src/tools/uid.js +7 -2
  165. package/dist/esm/types/src/components/Icon/Icon.d.ts +3 -9
  166. package/dist/esm/types/src/components/Icon/Icon.example.d.ts +1 -0
  167. package/package.json +1 -1
  168. package/dist/esm/index.js.map +0 -1
  169. package/dist/esm/node_modules/style-inject/dist/style-inject.es.js.map +0 -1
  170. package/dist/esm/src/components/AssistiveText/AssistiveText.js.map +0 -1
  171. package/dist/esm/src/components/AssistiveText/AssistiveText.styl.js.map +0 -1
  172. package/dist/esm/src/components/Button/Button.helpers.js.map +0 -1
  173. package/dist/esm/src/components/Button/Button.js.map +0 -1
  174. package/dist/esm/src/components/Button/Button.styl.js.map +0 -1
  175. package/dist/esm/src/components/ButtonGroup/ButtonGroup.js.map +0 -1
  176. package/dist/esm/src/components/ButtonGroup/ButtonGroup.styl.js.map +0 -1
  177. package/dist/esm/src/components/Calendar/Calendar.helpers.js.map +0 -1
  178. package/dist/esm/src/components/Calendar/Calendar.js.map +0 -1
  179. package/dist/esm/src/components/Calendar/Calendar.styl.js.map +0 -1
  180. package/dist/esm/src/components/Checkbox/Checkbox.js.map +0 -1
  181. package/dist/esm/src/components/Checkbox/Checkbox.styl.js.map +0 -1
  182. package/dist/esm/src/components/Container/Container.js.map +0 -1
  183. package/dist/esm/src/components/Container/Container.styl.js.map +0 -1
  184. package/dist/esm/src/components/DatePicker/DatePicker.helpers.js.map +0 -1
  185. package/dist/esm/src/components/DatePicker/DatePicker.js.map +0 -1
  186. package/dist/esm/src/components/DatePicker/DatePicker.styl.js.map +0 -1
  187. package/dist/esm/src/components/DatePickerInput/DatePickerInput.js.map +0 -1
  188. package/dist/esm/src/components/DatePickerInput/DatePickerInput.styl.js.map +0 -1
  189. package/dist/esm/src/components/DateTime/DateTime.js.map +0 -1
  190. package/dist/esm/src/components/Draggable/Draggable.js.map +0 -1
  191. package/dist/esm/src/components/Draggable/Draggable.styl.js.map +0 -1
  192. package/dist/esm/src/components/Expand/Expand.js.map +0 -1
  193. package/dist/esm/src/components/Expand/Expand.styl.js.map +0 -1
  194. package/dist/esm/src/components/Form/Form.helpers.js.map +0 -1
  195. package/dist/esm/src/components/Form/Form.js.map +0 -1
  196. package/dist/esm/src/components/Form/Form.styl.js.map +0 -1
  197. package/dist/esm/src/components/Form/Form.types.js.map +0 -1
  198. package/dist/esm/src/components/Form/SubmitButtons/SubmitButtons.js.map +0 -1
  199. package/dist/esm/src/components/Form/SubmitButtons/SubmitButtons.styl.js.map +0 -1
  200. package/dist/esm/src/components/Form/Validator.js.map +0 -1
  201. package/dist/esm/src/components/Gallery/Dots/Dots.js.map +0 -1
  202. package/dist/esm/src/components/Gallery/Dots/Dots.styl.js.map +0 -1
  203. package/dist/esm/src/components/Gallery/Gallery.js.map +0 -1
  204. package/dist/esm/src/components/Gallery/Gallery.styl.js.map +0 -1
  205. package/dist/esm/src/components/Heading/Heading.js.map +0 -1
  206. package/dist/esm/src/components/Heading/Heading.styl.js.map +0 -1
  207. package/dist/esm/src/components/Icon/Icon.js.map +0 -1
  208. package/dist/esm/src/components/Icon/Icon.styl.js.map +0 -1
  209. package/dist/esm/src/components/Icon/icons/avatar.svg.js.map +0 -1
  210. package/dist/esm/src/components/Icon/icons/brokenImage.svg.js.map +0 -1
  211. package/dist/esm/src/components/Icon/icons/check.svg.js.map +0 -1
  212. package/dist/esm/src/components/Icon/icons/chevronDown.svg.js.map +0 -1
  213. package/dist/esm/src/components/Icon/icons/chevronLeft.svg.js.map +0 -1
  214. package/dist/esm/src/components/Icon/icons/chevronRight.svg.js.map +0 -1
  215. package/dist/esm/src/components/Icon/icons/chevronUp.svg.js.map +0 -1
  216. package/dist/esm/src/components/Icon/icons/close.svg.js.map +0 -1
  217. package/dist/esm/src/components/Icon/icons/colors.svg.js.map +0 -1
  218. package/dist/esm/src/components/Icon/icons/copy.svg.js.map +0 -1
  219. package/dist/esm/src/components/Icon/icons/delete.svg.js.map +0 -1
  220. package/dist/esm/src/components/Icon/icons/draft.svg.js.map +0 -1
  221. package/dist/esm/src/components/Icon/icons/edit.svg.js.map +0 -1
  222. package/dist/esm/src/components/Icon/icons/email.svg.js.map +0 -1
  223. package/dist/esm/src/components/Icon/icons/externalLink.svg.js.map +0 -1
  224. package/dist/esm/src/components/Icon/icons/eye.svg.js.map +0 -1
  225. package/dist/esm/src/components/Icon/icons/fullscreen.svg.js.map +0 -1
  226. package/dist/esm/src/components/Icon/icons/fullscreenExit.svg.js.map +0 -1
  227. package/dist/esm/src/components/Icon/icons/function.svg.js.map +0 -1
  228. package/dist/esm/src/components/Icon/icons/gear.svg.js.map +0 -1
  229. package/dist/esm/src/components/Icon/icons/group.svg.js.map +0 -1
  230. package/dist/esm/src/components/Icon/icons/history.svg.js.map +0 -1
  231. package/dist/esm/src/components/Icon/icons/home.svg.js.map +0 -1
  232. package/dist/esm/src/components/Icon/icons/index.js.map +0 -1
  233. package/dist/esm/src/components/Icon/icons/instagram.svg.js.map +0 -1
  234. package/dist/esm/src/components/Icon/icons/link.svg.js.map +0 -1
  235. package/dist/esm/src/components/Icon/icons/loader.svg.js.map +0 -1
  236. package/dist/esm/src/components/Icon/icons/menu.svg.js.map +0 -1
  237. package/dist/esm/src/components/Icon/icons/mic.svg.js.map +0 -1
  238. package/dist/esm/src/components/Icon/icons/minus.svg.js.map +0 -1
  239. package/dist/esm/src/components/Icon/icons/moreHorizontal.svg.js.map +0 -1
  240. package/dist/esm/src/components/Icon/icons/moreVertical.svg.js.map +0 -1
  241. package/dist/esm/src/components/Icon/icons/output.svg.js.map +0 -1
  242. package/dist/esm/src/components/Icon/icons/plus.svg.js.map +0 -1
  243. package/dist/esm/src/components/Icon/icons/redo.svg.js.map +0 -1
  244. package/dist/esm/src/components/Icon/icons/requiredStar.svg.js.map +0 -1
  245. package/dist/esm/src/components/Icon/icons/save.svg.js.map +0 -1
  246. package/dist/esm/src/components/Icon/icons/send.svg.js.map +0 -1
  247. package/dist/esm/src/components/Icon/icons/settings.svg.js.map +0 -1
  248. package/dist/esm/src/components/Icon/icons/shoppingBag.svg.js.map +0 -1
  249. package/dist/esm/src/components/Icon/icons/table.svg.js.map +0 -1
  250. package/dist/esm/src/components/Icon/icons/telegram.svg.js.map +0 -1
  251. package/dist/esm/src/components/Icon/icons/undo.svg.js.map +0 -1
  252. package/dist/esm/src/components/Input/Input.js.map +0 -1
  253. package/dist/esm/src/components/Input/Input.styl.js.map +0 -1
  254. package/dist/esm/src/components/InputFile/InputFile.js.map +0 -1
  255. package/dist/esm/src/components/InputFile/InputFile.styl.js.map +0 -1
  256. package/dist/esm/src/components/InputFile/InputFile.types.js.map +0 -1
  257. package/dist/esm/src/components/InputFile/Item/Item.js.map +0 -1
  258. package/dist/esm/src/components/InputFile/Item/Item.styl.js.map +0 -1
  259. package/dist/esm/src/components/Label/Label.constants.json.js.map +0 -1
  260. package/dist/esm/src/components/Label/Label.helpers.js.map +0 -1
  261. package/dist/esm/src/components/Label/Label.js.map +0 -1
  262. package/dist/esm/src/components/Label/Label.styl.js.map +0 -1
  263. package/dist/esm/src/components/Lazy/Lazy.js.map +0 -1
  264. package/dist/esm/src/components/LightBox/LightBox.js.map +0 -1
  265. package/dist/esm/src/components/LightBox/LightBox.styl.js.map +0 -1
  266. package/dist/esm/src/components/Notifications/Notifications.constants.json.js.map +0 -1
  267. package/dist/esm/src/components/Notifications/Notifications.js.map +0 -1
  268. package/dist/esm/src/components/Notifications/Notifications.styl.js.map +0 -1
  269. package/dist/esm/src/components/Notifications/store.js.map +0 -1
  270. package/dist/esm/src/components/Paranja/Paranja.js.map +0 -1
  271. package/dist/esm/src/components/Paranja/Paranja.styl.js.map +0 -1
  272. package/dist/esm/src/components/Popup/Popup.helpers.js.map +0 -1
  273. package/dist/esm/src/components/Popup/Popup.js.map +0 -1
  274. package/dist/esm/src/components/Popup/Popup.styl.js.map +0 -1
  275. package/dist/esm/src/components/PopupMenu/PopupMenu.js.map +0 -1
  276. package/dist/esm/src/components/PopupMenu/PopupMenu.styl.js.map +0 -1
  277. package/dist/esm/src/components/Portal/Portal.js.map +0 -1
  278. package/dist/esm/src/components/RequiredStar/RequiredStar.js.map +0 -1
  279. package/dist/esm/src/components/RequiredStar/RequiredStar.styl.js.map +0 -1
  280. package/dist/esm/src/components/Router/Link/Link.js.map +0 -1
  281. package/dist/esm/src/components/Router/Link/Link.styl.js.map +0 -1
  282. package/dist/esm/src/components/Router/Redirect.js.map +0 -1
  283. package/dist/esm/src/components/Router/Route.js.map +0 -1
  284. package/dist/esm/src/components/Router/Router.helpers.js.map +0 -1
  285. package/dist/esm/src/components/Router/Router.js.map +0 -1
  286. package/dist/esm/src/components/Router/context.js.map +0 -1
  287. package/dist/esm/src/components/Router/store.js.map +0 -1
  288. package/dist/esm/src/components/Scroll/Scroll.js.map +0 -1
  289. package/dist/esm/src/components/Scroll/Scroll.styl.js.map +0 -1
  290. package/dist/esm/src/components/Select/Select.helpers.js.map +0 -1
  291. package/dist/esm/src/components/Select/Select.js.map +0 -1
  292. package/dist/esm/src/components/Select/Select.styl.js.map +0 -1
  293. package/dist/esm/src/components/Spinner/Spinner.js.map +0 -1
  294. package/dist/esm/src/components/Spinner/Spinner.styl.js.map +0 -1
  295. package/dist/esm/src/components/Spinner/spinner.svg.js.map +0 -1
  296. package/dist/esm/src/components/Table/Table.js.map +0 -1
  297. package/dist/esm/src/components/Table/Table.styl.js.map +0 -1
  298. package/dist/esm/src/components/Tabs/Tabs.js.map +0 -1
  299. package/dist/esm/src/components/Tabs/Tabs.styl.js.map +0 -1
  300. package/dist/esm/src/components/Text/Text.js.map +0 -1
  301. package/dist/esm/src/components/Text/Text.styl.js.map +0 -1
  302. package/dist/esm/src/components/Theme/Theme.defaults.js.map +0 -1
  303. package/dist/esm/src/components/Theme/Theme.helpers.js.map +0 -1
  304. package/dist/esm/src/components/Theme/Theme.js.map +0 -1
  305. package/dist/esm/src/components/VH/VH.js.map +0 -1
  306. package/dist/esm/src/components/Virtualized/List/List.js.map +0 -1
  307. package/dist/esm/src/components/Virtualized/List/List.styl.js.map +0 -1
  308. package/dist/esm/src/components/Virtualized/List/ListScroll.js.map +0 -1
  309. package/dist/esm/src/components/Virtualized/List/ListScroll.styl.js.map +0 -1
  310. package/dist/esm/src/components/Virtualized/Virtualized.helpers.js.map +0 -1
  311. package/dist/esm/src/components/Virtualized/Virtualized.js.map +0 -1
  312. package/dist/esm/src/components/Virtualized/Virtualized.styl.js.map +0 -1
  313. package/dist/esm/src/components/Virtualized/Virtualized.types.js.map +0 -1
  314. package/dist/esm/src/services/i18n.js.map +0 -1
  315. package/dist/esm/src/tools/array.js.map +0 -1
  316. package/dist/esm/src/tools/config.js.map +0 -1
  317. package/dist/esm/src/tools/date.js.map +0 -1
  318. package/dist/esm/src/tools/debounce.js.map +0 -1
  319. package/dist/esm/src/tools/dom.js.map +0 -1
  320. package/dist/esm/src/tools/env.js.map +0 -1
  321. package/dist/esm/src/tools/file.js.map +0 -1
  322. package/dist/esm/src/tools/localStorage.js.map +0 -1
  323. package/dist/esm/src/tools/number.js.map +0 -1
  324. package/dist/esm/src/tools/object.js.map +0 -1
  325. package/dist/esm/src/tools/queryParams.js.map +0 -1
  326. package/dist/esm/src/tools/rangeMap.js.map +0 -1
  327. package/dist/esm/src/tools/resizeObserver.js.map +0 -1
  328. package/dist/esm/src/tools/scroll.js.map +0 -1
  329. package/dist/esm/src/tools/string.js.map +0 -1
  330. package/dist/esm/src/tools/throttle.js.map +0 -1
  331. package/dist/esm/src/tools/uid.js.map +0 -1
@@ -1,2 +1,24 @@
1
- import*as React from"react";var _circle;function _extends(){return(_extends=Object.assign?Object.assign.bind():function(e){for(var r=1;r<arguments.length;r++){var t,n=arguments[r];for(t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=n[t])}return e}).apply(this,arguments)}var SvgSpinner=function(e){return React.createElement("svg",_extends({width:50,height:50,xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 100 100",preserveAspectRatio:"xMidYMid"},e),_circle=_circle||React.createElement("circle",{cx:50,cy:50,fill:"none",stroke:"currentColor",strokeWidth:8,r:45,strokeDasharray:"212.05750411731105 72.68583470577035",transform:"rotate(270 50 50)"}))};export{SvgSpinner as default};
2
- //# sourceMappingURL=spinner.svg.js.map
1
+ import * as React from 'react';
2
+
3
+ var _circle;
4
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
5
+ var SvgSpinner = function SvgSpinner(props) {
6
+ return /*#__PURE__*/React.createElement("svg", _extends({
7
+ width: 50,
8
+ height: 50,
9
+ xmlns: "http://www.w3.org/2000/svg",
10
+ viewBox: "0 0 100 100",
11
+ preserveAspectRatio: "xMidYMid"
12
+ }, props), _circle || (_circle = /*#__PURE__*/React.createElement("circle", {
13
+ cx: 50,
14
+ cy: 50,
15
+ fill: "none",
16
+ stroke: "currentColor",
17
+ strokeWidth: 8,
18
+ r: 45,
19
+ strokeDasharray: "212.05750411731105 72.68583470577035",
20
+ transform: "rotate(270 50 50)"
21
+ })));
22
+ };
23
+
24
+ export { SvgSpinner as default };
@@ -1,2 +1,24 @@
1
- import{jsx,jsxs}from"react/jsx-runtime";import{Component}from"react";import cn from"classnames";import{Paranja}from"../Paranja/Paranja.js";import{Scroll}from"../Scroll/Scroll.js";import{Spinner}from"../Spinner/Spinner.js";import S from"./Table.styl.js";class Table extends Component{renderHeaderColumn=({id:r,label:e,sticky:n})=>jsx("th",{className:cn(n&&S.sticky),children:e},r);renderRow=e=>{var r=this.props["columns"];return jsx("tr",{children:r.map(r=>this.renderDataCol(r,e))},e.id)};renderDataCol({id:r,dataField:e,render:n,sticky:s},a){return jsx("td",{className:cn(s&&S.sticky),children:n?n(a):a[e||r]},r)}render(){var{className:r,columns:e,isLoading:n=!1,loadingText:s,blur:a,data:l}=this.props;return jsxs("div",{className:cn(S.root,a&&S.blur,r),children:[jsx(Scroll,{x:!0,y:!0,offset:{x:{before:10,after:10}},children:jsxs("table",{children:[jsx("thead",{children:jsx("tr",{children:e.map(this.renderHeaderColumn)})}),jsx("tbody",{children:l.map(this.renderRow)})]})}),jsx(Paranja,{inline:!0,visible:n,blur:a,children:n&&(s??jsx(Spinner,{}))})]})}}export{Table};
2
- //# sourceMappingURL=Table.js.map
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { Component } from 'react';
3
+ import cn from 'classnames';
4
+ import { Paranja } from '../Paranja/Paranja.js';
5
+ import { Scroll } from '../Scroll/Scroll.js';
6
+ import { Spinner } from '../Spinner/Spinner.js';
7
+ import S from './Table.styl.js';
8
+
9
+ class Table extends Component {
10
+ renderHeaderColumn = ({ id, label, sticky }) => (jsx("th", { className: cn(sticky && S.sticky), children: label }, id));
11
+ renderRow = data => {
12
+ const { columns } = this.props;
13
+ return (jsx("tr", { children: columns.map(param => this.renderDataCol(param, data)) }, data.id));
14
+ };
15
+ renderDataCol({ id, dataField, render, sticky }, data) {
16
+ return (jsx("td", { className: cn(sticky && S.sticky), children: render ? render(data) : data[dataField || id] }, id));
17
+ }
18
+ render() {
19
+ const { className, columns, isLoading = false, loadingText, blur, data, } = this.props;
20
+ return (jsxs("div", { className: cn(S.root, blur && S.blur, className), children: [jsx(Scroll, { x: true, y: true, offset: { x: { before: 10, after: 10 } }, children: jsxs("table", { children: [jsx("thead", { children: jsx("tr", { children: columns.map(this.renderHeaderColumn) }) }), jsx("tbody", { children: data.map(this.renderRow) })] }) }), jsx(Paranja, { inline: true, visible: isLoading, blur: blur, children: isLoading && (loadingText ?? jsx(Spinner, {})) })] }));
21
+ }
22
+ }
23
+
24
+ export { Table };
@@ -1,2 +1,7 @@
1
- import styleInject from"../../../node_modules/style-inject/dist/style-inject.es.js";var css_248z=".Table_root__PxLR-{border-radius:var(--border-radius-l);box-shadow:0 0 0 2px var(--accent-color-alpha-100);overflow:hidden;position:relative}.Table_root__PxLR- table{min-width:100%}.Table_root__PxLR- tbody{overflow-scrolling:touch;overflow:auto}.Table_root__PxLR- thead{position:sticky;top:0;z-index:1}.Table_root__PxLR- td{box-shadow:inset 0 1px 0 0 var(--accent-color-alpha-100)}.Table_root__PxLR- td,.Table_root__PxLR- th{min-width:5em;padding:var(--indent-s);text-align:left}.Table_root__PxLR- th{background-color:var(--accent-color-alpha-100);padding-bottom:16px}.Table_root__PxLR- td{vertical-align:top}.Table_root__PxLR- tr:last-child td{padding-bottom:var(--indent-l)}.Table_sticky__99lks{background-color:var(--decent-color);left:0;position:sticky;z-index:1}th.Table_sticky__99lks{background-color:var(--accent-color);color:var(--decent-color)}.Table_blur__UwMAo .Table_sticky__99lks{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background-color:var(--decent-color-alpha-500)}.Table_blur__UwMAo th.Table_sticky__99lks{background-color:var(--accent-color-alpha-500);color:var(--decent-color-alpha-800)}",S={root:"Table_root__PxLR-",sticky:"Table_sticky__99lks",blur:"Table_blur__UwMAo"};styleInject(css_248z);export{S as default};
2
- //# sourceMappingURL=Table.styl.js.map
1
+ import styleInject from '../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = ".Table_root__PxLR-{border-radius:var(--border-radius-l);box-shadow:0 0 0 2px var(--accent-color-alpha-100);overflow:hidden;position:relative}.Table_root__PxLR- table{min-width:100%}.Table_root__PxLR- tbody{overflow-scrolling:touch;overflow:auto}.Table_root__PxLR- thead{position:sticky;top:0;z-index:1}.Table_root__PxLR- td{box-shadow:inset 0 1px 0 0 var(--accent-color-alpha-100)}.Table_root__PxLR- td,.Table_root__PxLR- th{min-width:5em;padding:var(--indent-s);text-align:left}.Table_root__PxLR- th{background-color:var(--accent-color-alpha-100);padding-bottom:16px}.Table_root__PxLR- td{vertical-align:top}.Table_root__PxLR- tr:last-child td{padding-bottom:var(--indent-l)}.Table_sticky__99lks{background-color:var(--decent-color);left:0;position:sticky;z-index:1}th.Table_sticky__99lks{background-color:var(--accent-color);color:var(--decent-color)}.Table_blur__UwMAo .Table_sticky__99lks{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background-color:var(--decent-color-alpha-500)}.Table_blur__UwMAo th.Table_sticky__99lks{background-color:var(--accent-color-alpha-500);color:var(--decent-color-alpha-800)}";
4
+ var S = {"root":"Table_root__PxLR-","sticky":"Table_sticky__99lks","blur":"Table_blur__UwMAo"};
5
+ styleInject(css_248z);
6
+
7
+ export { S as default };
@@ -1,2 +1,43 @@
1
- import{useState,useRef,useCallback,createElement}from"react";import{jsx,Fragment}from"react/jsx-runtime";import cn from"classnames";import{Button}from"../Button/Button.js";import{ButtonGroup}from"../ButtonGroup/ButtonGroup.js";import S from"./Tabs.styl.js";function isId(t){return["string","number"].includes(typeof t)}function Tabs(t){const{size:i="m",contentClassName:m,items:e,onChange:r,renderAll:l,activeId:n,children:o,...s}=t,[f,c]=useState(isId(n)?n:e[0].id),p=useRef([]),d=useCallback((t,{id:e,onClick:n}={})=>{n&&!n(t)?t.peventDefault():(c(e),r?.(e))},[]);p.current=[];t=e.map(e=>{const{id:t,label:n,forceRender:r,content:o,contentClassName:s,...c}=e;var u=f===t,a="function"==typeof o?o():o;return(l||r||u)&&p.current.push(jsx("div",{className:cn(m,s,!u&&S.inactive),children:a},t)),createElement(Button,{...c,size:i,key:t,onClick:t=>d(t,e),checked:u},n)});return"function"==typeof o?o({tabs:jsx(ButtonGroup,{...s,children:t}),content:p.current}):jsx(Fragment,{children:p.current})}export{Tabs};
2
- //# sourceMappingURL=Tabs.js.map
1
+ import { useState, useRef, useCallback, createElement } from 'react';
2
+ import { jsx, Fragment } from 'react/jsx-runtime';
3
+ import cn from 'classnames';
4
+ import { Button } from '../Button/Button.js';
5
+ import { ButtonGroup } from '../ButtonGroup/ButtonGroup.js';
6
+ import S from './Tabs.styl.js';
7
+
8
+ function isId(id) {
9
+ return ['string', 'number'].includes(typeof id);
10
+ }
11
+ function Tabs(props) {
12
+ const { size = 'm', contentClassName, items, onChange, renderAll, activeId: initialId, children, ...rest } = props;
13
+ const [activeId, setActiveId] = useState(isId(initialId) ? initialId : items[0].id);
14
+ const tabsContent = useRef([]);
15
+ const onTabClick = useCallback((e, { id, onClick } = {}) => {
16
+ // @ts-ignore
17
+ if (onClick && !onClick(e)) {
18
+ e.peventDefault();
19
+ return;
20
+ }
21
+ setActiveId(id);
22
+ onChange?.(id);
23
+ }, []);
24
+ tabsContent.current = [];
25
+ const tabs = items.map((params) => {
26
+ const { id, label, forceRender, content, contentClassName: currContentClassName, ...rest } = params;
27
+ const isActive = activeId === id;
28
+ const tabContent = typeof content === 'function' ? content() : content;
29
+ if (renderAll || forceRender || isActive) {
30
+ tabsContent.current.push(jsx("div", { className: cn(contentClassName, currContentClassName, !isActive && S.inactive), children: tabContent }, id));
31
+ }
32
+ return (createElement(Button, { ...rest, size: size, key: id, onClick: e => onTabClick(e, params), checked: isActive }, label));
33
+ });
34
+ if (typeof children === 'function') {
35
+ return children({
36
+ tabs: jsx(ButtonGroup, { ...rest, children: tabs }),
37
+ content: tabsContent.current,
38
+ });
39
+ }
40
+ return jsx(Fragment, { children: tabsContent.current });
41
+ }
42
+
43
+ export { Tabs };
@@ -1,2 +1,7 @@
1
- import styleInject from"../../../node_modules/style-inject/dist/style-inject.es.js";var css_248z="div .Tabs_inactive__H0mPh{display:none}",S={inactive:"Tabs_inactive__H0mPh"};styleInject(css_248z);export{S as default};
2
- //# sourceMappingURL=Tabs.styl.js.map
1
+ import styleInject from '../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = "div .Tabs_inactive__H0mPh{display:none}";
4
+ var S = {"inactive":"Tabs_inactive__H0mPh"};
5
+ styleInject(css_248z);
6
+
7
+ export { S as default };
@@ -1,2 +1,44 @@
1
- import{jsx,jsxs,Fragment}from"react/jsx-runtime";import cn from"classnames";import{useCallback}from"react";import{Link}from"../Router/Link/Link.js";import{isBrowser}from"../../tools/env.js";import"nanoid";import"../../tools/dom.js";import"timen";import"compareq";import"lodash.pick";import"../../tools/queryParams.js";import S from"./Text.styl.js";const textToAnchorId=o=>o.toLowerCase().split(" ").join("_"),getPath=()=>(isBrowser&&location.pathname)??"/",scrollIntoHeader=o=>document.getElementById(o)?.scrollIntoView();function useAnchor(o){if("string"!=typeof o)return[];const s=textToAnchorId(o);var o=getPath()+"#"+s,r=useCallback(()=>scrollIntoHeader(s),[s]);return[s,jsxs(Fragment,{children:[" ",jsx(Link,{href:o,className:S.anchor,onClick:r,children:"#"})]})]}function H({As:o,className:s,children:r,anchor:t,...e}){var[t,n]=useAnchor(t??r);return jsxs(o,{...e,className:cn(S.heading,s),id:t,children:[r,n]})}const H1=o=>jsx(H,{...o,As:"h1",anchor:!1}),H2=o=>jsx(H,{...o,As:"h2"}),H3=o=>jsx(H,{...o,As:"h3"}),H4=o=>jsx(H,{...o,As:"h4"}),H5=o=>jsx(H,{...o,As:"h5"}),H6=o=>jsx(H,{...o,As:"h6"});isBrowser&&window.addEventListener("load",()=>{scrollIntoHeader(location.hash.slice(1))});export{H1,H2,H3,H4,H5,H6};
2
- //# sourceMappingURL=Text.js.map
1
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
+ import cn from 'classnames';
3
+ import { useCallback } from 'react';
4
+ import { Link } from '../Router/Link/Link.js';
5
+ import { isBrowser } from '../../tools/env.js';
6
+ import 'nanoid';
7
+ import '../../tools/dom.js';
8
+ import 'timen';
9
+ import 'compareq';
10
+ import 'lodash.pick';
11
+ import '../../tools/queryParams.js';
12
+ import S from './Text.styl.js';
13
+
14
+ const textToAnchorId = text => text.toLowerCase().split(' ').join('_');
15
+ const getPath = () => (isBrowser && location.pathname) ?? '/';
16
+ const scrollIntoHeader = id => document.getElementById(id)?.scrollIntoView();
17
+ function useAnchor(text) {
18
+ if (typeof text !== 'string')
19
+ return [];
20
+ const id = textToAnchorId(text);
21
+ const href = `${getPath()}#${id}`;
22
+ const scrollUp = useCallback(() => scrollIntoHeader(id), [id]);
23
+ return [
24
+ id,
25
+ jsxs(Fragment, { children: ["\u00A0", jsx(Link, { href: href, className: S.anchor, onClick: scrollUp, children: "#" })] }),
26
+ ];
27
+ }
28
+ function H({ As, className, children, anchor, ...rest }) {
29
+ const [id, anchorEl] = useAnchor(anchor ?? children);
30
+ return (jsxs(As, { ...rest, className: cn(S.heading, className), id: id, children: [children, anchorEl] }));
31
+ }
32
+ const H1 = props => jsx(H, { ...props, As: "h1", anchor: false });
33
+ const H2 = props => jsx(H, { ...props, As: "h2" });
34
+ const H3 = props => jsx(H, { ...props, As: "h3" });
35
+ const H4 = props => jsx(H, { ...props, As: "h4" });
36
+ const H5 = props => jsx(H, { ...props, As: "h5" });
37
+ const H6 = props => jsx(H, { ...props, As: "h6" });
38
+ if (isBrowser) {
39
+ window.addEventListener('load', () => {
40
+ scrollIntoHeader(location.hash.slice(1));
41
+ });
42
+ }
43
+
44
+ export { H1, H2, H3, H4, H5, H6 };
@@ -1,2 +1,7 @@
1
- import styleInject from"../../../node_modules/style-inject/dist/style-inject.es.js";var css_248z=".Text_heading__DR-MG{position:relative}.Text_anchor__hq6W6{align-items:flex-start;border-radius:50%;height:100%;opacity:0;padding:0 .5em;transform:translateX(-1em);transition:.2s ease-out;transition-property:transform,opacity;-webkit-user-select:none;-moz-user-select:none;user-select:none}.Text_anchor__hq6W6:before{background:none!important;height:100%;position:absolute;width:2em}.Text_heading__DR-MG:hover .Text_anchor__hq6W6{opacity:1;transform:translateX(0)}.Text_heading__DR-MG .Text_anchor__hq6W6:hover{color:var(--active-color)}",S={heading:"Text_heading__DR-MG",anchor:"Text_anchor__hq6W6"};styleInject(css_248z);export{S as default};
2
- //# sourceMappingURL=Text.styl.js.map
1
+ import styleInject from '../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = ".Text_heading__DR-MG{position:relative}.Text_anchor__hq6W6{align-items:flex-start;border-radius:50%;height:100%;opacity:0;padding:0 .5em;transform:translateX(-1em);transition:.2s ease-out;transition-property:transform,opacity;-webkit-user-select:none;-moz-user-select:none;user-select:none}.Text_anchor__hq6W6:before{background:none!important;height:100%;position:absolute;width:2em}.Text_heading__DR-MG:hover .Text_anchor__hq6W6{opacity:1;transform:translateX(0)}.Text_heading__DR-MG .Text_anchor__hq6W6:hover{color:var(--active-color)}";
4
+ var S = {"heading":"Text_heading__DR-MG","anchor":"Text_anchor__hq6W6"};
5
+ styleInject(css_248z);
6
+
7
+ export { S as default };
@@ -1,2 +1,50 @@
1
- import{colorsConfigToVars}from"./Theme.helpers.js";const baseConfig={"indent-s":"10px","indent-m":"20px","indent-l":"30px","border-radius-s":"2px","border-radius-m":"4px","border-radius-l":"6px"},colorsAlphaModes=[0,50,100,200,300,500,800,900],colors={light:"#e6e6e6",dark:"#1a1a1a"};function getColors({accent:o=colors.light,decent:r=colors.dark,active:e="#54b62b",warning:a="#ffa31a",danger:s="#da3749",disabled:l="#f1f1f2",link:n="#3089fe"}={}){return{active:{color:e,mods:{alpha:[100,300,500,800]}},warning:{color:a,mods:{alpha:[100,300,500]}},danger:{color:s,mods:{alpha:[100,300,500]}},disabled:l,link:n,accent:{color:o,mods:{alpha:colorsAlphaModes}},decent:{color:r,mods:{alpha:colorsAlphaModes}}}}const getConfig=(o={})=>({...colorsConfigToVars(getColors(o.colors)),...baseConfig,...o.rest});export{baseConfig,colors,getColors,getConfig};
2
- //# sourceMappingURL=Theme.defaults.js.map
1
+ import { colorsConfigToVars } from './Theme.helpers.js';
2
+
3
+ const baseConfig = {
4
+ 'indent-s': '10px',
5
+ 'indent-m': '20px',
6
+ 'indent-l': '30px',
7
+ 'border-radius-s': '2px',
8
+ 'border-radius-m': '4px',
9
+ 'border-radius-l': '6px',
10
+ };
11
+ const colorsAlphaModes = [0, 50, 100, 200, 300, 500, 800, 900];
12
+ const colors = {
13
+ light: '#e6e6e6',
14
+ dark: '#1a1a1a',
15
+ };
16
+ function getColors({ accent = colors.light, decent = colors.dark, active = '#54b62b', warning = '#ffa31a', danger = '#da3749', disabled = '#f1f1f2', link = '#3089fe', } = {}) {
17
+ return {
18
+ active: {
19
+ color: active,
20
+ mods: { alpha: [100, 300, 500, 800] /* mix: [['accent', 300]] */ },
21
+ },
22
+ warning: {
23
+ color: warning,
24
+ mods: { alpha: [100, 300, 500] },
25
+ },
26
+ danger: {
27
+ color: danger,
28
+ mods: { alpha: [100, 300, 500] },
29
+ },
30
+ disabled,
31
+ link,
32
+ accent: {
33
+ color: accent,
34
+ mods: { alpha: colorsAlphaModes },
35
+ },
36
+ decent: {
37
+ color: decent,
38
+ mods: { alpha: colorsAlphaModes },
39
+ },
40
+ };
41
+ }
42
+ const getConfig = (cfg = {}) => ({
43
+ // @ts-ignore
44
+ ...colorsConfigToVars(getColors(cfg.colors)),
45
+ ...baseConfig,
46
+ // @ts-ignore
47
+ ...cfg.rest,
48
+ });
49
+
50
+ export { baseConfig, colors, getColors, getConfig };
@@ -1,2 +1,67 @@
1
- function hexToRGB(o){o=o.replace(/^#?([a-f\d])([a-f\d])([a-f\d])$/i,(o,r,e,t)=>r+r+e+e+t+t),o=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(o);return o?[parseInt(o[1],16),parseInt(o[2],16),parseInt(o[3],16)].join(","):null}const mix=(o,r,e)=>Math.floor(o*(1-e)+r*e);function mixColor(o,r,e=1){o=(/^#/.test(o)?hexToRGB(o):o).split(",").map(o=>parseInt(o,10)),r=(/^#/.test(r)?hexToRGB(r):r).split(",").map(o=>parseInt(o,10));return`rgb(${[mix(o[0],r[0],e),mix(o[1],r[1],e),mix(o[2],r[2],e)].join(",")})`}function rgba(o,r){return`rgba(${getRGB(o)},${r})`}function getRGB(o){return/^rgb/.test(o)?o.replace(/^rgb?\(|\)$/g,""):hexToRGB(o)}const getConfigColor=o=>o?.color||o,colorMods={alpha:(o,r)=>[rgba(o,r/1e3),"alpha-"+r],mix:(o,[r,e],t)=>[mixColor(o,getConfigColor(t[r]),e/1e3),`mix-${r}-`+e]};function colorsConfigToVars(i){return Object.entries(i).reduce((t,[o,r])=>{const n=o+"-color";if("string"==typeof r)t[n]=r;else{const{color:a,mods:e}=r;t[n]=a,"object"==typeof e&&null!==e&&Object.entries(e||{}).forEach(([e,o])=>{o.forEach(o=>{var[o,r]=colorMods[e](a,o,i);t[n+"-"+r]=o})})}return t},{})}export{colorsConfigToVars,getRGB,mixColor,rgba};
2
- //# sourceMappingURL=Theme.helpers.js.map
1
+ function hexToRGB(str) {
2
+ // Expand shorthand form (e.g. "03F") to full form (e.g. "0033FF")
3
+ const shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i;
4
+ const hex = str.replace(shorthandRegex, (m, r, g, b) => r + r + g + g + b + b);
5
+ const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
6
+ if (!result)
7
+ return null;
8
+ return [
9
+ parseInt(result[1], 16),
10
+ parseInt(result[2], 16),
11
+ parseInt(result[3], 16),
12
+ ].join(',');
13
+ }
14
+ const mix = (c1, c2, val) => Math.floor(c1 * (1 - val) + c2 * val);
15
+ function mixColor(color1, color2, val = 1) {
16
+ const c1 = (/^#/.test(color1) ? hexToRGB(color1) : color1)
17
+ .split(',')
18
+ .map(n => parseInt(n, 10));
19
+ const c2 = (/^#/.test(color2) ? hexToRGB(color2) : color2)
20
+ .split(',')
21
+ .map(n => parseInt(n, 10));
22
+ const rgb = [
23
+ mix(c1[0], c2[0], val),
24
+ mix(c1[1], c2[1], val),
25
+ mix(c1[2], c2[2], val),
26
+ ].join(',');
27
+ return `rgb(${rgb})`;
28
+ }
29
+ function rgba(color, transparency) {
30
+ return `rgba(${getRGB(color)},${transparency})`;
31
+ }
32
+ function getRGB(color) {
33
+ if (/^rgb/.test(color))
34
+ return color.replace(/^rgb?\(|\)$/g, '');
35
+ return hexToRGB(color);
36
+ }
37
+ const getConfigColor = val => val?.color || val;
38
+ const colorMods = {
39
+ alpha: (color, val) => [rgba(color, val / 1000), `alpha-${val}`],
40
+ mix: (color1, [color2, val], config) => [
41
+ mixColor(color1, getConfigColor(config[color2]), val / 1000),
42
+ `mix-${color2}-${val}`,
43
+ ],
44
+ };
45
+ function colorsConfigToVars(config) {
46
+ return Object.entries(config).reduce((acc, [name, val]) => {
47
+ const colorName = `${name}-color`;
48
+ if (typeof val === 'string') {
49
+ acc[colorName] = val;
50
+ }
51
+ else {
52
+ const { color, mods } = val;
53
+ acc[colorName] = color;
54
+ if (typeof mods === 'object' && mods !== null) {
55
+ Object.entries(mods || {}).forEach(([mod, vals]) => {
56
+ vals.forEach(val => {
57
+ const [res, prefix] = colorMods[mod](color, val, config);
58
+ acc[`${colorName}-${prefix}`] = res;
59
+ });
60
+ });
61
+ }
62
+ }
63
+ return acc;
64
+ }, {});
65
+ }
66
+
67
+ export { colorsConfigToVars, getRGB, mixColor, rgba };
@@ -1,2 +1,13 @@
1
- import{jsx}from"react/jsx-runtime";function buildVar(e,r){return`--${e}: ${r};`}function Theme({config:e={}}){e=Object.entries(e).map(([e,r])=>buildVar(e,r)).join("\n");return jsx("style",{children:`:root {${e}}`})}export{Theme};
2
- //# sourceMappingURL=Theme.js.map
1
+ import { jsx } from 'react/jsx-runtime';
2
+
3
+ function buildVar(name, val) {
4
+ return `--${name}: ${val};`;
5
+ }
6
+ function Theme({ config = {} }) {
7
+ const vars = Object.entries(config)
8
+ .map(([name, val]) => buildVar(name, val))
9
+ .join('\n');
10
+ return jsx("style", { children: `:root {${vars}}` });
11
+ }
12
+
13
+ export { Theme };
@@ -1,2 +1,33 @@
1
- import{jsx}from"react/jsx-runtime";import{Component}from"react";import{isBrowser}from"../../tools/env.js";import"nanoid";import"../../tools/dom.js";import"timen";import"compareq";import"lodash.pick";import"../../tools/queryParams.js";const getVH=()=>isBrowser?window.innerHeight/100:0;class VH extends Component{constructor(t){super(t),this.state={vh:0}}componentDidMount(){this.updateVH(),window.addEventListener("resize",this.updateVH)}componentWillUnmount(){window.removeEventListener("resize",this.updateVH)}updateVH=()=>{this.setState({vh:getVH()})};render(){var t=this.state["vh"];return jsx("style",{children:`:root{--vh: ${t}px;}`})}}export{VH};
2
- //# sourceMappingURL=VH.js.map
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { Component } from 'react';
3
+ import { isBrowser } from '../../tools/env.js';
4
+ import 'nanoid';
5
+ import '../../tools/dom.js';
6
+ import 'timen';
7
+ import 'compareq';
8
+ import 'lodash.pick';
9
+ import '../../tools/queryParams.js';
10
+
11
+ const getVH = () => (isBrowser ? window.innerHeight / 100 : 0);
12
+ class VH extends Component {
13
+ constructor(props) {
14
+ super(props);
15
+ this.state = { vh: 0 };
16
+ }
17
+ componentDidMount() {
18
+ this.updateVH();
19
+ window.addEventListener('resize', this.updateVH);
20
+ }
21
+ componentWillUnmount() {
22
+ window.removeEventListener('resize', this.updateVH);
23
+ }
24
+ updateVH = () => {
25
+ this.setState({ vh: getVH() });
26
+ };
27
+ render() {
28
+ const { vh } = this.state;
29
+ return jsx("style", { children: `:root{--vh: ${vh}px;}` });
30
+ }
31
+ }
32
+
33
+ export { VH };
@@ -1,2 +1,124 @@
1
- import{jsxs,Fragment,jsx}from"react/jsx-runtime";import{Component,createRef}from"react";import omit from"lodash.omit";import{createStore}from"justorm/react";import Time from"timen";import*as number from"../../../tools/number.js";import"nanoid";import"../../../tools/dom.js";import"compareq";import"lodash.pick";import"../../../tools/queryParams.js";import Virtualized from"../Virtualized.js";import S from"./List.styl.js";const zero=number["zero"],CONTENT_BEFORE_SIZE_CHECK_TIMEOUT=300;class List extends Component{store;wrapElem;contentBeforeElem;contentAfterElem;timers=Time.create();unsubscribeContentBeforeResize;constructor(e){super(e),this.store=createStore(this,{mounted:!1,contentBeforeHeight:0,hasWrap:!1}),this.contentBeforeElem=createRef(),this.contentAfterElem=createRef()}componentDidMount(){this.props.contentBefore&&(this.subscribeContentBeforeResize(),this.checkContentBeforeHeight())}componentDidUpdate(e){var t=this.props["contentBefore"];!e.contentBefore&&t&&this.subscribeContentBeforeResize(),e.contentBefore&&!t&&this.unsubscribeContentBeforeResize?.()}subscribeContentBeforeResize(){this.unsubscribeContentBeforeResize=Time.every(CONTENT_BEFORE_SIZE_CHECK_TIMEOUT,this.checkContentBeforeHeight)}checkContentBeforeHeight=()=>{var e=this.contentBeforeElem.current;e&&(e=e["offsetHeight"],e!==this.store.contentBeforeHeight)&&(this.store.contentBeforeHeight=e)};getProps(){var e=omit(this.props,["contentBefore","contentAfter","customWrapElem"]),t=this.store["contentBeforeHeight"],t=zero(t)+zero(this.props.offsetBefore),r=zero(this.contentAfterElem.current?.offsetHeight)+zero(this.props.offsetAfter);return t&&(e.offsetBefore=t),r&&(e.offsetAfter=r),e}getItemProps=({index:e,offsetBefore:t})=>{var r=this.props["itemHeight"];return{className:S.item,style:{top:zero(t)+e*r}}};onWrapRef=e=>{e&&(this.wrapElem=this.props.customWrapElem?.getRef?.(e)||e,this.store.hasWrap||(this.store.hasWrap=!0))};renderLayout=({state:e,items:t,...r})=>{var{contentBefore:o,contentAfter:s,customWrapElem:n}=this.props,{height:e,offsetAfter:i}=e,f=this.store["contentBeforeHeight"],r=omit(r,["contentBefore","contentAfter","scrollTop","itemHeight","itemsCount","totalCount","overlapCount","onScrollEnd","renderItem","wrapElem","getItemProps","offsetAfter","offsetBefore"]),o=jsxs(Fragment,{children:[o&&jsx("div",{ref:this.contentBeforeElem,children:o},"contentBefore"),jsx("div",{className:S.gap,style:{height:e-f}},"gap"),t,s&&jsx("div",{className:S.contentAfter,ref:this.contentAfterElem,style:{top:e-zero(i)},children:s},"contentAfter")]});let m="div";return n&&(m=n.component,Object.assign(r,n?.props)),jsx(m,{...r,ref:this.onWrapRef,children:o})};render(){return jsx(Virtualized,{...this.getProps(),wrapElem:this.wrapElem,getItemProps:this.getItemProps,children:this.renderLayout})}}export{List as default};
2
- //# sourceMappingURL=List.js.map
1
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
2
+ import { Component, createRef } from 'react';
3
+ import omit from 'lodash.omit';
4
+ import { createStore } from 'justorm/react';
5
+ import Time from 'timen';
6
+ import * as number from '../../../tools/number.js';
7
+ import 'nanoid';
8
+ import '../../../tools/dom.js';
9
+ import 'compareq';
10
+ import 'lodash.pick';
11
+ import '../../../tools/queryParams.js';
12
+ import Virtualized from '../Virtualized.js';
13
+ import S from './List.styl.js';
14
+
15
+ const { zero } = number;
16
+ const CONTENT_BEFORE_SIZE_CHECK_TIMEOUT = 300;
17
+ class List extends Component {
18
+ store;
19
+ wrapElem;
20
+ contentBeforeElem;
21
+ contentAfterElem;
22
+ timers = Time.create();
23
+ unsubscribeContentBeforeResize;
24
+ constructor(props) {
25
+ super(props);
26
+ this.store = createStore(this, {
27
+ mounted: false,
28
+ contentBeforeHeight: 0,
29
+ hasWrap: false,
30
+ });
31
+ // this.wrapElem = createRef<HTMLDivElement>();
32
+ this.contentBeforeElem = createRef();
33
+ this.contentAfterElem = createRef();
34
+ }
35
+ componentDidMount() {
36
+ // update, to pass actual wrapElem to Virtualized props
37
+ // this.store.mounted = true;
38
+ if (this.props.contentBefore) {
39
+ this.subscribeContentBeforeResize();
40
+ this.checkContentBeforeHeight();
41
+ }
42
+ }
43
+ componentDidUpdate(prevProps) {
44
+ const { contentBefore } = this.props;
45
+ if (!prevProps.contentBefore && contentBefore)
46
+ this.subscribeContentBeforeResize();
47
+ if (prevProps.contentBefore && !contentBefore)
48
+ this.unsubscribeContentBeforeResize?.();
49
+ }
50
+ subscribeContentBeforeResize() {
51
+ this.unsubscribeContentBeforeResize = Time.every(CONTENT_BEFORE_SIZE_CHECK_TIMEOUT, this.checkContentBeforeHeight);
52
+ }
53
+ checkContentBeforeHeight = () => {
54
+ const elem = this.contentBeforeElem.current;
55
+ if (!elem)
56
+ return;
57
+ const { offsetHeight } = elem;
58
+ if (offsetHeight !== this.store.contentBeforeHeight)
59
+ this.store.contentBeforeHeight = offsetHeight;
60
+ };
61
+ getProps() {
62
+ const props = omit(this.props, [
63
+ 'contentBefore',
64
+ 'contentAfter',
65
+ 'customWrapElem',
66
+ ]);
67
+ const { contentBeforeHeight } = this.store;
68
+ const offsetBefore = zero(contentBeforeHeight) + zero(this.props.offsetBefore);
69
+ const offsetAfter = zero(this.contentAfterElem.current?.offsetHeight) +
70
+ zero(this.props.offsetAfter);
71
+ if (offsetBefore)
72
+ props.offsetBefore = offsetBefore;
73
+ if (offsetAfter)
74
+ props.offsetAfter = offsetAfter;
75
+ return props;
76
+ }
77
+ getItemProps = ({ index, offsetBefore, offsetAfter }) => {
78
+ const { itemHeight } = this.props;
79
+ return {
80
+ className: S.item,
81
+ style: { top: zero(offsetBefore) + index * itemHeight },
82
+ };
83
+ };
84
+ onWrapRef = (ref) => {
85
+ if (!ref)
86
+ return;
87
+ // @ts-ignore
88
+ this.wrapElem = this.props.customWrapElem?.getRef?.(ref) || ref;
89
+ if (!this.store.hasWrap)
90
+ this.store.hasWrap = true;
91
+ };
92
+ renderLayout = ({ state, items, ...rest }) => {
93
+ const { contentBefore, contentAfter, customWrapElem } = this.props;
94
+ const { height, offsetAfter } = state;
95
+ const { contentBeforeHeight } = this.store;
96
+ const props = omit(rest, [
97
+ 'contentBefore',
98
+ 'contentAfter',
99
+ 'scrollTop',
100
+ 'itemHeight',
101
+ 'itemsCount',
102
+ 'totalCount',
103
+ 'overlapCount',
104
+ 'onScrollEnd',
105
+ 'renderItem',
106
+ 'wrapElem',
107
+ 'getItemProps',
108
+ 'offsetAfter',
109
+ 'offsetBefore',
110
+ ]);
111
+ const content = (jsxs(Fragment, { children: [contentBefore && (jsx("div", { ref: this.contentBeforeElem, children: contentBefore }, "contentBefore")), jsx("div", { className: S.gap, style: { height: height - contentBeforeHeight } }, "gap"), items, contentAfter && (jsx("div", { className: S.contentAfter, ref: this.contentAfterElem, style: { top: height - zero(offsetAfter) }, children: contentAfter }, "contentAfter"))] }));
112
+ let Elem = 'div';
113
+ if (customWrapElem) {
114
+ Elem = customWrapElem.component;
115
+ Object.assign(props, customWrapElem?.props);
116
+ }
117
+ return (jsx(Elem, { ...props, ref: this.onWrapRef, children: content }));
118
+ };
119
+ render() {
120
+ return (jsx(Virtualized, { ...this.getProps(), wrapElem: this.wrapElem, getItemProps: this.getItemProps, children: this.renderLayout }));
121
+ }
122
+ }
123
+
124
+ export { List as default };
@@ -1,2 +1,7 @@
1
- import styleInject from"../../../../node_modules/style-inject/dist/style-inject.es.js";var css_248z=".List_gap__-52oM{pointer-events:none;width:100%}.List_gap__-52oM,.List_item__-true{position:absolute}.List_contentAfter__H0Ujd{left:0;position:absolute;width:100%}",S={gap:"List_gap__-52oM",item:"List_item__-true",contentAfter:"List_contentAfter__H0Ujd"};styleInject(css_248z);export{S as default};
2
- //# sourceMappingURL=List.styl.js.map
1
+ import styleInject from '../../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = ".List_gap__-52oM{pointer-events:none;width:100%}.List_gap__-52oM,.List_item__-true{position:absolute}.List_contentAfter__H0Ujd{left:0;position:absolute;width:100%}";
4
+ var S = {"gap":"List_gap__-52oM","item":"List_item__-true","contentAfter":"List_contentAfter__H0Ujd"};
5
+ styleInject(css_248z);
6
+
7
+ export { S as default };
@@ -1,2 +1,21 @@
1
- import{jsx}from"react/jsx-runtime";import cn from"classnames";import{Scroll}from"../../Scroll/Scroll.js";import List from"./List.js";import S from"./ListScroll.styl.js";function ListScroll({scrollProps:r,...o}){var s=cn(r.x&&S.x,r.y&&S.y),r={...r,innerClassName:s};return jsx(List,{...o,customWrapElem:{component:Scroll,props:r,getRef:r=>r.innerElem}})}export{ListScroll as default};
2
- //# sourceMappingURL=ListScroll.js.map
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import cn from 'classnames';
3
+ import { Scroll } from '../../Scroll/Scroll.js';
4
+ import List from './List.js';
5
+ import S from './ListScroll.styl.js';
6
+
7
+ function ListScroll({ scrollProps, ...rest }) {
8
+ const innerClassName = cn(scrollProps.x && S.x, scrollProps.y && S.y);
9
+ const props = {
10
+ ...scrollProps,
11
+ innerClassName,
12
+ };
13
+ return (jsx(List, { ...rest, customWrapElem: {
14
+ component: Scroll,
15
+ props,
16
+ // @ts-ignore
17
+ getRef: ref => ref.innerElem,
18
+ } }));
19
+ }
20
+
21
+ export { ListScroll as default };
@@ -1,2 +1,7 @@
1
- import styleInject from"../../../../node_modules/style-inject/dist/style-inject.es.js";var css_248z=".ListScroll_x__tSPeG{width:100%}.ListScroll_y__mvFCU{height:100%}",S={x:"ListScroll_x__tSPeG",y:"ListScroll_y__mvFCU"};styleInject(css_248z);export{S as default};
2
- //# sourceMappingURL=ListScroll.styl.js.map
1
+ import styleInject from '../../../../node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = ".ListScroll_x__tSPeG{width:100%}.ListScroll_y__mvFCU{height:100%}";
4
+ var S = {"x":"ListScroll_x__tSPeG","y":"ListScroll_y__mvFCU"};
5
+ styleInject(css_248z);
6
+
7
+ export { S as default };
@@ -1,2 +1,14 @@
1
- function getLastIndex(t,e,n,o,i){return Math.min(i-1,Math.floor((t+e)/n+o))}function getIndexes({scrollTop:t,clientHeight:e,itemHeight:n,itemsCount:o,totalCount:i,overlapCount:a}){var r=Math.max(0,Math.floor(t/n-a));return{first:r,last:Math.min(Math.max(r,o+a-1),getLastIndex(t,e,n,a,i))}}function getHeight({itemsCount:t,itemHeight:e,offsetBefore:n=0,offsetAfter:o=0}){return t*e+n+o}export{getHeight,getIndexes,getLastIndex};
2
- //# sourceMappingURL=Virtualized.helpers.js.map
1
+ function getLastIndex(scrollTop, clientHeight, itemHeight, overlapCount, totalCount) {
2
+ return Math.min(totalCount - 1, Math.floor((scrollTop + clientHeight) / itemHeight + overlapCount));
3
+ }
4
+ // Returns indexes of first and last items to be rendered
5
+ function getIndexes({ scrollTop, clientHeight, itemHeight, itemsCount, totalCount, overlapCount, }) {
6
+ const first = Math.max(0, Math.floor(scrollTop / itemHeight - overlapCount));
7
+ const last = Math.min(Math.max(first, itemsCount + overlapCount - 1), getLastIndex(scrollTop, clientHeight, itemHeight, overlapCount, totalCount));
8
+ return { first, last };
9
+ }
10
+ function getHeight({ itemsCount, itemHeight, offsetBefore = 0, offsetAfter = 0, }) {
11
+ return itemsCount * itemHeight + offsetBefore + offsetAfter;
12
+ }
13
+
14
+ export { getHeight, getIndexes, getLastIndex };