torgbox-ui 1.0.7 → 1.0.9

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 (446) hide show
  1. package/dist/cjs/Inputs/Button/Button.js +37 -0
  2. package/dist/cjs/Inputs/Button/button.scss +358 -0
  3. package/dist/cjs/Inputs/Button/index.js +5 -0
  4. package/dist/cjs/Inputs/Checkbox/Checkbox.js +36 -0
  5. package/dist/cjs/Inputs/Checkbox/checkbox.scss +63 -0
  6. package/dist/cjs/Inputs/Checkbox/index.js +5 -0
  7. package/dist/cjs/Inputs/EmailField/EmailField.js +65 -0
  8. package/dist/cjs/Inputs/EmailField/ErrorMessages.js +6 -0
  9. package/dist/cjs/Inputs/EmailField/index.js +9 -0
  10. package/dist/cjs/Inputs/InnField/ErrorMessages.js +4 -0
  11. package/dist/cjs/Inputs/InnField/InnField.js +37 -0
  12. package/dist/cjs/Inputs/InnField/index.js +7 -0
  13. package/dist/cjs/Inputs/NameField/ErrorMessages.js +11 -0
  14. package/dist/cjs/Inputs/NameField/NameField.js +58 -0
  15. package/dist/cjs/Inputs/NameField/index.js +14 -0
  16. package/dist/cjs/Inputs/OtpInput/ErrorMessages.js +4 -0
  17. package/dist/cjs/Inputs/OtpInput/OtpInput.js +85 -0
  18. package/dist/cjs/Inputs/OtpInput/index.js +7 -0
  19. package/dist/cjs/Inputs/OtpInput/otpInput.scss +39 -0
  20. package/dist/cjs/Inputs/PasswordField/ErrorMessages.js +5 -0
  21. package/dist/cjs/Inputs/PasswordField/PasswordField.js +42 -0
  22. package/dist/cjs/Inputs/PasswordField/index.js +8 -0
  23. package/dist/cjs/Inputs/PhoneField/ErrorMessages.js +5 -0
  24. package/dist/cjs/Inputs/PhoneField/PhoneField.js +81 -0
  25. package/dist/cjs/Inputs/PhoneField/index.js +8 -0
  26. package/dist/cjs/Inputs/RepeatPasswordField/ErrorMessages.js +5 -0
  27. package/dist/cjs/Inputs/RepeatPasswordField/RepeatPasswordField.js +29 -0
  28. package/dist/cjs/Inputs/RepeatPasswordField/index.js +8 -0
  29. package/dist/cjs/Inputs/Selector/Collapse.js +47 -0
  30. package/dist/cjs/Inputs/Selector/Dropdown.js +88 -0
  31. package/dist/cjs/Inputs/Selector/Option/Option.js +17 -0
  32. package/dist/cjs/Inputs/Selector/Option/option.scss +44 -0
  33. package/dist/cjs/Inputs/Selector/index.js +9 -0
  34. package/dist/cjs/Inputs/Selector/selector.scss +101 -0
  35. package/dist/cjs/Inputs/TextField/TextField.js +92 -0
  36. package/dist/cjs/Inputs/TextField/index.js +5 -0
  37. package/dist/cjs/Inputs/TextField/textField.module.scss +157 -0
  38. package/dist/cjs/Inputs/TextField/textField.scss +156 -0
  39. package/dist/cjs/Inputs/index.js +27 -0
  40. package/dist/cjs/Inputs/index.scss +6 -0
  41. package/dist/cjs/Pages/ContentPage/ContentPage.js +26 -0
  42. package/dist/cjs/Pages/ContentPage/contentPage.scss +10 -0
  43. package/dist/cjs/Pages/ContentPage/index.js +5 -0
  44. package/dist/cjs/Pages/CreatePasswordPage/CreatePasswordPage.js +51 -0
  45. package/dist/cjs/Pages/CreatePasswordPage/createPasswordPage.scss +42 -0
  46. package/dist/cjs/Pages/CreatePasswordPage/index.js +5 -0
  47. package/dist/cjs/Pages/CreateTeamPage/CreateTeamPage.js +53 -0
  48. package/dist/cjs/Pages/CreateTeamPage/createTeamPage.scss +82 -0
  49. package/dist/cjs/Pages/CreateTeamPage/index.js +5 -0
  50. package/dist/cjs/Pages/EmailConfirmationPage/EmailConfirmationPage.js +41 -0
  51. package/dist/cjs/Pages/EmailConfirmationPage/emailConfirmationPage.scss +92 -0
  52. package/dist/cjs/Pages/EmailConfirmationPage/index.js +5 -0
  53. package/dist/cjs/Pages/JoinTeamPage/JoinTeamPage.js +13 -0
  54. package/dist/cjs/Pages/JoinTeamPage/index.js +5 -0
  55. package/dist/cjs/Pages/JoinTeamPage/joinTeamPage.scss +50 -0
  56. package/dist/cjs/Pages/LoginPage/LoginPage.js +36 -0
  57. package/dist/cjs/Pages/LoginPage/index.js +5 -0
  58. package/dist/cjs/Pages/LoginPage/loginPage.scss +80 -0
  59. package/dist/cjs/Pages/RegisterPage/RegisterPage.js +38 -0
  60. package/dist/cjs/Pages/RegisterPage/index.js +5 -0
  61. package/dist/cjs/Pages/RegisterPage/registerPage.scss +72 -0
  62. package/dist/cjs/Pages/ResetPasswordPage/ResetPasswordPage.js +17 -0
  63. package/dist/cjs/Pages/ResetPasswordPage/index.js +5 -0
  64. package/dist/cjs/Pages/ResetPasswordPage/resetPasswordPage.scss +41 -0
  65. package/dist/cjs/Pages/StartPage/StartPage.js +26 -0
  66. package/dist/cjs/Pages/StartPage/index.js +5 -0
  67. package/dist/cjs/Pages/StartPage/startPage.scss +58 -0
  68. package/dist/cjs/Pages/index.js +15 -0
  69. package/dist/cjs/Pages/index.scss +9 -0
  70. package/dist/cjs/Utils/Divider/Divider.js +6 -0
  71. package/dist/cjs/Utils/Divider/divider.scss +11 -0
  72. package/dist/cjs/Utils/ErrorBanner/ErrorBanner.js +13 -0
  73. package/dist/cjs/Utils/ErrorBanner/errorBanner.scss +24 -0
  74. package/dist/cjs/Utils/ErrorBanner/index.js +5 -0
  75. package/dist/cjs/Utils/Link/Link.js +12 -0
  76. package/dist/cjs/Utils/Link/index.js +5 -0
  77. package/dist/cjs/Utils/Link/index.scss +1 -0
  78. package/dist/cjs/Utils/Link/link.scss +21 -0
  79. package/dist/cjs/Utils/Modal/Modal.js +31 -0
  80. package/dist/cjs/Utils/Modal/index.js +5 -0
  81. package/dist/cjs/Utils/Modal/modal.scss +33 -0
  82. package/dist/cjs/Utils/Portal/Portal.js +9 -0
  83. package/dist/cjs/Utils/SectionPlaceholder/SectionPlaceholder.js +6 -0
  84. package/dist/cjs/Utils/SectionPlaceholder/sectionPlaceholder.scss +22 -0
  85. package/dist/cjs/Utils/Spinner/Spinner.js +12 -0
  86. package/dist/cjs/Utils/Spinner/spinner.scss +41 -0
  87. package/dist/cjs/Utils/api.js +10 -0
  88. package/dist/cjs/Utils/index.js +17 -0
  89. package/dist/cjs/Utils/index.scss +6 -0
  90. package/dist/cjs/Widgets/Header/Header.js +25 -0
  91. package/dist/cjs/Widgets/Header/header.scss +50 -0
  92. package/dist/cjs/Widgets/Header/index.js +5 -0
  93. package/dist/cjs/Widgets/Sidebar/Sidebar.js +32 -0
  94. package/dist/cjs/Widgets/Sidebar/index.js +5 -0
  95. package/dist/cjs/Widgets/Sidebar/sidebar.scss +23 -0
  96. package/dist/cjs/Widgets/index.js +7 -0
  97. package/dist/cjs/Widgets/index.scss +2 -0
  98. package/dist/cjs/app/main.js +12 -0
  99. package/dist/cjs/app/routes/AppRouter.js +35 -0
  100. package/dist/cjs/app/routes/index.js +5 -0
  101. package/dist/cjs/app/store/index.js +7 -0
  102. package/dist/cjs/app/store/store.js +17 -0
  103. package/dist/cjs/assets/scss/index.scss +5 -0
  104. package/dist/cjs/assets/scss/settings/fonts.scss +29 -0
  105. package/dist/cjs/assets/scss/settings/globals.scss +5 -0
  106. package/dist/cjs/assets/scss/settings/helpers.scss +3 -0
  107. package/dist/cjs/assets/scss/settings/reset.scss +8 -0
  108. package/dist/cjs/assets/scss/settings/variables.scss +91 -0
  109. package/dist/cjs/entities/user/api/api.js +44 -0
  110. package/dist/cjs/entities/user/api/index.js +17 -0
  111. package/dist/cjs/entities/user/index.js +23 -0
  112. package/dist/cjs/entities/user/model/index.js +21 -0
  113. package/dist/cjs/entities/user/model/selectors.js +7 -0
  114. package/dist/cjs/entities/user/model/slice.js +34 -0
  115. package/dist/cjs/entities/user/model/types.js +2 -0
  116. package/dist/cjs/index.js +19 -0
  117. package/dist/cjs/index.scss +6 -0
  118. package/dist/cjs/shared/model/api.js +9 -0
  119. package/dist/cjs/shared/model/constants.js +4 -0
  120. package/dist/cjs/shared/model/index.js +7 -0
  121. package/dist/cjs/shared/ui/Avatar/Avatar.js +13 -0
  122. package/dist/cjs/shared/ui/Avatar/avatar.scss +62 -0
  123. package/dist/cjs/shared/ui/Avatar/index.js +5 -0
  124. package/dist/cjs/shared/ui/index.js +5 -0
  125. package/dist/cjs/shared/ui/index.scss +1 -0
  126. package/dist/cjs/tools/customValidators.js +27 -0
  127. package/dist/cjs/tools/getCoords.js +22 -0
  128. package/dist/cjs/tools/regExp.js +8 -0
  129. package/dist/{types → cjs}/ui.d.ts +0 -1
  130. package/dist/cjs/ui.js +19 -0
  131. package/dist/cjs/ui.scss +4 -0
  132. package/dist/esm/Inputs/Button/Button.d.ts +17 -0
  133. package/dist/esm/Inputs/Button/Button.js +30 -0
  134. package/dist/esm/Inputs/Button/button.scss +358 -0
  135. package/dist/esm/Inputs/Button/index.d.ts +1 -0
  136. package/dist/esm/Inputs/Button/index.js +1 -0
  137. package/dist/esm/Inputs/Checkbox/Checkbox.d.ts +11 -0
  138. package/dist/esm/Inputs/Checkbox/Checkbox.js +29 -0
  139. package/dist/esm/Inputs/Checkbox/checkbox.scss +63 -0
  140. package/dist/esm/Inputs/Checkbox/index.d.ts +1 -0
  141. package/dist/esm/Inputs/Checkbox/index.js +1 -0
  142. package/dist/esm/Inputs/EmailField/EmailField.d.ts +7 -0
  143. package/dist/esm/Inputs/EmailField/EmailField.js +61 -0
  144. package/dist/esm/Inputs/EmailField/ErrorMessages.d.ts +3 -0
  145. package/dist/esm/Inputs/EmailField/ErrorMessages.js +3 -0
  146. package/dist/esm/Inputs/EmailField/index.d.ts +2 -0
  147. package/dist/esm/Inputs/EmailField/index.js +2 -0
  148. package/dist/esm/Inputs/InnField/ErrorMessages.d.ts +1 -0
  149. package/dist/esm/Inputs/InnField/ErrorMessages.js +1 -0
  150. package/dist/esm/Inputs/InnField/InnField.d.ts +6 -0
  151. package/dist/esm/Inputs/InnField/InnField.js +33 -0
  152. package/dist/esm/Inputs/InnField/index.d.ts +2 -0
  153. package/dist/esm/Inputs/InnField/index.js +2 -0
  154. package/dist/esm/Inputs/NameField/ErrorMessages.d.ts +8 -0
  155. package/dist/esm/Inputs/NameField/ErrorMessages.js +8 -0
  156. package/dist/esm/Inputs/NameField/NameField.d.ts +9 -0
  157. package/dist/esm/Inputs/NameField/NameField.js +54 -0
  158. package/dist/esm/Inputs/NameField/index.d.ts +2 -0
  159. package/dist/esm/Inputs/NameField/index.js +2 -0
  160. package/dist/esm/Inputs/OtpInput/ErrorMessages.d.ts +1 -0
  161. package/dist/esm/Inputs/OtpInput/ErrorMessages.js +1 -0
  162. package/dist/esm/Inputs/OtpInput/OtpInput.d.ts +9 -0
  163. package/dist/esm/Inputs/OtpInput/OtpInput.js +78 -0
  164. package/dist/esm/Inputs/OtpInput/index.d.ts +2 -0
  165. package/dist/esm/Inputs/OtpInput/index.js +2 -0
  166. package/dist/esm/Inputs/OtpInput/otpInput.scss +39 -0
  167. package/dist/esm/Inputs/PasswordField/ErrorMessages.d.ts +2 -0
  168. package/dist/esm/Inputs/PasswordField/ErrorMessages.js +2 -0
  169. package/dist/esm/Inputs/PasswordField/PasswordField.d.ts +7 -0
  170. package/dist/esm/Inputs/PasswordField/PasswordField.js +35 -0
  171. package/dist/esm/Inputs/PasswordField/index.d.ts +2 -0
  172. package/dist/esm/Inputs/PasswordField/index.js +2 -0
  173. package/dist/esm/Inputs/PhoneField/ErrorMessages.d.ts +2 -0
  174. package/dist/esm/Inputs/PhoneField/ErrorMessages.js +2 -0
  175. package/dist/esm/Inputs/PhoneField/PhoneField.d.ts +6 -0
  176. package/dist/esm/Inputs/PhoneField/PhoneField.js +74 -0
  177. package/dist/esm/Inputs/PhoneField/index.d.ts +2 -0
  178. package/dist/esm/Inputs/PhoneField/index.js +2 -0
  179. package/dist/esm/Inputs/RepeatPasswordField/ErrorMessages.d.ts +2 -0
  180. package/dist/esm/Inputs/RepeatPasswordField/ErrorMessages.js +2 -0
  181. package/dist/esm/Inputs/RepeatPasswordField/RepeatPasswordField.d.ts +6 -0
  182. package/dist/esm/Inputs/RepeatPasswordField/RepeatPasswordField.js +22 -0
  183. package/dist/esm/Inputs/RepeatPasswordField/index.d.ts +2 -0
  184. package/dist/esm/Inputs/RepeatPasswordField/index.js +2 -0
  185. package/dist/esm/Inputs/Selector/Collapse.d.ts +12 -0
  186. package/dist/esm/Inputs/Selector/Collapse.js +40 -0
  187. package/dist/esm/Inputs/Selector/Dropdown.d.ts +13 -0
  188. package/dist/esm/Inputs/Selector/Dropdown.js +81 -0
  189. package/dist/esm/Inputs/Selector/Option/Option.d.ts +13 -0
  190. package/dist/esm/Inputs/Selector/Option/Option.js +10 -0
  191. package/dist/esm/Inputs/Selector/Option/option.scss +44 -0
  192. package/dist/esm/Inputs/Selector/index.d.ts +3 -0
  193. package/dist/esm/Inputs/Selector/index.js +3 -0
  194. package/dist/esm/Inputs/Selector/selector.scss +101 -0
  195. package/dist/esm/Inputs/TextField/TextField.d.ts +25 -0
  196. package/dist/esm/Inputs/TextField/TextField.js +85 -0
  197. package/dist/esm/Inputs/TextField/index.d.ts +1 -0
  198. package/dist/esm/Inputs/TextField/index.js +1 -0
  199. package/dist/esm/Inputs/TextField/textField.module.scss +157 -0
  200. package/dist/esm/Inputs/TextField/textField.scss +156 -0
  201. package/dist/esm/Inputs/index.d.ts +11 -0
  202. package/dist/esm/Inputs/index.js +11 -0
  203. package/dist/esm/Inputs/index.scss +6 -0
  204. package/dist/esm/Pages/ContentPage/ContentPage.d.ts +6 -0
  205. package/dist/esm/Pages/ContentPage/ContentPage.js +22 -0
  206. package/dist/esm/Pages/ContentPage/contentPage.scss +10 -0
  207. package/dist/esm/Pages/ContentPage/index.d.ts +1 -0
  208. package/dist/esm/Pages/ContentPage/index.js +1 -0
  209. package/dist/esm/Pages/CreatePasswordPage/CreatePasswordPage.d.ts +1 -0
  210. package/dist/esm/Pages/CreatePasswordPage/CreatePasswordPage.js +47 -0
  211. package/dist/esm/Pages/CreatePasswordPage/createPasswordPage.scss +42 -0
  212. package/dist/esm/Pages/CreatePasswordPage/index.d.ts +1 -0
  213. package/dist/esm/Pages/CreatePasswordPage/index.js +1 -0
  214. package/dist/esm/Pages/CreateTeamPage/CreateTeamPage.d.ts +4 -0
  215. package/dist/esm/Pages/CreateTeamPage/CreateTeamPage.js +46 -0
  216. package/dist/esm/Pages/CreateTeamPage/createTeamPage.scss +82 -0
  217. package/dist/esm/Pages/CreateTeamPage/index.d.ts +1 -0
  218. package/dist/esm/Pages/CreateTeamPage/index.js +1 -0
  219. package/dist/esm/Pages/EmailConfirmationPage/EmailConfirmationPage.d.ts +4 -0
  220. package/dist/esm/Pages/EmailConfirmationPage/EmailConfirmationPage.js +34 -0
  221. package/dist/esm/Pages/EmailConfirmationPage/emailConfirmationPage.scss +92 -0
  222. package/dist/esm/Pages/EmailConfirmationPage/index.d.ts +1 -0
  223. package/dist/esm/Pages/EmailConfirmationPage/index.js +1 -0
  224. package/dist/esm/Pages/JoinTeamPage/JoinTeamPage.d.ts +1 -0
  225. package/dist/esm/Pages/JoinTeamPage/JoinTeamPage.js +6 -0
  226. package/dist/esm/Pages/JoinTeamPage/index.d.ts +1 -0
  227. package/dist/esm/Pages/JoinTeamPage/index.js +1 -0
  228. package/dist/esm/Pages/JoinTeamPage/joinTeamPage.scss +50 -0
  229. package/dist/esm/Pages/LoginPage/LoginPage.d.ts +1 -0
  230. package/dist/esm/Pages/LoginPage/LoginPage.js +32 -0
  231. package/dist/esm/Pages/LoginPage/index.d.ts +1 -0
  232. package/dist/esm/Pages/LoginPage/index.js +1 -0
  233. package/dist/esm/Pages/LoginPage/loginPage.scss +80 -0
  234. package/dist/esm/Pages/RegisterPage/RegisterPage.d.ts +1 -0
  235. package/dist/esm/Pages/RegisterPage/RegisterPage.js +34 -0
  236. package/dist/esm/Pages/RegisterPage/index.d.ts +1 -0
  237. package/dist/esm/Pages/RegisterPage/index.js +1 -0
  238. package/dist/esm/Pages/RegisterPage/registerPage.scss +72 -0
  239. package/dist/esm/Pages/ResetPasswordPage/ResetPasswordPage.d.ts +1 -0
  240. package/dist/esm/Pages/ResetPasswordPage/ResetPasswordPage.js +10 -0
  241. package/dist/esm/Pages/ResetPasswordPage/index.d.ts +1 -0
  242. package/dist/esm/Pages/ResetPasswordPage/index.js +1 -0
  243. package/dist/esm/Pages/ResetPasswordPage/resetPasswordPage.scss +41 -0
  244. package/dist/esm/Pages/StartPage/StartPage.d.ts +4 -0
  245. package/dist/esm/Pages/StartPage/StartPage.js +22 -0
  246. package/dist/esm/Pages/StartPage/index.d.ts +1 -0
  247. package/dist/esm/Pages/StartPage/index.js +1 -0
  248. package/dist/esm/Pages/StartPage/startPage.scss +58 -0
  249. package/dist/esm/Pages/index.d.ts +6 -0
  250. package/dist/esm/Pages/index.js +6 -0
  251. package/dist/esm/Pages/index.scss +9 -0
  252. package/dist/esm/Utils/Divider/Divider.d.ts +1 -0
  253. package/dist/esm/Utils/Divider/Divider.js +2 -0
  254. package/dist/esm/Utils/Divider/divider.scss +11 -0
  255. package/dist/esm/Utils/ErrorBanner/ErrorBanner.d.ts +4 -0
  256. package/dist/esm/Utils/ErrorBanner/ErrorBanner.js +6 -0
  257. package/dist/esm/Utils/ErrorBanner/errorBanner.scss +24 -0
  258. package/dist/esm/Utils/ErrorBanner/index.d.ts +1 -0
  259. package/dist/esm/Utils/ErrorBanner/index.js +1 -0
  260. package/dist/esm/Utils/Link/Link.d.ts +7 -0
  261. package/dist/esm/Utils/Link/Link.js +5 -0
  262. package/dist/esm/Utils/Link/index.d.ts +1 -0
  263. package/dist/esm/Utils/Link/index.js +1 -0
  264. package/dist/esm/Utils/Link/index.scss +1 -0
  265. package/dist/esm/Utils/Link/link.scss +21 -0
  266. package/dist/esm/Utils/Modal/Modal.d.ts +8 -0
  267. package/dist/esm/Utils/Modal/Modal.js +24 -0
  268. package/dist/esm/Utils/Modal/index.d.ts +1 -0
  269. package/dist/esm/Utils/Modal/index.js +1 -0
  270. package/dist/esm/Utils/Modal/modal.scss +33 -0
  271. package/dist/esm/Utils/Portal/Portal.d.ts +7 -0
  272. package/dist/esm/Utils/Portal/Portal.js +5 -0
  273. package/dist/esm/Utils/SectionPlaceholder/SectionPlaceholder.d.ts +5 -0
  274. package/dist/esm/Utils/SectionPlaceholder/SectionPlaceholder.js +2 -0
  275. package/dist/esm/Utils/SectionPlaceholder/sectionPlaceholder.scss +22 -0
  276. package/dist/esm/Utils/Spinner/Spinner.d.ts +5 -0
  277. package/dist/esm/Utils/Spinner/Spinner.js +5 -0
  278. package/dist/esm/Utils/Spinner/spinner.scss +41 -0
  279. package/dist/esm/Utils/api.d.ts +1 -0
  280. package/dist/esm/Utils/api.js +7 -0
  281. package/dist/esm/Utils/index.d.ts +7 -0
  282. package/dist/esm/Utils/index.js +7 -0
  283. package/dist/esm/Utils/index.scss +6 -0
  284. package/dist/esm/Widgets/Header/Header.d.ts +7 -0
  285. package/dist/esm/Widgets/Header/Header.js +18 -0
  286. package/dist/esm/Widgets/Header/header.scss +50 -0
  287. package/dist/esm/Widgets/Header/index.d.ts +1 -0
  288. package/dist/esm/Widgets/Header/index.js +1 -0
  289. package/dist/esm/Widgets/Sidebar/Sidebar.d.ts +9 -0
  290. package/dist/esm/Widgets/Sidebar/Sidebar.js +25 -0
  291. package/dist/esm/Widgets/Sidebar/index.d.ts +1 -0
  292. package/dist/esm/Widgets/Sidebar/index.js +1 -0
  293. package/dist/esm/Widgets/Sidebar/sidebar.scss +23 -0
  294. package/dist/esm/Widgets/index.d.ts +2 -0
  295. package/dist/esm/Widgets/index.js +2 -0
  296. package/dist/esm/Widgets/index.scss +2 -0
  297. package/dist/esm/app/main.d.ts +1 -0
  298. package/dist/esm/app/main.js +7 -0
  299. package/dist/esm/app/routes/AppRouter.d.ts +1 -0
  300. package/dist/esm/app/routes/AppRouter.js +31 -0
  301. package/dist/esm/app/routes/index.d.ts +1 -0
  302. package/dist/esm/app/routes/index.js +1 -0
  303. package/dist/esm/app/store/index.d.ts +1 -0
  304. package/dist/esm/app/store/index.js +1 -0
  305. package/dist/esm/app/store/store.d.ts +14 -0
  306. package/dist/esm/app/store/store.js +13 -0
  307. package/dist/esm/assets/scss/index.scss +5 -0
  308. package/dist/esm/assets/scss/settings/fonts.scss +29 -0
  309. package/dist/esm/assets/scss/settings/globals.scss +5 -0
  310. package/dist/esm/assets/scss/settings/helpers.scss +3 -0
  311. package/dist/esm/assets/scss/settings/reset.scss +8 -0
  312. package/dist/esm/assets/scss/settings/variables.scss +91 -0
  313. package/dist/esm/entities/user/api/api.d.ts +648 -0
  314. package/dist/esm/entities/user/api/api.js +41 -0
  315. package/dist/esm/entities/user/api/index.d.ts +1 -0
  316. package/dist/esm/entities/user/api/index.js +1 -0
  317. package/dist/esm/entities/user/index.d.ts +2 -0
  318. package/dist/esm/entities/user/index.js +2 -0
  319. package/dist/esm/entities/user/model/index.d.ts +3 -0
  320. package/dist/esm/entities/user/model/index.js +2 -0
  321. package/dist/esm/entities/user/model/selectors.d.ts +4 -0
  322. package/dist/esm/entities/user/model/selectors.js +2 -0
  323. package/dist/esm/entities/user/model/slice.d.ts +10 -0
  324. package/dist/esm/entities/user/model/slice.js +31 -0
  325. package/dist/esm/entities/user/model/types.d.ts +17 -0
  326. package/dist/esm/entities/user/model/types.js +1 -0
  327. package/dist/esm/index.d.ts +3 -0
  328. package/dist/esm/index.js +3 -0
  329. package/dist/esm/index.scss +6 -0
  330. package/dist/esm/shared/model/api.d.ts +6 -0
  331. package/dist/esm/shared/model/api.js +6 -0
  332. package/dist/esm/shared/model/constants.d.ts +1 -0
  333. package/dist/esm/shared/model/constants.js +1 -0
  334. package/dist/esm/shared/model/index.d.ts +2 -0
  335. package/dist/esm/shared/model/index.js +2 -0
  336. package/dist/esm/shared/ui/Avatar/Avatar.d.ts +8 -0
  337. package/dist/esm/shared/ui/Avatar/Avatar.js +6 -0
  338. package/dist/esm/shared/ui/Avatar/avatar.scss +62 -0
  339. package/dist/esm/shared/ui/Avatar/index.d.ts +1 -0
  340. package/dist/esm/shared/ui/Avatar/index.js +1 -0
  341. package/dist/esm/shared/ui/index.d.ts +1 -0
  342. package/dist/esm/shared/ui/index.js +1 -0
  343. package/dist/esm/shared/ui/index.scss +1 -0
  344. package/dist/esm/tools/customValidators.d.ts +5 -0
  345. package/dist/esm/tools/customValidators.js +19 -0
  346. package/dist/esm/tools/getCoords.d.ts +12 -0
  347. package/dist/esm/tools/getCoords.js +18 -0
  348. package/dist/esm/tools/regExp.d.ts +5 -0
  349. package/dist/esm/tools/regExp.js +5 -0
  350. package/dist/esm/ui.d.ts +3 -0
  351. package/dist/esm/ui.js +3 -0
  352. package/dist/esm/ui.scss +4 -0
  353. package/package.json +15 -8
  354. package/dist/torgbox-ui.cjs.js +0 -31
  355. package/dist/torgbox-ui.css +0 -1
  356. package/dist/torgbox-ui.es.js +0 -4799
  357. /package/dist/{types → cjs}/Inputs/Button/Button.d.ts +0 -0
  358. /package/dist/{types → cjs}/Inputs/Button/index.d.ts +0 -0
  359. /package/dist/{types → cjs}/Inputs/Checkbox/Checkbox.d.ts +0 -0
  360. /package/dist/{types → cjs}/Inputs/Checkbox/index.d.ts +0 -0
  361. /package/dist/{types → cjs}/Inputs/EmailField/EmailField.d.ts +0 -0
  362. /package/dist/{types → cjs}/Inputs/EmailField/ErrorMessages.d.ts +0 -0
  363. /package/dist/{types → cjs}/Inputs/EmailField/index.d.ts +0 -0
  364. /package/dist/{types → cjs}/Inputs/InnField/ErrorMessages.d.ts +0 -0
  365. /package/dist/{types → cjs}/Inputs/InnField/InnField.d.ts +0 -0
  366. /package/dist/{types → cjs}/Inputs/InnField/index.d.ts +0 -0
  367. /package/dist/{types → cjs}/Inputs/NameField/ErrorMessages.d.ts +0 -0
  368. /package/dist/{types → cjs}/Inputs/NameField/NameField.d.ts +0 -0
  369. /package/dist/{types → cjs}/Inputs/NameField/index.d.ts +0 -0
  370. /package/dist/{types → cjs}/Inputs/OtpInput/ErrorMessages.d.ts +0 -0
  371. /package/dist/{types → cjs}/Inputs/OtpInput/OtpInput.d.ts +0 -0
  372. /package/dist/{types → cjs}/Inputs/OtpInput/index.d.ts +0 -0
  373. /package/dist/{types → cjs}/Inputs/PasswordField/ErrorMessages.d.ts +0 -0
  374. /package/dist/{types → cjs}/Inputs/PasswordField/PasswordField.d.ts +0 -0
  375. /package/dist/{types → cjs}/Inputs/PasswordField/index.d.ts +0 -0
  376. /package/dist/{types → cjs}/Inputs/PhoneField/ErrorMessages.d.ts +0 -0
  377. /package/dist/{types → cjs}/Inputs/PhoneField/PhoneField.d.ts +0 -0
  378. /package/dist/{types → cjs}/Inputs/PhoneField/index.d.ts +0 -0
  379. /package/dist/{types → cjs}/Inputs/RepeatPasswordField/ErrorMessages.d.ts +0 -0
  380. /package/dist/{types → cjs}/Inputs/RepeatPasswordField/RepeatPasswordField.d.ts +0 -0
  381. /package/dist/{types → cjs}/Inputs/RepeatPasswordField/index.d.ts +0 -0
  382. /package/dist/{types → cjs}/Inputs/Selector/Collapse.d.ts +0 -0
  383. /package/dist/{types → cjs}/Inputs/Selector/Dropdown.d.ts +0 -0
  384. /package/dist/{types → cjs}/Inputs/Selector/Option/Option.d.ts +0 -0
  385. /package/dist/{types → cjs}/Inputs/Selector/index.d.ts +0 -0
  386. /package/dist/{types → cjs}/Inputs/TextField/TextField.d.ts +0 -0
  387. /package/dist/{types → cjs}/Inputs/TextField/index.d.ts +0 -0
  388. /package/dist/{types → cjs}/Inputs/index.d.ts +0 -0
  389. /package/dist/{types → cjs}/Pages/ContentPage/ContentPage.d.ts +0 -0
  390. /package/dist/{types → cjs}/Pages/ContentPage/index.d.ts +0 -0
  391. /package/dist/{types → cjs}/Pages/CreatePasswordPage/CreatePasswordPage.d.ts +0 -0
  392. /package/dist/{types → cjs}/Pages/CreatePasswordPage/index.d.ts +0 -0
  393. /package/dist/{types → cjs}/Pages/CreateTeamPage/CreateTeamPage.d.ts +0 -0
  394. /package/dist/{types → cjs}/Pages/CreateTeamPage/index.d.ts +0 -0
  395. /package/dist/{types → cjs}/Pages/EmailConfirmationPage/EmailConfirmationPage.d.ts +0 -0
  396. /package/dist/{types → cjs}/Pages/EmailConfirmationPage/index.d.ts +0 -0
  397. /package/dist/{types → cjs}/Pages/JoinTeamPage/JoinTeamPage.d.ts +0 -0
  398. /package/dist/{types → cjs}/Pages/JoinTeamPage/index.d.ts +0 -0
  399. /package/dist/{types → cjs}/Pages/LoginPage/LoginPage.d.ts +0 -0
  400. /package/dist/{types → cjs}/Pages/LoginPage/index.d.ts +0 -0
  401. /package/dist/{types → cjs}/Pages/RegisterPage/RegisterPage.d.ts +0 -0
  402. /package/dist/{types → cjs}/Pages/RegisterPage/index.d.ts +0 -0
  403. /package/dist/{types → cjs}/Pages/ResetPasswordPage/ResetPasswordPage.d.ts +0 -0
  404. /package/dist/{types → cjs}/Pages/ResetPasswordPage/index.d.ts +0 -0
  405. /package/dist/{types → cjs}/Pages/StartPage/StartPage.d.ts +0 -0
  406. /package/dist/{types → cjs}/Pages/StartPage/index.d.ts +0 -0
  407. /package/dist/{types → cjs}/Pages/index.d.ts +0 -0
  408. /package/dist/{types → cjs}/Utils/Divider/Divider.d.ts +0 -0
  409. /package/dist/{types → cjs}/Utils/ErrorBanner/ErrorBanner.d.ts +0 -0
  410. /package/dist/{types → cjs}/Utils/ErrorBanner/index.d.ts +0 -0
  411. /package/dist/{types → cjs}/Utils/Link/Link.d.ts +0 -0
  412. /package/dist/{types → cjs}/Utils/Link/index.d.ts +0 -0
  413. /package/dist/{types → cjs}/Utils/Modal/Modal.d.ts +0 -0
  414. /package/dist/{types → cjs}/Utils/Modal/index.d.ts +0 -0
  415. /package/dist/{types → cjs}/Utils/Portal/Portal.d.ts +0 -0
  416. /package/dist/{types → cjs}/Utils/SectionPlaceholder/SectionPlaceholder.d.ts +0 -0
  417. /package/dist/{types → cjs}/Utils/Spinner/Spinner.d.ts +0 -0
  418. /package/dist/{types → cjs}/Utils/api.d.ts +0 -0
  419. /package/dist/{types → cjs}/Utils/index.d.ts +0 -0
  420. /package/dist/{types → cjs}/Widgets/Header/Header.d.ts +0 -0
  421. /package/dist/{types → cjs}/Widgets/Header/index.d.ts +0 -0
  422. /package/dist/{types → cjs}/Widgets/Sidebar/Sidebar.d.ts +0 -0
  423. /package/dist/{types → cjs}/Widgets/Sidebar/index.d.ts +0 -0
  424. /package/dist/{types → cjs}/Widgets/index.d.ts +0 -0
  425. /package/dist/{types → cjs}/app/main.d.ts +0 -0
  426. /package/dist/{types → cjs}/app/routes/AppRouter.d.ts +0 -0
  427. /package/dist/{types → cjs}/app/routes/index.d.ts +0 -0
  428. /package/dist/{types → cjs}/app/store/index.d.ts +0 -0
  429. /package/dist/{types → cjs}/app/store/store.d.ts +0 -0
  430. /package/dist/{types → cjs}/entities/user/api/api.d.ts +0 -0
  431. /package/dist/{types → cjs}/entities/user/api/index.d.ts +0 -0
  432. /package/dist/{types → cjs}/entities/user/index.d.ts +0 -0
  433. /package/dist/{types → cjs}/entities/user/model/index.d.ts +0 -0
  434. /package/dist/{types → cjs}/entities/user/model/selectors.d.ts +0 -0
  435. /package/dist/{types → cjs}/entities/user/model/slice.d.ts +0 -0
  436. /package/dist/{types → cjs}/entities/user/model/types.d.ts +0 -0
  437. /package/dist/{types → cjs}/index.d.ts +0 -0
  438. /package/dist/{types → cjs}/shared/model/api.d.ts +0 -0
  439. /package/dist/{types → cjs}/shared/model/constants.d.ts +0 -0
  440. /package/dist/{types → cjs}/shared/model/index.d.ts +0 -0
  441. /package/dist/{types → cjs}/shared/ui/Avatar/Avatar.d.ts +0 -0
  442. /package/dist/{types → cjs}/shared/ui/Avatar/index.d.ts +0 -0
  443. /package/dist/{types → cjs}/shared/ui/index.d.ts +0 -0
  444. /package/dist/{types → cjs}/tools/customValidators.d.ts +0 -0
  445. /package/dist/{types → cjs}/tools/getCoords.d.ts +0 -0
  446. /package/dist/{types → cjs}/tools/regExp.d.ts +0 -0
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NameField = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const customValidators_1 = require("../../tools/customValidators");
7
+ const TextField_1 = require("../TextField");
8
+ const ErrorMessages_1 = require("./ErrorMessages");
9
+ ;
10
+ const NameField = (props) => {
11
+ const { nameType = 'fullName', onValidated, onTextValid } = props;
12
+ const [errorMessage, setErrorMessage] = (0, react_1.useState)('');
13
+ const [touched, setTouched] = (0, react_1.useState)(false);
14
+ const [name, setName] = (0, react_1.useState)('');
15
+ const nameArgs = {
16
+ firstName: {
17
+ label: 'Имя',
18
+ emptyMessage: ErrorMessages_1.emptyFirstNameError,
19
+ notCorrectMessage: ErrorMessages_1.notCorrectFirstNameError,
20
+ },
21
+ lastName: {
22
+ label: 'Фамилия',
23
+ emptyMessage: ErrorMessages_1.emptyLastNameError,
24
+ notCorrectMessage: ErrorMessages_1.notCorrectLastNameError,
25
+ },
26
+ patronymic: {
27
+ label: 'Отчество',
28
+ emptyMessage: ErrorMessages_1.emptyPatronymicNameError,
29
+ notCorrectMessage: ErrorMessages_1.notCorrectPatronymicNameError,
30
+ },
31
+ fullName: {
32
+ label: 'ФИО',
33
+ emptyMessage: ErrorMessages_1.emptyFullNameError,
34
+ notCorrectMessage: ErrorMessages_1.notCorrectFullNameError,
35
+ }
36
+ };
37
+ const { label, emptyMessage, notCorrectMessage } = nameArgs[nameType];
38
+ (0, react_1.useEffect)(() => {
39
+ if (!touched) {
40
+ return;
41
+ }
42
+ const valid = (0, customValidators_1.nameValidator)(nameType === 'fullName' ? name.split(' ') : name);
43
+ if (!valid) {
44
+ onValidated(false);
45
+ onTextValid('');
46
+ const error = (!name && emptyMessage) ||
47
+ (!valid && notCorrectMessage) ||
48
+ '';
49
+ setErrorMessage(error);
50
+ return;
51
+ }
52
+ onValidated(true);
53
+ onTextValid(name);
54
+ setErrorMessage('');
55
+ }, [emptyMessage, name, nameType, notCorrectMessage, onTextValid, onValidated, touched]);
56
+ return ((0, jsx_runtime_1.jsx)(TextField_1.TextField, { onChange: setName, onTouched: setTouched, state: touched && errorMessage ? 'error' : 'idle', errorMessage: errorMessage, label: label, type: 'text', value: name, required: true, checkIcon: true, ...props }));
57
+ };
58
+ exports.NameField = NameField;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notCorrectFullNameError = exports.notCorrectPatronymicNameError = exports.notCorrectLastNameError = exports.notCorrectFirstNameError = exports.emptyFullNameError = exports.emptyPatronymicNameError = exports.emptyLastNameError = exports.emptyFirstNameError = exports.NameField = void 0;
4
+ var NameField_1 = require("./NameField");
5
+ Object.defineProperty(exports, "NameField", { enumerable: true, get: function () { return NameField_1.NameField; } });
6
+ var ErrorMessages_1 = require("./ErrorMessages");
7
+ Object.defineProperty(exports, "emptyFirstNameError", { enumerable: true, get: function () { return ErrorMessages_1.emptyFirstNameError; } });
8
+ Object.defineProperty(exports, "emptyLastNameError", { enumerable: true, get: function () { return ErrorMessages_1.emptyLastNameError; } });
9
+ Object.defineProperty(exports, "emptyPatronymicNameError", { enumerable: true, get: function () { return ErrorMessages_1.emptyPatronymicNameError; } });
10
+ Object.defineProperty(exports, "emptyFullNameError", { enumerable: true, get: function () { return ErrorMessages_1.emptyFullNameError; } });
11
+ Object.defineProperty(exports, "notCorrectFirstNameError", { enumerable: true, get: function () { return ErrorMessages_1.notCorrectFirstNameError; } });
12
+ Object.defineProperty(exports, "notCorrectLastNameError", { enumerable: true, get: function () { return ErrorMessages_1.notCorrectLastNameError; } });
13
+ Object.defineProperty(exports, "notCorrectPatronymicNameError", { enumerable: true, get: function () { return ErrorMessages_1.notCorrectPatronymicNameError; } });
14
+ Object.defineProperty(exports, "notCorrectFullNameError", { enumerable: true, get: function () { return ErrorMessages_1.notCorrectFullNameError; } });
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.otpError = void 0;
4
+ exports.otpError = 'Неверный код. Сверьтесь с письмом';
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.OtpInput = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const classnames_1 = __importDefault(require("classnames"));
9
+ const fp_1 = __importDefault(require("lodash/fp"));
10
+ const react_1 = require("react");
11
+ const OtpInput = (props) => {
12
+ const { length = 6, onComplete = fp_1.default.noop, errorMessage = '', setErrorMessage = fp_1.default.noop, responseReceived = false, loading = false, } = props;
13
+ const inputRef = (0, react_1.useRef)(Array(length).fill(null));
14
+ const [Otp, setOtp] = (0, react_1.useState)(Array(length).fill(''));
15
+ const currentTarget = inputRef.current;
16
+ const handleComplete = (value, index) => {
17
+ onComplete(value.join(''));
18
+ currentTarget[index].blur();
19
+ };
20
+ const handleTextChange = (index) => (e) => {
21
+ setErrorMessage('');
22
+ const newPin = [...Otp];
23
+ const input = e.target.value.replace(/\D/g, '');
24
+ newPin[index] = input;
25
+ setOtp(newPin);
26
+ if (input.length === 1 && index < length - 1) {
27
+ currentTarget[index + 1]?.focus();
28
+ }
29
+ if (input.length === 0 && index > 0) {
30
+ currentTarget[index - 1]?.focus();
31
+ }
32
+ if (newPin.every((digit) => digit !== '')) {
33
+ onComplete(newPin.join(''));
34
+ currentTarget[index].blur();
35
+ }
36
+ };
37
+ const handlePaste = (index) => (e) => {
38
+ setErrorMessage('');
39
+ const value = e.clipboardData?.getData('text');
40
+ const updatedValue = value
41
+ .toString()
42
+ .replace(/\D/g, '')
43
+ .split('')
44
+ .slice(0, length);
45
+ setOtp(updatedValue);
46
+ if (updatedValue.length === length) {
47
+ handleComplete(updatedValue, index);
48
+ }
49
+ };
50
+ const goToFirstEmptyInput = () => {
51
+ const firstEmptyInput = currentTarget.findIndex((el) => el.value === '');
52
+ firstEmptyInput >= 0
53
+ ?
54
+ currentTarget[firstEmptyInput].focus()
55
+ :
56
+ currentTarget[length - 1].focus();
57
+ setErrorMessage('');
58
+ };
59
+ const handleBackspace = (index) => (e) => {
60
+ if (e.key === 'Backspace' &&
61
+ index !== 0 &&
62
+ currentTarget[index].value.length === 0) {
63
+ currentTarget[index - 1]?.focus();
64
+ }
65
+ };
66
+ const handleKeyDown = (e) => {
67
+ if (Number.parseInt(e.key) >= 0) {
68
+ goToFirstEmptyInput();
69
+ }
70
+ };
71
+ const inputMods = [
72
+ 'otp__input',
73
+ { 'otp__input--error': errorMessage },
74
+ ];
75
+ (0, react_1.useEffect)(() => {
76
+ !loading && currentTarget[0].focus();
77
+ }, [responseReceived, loading, currentTarget]);
78
+ (0, react_1.useEffect)(() => {
79
+ if (responseReceived) {
80
+ setOtp(Array(length).fill(''));
81
+ }
82
+ }, [responseReceived, length]);
83
+ return ((0, jsx_runtime_1.jsxs)("div", { className: 'otp', children: [Array.from({ length }, (_, index) => ((0, jsx_runtime_1.jsx)("input", { value: Otp[index], onChange: handleTextChange(index), onPaste: handlePaste(index), onKeyUp: handleBackspace(index), onKeyDown: handleKeyDown, onClick: goToFirstEmptyInput, ref: (ref) => (currentTarget[index] = ref), type: 'text', maxLength: 1, className: (0, classnames_1.default)(inputMods), tabIndex: index + 1 }, index))), errorMessage && ((0, jsx_runtime_1.jsx)("span", { className: 'otp__error', children: errorMessage }))] }));
84
+ };
85
+ exports.OtpInput = OtpInput;
@@ -0,0 +1,7 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.otpError = exports.OtpInput = void 0;
4
+ var OtpInput_1 = require("./OtpInput");
5
+ Object.defineProperty(exports, "OtpInput", { enumerable: true, get: function () { return OtpInput_1.OtpInput; } });
6
+ var ErrorMessages_1 = require("./ErrorMessages");
7
+ Object.defineProperty(exports, "otpError", { enumerable: true, get: function () { return ErrorMessages_1.otpError; } });
@@ -0,0 +1,39 @@
1
+ $border-color: $neutral-border-low;
2
+ $border-color-focus: $primary-border-high;
3
+ $error-message: $error-high;
4
+ $border-error: $error-border-high;
5
+
6
+ .otp {
7
+ display: flex;
8
+ gap: 8px;
9
+ position: relative;
10
+
11
+ &__input {
12
+ font-size: 16px;
13
+ line-height: 24px;
14
+ height: 44px;
15
+ width: 36px;
16
+ border: 1px solid $border-color;
17
+ border-radius: 4px;
18
+ text-align: center;
19
+ outline: none;
20
+
21
+ &:focus,
22
+ :active {
23
+ border-color: $border-color-focus;
24
+ }
25
+
26
+ &--error,
27
+ &--error:focus {
28
+ border-color: $border-error;
29
+ }
30
+ }
31
+ &__error {
32
+ font-size: 12px;
33
+ line-height: 16px;
34
+ color: $error-message;
35
+ position: absolute;
36
+ bottom: -16px;
37
+ left: 0;
38
+ }
39
+ }
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notCorrectPasswordError = exports.emptyPasswordError = void 0;
4
+ exports.emptyPasswordError = 'Введите пароль';
5
+ exports.notCorrectPasswordError = 'Введите пароль не менее 6 символов';
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.PasswordField = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const fp_1 = __importDefault(require("lodash/fp"));
9
+ const react_1 = require("react");
10
+ const customValidators_1 = require("../../tools/customValidators");
11
+ const TextField_1 = require("../TextField");
12
+ const ErrorMessages_1 = require("./ErrorMessages");
13
+ const PasswordField = (props) => {
14
+ const { onValidated, onPasswordInput, hidePassword = true, } = props;
15
+ const [errorMessage, setErrorMessage] = (0, react_1.useState)('');
16
+ const [touched, setTouched] = (0, react_1.useState)(false);
17
+ const [password, setPassword] = (0, react_1.useState)('');
18
+ (0, react_1.useEffect)(() => {
19
+ if (!touched) {
20
+ return;
21
+ }
22
+ onPasswordInput(password);
23
+ const valid = (0, customValidators_1.passwordValidator)(password);
24
+ if (!valid) {
25
+ onValidated(false);
26
+ setErrorMessage(fp_1.default.cond([
27
+ [() => !password, () => ErrorMessages_1.emptyPasswordError],
28
+ [() => !valid, () => ErrorMessages_1.notCorrectPasswordError],
29
+ ]));
30
+ return;
31
+ }
32
+ onValidated(true);
33
+ setErrorMessage('');
34
+ }, [
35
+ password,
36
+ onPasswordInput,
37
+ onValidated,
38
+ touched
39
+ ]);
40
+ return ((0, jsx_runtime_1.jsx)(TextField_1.TextField, { onChange: setPassword, onTouched: setTouched, state: touched && errorMessage ? 'error' : 'idle', errorMessage: errorMessage, label: '\u041F\u0430\u0440\u043E\u043B\u044C', type: hidePassword ? 'password' : 'text', value: password, eyeIcon: true, checkIcon: true, required: true, ...props }));
41
+ };
42
+ exports.PasswordField = PasswordField;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notCorrectPasswordError = exports.emptyPasswordError = exports.PasswordField = void 0;
4
+ var PasswordField_1 = require("./PasswordField");
5
+ Object.defineProperty(exports, "PasswordField", { enumerable: true, get: function () { return PasswordField_1.PasswordField; } });
6
+ var ErrorMessages_1 = require("./ErrorMessages");
7
+ Object.defineProperty(exports, "emptyPasswordError", { enumerable: true, get: function () { return ErrorMessages_1.emptyPasswordError; } });
8
+ Object.defineProperty(exports, "notCorrectPasswordError", { enumerable: true, get: function () { return ErrorMessages_1.notCorrectPasswordError; } });
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notCorrectPhoneError = exports.emptyPhoneError = void 0;
4
+ exports.emptyPhoneError = 'Введите номер телефона';
5
+ exports.notCorrectPhoneError = 'Номер телефона — 10 цифр';
@@ -0,0 +1,81 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.PhoneField = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const fp_1 = __importDefault(require("lodash/fp"));
9
+ const react_1 = require("react");
10
+ const customValidators_1 = require("../../tools/customValidators");
11
+ const TextField_1 = require("../TextField");
12
+ const ErrorMessages_1 = require("./ErrorMessages");
13
+ const PhoneField = (props) => {
14
+ const { onValidated, onTextValid } = props;
15
+ const [errorMessage, setErrorMessage] = (0, react_1.useState)('');
16
+ const [touched, setTouched] = (0, react_1.useState)(false);
17
+ const [phoneNumber, setPhoneNumber] = (0, react_1.useState)('');
18
+ const getInputNumbersValue = (value) => {
19
+ return value.replace(/\D/g, '');
20
+ };
21
+ const onPhoneInput = (value, e) => {
22
+ const { target } = e;
23
+ const { selectionStart } = target;
24
+ let inputNumbersValue = getInputNumbersValue(value);
25
+ let formattedInputValue = '';
26
+ const { data, inputType } = e.nativeEvent;
27
+ if (inputType === 'deleteContentBackward' && value.length === 0) {
28
+ setPhoneNumber('');
29
+ return;
30
+ }
31
+ if (value.length !== selectionStart) {
32
+ if (data === null || /\d/g.test(data)) {
33
+ setPhoneNumber(value);
34
+ }
35
+ return;
36
+ }
37
+ if (['7', '8', '9'].includes(inputNumbersValue[0])) {
38
+ if (inputNumbersValue[0] === '9')
39
+ inputNumbersValue = '7' + inputNumbersValue;
40
+ const firstSymbols = (inputNumbersValue[0] === '8') ? '8' : '+7';
41
+ formattedInputValue = firstSymbols;
42
+ if (inputNumbersValue.length > 1) {
43
+ formattedInputValue += '(' + inputNumbersValue.substring(1, 4);
44
+ }
45
+ if (inputNumbersValue.length >= 5) {
46
+ formattedInputValue += ')' + inputNumbersValue.substring(4, 7);
47
+ }
48
+ if (inputNumbersValue.length >= 8) {
49
+ formattedInputValue += '-' + inputNumbersValue.substring(7, 9);
50
+ }
51
+ if (inputNumbersValue.length >= 10) {
52
+ formattedInputValue += '-' + inputNumbersValue.substring(9, 11);
53
+ }
54
+ }
55
+ else {
56
+ formattedInputValue = '+' + inputNumbersValue.substring(0, 16);
57
+ }
58
+ setPhoneNumber(formattedInputValue);
59
+ };
60
+ (0, react_1.useEffect)(() => {
61
+ if (!touched) {
62
+ return;
63
+ }
64
+ const valid = (0, customValidators_1.phoneValidator)(phoneNumber);
65
+ if (!valid) {
66
+ onValidated(false);
67
+ onTextValid('');
68
+ setErrorMessage(fp_1.default.cond([
69
+ [fp_1.default.isEmpty, () => ErrorMessages_1.emptyPhoneError],
70
+ [() => !valid, () => ErrorMessages_1.notCorrectPhoneError],
71
+ [fp_1.default.stubTrue, fp_1.default.stubString]
72
+ ]));
73
+ return;
74
+ }
75
+ onValidated(true);
76
+ onTextValid(phoneNumber.replace(/\D/g, ''));
77
+ setErrorMessage('');
78
+ }, [onTextValid, onValidated, phoneNumber, touched]);
79
+ return ((0, jsx_runtime_1.jsx)(TextField_1.TextField, { onChange: onPhoneInput, onTouched: setTouched, state: touched && errorMessage ? 'error' : 'idle', errorMessage: errorMessage, label: '\u041C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0435\u043B\u0435\u0444\u043E\u043D', type: 'tel', value: phoneNumber, required: true, checkIcon: true, ...props }));
80
+ };
81
+ exports.PhoneField = PhoneField;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notCorrectPhoneError = exports.emptyPhoneError = exports.PhoneField = void 0;
4
+ var PhoneField_1 = require("./PhoneField");
5
+ Object.defineProperty(exports, "PhoneField", { enumerable: true, get: function () { return PhoneField_1.PhoneField; } });
6
+ var ErrorMessages_1 = require("./ErrorMessages");
7
+ Object.defineProperty(exports, "emptyPhoneError", { enumerable: true, get: function () { return ErrorMessages_1.emptyPhoneError; } });
8
+ Object.defineProperty(exports, "notCorrectPhoneError", { enumerable: true, get: function () { return ErrorMessages_1.notCorrectPhoneError; } });
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notCorrectRepeatPasswordError = exports.emptyRepeatPasswordError = void 0;
4
+ exports.emptyRepeatPasswordError = 'Введите пароль повторно';
5
+ exports.notCorrectRepeatPasswordError = 'Пароли не совпадают';
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.RepeatPasswordField = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const fp_1 = __importDefault(require("lodash/fp"));
9
+ const react_1 = require("react");
10
+ const TextField_1 = require("../TextField");
11
+ const ErrorMessages_1 = require("./ErrorMessages");
12
+ const RepeatPasswordField = (props) => {
13
+ const { equalHandler, comparedValue } = props;
14
+ const [touched, setTouched] = (0, react_1.useState)(false);
15
+ const [password, setPassword] = (0, react_1.useState)('');
16
+ const [errorMessage, setErrorMessage] = (0, react_1.useState)('');
17
+ (0, react_1.useEffect)(() => {
18
+ equalHandler(comparedValue === password);
19
+ if (!touched) {
20
+ return;
21
+ }
22
+ setErrorMessage(fp_1.default.cond([
23
+ [() => !password, () => ErrorMessages_1.emptyRepeatPasswordError],
24
+ [() => comparedValue !== password, () => ErrorMessages_1.notCorrectRepeatPasswordError],
25
+ ]));
26
+ }, [touched, password, comparedValue, equalHandler]);
27
+ return ((0, jsx_runtime_1.jsx)(TextField_1.TextField, { onChange: setPassword, onTouched: setTouched, state: touched && errorMessage ? 'error' : 'idle', errorMessage: errorMessage, label: '\u041F\u043E\u0432\u0442\u043E\u0440\u0438\u0442\u0435 \u043F\u0430\u0440\u043E\u043B\u044C', type: 'password', value: password, eyeIcon: true, checkIcon: true, required: true, ...props }));
28
+ };
29
+ exports.RepeatPasswordField = RepeatPasswordField;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.notCorrectRepeatPasswordError = exports.emptyRepeatPasswordError = exports.RepeatPasswordField = void 0;
4
+ var RepeatPasswordField_1 = require("./RepeatPasswordField");
5
+ Object.defineProperty(exports, "RepeatPasswordField", { enumerable: true, get: function () { return RepeatPasswordField_1.RepeatPasswordField; } });
6
+ var ErrorMessages_1 = require("./ErrorMessages");
7
+ Object.defineProperty(exports, "emptyRepeatPasswordError", { enumerable: true, get: function () { return ErrorMessages_1.emptyRepeatPasswordError; } });
8
+ Object.defineProperty(exports, "notCorrectRepeatPasswordError", { enumerable: true, get: function () { return ErrorMessages_1.notCorrectRepeatPasswordError; } });
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Collapse = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const classnames_1 = __importDefault(require("classnames"));
9
+ const react_1 = require("react");
10
+ const chevron_down_svg_1 = __importDefault(require("../../assets/img/chevron-down.svg"));
11
+ const Option_1 = require("./Option/Option");
12
+ const Collapse = (props) => {
13
+ const { options, selected, title, onSelect, chevron = true, optionsIcon, closeOnClick = true, } = props;
14
+ const [isOpen, setIsOpen] = (0, react_1.useState)(false);
15
+ const rootRef = (0, react_1.useRef)(null);
16
+ const titleRef = (0, react_1.useRef)(null);
17
+ (0, react_1.useEffect)(() => {
18
+ const handleClick = (event) => {
19
+ const { target } = event;
20
+ if (target instanceof Node &&
21
+ rootRef.current &&
22
+ !rootRef.current.contains(target)) {
23
+ closeOnClick && setIsOpen(false);
24
+ }
25
+ };
26
+ window.addEventListener('click', handleClick);
27
+ return () => {
28
+ window.removeEventListener('click', handleClick);
29
+ };
30
+ }, [closeOnClick, isOpen]);
31
+ const handleOptionClick = (value) => {
32
+ closeOnClick && setIsOpen(false);
33
+ onSelect(value);
34
+ };
35
+ const handleTitleClick = () => {
36
+ setIsOpen(!isOpen);
37
+ };
38
+ const chevronMods = [
39
+ 'title__chevron',
40
+ isOpen && 'title__chevron--rotate',
41
+ ];
42
+ const optionsBlock = ((0, jsx_runtime_1.jsx)("div", { className: 'selector__options selector__options--slide-down', children: options.map((option) => ((0, jsx_runtime_1.jsx)(Option_1.Option, { option: option, onClick: handleOptionClick, optionsIcon: optionsIcon, selected: option.value === selected?.value }, option.value))) }));
43
+ const hasIcon = optionsIcon !== undefined || selected?.icon !== undefined;
44
+ const label = selected ? ((0, jsx_runtime_1.jsxs)("div", { className: 'title__label', children: [hasIcon && ((0, jsx_runtime_1.jsx)("div", { className: 'title__icon', children: selected?.icon ?? optionsIcon })), selected.label] })) : title;
45
+ return ((0, jsx_runtime_1.jsxs)("div", { className: 'selector', ref: rootRef, children: [(0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)('title', isOpen && 'title--active'), onClick: handleTitleClick, ref: titleRef, children: [label, chevron && ((0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)(chevronMods), children: (0, jsx_runtime_1.jsx)(chevron_down_svg_1.default, {}) }))] }), isOpen && optionsBlock] }));
46
+ };
47
+ exports.Collapse = Collapse;
@@ -0,0 +1,88 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Dropdown = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const classnames_1 = __importDefault(require("classnames"));
9
+ const react_1 = require("react");
10
+ const getCoords_1 = require("../../tools/getCoords");
11
+ const Utils_1 = require("../../Utils");
12
+ const Option_1 = require("./Option/Option");
13
+ const Dropdown = (props) => {
14
+ const { options, selected, title, onSelect, optionsIcon, optionsMaxHeight, optionsDirection = 'down', noFlip = false, } = props;
15
+ const [isOpen, setIsOpen] = (0, react_1.useState)(false);
16
+ const [direction, setDirection] = (0, react_1.useState)(optionsDirection);
17
+ const [maxHeight, setMaxHeight] = (0, react_1.useState)(optionsMaxHeight);
18
+ const rootRef = (0, react_1.useRef)(null);
19
+ const titleRef = (0, react_1.useRef)(null);
20
+ const optionsRef = (0, react_1.useRef)(null);
21
+ const titleCoords = (0, getCoords_1.getCoords)(titleRef);
22
+ (0, react_1.useEffect)(() => {
23
+ const handleClick = (event) => {
24
+ const { target } = event;
25
+ if (target instanceof Node &&
26
+ rootRef.current &&
27
+ !rootRef.current.contains(target)) {
28
+ setIsOpen(false);
29
+ }
30
+ };
31
+ window.addEventListener('click', handleClick);
32
+ return () => {
33
+ window.removeEventListener('click', handleClick);
34
+ };
35
+ }, [isOpen]);
36
+ (0, react_1.useEffect)(() => {
37
+ if (!optionsRef.current || !titleCoords) {
38
+ return;
39
+ }
40
+ const { topViewport: distanceToTop, bottomViewport } = titleCoords;
41
+ const windowHeight = window.innerHeight;
42
+ const optionsHeight = optionsRef.current.offsetHeight;
43
+ const distanceToBottom = windowHeight - bottomViewport;
44
+ const isDownDirection = optionsDirection === 'down';
45
+ setDirection(optionsDirection);
46
+ setMaxHeight(isDownDirection ? distanceToBottom : distanceToTop);
47
+ if (noFlip) {
48
+ return;
49
+ }
50
+ const hasSpaceToOptionsBelow = distanceToBottom - optionsHeight > 0;
51
+ const hasSpaceToOptionsAbove = distanceToTop - optionsHeight > 0;
52
+ const oppositeDirection = isDownDirection ? 'up' : 'down';
53
+ if (isDownDirection &&
54
+ !hasSpaceToOptionsBelow &&
55
+ hasSpaceToOptionsAbove) {
56
+ setDirection(oppositeDirection);
57
+ setMaxHeight(distanceToTop);
58
+ return;
59
+ }
60
+ if (!isDownDirection &&
61
+ !hasSpaceToOptionsAbove &&
62
+ hasSpaceToOptionsBelow) {
63
+ setDirection(oppositeDirection);
64
+ setMaxHeight(distanceToBottom);
65
+ }
66
+ }, [isOpen, noFlip, optionsDirection, titleCoords]);
67
+ const handleOptionClick = (value) => {
68
+ setIsOpen(false);
69
+ onSelect(value);
70
+ };
71
+ const handleTitleClick = () => {
72
+ setIsOpen(!isOpen);
73
+ };
74
+ const optionsPosition = {
75
+ position: 'absolute',
76
+ left: `${titleCoords?.leftDocument ?? 0}px`,
77
+ minWidth: `${titleCoords?.width ?? 0}px`,
78
+ maxHeight: `${optionsMaxHeight ?? maxHeight}px`,
79
+ ...(direction === 'down'
80
+ ? { top: `${titleCoords?.bottomDocument ?? 0}px` }
81
+ : { bottom: `${window?.innerHeight - (titleCoords?.topDocument ?? 0)}px` }),
82
+ };
83
+ const optionsBlock = titleCoords && ((0, jsx_runtime_1.jsx)("div", { className: `selector__options selector__options--slide-${direction}`, style: { ...optionsPosition }, ref: optionsRef, children: options.map((option) => ((0, jsx_runtime_1.jsx)(Option_1.Option, { option: option, onClick: handleOptionClick, optionsIcon: optionsIcon, selected: option.value === selected?.value }, option.value))) }));
84
+ const hasIcon = optionsIcon !== undefined || selected?.icon !== undefined;
85
+ const label = selected ? ((0, jsx_runtime_1.jsxs)("div", { className: 'title__label', children: [hasIcon && ((0, jsx_runtime_1.jsx)("div", { className: 'title__icon', children: selected?.icon ?? optionsIcon })), selected.label] })) : title;
86
+ return ((0, jsx_runtime_1.jsxs)("div", { className: 'selector', ref: rootRef, children: [(0, jsx_runtime_1.jsx)("div", { className: (0, classnames_1.default)('title', isOpen && 'title--active'), onClick: handleTitleClick, ref: titleRef, children: label }), isOpen && (0, jsx_runtime_1.jsx)(Utils_1.Portal, { children: optionsBlock })] }));
87
+ };
88
+ exports.Dropdown = Dropdown;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Option = void 0;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const classnames_1 = __importDefault(require("classnames"));
9
+ const Option = (props) => {
10
+ const { option: { value, label, icon }, onClick, selected = false, optionsIcon, } = props;
11
+ const handleClick = (clickedValue) => () => {
12
+ onClick(clickedValue);
13
+ };
14
+ const hasIcon = optionsIcon !== undefined || icon !== undefined;
15
+ return ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)('selector-option', selected && 'selector-option--selected'), onClick: handleClick(value), children: [hasIcon && ((0, jsx_runtime_1.jsx)("div", { className: 'selector-option__icon', children: icon ?? optionsIcon })), label] }));
16
+ };
17
+ exports.Option = Option;
@@ -0,0 +1,44 @@
1
+ $option-bg: $color-neutral-gray;
2
+ $option-bg-hover: $neutral-A8;
3
+ $option-bg-selected: $primary-A12;
4
+ $option-text: $neutral-high;
5
+ $option-text-selected: $primary-high;
6
+ $option-icon: $neutral-high;
7
+ $option-icon-selected: $primary-high;
8
+
9
+ .selector-option {
10
+ cursor: pointer;
11
+
12
+ display: flex;
13
+ align-items: center;
14
+
15
+ padding: 8px 12px;
16
+
17
+ color: $option-text;
18
+
19
+ background: $option-bg;
20
+ border-radius: 4px;
21
+
22
+ fill: $option-icon;
23
+
24
+ &:hover {
25
+ background: $option-bg-hover;
26
+ transition: background-color 0.2s;
27
+ }
28
+
29
+ &--selected {
30
+ color: $option-text-selected;
31
+ background: $option-bg-selected;
32
+ fill: $option-icon-selected;
33
+
34
+ &:hover {
35
+ background: $option-bg-selected;
36
+ }
37
+ }
38
+
39
+ &__icon {
40
+ display: flex;
41
+ width: 20px;
42
+ padding-right: 8px;
43
+ }
44
+ }
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Dropdown = exports.Collapse = exports.Option = void 0;
4
+ var Option_1 = require("./Option/Option");
5
+ Object.defineProperty(exports, "Option", { enumerable: true, get: function () { return Option_1.Option; } });
6
+ var Collapse_1 = require("./Collapse");
7
+ Object.defineProperty(exports, "Collapse", { enumerable: true, get: function () { return Collapse_1.Collapse; } });
8
+ var Dropdown_1 = require("./Dropdown");
9
+ Object.defineProperty(exports, "Dropdown", { enumerable: true, get: function () { return Dropdown_1.Dropdown; } });