@true-engineering/true-react-common-ui-kit 2.3.2 → 2.5.0

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 (374) hide show
  1. package/dist/components/AccountInfo/constants.d.ts +1 -0
  2. package/dist/components/Button/Button.d.ts +1 -3
  3. package/dist/components/Button/constants.d.ts +1 -0
  4. package/dist/components/Button/index.d.ts +1 -0
  5. package/dist/components/Button/types.d.ts +3 -0
  6. package/dist/components/DatePicker/DatePicker.styles.d.ts +4 -5
  7. package/dist/components/DatePicker/{DatePickerHeader → components/DatePickerHeader}/DatePickerHeader.styles.d.ts +1 -1
  8. package/dist/components/DatePicker/components/PopperContainer/PopperContainer.d.ts +4 -0
  9. package/dist/components/DatePicker/components/PopperContainer/index.d.ts +1 -0
  10. package/dist/components/DatePicker/components/index.d.ts +2 -0
  11. package/dist/components/DatePicker/constants.d.ts +2 -0
  12. package/dist/components/DatePicker/index.d.ts +2 -1
  13. package/dist/components/Description/constants.d.ts +1 -0
  14. package/dist/components/FiltersPane/FiltersPane.d.ts +2 -3
  15. package/dist/components/FiltersPane/components/Filter/Filter.d.ts +12 -0
  16. package/dist/components/FiltersPane/components/Filter/index.d.ts +1 -0
  17. package/dist/components/FiltersPane/{FilterInterval → components/FilterInterval}/FilterInterval.d.ts +2 -2
  18. package/dist/components/FiltersPane/{FilterInterval → components/FilterInterval}/FilterInterval.styles.d.ts +1 -1
  19. package/dist/components/FiltersPane/components/FilterInterval/index.d.ts +2 -0
  20. package/dist/components/FiltersPane/{FilterMultiSelect → components/FilterMultiSelect}/FilterMultiSelect.d.ts +2 -2
  21. package/dist/components/FiltersPane/{FilterSelect → components/FilterSelect}/FilterSelect.d.ts +2 -4
  22. package/dist/components/FiltersPane/{FilterSelect → components/FilterSelect}/FilterSelect.styles.d.ts +1 -1
  23. package/dist/components/FiltersPane/components/FilterSelect/index.d.ts +2 -0
  24. package/dist/components/FiltersPane/{FilterValueView → components/FilterValueView}/FilterValueView.styles.d.ts +1 -1
  25. package/dist/components/FiltersPane/components/FilterValueView/index.d.ts +2 -0
  26. package/dist/components/FiltersPane/{FilterWithDates → components/FilterWithDates}/FilterWithDates.d.ts +4 -9
  27. package/dist/components/FiltersPane/{FilterWithDates → components/FilterWithDates}/FilterWithDates.styles.d.ts +1 -1
  28. package/dist/components/FiltersPane/components/FilterWithDates/index.d.ts +2 -0
  29. package/dist/components/FiltersPane/{FilterWithPeriod → components/FilterWithPeriod}/FilterWithPeriod.d.ts +2 -3
  30. package/dist/components/FiltersPane/{FilterWithPeriod → components/FilterWithPeriod}/FilterWithPeriod.styles.d.ts +1 -1
  31. package/dist/components/FiltersPane/components/FilterWithPeriod/index.d.ts +2 -0
  32. package/dist/components/FiltersPane/components/FilterWrapper/FilterWrapper.d.ts +15 -0
  33. package/dist/components/FiltersPane/{FilterWrapper → components/FilterWrapper}/FilterWrapper.styles.d.ts +1 -1
  34. package/dist/components/FiltersPane/components/FilterWrapper/index.d.ts +2 -0
  35. package/dist/components/FiltersPane/{FiltersPaneSearch → components/FiltersPaneSearch}/FiltersPaneSearch.d.ts +2 -3
  36. package/dist/components/FiltersPane/{FiltersPaneSearch → components/FiltersPaneSearch}/FiltersPaneSearch.styles.d.ts +1 -1
  37. package/dist/components/FiltersPane/components/FiltersPaneSearch/index.d.ts +2 -0
  38. package/dist/components/FiltersPane/components/index.d.ts +9 -0
  39. package/dist/components/FiltersPane/constants.d.ts +9 -0
  40. package/dist/components/FiltersPane/helpers.d.ts +5 -0
  41. package/dist/components/FiltersPane/index.d.ts +1 -13
  42. package/dist/components/FiltersPane/types.d.ts +37 -7
  43. package/dist/components/FlexibleTable/FlexibleTable.d.ts +3 -3
  44. package/dist/components/FlexibleTable/{TableRow.d.ts → components/TableRow/TableRow.d.ts} +8 -8
  45. package/dist/components/FlexibleTable/components/TableRow/index.d.ts +1 -0
  46. package/dist/components/FlexibleTable/{TableValue.d.ts → components/TableValue/TableValue.d.ts} +3 -3
  47. package/dist/components/FlexibleTable/components/TableValue/index.d.ts +1 -0
  48. package/dist/components/FlexibleTable/components/index.d.ts +2 -0
  49. package/dist/components/FlexibleTable/constants.d.ts +1 -0
  50. package/dist/components/Icon/Icon.d.ts +3 -5
  51. package/dist/components/Icon/complexIcons/icons.d.ts +0 -1
  52. package/dist/components/Icon/components/ComplexIconBoilerplate/ComplexIconBoilerplate.d.ts +6 -0
  53. package/dist/components/Icon/components/ComplexIconBoilerplate/index.d.ts +1 -0
  54. package/dist/components/Icon/{IconBoilerplate.d.ts → components/IconBolerplate/IconBoilerplate.d.ts} +1 -1
  55. package/dist/components/Icon/components/IconBolerplate/index.d.ts +1 -0
  56. package/dist/components/Icon/components/index.d.ts +2 -0
  57. package/dist/components/Icon/helpers.d.ts +6 -0
  58. package/dist/components/Icon/icons-list.d.ts +1 -0
  59. package/dist/components/Icon/index.d.ts +2 -2
  60. package/dist/components/Icon/types.d.ts +12 -0
  61. package/dist/components/IncrementInput/{ChangeButton.d.ts → components/ChangeButton/ChangeButton.d.ts} +1 -2
  62. package/dist/components/IncrementInput/components/ChangeButton/index.d.ts +1 -0
  63. package/dist/components/IncrementInput/components/index.d.ts +1 -0
  64. package/dist/components/Input/Input.d.ts +2 -4
  65. package/dist/components/Input/constants.d.ts +1 -0
  66. package/dist/components/Input/index.d.ts +1 -0
  67. package/dist/components/Input/types.d.ts +2 -0
  68. package/dist/components/List/List.d.ts +3 -12
  69. package/dist/components/List/index.d.ts +1 -0
  70. package/dist/components/List/types.d.ts +12 -0
  71. package/dist/components/Modal/Modal.d.ts +1 -3
  72. package/dist/components/Modal/index.d.ts +1 -0
  73. package/dist/components/Modal/types.d.ts +3 -0
  74. package/dist/components/MultiSelect/MultiSelect.d.ts +2 -3
  75. package/dist/components/MultiSelect/{MultiSelectInput → components/MultiSelectInput}/MultiSelectInput.d.ts +2 -2
  76. package/dist/components/MultiSelect/{MultiSelectInput → components/MultiSelectInput}/MultiSelectInput.styles.d.ts +1 -1
  77. package/dist/components/MultiSelect/components/MultiSelectInput/index.d.ts +2 -0
  78. package/dist/components/MultiSelect/index.d.ts +2 -1
  79. package/dist/components/MultiSelect/types.d.ts +1 -0
  80. package/dist/components/MultiSelectList/MultiSelectList.d.ts +1 -4
  81. package/dist/components/MultiSelectList/constants.d.ts +3 -0
  82. package/dist/components/MultiSelectList/helpers.d.ts +3 -0
  83. package/dist/components/MultiSelectList/index.d.ts +1 -0
  84. package/dist/components/MultiSelectList/types.d.ts +12 -0
  85. package/dist/components/Notification/Notification.d.ts +1 -1
  86. package/dist/components/Notification/Notification.styles.d.ts +1 -1
  87. package/dist/components/Notification/index.d.ts +1 -0
  88. package/dist/components/Notification/types.d.ts +1 -0
  89. package/dist/components/PhoneInput/PhoneInput.d.ts +2 -2
  90. package/dist/components/PhoneInput/{PhoneInputCountryList → components/PhoneInputCountryList}/PhoneInputCountryList.d.ts +2 -3
  91. package/dist/components/PhoneInput/{PhoneInputCountryList → components/PhoneInputCountryList}/PhoneInputCountryList.styles.d.ts +1 -1
  92. package/dist/components/PhoneInput/components/PhoneInputCountryList/index.d.ts +2 -0
  93. package/dist/components/PhoneInput/components/index.d.ts +1 -0
  94. package/dist/components/PhoneInput/constants.d.ts +2 -0
  95. package/dist/components/PhoneInput/index.d.ts +2 -2
  96. package/dist/components/ScrollIntoViewIfNeeded/ScrollIntoViewIfNeeded.d.ts +2 -2
  97. package/dist/components/ScrollIntoViewIfNeeded/constants.d.ts +3 -0
  98. package/dist/components/SearchInput/SearchInput.d.ts +1 -1
  99. package/dist/components/Select/{SelectList → components/SelectList}/SelectList.d.ts +1 -1
  100. package/dist/components/Select/{SelectList → components/SelectList}/SelectList.styles.d.ts +1 -1
  101. package/dist/components/Select/components/SelectList/index.d.ts +2 -0
  102. package/dist/components/Select/{SelectListItem → components/SelectListItem}/SelectListItem.styles.d.ts +1 -1
  103. package/dist/components/Select/components/SelectListItem/index.d.ts +1 -0
  104. package/dist/components/Select/components/index.d.ts +2 -0
  105. package/dist/components/Select/index.d.ts +2 -2
  106. package/dist/components/SmartInput/SmartInput.d.ts +3 -15
  107. package/dist/components/SmartInput/constants.d.ts +18 -0
  108. package/dist/components/SmartInput/helpers.d.ts +1 -7
  109. package/dist/components/SmartInput/index.d.ts +1 -0
  110. package/dist/components/SmartInput/types.d.ts +1 -0
  111. package/dist/components/Switch/Switch.d.ts +1 -4
  112. package/dist/components/Switch/index.d.ts +1 -0
  113. package/dist/components/Switch/types.d.ts +4 -0
  114. package/dist/components/TextArea/TextArea.d.ts +5 -5
  115. package/dist/components/TextWithTooltip/TextWithTooltip.d.ts +2 -2
  116. package/dist/components/ThemedPreloader/ThemedPreloader.d.ts +1 -3
  117. package/dist/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.d.ts +1 -1
  118. package/dist/components/ThemedPreloader/components/index.d.ts +3 -2
  119. package/dist/components/ThemedPreloader/constants.d.ts +1 -0
  120. package/dist/components/ThemedPreloader/index.d.ts +2 -0
  121. package/dist/components/ThemedPreloader/types.d.ts +2 -0
  122. package/dist/components/Toaster/Toaster.d.ts +1 -1
  123. package/dist/components/Toaster/constants.d.ts +1 -0
  124. package/dist/components/Toaster/index.d.ts +1 -0
  125. package/dist/components/Toaster/types.d.ts +1 -0
  126. package/dist/components/Tooltip/index.d.ts +1 -1
  127. package/dist/true-react-common-ui-kit.js +1246 -1193
  128. package/dist/true-react-common-ui-kit.js.map +1 -1
  129. package/dist/true-react-common-ui-kit.umd.cjs +1245 -1192
  130. package/dist/true-react-common-ui-kit.umd.cjs.map +1 -1
  131. package/dist/types.d.ts +1 -1
  132. package/package.json +93 -93
  133. package/src/components/AccountInfo/AccountInfo.stories.tsx +32 -32
  134. package/src/components/AccountInfo/AccountInfo.tsx +76 -77
  135. package/src/components/AccountInfo/constants.ts +1 -0
  136. package/src/components/AddButton/AddButton.tsx +48 -48
  137. package/src/components/Button/Button.stories.tsx +56 -52
  138. package/src/components/Button/Button.tsx +154 -167
  139. package/src/components/Button/constants.ts +9 -0
  140. package/src/components/Button/index.ts +3 -2
  141. package/src/components/Button/types.ts +5 -0
  142. package/src/components/Checkbox/Checkbox.stories.tsx +32 -32
  143. package/src/components/Checkbox/Checkbox.tsx +105 -105
  144. package/src/components/CloseButton/CloseButton.styles.ts +34 -34
  145. package/src/components/CloseButton/CloseButton.tsx +35 -35
  146. package/src/components/Colors/Colors.tsx +26 -26
  147. package/src/components/CssBaseline/CssBaseline.tsx +15 -15
  148. package/src/components/DateInput/DateInput.stories.tsx +61 -61
  149. package/src/components/DateInput/DateInput.tsx +82 -82
  150. package/src/components/DatePicker/DatePicker.stories.tsx +87 -87
  151. package/src/components/DatePicker/DatePicker.styles.ts +44 -44
  152. package/src/components/DatePicker/DatePicker.tsx +309 -327
  153. package/src/components/DatePicker/{DatePickerHeader → components/DatePickerHeader}/DatePickerHeader.styles.ts +84 -84
  154. package/src/components/DatePicker/{DatePickerHeader → components/DatePickerHeader}/DatePickerHeader.tsx +79 -79
  155. package/src/components/DatePicker/{DatePickerHeader → components/DatePickerHeader}/index.ts +2 -2
  156. package/src/components/DatePicker/components/PopperContainer/PopperContainer.tsx +6 -0
  157. package/src/components/DatePicker/components/PopperContainer/index.ts +1 -0
  158. package/src/components/DatePicker/components/index.ts +2 -0
  159. package/src/components/DatePicker/constants.ts +6 -1
  160. package/src/components/DatePicker/helpers.ts +23 -23
  161. package/src/components/DatePicker/index.ts +4 -3
  162. package/src/components/DatePicker/types.ts +45 -45
  163. package/src/components/Description/Description.stories.tsx +27 -27
  164. package/src/components/Description/Description.tsx +59 -60
  165. package/src/components/Description/constants.ts +1 -0
  166. package/src/components/FiltersPane/FiltersPane.stories.tsx +295 -295
  167. package/src/components/FiltersPane/FiltersPane.tsx +150 -151
  168. package/src/components/FiltersPane/{FilterWrapper/FilterWrapper.tsx → components/Filter/Filter.tsx} +203 -346
  169. package/src/components/FiltersPane/components/Filter/index.ts +1 -0
  170. package/src/components/FiltersPane/{FilterInterval → components/FilterInterval}/FilterInterval.styles.ts +64 -64
  171. package/src/components/FiltersPane/{FilterInterval → components/FilterInterval}/FilterInterval.tsx +141 -143
  172. package/src/components/FiltersPane/components/FilterInterval/index.ts +2 -0
  173. package/src/components/FiltersPane/{FilterMultiSelect → components/FilterMultiSelect}/FilterMultiSelect.tsx +10 -10
  174. package/src/components/FiltersPane/{FilterMultiSelect → components/FilterMultiSelect}/index.ts +1 -1
  175. package/src/components/FiltersPane/{FilterSelect → components/FilterSelect}/FilterSelect.styles.ts +143 -143
  176. package/src/components/FiltersPane/{FilterSelect → components/FilterSelect}/FilterSelect.tsx +346 -348
  177. package/src/components/FiltersPane/components/FilterSelect/index.ts +2 -0
  178. package/src/components/FiltersPane/{FilterValueView → components/FilterValueView}/FilterValueView.styles.tsx +15 -15
  179. package/src/components/FiltersPane/{FilterValueView → components/FilterValueView}/FilterValueView.tsx +163 -166
  180. package/src/components/FiltersPane/components/FilterValueView/index.tsx +2 -0
  181. package/src/components/FiltersPane/{FilterWithDates → components/FilterWithDates}/FilterWithDates.styles.ts +60 -60
  182. package/src/components/FiltersPane/{FilterWithDates → components/FilterWithDates}/FilterWithDates.tsx +181 -184
  183. package/src/components/FiltersPane/components/FilterWithDates/index.ts +2 -0
  184. package/src/components/FiltersPane/{FilterWithPeriod → components/FilterWithPeriod}/FilterWithPeriod.styles.ts +17 -17
  185. package/src/components/FiltersPane/{FilterWithPeriod → components/FilterWithPeriod}/FilterWithPeriod.tsx +174 -198
  186. package/src/components/FiltersPane/components/FilterWithPeriod/index.ts +2 -0
  187. package/src/components/FiltersPane/{FilterWrapper → components/FilterWrapper}/FilterWrapper.styles.ts +110 -110
  188. package/src/components/FiltersPane/components/FilterWrapper/FilterWrapper.tsx +149 -0
  189. package/src/components/FiltersPane/components/FilterWrapper/index.ts +2 -0
  190. package/src/components/FiltersPane/{FiltersPaneSearch → components/FiltersPaneSearch}/FiltersPaneSearch.styles.ts +109 -109
  191. package/src/components/FiltersPane/{FiltersPaneSearch → components/FiltersPaneSearch}/FiltersPaneSearch.tsx +155 -155
  192. package/src/components/FiltersPane/components/FiltersPaneSearch/index.ts +2 -0
  193. package/src/components/FiltersPane/components/index.ts +9 -0
  194. package/src/components/FiltersPane/constants.ts +137 -0
  195. package/src/components/FiltersPane/helpers.ts +26 -0
  196. package/src/components/FiltersPane/index.ts +5 -20
  197. package/src/components/FiltersPane/types.ts +156 -112
  198. package/src/components/Flag/Flag.stories.tsx +29 -29
  199. package/src/components/Flag/Flag.tsx +27 -27
  200. package/src/components/FlexibleTable/FlexibleTable.stories.tsx +338 -84
  201. package/src/components/FlexibleTable/FlexibleTable.styles.ts +131 -131
  202. package/src/components/FlexibleTable/FlexibleTable.tsx +205 -205
  203. package/src/components/FlexibleTable/{TableRow.tsx → components/TableRow/TableRow.tsx} +152 -152
  204. package/src/components/FlexibleTable/components/TableRow/index.ts +1 -0
  205. package/src/components/FlexibleTable/{TableValue.tsx → components/TableValue/TableValue.tsx} +74 -75
  206. package/src/components/FlexibleTable/components/TableValue/index.ts +1 -0
  207. package/src/components/FlexibleTable/components/index.ts +2 -0
  208. package/src/components/FlexibleTable/constants.ts +1 -0
  209. package/src/components/FlexibleTable/types.ts +52 -52
  210. package/src/components/Icon/Icon.stories.tsx +86 -85
  211. package/src/components/Icon/Icon.tsx +27 -32
  212. package/src/components/Icon/complexIcons/icons.ts +5 -7
  213. package/src/components/Icon/{ComplexIconBoilerplate.tsx → components/ComplexIconBoilerplate/ComplexIconBoilerplate.tsx} +16 -17
  214. package/src/components/Icon/components/ComplexIconBoilerplate/index.ts +1 -0
  215. package/src/components/Icon/{IconBoilerplate.tsx → components/IconBolerplate/IconBoilerplate.tsx} +43 -42
  216. package/src/components/Icon/components/IconBolerplate/index.ts +1 -0
  217. package/src/components/Icon/components/index.ts +2 -0
  218. package/src/components/Icon/helpers.ts +9 -0
  219. package/src/components/Icon/{icons/icons.ts → icons-list.ts} +826 -838
  220. package/src/components/Icon/index.ts +4 -4
  221. package/src/components/Icon/types.ts +16 -0
  222. package/src/components/IncrementInput/IncrementInput.stories.tsx +31 -31
  223. package/src/components/IncrementInput/IncrementInput.tsx +80 -80
  224. package/src/components/IncrementInput/{ChangeButton.tsx → components/ChangeButton/ChangeButton.tsx} +33 -33
  225. package/src/components/IncrementInput/components/ChangeButton/index.ts +1 -0
  226. package/src/components/IncrementInput/components/index.ts +1 -0
  227. package/src/components/Input/Input.stories.tsx +86 -86
  228. package/src/components/Input/Input.tsx +308 -311
  229. package/src/components/Input/constants.ts +1 -0
  230. package/src/components/Input/index.ts +3 -2
  231. package/src/components/Input/types.ts +6 -0
  232. package/src/components/List/List.stories.tsx +63 -62
  233. package/src/components/List/List.tsx +54 -64
  234. package/src/components/List/index.ts +3 -2
  235. package/src/components/List/types.ts +13 -0
  236. package/src/components/Modal/Modal.stories.tsx +105 -105
  237. package/src/components/Modal/Modal.styles.ts +305 -305
  238. package/src/components/Modal/Modal.tsx +184 -200
  239. package/src/components/Modal/index.ts +3 -2
  240. package/src/components/Modal/types.ts +17 -0
  241. package/src/components/MoreMenu/MoreMenu.styles.ts +70 -70
  242. package/src/components/MoreMenu/MoreMenu.tsx +90 -90
  243. package/src/components/MultiSelect/MultiSelect.stories.tsx +46 -46
  244. package/src/components/MultiSelect/MultiSelect.tsx +92 -89
  245. package/src/components/MultiSelect/{MultiSelectInput → components/MultiSelectInput}/MultiSelectInput.styles.ts +73 -73
  246. package/src/components/MultiSelect/{MultiSelectInput → components/MultiSelectInput}/MultiSelectInput.tsx +51 -51
  247. package/src/components/MultiSelect/components/MultiSelectInput/index.ts +2 -0
  248. package/src/components/MultiSelect/{MultiSelectInput → components}/index.ts +1 -1
  249. package/src/components/MultiSelect/index.ts +4 -3
  250. package/src/components/MultiSelect/types.ts +1 -0
  251. package/src/components/MultiSelectList/MultiSelectList.styles.ts +124 -124
  252. package/src/components/MultiSelectList/MultiSelectList.tsx +441 -451
  253. package/src/components/MultiSelectList/constants.ts +21 -0
  254. package/src/components/MultiSelectList/helpers.ts +11 -0
  255. package/src/components/MultiSelectList/index.ts +3 -2
  256. package/src/components/MultiSelectList/types.ts +15 -0
  257. package/src/components/Notification/Notification.stories.tsx +46 -46
  258. package/src/components/Notification/Notification.styles.ts +50 -50
  259. package/src/components/Notification/Notification.tsx +78 -79
  260. package/src/components/Notification/index.ts +3 -2
  261. package/src/components/Notification/types.ts +1 -0
  262. package/src/components/NumberInput/NumberInput.stories.tsx +35 -35
  263. package/src/components/NumberInput/NumberInput.tsx +133 -133
  264. package/src/components/NumberInput/helpers.ts +86 -86
  265. package/src/components/PhoneInput/PhoneInput.stories.tsx +70 -70
  266. package/src/components/PhoneInput/PhoneInput.tsx +193 -194
  267. package/src/components/PhoneInput/{PhoneInputCountryList → components/PhoneInputCountryList}/PhoneInputCountryList.stories.tsx +21 -21
  268. package/src/components/PhoneInput/{PhoneInputCountryList → components/PhoneInputCountryList}/PhoneInputCountryList.styles.ts +100 -100
  269. package/src/components/PhoneInput/{PhoneInputCountryList → components/PhoneInputCountryList}/PhoneInputCountryList.tsx +145 -147
  270. package/src/components/PhoneInput/components/PhoneInputCountryList/index.ts +2 -0
  271. package/src/components/PhoneInput/components/index.ts +1 -0
  272. package/src/components/PhoneInput/constants.ts +3 -0
  273. package/src/components/PhoneInput/index.ts +5 -6
  274. package/src/components/PhoneInput/phone-info.ts +2147 -2147
  275. package/src/components/RadioButton/RadioButton.stories.tsx +46 -46
  276. package/src/components/RadioButton/RadioButton.tsx +55 -55
  277. package/src/components/ScrollIntoViewIfNeeded/ScrollIntoViewIfNeeded.ts +54 -61
  278. package/src/components/ScrollIntoViewIfNeeded/constants.ts +12 -0
  279. package/src/components/SearchInput/SearchInput.stories.tsx +23 -23
  280. package/src/components/SearchInput/SearchInput.styles.ts +50 -50
  281. package/src/components/SearchInput/SearchInput.tsx +51 -50
  282. package/src/components/Select/MultiSelect.stories.tsx +240 -240
  283. package/src/components/Select/Select.stories.tsx +235 -235
  284. package/src/components/Select/Select.tsx +575 -575
  285. package/src/components/Select/{SelectList → components/SelectList}/SelectList.styles.ts +72 -72
  286. package/src/components/Select/{SelectList → components/SelectList}/SelectList.tsx +158 -158
  287. package/src/components/Select/components/SelectList/index.ts +2 -0
  288. package/src/components/Select/{SelectListItem → components/SelectListItem}/SelectListItem.styles.ts +14 -14
  289. package/src/components/Select/{SelectListItem → components/SelectListItem}/SelectListItem.tsx +68 -68
  290. package/src/components/Select/components/SelectListItem/index.ts +1 -0
  291. package/src/components/Select/components/index.ts +2 -0
  292. package/src/components/Select/helpers.ts +26 -26
  293. package/src/components/Select/index.ts +4 -4
  294. package/src/components/SmartInput/SmartInput.stories.tsx +51 -50
  295. package/src/components/SmartInput/SmartInput.tsx +124 -147
  296. package/src/components/SmartInput/constants.ts +84 -0
  297. package/src/components/SmartInput/helpers.ts +13 -85
  298. package/src/components/SmartInput/index.ts +2 -1
  299. package/src/components/SmartInput/types.ts +11 -0
  300. package/src/components/Switch/Switch.stories.tsx +40 -40
  301. package/src/components/Switch/Switch.tsx +79 -83
  302. package/src/components/Switch/index.ts +3 -2
  303. package/src/components/Switch/types.ts +4 -0
  304. package/src/components/TextArea/TextArea.stories.tsx +35 -35
  305. package/src/components/TextArea/TextArea.tsx +174 -165
  306. package/src/components/TextWithInfo/TextWithInfo.stories.tsx +53 -53
  307. package/src/components/TextWithInfo/TextWithInfo.tsx +60 -60
  308. package/src/components/TextWithTooltip/TextWithTooltip.tsx +143 -143
  309. package/src/components/ThemedPreloader/ThemedPreloader.stories.tsx +41 -41
  310. package/src/components/ThemedPreloader/ThemedPreloader.tsx +47 -50
  311. package/src/components/ThemedPreloader/components/DefaultPreloader/DefaultPreloader.tsx +29 -29
  312. package/src/components/ThemedPreloader/components/DotsPreloader/DotsPreloader.tsx +18 -18
  313. package/src/components/ThemedPreloader/components/SvgPreloader/SvgPreloader.tsx +25 -25
  314. package/src/components/ThemedPreloader/components/index.ts +3 -2
  315. package/src/components/ThemedPreloader/constants.ts +1 -0
  316. package/src/components/ThemedPreloader/index.ts +4 -2
  317. package/src/components/ThemedPreloader/types.ts +3 -0
  318. package/src/components/Toaster/Toaster.stories.tsx +30 -30
  319. package/src/components/Toaster/Toaster.tsx +108 -110
  320. package/src/components/Toaster/constants.ts +1 -0
  321. package/src/components/Toaster/index.ts +3 -2
  322. package/src/components/Toaster/types.ts +1 -0
  323. package/src/components/Tooltip/Tooltip.stories.tsx +19 -19
  324. package/src/components/Tooltip/Tooltip.styles.ts +45 -45
  325. package/src/components/Tooltip/Tooltip.tsx +35 -35
  326. package/src/components/Tooltip/index.ts +3 -3
  327. package/src/helpers/deprecated.ts +23 -23
  328. package/src/helpers/index.ts +4 -4
  329. package/src/helpers/misc.ts +158 -158
  330. package/src/helpers/phone.ts +87 -87
  331. package/src/helpers/snippets.tsx +6 -6
  332. package/src/hooks/use-did-mount-effect.ts +18 -18
  333. package/src/hooks/use-dropdown.ts +82 -82
  334. package/src/hooks/use-on-click-outside.ts +77 -77
  335. package/src/hooks/use-theme.ts +32 -32
  336. package/src/hooks/use-tweak-styles.ts +13 -13
  337. package/src/theme.ts +149 -149
  338. package/src/types.ts +108 -107
  339. package/dist/components/FiltersPane/FilterInterval/index.d.ts +0 -1
  340. package/dist/components/FiltersPane/FilterSelect/index.d.ts +0 -1
  341. package/dist/components/FiltersPane/FilterSelect/locales.d.ts +0 -11
  342. package/dist/components/FiltersPane/FilterValueView/index.d.ts +0 -1
  343. package/dist/components/FiltersPane/FilterWithDates/index.d.ts +0 -1
  344. package/dist/components/FiltersPane/FilterWithPeriod/index.d.ts +0 -1
  345. package/dist/components/FiltersPane/FilterWrapper/FilterWrapper.d.ts +0 -27
  346. package/dist/components/FiltersPane/FilterWrapper/index.d.ts +0 -1
  347. package/dist/components/FiltersPane/FiltersPaneSearch/index.d.ts +0 -1
  348. package/dist/components/FiltersPane/locales.d.ts +0 -28
  349. package/dist/components/Icon/ComplexIconBoilerplate.d.ts +0 -7
  350. package/dist/components/Icon/icons/icons.d.ts +0 -9
  351. package/dist/components/Icon/icons/index.d.ts +0 -1
  352. package/dist/components/MultiSelectList/locales.d.ts +0 -11
  353. package/dist/components/PhoneInput/PhoneInputCountryList/index.d.ts +0 -2
  354. package/dist/components/Select/SelectList/index.d.ts +0 -1
  355. package/src/components/FiltersPane/FilterInterval/index.ts +0 -1
  356. package/src/components/FiltersPane/FilterSelect/index.ts +0 -1
  357. package/src/components/FiltersPane/FilterSelect/locales.ts +0 -37
  358. package/src/components/FiltersPane/FilterValueView/index.tsx +0 -1
  359. package/src/components/FiltersPane/FilterWithDates/index.ts +0 -1
  360. package/src/components/FiltersPane/FilterWithPeriod/index.ts +0 -1
  361. package/src/components/FiltersPane/FilterWrapper/index.ts +0 -1
  362. package/src/components/FiltersPane/FiltersPaneSearch/index.ts +0 -1
  363. package/src/components/FiltersPane/locales.ts +0 -107
  364. package/src/components/FlexibleTable/fixture-test.ts +0 -254
  365. package/src/components/Icon/icons/index.ts +0 -1
  366. package/src/components/MultiSelectList/locales.ts +0 -37
  367. package/src/components/PhoneInput/PhoneInputCountryList/index.ts +0 -2
  368. package/src/components/Select/SelectList/index.ts +0 -1
  369. /package/dist/components/DatePicker/{DatePickerHeader → components/DatePickerHeader}/DatePickerHeader.d.ts +0 -0
  370. /package/dist/components/DatePicker/{DatePickerHeader → components/DatePickerHeader}/index.d.ts +0 -0
  371. /package/dist/components/FiltersPane/{FilterMultiSelect → components/FilterMultiSelect}/index.d.ts +0 -0
  372. /package/dist/components/FiltersPane/{FilterValueView → components/FilterValueView}/FilterValueView.d.ts +0 -0
  373. /package/dist/components/MultiSelect/{MultiSelectInput → components}/index.d.ts +0 -0
  374. /package/dist/components/Select/{SelectListItem → components/SelectListItem}/SelectListItem.d.ts +0 -0
