@addev-be/ui 1.1.3 → 1.1.4

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 (276) hide show
  1. package/assets/icons/arrow-down-1-9.svg +1 -1
  2. package/assets/icons/arrow-down-a-z.svg +1 -1
  3. package/assets/icons/arrow-up-z-a.svg +1 -1
  4. package/assets/icons/check.svg +1 -1
  5. package/assets/icons/circle-check.svg +1 -1
  6. package/assets/icons/down.svg +1 -1
  7. package/assets/icons/filter-full.svg +1 -1
  8. package/assets/icons/filter.svg +1 -1
  9. package/assets/icons/hashtag.svg +1 -1
  10. package/assets/icons/image-slash.svg +1 -1
  11. package/assets/icons/left.svg +1 -1
  12. package/assets/icons/magnifier.svg +1 -1
  13. package/assets/icons/phone.svg +1 -1
  14. package/assets/icons/right.svg +1 -1
  15. package/assets/icons/sort-calendar-ascending.svg +5 -5
  16. package/assets/icons/spinner-third.svg +1 -1
  17. package/assets/icons/table-columns.svg +1 -1
  18. package/assets/icons/table-footer-slash.svg +4 -4
  19. package/assets/icons/table-footer.svg +3 -3
  20. package/assets/icons/table.svg +1 -1
  21. package/assets/icons/up.svg +1 -1
  22. package/assets/icons/user-tie.svg +1 -1
  23. package/assets/icons/x-bar.svg +3 -3
  24. package/dist/components/data/DataGrid/helpers/columns.d.ts +11 -9
  25. package/dist/components/data/DataGrid/helpers/columns.js +17 -12
  26. package/dist/components/data/DataGrid/index.d.ts +1 -1
  27. package/dist/components/data/DataGrid/index.js +2 -2
  28. package/dist/components/data/DataGrid/styles.d.ts +1 -1
  29. package/dist/components/data/DataGrid/styles.js +2 -2
  30. package/dist/components/data/DataGrid/types.d.ts +8 -1
  31. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +11 -10
  32. package/dist/components/layout/Columns.d.ts +1 -1
  33. package/dist/components/layout/Columns.js +2 -2
  34. package/dist/components/layout/Flexbox.d.ts +1 -1
  35. package/dist/components/layout/Flexbox.js +2 -2
  36. package/dist/components/ui/TabsView/TabsList.d.ts +1 -1
  37. package/dist/components/ui/TabsView/styles.d.ts +1 -1
  38. package/dist/components/ui/TabsView/styles.js +2 -2
  39. package/dist/helpers/index.d.ts +0 -1
  40. package/dist/helpers/index.js +0 -1
  41. package/dist/helpers/styled/typography.d.ts +9 -0
  42. package/dist/helpers/styled/typography.js +51 -0
  43. package/dist/index.d.ts +2 -0
  44. package/dist/index.js +3 -0
  45. package/eslint.config.js +3 -3
  46. package/package.json +2 -2
  47. package/src/Icons.tsx +138 -138
  48. package/src/components/auth/LoginForm.tsx +84 -84
  49. package/src/components/auth/LoginPage.tsx +32 -32
  50. package/src/components/auth/PasswordRecoveryForm.tsx +52 -52
  51. package/src/components/auth/PasswordResetForm.tsx +112 -112
  52. package/src/components/auth/index.ts +4 -4
  53. package/src/components/auth/styles.ts +14 -14
  54. package/src/components/data/DataGrid/DataGridCell.tsx +81 -81
  55. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +9 -9
  56. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -59
  57. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +182 -182
  58. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  59. package/src/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.tsx +38 -38
  60. package/src/components/data/DataGrid/DataGridEditableCell/DateEditableCell.tsx +39 -39
  61. package/src/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.tsx +75 -75
  62. package/src/components/data/DataGrid/DataGridEditableCell/TextEditableCell.tsx +38 -38
  63. package/src/components/data/DataGrid/DataGridEditableCell/index.tsx +106 -106
  64. package/src/components/data/DataGrid/DataGridEditableCell/styles.ts +35 -35
  65. package/src/components/data/DataGrid/DataGridEditableCell/types.ts +19 -19
  66. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +129 -129
  67. package/src/components/data/DataGrid/DataGridFilterMenu/helpers.ts +23 -23
  68. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +81 -81
  69. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +370 -370
  70. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +97 -97
  71. package/src/components/data/DataGrid/DataGridFooter.tsx +45 -45
  72. package/src/components/data/DataGrid/DataGridHeader.tsx +74 -74
  73. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +112 -112
  74. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +83 -83
  75. package/src/components/data/DataGrid/DataGridToolbar.tsx +134 -134
  76. package/src/components/data/DataGrid/FilterModalContent/index.tsx +135 -135
  77. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  78. package/src/components/data/DataGrid/constants.ts +6 -6
  79. package/src/components/data/DataGrid/helpers/columns.tsx +453 -394
  80. package/src/components/data/DataGrid/helpers/filters.ts +287 -287
  81. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  82. package/src/components/data/DataGrid/hooks/index.ts +29 -29
  83. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +380 -380
  84. package/src/components/data/DataGrid/hooks/useDataGridChangedRows.ts +97 -97
  85. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +174 -174
  86. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  87. package/src/components/data/DataGrid/hooks/useRefreshModal.tsx +48 -48
  88. package/src/components/data/DataGrid/index.tsx +122 -122
  89. package/src/components/data/DataGrid/styles.ts +430 -430
  90. package/src/components/data/DataGrid/types.ts +380 -372
  91. package/src/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.tsx +16 -16
  92. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +526 -479
  93. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  94. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  95. package/src/components/data/SqlRequestDataGrid/index.tsx +420 -420
  96. package/src/components/data/SqlRequestDataGrid/styles.ts +15 -15
  97. package/src/components/data/SqlRequestDataGrid/types.ts +74 -74
  98. package/src/components/data/SqlRequestForeignList/index.tsx +257 -257
  99. package/src/components/data/SqlRequestForeignList/styles.ts +43 -43
  100. package/src/components/data/SqlRequestForeignList/types.ts +32 -32
  101. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +108 -108
  102. package/src/components/data/SqlRequestGrid/filters/styles.ts +88 -88
  103. package/src/components/data/SqlRequestGrid/helpers/index.ts +1 -1
  104. package/src/components/data/SqlRequestGrid/helpers/sqlRequests.ts +16 -16
  105. package/src/components/data/SqlRequestGrid/index.tsx +315 -315
  106. package/src/components/data/SqlRequestGrid/styles.ts +20 -20
  107. package/src/components/data/SqlRequestGrid/types.ts +73 -73
  108. package/src/components/data/VirtualScroller/hooks.ts +71 -71
  109. package/src/components/data/VirtualScroller/index.tsx +89 -89
  110. package/src/components/data/VirtualScroller/styles.ts +57 -57
  111. package/src/components/data/VirtualScroller/types.ts +10 -10
  112. package/src/components/data/index.ts +16 -16
  113. package/src/components/forms/AutoTextArea.tsx +48 -48
  114. package/src/components/forms/Button.tsx +132 -132
  115. package/src/components/forms/Form/Checkbox.tsx +12 -12
  116. package/src/components/forms/Form/FormGroup.tsx +31 -31
  117. package/src/components/forms/Form/Input.tsx +16 -16
  118. package/src/components/forms/Form/Row.tsx +32 -32
  119. package/src/components/forms/Form/Select.tsx +87 -87
  120. package/src/components/forms/Form/TextArea.tsx +17 -17
  121. package/src/components/forms/Form/index.tsx +45 -45
  122. package/src/components/forms/Form/styles.ts +184 -184
  123. package/src/components/forms/IconButton.tsx +67 -67
  124. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  125. package/src/components/forms/NumberInput.tsx +53 -53
  126. package/src/components/forms/Select.tsx +34 -34
  127. package/src/components/forms/VerticalLabel.tsx +20 -20
  128. package/src/components/forms/index.ts +9 -9
  129. package/src/components/forms/styles.ts +42 -42
  130. package/src/components/index.ts +6 -6
  131. package/src/components/layout/Columns.ts +27 -27
  132. package/src/components/layout/Dropdown/index.tsx +113 -113
  133. package/src/components/layout/Dropdown/styles.ts +45 -45
  134. package/src/components/layout/Flexbox.ts +21 -21
  135. package/src/components/layout/Grid/index.tsx +8 -8
  136. package/src/components/layout/Grid/styles.ts +34 -34
  137. package/src/components/layout/Loading/index.tsx +29 -29
  138. package/src/components/layout/Loading/styles.ts +29 -29
  139. package/src/components/layout/Masonry/index.tsx +29 -29
  140. package/src/components/layout/Masonry/styles.ts +20 -20
  141. package/src/components/layout/Modal/index.tsx +51 -51
  142. package/src/components/layout/Modal/styles.ts +125 -125
  143. package/src/components/layout/index.ts +7 -7
  144. package/src/components/search/HighlightedText.tsx +41 -41
  145. package/src/components/search/QuickSearchBar.tsx +99 -99
  146. package/src/components/search/QuickSearchResults.tsx +86 -86
  147. package/src/components/search/index.ts +9 -9
  148. package/src/components/search/styles.ts +96 -96
  149. package/src/components/search/types.ts +29 -29
  150. package/src/components/ui/Avatar/index.tsx +54 -54
  151. package/src/components/ui/Avatar/styles.ts +61 -61
  152. package/src/components/ui/Card/index.tsx +14 -14
  153. package/src/components/ui/Card/styles.ts +37 -37
  154. package/src/components/ui/ContextMenu/index.tsx +79 -79
  155. package/src/components/ui/ContextMenu/styles.ts +119 -119
  156. package/src/components/ui/Ellipsis.tsx +34 -34
  157. package/src/components/ui/Label.tsx +99 -99
  158. package/src/components/ui/Message/index.tsx +57 -57
  159. package/src/components/ui/Message/styles.ts +40 -40
  160. package/src/components/ui/TabsView/TabsList.tsx +44 -44
  161. package/src/components/ui/TabsView/TabsView.tsx +38 -38
  162. package/src/components/ui/TabsView/index.ts +3 -3
  163. package/src/components/ui/TabsView/styles.ts +73 -73
  164. package/src/components/ui/TabsView/types.ts +12 -12
  165. package/src/components/ui/index.ts +7 -7
  166. package/src/config/index.ts +14 -14
  167. package/src/helpers/components.ts +23 -23
  168. package/src/helpers/dates.ts +17 -17
  169. package/src/helpers/getScrollbarSize.ts +14 -14
  170. package/src/helpers/index.ts +5 -6
  171. package/src/helpers/numbers.ts +63 -63
  172. package/src/helpers/responsive.ts +83 -83
  173. package/src/helpers/styled/space.ts +111 -111
  174. package/src/helpers/styled/typography.ts +25 -0
  175. package/src/helpers/text.ts +13 -13
  176. package/src/helpers/types.ts +9 -9
  177. package/src/hooks/index.ts +7 -7
  178. package/src/hooks/useContainerMediaQuery.ts +7 -7
  179. package/src/hooks/useElementSize.ts +24 -24
  180. package/src/hooks/useMediaQuery.ts +9 -9
  181. package/src/hooks/useMediaQueryForWidth.ts +35 -35
  182. package/src/hooks/useMutableState.ts +17 -17
  183. package/src/hooks/useShowArchived.ts +28 -28
  184. package/src/hooks/useWindowSize.ts +20 -20
  185. package/src/index.ts +13 -9
  186. package/src/providers/AuthenticationProvider/helpers.ts +3 -3
  187. package/src/providers/AuthenticationProvider/index.tsx +303 -303
  188. package/src/providers/LoadingProvider/index.tsx +47 -47
  189. package/src/providers/PortalsProvider/index.tsx +54 -54
  190. package/src/providers/PortalsProvider/styles.ts +31 -31
  191. package/src/providers/SettingsProvider/index.tsx +70 -70
  192. package/src/providers/ThemeProvider/ThemeProvider.ts +66 -66
  193. package/src/providers/ThemeProvider/defaultTheme.ts +470 -470
  194. package/src/providers/ThemeProvider/helpers.ts +84 -84
  195. package/src/providers/ThemeProvider/index.ts +5 -5
  196. package/src/providers/ThemeProvider/types.ts +134 -134
  197. package/src/providers/ToastProvider/index.tsx +93 -93
  198. package/src/providers/TrackingProvider/hooks.ts +14 -14
  199. package/src/providers/TrackingProvider/index.tsx +71 -71
  200. package/src/providers/UiProviders/index.tsx +76 -76
  201. package/src/providers/UiProviders/styles.ts +10 -10
  202. package/src/providers/hooks.ts +14 -14
  203. package/src/providers/index.ts +9 -9
  204. package/src/services/HttpService.ts +92 -92
  205. package/src/services/WebSocketService.ts +155 -155
  206. package/src/services/advancedRequests.ts +102 -102
  207. package/src/services/base.ts +23 -23
  208. package/src/services/globalSearch.ts +32 -32
  209. package/src/services/hooks.ts +92 -92
  210. package/src/services/index.ts +21 -21
  211. package/src/services/requests/auth.ts +44 -44
  212. package/src/services/requests/generic.ts +62 -62
  213. package/src/services/requests/tracking.ts +12 -12
  214. package/src/services/requests/userProfiles.ts +35 -35
  215. package/src/services/requests/users.ts +28 -28
  216. package/src/services/smartQueries.ts +122 -122
  217. package/src/services/sqlRequests.ts +111 -111
  218. package/src/services/types/auth.ts +98 -98
  219. package/src/services/types/base.ts +10 -10
  220. package/src/services/types/generic.ts +82 -82
  221. package/src/services/types/tracking.ts +29 -29
  222. package/src/services/types/userProfiles.ts +79 -79
  223. package/src/services/types/users.ts +74 -74
  224. package/src/services/updateSqlRequests.ts +32 -32
  225. package/src/styles/animations.scss +30 -30
  226. package/src/styles/index.scss +42 -42
  227. package/src/typings.d.ts +17 -17
  228. package/tsconfig.json +18 -18
  229. package/tsconfig.tsbuildinfo +1 -1
  230. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.d.ts +0 -14
  231. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.js +0 -77
  232. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.d.ts +0 -22
  233. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.js +0 -105
  234. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.d.ts +0 -2
  235. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.js +0 -18
  236. package/dist/components/data/AdvancedRequestDataGrid/index.d.ts +0 -2
  237. package/dist/components/data/AdvancedRequestDataGrid/index.js +0 -215
  238. package/dist/components/data/AdvancedRequestDataGrid/types.d.ts +0 -21
  239. package/dist/components/data/AdvancedRequestDataGrid/types.js +0 -2
  240. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +0 -10
  241. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +0 -173
  242. package/dist/components/data/DataGrid/DataGridEditableCell.d.ts +0 -2
  243. package/dist/components/data/DataGrid/DataGridEditableCell.js +0 -27
  244. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +0 -13
  245. package/dist/components/data/DataGrid/FilterValuesScroller.js +0 -73
  246. package/dist/components/data/DataGrid/VirtualScroller.d.ts +0 -11
  247. package/dist/components/data/DataGrid/VirtualScroller.js +0 -41
  248. package/dist/components/data/DataGrid/helpers/advancedRequests.d.ts +0 -12
  249. package/dist/components/data/DataGrid/helpers/advancedRequests.js +0 -53
  250. package/dist/components/data/DataGrid/helpers.d.ts +0 -28
  251. package/dist/components/data/DataGrid/helpers.js +0 -436
  252. package/dist/components/data/SmartQueryDataGrid/helpers/columns.d.ts +0 -20
  253. package/dist/components/data/SmartQueryDataGrid/helpers/columns.js +0 -160
  254. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.d.ts +0 -5
  255. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.js +0 -41
  256. package/dist/components/data/SmartQueryDataGrid/helpers/index.d.ts +0 -2
  257. package/dist/components/data/SmartQueryDataGrid/helpers/index.js +0 -18
  258. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.d.ts +0 -3
  259. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.js +0 -15
  260. package/dist/components/data/SmartQueryDataGrid/hooks.d.ts +0 -9
  261. package/dist/components/data/SmartQueryDataGrid/hooks.js +0 -63
  262. package/dist/components/data/SmartQueryDataGrid/index.d.ts +0 -12
  263. package/dist/components/data/SmartQueryDataGrid/index.js +0 -242
  264. package/dist/components/data/SmartQueryDataGrid/types.d.ts +0 -22
  265. package/dist/components/data/SmartQueryDataGrid/types.js +0 -2
  266. package/dist/components/forms/Form/InputWithLabel.d.ts +0 -2
  267. package/dist/components/forms/Form/InputWithLabel.js +0 -10
  268. package/dist/components/forms/Form/types.d.ts +0 -7
  269. package/dist/components/forms/Form/types.js +0 -2
  270. package/dist/config/types.d.ts +0 -11
  271. package/dist/config/types.js +0 -2
  272. package/dist/helpers/styled/index.d.ts +0 -1
  273. package/dist/helpers/styled/index.js +0 -17
  274. package/dist/services/requests/userPermissions.d.ts +0 -4
  275. package/dist/services/requests/userPermissions.js +0 -20
  276. package/src/helpers/styled/index.ts +0 -1
