torgbox-ui 1.0.11 → 1.0.13
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.
- package/dist/cjs/assets/style.css +1 -0
- package/dist/cjs/ui.js +31 -19
- package/dist/esm/assets/style.css +1 -0
- package/dist/esm/ui.js +1 -3
- package/dist/esm/ui10.js +1 -0
- package/dist/esm/ui11.js +1 -0
- package/dist/esm/ui12.js +1 -0
- package/dist/esm/ui13.js +1 -0
- package/dist/esm/ui14.js +1 -0
- package/dist/esm/ui15.js +1 -0
- package/dist/esm/ui16.js +1 -0
- package/dist/esm/ui17.js +1 -0
- package/dist/esm/ui18.js +1 -0
- package/dist/esm/ui19.js +1 -0
- package/dist/esm/ui2.js +1 -0
- package/dist/esm/ui20.js +1 -0
- package/dist/esm/ui21.js +1 -0
- package/dist/esm/ui22.js +1 -0
- package/dist/esm/ui23.js +1 -0
- package/dist/esm/ui24.js +1 -0
- package/dist/esm/ui25.js +1 -0
- package/dist/esm/ui26.js +1 -0
- package/dist/esm/ui27.js +1 -0
- package/dist/esm/ui28.js +1 -0
- package/dist/esm/ui29.js +1 -0
- package/dist/esm/ui3.js +1 -0
- package/dist/esm/ui30.js +1 -0
- package/dist/esm/ui31.js +1 -0
- package/dist/esm/ui32.js +1 -0
- package/dist/esm/ui33.js +1 -0
- package/dist/esm/ui34.js +1 -0
- package/dist/esm/ui35.js +1 -0
- package/dist/esm/ui36.js +1 -0
- package/dist/esm/ui37.js +1 -0
- package/dist/esm/ui38.js +1 -0
- package/dist/esm/ui39.js +1 -0
- package/dist/esm/ui4.js +1 -0
- package/dist/esm/ui40.js +1 -0
- package/dist/esm/ui41.js +1 -0
- package/dist/esm/ui42.js +5 -0
- package/dist/esm/ui43.js +1 -0
- package/dist/esm/ui44.js +1 -0
- package/dist/esm/ui45.js +1 -0
- package/dist/esm/ui46.js +1 -0
- package/dist/esm/ui47.js +27 -0
- package/dist/esm/ui48.js +1 -0
- package/dist/esm/ui49.js +1 -0
- package/dist/esm/ui5.js +1 -0
- package/dist/esm/ui50.js +1 -0
- package/dist/esm/ui51.js +1 -0
- package/dist/esm/ui52.js +1 -0
- package/dist/esm/ui53.js +1 -0
- package/dist/esm/ui6.js +1 -0
- package/dist/esm/ui7.js +1 -0
- package/dist/esm/ui8.js +1 -0
- package/dist/esm/ui9.js +1 -0
- package/package.json +10 -12
- package/dist/cjs/Inputs/Button/Button.js +0 -37
- package/dist/cjs/Inputs/Button/button.scss +0 -358
- package/dist/cjs/Inputs/Button/index.js +0 -5
- package/dist/cjs/Inputs/Checkbox/Checkbox.js +0 -36
- package/dist/cjs/Inputs/Checkbox/checkbox.scss +0 -63
- package/dist/cjs/Inputs/Checkbox/index.js +0 -5
- package/dist/cjs/Inputs/EmailField/EmailField.js +0 -65
- package/dist/cjs/Inputs/EmailField/ErrorMessages.js +0 -6
- package/dist/cjs/Inputs/EmailField/index.js +0 -9
- package/dist/cjs/Inputs/InnField/ErrorMessages.js +0 -4
- package/dist/cjs/Inputs/InnField/InnField.js +0 -37
- package/dist/cjs/Inputs/InnField/index.js +0 -7
- package/dist/cjs/Inputs/NameField/ErrorMessages.js +0 -11
- package/dist/cjs/Inputs/NameField/NameField.js +0 -58
- package/dist/cjs/Inputs/NameField/index.js +0 -14
- package/dist/cjs/Inputs/OtpInput/ErrorMessages.js +0 -4
- package/dist/cjs/Inputs/OtpInput/OtpInput.js +0 -85
- package/dist/cjs/Inputs/OtpInput/index.js +0 -7
- package/dist/cjs/Inputs/OtpInput/otpInput.scss +0 -39
- package/dist/cjs/Inputs/PasswordField/ErrorMessages.js +0 -5
- package/dist/cjs/Inputs/PasswordField/PasswordField.js +0 -42
- package/dist/cjs/Inputs/PasswordField/index.js +0 -8
- package/dist/cjs/Inputs/PhoneField/ErrorMessages.js +0 -5
- package/dist/cjs/Inputs/PhoneField/PhoneField.js +0 -81
- package/dist/cjs/Inputs/PhoneField/index.js +0 -8
- package/dist/cjs/Inputs/RepeatPasswordField/ErrorMessages.js +0 -5
- package/dist/cjs/Inputs/RepeatPasswordField/RepeatPasswordField.js +0 -29
- package/dist/cjs/Inputs/RepeatPasswordField/index.js +0 -8
- package/dist/cjs/Inputs/Selector/Collapse.js +0 -47
- package/dist/cjs/Inputs/Selector/Dropdown.js +0 -88
- package/dist/cjs/Inputs/Selector/Option/Option.js +0 -17
- package/dist/cjs/Inputs/Selector/Option/option.scss +0 -44
- package/dist/cjs/Inputs/Selector/index.js +0 -9
- package/dist/cjs/Inputs/Selector/selector.scss +0 -101
- package/dist/cjs/Inputs/TextField/TextField.js +0 -92
- package/dist/cjs/Inputs/TextField/index.js +0 -5
- package/dist/cjs/Inputs/TextField/textField.module.scss +0 -157
- package/dist/cjs/Inputs/TextField/textField.scss +0 -156
- package/dist/cjs/Inputs/index.js +0 -27
- package/dist/cjs/Inputs/index.scss +0 -6
- package/dist/cjs/Pages/ContentPage/ContentPage.d.ts +0 -6
- package/dist/cjs/Pages/ContentPage/ContentPage.js +0 -26
- package/dist/cjs/Pages/ContentPage/contentPage.scss +0 -10
- package/dist/cjs/Pages/ContentPage/index.d.ts +0 -1
- package/dist/cjs/Pages/ContentPage/index.js +0 -5
- package/dist/cjs/Pages/CreatePasswordPage/CreatePasswordPage.d.ts +0 -1
- package/dist/cjs/Pages/CreatePasswordPage/CreatePasswordPage.js +0 -51
- package/dist/cjs/Pages/CreatePasswordPage/createPasswordPage.scss +0 -42
- package/dist/cjs/Pages/CreatePasswordPage/index.d.ts +0 -1
- package/dist/cjs/Pages/CreatePasswordPage/index.js +0 -5
- package/dist/cjs/Pages/CreateTeamPage/CreateTeamPage.d.ts +0 -4
- package/dist/cjs/Pages/CreateTeamPage/CreateTeamPage.js +0 -53
- package/dist/cjs/Pages/CreateTeamPage/createTeamPage.scss +0 -82
- package/dist/cjs/Pages/CreateTeamPage/index.d.ts +0 -1
- package/dist/cjs/Pages/CreateTeamPage/index.js +0 -5
- package/dist/cjs/Pages/EmailConfirmationPage/EmailConfirmationPage.d.ts +0 -4
- package/dist/cjs/Pages/EmailConfirmationPage/EmailConfirmationPage.js +0 -41
- package/dist/cjs/Pages/EmailConfirmationPage/emailConfirmationPage.scss +0 -92
- package/dist/cjs/Pages/EmailConfirmationPage/index.d.ts +0 -1
- package/dist/cjs/Pages/EmailConfirmationPage/index.js +0 -5
- package/dist/cjs/Pages/JoinTeamPage/JoinTeamPage.d.ts +0 -1
- package/dist/cjs/Pages/JoinTeamPage/JoinTeamPage.js +0 -13
- package/dist/cjs/Pages/JoinTeamPage/index.d.ts +0 -1
- package/dist/cjs/Pages/JoinTeamPage/index.js +0 -5
- package/dist/cjs/Pages/JoinTeamPage/joinTeamPage.scss +0 -50
- package/dist/cjs/Pages/LoginPage/LoginPage.d.ts +0 -1
- package/dist/cjs/Pages/LoginPage/LoginPage.js +0 -36
- package/dist/cjs/Pages/LoginPage/index.d.ts +0 -1
- package/dist/cjs/Pages/LoginPage/index.js +0 -5
- package/dist/cjs/Pages/LoginPage/loginPage.scss +0 -80
- package/dist/cjs/Pages/RegisterPage/RegisterPage.d.ts +0 -1
- package/dist/cjs/Pages/RegisterPage/RegisterPage.js +0 -38
- package/dist/cjs/Pages/RegisterPage/index.d.ts +0 -1
- package/dist/cjs/Pages/RegisterPage/index.js +0 -5
- package/dist/cjs/Pages/RegisterPage/registerPage.scss +0 -72
- package/dist/cjs/Pages/ResetPasswordPage/ResetPasswordPage.d.ts +0 -1
- package/dist/cjs/Pages/ResetPasswordPage/ResetPasswordPage.js +0 -17
- package/dist/cjs/Pages/ResetPasswordPage/index.d.ts +0 -1
- package/dist/cjs/Pages/ResetPasswordPage/index.js +0 -5
- package/dist/cjs/Pages/ResetPasswordPage/resetPasswordPage.scss +0 -41
- package/dist/cjs/Pages/StartPage/StartPage.d.ts +0 -4
- package/dist/cjs/Pages/StartPage/StartPage.js +0 -26
- package/dist/cjs/Pages/StartPage/index.d.ts +0 -1
- package/dist/cjs/Pages/StartPage/index.js +0 -5
- package/dist/cjs/Pages/StartPage/startPage.scss +0 -58
- package/dist/cjs/Pages/index.d.ts +0 -6
- package/dist/cjs/Pages/index.js +0 -15
- package/dist/cjs/Pages/index.scss +0 -9
- package/dist/cjs/Utils/Divider/Divider.js +0 -6
- package/dist/cjs/Utils/Divider/divider.scss +0 -11
- package/dist/cjs/Utils/ErrorBanner/ErrorBanner.js +0 -13
- package/dist/cjs/Utils/ErrorBanner/errorBanner.scss +0 -24
- package/dist/cjs/Utils/ErrorBanner/index.js +0 -5
- package/dist/cjs/Utils/Link/Link.js +0 -12
- package/dist/cjs/Utils/Link/index.d.ts +0 -1
- package/dist/cjs/Utils/Link/index.js +0 -5
- package/dist/cjs/Utils/Link/index.scss +0 -1
- package/dist/cjs/Utils/Link/link.scss +0 -21
- package/dist/cjs/Utils/Modal/Modal.js +0 -31
- package/dist/cjs/Utils/Modal/index.d.ts +0 -1
- package/dist/cjs/Utils/Modal/index.js +0 -5
- package/dist/cjs/Utils/Modal/modal.scss +0 -33
- package/dist/cjs/Utils/Portal/Portal.js +0 -9
- package/dist/cjs/Utils/SectionPlaceholder/SectionPlaceholder.js +0 -6
- package/dist/cjs/Utils/SectionPlaceholder/sectionPlaceholder.scss +0 -22
- package/dist/cjs/Utils/Spinner/Spinner.js +0 -12
- package/dist/cjs/Utils/Spinner/spinner.scss +0 -41
- package/dist/cjs/Utils/api.d.ts +0 -1
- package/dist/cjs/Utils/api.js +0 -10
- package/dist/cjs/Utils/index.js +0 -17
- package/dist/cjs/Utils/index.scss +0 -6
- package/dist/cjs/Widgets/Header/Header.d.ts +0 -7
- package/dist/cjs/Widgets/Header/Header.js +0 -25
- package/dist/cjs/Widgets/Header/header.scss +0 -50
- package/dist/cjs/Widgets/Header/index.d.ts +0 -1
- package/dist/cjs/Widgets/Header/index.js +0 -5
- package/dist/cjs/Widgets/Sidebar/Sidebar.d.ts +0 -9
- package/dist/cjs/Widgets/Sidebar/Sidebar.js +0 -32
- package/dist/cjs/Widgets/Sidebar/index.d.ts +0 -1
- package/dist/cjs/Widgets/Sidebar/index.js +0 -5
- package/dist/cjs/Widgets/Sidebar/sidebar.scss +0 -23
- package/dist/cjs/Widgets/index.d.ts +0 -2
- package/dist/cjs/Widgets/index.js +0 -7
- package/dist/cjs/Widgets/index.scss +0 -2
- package/dist/cjs/app/main.d.ts +0 -1
- package/dist/cjs/app/main.js +0 -12
- package/dist/cjs/app/routes/AppRouter.d.ts +0 -1
- package/dist/cjs/app/routes/AppRouter.js +0 -35
- package/dist/cjs/app/routes/index.d.ts +0 -1
- package/dist/cjs/app/routes/index.js +0 -5
- package/dist/cjs/app/store/index.d.ts +0 -1
- package/dist/cjs/app/store/index.js +0 -7
- package/dist/cjs/app/store/store.d.ts +0 -14
- package/dist/cjs/app/store/store.js +0 -17
- package/dist/cjs/assets/img/belt.svg +0 -3
- package/dist/cjs/assets/img/burger-menu.svg +0 -3
- package/dist/cjs/assets/img/check.svg +0 -3
- package/dist/cjs/assets/img/checked.svg +0 -3
- package/dist/cjs/assets/img/chevron-down.svg +0 -3
- package/dist/cjs/assets/img/chevron-left.svg +0 -3
- package/dist/cjs/assets/img/cross.svg +0 -3
- package/dist/cjs/assets/img/dot.svg +0 -3
- package/dist/cjs/assets/img/eye-close.svg +0 -1
- package/dist/cjs/assets/img/eye-open.svg +0 -3
- package/dist/cjs/assets/img/left-arrow.svg +0 -3
- package/dist/cjs/assets/img/logo-main.svg +0 -6
- package/dist/cjs/assets/img/logo.svg +0 -44
- package/dist/cjs/assets/img/partial-checked.svg +0 -3
- package/dist/cjs/assets/img/right-arrow.svg +0 -3
- package/dist/cjs/assets/img/sample-logo.svg +0 -17
- package/dist/cjs/assets/img/search.svg +0 -3
- package/dist/cjs/assets/img/star.svg +0 -3
- package/dist/cjs/assets/img/warning.svg +0 -3
- package/dist/cjs/assets/scss/index.scss +0 -5
- package/dist/cjs/assets/scss/settings/fonts.scss +0 -29
- package/dist/cjs/assets/scss/settings/globals.scss +0 -5
- package/dist/cjs/assets/scss/settings/helpers.scss +0 -3
- package/dist/cjs/assets/scss/settings/reset.scss +0 -8
- package/dist/cjs/assets/scss/settings/variables.scss +0 -91
- package/dist/cjs/entities/user/api/api.d.ts +0 -648
- package/dist/cjs/entities/user/api/api.js +0 -44
- package/dist/cjs/entities/user/api/index.d.ts +0 -1
- package/dist/cjs/entities/user/api/index.js +0 -17
- package/dist/cjs/entities/user/index.d.ts +0 -2
- package/dist/cjs/entities/user/index.js +0 -23
- package/dist/cjs/entities/user/model/index.d.ts +0 -3
- package/dist/cjs/entities/user/model/index.js +0 -21
- package/dist/cjs/entities/user/model/selectors.d.ts +0 -4
- package/dist/cjs/entities/user/model/selectors.js +0 -7
- package/dist/cjs/entities/user/model/slice.d.ts +0 -10
- package/dist/cjs/entities/user/model/slice.js +0 -34
- package/dist/cjs/entities/user/model/types.d.ts +0 -17
- package/dist/cjs/entities/user/model/types.js +0 -2
- package/dist/cjs/index.d.ts +0 -3
- package/dist/cjs/index.js +0 -19
- package/dist/cjs/index.scss +0 -6
- package/dist/cjs/shared/model/api.d.ts +0 -6
- package/dist/cjs/shared/model/api.js +0 -9
- package/dist/cjs/shared/model/constants.d.ts +0 -1
- package/dist/cjs/shared/model/constants.js +0 -4
- package/dist/cjs/shared/model/index.d.ts +0 -2
- package/dist/cjs/shared/model/index.js +0 -7
- package/dist/cjs/shared/ui/Avatar/Avatar.js +0 -13
- package/dist/cjs/shared/ui/Avatar/avatar.scss +0 -62
- package/dist/cjs/shared/ui/Avatar/index.js +0 -5
- package/dist/cjs/shared/ui/index.js +0 -5
- package/dist/cjs/shared/ui/index.scss +0 -1
- package/dist/cjs/tools/customValidators.js +0 -27
- package/dist/cjs/tools/getCoords.js +0 -22
- package/dist/cjs/tools/regExp.js +0 -8
- package/dist/cjs/ui.scss +0 -4
- package/dist/esm/Inputs/Button/Button.d.ts +0 -17
- package/dist/esm/Inputs/Button/Button.js +0 -30
- package/dist/esm/Inputs/Button/button.scss +0 -358
- package/dist/esm/Inputs/Button/index.d.ts +0 -1
- package/dist/esm/Inputs/Button/index.js +0 -1
- package/dist/esm/Inputs/Checkbox/Checkbox.d.ts +0 -11
- package/dist/esm/Inputs/Checkbox/Checkbox.js +0 -29
- package/dist/esm/Inputs/Checkbox/checkbox.scss +0 -63
- package/dist/esm/Inputs/Checkbox/index.d.ts +0 -1
- package/dist/esm/Inputs/Checkbox/index.js +0 -1
- package/dist/esm/Inputs/EmailField/EmailField.d.ts +0 -7
- package/dist/esm/Inputs/EmailField/EmailField.js +0 -61
- package/dist/esm/Inputs/EmailField/ErrorMessages.d.ts +0 -3
- package/dist/esm/Inputs/EmailField/ErrorMessages.js +0 -3
- package/dist/esm/Inputs/EmailField/index.d.ts +0 -2
- package/dist/esm/Inputs/EmailField/index.js +0 -2
- package/dist/esm/Inputs/InnField/ErrorMessages.d.ts +0 -1
- package/dist/esm/Inputs/InnField/ErrorMessages.js +0 -1
- package/dist/esm/Inputs/InnField/InnField.d.ts +0 -6
- package/dist/esm/Inputs/InnField/InnField.js +0 -33
- package/dist/esm/Inputs/InnField/index.d.ts +0 -2
- package/dist/esm/Inputs/InnField/index.js +0 -2
- package/dist/esm/Inputs/NameField/ErrorMessages.d.ts +0 -8
- package/dist/esm/Inputs/NameField/ErrorMessages.js +0 -8
- package/dist/esm/Inputs/NameField/NameField.d.ts +0 -9
- package/dist/esm/Inputs/NameField/NameField.js +0 -54
- package/dist/esm/Inputs/NameField/index.d.ts +0 -2
- package/dist/esm/Inputs/NameField/index.js +0 -2
- package/dist/esm/Inputs/OtpInput/ErrorMessages.d.ts +0 -1
- package/dist/esm/Inputs/OtpInput/ErrorMessages.js +0 -1
- package/dist/esm/Inputs/OtpInput/OtpInput.d.ts +0 -9
- package/dist/esm/Inputs/OtpInput/OtpInput.js +0 -78
- package/dist/esm/Inputs/OtpInput/index.d.ts +0 -2
- package/dist/esm/Inputs/OtpInput/index.js +0 -2
- package/dist/esm/Inputs/OtpInput/otpInput.scss +0 -39
- package/dist/esm/Inputs/PasswordField/ErrorMessages.d.ts +0 -2
- package/dist/esm/Inputs/PasswordField/ErrorMessages.js +0 -2
- package/dist/esm/Inputs/PasswordField/PasswordField.d.ts +0 -7
- package/dist/esm/Inputs/PasswordField/PasswordField.js +0 -35
- package/dist/esm/Inputs/PasswordField/index.d.ts +0 -2
- package/dist/esm/Inputs/PasswordField/index.js +0 -2
- package/dist/esm/Inputs/PhoneField/ErrorMessages.d.ts +0 -2
- package/dist/esm/Inputs/PhoneField/ErrorMessages.js +0 -2
- package/dist/esm/Inputs/PhoneField/PhoneField.d.ts +0 -6
- package/dist/esm/Inputs/PhoneField/PhoneField.js +0 -74
- package/dist/esm/Inputs/PhoneField/index.d.ts +0 -2
- package/dist/esm/Inputs/PhoneField/index.js +0 -2
- package/dist/esm/Inputs/RepeatPasswordField/ErrorMessages.d.ts +0 -2
- package/dist/esm/Inputs/RepeatPasswordField/ErrorMessages.js +0 -2
- package/dist/esm/Inputs/RepeatPasswordField/RepeatPasswordField.d.ts +0 -6
- package/dist/esm/Inputs/RepeatPasswordField/RepeatPasswordField.js +0 -22
- package/dist/esm/Inputs/RepeatPasswordField/index.d.ts +0 -2
- package/dist/esm/Inputs/RepeatPasswordField/index.js +0 -2
- package/dist/esm/Inputs/Selector/Collapse.d.ts +0 -12
- package/dist/esm/Inputs/Selector/Collapse.js +0 -40
- package/dist/esm/Inputs/Selector/Dropdown.d.ts +0 -13
- package/dist/esm/Inputs/Selector/Dropdown.js +0 -81
- package/dist/esm/Inputs/Selector/Option/Option.d.ts +0 -13
- package/dist/esm/Inputs/Selector/Option/Option.js +0 -10
- package/dist/esm/Inputs/Selector/Option/option.scss +0 -44
- package/dist/esm/Inputs/Selector/index.d.ts +0 -3
- package/dist/esm/Inputs/Selector/index.js +0 -3
- package/dist/esm/Inputs/Selector/selector.scss +0 -101
- package/dist/esm/Inputs/TextField/TextField.d.ts +0 -25
- package/dist/esm/Inputs/TextField/TextField.js +0 -85
- package/dist/esm/Inputs/TextField/index.d.ts +0 -1
- package/dist/esm/Inputs/TextField/index.js +0 -1
- package/dist/esm/Inputs/TextField/textField.module.scss +0 -157
- package/dist/esm/Inputs/TextField/textField.scss +0 -156
- package/dist/esm/Inputs/index.d.ts +0 -11
- package/dist/esm/Inputs/index.js +0 -11
- package/dist/esm/Inputs/index.scss +0 -6
- package/dist/esm/Pages/ContentPage/ContentPage.d.ts +0 -6
- package/dist/esm/Pages/ContentPage/ContentPage.js +0 -22
- package/dist/esm/Pages/ContentPage/contentPage.scss +0 -10
- package/dist/esm/Pages/ContentPage/index.d.ts +0 -1
- package/dist/esm/Pages/ContentPage/index.js +0 -1
- package/dist/esm/Pages/CreatePasswordPage/CreatePasswordPage.d.ts +0 -1
- package/dist/esm/Pages/CreatePasswordPage/CreatePasswordPage.js +0 -47
- package/dist/esm/Pages/CreatePasswordPage/createPasswordPage.scss +0 -42
- package/dist/esm/Pages/CreatePasswordPage/index.d.ts +0 -1
- package/dist/esm/Pages/CreatePasswordPage/index.js +0 -1
- package/dist/esm/Pages/CreateTeamPage/CreateTeamPage.d.ts +0 -4
- package/dist/esm/Pages/CreateTeamPage/CreateTeamPage.js +0 -46
- package/dist/esm/Pages/CreateTeamPage/createTeamPage.scss +0 -82
- package/dist/esm/Pages/CreateTeamPage/index.d.ts +0 -1
- package/dist/esm/Pages/CreateTeamPage/index.js +0 -1
- package/dist/esm/Pages/EmailConfirmationPage/EmailConfirmationPage.d.ts +0 -4
- package/dist/esm/Pages/EmailConfirmationPage/EmailConfirmationPage.js +0 -34
- package/dist/esm/Pages/EmailConfirmationPage/emailConfirmationPage.scss +0 -92
- package/dist/esm/Pages/EmailConfirmationPage/index.d.ts +0 -1
- package/dist/esm/Pages/EmailConfirmationPage/index.js +0 -1
- package/dist/esm/Pages/JoinTeamPage/JoinTeamPage.d.ts +0 -1
- package/dist/esm/Pages/JoinTeamPage/JoinTeamPage.js +0 -6
- package/dist/esm/Pages/JoinTeamPage/index.d.ts +0 -1
- package/dist/esm/Pages/JoinTeamPage/index.js +0 -1
- package/dist/esm/Pages/JoinTeamPage/joinTeamPage.scss +0 -50
- package/dist/esm/Pages/LoginPage/LoginPage.d.ts +0 -1
- package/dist/esm/Pages/LoginPage/LoginPage.js +0 -32
- package/dist/esm/Pages/LoginPage/index.d.ts +0 -1
- package/dist/esm/Pages/LoginPage/index.js +0 -1
- package/dist/esm/Pages/LoginPage/loginPage.scss +0 -80
- package/dist/esm/Pages/RegisterPage/RegisterPage.d.ts +0 -1
- package/dist/esm/Pages/RegisterPage/RegisterPage.js +0 -34
- package/dist/esm/Pages/RegisterPage/index.d.ts +0 -1
- package/dist/esm/Pages/RegisterPage/index.js +0 -1
- package/dist/esm/Pages/RegisterPage/registerPage.scss +0 -72
- package/dist/esm/Pages/ResetPasswordPage/ResetPasswordPage.d.ts +0 -1
- package/dist/esm/Pages/ResetPasswordPage/ResetPasswordPage.js +0 -10
- package/dist/esm/Pages/ResetPasswordPage/index.d.ts +0 -1
- package/dist/esm/Pages/ResetPasswordPage/index.js +0 -1
- package/dist/esm/Pages/ResetPasswordPage/resetPasswordPage.scss +0 -41
- package/dist/esm/Pages/StartPage/StartPage.d.ts +0 -4
- package/dist/esm/Pages/StartPage/StartPage.js +0 -22
- package/dist/esm/Pages/StartPage/index.d.ts +0 -1
- package/dist/esm/Pages/StartPage/index.js +0 -1
- package/dist/esm/Pages/StartPage/startPage.scss +0 -58
- package/dist/esm/Pages/index.d.ts +0 -6
- package/dist/esm/Pages/index.js +0 -6
- package/dist/esm/Pages/index.scss +0 -9
- package/dist/esm/Utils/Divider/Divider.d.ts +0 -1
- package/dist/esm/Utils/Divider/Divider.js +0 -2
- package/dist/esm/Utils/Divider/divider.scss +0 -11
- package/dist/esm/Utils/ErrorBanner/ErrorBanner.d.ts +0 -4
- package/dist/esm/Utils/ErrorBanner/ErrorBanner.js +0 -6
- package/dist/esm/Utils/ErrorBanner/errorBanner.scss +0 -24
- package/dist/esm/Utils/ErrorBanner/index.d.ts +0 -1
- package/dist/esm/Utils/ErrorBanner/index.js +0 -1
- package/dist/esm/Utils/Link/Link.d.ts +0 -7
- package/dist/esm/Utils/Link/Link.js +0 -5
- package/dist/esm/Utils/Link/index.d.ts +0 -1
- package/dist/esm/Utils/Link/index.js +0 -1
- package/dist/esm/Utils/Link/index.scss +0 -1
- package/dist/esm/Utils/Link/link.scss +0 -21
- package/dist/esm/Utils/Modal/Modal.d.ts +0 -8
- package/dist/esm/Utils/Modal/Modal.js +0 -24
- package/dist/esm/Utils/Modal/index.d.ts +0 -1
- package/dist/esm/Utils/Modal/index.js +0 -1
- package/dist/esm/Utils/Modal/modal.scss +0 -33
- package/dist/esm/Utils/Portal/Portal.d.ts +0 -7
- package/dist/esm/Utils/Portal/Portal.js +0 -5
- package/dist/esm/Utils/SectionPlaceholder/SectionPlaceholder.d.ts +0 -5
- package/dist/esm/Utils/SectionPlaceholder/SectionPlaceholder.js +0 -2
- package/dist/esm/Utils/SectionPlaceholder/sectionPlaceholder.scss +0 -22
- package/dist/esm/Utils/Spinner/Spinner.d.ts +0 -5
- package/dist/esm/Utils/Spinner/Spinner.js +0 -5
- package/dist/esm/Utils/Spinner/spinner.scss +0 -41
- package/dist/esm/Utils/api.d.ts +0 -1
- package/dist/esm/Utils/api.js +0 -7
- package/dist/esm/Utils/index.d.ts +0 -7
- package/dist/esm/Utils/index.js +0 -7
- package/dist/esm/Utils/index.scss +0 -6
- package/dist/esm/Widgets/Header/Header.d.ts +0 -7
- package/dist/esm/Widgets/Header/Header.js +0 -18
- package/dist/esm/Widgets/Header/header.scss +0 -50
- package/dist/esm/Widgets/Header/index.d.ts +0 -1
- package/dist/esm/Widgets/Header/index.js +0 -1
- package/dist/esm/Widgets/Sidebar/Sidebar.d.ts +0 -9
- package/dist/esm/Widgets/Sidebar/Sidebar.js +0 -25
- package/dist/esm/Widgets/Sidebar/index.d.ts +0 -1
- package/dist/esm/Widgets/Sidebar/index.js +0 -1
- package/dist/esm/Widgets/Sidebar/sidebar.scss +0 -23
- package/dist/esm/Widgets/index.d.ts +0 -2
- package/dist/esm/Widgets/index.js +0 -2
- package/dist/esm/Widgets/index.scss +0 -2
- package/dist/esm/app/main.d.ts +0 -1
- package/dist/esm/app/main.js +0 -7
- package/dist/esm/app/routes/AppRouter.d.ts +0 -1
- package/dist/esm/app/routes/AppRouter.js +0 -31
- package/dist/esm/app/routes/index.d.ts +0 -1
- package/dist/esm/app/routes/index.js +0 -1
- package/dist/esm/app/store/index.d.ts +0 -1
- package/dist/esm/app/store/index.js +0 -1
- package/dist/esm/app/store/store.d.ts +0 -14
- package/dist/esm/app/store/store.js +0 -13
- package/dist/esm/assets/img/belt.svg +0 -3
- package/dist/esm/assets/img/burger-menu.svg +0 -3
- package/dist/esm/assets/img/check.svg +0 -3
- package/dist/esm/assets/img/checked.svg +0 -3
- package/dist/esm/assets/img/chevron-down.svg +0 -3
- package/dist/esm/assets/img/chevron-left.svg +0 -3
- package/dist/esm/assets/img/cross.svg +0 -3
- package/dist/esm/assets/img/dot.svg +0 -3
- package/dist/esm/assets/img/eye-close.svg +0 -1
- package/dist/esm/assets/img/eye-open.svg +0 -3
- package/dist/esm/assets/img/left-arrow.svg +0 -3
- package/dist/esm/assets/img/logo-main.svg +0 -6
- package/dist/esm/assets/img/logo.svg +0 -44
- package/dist/esm/assets/img/partial-checked.svg +0 -3
- package/dist/esm/assets/img/right-arrow.svg +0 -3
- package/dist/esm/assets/img/sample-logo.svg +0 -17
- package/dist/esm/assets/img/search.svg +0 -3
- package/dist/esm/assets/img/star.svg +0 -3
- package/dist/esm/assets/img/warning.svg +0 -3
- package/dist/esm/assets/scss/index.scss +0 -5
- package/dist/esm/assets/scss/settings/fonts.scss +0 -29
- package/dist/esm/assets/scss/settings/globals.scss +0 -5
- package/dist/esm/assets/scss/settings/helpers.scss +0 -3
- package/dist/esm/assets/scss/settings/reset.scss +0 -8
- package/dist/esm/assets/scss/settings/variables.scss +0 -91
- package/dist/esm/entities/user/api/api.d.ts +0 -648
- package/dist/esm/entities/user/api/api.js +0 -41
- package/dist/esm/entities/user/api/index.d.ts +0 -1
- package/dist/esm/entities/user/api/index.js +0 -1
- package/dist/esm/entities/user/index.d.ts +0 -2
- package/dist/esm/entities/user/index.js +0 -2
- package/dist/esm/entities/user/model/index.d.ts +0 -3
- package/dist/esm/entities/user/model/index.js +0 -2
- package/dist/esm/entities/user/model/selectors.d.ts +0 -4
- package/dist/esm/entities/user/model/selectors.js +0 -2
- package/dist/esm/entities/user/model/slice.d.ts +0 -10
- package/dist/esm/entities/user/model/slice.js +0 -31
- package/dist/esm/entities/user/model/types.d.ts +0 -17
- package/dist/esm/entities/user/model/types.js +0 -1
- package/dist/esm/index.d.ts +0 -3
- package/dist/esm/index.js +0 -3
- package/dist/esm/index.scss +0 -6
- package/dist/esm/shared/model/api.d.ts +0 -6
- package/dist/esm/shared/model/api.js +0 -6
- package/dist/esm/shared/model/constants.d.ts +0 -1
- package/dist/esm/shared/model/constants.js +0 -1
- package/dist/esm/shared/model/index.d.ts +0 -2
- package/dist/esm/shared/model/index.js +0 -2
- package/dist/esm/shared/ui/Avatar/Avatar.d.ts +0 -8
- package/dist/esm/shared/ui/Avatar/Avatar.js +0 -6
- package/dist/esm/shared/ui/Avatar/avatar.scss +0 -62
- package/dist/esm/shared/ui/Avatar/index.d.ts +0 -1
- package/dist/esm/shared/ui/Avatar/index.js +0 -1
- package/dist/esm/shared/ui/index.d.ts +0 -1
- package/dist/esm/shared/ui/index.js +0 -1
- package/dist/esm/shared/ui/index.scss +0 -1
- package/dist/esm/tools/customValidators.d.ts +0 -5
- package/dist/esm/tools/customValidators.js +0 -19
- package/dist/esm/tools/getCoords.d.ts +0 -12
- package/dist/esm/tools/getCoords.js +0 -18
- package/dist/esm/tools/regExp.d.ts +0 -5
- package/dist/esm/tools/regExp.js +0 -5
- package/dist/esm/ui.d.ts +0 -3
- package/dist/esm/ui.scss +0 -4
- /package/dist/{cjs → types}/Inputs/Button/Button.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/Button/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/Checkbox/Checkbox.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/Checkbox/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/EmailField/EmailField.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/EmailField/ErrorMessages.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/EmailField/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/InnField/ErrorMessages.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/InnField/InnField.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/InnField/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/NameField/ErrorMessages.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/NameField/NameField.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/NameField/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/OtpInput/ErrorMessages.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/OtpInput/OtpInput.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/OtpInput/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/PasswordField/ErrorMessages.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/PasswordField/PasswordField.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/PasswordField/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/PhoneField/ErrorMessages.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/PhoneField/PhoneField.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/PhoneField/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/RepeatPasswordField/ErrorMessages.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/RepeatPasswordField/RepeatPasswordField.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/RepeatPasswordField/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/Selector/Collapse.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/Selector/Dropdown.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/Selector/Option/Option.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/Selector/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/TextField/TextField.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/TextField/index.d.ts +0 -0
- /package/dist/{cjs → types}/Inputs/index.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/Divider/Divider.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/ErrorBanner/ErrorBanner.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/ErrorBanner/index.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/Link/Link.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/Modal/Modal.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/Portal/Portal.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/SectionPlaceholder/SectionPlaceholder.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/Spinner/Spinner.d.ts +0 -0
- /package/dist/{cjs → types}/Utils/index.d.ts +0 -0
- /package/dist/{cjs → types}/shared/ui/Avatar/Avatar.d.ts +0 -0
- /package/dist/{cjs → types}/shared/ui/Avatar/index.d.ts +0 -0
- /package/dist/{cjs → types}/shared/ui/index.d.ts +0 -0
- /package/dist/{cjs → types}/tools/customValidators.d.ts +0 -0
- /package/dist/{cjs → types}/tools/getCoords.d.ts +0 -0
- /package/dist/{cjs → types}/tools/regExp.d.ts +0 -0
- /package/dist/{cjs → types}/ui.d.ts +0 -0
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { useEffect, useState } from 'react';
|
|
3
|
-
import { nameValidator } from '../../tools/customValidators';
|
|
4
|
-
import { TextField } from '../TextField';
|
|
5
|
-
import { emptyFirstNameError, emptyLastNameError, emptyPatronymicNameError, emptyFullNameError, notCorrectFirstNameError, notCorrectLastNameError, notCorrectPatronymicNameError, notCorrectFullNameError } from './ErrorMessages';
|
|
6
|
-
;
|
|
7
|
-
export const NameField = (props) => {
|
|
8
|
-
const { nameType = 'fullName', onValidated, onTextValid } = props;
|
|
9
|
-
const [errorMessage, setErrorMessage] = useState('');
|
|
10
|
-
const [touched, setTouched] = useState(false);
|
|
11
|
-
const [name, setName] = useState('');
|
|
12
|
-
const nameArgs = {
|
|
13
|
-
firstName: {
|
|
14
|
-
label: 'Имя',
|
|
15
|
-
emptyMessage: emptyFirstNameError,
|
|
16
|
-
notCorrectMessage: notCorrectFirstNameError,
|
|
17
|
-
},
|
|
18
|
-
lastName: {
|
|
19
|
-
label: 'Фамилия',
|
|
20
|
-
emptyMessage: emptyLastNameError,
|
|
21
|
-
notCorrectMessage: notCorrectLastNameError,
|
|
22
|
-
},
|
|
23
|
-
patronymic: {
|
|
24
|
-
label: 'Отчество',
|
|
25
|
-
emptyMessage: emptyPatronymicNameError,
|
|
26
|
-
notCorrectMessage: notCorrectPatronymicNameError,
|
|
27
|
-
},
|
|
28
|
-
fullName: {
|
|
29
|
-
label: 'ФИО',
|
|
30
|
-
emptyMessage: emptyFullNameError,
|
|
31
|
-
notCorrectMessage: notCorrectFullNameError,
|
|
32
|
-
}
|
|
33
|
-
};
|
|
34
|
-
const { label, emptyMessage, notCorrectMessage } = nameArgs[nameType];
|
|
35
|
-
useEffect(() => {
|
|
36
|
-
if (!touched) {
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
const valid = nameValidator(nameType === 'fullName' ? name.split(' ') : name);
|
|
40
|
-
if (!valid) {
|
|
41
|
-
onValidated(false);
|
|
42
|
-
onTextValid('');
|
|
43
|
-
const error = (!name && emptyMessage) ||
|
|
44
|
-
(!valid && notCorrectMessage) ||
|
|
45
|
-
'';
|
|
46
|
-
setErrorMessage(error);
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
onValidated(true);
|
|
50
|
-
onTextValid(name);
|
|
51
|
-
setErrorMessage('');
|
|
52
|
-
}, [emptyMessage, name, nameType, notCorrectMessage, onTextValid, onValidated, touched]);
|
|
53
|
-
return (_jsx(TextField, { onChange: setName, onTouched: setTouched, state: touched && errorMessage ? 'error' : 'idle', errorMessage: errorMessage, label: label, type: 'text', value: name, required: true, checkIcon: true, ...props }));
|
|
54
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const otpError = "\u041D\u0435\u0432\u0435\u0440\u043D\u044B\u0439 \u043A\u043E\u0434. \u0421\u0432\u0435\u0440\u044C\u0442\u0435\u0441\u044C \u0441 \u043F\u0438\u0441\u044C\u043C\u043E\u043C";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export const otpError = 'Неверный код. Сверьтесь с письмом';
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export interface IOtpInput {
|
|
2
|
-
length?: number;
|
|
3
|
-
errorMessage: string;
|
|
4
|
-
responseReceived: boolean;
|
|
5
|
-
loading: boolean;
|
|
6
|
-
onComplete: (pin: string) => void;
|
|
7
|
-
setErrorMessage: (value: string) => void;
|
|
8
|
-
}
|
|
9
|
-
export declare const OtpInput: (props: IOtpInput) => JSX.Element;
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import cn from 'classnames';
|
|
3
|
-
import _ from 'lodash/fp';
|
|
4
|
-
import { useRef, useState, useEffect } from 'react';
|
|
5
|
-
export const OtpInput = (props) => {
|
|
6
|
-
const { length = 6, onComplete = _.noop, errorMessage = '', setErrorMessage = _.noop, responseReceived = false, loading = false, } = props;
|
|
7
|
-
const inputRef = useRef(Array(length).fill(null));
|
|
8
|
-
const [Otp, setOtp] = useState(Array(length).fill(''));
|
|
9
|
-
const currentTarget = inputRef.current;
|
|
10
|
-
const handleComplete = (value, index) => {
|
|
11
|
-
onComplete(value.join(''));
|
|
12
|
-
currentTarget[index].blur();
|
|
13
|
-
};
|
|
14
|
-
const handleTextChange = (index) => (e) => {
|
|
15
|
-
setErrorMessage('');
|
|
16
|
-
const newPin = [...Otp];
|
|
17
|
-
const input = e.target.value.replace(/\D/g, '');
|
|
18
|
-
newPin[index] = input;
|
|
19
|
-
setOtp(newPin);
|
|
20
|
-
if (input.length === 1 && index < length - 1) {
|
|
21
|
-
currentTarget[index + 1]?.focus();
|
|
22
|
-
}
|
|
23
|
-
if (input.length === 0 && index > 0) {
|
|
24
|
-
currentTarget[index - 1]?.focus();
|
|
25
|
-
}
|
|
26
|
-
if (newPin.every((digit) => digit !== '')) {
|
|
27
|
-
onComplete(newPin.join(''));
|
|
28
|
-
currentTarget[index].blur();
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
const handlePaste = (index) => (e) => {
|
|
32
|
-
setErrorMessage('');
|
|
33
|
-
const value = e.clipboardData?.getData('text');
|
|
34
|
-
const updatedValue = value
|
|
35
|
-
.toString()
|
|
36
|
-
.replace(/\D/g, '')
|
|
37
|
-
.split('')
|
|
38
|
-
.slice(0, length);
|
|
39
|
-
setOtp(updatedValue);
|
|
40
|
-
if (updatedValue.length === length) {
|
|
41
|
-
handleComplete(updatedValue, index);
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
const goToFirstEmptyInput = () => {
|
|
45
|
-
const firstEmptyInput = currentTarget.findIndex((el) => el.value === '');
|
|
46
|
-
firstEmptyInput >= 0
|
|
47
|
-
?
|
|
48
|
-
currentTarget[firstEmptyInput].focus()
|
|
49
|
-
:
|
|
50
|
-
currentTarget[length - 1].focus();
|
|
51
|
-
setErrorMessage('');
|
|
52
|
-
};
|
|
53
|
-
const handleBackspace = (index) => (e) => {
|
|
54
|
-
if (e.key === 'Backspace' &&
|
|
55
|
-
index !== 0 &&
|
|
56
|
-
currentTarget[index].value.length === 0) {
|
|
57
|
-
currentTarget[index - 1]?.focus();
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
const handleKeyDown = (e) => {
|
|
61
|
-
if (Number.parseInt(e.key) >= 0) {
|
|
62
|
-
goToFirstEmptyInput();
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
const inputMods = [
|
|
66
|
-
'otp__input',
|
|
67
|
-
{ 'otp__input--error': errorMessage },
|
|
68
|
-
];
|
|
69
|
-
useEffect(() => {
|
|
70
|
-
!loading && currentTarget[0].focus();
|
|
71
|
-
}, [responseReceived, loading, currentTarget]);
|
|
72
|
-
useEffect(() => {
|
|
73
|
-
if (responseReceived) {
|
|
74
|
-
setOtp(Array(length).fill(''));
|
|
75
|
-
}
|
|
76
|
-
}, [responseReceived, length]);
|
|
77
|
-
return (_jsxs("div", { className: 'otp', children: [Array.from({ length }, (_, index) => (_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: cn(inputMods), tabIndex: index + 1 }, index))), errorMessage && (_jsx("span", { className: 'otp__error', children: errorMessage }))] }));
|
|
78
|
-
};
|
|
@@ -1,39 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export declare const emptyPasswordError = "\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u043F\u0430\u0440\u043E\u043B\u044C";
|
|
2
|
-
export declare const notCorrectPasswordError = "\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u043F\u0430\u0440\u043E\u043B\u044C \u043D\u0435 \u043C\u0435\u043D\u0435\u0435 6 \u0441\u0438\u043C\u0432\u043E\u043B\u043E\u0432";
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { type ITextField, type THTMLInput } from '../TextField';
|
|
2
|
-
export interface IPasswordField extends THTMLInput, Pick<ITextField, 'onVisibilityToggle'> {
|
|
3
|
-
onValidated: (state: boolean) => void;
|
|
4
|
-
onPasswordInput: (value: string) => void;
|
|
5
|
-
hidePassword?: boolean;
|
|
6
|
-
}
|
|
7
|
-
export declare const PasswordField: (props: IPasswordField) => JSX.Element;
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import _ from 'lodash/fp';
|
|
3
|
-
import { useEffect, useState } from 'react';
|
|
4
|
-
import { passwordValidator } from '../../tools/customValidators';
|
|
5
|
-
import { TextField, } from '../TextField';
|
|
6
|
-
import { emptyPasswordError, notCorrectPasswordError } from './ErrorMessages';
|
|
7
|
-
export const PasswordField = (props) => {
|
|
8
|
-
const { onValidated, onPasswordInput, hidePassword = true, } = props;
|
|
9
|
-
const [errorMessage, setErrorMessage] = useState('');
|
|
10
|
-
const [touched, setTouched] = useState(false);
|
|
11
|
-
const [password, setPassword] = useState('');
|
|
12
|
-
useEffect(() => {
|
|
13
|
-
if (!touched) {
|
|
14
|
-
return;
|
|
15
|
-
}
|
|
16
|
-
onPasswordInput(password);
|
|
17
|
-
const valid = passwordValidator(password);
|
|
18
|
-
if (!valid) {
|
|
19
|
-
onValidated(false);
|
|
20
|
-
setErrorMessage(_.cond([
|
|
21
|
-
[() => !password, () => emptyPasswordError],
|
|
22
|
-
[() => !valid, () => notCorrectPasswordError],
|
|
23
|
-
]));
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
onValidated(true);
|
|
27
|
-
setErrorMessage('');
|
|
28
|
-
}, [
|
|
29
|
-
password,
|
|
30
|
-
onPasswordInput,
|
|
31
|
-
onValidated,
|
|
32
|
-
touched
|
|
33
|
-
]);
|
|
34
|
-
return (_jsx(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 }));
|
|
35
|
-
};
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export declare const emptyPhoneError = "\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u043D\u043E\u043C\u0435\u0440 \u0442\u0435\u043B\u0435\u0444\u043E\u043D\u0430";
|
|
2
|
-
export declare const notCorrectPhoneError = "\u041D\u043E\u043C\u0435\u0440 \u0442\u0435\u043B\u0435\u0444\u043E\u043D\u0430 \u2014 10 \u0446\u0438\u0444\u0440";
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import _ from 'lodash/fp';
|
|
3
|
-
import { useEffect, useState } from 'react';
|
|
4
|
-
import { phoneValidator } from '../../tools/customValidators';
|
|
5
|
-
import { TextField } from '../TextField';
|
|
6
|
-
import { emptyPhoneError, notCorrectPhoneError } from './ErrorMessages';
|
|
7
|
-
export const PhoneField = (props) => {
|
|
8
|
-
const { onValidated, onTextValid } = props;
|
|
9
|
-
const [errorMessage, setErrorMessage] = useState('');
|
|
10
|
-
const [touched, setTouched] = useState(false);
|
|
11
|
-
const [phoneNumber, setPhoneNumber] = useState('');
|
|
12
|
-
const getInputNumbersValue = (value) => {
|
|
13
|
-
return value.replace(/\D/g, '');
|
|
14
|
-
};
|
|
15
|
-
const onPhoneInput = (value, e) => {
|
|
16
|
-
const { target } = e;
|
|
17
|
-
const { selectionStart } = target;
|
|
18
|
-
let inputNumbersValue = getInputNumbersValue(value);
|
|
19
|
-
let formattedInputValue = '';
|
|
20
|
-
const { data, inputType } = e.nativeEvent;
|
|
21
|
-
if (inputType === 'deleteContentBackward' && value.length === 0) {
|
|
22
|
-
setPhoneNumber('');
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
if (value.length !== selectionStart) {
|
|
26
|
-
if (data === null || /\d/g.test(data)) {
|
|
27
|
-
setPhoneNumber(value);
|
|
28
|
-
}
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
if (['7', '8', '9'].includes(inputNumbersValue[0])) {
|
|
32
|
-
if (inputNumbersValue[0] === '9')
|
|
33
|
-
inputNumbersValue = '7' + inputNumbersValue;
|
|
34
|
-
const firstSymbols = (inputNumbersValue[0] === '8') ? '8' : '+7';
|
|
35
|
-
formattedInputValue = firstSymbols;
|
|
36
|
-
if (inputNumbersValue.length > 1) {
|
|
37
|
-
formattedInputValue += '(' + inputNumbersValue.substring(1, 4);
|
|
38
|
-
}
|
|
39
|
-
if (inputNumbersValue.length >= 5) {
|
|
40
|
-
formattedInputValue += ')' + inputNumbersValue.substring(4, 7);
|
|
41
|
-
}
|
|
42
|
-
if (inputNumbersValue.length >= 8) {
|
|
43
|
-
formattedInputValue += '-' + inputNumbersValue.substring(7, 9);
|
|
44
|
-
}
|
|
45
|
-
if (inputNumbersValue.length >= 10) {
|
|
46
|
-
formattedInputValue += '-' + inputNumbersValue.substring(9, 11);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
else {
|
|
50
|
-
formattedInputValue = '+' + inputNumbersValue.substring(0, 16);
|
|
51
|
-
}
|
|
52
|
-
setPhoneNumber(formattedInputValue);
|
|
53
|
-
};
|
|
54
|
-
useEffect(() => {
|
|
55
|
-
if (!touched) {
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
const valid = phoneValidator(phoneNumber);
|
|
59
|
-
if (!valid) {
|
|
60
|
-
onValidated(false);
|
|
61
|
-
onTextValid('');
|
|
62
|
-
setErrorMessage(_.cond([
|
|
63
|
-
[_.isEmpty, () => emptyPhoneError],
|
|
64
|
-
[() => !valid, () => notCorrectPhoneError],
|
|
65
|
-
[_.stubTrue, _.stubString]
|
|
66
|
-
]));
|
|
67
|
-
return;
|
|
68
|
-
}
|
|
69
|
-
onValidated(true);
|
|
70
|
-
onTextValid(phoneNumber.replace(/\D/g, ''));
|
|
71
|
-
setErrorMessage('');
|
|
72
|
-
}, [onTextValid, onValidated, phoneNumber, touched]);
|
|
73
|
-
return (_jsx(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 }));
|
|
74
|
-
};
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export declare const emptyRepeatPasswordError = "\u0412\u0432\u0435\u0434\u0438\u0442\u0435 \u043F\u0430\u0440\u043E\u043B\u044C \u043F\u043E\u0432\u0442\u043E\u0440\u043D\u043E";
|
|
2
|
-
export declare const notCorrectRepeatPasswordError = "\u041F\u0430\u0440\u043E\u043B\u0438 \u043D\u0435 \u0441\u043E\u0432\u043F\u0430\u0434\u0430\u044E\u0442";
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { type ITextField, type THTMLInput } from '../TextField';
|
|
2
|
-
export interface IRepeatPasswordField extends THTMLInput, Pick<ITextField, 'onVisibilityToggle'> {
|
|
3
|
-
equalHandler: (state: boolean) => void;
|
|
4
|
-
comparedValue: string;
|
|
5
|
-
}
|
|
6
|
-
export declare const RepeatPasswordField: (props: IRepeatPasswordField) => JSX.Element;
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import _ from 'lodash/fp';
|
|
3
|
-
import { useEffect, useState } from 'react';
|
|
4
|
-
import { TextField, } from '../TextField';
|
|
5
|
-
import { emptyRepeatPasswordError, notCorrectRepeatPasswordError } from './ErrorMessages';
|
|
6
|
-
export const RepeatPasswordField = (props) => {
|
|
7
|
-
const { equalHandler, comparedValue } = props;
|
|
8
|
-
const [touched, setTouched] = useState(false);
|
|
9
|
-
const [password, setPassword] = useState('');
|
|
10
|
-
const [errorMessage, setErrorMessage] = useState('');
|
|
11
|
-
useEffect(() => {
|
|
12
|
-
equalHandler(comparedValue === password);
|
|
13
|
-
if (!touched) {
|
|
14
|
-
return;
|
|
15
|
-
}
|
|
16
|
-
setErrorMessage(_.cond([
|
|
17
|
-
[() => !password, () => emptyRepeatPasswordError],
|
|
18
|
-
[() => comparedValue !== password, () => notCorrectRepeatPasswordError],
|
|
19
|
-
]));
|
|
20
|
-
}, [touched, password, comparedValue, equalHandler]);
|
|
21
|
-
return (_jsx(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 }));
|
|
22
|
-
};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { type ReactNode } from 'react';
|
|
2
|
-
import { type IOptionItem } from './Option/Option';
|
|
3
|
-
export interface ICollapse {
|
|
4
|
-
options: IOptionItem[];
|
|
5
|
-
selected?: IOptionItem;
|
|
6
|
-
title?: ReactNode;
|
|
7
|
-
onSelect: (selected: IOptionItem['value']) => void;
|
|
8
|
-
chevron?: boolean;
|
|
9
|
-
optionsIcon?: ReactNode;
|
|
10
|
-
closeOnClick?: boolean;
|
|
11
|
-
}
|
|
12
|
-
export declare const Collapse: (props: ICollapse) => JSX.Element;
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import cn from 'classnames';
|
|
3
|
-
import { useRef, useState, useEffect } from 'react';
|
|
4
|
-
import ChevronDown from '../../assets/img/chevron-down.svg';
|
|
5
|
-
import { Option } from './Option/Option';
|
|
6
|
-
export const Collapse = (props) => {
|
|
7
|
-
const { options, selected, title, onSelect, chevron = true, optionsIcon, closeOnClick = true, } = props;
|
|
8
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
9
|
-
const rootRef = useRef(null);
|
|
10
|
-
const titleRef = useRef(null);
|
|
11
|
-
useEffect(() => {
|
|
12
|
-
const handleClick = (event) => {
|
|
13
|
-
const { target } = event;
|
|
14
|
-
if (target instanceof Node &&
|
|
15
|
-
rootRef.current &&
|
|
16
|
-
!rootRef.current.contains(target)) {
|
|
17
|
-
closeOnClick && setIsOpen(false);
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
window.addEventListener('click', handleClick);
|
|
21
|
-
return () => {
|
|
22
|
-
window.removeEventListener('click', handleClick);
|
|
23
|
-
};
|
|
24
|
-
}, [closeOnClick, isOpen]);
|
|
25
|
-
const handleOptionClick = (value) => {
|
|
26
|
-
closeOnClick && setIsOpen(false);
|
|
27
|
-
onSelect(value);
|
|
28
|
-
};
|
|
29
|
-
const handleTitleClick = () => {
|
|
30
|
-
setIsOpen(!isOpen);
|
|
31
|
-
};
|
|
32
|
-
const chevronMods = [
|
|
33
|
-
'title__chevron',
|
|
34
|
-
isOpen && 'title__chevron--rotate',
|
|
35
|
-
];
|
|
36
|
-
const optionsBlock = (_jsx("div", { className: 'selector__options selector__options--slide-down', children: options.map((option) => (_jsx(Option, { option: option, onClick: handleOptionClick, optionsIcon: optionsIcon, selected: option.value === selected?.value }, option.value))) }));
|
|
37
|
-
const hasIcon = optionsIcon !== undefined || selected?.icon !== undefined;
|
|
38
|
-
const label = selected ? (_jsxs("div", { className: 'title__label', children: [hasIcon && (_jsx("div", { className: 'title__icon', children: selected?.icon ?? optionsIcon })), selected.label] })) : title;
|
|
39
|
-
return (_jsxs("div", { className: 'selector', ref: rootRef, children: [_jsxs("div", { className: cn('title', isOpen && 'title--active'), onClick: handleTitleClick, ref: titleRef, children: [label, chevron && (_jsx("div", { className: cn(chevronMods), children: _jsx(ChevronDown, {}) }))] }), isOpen && optionsBlock] }));
|
|
40
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { type ReactNode } from 'react';
|
|
2
|
-
import { type IOptionItem } from './Option/Option';
|
|
3
|
-
export interface IDropdown {
|
|
4
|
-
options: IOptionItem[];
|
|
5
|
-
selected?: IOptionItem;
|
|
6
|
-
title?: ReactNode;
|
|
7
|
-
onSelect: (selected: IOptionItem['value']) => void;
|
|
8
|
-
optionsIcon?: ReactNode;
|
|
9
|
-
optionsDirection?: 'up' | 'down';
|
|
10
|
-
noFlip?: boolean;
|
|
11
|
-
optionsMaxHeight?: number;
|
|
12
|
-
}
|
|
13
|
-
export declare const Dropdown: (props: IDropdown) => JSX.Element;
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import cn from 'classnames';
|
|
3
|
-
import { useRef, useState, useEffect } from 'react';
|
|
4
|
-
import { getCoords } from '../../tools/getCoords';
|
|
5
|
-
import { Portal } from '../../Utils';
|
|
6
|
-
import { Option } from './Option/Option';
|
|
7
|
-
export const Dropdown = (props) => {
|
|
8
|
-
const { options, selected, title, onSelect, optionsIcon, optionsMaxHeight, optionsDirection = 'down', noFlip = false, } = props;
|
|
9
|
-
const [isOpen, setIsOpen] = useState(false);
|
|
10
|
-
const [direction, setDirection] = useState(optionsDirection);
|
|
11
|
-
const [maxHeight, setMaxHeight] = useState(optionsMaxHeight);
|
|
12
|
-
const rootRef = useRef(null);
|
|
13
|
-
const titleRef = useRef(null);
|
|
14
|
-
const optionsRef = useRef(null);
|
|
15
|
-
const titleCoords = getCoords(titleRef);
|
|
16
|
-
useEffect(() => {
|
|
17
|
-
const handleClick = (event) => {
|
|
18
|
-
const { target } = event;
|
|
19
|
-
if (target instanceof Node &&
|
|
20
|
-
rootRef.current &&
|
|
21
|
-
!rootRef.current.contains(target)) {
|
|
22
|
-
setIsOpen(false);
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
window.addEventListener('click', handleClick);
|
|
26
|
-
return () => {
|
|
27
|
-
window.removeEventListener('click', handleClick);
|
|
28
|
-
};
|
|
29
|
-
}, [isOpen]);
|
|
30
|
-
useEffect(() => {
|
|
31
|
-
if (!optionsRef.current || !titleCoords) {
|
|
32
|
-
return;
|
|
33
|
-
}
|
|
34
|
-
const { topViewport: distanceToTop, bottomViewport } = titleCoords;
|
|
35
|
-
const windowHeight = window.innerHeight;
|
|
36
|
-
const optionsHeight = optionsRef.current.offsetHeight;
|
|
37
|
-
const distanceToBottom = windowHeight - bottomViewport;
|
|
38
|
-
const isDownDirection = optionsDirection === 'down';
|
|
39
|
-
setDirection(optionsDirection);
|
|
40
|
-
setMaxHeight(isDownDirection ? distanceToBottom : distanceToTop);
|
|
41
|
-
if (noFlip) {
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
const hasSpaceToOptionsBelow = distanceToBottom - optionsHeight > 0;
|
|
45
|
-
const hasSpaceToOptionsAbove = distanceToTop - optionsHeight > 0;
|
|
46
|
-
const oppositeDirection = isDownDirection ? 'up' : 'down';
|
|
47
|
-
if (isDownDirection &&
|
|
48
|
-
!hasSpaceToOptionsBelow &&
|
|
49
|
-
hasSpaceToOptionsAbove) {
|
|
50
|
-
setDirection(oppositeDirection);
|
|
51
|
-
setMaxHeight(distanceToTop);
|
|
52
|
-
return;
|
|
53
|
-
}
|
|
54
|
-
if (!isDownDirection &&
|
|
55
|
-
!hasSpaceToOptionsAbove &&
|
|
56
|
-
hasSpaceToOptionsBelow) {
|
|
57
|
-
setDirection(oppositeDirection);
|
|
58
|
-
setMaxHeight(distanceToBottom);
|
|
59
|
-
}
|
|
60
|
-
}, [isOpen, noFlip, optionsDirection, titleCoords]);
|
|
61
|
-
const handleOptionClick = (value) => {
|
|
62
|
-
setIsOpen(false);
|
|
63
|
-
onSelect(value);
|
|
64
|
-
};
|
|
65
|
-
const handleTitleClick = () => {
|
|
66
|
-
setIsOpen(!isOpen);
|
|
67
|
-
};
|
|
68
|
-
const optionsPosition = {
|
|
69
|
-
position: 'absolute',
|
|
70
|
-
left: `${titleCoords?.leftDocument ?? 0}px`,
|
|
71
|
-
minWidth: `${titleCoords?.width ?? 0}px`,
|
|
72
|
-
maxHeight: `${optionsMaxHeight ?? maxHeight}px`,
|
|
73
|
-
...(direction === 'down'
|
|
74
|
-
? { top: `${titleCoords?.bottomDocument ?? 0}px` }
|
|
75
|
-
: { bottom: `${window?.innerHeight - (titleCoords?.topDocument ?? 0)}px` }),
|
|
76
|
-
};
|
|
77
|
-
const optionsBlock = titleCoords && (_jsx("div", { className: `selector__options selector__options--slide-${direction}`, style: { ...optionsPosition }, ref: optionsRef, children: options.map((option) => (_jsx(Option, { option: option, onClick: handleOptionClick, optionsIcon: optionsIcon, selected: option.value === selected?.value }, option.value))) }));
|
|
78
|
-
const hasIcon = optionsIcon !== undefined || selected?.icon !== undefined;
|
|
79
|
-
const label = selected ? (_jsxs("div", { className: 'title__label', children: [hasIcon && (_jsx("div", { className: 'title__icon', children: selected?.icon ?? optionsIcon })), selected.label] })) : title;
|
|
80
|
-
return (_jsxs("div", { className: 'selector', ref: rootRef, children: [_jsx("div", { className: cn('title', isOpen && 'title--active'), onClick: handleTitleClick, ref: titleRef, children: label }), isOpen && _jsx(Portal, { children: optionsBlock })] }));
|
|
81
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import type { ReactNode } from 'react';
|
|
2
|
-
export interface IOptionItem {
|
|
3
|
-
label: string;
|
|
4
|
-
value: string;
|
|
5
|
-
icon?: ReactNode;
|
|
6
|
-
}
|
|
7
|
-
export interface IOption {
|
|
8
|
-
option: IOptionItem;
|
|
9
|
-
onClick: (value: IOptionItem['value']) => void;
|
|
10
|
-
selected?: boolean;
|
|
11
|
-
optionsIcon?: ReactNode;
|
|
12
|
-
}
|
|
13
|
-
export declare const Option: (props: IOption) => JSX.Element;
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import cn from 'classnames';
|
|
3
|
-
export const Option = (props) => {
|
|
4
|
-
const { option: { value, label, icon }, onClick, selected = false, optionsIcon, } = props;
|
|
5
|
-
const handleClick = (clickedValue) => () => {
|
|
6
|
-
onClick(clickedValue);
|
|
7
|
-
};
|
|
8
|
-
const hasIcon = optionsIcon !== undefined || icon !== undefined;
|
|
9
|
-
return (_jsxs("div", { className: cn('selector-option', selected && 'selector-option--selected'), onClick: handleClick(value), children: [hasIcon && (_jsx("div", { className: 'selector-option__icon', children: icon ?? optionsIcon })), label] }));
|
|
10
|
-
};
|
|
@@ -1,44 +0,0 @@
|
|
|
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
|
-
}
|