@addev-be/ui 0.20.0 → 0.20.2

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 (339) 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/Icons.d.ts +3 -1
  25. package/dist/Icons.js +6 -1
  26. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.d.ts +2 -0
  27. package/dist/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.js +4 -2
  28. package/dist/components/data/DataGrid/DataGridEditableCell/index.js +5 -5
  29. package/dist/components/data/DataGrid/DataGridHeader.js +19 -9
  30. package/dist/components/data/DataGrid/DataGridHeaderCell.js +1 -2
  31. package/dist/components/data/DataGrid/DataGridRowTemplate.js +2 -2
  32. package/dist/components/data/DataGrid/hooks/useDataGrid.js +6 -5
  33. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.d.ts +7 -7
  34. package/dist/components/data/DataGrid/hooks/useDataGridChangedRows.js +52 -32
  35. package/dist/components/data/DataGrid/hooks/useRefreshModal.d.ts +5 -0
  36. package/dist/components/data/DataGrid/hooks/useRefreshModal.js +25 -0
  37. package/dist/components/data/DataGrid/index.d.ts +2 -2
  38. package/dist/components/data/DataGrid/index.js +4 -3
  39. package/dist/components/data/DataGrid/styles.js +5 -5
  40. package/dist/components/data/DataGrid/types.d.ts +11 -7
  41. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +6 -5
  42. package/dist/components/data/SqlRequestDataGrid/index.d.ts +2 -2
  43. package/dist/components/data/SqlRequestDataGrid/index.js +23 -13
  44. package/dist/components/data/SqlRequestGrid/index.js +1 -2
  45. package/dist/components/forms/AutoTextArea.js +2 -1
  46. package/dist/components/forms/Button.d.ts +3 -3
  47. package/dist/components/forms/Button.js +12 -12
  48. package/dist/components/forms/Form/Checkbox.d.ts +2 -2
  49. package/dist/components/forms/Form/Checkbox.js +2 -2
  50. package/dist/components/forms/Form/FormGroup.d.ts +2 -0
  51. package/dist/components/forms/Form/FormGroup.js +2 -2
  52. package/dist/components/forms/Form/Input.d.ts +2 -2
  53. package/dist/components/forms/Form/Input.js +3 -2
  54. package/dist/components/forms/Form/Row.d.ts +9 -0
  55. package/dist/components/forms/Form/Row.js +10 -0
  56. package/dist/components/forms/Form/Select.d.ts +1 -0
  57. package/dist/components/forms/Form/Select.js +9 -4
  58. package/dist/components/forms/Form/TextArea.d.ts +2 -2
  59. package/dist/components/forms/Form/TextArea.js +3 -2
  60. package/dist/components/forms/Form/index.d.ts +27 -12
  61. package/dist/components/forms/Form/index.js +13 -8
  62. package/dist/components/forms/Form/styles.d.ts +9 -4
  63. package/dist/components/forms/Form/styles.js +13 -11
  64. package/dist/components/forms/NumberInput.d.ts +9 -0
  65. package/dist/components/forms/NumberInput.js +40 -0
  66. package/dist/components/forms/index.d.ts +2 -1
  67. package/dist/components/forms/index.js +2 -1
  68. package/dist/components/forms/styles.d.ts +17 -3
  69. package/dist/components/forms/styles.js +8 -7
  70. package/dist/components/layout/Columns.d.ts +2 -1
  71. package/dist/components/layout/Columns.js +10 -6
  72. package/dist/components/layout/Flexbox.d.ts +11 -0
  73. package/dist/components/layout/Flexbox.js +26 -0
  74. package/dist/components/layout/Modal/styles.js +1 -1
  75. package/dist/components/layout/index.d.ts +1 -0
  76. package/dist/components/layout/index.js +1 -0
  77. package/dist/components/search/HighlightedText.js +9 -7
  78. package/dist/components/search/QuickSearchBar.d.ts +6 -2
  79. package/dist/components/search/QuickSearchBar.js +7 -13
  80. package/dist/components/search/styles.js +1 -1
  81. package/dist/components/search/types.d.ts +3 -0
  82. package/dist/components/ui/Tab/index.d.ts +3 -0
  83. package/dist/components/ui/Tab/index.js +12 -0
  84. package/dist/components/ui/Tab/styles.d.ts +6 -0
  85. package/dist/components/ui/Tab/styles.js +41 -0
  86. package/dist/components/ui/Tab/types.d.ts +13 -0
  87. package/dist/components/ui/Tabs/index.d.ts +2 -0
  88. package/dist/components/ui/Tabs/index.js +10 -0
  89. package/dist/components/ui/Tabs/styles.d.ts +0 -0
  90. package/dist/components/ui/Tabs/styles.js +1 -0
  91. package/dist/components/ui/Tabs/types.d.ts +8 -0
  92. package/dist/components/ui/Tab/302/265/index.d.ts +2 -0
  93. package/dist/components/ui/Tab/302/265/index.js +10 -0
  94. package/dist/components/ui/Tab/302/265/styles.d.ts +0 -0
  95. package/dist/components/ui/Tab/302/265/styles.js +1 -0
  96. package/dist/components/ui/Tab/302/265/types.d.ts +8 -0
  97. package/dist/components/ui/ToastNotification.d.ts +14 -0
  98. package/dist/components/ui/ToastNotification.js +78 -0
  99. package/dist/components/ui/index.d.ts +1 -0
  100. package/dist/components/ui/index.js +1 -0
  101. package/dist/helpers/index.d.ts +1 -0
  102. package/dist/helpers/index.js +1 -0
  103. package/dist/helpers/styled/index.d.ts +1 -0
  104. package/dist/{components/data/SmartQueryDataGrid/helpers → helpers/styled}/index.js +1 -2
  105. package/dist/helpers/styled/space.d.ts +23 -0
  106. package/dist/helpers/styled/space.js +56 -0
  107. package/dist/hooks/index.d.ts +1 -0
  108. package/dist/hooks/index.js +1 -0
  109. package/dist/hooks/useMutableState.d.ts +2 -0
  110. package/dist/hooks/useMutableState.js +16 -0
  111. package/dist/poppins-700.woff2 +0 -0
  112. package/dist/providers/AuthenticationProvider/index.d.ts +1 -0
  113. package/dist/providers/AuthenticationProvider/index.js +54 -13
  114. package/dist/providers/ThemeProvider/helpers.d.ts +8 -3
  115. package/dist/providers/ThemeProvider/helpers.js +42 -2
  116. package/dist/services/WebSocketService.d.ts +8 -0
  117. package/dist/services/WebSocketService.js +34 -2
  118. package/dist/services/globalSearch.d.ts +5 -2
  119. package/dist/services/hooks.d.ts +10 -0
  120. package/dist/services/hooks.js +89 -2
  121. package/package.json +2 -2
  122. package/src/Icons.tsx +138 -138
  123. package/src/components/auth/LoginForm.tsx +84 -84
  124. package/src/components/auth/LoginPage.tsx +32 -32
  125. package/src/components/auth/PasswordRecoveryForm.tsx +52 -52
  126. package/src/components/auth/PasswordResetForm.tsx +112 -112
  127. package/src/components/auth/index.ts +4 -4
  128. package/src/components/auth/styles.ts +14 -14
  129. package/src/components/data/DataGrid/DataGridCell.tsx +77 -77
  130. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +9 -9
  131. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -59
  132. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +182 -182
  133. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  134. package/src/components/data/DataGrid/DataGridEditableCell/CheckboxEditableCell.tsx +38 -38
  135. package/src/components/data/DataGrid/DataGridEditableCell/DateEditableCell.tsx +39 -39
  136. package/src/components/data/DataGrid/DataGridEditableCell/NumberEditableCell.tsx +75 -75
  137. package/src/components/data/DataGrid/DataGridEditableCell/TextEditableCell.tsx +38 -38
  138. package/src/components/data/DataGrid/DataGridEditableCell/index.tsx +106 -106
  139. package/src/components/data/DataGrid/DataGridEditableCell/styles.ts +35 -35
  140. package/src/components/data/DataGrid/DataGridEditableCell/types.ts +19 -19
  141. package/src/components/data/DataGrid/DataGridFilterMenu/FilterValuesScroller.tsx +131 -131
  142. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +81 -81
  143. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +376 -376
  144. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +97 -97
  145. package/src/components/data/DataGrid/DataGridFooter.tsx +45 -45
  146. package/src/components/data/DataGrid/DataGridHeader.tsx +185 -185
  147. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +111 -111
  148. package/src/components/data/DataGrid/DataGridRowTemplate.tsx +82 -82
  149. package/src/components/data/DataGrid/FilterModalContent/index.tsx +136 -136
  150. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  151. package/src/components/data/DataGrid/constants.ts +6 -6
  152. package/src/components/data/DataGrid/helpers/columns.tsx +386 -386
  153. package/src/components/data/DataGrid/helpers/filters.ts +287 -287
  154. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  155. package/src/components/data/DataGrid/hooks/index.ts +29 -29
  156. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +380 -381
  157. package/src/components/data/DataGrid/hooks/useDataGridChangedRows.ts +97 -97
  158. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +174 -174
  159. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  160. package/src/components/data/DataGrid/hooks/useRefreshModal.tsx +48 -48
  161. package/src/components/data/DataGrid/index.tsx +112 -112
  162. package/src/components/data/DataGrid/styles.ts +380 -380
  163. package/src/components/data/DataGrid/types.ts +371 -371
  164. package/src/components/data/SqlRequestDataGrid/SqlRequestForeignListEditableCell.tsx +16 -16
  165. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +484 -484
  166. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  167. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  168. package/src/components/data/SqlRequestDataGrid/index.tsx +414 -414
  169. package/src/components/data/SqlRequestDataGrid/styles.ts +15 -15
  170. package/src/components/data/SqlRequestDataGrid/types.ts +74 -74
  171. package/src/components/data/SqlRequestForeignList/index.tsx +259 -259
  172. package/src/components/data/SqlRequestForeignList/styles.ts +43 -43
  173. package/src/components/data/SqlRequestForeignList/types.ts +34 -34
  174. package/src/components/data/SqlRequestGrid/filters/FiltersSidebar.tsx +110 -110
  175. package/src/components/data/SqlRequestGrid/filters/styles.ts +88 -88
  176. package/src/components/data/SqlRequestGrid/helpers/index.ts +1 -1
  177. package/src/components/data/SqlRequestGrid/helpers/sqlRequests.ts +16 -16
  178. package/src/components/data/SqlRequestGrid/index.tsx +315 -316
  179. package/src/components/data/SqlRequestGrid/styles.ts +20 -20
  180. package/src/components/data/SqlRequestGrid/types.ts +75 -75
  181. package/src/components/data/VirtualScroller/hooks.ts +71 -71
  182. package/src/components/data/VirtualScroller/index.tsx +91 -91
  183. package/src/components/data/VirtualScroller/styles.ts +58 -58
  184. package/src/components/data/VirtualScroller/types.ts +12 -12
  185. package/src/components/data/index.ts +16 -16
  186. package/src/components/forms/AutoTextArea.tsx +48 -48
  187. package/src/components/forms/Button.tsx +132 -132
  188. package/src/components/forms/Form/Checkbox.tsx +12 -12
  189. package/src/components/forms/Form/FormGroup.tsx +31 -31
  190. package/src/components/forms/Form/Input.tsx +16 -16
  191. package/src/components/forms/Form/Row.tsx +32 -32
  192. package/src/components/forms/Form/Select.tsx +87 -87
  193. package/src/components/forms/Form/TextArea.tsx +17 -17
  194. package/src/components/forms/Form/index.tsx +45 -45
  195. package/src/components/forms/Form/styles.ts +184 -184
  196. package/src/components/forms/IconButton.tsx +57 -57
  197. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  198. package/src/components/forms/NumberInput.tsx +53 -53
  199. package/src/components/forms/Select.tsx +35 -35
  200. package/src/components/forms/VerticalLabel.tsx +20 -20
  201. package/src/components/forms/index.ts +9 -9
  202. package/src/components/forms/styles.ts +41 -41
  203. package/src/components/index.ts +6 -6
  204. package/src/components/layout/Columns.ts +28 -28
  205. package/src/components/layout/Dropdown/index.tsx +113 -113
  206. package/src/components/layout/Dropdown/styles.ts +45 -45
  207. package/src/components/layout/Flexbox.ts +21 -21
  208. package/src/components/layout/Grid/index.tsx +8 -8
  209. package/src/components/layout/Grid/styles.ts +34 -34
  210. package/src/components/layout/Loading/index.tsx +29 -29
  211. package/src/components/layout/Loading/styles.ts +29 -29
  212. package/src/components/layout/Masonry/index.tsx +29 -29
  213. package/src/components/layout/Masonry/styles.ts +20 -20
  214. package/src/components/layout/Modal/index.tsx +51 -51
  215. package/src/components/layout/Modal/styles.ts +125 -125
  216. package/src/components/layout/index.ts +7 -7
  217. package/src/components/search/HighlightedText.tsx +41 -41
  218. package/src/components/search/QuickSearchBar.tsx +100 -100
  219. package/src/components/search/QuickSearchResults.tsx +86 -86
  220. package/src/components/search/index.ts +9 -9
  221. package/src/components/search/styles.ts +96 -96
  222. package/src/components/search/types.ts +29 -29
  223. package/src/components/ui/Avatar/index.tsx +54 -54
  224. package/src/components/ui/Avatar/styles.ts +61 -61
  225. package/src/components/ui/Card/index.tsx +14 -14
  226. package/src/components/ui/Card/styles.ts +37 -37
  227. package/src/components/ui/ContextMenu/index.tsx +79 -79
  228. package/src/components/ui/ContextMenu/styles.ts +119 -119
  229. package/src/components/ui/Ellipsis.tsx +34 -34
  230. package/src/components/ui/Message/index.tsx +57 -57
  231. package/src/components/ui/Message/styles.ts +40 -40
  232. package/src/components/ui/Tab/index.tsx +33 -0
  233. package/src/components/ui/Tab/styles.ts +61 -0
  234. package/src/components/ui/Tab/types.ts +16 -0
  235. package/src/components/ui/index.ts +7 -6
  236. package/src/config/index.ts +14 -14
  237. package/src/helpers/dates.ts +17 -17
  238. package/src/helpers/getScrollbarSize.ts +14 -14
  239. package/src/helpers/index.ts +5 -5
  240. package/src/helpers/numbers.ts +63 -63
  241. package/src/helpers/responsive.ts +83 -83
  242. package/src/helpers/styled/index.ts +1 -1
  243. package/src/helpers/styled/space.ts +55 -55
  244. package/src/helpers/text.ts +13 -13
  245. package/src/hooks/index.ts +7 -7
  246. package/src/hooks/useContainerMediaQuery.ts +7 -7
  247. package/src/hooks/useElementSize.ts +24 -24
  248. package/src/hooks/useMediaQuery.ts +9 -9
  249. package/src/hooks/useMediaQueryForWidth.ts +35 -35
  250. package/src/hooks/useMutableState.ts +19 -19
  251. package/src/hooks/useShowArchived.ts +28 -28
  252. package/src/hooks/useWindowSize.ts +20 -20
  253. package/src/index.ts +9 -9
  254. package/src/providers/AuthenticationProvider/helpers.ts +3 -3
  255. package/src/providers/AuthenticationProvider/index.tsx +303 -303
  256. package/src/providers/LoadingProvider/index.tsx +47 -47
  257. package/src/providers/PortalsProvider/index.tsx +54 -54
  258. package/src/providers/PortalsProvider/styles.ts +31 -31
  259. package/src/providers/SettingsProvider/index.tsx +70 -70
  260. package/src/providers/ThemeProvider/ThemeProvider.ts +63 -63
  261. package/src/providers/ThemeProvider/defaultTheme.ts +457 -457
  262. package/src/providers/ThemeProvider/helpers.ts +69 -69
  263. package/src/providers/ThemeProvider/index.ts +4 -4
  264. package/src/providers/ThemeProvider/types.ts +131 -131
  265. package/src/providers/TrackingProvider/hooks.ts +14 -14
  266. package/src/providers/TrackingProvider/index.tsx +71 -71
  267. package/src/providers/UiProviders/index.tsx +68 -68
  268. package/src/providers/UiProviders/styles.ts +10 -10
  269. package/src/providers/hooks.ts +12 -12
  270. package/src/providers/index.ts +8 -8
  271. package/src/services/HttpService.ts +92 -92
  272. package/src/services/WebSocketService.ts +155 -155
  273. package/src/services/advancedRequests.ts +102 -102
  274. package/src/services/base.ts +23 -23
  275. package/src/services/globalSearch.ts +32 -32
  276. package/src/services/hooks.ts +92 -92
  277. package/src/services/index.ts +21 -21
  278. package/src/services/requests/auth.ts +44 -44
  279. package/src/services/requests/generic.ts +62 -62
  280. package/src/services/requests/tracking.ts +12 -12
  281. package/src/services/requests/userProfiles.ts +35 -35
  282. package/src/services/requests/users.ts +28 -28
  283. package/src/services/smartQueries.ts +122 -122
  284. package/src/services/sqlRequests.ts +111 -111
  285. package/src/services/types/auth.ts +131 -131
  286. package/src/services/types/base.ts +10 -10
  287. package/src/services/types/generic.ts +96 -96
  288. package/src/services/types/tracking.ts +39 -39
  289. package/src/services/types/userProfiles.ts +107 -107
  290. package/src/services/types/users.ts +106 -106
  291. package/src/services/updateSqlRequests.ts +34 -34
  292. package/src/styles/animations.scss +30 -30
  293. package/src/styles/index.scss +42 -42
  294. package/src/typings.d.ts +19 -19
  295. package/tsconfig.json +18 -18
  296. package/tsconfig.tsbuildinfo +1 -1
  297. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.d.ts +0 -14
  298. package/dist/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.js +0 -77
  299. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.d.ts +0 -22
  300. package/dist/components/data/AdvancedRequestDataGrid/helpers/columns.js +0 -105
  301. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.d.ts +0 -2
  302. package/dist/components/data/AdvancedRequestDataGrid/helpers/index.js +0 -18
  303. package/dist/components/data/AdvancedRequestDataGrid/index.d.ts +0 -2
  304. package/dist/components/data/AdvancedRequestDataGrid/index.js +0 -215
  305. package/dist/components/data/AdvancedRequestDataGrid/types.d.ts +0 -21
  306. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +0 -10
  307. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +0 -173
  308. package/dist/components/data/DataGrid/DataGridEditableCell.d.ts +0 -2
  309. package/dist/components/data/DataGrid/DataGridEditableCell.js +0 -27
  310. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +0 -13
  311. package/dist/components/data/DataGrid/FilterValuesScroller.js +0 -73
  312. package/dist/components/data/DataGrid/VirtualScroller.d.ts +0 -11
  313. package/dist/components/data/DataGrid/VirtualScroller.js +0 -41
  314. package/dist/components/data/DataGrid/helpers/advancedRequests.d.ts +0 -12
  315. package/dist/components/data/DataGrid/helpers/advancedRequests.js +0 -53
  316. package/dist/components/data/DataGrid/helpers.d.ts +0 -28
  317. package/dist/components/data/DataGrid/helpers.js +0 -436
  318. package/dist/components/data/SmartQueryDataGrid/helpers/columns.d.ts +0 -20
  319. package/dist/components/data/SmartQueryDataGrid/helpers/columns.js +0 -160
  320. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.d.ts +0 -5
  321. package/dist/components/data/SmartQueryDataGrid/helpers/hooks.js +0 -41
  322. package/dist/components/data/SmartQueryDataGrid/helpers/index.d.ts +0 -2
  323. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.d.ts +0 -3
  324. package/dist/components/data/SmartQueryDataGrid/helpers/smartQueries.js +0 -15
  325. package/dist/components/data/SmartQueryDataGrid/hooks.d.ts +0 -9
  326. package/dist/components/data/SmartQueryDataGrid/hooks.js +0 -63
  327. package/dist/components/data/SmartQueryDataGrid/index.d.ts +0 -12
  328. package/dist/components/data/SmartQueryDataGrid/index.js +0 -242
  329. package/dist/components/data/SmartQueryDataGrid/types.d.ts +0 -22
  330. package/dist/components/forms/Form/InputWithLabel.d.ts +0 -2
  331. package/dist/components/forms/Form/InputWithLabel.js +0 -10
  332. package/dist/components/forms/Form/types.d.ts +0 -7
  333. package/dist/config/types.d.ts +0 -11
  334. package/dist/config/types.js +0 -2
  335. package/dist/services/requests/userPermissions.d.ts +0 -4
  336. package/dist/services/requests/userPermissions.js +0 -20
  337. /package/dist/components/{data/AdvancedRequestDataGrid → ui/Tab}/types.js +0 -0
  338. /package/dist/components/{data/SmartQueryDataGrid → ui/Tabs}/types.js +0 -0
  339. /package/dist/components/{forms/Form/types.js → ui/Tab/302/265/types.js"} +0 -0
@@ -1,68 +1,68 @@
1
- import '../../styles/index.scss';
2
- import '../../styles/animations.scss';
3
-
4
- import * as styles from './styles';
5
-
6
- import {
7
- FC,
8
- PropsWithChildren,
9
- createContext,
10
- useCallback,
11
- useMemo,
12
- useRef,
13
- } from 'react';
14
-
15
- import { PortalsProvider } from '../PortalsProvider';
16
- import { SettingsProvider } from '../SettingsProvider';
17
- import { ThemeProvider } from '../ThemeProvider/ThemeProvider';
18
- import { TrackingProvider } from '../TrackingProvider';
19
- import { defaultTheme } from '../ThemeProvider/defaultTheme';
20
-
21
- export type UiProvidersProps = PropsWithChildren<{
22
- $darkMode?: boolean;
23
- }>;
24
-
25
- export type UiContextType = {
26
- rootRect: DOMRect;
27
- getElementScreenRect: (element: HTMLElement) => DOMRect;
28
- };
29
-
30
- export const UiContext = createContext<UiContextType>({
31
- rootRect: new DOMRect(),
32
- getElementScreenRect: () => new DOMRect(),
33
- });
34
-
35
- export const UiProviders: FC<UiProvidersProps> = ({ $darkMode, children }) => {
36
- const rootRef = useRef<HTMLDivElement | null>(null);
37
-
38
- const getElementScreenRect = useCallback((element: HTMLElement) => {
39
- const rootRect = rootRef.current?.getBoundingClientRect();
40
- const rect = element.getBoundingClientRect();
41
- rect.x -= (rootRect?.x ?? 0) + window.scrollX;
42
- rect.y -= (rootRect?.y ?? 0) + window.scrollY;
43
- return rect;
44
- }, []);
45
-
46
- const value = useMemo(
47
- () => ({
48
- rootRect: rootRef.current?.getBoundingClientRect() ?? new DOMRect(),
49
- getElementScreenRect,
50
- }),
51
- // eslint-disable-next-line react-hooks/exhaustive-deps
52
- [rootRef.current]
53
- );
54
-
55
- return (
56
- <ThemeProvider $theme={defaultTheme} $darkMode={$darkMode}>
57
- <UiContext.Provider value={value}>
58
- <styles.Root ref={rootRef}>
59
- <SettingsProvider>
60
- <TrackingProvider>
61
- <PortalsProvider>{children}</PortalsProvider>
62
- </TrackingProvider>
63
- </SettingsProvider>
64
- </styles.Root>
65
- </UiContext.Provider>
66
- </ThemeProvider>
67
- );
68
- };
1
+ import '../../styles/index.scss';
2
+ import '../../styles/animations.scss';
3
+
4
+ import * as styles from './styles';
5
+
6
+ import {
7
+ FC,
8
+ PropsWithChildren,
9
+ createContext,
10
+ useCallback,
11
+ useMemo,
12
+ useRef,
13
+ } from 'react';
14
+
15
+ import { PortalsProvider } from '../PortalsProvider';
16
+ import { SettingsProvider } from '../SettingsProvider';
17
+ import { ThemeProvider } from '../ThemeProvider/ThemeProvider';
18
+ import { TrackingProvider } from '../TrackingProvider';
19
+ import { defaultTheme } from '../ThemeProvider/defaultTheme';
20
+
21
+ export type UiProvidersProps = PropsWithChildren<{
22
+ $darkMode?: boolean;
23
+ }>;
24
+
25
+ export type UiContextType = {
26
+ rootRect: DOMRect;
27
+ getElementScreenRect: (element: HTMLElement) => DOMRect;
28
+ };
29
+
30
+ export const UiContext = createContext<UiContextType>({
31
+ rootRect: new DOMRect(),
32
+ getElementScreenRect: () => new DOMRect(),
33
+ });
34
+
35
+ export const UiProviders: FC<UiProvidersProps> = ({ $darkMode, children }) => {
36
+ const rootRef = useRef<HTMLDivElement | null>(null);
37
+
38
+ const getElementScreenRect = useCallback((element: HTMLElement) => {
39
+ const rootRect = rootRef.current?.getBoundingClientRect();
40
+ const rect = element.getBoundingClientRect();
41
+ rect.x -= (rootRect?.x ?? 0) + window.scrollX;
42
+ rect.y -= (rootRect?.y ?? 0) + window.scrollY;
43
+ return rect;
44
+ }, []);
45
+
46
+ const value = useMemo(
47
+ () => ({
48
+ rootRect: rootRef.current?.getBoundingClientRect() ?? new DOMRect(),
49
+ getElementScreenRect,
50
+ }),
51
+ // eslint-disable-next-line react-hooks/exhaustive-deps
52
+ [rootRef.current]
53
+ );
54
+
55
+ return (
56
+ <ThemeProvider $theme={defaultTheme} $darkMode={$darkMode}>
57
+ <UiContext.Provider value={value}>
58
+ <styles.Root ref={rootRef}>
59
+ <SettingsProvider>
60
+ <TrackingProvider>
61
+ <PortalsProvider>{children}</PortalsProvider>
62
+ </TrackingProvider>
63
+ </SettingsProvider>
64
+ </styles.Root>
65
+ </UiContext.Provider>
66
+ </ThemeProvider>
67
+ );
68
+ };
@@ -1,10 +1,10 @@
1
- import styled from 'styled-components';
2
-
3
- export const Root = styled.div.attrs({ className: 'Root' })`
4
- position: relative;
5
- font-family: var(--font-sans);
6
- font-size: var(--text-base);
7
- color: var(--color-neutral-900);
8
- width: 100%;
9
- height: 100%;
10
- `;
1
+ import styled from 'styled-components';
2
+
3
+ export const Root = styled.div.attrs({ className: 'Root' })`
4
+ position: relative;
5
+ font-family: var(--font-sans);
6
+ font-size: var(--text-base);
7
+ color: var(--color-neutral-900);
8
+ width: 100%;
9
+ height: 100%;
10
+ `;
@@ -1,12 +1,12 @@
1
- import { AuthenticationContext } from './AuthenticationProvider';
2
- import { LoadingContext } from './LoadingProvider';
3
- import { PortalsContext } from './PortalsProvider';
4
- import { SettingsContext } from './SettingsProvider';
5
- import { UiContext } from './UiProviders';
6
- import { useContext } from 'react';
7
-
8
- export const useAuthentication = () => useContext(AuthenticationContext);
9
- export const useLoading = () => useContext(LoadingContext);
10
- export const usePortals = () => useContext(PortalsContext);
11
- export const useSettings = () => useContext(SettingsContext);
12
- export const useUi = () => useContext(UiContext);
1
+ import { AuthenticationContext } from './AuthenticationProvider';
2
+ import { LoadingContext } from './LoadingProvider';
3
+ import { PortalsContext } from './PortalsProvider';
4
+ import { SettingsContext } from './SettingsProvider';
5
+ import { UiContext } from './UiProviders';
6
+ import { useContext } from 'react';
7
+
8
+ export const useAuthentication = () => useContext(AuthenticationContext);
9
+ export const useLoading = () => useContext(LoadingContext);
10
+ export const usePortals = () => useContext(PortalsContext);
11
+ export const useSettings = () => useContext(SettingsContext);
12
+ export const useUi = () => useContext(UiContext);
@@ -1,8 +1,8 @@
1
- export * from './AuthenticationProvider';
2
- export * from './PortalsProvider';
3
- export * from './ThemeProvider';
4
- export * from './TrackingProvider';
5
- export * from './UiProviders';
6
-
7
- export * from './TrackingProvider/hooks';
8
- export * from './hooks';
1
+ export * from './AuthenticationProvider';
2
+ export * from './PortalsProvider';
3
+ export * from './ThemeProvider';
4
+ export * from './TrackingProvider';
5
+ export * from './UiProviders';
6
+
7
+ export * from './TrackingProvider/hooks';
8
+ export * from './hooks';
@@ -1,92 +1,92 @@
1
- import { Config } from '../config';
2
- import { trimEnd } from 'lodash';
3
- import { v4 } from 'uuid';
4
-
5
- export class HttpService {
6
- private static instance: HttpService;
7
- private config: Config;
8
- private promises: {
9
- [id: string]: {
10
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
11
- resolve: (value: any) => void;
12
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
13
- reject: (reason?: any) => void;
14
- };
15
- } = {};
16
-
17
- constructor(config: Config) {
18
- HttpService.instance = this;
19
- this.config = config;
20
- }
21
-
22
- public static getInstance() {
23
- return HttpService.instance;
24
- }
25
-
26
- public sendRequest<TReq, TRes>(
27
- name: string,
28
- data: TReq,
29
- files?: Record<string, File>
30
- ) {
31
- const id = v4();
32
- const promise = new Promise<TRes>((resolve, reject) => {
33
- this.promises[id] = { resolve, reject };
34
-
35
- const formData = new FormData();
36
- formData.append('id', id);
37
- formData.append('data', JSON.stringify(data));
38
- if (files) {
39
- Object.entries(files).forEach(([key, file]) => {
40
- formData.append(key, file);
41
- });
42
- }
43
-
44
- console.log('[HTTP] Sending request:', { id, name, data });
45
- fetch(`${trimEnd(this.config.httpServerUrl, '/')}/${name}`, {
46
- method: 'POST',
47
- headers: {
48
- 'Content-Type': 'application/json',
49
- },
50
- body: formData,
51
- })
52
- .then(async (response) => {
53
- if (!response.ok) {
54
- throw new Error('HTTP request failed');
55
- }
56
- const body = await response.text();
57
- this.parseMessage(body);
58
- })
59
- .catch((error) => {
60
- reject(error);
61
- });
62
- });
63
- return promise;
64
- }
65
-
66
- private parseMessage(message: string) {
67
- try {
68
- const response = JSON.parse(message);
69
- if (!response.id) {
70
- throw new Error('Received message is not valid');
71
- }
72
- if (this.promises[response.id]) {
73
- console.log('[HTTP] Received response:', response);
74
- if (
75
- typeof response.data?.status === 'number' &&
76
- response.data.status < 0
77
- ) {
78
- this.promises[response.id].reject(new Error(response.data.message));
79
- } else {
80
- this.promises[response.id].resolve(response.data);
81
- }
82
- delete this.promises[response.id];
83
- } else {
84
- console.log('[HTTP] Received request:', response);
85
- // TODO : Implement request handling
86
- throw new Error('Not yet implemented');
87
- }
88
- } catch (error) {
89
- console.error('[HTTP] Error parsing message:', error);
90
- }
91
- }
92
- }
1
+ import { Config } from '../config';
2
+ import { trimEnd } from 'lodash';
3
+ import { v4 } from 'uuid';
4
+
5
+ export class HttpService {
6
+ private static instance: HttpService;
7
+ private config: Config;
8
+ private promises: {
9
+ [id: string]: {
10
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
11
+ resolve: (value: any) => void;
12
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
13
+ reject: (reason?: any) => void;
14
+ };
15
+ } = {};
16
+
17
+ constructor(config: Config) {
18
+ HttpService.instance = this;
19
+ this.config = config;
20
+ }
21
+
22
+ public static getInstance() {
23
+ return HttpService.instance;
24
+ }
25
+
26
+ public sendRequest<TReq, TRes>(
27
+ name: string,
28
+ data: TReq,
29
+ files?: Record<string, File>
30
+ ) {
31
+ const id = v4();
32
+ const promise = new Promise<TRes>((resolve, reject) => {
33
+ this.promises[id] = { resolve, reject };
34
+
35
+ const formData = new FormData();
36
+ formData.append('id', id);
37
+ formData.append('data', JSON.stringify(data));
38
+ if (files) {
39
+ Object.entries(files).forEach(([key, file]) => {
40
+ formData.append(key, file);
41
+ });
42
+ }
43
+
44
+ console.log('[HTTP] Sending request:', { id, name, data });
45
+ fetch(`${trimEnd(this.config.httpServerUrl, '/')}/${name}`, {
46
+ method: 'POST',
47
+ headers: {
48
+ 'Content-Type': 'application/json',
49
+ },
50
+ body: formData,
51
+ })
52
+ .then(async (response) => {
53
+ if (!response.ok) {
54
+ throw new Error('HTTP request failed');
55
+ }
56
+ const body = await response.text();
57
+ this.parseMessage(body);
58
+ })
59
+ .catch((error) => {
60
+ reject(error);
61
+ });
62
+ });
63
+ return promise;
64
+ }
65
+
66
+ private parseMessage(message: string) {
67
+ try {
68
+ const response = JSON.parse(message);
69
+ if (!response.id) {
70
+ throw new Error('Received message is not valid');
71
+ }
72
+ if (this.promises[response.id]) {
73
+ console.log('[HTTP] Received response:', response);
74
+ if (
75
+ typeof response.data?.status === 'number' &&
76
+ response.data.status < 0
77
+ ) {
78
+ this.promises[response.id].reject(new Error(response.data.message));
79
+ } else {
80
+ this.promises[response.id].resolve(response.data);
81
+ }
82
+ delete this.promises[response.id];
83
+ } else {
84
+ console.log('[HTTP] Received request:', response);
85
+ // TODO : Implement request handling
86
+ throw new Error('Not yet implemented');
87
+ }
88
+ } catch (error) {
89
+ console.error('[HTTP] Error parsing message:', error);
90
+ }
91
+ }
92
+ }