@@ -28,11 +28,11 @@ var __importStar = (this && this.__importStar) || function (mod) {
28
28
  };
29
29
  Object.defineProperty(exports, "__esModule", { value: true });
30
30
  exports.TabContentContainer = exports.TabContainer = exports.TabsListContainer = exports.TabsViewContainer = void 0;
31
- var styled_1 = require("../../../helpers/styled");
31
+ var space_1 = require("../../../helpers/styled/space");
32
32
  var styled_components_1 = __importStar(require("styled-components"));
33
33
  var helpers_1 = require("../../../providers/ThemeProvider/helpers");
34
34
  exports.TabsViewContainer = styled_components_1.default.div(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n display: flex;\n flex-direction: column;\n height: 100%;\n"], ["\n display: flex;\n flex-direction: column;\n height: 100%;\n"])));
35
- exports.TabsListContainer = styled_components_1.default.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n display: flex;\n gap: var(--space-4);\n flex-shrink: 0;\n overflow-x: scroll;\n scrollbar-width: none;\n font-size: var(--text-lg);\n white-space: nowrap;\n\n ", "\n"], ["\n display: flex;\n gap: var(--space-4);\n flex-shrink: 0;\n overflow-x: scroll;\n scrollbar-width: none;\n font-size: var(--text-lg);\n white-space: nowrap;\n\n ", "\n"])), styled_1.space);
35
+ exports.TabsListContainer = styled_components_1.default.div(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n display: flex;\n gap: var(--space-4);\n flex-shrink: 0;\n overflow-x: scroll;\n scrollbar-width: none;\n font-size: var(--text-lg);\n white-space: nowrap;\n\n ", "\n"], ["\n display: flex;\n gap: var(--space-4);\n flex-shrink: 0;\n overflow-x: scroll;\n scrollbar-width: none;\n font-size: var(--text-lg);\n white-space: nowrap;\n\n ", "\n"])), space_1.space);
36
36
  exports.TabContainer = styled_components_1.default.div(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n display: flex;\n align-items: center;\n height: var(--space-8);\n gap: var(--space-2);\n cursor: pointer;\n padding: 0 var(--space-2);\n color: var(--color-text-800);\n\n svg {\n height: var(--space-4);\n width: var(--space-4);\n fill: var(--color-base-800);\n }\n\n ", ";\n\n ", "\n"], ["\n display: flex;\n align-items: center;\n height: var(--space-8);\n gap: var(--space-2);\n cursor: pointer;\n padding: 0 var(--space-2);\n color: var(--color-text-800);\n\n svg {\n height: var(--space-4);\n width: var(--space-4);\n fill: var(--color-base-800);\n }\n\n ", ";\n\n ", "\n"])), function (_a) {
37
37
  var _b = _a.$color, $color = _b === void 0 ? 'primary' : _b;
38
38
  return (0, styled_components_1.css)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n &:hover {\n color: var(--color-", ");\n svg {\n fill: var(--color-", ");\n }\n }\n "], ["\n &:hover {\n color: var(--color-", ");\n svg {\n fill: var(--color-", ");\n }\n }\n "])), (0, helpers_1.getColorWithIntensity)($color, 500), (0, helpers_1.getColorWithIntensity)($color, 500));
@@ -2,5 +2,4 @@ export * from './dates';
2
2
  export * from './numbers';
3
3
  export * from './text';
4
4
  export * from './responsive';
5
- export * from './styled';
6
5
  export * from './types';
@@ -18,5 +18,4 @@ __exportStar(require("./dates"), exports);
18
18
  __exportStar(require("./numbers"), exports);
19
19
  __exportStar(require("./text"), exports);
20
20
  __exportStar(require("./responsive"), exports);
21
- __exportStar(require("./styled"), exports);
22
21
  __exportStar(require("./types"), exports);
@@ -0,0 +1,9 @@
1
+ export type TypographyProps = {
2
+ ellipsis?: boolean;
3
+ bold?: boolean;
4
+ italic?: boolean;
5
+ underline?: boolean;
6
+ lineClamp?: number;
7
+ };
8
+ export declare const typography: import("styled-components").RuleSet<TypographyProps>;
9
+ export declare const StyledTypography: import("styled-components/dist/types").IStyledComponentBase<"web", import("styled-components/dist/types").Substitute<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, TypographyProps>> & string;
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) {
3
+ if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
4
+ return cooked;
5
+ };
6
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ var desc = Object.getOwnPropertyDescriptor(m, k);
9
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
10
+ desc = { enumerable: true, get: function() { return m[k]; } };
11
+ }
12
+ Object.defineProperty(o, k2, desc);
13
+ }) : (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ o[k2] = m[k];
16
+ }));
17
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
18
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
19
+ }) : function(o, v) {
20
+ o["default"] = v;
21
+ });
22
+ var __importStar = (this && this.__importStar) || function (mod) {
23
+ if (mod && mod.__esModule) return mod;
24
+ var result = {};
25
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
26
+ __setModuleDefault(result, mod);
27
+ return result;
28
+ };
29
+ Object.defineProperty(exports, "__esModule", { value: true });
30
+ exports.StyledTypography = exports.typography = void 0;
31
+ var styled_components_1 = __importStar(require("styled-components"));
32
+ exports.typography = (0, styled_components_1.css)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n ", "\n ", "\n ", "\n ", "\n ", "\n"], ["\n ", "\n ", "\n ", "\n ", "\n ", "\n"])), function (_a) {
33
+ var ellipsis = _a.ellipsis;
34
+ return ellipsis &&
35
+ 'white-space: nowrap; overflow: hidden; text-overflow: ellipsis;';
36
+ }, function (_a) {
37
+ var bold = _a.bold;
38
+ return bold && 'font-weight: bold;';
39
+ }, function (_a) {
40
+ var italic = _a.italic;
41
+ return italic && 'font-style: italic;';
42
+ }, function (_a) {
43
+ var underline = _a.underline;
44
+ return underline && 'text-decoration: underline;';
45
+ }, function (_a) {
46
+ var lineClamp = _a.lineClamp;
47
+ return lineClamp &&
48
+ "display: -webkit-box; -webkit-line-clamp: ".concat(lineClamp, "; -webkit-box-orient: vertical; overflow: hidden;");
49
+ });
50
+ exports.StyledTypography = styled_components_1.default.span(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n ", "\n"], ["\n ", "\n"])), exports.typography);
51
+ var templateObject_1, templateObject_2;
package/dist/index.d.ts CHANGED
@@ -5,3 +5,5 @@ export * from './config';
5
5
  export * from './helpers';
6
6
  export * from './hooks';
7
7
  export * from './services';
8
+ export * from './helpers/styled/typography';
9
+ export * from './helpers/styled/space';
package/dist/index.js CHANGED
@@ -21,3 +21,6 @@ __exportStar(require("./config"), exports);
21
21
  __exportStar(require("./helpers"), exports);
22
22
  __exportStar(require("./hooks"), exports);
23
23
  __exportStar(require("./services"), exports);
24
+ // helpers
25
+ __exportStar(require("./helpers/styled/typography"), exports);
26
+ __exportStar(require("./helpers/styled/space"), exports);
package/eslint.config.js CHANGED
@@ -1,3 +1,3 @@
1
- import { eslintReactConfig } from '@addev-be/framework-utils/eslint/react.config.mjs';
2
-
3
- export default [...eslintReactConfig, { ignores: ['dist'] }];
1
+ import { eslintReactConfig } from '@addev-be/framework-utils/eslint/react.config.mjs';
2
+
3
+ export default [...eslintReactConfig, { ignores: ['dist'] }];
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@addev-be/ui",
3
- "version": "1.1.3",
3
+ "version": "1.1.4",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "watch": "tsc -b --watch",
@@ -20,7 +20,7 @@
20
20
  "update-version": "../../node/update-version.mjs"
21
21
  },