@@ -1,158 +1,158 @@
1
- import hexToRgba from 'hex-to-rgba';
2
- import {
3
- isNotEmpty,
4
- isString,
5
- isStringNotEmpty,
6
- } from '@true-engineering/true-react-platform-helpers';
7
- import { IDataAttributes } from '../types';
8
-
9
- export const rgba = hexToRgba;
10
-
11
- export const transformToKebab = (string: string): string => {
12
- let result = '';
13
- string.split('').forEach((char) => {
14
- if (char.toLowerCase() === char) {
15
- result += char;
16
- } else {
17
- result += `-${char.toLowerCase()}`;
18
- }
19
- });
20
-
21
- return result;
22
- };
23
-
24
- export const hasExactParent = (element: Element, parent: Element): boolean => {
25
- if (element === parent) {
26
- return true; // Found the exact parent
27
- }
28
-
29
- const parentNode = getParentNode(element);
30
-
31
- if (parentNode === element) {
32
- return false; // Reached the top-level HTML element or Shadow DOM host
33
- }
34
-
35
- return hasExactParent(parentNode, parent);
36
- };
37
-
38
- export const getParentNode = (element: Element | ShadowRoot | Document): Element =>
39
- element.nodeName === 'HTML' || element === document
40
- ? (element as Element)
41
- : (element.parentNode as Element) ?? (element as ShadowRoot).host;
42
-
43
- export const getStyleComputedProperty = (element: Element): Partial<CSSStyleDeclaration> =>
44
- element.nodeType !== 1 ? {} : getComputedStyle(element, null);
45
-
46
- export const getScrollParent = (element: Element | Document): Element => {
47
- if (!element) {
48
- return document.body;
49
- }
50
-
51
- switch (element.nodeName) {
52
- case 'HTML':
53
- case 'BODY':
54
- return (element as Element).ownerDocument.body;
55
- case '#document':
56
- return (element as Document).body;
57
- }
58
-
59
- const { overflow, overflowX, overflowY } = getStyleComputedProperty(element as Element) ?? {};
60
- if (/(auto|scroll|overlay)/.test((overflow ?? '') + (overflowY ?? '') + (overflowX ?? ''))) {
61
- return element as Element;
62
- }
63
- return getScrollParent(getParentNode(element as Element));
64
- };
65
-
66
- export const isElementOffScreen = (element: HTMLElement, input?: HTMLElement): boolean => {
67
- const el = element;
68
- const scrollParent = getScrollParent(element);
69
-
70
- const { scrollHeight: scrollHeightWithElement } = scrollParent;
71
- el.hidden = true;
72
- const { scrollHeight: scrollHeightWithoutElement } = scrollParent;
73
- el.hidden = false;
74
-
75
- const isOffscreen = scrollHeightWithElement !== scrollHeightWithoutElement;
76
-
77
- if (isOffscreen && input !== undefined) {
78
- const elRect = el.getBoundingClientRect();
79
- const scrollParentRect = scrollParent.getBoundingClientRect();
80
- const topOffset = elRect.top - scrollParentRect.top;
81
- if (input.clientHeight + el.clientHeight > topOffset) {
82
- return false;
83
- }
84
- }
85
-
86
- return isOffscreen;
87
- };
88
-
89
- export const getNumberInRange = (value: number, min = -Infinity, max = Infinity): number =>
90
- Math.min(max, Math.max(min, value));
91
-
92
- const DEFAULT_THOUSANDS_SEPARATOR = '\u2009';
93
-
94
- export const formatStringNumber = (
95
- val?: string,
96
- separator = DEFAULT_THOUSANDS_SEPARATOR,
97
- ): string => {
98
- if (val === undefined) {
99
- return '';
100
- }
101
- const parts = val.split('.');
102
-
103
- parts[0] = parts[0]
104
- // убрать лидирующие нули
105
- .replace(/^0+(?=\d)/, '')
106
- // проставить сепараторы тысяч
107
- .replace(/\B(?=(\d{3})+(?!\d))/g, separator);
108
- return (parts[1] ?? '').length > 0 ? parts.join('.') : parts[0];
109
- };
110
-
111
- export const formatNumber = (val?: number, separator = DEFAULT_THOUSANDS_SEPARATOR): string => {
112
- if (val === undefined || isNaN(val)) {
113
- return '';
114
- }
115
- return formatStringNumber(String(val), separator);
116
- };
117
-
118
- export const removeStringFormat = (val?: string): string =>
119
- (val ?? '').replace(',', '.').replace(/\s/g, '');
120
-
121
- export const stringToNumber = (val?: string): number | undefined => {
122
- const trimmed = removeStringFormat(val);
123
- if (trimmed === '') {
124
- return undefined;
125
- }
126
- const num = Number(trimmed);
127
- return isNaN(num) ? undefined : num;
128
- };
129
-
130
- export const setCaretPosition = (elem: HTMLInputElement, caretPos: number | null): void => {
131
- if (caretPos === null || elem === null) {
132
- return;
133
- }
134
- if (elem.selectionStart) {
135
- elem.focus();
136
- elem.setSelectionRange(caretPos, caretPos);
137
- } else {
138
- elem.focus();
139
- }
140
- };
141
-
142
- export const isSpaceChar = (char?: string): boolean =>
143
- char !== undefined && char.match(/\s/) !== null;
144
-
145
- export const getNumberLength = (n?: number): number =>
146
- n === undefined || isNaN(n) ? 0 : n.toString().length;
147
-
148
- export const trimStringToMaxLength = (val: string, maxLength: number) =>
149
- val.length > maxLength ? val.slice(0, maxLength) : val;
150
-
151
- export const addDataAttributes = (data: IDataAttributes = {}): IDataAttributes =>
152
- Object.fromEntries(
153
- Object.entries(data).map(([key, value]) =>
154
- (isString(value) && isStringNotEmpty(value)) || isNotEmpty(value)
155
- ? [`data-${transformToKebab(key)}`, value]
156
- : [],
157
- ),
158
- );
1
+ import hexToRgba from 'hex-to-rgba';
2
+ import {
3
+ isNotEmpty,
4
+ isString,
5
+ isStringNotEmpty,
6
+ } from '@true-engineering/true-react-platform-helpers';
7
+ import { IDataAttributes } from '../types';
8
+
9
+ export const rgba = hexToRgba;
10
+
11
+ export const transformToKebab = (string: string): string => {
12
+ let result = '';
13
+ string.split('').forEach((char) => {
14
+ if (char.toLowerCase() === char) {
15
+ result += char;
16
+ } else {
17
+ result += `-${char.toLowerCase()}`;
18
+ }
19
+ });
20
+
21
+ return result;
22
+ };
23
+
24
+ export const hasExactParent = (element: Element, parent: Element): boolean => {
25
+ if (element === parent) {
26
+ return true; // Found the exact parent
27
+ }
28
+
29
+ const parentNode = getParentNode(element);
30
+
31
+ if (parentNode === element) {
32
+ return false; // Reached the top-level HTML element or Shadow DOM host
33
+ }
34
+
35
+ return hasExactParent(parentNode, parent);
36
+ };
37
+
38
+ export const getParentNode = (element: Element | ShadowRoot | Document): Element =>
39
+ element.nodeName === 'HTML' || element === document
40
+ ? (element as Element)
41
+ : (element.parentNode as Element) ?? (element as ShadowRoot).host;
42
+
43
+ export const getStyleComputedProperty = (element: Element): Partial<CSSStyleDeclaration> =>
44
+ element.nodeType !== 1 ? {} : getComputedStyle(element, null);
45
+
46
+ export const getScrollParent = (element: Element | Document): Element => {
47
+ if (!element) {
48
+ return document.body;
49
+ }
50
+
51
+ switch (element.nodeName) {
52
+ case 'HTML':
53
+ case 'BODY':
54
+ return (element as Element).ownerDocument.body;
55
+ case '#document':
56
+ return (element as Document).body;
57
+ }
58
+
59
+ const { overflow, overflowX, overflowY } = getStyleComputedProperty(element as Element) ?? {};
60
+ if (/(auto|scroll|overlay)/.test((overflow ?? '') + (overflowY ?? '') + (overflowX ?? ''))) {
61
+ return element as Element;
62
+ }
63
+ return getScrollParent(getParentNode(element as Element));
64
+ };
65
+
66
+ export const isElementOffScreen = (element: HTMLElement, input?: HTMLElement): boolean => {
67
+ const el = element;
68
+ const scrollParent = getScrollParent(element);
69
+
70
+ const { scrollHeight: scrollHeightWithElement } = scrollParent;
71
+ el.hidden = true;
72
+ const { scrollHeight: scrollHeightWithoutElement } = scrollParent;
73
+ el.hidden = false;
74
+
75
+ const isOffscreen = scrollHeightWithElement !== scrollHeightWithoutElement;
76
+
77
+ if (isOffscreen && input !== undefined) {
78
+ const elRect = el.getBoundingClientRect();
79
+ const scrollParentRect = scrollParent.getBoundingClientRect();
80
+ const topOffset = elRect.top - scrollParentRect.top;
81
+ if (input.clientHeight + el.clientHeight > topOffset) {
82
+ return false;
83
+ }
84
+ }
85
+
86
+ return isOffscreen;
87
+ };
88
+
89
+ export const getNumberInRange = (value: number, min = -Infinity, max = Infinity): number =>
90
+ Math.min(max, Math.max(min, value));
91
+
92
+ const DEFAULT_THOUSANDS_SEPARATOR = '\u2009';
93
+
94
+ export const formatStringNumber = (
95
+ val?: string,
96
+ separator = DEFAULT_THOUSANDS_SEPARATOR,
97
+ ): string => {
98
+ if (val === undefined) {
99
+ return '';
100
+ }
101
+ const parts = val.split('.');
102
+
103
+ parts[0] = parts[0]
104
+ // убрать лидирующие нули
105
+ .replace(/^0+(?=\d)/, '')
106
+ // проставить сепараторы тысяч
107
+ .replace(/\B(?=(\d{3})+(?!\d))/g, separator);
108
+ return (parts[1] ?? '').length > 0 ? parts.join('.') : parts[0];
109
+ };
110
+
111
+ export const formatNumber = (val?: number, separator = DEFAULT_THOUSANDS_SEPARATOR): string => {
112
+ if (val === undefined || isNaN(val)) {
113
+ return '';
114
+ }
115
+ return formatStringNumber(String(val), separator);
116
+ };
117
+
118
+ export const removeStringFormat = (val?: string): string =>
119
+ (val ?? '').replace(',', '.').replace(/\s/g, '');
120
+
121
+ export const stringToNumber = (val?: string): number | undefined => {
122
+ const trimmed = removeStringFormat(val);
123
+ if (trimmed === '') {
124
+ return undefined;
125
+ }
126
+ const num = Number(trimmed);
127
+ return isNaN(num) ? undefined : num;
128
+ };
129
+
130
+ export const setCaretPosition = (elem: HTMLInputElement, caretPos: number | null): void => {
131
+ if (caretPos === null || elem === null) {
132
+ return;
133
+ }
134
+ if (elem.selectionStart) {
135
+ elem.focus();
136
+ elem.setSelectionRange(caretPos, caretPos);
137
+ } else {
138
+ elem.focus();
139
+ }
140
+ };
141
+
142
+ export const isSpaceChar = (char?: string): boolean =>
143
+ char !== undefined && char.match(/\s/) !== null;
144
+
145
+ export const getNumberLength = (n?: number): number =>
146
+ n === undefined || isNaN(n) ? 0 : n.toString().length;
147
+
148
+ export const trimStringToMaxLength = (val: string, maxLength: number) =>
149
+ val.length > maxLength ? val.slice(0, maxLength) : val;
150
+
151
+ export const addDataAttributes = (data: IDataAttributes = {}): IDataAttributes =>
152
+ Object.fromEntries(
153
+ Object.entries(data).map(([key, value]) =>
154
+ (isString(value) && isStringNotEmpty(value)) || isNotEmpty(value)
155
+ ? [`data-${transformToKebab(key)}`, value]
156
+ : [],
157
+ ),
158
+ );
@@ -1,87 +1,87 @@
1
- import { isNotEmpty, isEmpty } from '@true-engineering/true-react-platform-helpers';
2
- import { phoneInfo, IPhoneInfo, IPhoneValue } from '../components';
3
-
4
- export const findCountryByCode = (
5
- countryCode?: string,
6
- countriesList = phoneInfo,
7
- ): IPhoneInfo | undefined =>
8
- isNotEmpty(countryCode)
9
- ? countriesList.find((info) => info.countryCode === countryCode)
10
- : undefined;
11
-
12
- export const findCountryIndexByCode = (countryCode?: string, countriesList = phoneInfo): number =>
13
- isNotEmpty(countryCode)
14
- ? countriesList.findIndex((info) => info.countryCode === countryCode)
15
- : -1;
16
-
17
- export const getCountryTextByLocale = (country: IPhoneInfo, locale: string): string =>
18
- locale.toLowerCase() === 'ru' ? country.countryRu : country.countryEn;
19
-
20
- export const sortCountriesByLocale = (countriesList: IPhoneInfo[], locale: string) =>
21
- countriesList.sort((countryA, countryB) =>
22
- getCountryTextByLocale(countryA, locale).localeCompare(
23
- getCountryTextByLocale(countryB, locale),
24
- ),
25
- );
26
-
27
- export const checkSearchStringInCountry = (country: IPhoneInfo, searchString: string): boolean => {
28
- const checkValue = searchString.toLowerCase().trim().replace('+', '');
29
-
30
- const possibleValues = [
31
- country.countryRu,
32
- country.countryEn,
33
- ...country.countryRu.split(' '),
34
- ...country.countryEn.split(' '),
35
- country.dialCode,
36
- ].map((part) => part.toLowerCase());
37
-
38
- return possibleValues.some((v) => v.startsWith(checkValue));
39
- };
40
-
41
- export const getFullPhone = (phone?: IPhoneValue): string =>
42
- (phone?.dialCode ?? '') + (phone?.phoneNumber ?? '');
43
-
44
- export const getCountryCodeFromPhone = (phoneWithCode: string): string | undefined => {
45
- // попробуем найти уникальный код страны fullCode (dialCode + arealCode)
46
- let countryCode = phoneInfo.find((info) =>
47
- info.fullCodes.some((code) => phoneWithCode.startsWith(code)),
48
- )?.countryCode;
49
-
50
- if (isEmpty(countryCode) && isNotEmpty(phoneWithCode)) {
51
- // если не нашли уникальный fullCode (dialCode + arealCode),
52
- // то пробуем найти dialCode и выбираем с наименьшим Priority
53
- countryCode = phoneInfo
54
- .filter((info) => phoneWithCode.startsWith(info.dialCode))
55
- .sort(
56
- (infoA, infoB) => (infoA.dialCodePriority ?? 1000) - (infoB.dialCodePriority ?? 1000),
57
- )[0]?.countryCode;
58
- }
59
-
60
- return countryCode;
61
- };
62
-
63
- export const getPhoneObjFromString = (fullPhone: string, countryCode?: string): IPhoneValue => {
64
- const newCountryCode = countryCode ?? getCountryCodeFromPhone(fullPhone);
65
- const dialCode = findCountryByCode(newCountryCode)?.dialCode;
66
- const phoneNumber = fullPhone.slice(dialCode?.length);
67
-
68
- return { dialCode, phoneNumber, countryCode: newCountryCode };
69
- };
70
-
71
- export const DEFAULT_PHONE_MASK = '+ 9 999 999 999 999 99';
72
-
73
- export const getPhoneMask = (countryCode?: string): string => {
74
- let mask = DEFAULT_PHONE_MASK;
75
- if (isNotEmpty(countryCode)) {
76
- const countrySettings = findCountryByCode(countryCode);
77
-
78
- if (countrySettings !== undefined) {
79
- const dialCodeLength = countrySettings.dialCode.length;
80
- const areaAndPhoneMask =
81
- countrySettings.phoneMask ?? mask.substring(2, mask.length - dialCodeLength);
82
- mask = `+ ${'9'.repeat(dialCodeLength)} ${areaAndPhoneMask}`;
83
- }
84
- }
85
-
86
- return mask;
87
- };
1
+ import { isNotEmpty, isEmpty } from '@true-engineering/true-react-platform-helpers';
2
+ import { phoneInfo, IPhoneInfo, IPhoneValue } from '../components';
3
+
4
+ export const findCountryByCode = (
5
+ countryCode?: string,
6
+ countriesList = phoneInfo,
7
+ ): IPhoneInfo | undefined =>
8
+ isNotEmpty(countryCode)
9
+ ? countriesList.find((info) => info.countryCode === countryCode)
10
+ : undefined;
11
+
12
+ export const findCountryIndexByCode = (countryCode?: string, countriesList = phoneInfo): number =>
13
+ isNotEmpty(countryCode)
14
+ ? countriesList.findIndex((info) => info.countryCode === countryCode)
15
+ : -1;
16
+
17
+ export const getCountryTextByLocale = (country: IPhoneInfo, locale: string): string =>
18
+ locale.toLowerCase() === 'ru' ? country.countryRu : country.countryEn;
19
+
20
+ export const sortCountriesByLocale = (countriesList: IPhoneInfo[], locale: string) =>
21
+ countriesList.sort((countryA, countryB) =>
22
+ getCountryTextByLocale(countryA, locale).localeCompare(
23
+ getCountryTextByLocale(countryB, locale),
24
+ ),
25
+ );
26
+
27
+ export const checkSearchStringInCountry = (country: IPhoneInfo, searchString: string): boolean => {
28
+ const checkValue = searchString.toLowerCase().trim().replace('+', '');
29
+
30
+ const possibleValues = [
31
+ country.countryRu,
32
+ country.countryEn,
33
+ ...country.countryRu.split(' '),
34
+ ...country.countryEn.split(' '),
35
+ country.dialCode,
36
+ ].map((part) => part.toLowerCase());
37
+
38
+ return possibleValues.some((v) => v.startsWith(checkValue));
39
+ };
40
+
41
+ export const getFullPhone = (phone?: IPhoneValue): string =>
42
+ (phone?.dialCode ?? '') + (phone?.phoneNumber ?? '');
43
+
44
+ export const getCountryCodeFromPhone = (phoneWithCode: string): string | undefined => {
45
+ // попробуем найти уникальный код страны fullCode (dialCode + arealCode)
46
+ let countryCode = phoneInfo.find((info) =>
47
+ info.fullCodes.some((code) => phoneWithCode.startsWith(code)),
48
+ )?.countryCode;
49
+
50
+ if (isEmpty(countryCode) && isNotEmpty(phoneWithCode)) {
51
+ // если не нашли уникальный fullCode (dialCode + arealCode),
52
+ // то пробуем найти dialCode и выбираем с наименьшим Priority
53
+ countryCode = phoneInfo
54
+ .filter((info) => phoneWithCode.startsWith(info.dialCode))
55
+ .sort(
56
+ (infoA, infoB) => (infoA.dialCodePriority ?? 1000) - (infoB.dialCodePriority ?? 1000),
57
+ )[0]?.countryCode;
58
+ }
59
+
60
+ return countryCode;
61
+ };
62
+
63
+ export const getPhoneObjFromString = (fullPhone: string, countryCode?: string): IPhoneValue => {
64
+ const newCountryCode = countryCode ?? getCountryCodeFromPhone(fullPhone);
65
+ const dialCode = findCountryByCode(newCountryCode)?.dialCode;
66
+ const phoneNumber = fullPhone.slice(dialCode?.length);
67
+
68
+ return { dialCode, phoneNumber, countryCode: newCountryCode };
69
+ };
70
+
71
+ export const DEFAULT_PHONE_MASK = '+ 9 999 999 999 999 99';
72
+
73
+ export const getPhoneMask = (countryCode?: string): string => {
74
+ let mask = DEFAULT_PHONE_MASK;
75
+ if (isNotEmpty(countryCode)) {
76
+ const countrySettings = findCountryByCode(countryCode);
77
+
78
+ if (countrySettings !== undefined) {
79
+ const dialCodeLength = countrySettings.dialCode.length;
80
+ const areaAndPhoneMask =
81
+ countrySettings.phoneMask ?? mask.substring(2, mask.length - dialCodeLength);
82
+ mask = `+ ${'9'.repeat(dialCodeLength)} ${areaAndPhoneMask}`;
83
+ }
84
+ }
85
+
86
+ return mask;
87
+ };
@@ -1,6 +1,6 @@
1
- import { ReactNode } from 'react';
2
- import { Icon } from '../components';
3
- import { IIcon } from '../types';
4
-
5
- export const renderIcon = (icon: IIcon): ReactNode =>
6
- typeof icon === 'string' ? <Icon type={icon} /> : icon;
1
+ import { ReactNode } from 'react';
2
+ import { Icon } from '../components';
3
+ import { IIcon } from '../types';
4
+
5
+ export const renderIcon = (icon: IIcon): ReactNode =>
6
+ typeof icon === 'string' ? <Icon type={icon} /> : icon;
@@ -1,18 +1,18 @@
1
- import { DependencyList, EffectCallback, useEffect, useRef } from 'react';
2
-
3
- export const useDidMountEffect = (effect: EffectCallback, dependencies: DependencyList): void => {
4
- const isMountedRef = useRef(false);
5
- useEffect(() => {
6
- let unmount: ReturnType<EffectCallback>;
7
- if (isMountedRef.current) {
8
- unmount = effect();
9
- } else {
10
- isMountedRef.current = true;
11
- }
12
- return () => {
13
- if (unmount !== undefined) {
14
- unmount();
15
- }
16
- };
17
- }, dependencies);
18
- };
1
+ import { DependencyList, EffectCallback, useEffect, useRef } from 'react';
2
+
3
+ export const useDidMountEffect = (effect: EffectCallback, dependencies: DependencyList): void => {
4
+ const isMountedRef = useRef(false);
5
+ useEffect(() => {
6
+ let unmount: ReturnType<EffectCallback>;
7
+ if (isMountedRef.current) {
8
+ unmount = effect();
9
+ } else {
10
+ isMountedRef.current = true;
11
+ }
12
+ return () => {
13
+ if (unmount !== undefined) {
14
+ unmount();
15
+ }
16
+ };
17
+ }, dependencies);
18
+ };