torgbox-ui 1.0.7 → 1.0.8

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 (286) hide show
  1. package/dist/.storybook/decorators/ReduxDecorator.d.ts +2 -0
  2. package/dist/.storybook/decorators/ReduxDecorator.js +4 -0
  3. package/dist/.storybook/decorators/RouterDecorator.d.ts +2 -0
  4. package/dist/.storybook/decorators/RouterDecorator.js +3 -0
  5. package/dist/.storybook/decorators/index.d.ts +2 -0
  6. package/dist/.storybook/decorators/index.js +2 -0
  7. package/dist/src/Inputs/Button/Button.js +30 -0
  8. package/dist/src/Inputs/Button/Button.stories.d.ts +21 -0
  9. package/dist/src/Inputs/Button/Button.stories.js +210 -0
  10. package/dist/src/Inputs/Button/Icon.stories.d.ts +20 -0
  11. package/dist/src/Inputs/Button/Icon.stories.js +196 -0
  12. package/dist/src/Inputs/Button/button.scss +358 -0
  13. package/dist/src/Inputs/Button/index.js +1 -0
  14. package/dist/src/Inputs/Checkbox/Checkbox.js +29 -0
  15. package/dist/src/Inputs/Checkbox/Checkbox.stories.d.ts +11 -0
  16. package/dist/src/Inputs/Checkbox/Checkbox.stories.js +108 -0
  17. package/dist/src/Inputs/Checkbox/checkbox.scss +63 -0
  18. package/dist/src/Inputs/Checkbox/index.js +1 -0
  19. package/dist/src/Inputs/EmailField/EmailField.js +61 -0
  20. package/dist/src/Inputs/EmailField/EmailField.stories.d.ts +8 -0
  21. package/dist/src/Inputs/EmailField/EmailField.stories.js +43 -0
  22. package/dist/src/Inputs/EmailField/ErrorMessages.js +3 -0
  23. package/dist/src/Inputs/EmailField/index.js +2 -0
  24. package/dist/src/Inputs/InnField/ErrorMessages.js +1 -0
  25. package/dist/src/Inputs/InnField/InnField.js +33 -0
  26. package/dist/src/Inputs/InnField/InnField.stories.d.ts +8 -0
  27. package/dist/src/Inputs/InnField/InnField.stories.js +43 -0
  28. package/dist/src/Inputs/InnField/index.js +2 -0
  29. package/dist/src/Inputs/NameField/ErrorMessages.js +8 -0
  30. package/dist/src/Inputs/NameField/NameField.js +54 -0
  31. package/dist/src/Inputs/NameField/NameField.stories.d.ts +8 -0
  32. package/dist/src/Inputs/NameField/NameField.stories.js +43 -0
  33. package/dist/src/Inputs/NameField/index.js +2 -0
  34. package/dist/src/Inputs/OtpInput/ErrorMessages.js +1 -0
  35. package/dist/src/Inputs/OtpInput/OtpInput.js +78 -0
  36. package/dist/src/Inputs/OtpInput/OtpInput.stories.d.ts +8 -0
  37. package/dist/src/Inputs/OtpInput/OtpInput.stories.js +52 -0
  38. package/dist/src/Inputs/OtpInput/index.js +2 -0
  39. package/dist/src/Inputs/OtpInput/otpInput.scss +39 -0
  40. package/dist/src/Inputs/PasswordField/ErrorMessages.js +2 -0
  41. package/dist/src/Inputs/PasswordField/PasswordField.js +35 -0
  42. package/dist/src/Inputs/PasswordField/PasswordField.stories.d.ts +8 -0
  43. package/dist/src/Inputs/PasswordField/PasswordField.stories.js +43 -0
  44. package/dist/src/Inputs/PasswordField/index.js +2 -0
  45. package/dist/src/Inputs/PhoneField/ErrorMessages.js +2 -0
  46. package/dist/src/Inputs/PhoneField/PhoneField.js +74 -0
  47. package/dist/src/Inputs/PhoneField/PhoneField.stories.d.ts +8 -0
  48. package/dist/src/Inputs/PhoneField/PhoneField.stories.js +43 -0
  49. package/dist/src/Inputs/PhoneField/index.js +2 -0
  50. package/dist/src/Inputs/RepeatPasswordField/ErrorMessages.js +2 -0
  51. package/dist/src/Inputs/RepeatPasswordField/RepeatPasswordField.js +22 -0
  52. package/dist/src/Inputs/RepeatPasswordField/index.js +2 -0
  53. package/dist/src/Inputs/Selector/Collapse.js +40 -0
  54. package/dist/src/Inputs/Selector/Collapse.stories.d.ts +8 -0
  55. package/dist/src/Inputs/Selector/Collapse.stories.js +108 -0
  56. package/dist/src/Inputs/Selector/Dropdown.js +81 -0
  57. package/dist/src/Inputs/Selector/Dropdown.stories.d.ts +9 -0
  58. package/dist/src/Inputs/Selector/Dropdown.stories.js +103 -0
  59. package/dist/src/Inputs/Selector/Option/Option.js +10 -0
  60. package/dist/src/Inputs/Selector/Option/Option.stories.d.ts +9 -0
  61. package/dist/src/Inputs/Selector/Option/Option.stories.js +47 -0
  62. package/dist/src/Inputs/Selector/Option/option.scss +44 -0
  63. package/dist/src/Inputs/Selector/index.js +3 -0
  64. package/dist/src/Inputs/Selector/selector.scss +101 -0
  65. package/dist/src/Inputs/TextField/TextField.js +85 -0
  66. package/dist/src/Inputs/TextField/TextField.stories.d.ts +12 -0
  67. package/dist/src/Inputs/TextField/TextField.stories.js +101 -0
  68. package/dist/src/Inputs/TextField/index.js +1 -0
  69. package/dist/src/Inputs/TextField/textField.module.scss +157 -0
  70. package/dist/src/Inputs/TextField/textField.scss +156 -0
  71. package/dist/src/Inputs/index.js +11 -0
  72. package/dist/src/Inputs/index.scss +6 -0
  73. package/dist/src/Pages/ContentPage/ContentPage.js +22 -0
  74. package/dist/src/Pages/ContentPage/ContentPage.stories.d.ts +6 -0
  75. package/dist/src/Pages/ContentPage/ContentPage.stories.js +17 -0
  76. package/dist/src/Pages/ContentPage/contentPage.scss +10 -0
  77. package/dist/src/Pages/ContentPage/index.js +1 -0
  78. package/dist/src/Pages/CreatePasswordPage/CreatePasswordPage.js +47 -0
  79. package/dist/src/Pages/CreatePasswordPage/CreatePasswordPage.stories.d.ts +7 -0
  80. package/dist/src/Pages/CreatePasswordPage/CreatePasswordPage.stories.js +96 -0
  81. package/dist/src/Pages/CreatePasswordPage/createPasswordPage.scss +42 -0
  82. package/dist/src/Pages/CreatePasswordPage/index.js +1 -0
  83. package/dist/src/Pages/CreateTeamPage/CreateTeamPage.js +46 -0
  84. package/dist/src/Pages/CreateTeamPage/CreateTeamPage.stories.d.ts +7 -0
  85. package/dist/src/Pages/CreateTeamPage/CreateTeamPage.stories.js +82 -0
  86. package/dist/src/Pages/CreateTeamPage/createTeamPage.scss +82 -0
  87. package/dist/src/Pages/CreateTeamPage/index.js +1 -0
  88. package/dist/src/Pages/EmailConfirmationPage/EmailConfirmationPage.js +34 -0
  89. package/dist/src/Pages/EmailConfirmationPage/EmailConfirmationPage.stories.d.ts +8 -0
  90. package/dist/src/Pages/EmailConfirmationPage/EmailConfirmationPage.stories.js +86 -0
  91. package/dist/src/Pages/EmailConfirmationPage/emailConfirmationPage.scss +92 -0
  92. package/dist/src/Pages/EmailConfirmationPage/index.js +1 -0
  93. package/dist/src/Pages/JoinTeamPage/JoinTeamPage.js +6 -0
  94. package/dist/src/Pages/JoinTeamPage/JoinTeamPage.stories.d.ts +7 -0
  95. package/dist/src/Pages/JoinTeamPage/JoinTeamPage.stories.js +24 -0
  96. package/dist/src/Pages/JoinTeamPage/index.js +1 -0
  97. package/dist/src/Pages/JoinTeamPage/joinTeamPage.scss +50 -0
  98. package/dist/src/Pages/LoginPage/LoginPage.js +32 -0
  99. package/dist/src/Pages/LoginPage/LoginPage.stories.d.ts +7 -0
  100. package/dist/src/Pages/LoginPage/LoginPage.stories.js +108 -0
  101. package/dist/src/Pages/LoginPage/index.js +1 -0
  102. package/dist/src/Pages/LoginPage/loginPage.scss +80 -0
  103. package/dist/src/Pages/RegisterPage/RegisterPage.js +34 -0
  104. package/dist/src/Pages/RegisterPage/RegisterPage.stories.d.ts +7 -0
  105. package/dist/src/Pages/RegisterPage/RegisterPage.stories.js +149 -0
  106. package/dist/src/Pages/RegisterPage/index.js +1 -0
  107. package/dist/src/Pages/RegisterPage/registerPage.scss +72 -0
  108. package/dist/src/Pages/ResetPasswordPage/ResetPasswordPage.js +10 -0
  109. package/dist/src/Pages/ResetPasswordPage/ResetPasswordPage.stories.d.ts +7 -0
  110. package/dist/src/Pages/ResetPasswordPage/ResetPasswordPage.stories.js +24 -0
  111. package/dist/src/Pages/ResetPasswordPage/index.js +1 -0
  112. package/dist/src/Pages/ResetPasswordPage/resetPasswordPage.scss +41 -0
  113. package/dist/src/Pages/StartPage/StartPage.js +22 -0
  114. package/dist/src/Pages/StartPage/StartPage.stories.d.ts +7 -0
  115. package/dist/src/Pages/StartPage/StartPage.stories.js +48 -0
  116. package/dist/src/Pages/StartPage/index.js +1 -0
  117. package/dist/src/Pages/StartPage/startPage.scss +58 -0
  118. package/dist/src/Pages/index.js +6 -0
  119. package/dist/src/Pages/index.scss +9 -0
  120. package/dist/src/Utils/Divider/Divider.js +2 -0
  121. package/dist/src/Utils/Divider/divider.scss +11 -0
  122. package/dist/src/Utils/ErrorBanner/ErrorBanner.js +6 -0
  123. package/dist/src/Utils/ErrorBanner/errorBanner.scss +24 -0
  124. package/dist/src/Utils/ErrorBanner/index.js +1 -0
  125. package/dist/src/Utils/Link/Link.js +5 -0
  126. package/dist/src/Utils/Link/Link.stories.d.ts +8 -0
  127. package/dist/src/Utils/Link/Link.stories.js +49 -0
  128. package/dist/src/Utils/Link/index.js +1 -0
  129. package/dist/src/Utils/Link/index.scss +1 -0
  130. package/dist/src/Utils/Link/link.scss +21 -0
  131. package/dist/src/Utils/Modal/Modal.js +24 -0
  132. package/dist/src/Utils/Modal/Modal.stories.d.ts +6 -0
  133. package/dist/src/Utils/Modal/Modal.stories.js +38 -0
  134. package/dist/src/Utils/Modal/index.js +1 -0
  135. package/dist/src/Utils/Modal/modal.scss +33 -0
  136. package/dist/src/Utils/Portal/Portal.js +5 -0
  137. package/dist/src/Utils/SectionPlaceholder/SectionPlaceholder.js +2 -0
  138. package/dist/src/Utils/SectionPlaceholder/sectionPlaceholder.scss +22 -0
  139. package/dist/src/Utils/Spinner/Spinner.js +5 -0
  140. package/dist/src/Utils/Spinner/spinner.scss +41 -0
  141. package/dist/src/Utils/api.js +7 -0
  142. package/dist/src/Utils/index.js +7 -0
  143. package/dist/src/Utils/index.scss +6 -0
  144. package/dist/src/Widgets/Header/Header.js +18 -0
  145. package/dist/src/Widgets/Header/Header.stories.d.ts +6 -0
  146. package/dist/src/Widgets/Header/Header.stories.js +17 -0
  147. package/dist/src/Widgets/Header/header.scss +50 -0
  148. package/dist/src/Widgets/Header/index.js +1 -0
  149. package/dist/src/Widgets/Sidebar/Sidebar.js +25 -0
  150. package/dist/src/Widgets/Sidebar/Sidebar.stories.d.ts +6 -0
  151. package/dist/src/Widgets/Sidebar/Sidebar.stories.js +17 -0
  152. package/dist/src/Widgets/Sidebar/index.js +1 -0
  153. package/dist/src/Widgets/Sidebar/sidebar.scss +23 -0
  154. package/dist/src/Widgets/index.js +2 -0
  155. package/dist/src/Widgets/index.scss +2 -0
  156. package/dist/src/app/main.js +7 -0
  157. package/dist/src/app/routes/AppRouter.js +31 -0
  158. package/dist/src/app/routes/index.js +1 -0
  159. package/dist/src/app/store/index.js +1 -0
  160. package/dist/src/app/store/store.js +13 -0
  161. package/dist/src/assets/scss/index.scss +5 -0
  162. package/dist/src/assets/scss/settings/fonts.scss +29 -0
  163. package/dist/src/assets/scss/settings/globals.scss +5 -0
  164. package/dist/src/assets/scss/settings/helpers.scss +3 -0
  165. package/dist/src/assets/scss/settings/reset.scss +8 -0
  166. package/dist/src/assets/scss/settings/variables.scss +91 -0
  167. package/dist/src/entities/user/api/api.js +41 -0
  168. package/dist/src/entities/user/api/index.js +1 -0
  169. package/dist/src/entities/user/index.js +2 -0
  170. package/dist/src/entities/user/model/index.js +2 -0
  171. package/dist/src/entities/user/model/selectors.js +2 -0
  172. package/dist/src/entities/user/model/slice.js +31 -0
  173. package/dist/src/entities/user/model/types.js +1 -0
  174. package/dist/src/index.js +3 -0
  175. package/dist/src/index.scss +6 -0
  176. package/dist/src/shared/model/api.js +6 -0
  177. package/dist/src/shared/model/constants.js +1 -0
  178. package/dist/src/shared/model/index.js +2 -0
  179. package/dist/src/shared/ui/Avatar/Avatar.js +6 -0
  180. package/dist/src/shared/ui/Avatar/Avatar.stories.d.ts +6 -0
  181. package/dist/src/shared/ui/Avatar/Avatar.stories.js +17 -0
  182. package/dist/src/shared/ui/Avatar/avatar.scss +62 -0
  183. package/dist/src/shared/ui/index.d.ts +1 -0
  184. package/dist/src/shared/ui/index.js +1 -0
  185. package/dist/src/shared/ui/index.scss +1 -0
  186. package/dist/src/tools/customValidators.js +19 -0
  187. package/dist/src/tools/getCoords.js +18 -0
  188. package/dist/src/tools/regExp.js +5 -0
  189. package/dist/{types → src}/ui.d.ts +0 -1
  190. package/dist/src/ui.js +3 -0
  191. package/dist/src/ui.scss +4 -0
  192. package/dist/tsconfig.tsbuildinfo +1 -0
  193. package/package.json +9 -8
  194. package/dist/torgbox-ui.cjs.js +0 -31
  195. package/dist/torgbox-ui.css +0 -1
  196. package/dist/torgbox-ui.es.js +0 -4799
  197. /package/dist/{types → src}/Inputs/Button/Button.d.ts +0 -0
  198. /package/dist/{types → src}/Inputs/Button/index.d.ts +0 -0
  199. /package/dist/{types → src}/Inputs/Checkbox/Checkbox.d.ts +0 -0
  200. /package/dist/{types → src}/Inputs/Checkbox/index.d.ts +0 -0
  201. /package/dist/{types → src}/Inputs/EmailField/EmailField.d.ts +0 -0
  202. /package/dist/{types → src}/Inputs/EmailField/ErrorMessages.d.ts +0 -0
  203. /package/dist/{types → src}/Inputs/EmailField/index.d.ts +0 -0
  204. /package/dist/{types → src}/Inputs/InnField/ErrorMessages.d.ts +0 -0
  205. /package/dist/{types → src}/Inputs/InnField/InnField.d.ts +0 -0
  206. /package/dist/{types → src}/Inputs/InnField/index.d.ts +0 -0
  207. /package/dist/{types → src}/Inputs/NameField/ErrorMessages.d.ts +0 -0
  208. /package/dist/{types → src}/Inputs/NameField/NameField.d.ts +0 -0
  209. /package/dist/{types → src}/Inputs/NameField/index.d.ts +0 -0
  210. /package/dist/{types → src}/Inputs/OtpInput/ErrorMessages.d.ts +0 -0
  211. /package/dist/{types → src}/Inputs/OtpInput/OtpInput.d.ts +0 -0
  212. /package/dist/{types → src}/Inputs/OtpInput/index.d.ts +0 -0
  213. /package/dist/{types → src}/Inputs/PasswordField/ErrorMessages.d.ts +0 -0
  214. /package/dist/{types → src}/Inputs/PasswordField/PasswordField.d.ts +0 -0
  215. /package/dist/{types → src}/Inputs/PasswordField/index.d.ts +0 -0
  216. /package/dist/{types → src}/Inputs/PhoneField/ErrorMessages.d.ts +0 -0
  217. /package/dist/{types → src}/Inputs/PhoneField/PhoneField.d.ts +0 -0
  218. /package/dist/{types → src}/Inputs/PhoneField/index.d.ts +0 -0
  219. /package/dist/{types → src}/Inputs/RepeatPasswordField/ErrorMessages.d.ts +0 -0
  220. /package/dist/{types → src}/Inputs/RepeatPasswordField/RepeatPasswordField.d.ts +0 -0
  221. /package/dist/{types → src}/Inputs/RepeatPasswordField/index.d.ts +0 -0
  222. /package/dist/{types → src}/Inputs/Selector/Collapse.d.ts +0 -0
  223. /package/dist/{types → src}/Inputs/Selector/Dropdown.d.ts +0 -0
  224. /package/dist/{types → src}/Inputs/Selector/Option/Option.d.ts +0 -0
  225. /package/dist/{types → src}/Inputs/Selector/index.d.ts +0 -0
  226. /package/dist/{types → src}/Inputs/TextField/TextField.d.ts +0 -0
  227. /package/dist/{types → src}/Inputs/TextField/index.d.ts +0 -0
  228. /package/dist/{types → src}/Inputs/index.d.ts +0 -0
  229. /package/dist/{types → src}/Pages/ContentPage/ContentPage.d.ts +0 -0
  230. /package/dist/{types → src}/Pages/ContentPage/index.d.ts +0 -0
  231. /package/dist/{types → src}/Pages/CreatePasswordPage/CreatePasswordPage.d.ts +0 -0
  232. /package/dist/{types → src}/Pages/CreatePasswordPage/index.d.ts +0 -0
  233. /package/dist/{types → src}/Pages/CreateTeamPage/CreateTeamPage.d.ts +0 -0
  234. /package/dist/{types → src}/Pages/CreateTeamPage/index.d.ts +0 -0
  235. /package/dist/{types → src}/Pages/EmailConfirmationPage/EmailConfirmationPage.d.ts +0 -0
  236. /package/dist/{types → src}/Pages/EmailConfirmationPage/index.d.ts +0 -0
  237. /package/dist/{types → src}/Pages/JoinTeamPage/JoinTeamPage.d.ts +0 -0
  238. /package/dist/{types → src}/Pages/JoinTeamPage/index.d.ts +0 -0
  239. /package/dist/{types → src}/Pages/LoginPage/LoginPage.d.ts +0 -0
  240. /package/dist/{types → src}/Pages/LoginPage/index.d.ts +0 -0
  241. /package/dist/{types → src}/Pages/RegisterPage/RegisterPage.d.ts +0 -0
  242. /package/dist/{types → src}/Pages/RegisterPage/index.d.ts +0 -0
  243. /package/dist/{types → src}/Pages/ResetPasswordPage/ResetPasswordPage.d.ts +0 -0
  244. /package/dist/{types → src}/Pages/ResetPasswordPage/index.d.ts +0 -0
  245. /package/dist/{types → src}/Pages/StartPage/StartPage.d.ts +0 -0
  246. /package/dist/{types → src}/Pages/StartPage/index.d.ts +0 -0
  247. /package/dist/{types → src}/Pages/index.d.ts +0 -0
  248. /package/dist/{types → src}/Utils/Divider/Divider.d.ts +0 -0
  249. /package/dist/{types → src}/Utils/ErrorBanner/ErrorBanner.d.ts +0 -0
  250. /package/dist/{types → src}/Utils/ErrorBanner/index.d.ts +0 -0
  251. /package/dist/{types → src}/Utils/Link/Link.d.ts +0 -0
  252. /package/dist/{types → src}/Utils/Link/index.d.ts +0 -0
  253. /package/dist/{types → src}/Utils/Modal/Modal.d.ts +0 -0
  254. /package/dist/{types → src}/Utils/Modal/index.d.ts +0 -0
  255. /package/dist/{types → src}/Utils/Portal/Portal.d.ts +0 -0
  256. /package/dist/{types → src}/Utils/SectionPlaceholder/SectionPlaceholder.d.ts +0 -0
  257. /package/dist/{types → src}/Utils/Spinner/Spinner.d.ts +0 -0
  258. /package/dist/{types → src}/Utils/api.d.ts +0 -0
  259. /package/dist/{types → src}/Utils/index.d.ts +0 -0
  260. /package/dist/{types → src}/Widgets/Header/Header.d.ts +0 -0
  261. /package/dist/{types → src}/Widgets/Header/index.d.ts +0 -0
  262. /package/dist/{types → src}/Widgets/Sidebar/Sidebar.d.ts +0 -0
  263. /package/dist/{types → src}/Widgets/Sidebar/index.d.ts +0 -0
  264. /package/dist/{types → src}/Widgets/index.d.ts +0 -0
  265. /package/dist/{types → src}/app/main.d.ts +0 -0
  266. /package/dist/{types → src}/app/routes/AppRouter.d.ts +0 -0
  267. /package/dist/{types → src}/app/routes/index.d.ts +0 -0
  268. /package/dist/{types → src}/app/store/index.d.ts +0 -0
  269. /package/dist/{types → src}/app/store/store.d.ts +0 -0
  270. /package/dist/{types → src}/entities/user/api/api.d.ts +0 -0
  271. /package/dist/{types → src}/entities/user/api/index.d.ts +0 -0
  272. /package/dist/{types → src}/entities/user/index.d.ts +0 -0
  273. /package/dist/{types → src}/entities/user/model/index.d.ts +0 -0
  274. /package/dist/{types → src}/entities/user/model/selectors.d.ts +0 -0
  275. /package/dist/{types → src}/entities/user/model/slice.d.ts +0 -0
  276. /package/dist/{types → src}/entities/user/model/types.d.ts +0 -0
  277. /package/dist/{types → src}/index.d.ts +0 -0
  278. /package/dist/{types → src}/shared/model/api.d.ts +0 -0
  279. /package/dist/{types → src}/shared/model/constants.d.ts +0 -0
  280. /package/dist/{types → src}/shared/model/index.d.ts +0 -0
  281. /package/dist/{types → src}/shared/ui/Avatar/Avatar.d.ts +0 -0
  282. /package/dist/{types → src}/shared/ui/Avatar/index.d.ts +0 -0
  283. /package/dist/{types/shared/ui/index.d.ts → src/shared/ui/Avatar/index.js} +0 -0
  284. /package/dist/{types → src}/tools/customValidators.d.ts +0 -0
  285. /package/dist/{types → src}/tools/getCoords.d.ts +0 -0
  286. /package/dist/{types → src}/tools/regExp.d.ts +0 -0