22
22
  "devDependencies": {
23
- "@addev-be/framework-utils": "^1.1.3",
23
+ "@addev-be/framework-utils": "^1.1.4",
24
24
  "@types/lodash": "^4",
25
25
  "@types/react": "^18.3.3",
26
26
  "@types/react-dom": "^18.3.0",
package/src/Icons.tsx CHANGED
@@ -1,138 +1,138 @@
1
- import { FC, SVGProps, useEffect, useState } from 'react';
2
-
3
- import AngleLeftIcon from '../assets/icons/angle-left.svg?react';
4
- import AngleRightIcon from '../assets/icons/angle-right.svg?react';
5
- import ArrowDown19Icon from '../assets/icons/arrow-down-1-9.svg?react';
6
- import ArrowDownAZIcon from '../assets/icons/arrow-down-a-z.svg?react';
7
- import ArrowDownBigSmallIcon from '../assets/icons/arrow-down-big-small.svg?react';
8
- import ArrowUp91Icon from '../assets/icons/arrow-up-9-1.svg?react';
9
- import ArrowUpBigSmallIcon from '../assets/icons/arrow-up-big-small.svg?react';
10
- import ArrowUpZAIcon from '../assets/icons/arrow-up-z-a.svg?react';
11
- import ArrowsRotateIcon from '../assets/icons/arrows-rotate.svg?react';
12
- import ArrowsUpDownIcon from '../assets/icons/arrows-up-down.svg?react';
13
- import BarsIcon from '../assets/icons/bars.svg?react';
14
- import CheckIcon from '../assets/icons/check.svg?react';
15
- import ChevronDownIcon from '../assets/icons/chevron-down.svg?react';
16
- import ChevronLeftIcon from '../assets/icons/chevron-left.svg?react';
17
- import ChevronRightIcon from '../assets/icons/chevron-right.svg?react';
18
- import CircleCheckIcon from '../assets/icons/circle-check.svg?react';
19
- import CircleInfoIcon from '../assets/icons/circle-info.svg?react';
20
- import CircleXMarkIcon from '../assets/icons/circle-xmark.svg?react';
21
- import CopyIcon from '../assets/icons/copy.svg?react';
22
- import DownIcon from '../assets/icons/down.svg?react';
23
- import EllipsisIcon from '../assets/icons/ellipsis.svg?react';
24
- import FilterFullIcon from '../assets/icons/filter-full.svg?react';
25
- import FilterIcon from '../assets/icons/filter.svg?react';
26
- import FilterSlashIcon from '../assets/icons/filter-slash.svg?react';
27
- import FloppyDiskIcon from '../assets/icons/floppy-disk.svg?react';
28
- import HashtagIcon from '../assets/icons/hashtag.svg?react';
29
- import ImageSlashIcon from '../assets/icons/image-slash.svg?react';
30
- import LeftIcon from '../assets/icons/left.svg?react';
31
- import MagnifierIcon from '../assets/icons/magnifier.svg?react';
32
- import PhoneIcon from '../assets/icons/phone.svg?react';
33
- import PlusIcon from '../assets/icons/plus.svg?react';
34
- import RightIcon from '../assets/icons/right.svg?react';
35
- import SigmaIcon from '../assets/icons/sigma.svg?react';
36
- import SortCalendarAscendingIcon from '../assets/icons/sort-calendar-ascending.svg?react';
37
- import SortCalendarDescendingIcon from '../assets/icons/sort-calendar-descending.svg?react';
38
- import SpinnerIcon from '../assets/icons/spinner-third.svg?react';
39
- import TableColumnsIcon from '../assets/icons/table-columns.svg?react';
40
- import TableFooterIcon from '../assets/icons/table-footer.svg?react';
41
- import TableFooterSlashIcon from '../assets/icons/table-footer-slash.svg?react';
42
- import TableIcon from '../assets/icons/table.svg?react';
43
- import TallyIcon from '../assets/icons/tally.svg?react';
44
- import TrashCanIcon from '../assets/icons/trash-can.svg?react';
45
- import TriangleExclamationIcon from '../assets/icons/triangle-exclamation.svg?react';
46
- import UpIcon from '../assets/icons/up.svg?react';
47
- import UserTieIcon from '../assets/icons/user-tie.svg?react';
48
- import XBarIcon from '../assets/icons/x-bar.svg?react';
49
- import XMarkIcon from '../assets/icons/xmark.svg?react';
50
- import XMarkLargeIcon from '../assets/icons/xmark-large.svg?react';
51
-
52
- type IconFCProps = SVGProps<SVGSVGElement>;
53
- export type IconFC = FC<IconFCProps>;
54
-
55
- type AnimatedIconProps = {
56
- icons: FC[];
57
- speed?: number;
58
- };
59
-
60
- export const AnimatedIcon: FC<AnimatedIconProps & IconFCProps> = ({
61
- icons,
62
- speed = 150,
63
- ...props
64
- }) => {
65
- const [currentIcon, setCurrentIcon] = useState(0);
66
-
67
- useEffect(() => {
68
- const interval = setInterval(() => {
69
- setCurrentIcon((currentIcon) => (currentIcon + 1) % icons.length);
70
- }, speed);
71
-
72
- return () => {
73
- clearInterval(interval);
74
- };
75
- }, [icons.length, speed]);
76
-
77
- const Icon = icons[currentIcon];
78
- return <Icon {...props} />;
79
- };
80
-
81
- export const LoadingIcon: FC<IconFCProps> = ({ className, ...props }) => (
82
- <SpinnerIcon className={`animate-spin ${className}`} {...props} />
83
- );
84
-
85
- export const BlankIcon: FC<IconFCProps> = (props) => (
86
- <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" {...props} />
87
- );
88
-
89
- export {
90
- AngleLeftIcon,
91
- AngleRightIcon,
92
- ArrowDown19Icon,
93
- ArrowDownAZIcon,
94
- ArrowDownBigSmallIcon,
95
- ArrowsRotateIcon,
96
- ArrowsUpDownIcon,
97
- ArrowUp91Icon,
98
- ArrowUpBigSmallIcon,
99
- ArrowUpZAIcon,
100
- BarsIcon,
101
- CheckIcon,
102
- ChevronDownIcon,
103
- ChevronLeftIcon,
104
- ChevronRightIcon,
105
- CircleCheckIcon,
106
- CircleInfoIcon,
107
- CircleXMarkIcon,
108
- CopyIcon,
109
- DownIcon,
110
- EllipsisIcon,
111
- FilterFullIcon,
112
- FilterIcon,
113
- FilterSlashIcon,
114
- FloppyDiskIcon,
115
- HashtagIcon,
116
- ImageSlashIcon,
117
- LeftIcon,
118
- MagnifierIcon,
119
- PhoneIcon,
120
- PlusIcon,
121
- RightIcon,
122
- SigmaIcon,
123
- SortCalendarAscendingIcon,
124
- SortCalendarDescendingIcon,
125
- SpinnerIcon,
126
- TableColumnsIcon,
127
- TableFooterIcon,
128
- TableFooterSlashIcon,
129
- TableIcon,
130
- TallyIcon,
131
- TrashCanIcon,
132
- TriangleExclamationIcon,
133
- UpIcon,
134
- UserTieIcon,
135
- XBarIcon,
136
- XMarkIcon,
137
- XMarkLargeIcon,
138
- };
1
+ import { FC, SVGProps, useEffect, useState } from 'react';
2
+
3
+ import AngleLeftIcon from '../assets/icons/angle-left.svg?react';
4
+ import AngleRightIcon from '../assets/icons/angle-right.svg?react';
5
+ import ArrowDown19Icon from '../assets/icons/arrow-down-1-9.svg?react';
6
+ import ArrowDownAZIcon from '../assets/icons/arrow-down-a-z.svg?react';
7
+ import ArrowDownBigSmallIcon from '../assets/icons/arrow-down-big-small.svg?react';
8
+ import ArrowUp91Icon from '../assets/icons/arrow-up-9-1.svg?react';
9
+ import ArrowUpBigSmallIcon from '../assets/icons/arrow-up-big-small.svg?react';
10
+ import ArrowUpZAIcon from '../assets/icons/arrow-up-z-a.svg?react';
11
+ import ArrowsRotateIcon from '../assets/icons/arrows-rotate.svg?react';
12
+ import ArrowsUpDownIcon from '../assets/icons/arrows-up-down.svg?react';
13
+ import BarsIcon from '../assets/icons/bars.svg?react';
14
+ import CheckIcon from '../assets/icons/check.svg?react';
15
+ import ChevronDownIcon from '../assets/icons/chevron-down.svg?react';
16
+ import ChevronLeftIcon from '../assets/icons/chevron-left.svg?react';
17
+ import ChevronRightIcon from '../assets/icons/chevron-right.svg?react';
18
+ import CircleCheckIcon from '../assets/icons/circle-check.svg?react';
19
+ import CircleInfoIcon from '../assets/icons/circle-info.svg?react';
20
+ import CircleXMarkIcon from '../assets/icons/circle-xmark.svg?react';
21
+ import CopyIcon from '../assets/icons/copy.svg?react';
22
+ import DownIcon from '../assets/icons/down.svg?react';
23
+ import EllipsisIcon from '../assets/icons/ellipsis.svg?react';
24
+ import FilterFullIcon from '../assets/icons/filter-full.svg?react';
25
+ import FilterIcon from '../assets/icons/filter.svg?react';
26
+ import FilterSlashIcon from '../assets/icons/filter-slash.svg?react';
27
+ import FloppyDiskIcon from '../assets/icons/floppy-disk.svg?react';
28
+ import HashtagIcon from '../assets/icons/hashtag.svg?react';
29
+ import ImageSlashIcon from '../assets/icons/image-slash.svg?react';
30
+ import LeftIcon from '../assets/icons/left.svg?react';
31
+ import MagnifierIcon from '../assets/icons/magnifier.svg?react';
32
+ import PhoneIcon from '../assets/icons/phone.svg?react';
33
+ import PlusIcon from '../assets/icons/plus.svg?react';
34
+ import RightIcon from '../assets/icons/right.svg?react';
35
+ import SigmaIcon from '../assets/icons/sigma.svg?react';
36
+ import SortCalendarAscendingIcon from '../assets/icons/sort-calendar-ascending.svg?react';
37
+ import SortCalendarDescendingIcon from '../assets/icons/sort-calendar-descending.svg?react';
38
+ import SpinnerIcon from '../assets/icons/spinner-third.svg?react';
39
+ import TableColumnsIcon from '../assets/icons/table-columns.svg?react';
40
+ import TableFooterIcon from '../assets/icons/table-footer.svg?react';
41
+ import TableFooterSlashIcon from '../assets/icons/table-footer-slash.svg?react';
42
+ import TableIcon from '../assets/icons/table.svg?react';
43
+ import TallyIcon from '../assets/icons/tally.svg?react';
44
+ import TrashCanIcon from '../assets/icons/trash-can.svg?react';
45
+ import TriangleExclamationIcon from '../assets/icons/triangle-exclamation.svg?react';
46
+ import UpIcon from '../assets/icons/up.svg?react';
47
+ import UserTieIcon from '../assets/icons/user-tie.svg?react';
48
+ import XBarIcon from '../assets/icons/x-bar.svg?react';
49
+ import XMarkIcon from '../assets/icons/xmark.svg?react';
50
+ import XMarkLargeIcon from '../assets/icons/xmark-large.svg?react';
51
+
52
+ type IconFCProps = SVGProps<SVGSVGElement>;
53
+ export type IconFC = FC<IconFCProps>;
54
+
55
+ type AnimatedIconProps = {
56
+ icons: FC[];
57
+ speed?: number;
58
+ };
59
+
60
+ export const AnimatedIcon: FC<AnimatedIconProps & IconFCProps> = ({
61
+ icons,
62
+ speed = 150,
63
+ ...props
64
+ }) => {
65
+ const [currentIcon, setCurrentIcon] = useState(0);
66
+
67
+ useEffect(() => {
68
+ const interval = setInterval(() => {
69
+ setCurrentIcon((currentIcon) => (currentIcon + 1) % icons.length);
70
+ }, speed);
71
+
72
+ return () => {
73
+ clearInterval(interval);
74
+ };
75
+ }, [icons.length, speed]);
76
+
77
+ const Icon = icons[currentIcon];
78
+ return <Icon {...props} />;
79
+ };
80
+
81
+ export const LoadingIcon: FC<IconFCProps> = ({ className, ...props }) => (
82
+ <SpinnerIcon className={`animate-spin ${className}`} {...props} />
83
+ );
84
+
85
+ export const BlankIcon: FC<IconFCProps> = (props) => (
86
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" {...props} />
87
+ );
88
+
89
+ export {
90
+ AngleLeftIcon,
91
+ AngleRightIcon,
92
+ ArrowDown19Icon,
93
+ ArrowDownAZIcon,
94
+ ArrowDownBigSmallIcon,
95
+ ArrowsRotateIcon,
96
+ ArrowsUpDownIcon,
97
+ ArrowUp91Icon,
98
+ ArrowUpBigSmallIcon,
99
+ ArrowUpZAIcon,
100
+ BarsIcon,
101
+ CheckIcon,
102
+ ChevronDownIcon,
103
+ ChevronLeftIcon,
104
+ ChevronRightIcon,
105
+ CircleCheckIcon,
106
+ CircleInfoIcon,
107
+ CircleXMarkIcon,
108
+ CopyIcon,
109
+ DownIcon,
110
+ EllipsisIcon,
111
+ FilterFullIcon,
112
+ FilterIcon,
113
+ FilterSlashIcon,
114
+ FloppyDiskIcon,
115
+ HashtagIcon,
116
+ ImageSlashIcon,
117
+ LeftIcon,
118
+ MagnifierIcon,
119
+ PhoneIcon,
120
+ PlusIcon,
121
+ RightIcon,
122
+ SigmaIcon,
123
+ SortCalendarAscendingIcon,
124
+ SortCalendarDescendingIcon,
125
+ SpinnerIcon,
126
+ TableColumnsIcon,
127
+ TableFooterIcon,
128
+ TableFooterSlashIcon,
129
+ TableIcon,
130
+ TallyIcon,
131
+ TrashCanIcon,
132
+ TriangleExclamationIcon,
133
+ UpIcon,
134
+ UserTieIcon,
135
+ XBarIcon,
136
+ XMarkIcon,
137
+ XMarkLargeIcon,
138
+ };
@@ -1,84 +1,84 @@
1
- import { Button, Input } from '../forms';
2
- import { Card, Message } from '../ui';
3
- import { FC, useCallback, useEffect, useRef, useState } from 'react';
4
- import { Link, redirect } from 'react-router-dom';
5
-
6
- import { FormContainer } from './styles';
7
- import { StackedLabel } from '../forms/VerticalLabel';
8
- import { useAuthentication } from '../../providers';
9
-
10
- export const LoginForm: FC = () => {
11
- const [username, setUsername] = useState(
12
- localStorage.getItem('username') || ''
13
- );
14
- const [password, setPassword] = useState('');
15
- const [isLoading, setIsLoading] = useState(false);
16
- const [error, setError] = useState('');
17
- const usernameInputRef = useRef<HTMLInputElement>(null);
18
- const passwordInputRef = useRef<HTMLInputElement>(null);
19
-
20
- const { login } = useAuthentication();
21
-
22
- const onLoginClicked = useCallback(() => {
23
- setError('');
24
- setIsLoading(true);
25
- login(username, password).then((success) => {
26
- setIsLoading(false);
27
- if (success) {
28
- localStorage.setItem('username', username);
29
- redirect('/');
30
- } else {
31
- setError('Identifiants invalides');
32
- }
33
- });
34
- }, [login, password, username]);
35
-
36
- useEffect(() => {
37
- if (usernameInputRef.current && passwordInputRef.current) {
38
- const input = !username
39
- ? usernameInputRef.current
40
- : passwordInputRef.current;
41
- input.select();
42
- input.focus();
43
- }
44
- // eslint-disable-next-line react-hooks/exhaustive-deps
45
- }, []);
46
-
47
- if (isLoading) return <div>Chargement...</div>;
48
-
49
- return (
50
- <Card>
51
- <FormContainer>
52
- <StackedLabel label="Adresse e-mail / Nom d'utilisateur">
53
- <Input
54
- ref={usernameInputRef}
55
- type="email"
56
- autoComplete="email"
57
- required
58
- value={username}
59
- onChange={(e) => setUsername(e.target.value)}
60
- />
61
- </StackedLabel>
62
-
63
- <StackedLabel label="Mot de passe">
64
- <Input
65
- ref={passwordInputRef}
66
- type="password"
67
- autoComplete="current-password"
68
- required
69
- value={password}
70
- onChange={(e) => setPassword(e.target.value)}
71
- />
72
- </StackedLabel>
73
-
74
- {error && <Message type="error">{error}</Message>}
75
-
76
- <Button $color="primary" onClick={onLoginClicked}>
77
- Se connecter
78
- </Button>
79
-
80
- <Link to="/recover">Mot de passe oublié ?</Link>
81
- </FormContainer>
82
- </Card>
83
- );
84
- };
1
+ import { Button, Input } from '../forms';
2
+ import { Card, Message } from '../ui';
3
+ import { FC, useCallback, useEffect, useRef, useState } from 'react';
4
+ import { Link, redirect } from 'react-router-dom';
5
+
6
+ import { FormContainer } from './styles';
7
+ import { StackedLabel } from '../forms/VerticalLabel';
8
+ import { useAuthentication } from '../../providers';
9
+
10
+ export const LoginForm: FC = () => {
11
+ const [username, setUsername] = useState(
12
+ localStorage.getItem('username') || ''
13
+ );
14
+ const [password, setPassword] = useState('');
15
+ const [isLoading, setIsLoading] = useState(false);
16
+ const [error, setError] = useState('');
17
+ const usernameInputRef = useRef<HTMLInputElement>(null);
18
+ const passwordInputRef = useRef<HTMLInputElement>(null);
19
+
20
+ const { login } = useAuthentication();
21
+
22
+ const onLoginClicked = useCallback(() => {
23
+ setError('');
24
+ setIsLoading(true);
25
+ login(username, password).then((success) => {
26
+ setIsLoading(false);
27
+ if (success) {
28
+ localStorage.setItem('username', username);
29
+ redirect('/');
30
+ } else {
31
+ setError('Identifiants invalides');
32
+ }
33
+ });
34
+ }, [login, password, username]);
35
+
36
+ useEffect(() => {
37
+ if (usernameInputRef.current && passwordInputRef.current) {
38
+ const input = !username
39
+ ? usernameInputRef.current
40
+ : passwordInputRef.current;
41
+ input.select();
42
+ input.focus();
43
+ }
44
+ // eslint-disable-next-line react-hooks/exhaustive-deps
45
+ }, []);
46
+
47
+ if (isLoading) return <div>Chargement...</div>;
48
+
49
+ return (
50
+ <Card>
51
+ <FormContainer>
52
+ <StackedLabel label="Adresse e-mail / Nom d'utilisateur">
53
+ <Input
54
+ ref={usernameInputRef}
55
+ type="email"
56
+ autoComplete="email"
57
+ required
58
+ value={username}
59
+ onChange={(e) => setUsername(e.target.value)}
60
+ />
61
+ </StackedLabel>
62
+
63
+ <StackedLabel label="Mot de passe">
64
+ <Input
65
+ ref={passwordInputRef}
66
+ type="password"
67
+ autoComplete="current-password"
68
+ required
69
+ value={password}
70
+ onChange={(e) => setPassword(e.target.value)}
71
+ />
72
+ </StackedLabel>
73
+
74
+ {error && <Message type="error">{error}</Message>}
75
+
76
+ <Button $color="primary" onClick={onLoginClicked}>
77
+ Se connecter
78
+ </Button>
79
+
80
+ <Link to="/recover">Mot de passe oublié ?</Link>
81
+ </FormContainer>
82
+ </Card>
83
+ );
84
+ };
@@ -1,32 +1,32 @@
1
- import { FC } from 'react';
2
- import { Outlet } from 'react-router-dom';
3
-
4
- export const LoginPage: FC = () => {
5
- return (
6
- <div className="flex flex-row h-full w-full">
7
- <div className="relative hidden w-0 flex-1 lg:block">
8
- <img className="absolute inset-0 h-full w-full object-cover" alt="" />
9
- </div>
10
- <div className="flex flex-1 flex-col justify-space-evenly overflow-y-auto px-4 py-12 sm:px-6 lg:flex-none lg:px-24 xl:px-36">
11
- <div className="mx-auto w-full max-w-sm lg:max-w-96 lg:w-96 xl:max-w-[32rem] xl:w-[32rem]">
12
- <div className="text-center">
13
- <img
14
- className="h-20 w-auto inline-block"
15
- src="/logo192.png"
16
- alt="Burotel"
17
- />
18
- <h2 className="mt-8 text-2xl font-bold leading-9 tracking-tight text-gray-900">
19
- Connectez-vous
20
- </h2>
21
- </div>
22
-
23
- <div className="mt-10 sm:mx-auto sm:w-full sm:max-w-[640px]">
24
- <div className="bg-white px-6 py-12 shadow sm:rounded-lg sm:px-12">
25
- <Outlet />
26
- </div>
27
- </div>
28
- </div>
29
- </div>
30
- </div>
31
- );
32
- };
1
+ import { FC } from 'react';
2
+ import { Outlet } from 'react-router-dom';
3
+
4
+ export const LoginPage: FC = () => {
5
+ return (
6
+ <div className="flex flex-row h-full w-full">
7
+ <div className="relative hidden w-0 flex-1 lg:block">
8
+ <img className="absolute inset-0 h-full w-full object-cover" alt="" />
9
+ </div>
10
+ <div className="flex flex-1 flex-col justify-space-evenly overflow-y-auto px-4 py-12 sm:px-6 lg:flex-none lg:px-24 xl:px-36">
11
+ <div className="mx-auto w-full max-w-sm lg:max-w-96 lg:w-96 xl:max-w-[32rem] xl:w-[32rem]">
12
+ <div className="text-center">
13
+ <img
14
+ className="h-20 w-auto inline-block"
15
+ src="/logo192.png"
16
+ alt="Burotel"
17
+ />
18
+ <h2 className="mt-8 text-2xl font-bold leading-9 tracking-tight text-gray-900">
19
+ Connectez-vous
20
+ </h2>
21
+ </div>
22
+
23
+ <div className="mt-10 sm:mx-auto sm:w-full sm:max-w-[640px]">
24
+ <div className="bg-white px-6 py-12 shadow sm:rounded-lg sm:px-12">
25
+ <Outlet />
26
+ </div>
27
+ </div>
28
+ </div>
29
+ </div>
30
+ </div>
31
+ );
32
+ };