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,3 @@
1
+ export { Option, } from './Option/Option';
2
+ export { Collapse } from './Collapse';
3
+ export { Dropdown } from './Dropdown';
@@ -0,0 +1,101 @@
1
+ $title-bg: transparent;
2
+ $title-bg-hover: $neutral-A8;
3
+ $title-bg-active: $neutral-A12;
4
+ $title-text: $neutral-high;
5
+ $title-icon: $neutral-high;
6
+ $title-border: $neutral-border-low;
7
+ $options-bg: $color-neutral-gray;
8
+
9
+ .selector {
10
+ @keyframes slide-down {
11
+ from {
12
+ transform: translateY(-5%);
13
+ opacity: 0;
14
+ }
15
+
16
+ to {
17
+ transform: translateY(0);
18
+ opacity: 1;
19
+ }
20
+ }
21
+
22
+ @keyframes slide-up {
23
+ from {
24
+ transform: translateY(5%);
25
+ opacity: 0;
26
+ }
27
+
28
+ to {
29
+ transform: translateY(0);
30
+ opacity: 1;
31
+ }
32
+ }
33
+
34
+ width: 200px;
35
+
36
+ .title {
37
+ cursor: pointer;
38
+
39
+ display: flex;
40
+ align-items: center;
41
+ justify-content: space-between;
42
+
43
+ padding: 8px 12px;
44
+
45
+ color: $title-text;
46
+
47
+ background: $title-bg;
48
+ border-radius: 4px;
49
+
50
+ transition: background-color 0.2s;
51
+
52
+ &:hover {
53
+ background: $title-bg-hover;
54
+ }
55
+
56
+ &--active {
57
+ background: $title-bg-active;
58
+ border-bottom: 1px solid $title-border;
59
+ border-radius: 4px 4px 0 0;
60
+ &:hover {
61
+ background: $title-bg-active;
62
+ }
63
+ }
64
+
65
+ &__label {
66
+ display: flex;
67
+ }
68
+
69
+ &__icon {
70
+ display: flex;
71
+ width: 20px;
72
+ padding-right: 8px;
73
+ fill: $title-icon;
74
+ }
75
+
76
+ &__chevron {
77
+ display: flex;
78
+ align-items: center;
79
+ fill: $title-icon;
80
+ transition: all 200ms;
81
+
82
+ &--rotate {
83
+ transform: rotate(180deg);
84
+ }
85
+ }
86
+ }
87
+
88
+ &__options {
89
+ overflow: auto;
90
+ background: $options-bg;
91
+ border-radius: 0 0 4px 4px;
92
+
93
+ &--slide-up {
94
+ animation: slide-up 0.2s forwards;
95
+ }
96
+
97
+ &--slide-down {
98
+ animation: slide-down 0.2s forwards;
99
+ }
100
+ }
101
+ }
@@ -0,0 +1,25 @@
1
+ import { type InputHTMLAttributes } from 'react';
2
+ export type THTMLInput = Pick<InputHTMLAttributes<HTMLInputElement>, 'className' | 'placeholder' | 'tabIndex' | 'maxLength' | 'required'>;
3
+ export type TTextFieldType = 'text' | 'password' | 'tel' | 'email';
4
+ export type TTextFieldSize = 'medium' | 'large';
5
+ export type TTextFieldState = 'idle' | 'error' | 'disabled';
6
+ export interface ITextField extends THTMLInput {
7
+ label?: string;
8
+ value: string;
9
+ description?: string;
10
+ errorMessage?: string;
11
+ type?: TTextFieldType;
12
+ size?: TTextFieldSize;
13
+ state?: TTextFieldState;
14
+ onChange?: (value: string, e: React.ChangeEvent<HTMLInputElement>) => void;
15
+ onClear?: () => void;
16
+ onVisibilityToggle?: () => void;
17
+ onTouched?: (state: boolean) => void;
18
+ autoFocus?: boolean;
19
+ checkIcon?: boolean;
20
+ clearIcon?: boolean;
21
+ eyeIcon?: boolean;
22
+ searchIcon?: boolean;
23
+ alwaysShowError?: boolean;
24
+ }
25
+ export declare const TextField: (props: ITextField) => JSX.Element;
@@ -0,0 +1,85 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import cn from 'classnames';
3
+ import _ from 'lodash/fp';
4
+ import { useEffect, useRef, useState, } from 'react';
5
+ import CheckIcon from '../../assets/img/check.svg';
6
+ import CrossIcon from '../../assets/img/cross.svg';
7
+ import EyeCloseIcon from '../../assets/img/eye-close.svg';
8
+ import EyeOpenIcon from '../../assets/img/eye-open.svg';
9
+ import SearchIcon from '../../assets/img/search.svg';
10
+ import styles from './textField.module.scss';
11
+ export const TextField = (props) => {
12
+ const { label, value, description, className, placeholder, type = 'text', size = 'large', state = 'idle', tabIndex, maxLength, errorMessage, onChange = _.noop, onClear = _.noop, onVisibilityToggle = _.noop, onTouched = _.noop, required = false, autoFocus = false, checkIcon = false, clearIcon = false, eyeIcon = false, searchIcon = false, alwaysShowError = false, } = props;
13
+ const ref = useRef(null);
14
+ const [focused, setFocused] = useState(false);
15
+ const [inputType, setInputType] = useState(type);
16
+ useEffect(() => {
17
+ setInputType(type);
18
+ }, [type]);
19
+ useEffect(() => {
20
+ if (autoFocus) {
21
+ setFocused(true);
22
+ ref.current?.focus();
23
+ }
24
+ }, [autoFocus]);
25
+ const onChangeHandler = (e) => {
26
+ onChange(e.target.value, e);
27
+ };
28
+ const toggleVisibility = () => {
29
+ const newType = inputType === 'password' ? 'text' : 'password';
30
+ setInputType(newType);
31
+ onVisibilityToggle();
32
+ };
33
+ const onBlur = () => {
34
+ setFocused(false);
35
+ };
36
+ const onFocus = () => {
37
+ setFocused(true);
38
+ onTouched(true);
39
+ };
40
+ const disabledState = state === 'disabled';
41
+ const wrapperSizeClassBySize = {
42
+ medium: styles.textFieldWrapperMedium,
43
+ large: styles.textFieldWrapperLarge,
44
+ };
45
+ const labelSizeClassBySize = {
46
+ medium: styles.textFieldWrapperLabelMedium,
47
+ large: styles.textFieldWrapperLabelLarge,
48
+ };
49
+ const inputSizeClassBySize = {
50
+ medium: styles.textFieldInputMedium,
51
+ large: styles.textFieldInputLarge,
52
+ };
53
+ const iconsSizeClassBySize = {
54
+ medium: styles.textFieldIconsMedium,
55
+ large: styles.textFieldIconsLarge,
56
+ };
57
+ const fieldSizeClassBySize = {
58
+ medium: styles.textFieldMedium,
59
+ large: styles.textFieldLarge,
60
+ };
61
+ const stateClassByState = {
62
+ idle: styles.textFieldIdle,
63
+ error: styles.textFieldError,
64
+ disabled: styles.textFieldDisabled,
65
+ };
66
+ const textFieldWrapperClassName = cn(styles.textFieldWrapper, wrapperSizeClassBySize[size]);
67
+ const textFieldClassName = cn(styles.textField, fieldSizeClassBySize[size], stateClassByState[state], {
68
+ [styles.textFieldFocused]: !alwaysShowError ? focused : state !== 'error',
69
+ }, className);
70
+ const inputClassName = cn(styles.textFieldInput, inputSizeClassBySize[size]);
71
+ const iconsClassName = cn(styles.textFieldIcons, iconsSizeClassBySize[size]);
72
+ const labelClassName = cn(styles.textFieldWrapperLabel, labelSizeClassBySize[size], { [styles.textFieldWrapperLabelDisabled]: disabledState });
73
+ const bottomText = () => {
74
+ const showError = !!errorMessage && (alwaysShowError || !focused);
75
+ if (!showError && !description) {
76
+ return;
77
+ }
78
+ return (_jsx("span", { className: cn(styles.textFieldWrapperBottomText, {
79
+ [styles.textFieldWrapperBottomTextDescription]: !!description,
80
+ [styles.textFieldWrapperBottomTextError]: showError,
81
+ }), children: showError ? errorMessage : description }));
82
+ };
83
+ const input = (_jsxs("div", { className: textFieldClassName, children: [searchIcon && (_jsx("div", { className: iconsClassName, children: _jsx(SearchIcon, {}) })), _jsx("input", { ref: ref, type: inputType, value: value, onChange: onChangeHandler, className: inputClassName, onFocus: onFocus, onBlur: onBlur, placeholder: disabledState ? '' : placeholder, disabled: disabledState, onClick: onFocus, tabIndex: tabIndex, maxLength: maxLength }), (checkIcon && value && !errorMessage && !disabledState) && (_jsx("div", { id: 'check-icon', className: iconsClassName, children: _jsx(CheckIcon, {}) })), clearIcon && value && !disabledState && (_jsx("div", { className: [iconsClassName, 'cursor-pointer'].join(' '), onClick: onClear, children: _jsx(CrossIcon, {}) })), eyeIcon && !disabledState && (_jsx("div", { id: 'eye-icon', className: [iconsClassName, 'cursor-pointer'].join(' '), onClick: toggleVisibility, children: inputType === 'password' ? _jsx(EyeOpenIcon, {}) : _jsx(EyeCloseIcon, {}) }))] }));
84
+ return (_jsxs("div", { className: textFieldWrapperClassName, children: [label && (_jsxs("div", { className: labelClassName, children: [label, required && (_jsx("span", { className: 'text-field-wrapper__label--required', children: "*" }))] })), input, bottomText()] }));
85
+ };
@@ -0,0 +1 @@
1
+ export { TextField, type ITextField, type THTMLInput, type TTextFieldType } from './TextField';
@@ -0,0 +1 @@
1
+ export { TextField } from './TextField';
@@ -0,0 +1,157 @@
1
+ @use 'sass:color';
2
+ @use '@/assets/scss' as *;
3
+
4
+ $border-inactive: $neutral-border-low;
5
+ $border-hover: $neutral-border-middle;
6
+ $border-focus: $primary-border-high;
7
+ $border-disabled: $neutral-border-low;
8
+ $border-error: $error-border-high;
9
+ $border-error-hover: $error-border-middle;
10
+
11
+ $label: $neutral-middle;
12
+ $label-disabled: $neutral-A48;
13
+ $label-required: $primary-high;
14
+
15
+ $placeholder: $neutral-low;
16
+ $value: $neutral-high;
17
+ $value-disabled: $neutral-A48;
18
+
19
+ $icons: $neutral-middle;
20
+
21
+ $description: $neutral-middle;
22
+ $description-error: $error-high;
23
+
24
+ .text-field-wrapper {
25
+ position: relative;
26
+ display: flex;
27
+ flex-direction: column;
28
+ font-family: 'Roboto Regular', sans-serif;
29
+
30
+ &__label {
31
+ line-height: 20px;
32
+ color: $label;
33
+
34
+ &--medium {
35
+ font-size: 12px;
36
+ }
37
+
38
+ &--large {
39
+ font-size: 14px;
40
+ }
41
+
42
+ &--required {
43
+ padding-left: 4px;
44
+ color: $label-required;
45
+ }
46
+
47
+ &--disabled {
48
+ color: $label-disabled;
49
+ }
50
+ }
51
+
52
+ &__bottom-text {
53
+ position: absolute;
54
+ bottom: -16px;
55
+ left: 0;
56
+ font-size: 12px;
57
+ line-height: 16px;
58
+
59
+
60
+ &--description {
61
+ color: $description;
62
+ }
63
+
64
+ &--error {
65
+ color: $description-error;
66
+ }
67
+ }
68
+ }
69
+
70
+ .text-field {
71
+ display: flex;
72
+ align-items: center;
73
+
74
+ max-width: 400px;
75
+ padding: 0 12px;
76
+
77
+ border: 1px solid $border-inactive;
78
+ border-radius: 4px;
79
+
80
+ &--medium {
81
+ height: 36px;
82
+ }
83
+
84
+ &--large {
85
+ height: 44px;
86
+ }
87
+
88
+ &--idle {
89
+ &:hover {
90
+ border: 1px solid $border-hover;
91
+ }
92
+ }
93
+
94
+ &--error {
95
+ border: 1px solid $border-error;
96
+
97
+ &:hover {
98
+ border: 1px solid $border-error-hover;
99
+ }
100
+ }
101
+
102
+ &--disabled {
103
+ border: 1px solid $border-disabled;
104
+ }
105
+
106
+ &--focused {
107
+ border: 1px solid $border-focus;
108
+
109
+ &:hover {
110
+ border: 1px solid $border-focus;
111
+ }
112
+ }
113
+
114
+ &__input {
115
+ width: 100%;
116
+ height: 100%;
117
+ padding: 0 4px;
118
+
119
+ font-weight: 400;
120
+
121
+ background: none;
122
+ border: none;
123
+ outline: none;
124
+
125
+ &::placeholder {
126
+ color: $placeholder;
127
+ }
128
+
129
+ &--medium {
130
+ font-size: 14px;
131
+ line-height: 20px;
132
+ }
133
+
134
+ &--large {
135
+ font-size: 16px;
136
+ line-height: 24px;
137
+ }
138
+
139
+ &:disabled {
140
+ color: $value-disabled;
141
+ }
142
+ }
143
+
144
+ &__icons {
145
+ display: flex;
146
+ align-items: center;
147
+ fill: $icons;
148
+
149
+ &--medium {
150
+ width: 20px;
151
+ }
152
+
153
+ &--large {
154
+ width: 24px;
155
+ }
156
+ }
157
+ }
@@ -0,0 +1,156 @@
1
+ @use 'sass:color';
2
+
3
+ $border-inactive: $neutral-border-low;
4
+ $border-hover: $neutral-border-middle;
5
+ $border-focus: $primary-border-high;
6
+ $border-disabled: $neutral-border-low;
7
+ $border-error: $error-border-high;
8
+ $border-error-hover: $error-border-middle;
9
+
10
+ $label: $neutral-middle;
11
+ $label-disabled: $neutral-A48;
12
+ $label-required: $primary-high;
13
+
14
+ $placeholder: $neutral-low;
15
+ $value: $neutral-high;
16
+ $value-disabled: $neutral-A48;
17
+
18
+ $icons: $neutral-middle;
19
+
20
+ $description: $neutral-middle;
21
+ $description-error: $error-high;
22
+
23
+ .text-field-wrapper {
24
+ position: relative;
25
+ display: flex;
26
+ flex-direction: column;
27
+ font-family: 'Roboto Regular', sans-serif;
28
+
29
+ &__label {
30
+ line-height: 20px;
31
+ color: $label;
32
+
33
+ &--medium {
34
+ font-size: 12px;
35
+ }
36
+
37
+ &--large {
38
+ font-size: 14px;
39
+ }
40
+
41
+ &--required {
42
+ padding-left: 4px;
43
+ color: $label-required;
44
+ }
45
+
46
+ &--disabled {
47
+ color: $label-disabled;
48
+ }
49
+ }
50
+
51
+ &__bottom-text {
52
+ position: absolute;
53
+ bottom: -16px;
54
+ left: 0;
55
+ font-size: 12px;
56
+ line-height: 16px;
57
+
58
+
59
+ &--description {
60
+ color: $description;
61
+ }
62
+
63
+ &--error {
64
+ color: $description-error;
65
+ }
66
+ }
67
+ }
68
+
69
+ .text-field {
70
+ display: flex;
71
+ align-items: center;
72
+
73
+ max-width: 400px;
74
+ padding: 0 12px;
75
+
76
+ border: 1px solid $border-inactive;
77
+ border-radius: 4px;
78
+
79
+ &--medium {
80
+ height: 36px;
81
+ }
82
+
83
+ &--large {
84
+ height: 44px;
85
+ }
86
+
87
+ &--idle {
88
+ &:hover {
89
+ border: 1px solid $border-hover;
90
+ }
91
+ }
92
+
93
+ &--error {
94
+ border: 1px solid $border-error;
95
+
96
+ &:hover {
97
+ border: 1px solid $border-error-hover;
98
+ }
99
+ }
100
+
101
+ &--disabled {
102
+ border: 1px solid $border-disabled;
103
+ }
104
+
105
+ &--focused {
106
+ border: 1px solid $border-focus;
107
+
108
+ &:hover {
109
+ border: 1px solid $border-focus;
110
+ }
111
+ }
112
+
113
+ &__input {
114
+ width: 100%;
115
+ height: 100%;
116
+ padding: 0 4px;
117
+
118
+ font-weight: 400;
119
+
120
+ background: none;
121
+ border: none;
122
+ outline: none;
123
+
124
+ &::placeholder {
125
+ color: $placeholder;
126
+ }
127
+
128
+ &--medium {
129
+ font-size: 14px;
130
+ line-height: 20px;
131
+ }
132
+
133
+ &--large {
134
+ font-size: 16px;
135
+ line-height: 24px;
136
+ }
137
+
138
+ &:disabled {
139
+ color: $value-disabled;
140
+ }
141
+ }
142
+
143
+ &__icons {
144
+ display: flex;
145
+ align-items: center;
146
+ fill: $icons;
147
+
148
+ &--medium {
149
+ width: 20px;
150
+ }
151
+
152
+ &--large {
153
+ width: 24px;
154
+ }
155
+ }
156
+ }
@@ -0,0 +1,11 @@
1
+ export { Button, type IButton, type TButtonState } from './Button';
2
+ export { TextField, type ITextField } from './TextField';
3
+ export { Dropdown, Collapse, Option } from './Selector';
4
+ export { EmailField } from './EmailField';
5
+ export { NameField } from './NameField';
6
+ export { PhoneField } from './PhoneField';
7
+ export { PasswordField } from './PasswordField';
8
+ export { RepeatPasswordField } from './RepeatPasswordField';
9
+ export { OtpInput } from './OtpInput';
10
+ export { Checkbox } from './Checkbox';
11
+ export { InnField } from './InnField';
@@ -0,0 +1,11 @@
1
+ export { Button } from './Button';
2
+ export { TextField } from './TextField';
3
+ export { Dropdown, Collapse, Option } from './Selector';
4
+ export { EmailField } from './EmailField';
5
+ export { NameField } from './NameField';
6
+ export { PhoneField } from './PhoneField';
7
+ export { PasswordField } from './PasswordField';
8
+ export { RepeatPasswordField } from './RepeatPasswordField';
9
+ export { OtpInput } from './OtpInput';
10
+ export { Checkbox } from './Checkbox';
11
+ export { InnField } from './InnField';
@@ -0,0 +1,6 @@
1
+ @import './Button/button';
2
+ @import './TextField/textField';
3
+ @import './Selector/selector';
4
+ @import './Selector/Option/option';
5
+ @import './OtpInput/otpInput';
6
+ @import './Checkbox/checkbox';
@@ -0,0 +1,6 @@
1
+ import { type ReactNode } from 'react';
2
+ interface ContentPageProps {
3
+ children?: ReactNode;
4
+ }
5
+ export declare const ContentPage: ({ children }: ContentPageProps) => JSX.Element;
6
+ export {};
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useCallback, useState } from 'react';
3
+ import { SectionPlaceholder } from '../../Utils';
4
+ import { Header, Sidebar } from '../../Widgets';
5
+ export const ContentPage = ({ children }) => {
6
+ const [sidebarOpened, setSidebarOpened] = useState(false);
7
+ const [sidebarPinned, setSidebarPinned] = useState(false);
8
+ const onShowSidebar = () => {
9
+ setSidebarOpened(true);
10
+ };
11
+ const onCloseSidebar = useCallback(() => {
12
+ setSidebarOpened(false);
13
+ }, []);
14
+ const onPinSidebar = () => {
15
+ setSidebarPinned(true);
16
+ };
17
+ const onUnpinSidebar = () => {
18
+ setSidebarPinned(false);
19
+ onCloseSidebar();
20
+ };
21
+ return (_jsxs(_Fragment, { children: [_jsx(Header, { onShowSidebar: onShowSidebar, onCloseSidebar: onCloseSidebar, sidebarOpened: sidebarOpened, sidebarPinned: sidebarPinned }), _jsxs("div", { className: 'content-page__content', children: [sidebarOpened && (_jsx(Sidebar, { pinned: sidebarPinned, onPinSidebar: onPinSidebar, onUnpinSidebar: onUnpinSidebar })), _jsx("main", { className: 'content-page__main', children: children || _jsx(SectionPlaceholder, {}) })] })] }));
22
+ };
@@ -0,0 +1,10 @@
1
+ .content-page {
2
+ &__content {
3
+ display: flex;
4
+ overflow: hidden;
5
+ }
6
+
7
+ &__main {
8
+ width: 100%;
9
+ }
10
+ }
@@ -0,0 +1 @@
1
+ export { ContentPage } from './ContentPage';
@@ -0,0 +1 @@
1
+ export { ContentPage } from './ContentPage';
@@ -0,0 +1 @@
1
+ export declare const CreatePasswordPage: () => JSX.Element;
@@ -0,0 +1,47 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useState } from 'react';
3
+ import { useNavigate } from 'react-router-dom';
4
+ import { useAppSelector } from '../../app/store';
5
+ import { useCreatePasswordMutation, selectEmail } from '../../entities/user';
6
+ import { Button, RepeatPasswordField, PasswordField, } from '../../Inputs';
7
+ import { ErrorBanner } from '../../Utils';
8
+ export const CreatePasswordPage = () => {
9
+ const [password, setPassword] = useState('');
10
+ const [passwordValid, setPasswordValid] = useState(false);
11
+ const [passwordEqual, setPasswordEqual] = useState(false);
12
+ const [formValid, setFormValid] = useState(false);
13
+ const [hidePassword, setHidePassword] = useState(true);
14
+ const [createPassword, { isSuccess, isError, isLoading }] = useCreatePasswordMutation();
15
+ const navigate = useNavigate();
16
+ const email = useAppSelector(selectEmail);
17
+ useEffect(() => {
18
+ if (!hidePassword) {
19
+ setFormValid(passwordValid);
20
+ return;
21
+ }
22
+ setFormValid([passwordValid, passwordEqual].every(Boolean));
23
+ }, [passwordValid, passwordEqual, hidePassword]);
24
+ useEffect(() => {
25
+ if (isSuccess) {
26
+ void navigate('/');
27
+ }
28
+ }, [isSuccess, navigate]);
29
+ const getBtnState = () => {
30
+ if (isLoading)
31
+ return 'loading';
32
+ return formValid ? 'idle' : 'disabled';
33
+ };
34
+ const handleSendPassword = () => {
35
+ if (formValid && email) {
36
+ void createPassword({ email, password });
37
+ }
38
+ };
39
+ return (_jsxs("div", { className: 'create-password-page', children: [isLoading && _jsx("div", { className: 'email-confirmation-page__overlay' }), _jsx("h1", { className: 'create-password-page__title', children: "\u0421\u043E\u0437\u0434\u0430\u043D\u0438\u0435 \u043F\u0430\u0440\u043E\u043B\u044F" }), isError && (_jsx(ErrorBanner, { error: '\u041E\u0448\u0438\u0431\u043A\u0430 \u0441\u043E\u0437\u0434\u0430\u043D\u0438\u044F \u043F\u0430\u0440\u043E\u043B\u044F' })), _jsxs("form", { className: 'create-password-page__form', children: [_jsx(PasswordField, { onValidated: setPasswordValid, onPasswordInput: (password) => {
40
+ setPassword(password);
41
+ }, hidePassword: hidePassword, tabIndex: 1, onVisibilityToggle: () => {
42
+ setHidePassword(!hidePassword);
43
+ } }), hidePassword &&
44
+ _jsx(RepeatPasswordField, { comparedValue: password, equalHandler: setPasswordEqual, tabIndex: 2, onVisibilityToggle: () => {
45
+ setHidePassword(!hidePassword);
46
+ } }), _jsx(Button, { label: '\u0412\u043E\u0439\u0442\u0438 \u0432 CRM', size: 'large', state: getBtnState(), tabIndex: 3, fullWidth: true, onClick: handleSendPassword })] })] }));
47
+ };