@@ -0,0 +1 @@
1
+ export { CreatePasswordPage } from './CreatePasswordPage';
@@ -0,0 +1,46 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { debounce } from 'lodash/fp';
3
+ import { useCallback, useEffect, useRef, useState } from 'react';
4
+ import ChevronLeft from '../../assets/img/chevron-left.svg';
5
+ import { Button, InnField } from '../../Inputs';
6
+ import { Link, Spinner } from '../../Utils';
7
+ export const CreateTeamPage = (props) => {
8
+ const { email } = props;
9
+ const [loading, setLoading] = useState(false);
10
+ const [innValid, setInnValid] = useState(false);
11
+ const [searchResult, setSearchResult] = useState('');
12
+ const [startWorkLoading, setStartWorkLoading] = useState(false);
13
+ const innRef = useRef('');
14
+ const getOrganization = () => {
15
+ setLoading(true);
16
+ setTimeout(() => {
17
+ setLoading(false);
18
+ setSearchResult('ООО “Сокращенное наименование”');
19
+ }, 1000);
20
+ };
21
+ const handleInnCheck = useCallback(debounce(500, getOrganization), []);
22
+ useEffect(() => {
23
+ if (innValid) {
24
+ handleInnCheck();
25
+ return;
26
+ }
27
+ handleInnCheck.cancel();
28
+ setLoading(false);
29
+ setSearchResult('');
30
+ }, [handleInnCheck, innValid]);
31
+ useEffect(() => {
32
+ if (startWorkLoading) {
33
+ setTimeout(() => {
34
+ setStartWorkLoading(false);
35
+ }, 1000);
36
+ }
37
+ }, [startWorkLoading]);
38
+ const getBtnState = () => {
39
+ if (startWorkLoading)
40
+ return 'loading';
41
+ return innValid ? 'idle' : 'disabled';
42
+ };
43
+ return (_jsxs("div", { className: 'create-team-page', children: [startWorkLoading && _jsx("div", { className: 'create-team-page__overlay' }), _jsxs("h1", { className: 'create-team-page__title', children: ["\u0421\u043E\u0437\u0434\u0430\u0442\u044C \u043A\u043E\u043C\u0430\u043D\u0434\u0443 \u0434\u043B\u044F ", _jsx("br", {}), _jsx("span", { className: 'create-team-page__email', children: email })] }), _jsx("p", { className: 'create-team-page__text', children: "\u0420\u044B\u0431\u0430\u0442\u0435\u043A\u0441\u0442 \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u0435\u0442\u0441\u044F \u0434\u0438\u0437\u0430\u0439\u043D\u0435\u0440\u0430\u043C\u0438, \u043F\u0440\u043E\u0435\u043A\u0442\u0438\u0440\u043E\u0432\u0449\u0438\u043A\u0430\u043C\u0438 \u0438 \u0444\u0440\u043E\u043D\u0442\u0435\u043D\u0434\u0435\u0440\u0430\u043C\u0438, \u043A\u043E\u0433\u0434\u0430 \u043D\u0443\u0436\u043D\u043E \u0431\u044B\u0441\u0442\u0440\u043E \u0437\u0430\u043F\u043E\u043B\u043D\u0438\u0442\u044C \u043C\u0430\u043A\u0435\u0442\u044B \u0438\u043B\u0438 \u043F\u0440\u043E\u0442\u043E\u0442\u0438\u043F\u044B." }), _jsxs("form", { className: 'create-team-page__form', children: [_jsx(InnField, { onValidated: setInnValid, onTextValid: (inn) => innRef.current = inn }), loading && _jsx(Spinner, { className: 'create-team-page__spinner' }), searchResult && _jsx("p", { className: 'create-team-page__organization', children: searchResult }), _jsx(Button, { label: '\u041D\u0430\u0447\u0430\u0442\u044C \u0440\u0430\u0431\u043E\u0442\u0443', size: 'large', state: getBtnState(), tabIndex: 1, onClick: () => {
44
+ setStartWorkLoading(true);
45
+ }, fullWidth: true })] }), _jsx(Link, { label: '\u041D\u0430\u0437\u0430\u0434', iconComponent: _jsx(ChevronLeft, {}) })] }));
46
+ };
@@ -0,0 +1,7 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { CreateTeamPage } from './CreateTeamPage';
3
+ declare const meta: Meta;
4
+ export default meta;
5
+ type Story = StoryObj<typeof CreateTeamPage>;
6
+ export declare const CreateTeamPageDesktop: Story;
7
+ export declare const CreateTeamPageMobile: Story;
@@ -0,0 +1,82 @@
1
+ import { expect, userEvent, waitFor, within } from '@storybook/test';
2
+ import { InnError } from '../../Inputs/InnField';
3
+ import { CreateTeamPage } from './CreateTeamPage';
4
+ const meta = {
5
+ component: CreateTeamPage,
6
+ title: 'Pages/CreateTeamPage',
7
+ parameters: {
8
+ layout: 'fullscreen',
9
+ },
10
+ args: {
11
+ email: 'test@test.com'
12
+ }
13
+ };
14
+ export default meta;
15
+ export const CreateTeamPageDesktop = {
16
+ parameters: {
17
+ design: {
18
+ type: 'figma',
19
+ url: 'https://www.figma.com/file/8cQcICaes5IWFubU66DMdl/Torgbox-CRM?type=design&node-id=12659-17942&mode=design&t=wnKZYt4uc5mLPiqN-4',
20
+ },
21
+ },
22
+ play: async ({ canvasElement, step }) => {
23
+ const canvas = within(canvasElement);
24
+ const innInput = canvasElement.querySelector('.text-field__input');
25
+ const submitBtn = canvasElement.querySelector('.btn');
26
+ const delay = 100;
27
+ const overlaySelector = '.create-team-page__overlay';
28
+ const btnLoadingSelector = '.btn__filled--loading';
29
+ const spinnerSelector = '.spinner';
30
+ const organizationSelector = '.create-team-page__organization';
31
+ const incorrectInn = '1226542';
32
+ const correctInn = '1254169852';
33
+ await step('Проверяем, заблокирована ли кнопка "Войти" при незаполненном поле "ИНН"', async () => {
34
+ await expect(submitBtn).toBeDisabled();
35
+ });
36
+ await step('При пустом значении в поле "ИНН" выпадает ошибка', async () => {
37
+ await userEvent.click(innInput, { delay });
38
+ await userEvent.click(canvasElement, { delay });
39
+ await expect(canvas.getByText(InnError)).toBeInTheDocument();
40
+ });
41
+ await step('При некорректном значении в поле "ИНН" выпадает ошибка', async () => {
42
+ await userEvent.type(innInput, incorrectInn, { delay });
43
+ await userEvent.click(canvasElement, { delay });
44
+ await expect(canvas.getByText(InnError)).toBeInTheDocument();
45
+ });
46
+ await step('Кнопка "Начать работу" заблокирована при наличии ошибки в поле "ИНН"', async () => {
47
+ await expect(submitBtn).toBeDisabled();
48
+ });
49
+ await step('Кнопка "Начать работу" доступна при корректно заполненном поле "ИНН"', async () => {
50
+ await userEvent.clear(innInput);
51
+ await userEvent.type(innInput, correctInn, { delay });
52
+ await expect(submitBtn).toBeEnabled();
53
+ });
54
+ await step('При корректно заполненном поле "ИНН" появляется спиннер и результат поиска', async () => {
55
+ await waitFor(async () => {
56
+ await expect(canvasElement.querySelector(spinnerSelector)).toBeInTheDocument();
57
+ });
58
+ });
59
+ await step('При корректно заполненном поле "ИНН" появляется результат поиска', async () => {
60
+ await waitFor(async () => {
61
+ await expect(canvasElement.querySelector(organizationSelector)).toBeInTheDocument();
62
+ });
63
+ await step('Кнопка "Начать работу" заблокирована при наличии ошибки в поле "ИНН"', async () => {
64
+ await userEvent.type(innInput, '1', { delay });
65
+ await expect(submitBtn).toBeDisabled();
66
+ });
67
+ });
68
+ await step('При клике на кнопку "Начать работу" блокируется окно и статус кнопки меняется на loading', async () => {
69
+ await userEvent.type(innInput, '6', { delay });
70
+ await userEvent.click(submitBtn, { delay });
71
+ await expect(canvasElement.querySelector(overlaySelector)).toBeInTheDocument();
72
+ await expect(canvasElement.querySelector(btnLoadingSelector)).toBeInTheDocument();
73
+ });
74
+ },
75
+ };
76
+ export const CreateTeamPageMobile = {
77
+ parameters: {
78
+ viewport: {
79
+ defaultViewport: 'mobile',
80
+ }
81
+ },
82
+ };
@@ -0,0 +1,82 @@
1
+ $page-background: $surface-bright;
2
+ $title: $neutral-high;
3
+ $text: $neutral-middle;
4
+
5
+ .create-team-page {
6
+ background-color: $page-background;
7
+ display: flex;
8
+ flex-direction: column;
9
+ align-items: center;
10
+ gap: 16px;
11
+ box-sizing: border-box;
12
+ max-width: 400px;
13
+ margin: 0 auto;
14
+ padding: 24px 40px;
15
+
16
+ &__overlay {
17
+ position: fixed;
18
+ top: 0;
19
+ bottom: 0;
20
+ right: 0;
21
+ left: 0;
22
+ background-color: $page-background;
23
+ opacity: 0.6;
24
+ z-index: 1;
25
+ }
26
+
27
+ &__title {
28
+ text-align: center;
29
+ margin-bottom: 32px;
30
+ font-size: 28px;
31
+ line-height: 36px;
32
+ color: $title;
33
+ }
34
+
35
+ &__text-wrapper {
36
+ display: flex;
37
+ flex-direction: column;
38
+ gap: 12px;
39
+ padding-bottom: 12px;
40
+ }
41
+
42
+ &__text {
43
+ color: $text;
44
+ }
45
+
46
+ &__email {
47
+ color: $title;
48
+ font-weight: 400;
49
+ }
50
+
51
+ &__form {
52
+ width: 100%;
53
+ display: flex;
54
+ flex-direction: column;
55
+
56
+ &>div:first-child {
57
+ margin-bottom: 38px;
58
+ }
59
+ }
60
+
61
+ &__spinner {
62
+ align-self: center;
63
+ width: 20px;
64
+ stroke: $text;
65
+ z-index: 2;
66
+ margin-bottom: 26px;
67
+ }
68
+
69
+ &__organization {
70
+ font-size: 16px;
71
+ line-height: 24px;
72
+ font-weight: 500;
73
+ margin-bottom: 24px;
74
+ }
75
+ }
76
+
77
+ @media screen and (max-width: $sm) {
78
+ .create-team-page {
79
+ max-width: 320px;
80
+ padding: 24px 16px;
81
+ }
82
+ }
@@ -0,0 +1 @@
1
+ export { CreateTeamPage } from './CreateTeamPage';
@@ -0,0 +1,34 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useState } from 'react';
3
+ import ChevronLeft from '../../assets/img/chevron-left.svg';
4
+ import { useVerifyEmailMutation } from '../../entities/user';
5
+ import { Button, OtpInput, } from '../../Inputs';
6
+ import { otpError } from '../../Inputs/OtpInput';
7
+ import { Spinner, Link } from '../../Utils';
8
+ export const EmailConfirmationPage = (props) => {
9
+ const { email } = props;
10
+ const secondsCount = 60;
11
+ const [errorMessage, setErrorMessage] = useState('');
12
+ const [secondsLeft, setSecondsLeft] = useState(0);
13
+ const [verify, { isLoading, isError, isSuccess }] = useVerifyEmailMutation();
14
+ const handleSendEmail = (pin) => {
15
+ setErrorMessage('');
16
+ void verify({ code: pin, email });
17
+ };
18
+ useEffect(() => {
19
+ setErrorMessage(otpError);
20
+ }, [isError]);
21
+ const handleResend = () => {
22
+ setSecondsLeft(secondsCount);
23
+ };
24
+ useEffect(() => {
25
+ let time;
26
+ if (secondsLeft > 0) {
27
+ time = setTimeout(setSecondsLeft, 1000, secondsLeft - 1);
28
+ }
29
+ return () => {
30
+ clearTimeout(time);
31
+ };
32
+ }, [secondsLeft]);
33
+ return (_jsxs("div", { className: 'email-confirmation-page', children: [isLoading && _jsx("div", { className: 'email-confirmation-page__overlay' }), _jsxs("h1", { className: 'email-confirmation-page__title', children: ["\u041F\u043E\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0435\u043D\u0438\u0435 ", _jsx("br", {}), "\u043F\u043E\u0447\u0442\u044B"] }), _jsxs("div", { className: 'email-confirmation-page__text-wrapper', children: [_jsx("p", { className: 'email-confirmation-page__variant-text', children: "\u041F\u041E \u0421\u0421\u042B\u041B\u041A\u0415" }), _jsx("p", { className: 'email-confirmation-page__main-text', children: "\u041F\u0440\u043E\u0439\u0434\u0438\u0442\u0435 \u043F\u043E \u0441\u0441\u044B\u043B\u043A\u0435, \u043E\u0442\u043F\u0440\u0430\u0432\u043B\u0435\u043D\u043D\u043E\u0439 \u043D\u0430" }), _jsx("span", { className: 'email-confirmation-page__email', children: email })] }), _jsxs("div", { className: 'email-confirmation-page__text-wrapper', children: [_jsx("p", { className: 'email-confirmation-page__variant-text', children: "\u0418\u041B\u0418 \u041F\u041E \u041A\u041E\u0414\u0423" }), _jsx("p", { className: 'email-confirmation-page__main-text', children: "\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u043A\u043E\u0434 \u0438\u0437 \u0442\u043E\u0433\u043E \u0436\u0435 \u043F\u0438\u0441\u044C\u043C\u0430." })] }), _jsxs("form", { className: 'email-confirmation-page__form', children: [_jsx(OtpInput, { onComplete: handleSendEmail, errorMessage: errorMessage, setErrorMessage: setErrorMessage, responseReceived: isSuccess || isError, loading: isLoading }), isLoading && (_jsx(Spinner, { className: 'email-confirmation-page__spinner' })), !secondsLeft ? (_jsx(Button, { label: '\u041E\u0442\u043F\u0440\u0430\u0432\u0438\u0442\u044C \u043F\u043E\u0432\u0442\u043E\u0440\u043D\u043E', onClick: handleResend, size: 'medium', variant: 'clear-color' })) : (_jsxs("p", { className: 'email-confirmation-page__resend', children: ["\u041F\u0438\u0441\u044C\u043C\u043E \u043D\u0435 \u043F\u0440\u0438\u0448\u043B\u043E? \u041E\u0442\u043F\u0440\u0430\u0432\u0438\u0442\u044C \u043F\u043E\u0432\u0442\u043E\u0440\u043D\u043E ", secondsLeft] }))] }), _jsx(Link, { label: '\u0418\u0437\u043C\u0435\u043D\u0438\u0442\u044C \u043F\u043E\u0447\u0442\u0443', iconComponent: _jsx(ChevronLeft, {}) })] }));
34
+ };
@@ -0,0 +1,8 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { type IEmailConfirmationPage } from './EmailConfirmationPage';
3
+ declare const meta: Meta;
4
+ export default meta;
5
+ type Story = StoryObj<IEmailConfirmationPage>;
6
+ export declare const DesktopEmailConfirmation: Story;
7
+ export declare const MobileEmailConfirmation: Story;
8
+ export declare const FilledEmailConfirmation: Story;
@@ -0,0 +1,86 @@
1
+ import { expect, userEvent, waitFor, within } from '@storybook/test';
2
+ import { ReduxDecorator } from '../../../.storybook/decorators';
3
+ import { otpError } from '../../Inputs/OtpInput';
4
+ import { EmailConfirmationPage } from './EmailConfirmationPage';
5
+ const meta = {
6
+ component: EmailConfirmationPage,
7
+ decorators: [ReduxDecorator],
8
+ title: 'Pages/Authorization/EmailConfirmationPage',
9
+ parameters: {
10
+ layout: 'fullscreen',
11
+ },
12
+ args: {
13
+ email: 'test@test.com'
14
+ }
15
+ };
16
+ export default meta;
17
+ export const DesktopEmailConfirmation = {
18
+ parameters: {
19
+ design: {
20
+ type: 'figma',
21
+ url: 'https://www.figma.com/file/8cQcICaes5IWFubU66DMdl/Torgbox-CRM?type=design&node-id=14738-24663&mode=design&t=IrHRiRVwxfX0SzRe-4',
22
+ },
23
+ },
24
+ play: async ({ canvasElement, step }) => {
25
+ const canvas = within(canvasElement);
26
+ const input = canvas.getAllByRole('textbox');
27
+ const button = canvasElement.querySelector('.btn');
28
+ const resendTextSelector = '.email-confirmation-page__resend';
29
+ const overlaySelector = '.email-confirmation-page__overlay';
30
+ const spinnerSelector = '.spinner';
31
+ const delay = 100;
32
+ const resendTextContent = 'Письмо не пришло? Отправить повторно ';
33
+ await step('При клике на любое поле фокус переносится на первое незаполненное поле', async () => {
34
+ await userEvent.click(input[5]);
35
+ await expect(input[0]).toHaveFocus();
36
+ await userEvent.type(input[0], '11', { delay });
37
+ await userEvent.click(input[3]);
38
+ await expect(input[2]).toHaveFocus();
39
+ await userEvent.click(input[0]);
40
+ await expect(input[2]).toHaveFocus();
41
+ });
42
+ await step('При заполнении всех полей блокируется окно и появляется спиннер', async () => {
43
+ void userEvent.type(input[0], '2222', { delay });
44
+ await waitFor(() => {
45
+ void expect(canvasElement.querySelector(overlaySelector)).toBeInTheDocument();
46
+ void expect(canvasElement.querySelector(spinnerSelector)).toBeInTheDocument();
47
+ }, { timeout: 2000 });
48
+ });
49
+ await step('При некорректном заполненных полях выпадает ошибка', async () => {
50
+ await waitFor(async () => {
51
+ await expect(canvas.getByText(otpError)).toBeInTheDocument();
52
+ });
53
+ });
54
+ await step('Удаляются ли значения с полей', async () => {
55
+ await userEvent.type(input[0], '01234', { delay });
56
+ await userEvent.type(input[4], '{backspace}{backspace}');
57
+ await expect(input[0]).toHaveValue('0');
58
+ await expect(input[1]).toHaveValue('1');
59
+ await expect(input[2]).toHaveValue('2');
60
+ await expect(input[3]).toHaveValue('3');
61
+ await expect(input[4]).toHaveValue('');
62
+ await expect(input[5]).toHaveValue('');
63
+ });
64
+ await step('При клике на кнопку "Отправить повторно" появляется сообщение', async () => {
65
+ await userEvent.click(button, { delay });
66
+ await waitFor(() => {
67
+ void expect(canvasElement.querySelector(resendTextSelector)).toBeInTheDocument();
68
+ }, { timeout: 2000 });
69
+ await expect(canvasElement
70
+ .querySelector(resendTextSelector)
71
+ ?.textContent?.replace(/\d/g, '')).toEqual(resendTextContent);
72
+ });
73
+ },
74
+ };
75
+ export const MobileEmailConfirmation = {
76
+ parameters: {
77
+ viewport: {
78
+ defaultViewport: 'mobile',
79
+ }
80
+ },
81
+ };
82
+ export const FilledEmailConfirmation = {
83
+ args: {
84
+ email: 'test@test.ru',
85
+ },
86
+ };
@@ -0,0 +1,92 @@
1
+ $page-background: $surface-bright;
2
+ $title: $neutral-high;
3
+ $variant-text: $neutral-low;
4
+ $main-text: $neutral-middle;
5
+ $link-text: $primary-high;
6
+ $link-border: $primary-border-low;
7
+
8
+ .email-confirmation-page {
9
+ position: relative;
10
+ background-color: $page-background;
11
+ display: flex;
12
+ flex-direction: column;
13
+ align-items: center;
14
+ box-sizing: border-box;
15
+ max-width: 400px;
16
+ margin: 0 auto;
17
+ padding: 24px 40px;
18
+
19
+ &__overlay {
20
+ position: fixed;
21
+ top: 0;
22
+ bottom: 0;
23
+ right: 0;
24
+ left: 0;
25
+ background-color: $page-background;
26
+ opacity: 0.6;
27
+ z-index: 1;
28
+ }
29
+
30
+ &__title {
31
+ margin-bottom: 16px;
32
+ font-size: 28px;
33
+ line-height: 36px;
34
+ color: $title;
35
+ text-align: center;
36
+ }
37
+
38
+ &__text-wrapper {
39
+ margin-top: 16px;
40
+ display: flex;
41
+ flex-direction: column;
42
+ align-items: center;
43
+ }
44
+
45
+ &__variant-text {
46
+ font-size: 12px;
47
+ line-height: 16px;
48
+ color: $variant-text;
49
+ }
50
+
51
+ &__main-text {
52
+ color: $main-text;
53
+ }
54
+
55
+ &__email {
56
+ font-weight: 700;
57
+ }
58
+
59
+ &__form {
60
+ position: relative;
61
+ display: flex;
62
+ flex-direction: column;
63
+ align-items: center;
64
+ gap: 36px;
65
+ margin: 16px 0;
66
+ }
67
+
68
+ &__spinner {
69
+ position: absolute;
70
+ top: 14px;
71
+ right: -33px;
72
+ width: 20px;
73
+ stroke: $main-text;
74
+ z-index: 2;
75
+ }
76
+
77
+ &__resend {
78
+ color: $variant-text;
79
+ }
80
+ }
81
+
82
+ @media screen and (max-width: $sm) {
83
+ .email-confirmation-page {
84
+ max-width: 320px;
85
+ padding: 24px 16px;
86
+
87
+ &__title {
88
+ font-size: 24px;
89
+ line-height: 32px;
90
+ }
91
+ }
92
+ }
@@ -0,0 +1 @@
1
+ export { EmailConfirmationPage } from './EmailConfirmationPage';
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import ChevronLeft from '../../assets/img/chevron-left.svg';
3
+ import { Link } from '../../Utils';
4
+ export const JoinTeamPage = () => {
5
+ return (_jsxs("div", { className: 'join-team-page', children: [_jsx("h1", { className: 'join-team-page__title', children: "\u0412\u0441\u0442\u0443\u043F\u0438\u0442\u044C \u0432 \u043A\u043E\u043C\u0430\u043D\u0434\u0443 " }), _jsxs("div", { className: 'join-team-page__text-wrapper', children: [_jsx("p", { children: "\u0420\u044B\u0431\u0430\u0442\u0435\u043A\u0441\u0442 \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u0435\u0442\u0441\u044F \u0434\u0438\u0437\u0430\u0439\u043D\u0435\u0440\u0430\u043C\u0438, \u043F\u0440\u043E\u0435\u043A\u0442\u0438\u0440\u043E\u0432\u0449\u0438\u043A\u0430\u043C\u0438 \u0438 \u0444\u0440\u043E\u043D\u0442\u0435\u043D\u0434\u0435\u0440\u0430\u043C\u0438, \u043A\u043E\u0433\u0434\u0430 \u043D\u0443\u0436\u043D\u043E \u0431\u044B\u0441\u0442\u0440\u043E \u0437\u0430\u043F\u043E\u043B\u043D\u0438\u0442\u044C \u043C\u0430\u043A\u0435\u0442\u044B \u0438\u043B\u0438 \u043F\u0440\u043E\u0442\u043E\u0442\u0438\u043F\u044B." }), _jsxs("p", { children: ["\u041C\u043E\u0436\u043D\u043E \u043F\u0440\u043E\u0441\u0442\u043E ", _jsx("a", { className: 'join-team-page__link', href: '#', children: "\u0437\u0430\u043A\u0440\u044B\u0442\u044C \u044D\u0442\u0443 \u0432\u043A\u043B\u0430\u0434\u043A\u0443" }), " \u0438 \u043F\u043E\u0434\u043E\u0436\u0434\u0430\u0442\u044C \u043F\u0440\u0438\u0433\u043B\u0430\u0448\u0435\u043D\u0438\u044F."] })] }), _jsx(Link, { label: '\u041D\u0430\u0437\u0430\u0434', iconComponent: _jsx(ChevronLeft, {}) })] }));
6
+ };
@@ -0,0 +1,7 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { JoinTeamPage } from './JoinTeamPage';
3
+ declare const meta: Meta;
4
+ export default meta;
5
+ type Story = StoryObj<typeof JoinTeamPage>;
6
+ export declare const JoinTeamPageDesktop: Story;
7
+ export declare const JoinTeamPageMobile: Story;
@@ -0,0 +1,24 @@
1
+ import { JoinTeamPage } from './JoinTeamPage';
2
+ const meta = {
3
+ component: JoinTeamPage,
4
+ title: 'Pages/JoinTeamPage',
5
+ parameters: {
6
+ layout: 'fullscreen',
7
+ },
8
+ };
9
+ export default meta;
10
+ export const JoinTeamPageDesktop = {
11
+ parameters: {
12
+ design: {
13
+ type: 'figma',
14
+ url: 'https://www.figma.com/file/8cQcICaes5IWFubU66DMdl/Torgbox-CRM?type=design&node-id=12659-18507&mode=design&t=hNpF3IDGWJpyx7qO-4',
15
+ },
16
+ },
17
+ };
18
+ export const JoinTeamPageMobile = {
19
+ parameters: {
20
+ viewport: {
21
+ defaultViewport: 'mobile',
22
+ }
23
+ },
24
+ };
@@ -0,0 +1 @@
1
+ export { JoinTeamPage } from './JoinTeamPage';
@@ -0,0 +1,50 @@
1
+ $page-background: $surface-bright;
2
+ $text: $neutral-middle;
3
+ $title: $neutral-high;
4
+ $link: $primary-high;
5
+ $underline: $primary-middle;
6
+
7
+ .join-team-page {
8
+ background-color: $page-background;
9
+ display: flex;
10
+ flex-direction: column;
11
+ align-items: center;
12
+ gap: 16px;
13
+ box-sizing: border-box;
14
+ max-width: 400px;
15
+ margin: 0 auto;
16
+ padding: 24px 40px;
17
+
18
+ &__title {
19
+ text-align: center;
20
+ margin-bottom: 32px;
21
+ font-size: 28px;
22
+ line-height: 36px;
23
+ color: $title;
24
+ }
25
+
26
+ &__text-wrapper {
27
+ color: $text;
28
+ display: flex;
29
+ flex-direction: column;
30
+ gap: 12px;
31
+ padding-bottom: 12px;
32
+ }
33
+
34
+ &__link {
35
+ color: $link;
36
+ text-decoration: none;
37
+
38
+ &:hover, &:focus {
39
+ cursor: pointer;
40
+ text-decoration: underline $underline;
41
+ }
42
+ }
43
+ }
44
+
45
+ @media screen and (max-width: $sm) {
46
+ .join-team-page {
47
+ max-width: 320px;
48
+ padding: 24px 16px;
49
+ }
50
+ }
@@ -0,0 +1,32 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useState, useRef, } from 'react';
3
+ import { useLoginMutation } from '../../entities/user';
4
+ import { Button, EmailField, PasswordField, Checkbox, } from '../../Inputs';
5
+ import { ErrorBanner, Link } from '../../Utils';
6
+ export const LoginPage = () => {
7
+ const [emailValid, setEmailValid] = useState(false);
8
+ const [passwordValid, setPasswordValid] = useState(false);
9
+ const [remember, setRemember] = useState(false);
10
+ const [formValid, setFormValid] = useState(false);
11
+ const [login, { isLoading, isError }] = useLoginMutation();
12
+ const formRef = useRef({
13
+ email: '',
14
+ password: '',
15
+ remember
16
+ });
17
+ const getBtnState = () => {
18
+ if (isLoading)
19
+ return 'loading';
20
+ return formValid ? 'idle' : 'disabled';
21
+ };
22
+ const handleSendForm = () => {
23
+ if (formValid) {
24
+ const { email, password } = formRef.current;
25
+ void login({ email, password });
26
+ }
27
+ };
28
+ useEffect(() => {
29
+ setFormValid([emailValid, passwordValid].every(Boolean));
30
+ }, [emailValid, passwordValid, isLoading]);
31
+ return (_jsxs("div", { className: 'login-page', children: [isLoading && _jsx("div", { className: 'login-page__overlay' }), _jsx("h1", { className: 'login-page__title', children: "\u0412\u0445\u043E\u0434 \u0432 \u0430\u043A\u043A\u0430\u0443\u043D\u0442" }), isError && (_jsx(ErrorBanner, { error: '\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 email \u0438\u043B\u0438 \u043F\u0430\u0440\u043E\u043B\u044C' })), _jsxs("form", { className: 'login-page__form', children: [_jsx(EmailField, { onValidated: setEmailValid, onTextValid: (email) => (formRef.current.email = email), tabIndex: 1 }), _jsx(PasswordField, { onValidated: setPasswordValid, onPasswordInput: (password) => (formRef.current.password = password), tabIndex: 2 }), _jsx(Checkbox, { checked: remember, label: '\u0417\u0430\u043F\u043E\u043C\u043D\u0438\u0442\u044C \u043C\u0435\u043D\u044F', onClick: setRemember }), _jsx(Button, { label: '\u0412\u043E\u0439\u0442\u0438', size: 'large', state: getBtnState(), onClick: handleSendForm, fullWidth: true, tabIndex: 3 })] }), _jsxs("div", { className: 'login-page__footer', children: [_jsx("p", { className: 'login-page__text', children: "\u0415\u0449\u0435 \u043D\u0435 \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043E\u0432\u0430\u043D\u044B?" }), _jsx(Link, { label: '\u0421\u043E\u0437\u0434\u0430\u0442\u044C \u0430\u043A\u043A\u0430\u0443\u043D\u0442' })] })] }));
32
+ };
@@ -0,0 +1,7 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { LoginPage } from './LoginPage';
3
+ declare const meta: Meta;
4
+ export default meta;
5
+ type Story = StoryObj<typeof LoginPage>;
6
+ export declare const LoginPageDesktop: Story;
7
+ export declare const LoginPageMobile: Story;