@addev-be/ui 0.2.5 → 0.2.6

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 (133) hide show
  1. package/assets/icons/arrow-down-a-z.svg +1 -1
  2. package/assets/icons/arrow-up-z-a.svg +1 -1
  3. package/assets/icons/check.svg +1 -1
  4. package/assets/icons/down.svg +1 -1
  5. package/assets/icons/filter-full.svg +1 -1
  6. package/assets/icons/filter.svg +1 -1
  7. package/assets/icons/hashtag.svg +1 -1
  8. package/assets/icons/image-slash.svg +1 -1
  9. package/assets/icons/left.svg +1 -1
  10. package/assets/icons/magnifier.svg +1 -1
  11. package/assets/icons/phone.svg +1 -1
  12. package/assets/icons/right.svg +1 -1
  13. package/assets/icons/spinner-third.svg +1 -1
  14. package/assets/icons/table-columns.svg +1 -1
  15. package/assets/icons/up.svg +1 -1
  16. package/assets/icons/user-tie.svg +1 -1
  17. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +1 -2
  18. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +3 -5
  19. package/dist/components/data/DataGrid/DataGridCell.d.ts +1 -1
  20. package/dist/components/data/DataGrid/DataGridCell.js +5 -5
  21. package/dist/components/data/DataGrid/DataGridEditableCell.js +2 -7
  22. package/dist/components/data/DataGrid/DataGridFilterMenu/index.js +10 -8
  23. package/dist/components/data/DataGrid/DataGridFooter.js +4 -14
  24. package/dist/components/data/DataGrid/DataGridHeader.js +1 -3
  25. package/dist/components/data/DataGrid/DataGridHeaderCell.js +6 -5
  26. package/dist/components/data/DataGrid/FilterModalContent/index.d.ts +5 -5
  27. package/dist/components/data/DataGrid/FilterModalContent/index.js +11 -9
  28. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +8 -7
  29. package/dist/components/data/DataGrid/FilterValuesScroller.js +5 -6
  30. package/dist/components/data/DataGrid/helpers/columns.js +1 -4
  31. package/dist/components/data/DataGrid/helpers/filters.d.ts +4 -3
  32. package/dist/components/data/DataGrid/helpers/filters.js +13 -5
  33. package/dist/components/data/DataGrid/hooks/useDataGrid.js +2 -2
  34. package/dist/components/data/DataGrid/hooks/useDataGridCopy.js +0 -1
  35. package/dist/components/data/DataGrid/hooks/useDataGridSettings.js +0 -1
  36. package/dist/components/data/DataGrid/index.js +16 -5
  37. package/dist/components/data/DataGrid/styles.d.ts +4 -1
  38. package/dist/components/data/DataGrid/styles.js +11 -8
  39. package/dist/components/data/DataGrid/types.d.ts +20 -15
  40. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +7 -9
  41. package/dist/components/data/SqlRequestDataGrid/index.js +34 -18
  42. package/dist/components/data/SqlRequestDataGrid/types.d.ts +1 -0
  43. package/dist/components/data/index.d.ts +2 -0
  44. package/dist/components/data/index.js +2 -0
  45. package/dist/helpers/dates.d.ts +2 -0
  46. package/dist/helpers/dates.js +13 -0
  47. package/package.json +1 -1
  48. package/src/Icons.tsx +80 -80
  49. package/src/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.ts +93 -93
  50. package/src/components/data/AdvancedRequestDataGrid/helpers/columns.tsx +262 -262
  51. package/src/components/data/AdvancedRequestDataGrid/helpers/index.ts +2 -2
  52. package/src/components/data/AdvancedRequestDataGrid/index.tsx +269 -269
  53. package/src/components/data/AdvancedRequestDataGrid/types.ts +47 -47
  54. package/src/components/data/DataGrid/DataGridCell.tsx +73 -73
  55. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +14 -14
  56. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +58 -58
  57. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +181 -181
  58. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  59. package/src/components/data/DataGrid/DataGridEditableCell.tsx +43 -54
  60. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +75 -75
  61. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +200 -190
  62. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +100 -100
  63. package/src/components/data/DataGrid/DataGridFooter.tsx +44 -64
  64. package/src/components/data/DataGrid/DataGridHeader.tsx +126 -126
  65. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +167 -167
  66. package/src/components/data/DataGrid/FilterModalContent/index.tsx +124 -125
  67. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  68. package/src/components/data/DataGrid/FilterValuesScroller.tsx +133 -131
  69. package/src/components/data/DataGrid/VirtualScroller.tsx +46 -46
  70. package/src/components/data/DataGrid/helpers/columns.tsx +196 -196
  71. package/src/components/data/DataGrid/helpers/filters.ts +220 -207
  72. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  73. package/src/components/data/DataGrid/hooks/index.ts +30 -30
  74. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +264 -264
  75. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +165 -165
  76. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  77. package/src/components/data/DataGrid/index.tsx +132 -132
  78. package/src/components/data/DataGrid/styles.ts +326 -326
  79. package/src/components/data/DataGrid/types.ts +241 -240
  80. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +224 -224
  81. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  82. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  83. package/src/components/data/SqlRequestDataGrid/index.tsx +252 -252
  84. package/src/components/data/SqlRequestDataGrid/types.ts +47 -47
  85. package/src/components/data/index.ts +8 -8
  86. package/src/components/forms/Button.tsx +99 -99
  87. package/src/components/forms/IconButton.tsx +56 -56
  88. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  89. package/src/components/forms/Select.tsx +40 -40
  90. package/src/components/forms/index.ts +5 -5
  91. package/src/components/forms/styles.ts +20 -20
  92. package/src/components/index.ts +3 -3
  93. package/src/components/layout/Dropdown/index.tsx +79 -79
  94. package/src/components/layout/Dropdown/styles.ts +44 -44
  95. package/src/components/layout/Loading/index.tsx +29 -29
  96. package/src/components/layout/Loading/styles.ts +29 -29
  97. package/src/components/layout/Modal/index.tsx +51 -51
  98. package/src/components/layout/Modal/styles.ts +110 -110
  99. package/src/components/layout/index.ts +3 -3
  100. package/src/config/index.ts +14 -14
  101. package/src/helpers/dates.ts +9 -9
  102. package/src/helpers/getScrollbarSize.ts +14 -14
  103. package/src/helpers/numbers.ts +20 -20
  104. package/src/hooks/index.ts +2 -2
  105. package/src/hooks/useElementSize.ts +24 -24
  106. package/src/hooks/useWindowSize.ts +20 -20
  107. package/src/index.ts +7 -7
  108. package/src/providers/PortalsProvider/index.tsx +54 -54
  109. package/src/providers/PortalsProvider/styles.ts +27 -27
  110. package/src/providers/SettingsProvider/index.tsx +70 -70
  111. package/src/providers/ThemeProvider/ThemeProvider.ts +55 -55
  112. package/src/providers/ThemeProvider/defaultTheme.ts +444 -444
  113. package/src/providers/ThemeProvider/index.ts +3 -3
  114. package/src/providers/ThemeProvider/types.ts +123 -123
  115. package/src/providers/UiProviders/index.tsx +65 -65
  116. package/src/providers/UiProviders/styles.ts +10 -10
  117. package/src/providers/hooks.ts +8 -8
  118. package/src/providers/index.ts +5 -5
  119. package/src/services/HttpService.ts +80 -80
  120. package/src/services/WebSocketService.ts +147 -147
  121. package/src/services/advancedRequests.ts +101 -101
  122. package/src/services/base.ts +31 -31
  123. package/src/services/hooks.ts +23 -23
  124. package/src/services/index.ts +2 -2
  125. package/src/services/sqlRequests.ts +99 -99
  126. package/src/styles/animations.scss +30 -30
  127. package/src/styles/index.scss +42 -42
  128. package/src/typings.d.ts +6 -6
  129. package/tsconfig.tsbuildinfo +1 -1
  130. package/dist/components/data/DataGrid/helpers.d.ts +0 -28
  131. package/dist/components/data/DataGrid/helpers.js +0 -436
  132. package/dist/config/types.d.ts +0 -11
  133. package/dist/config/types.js +0 -2
@@ -1,110 +1,110 @@
1
- import styled, { css } from 'styled-components';
2
-
3
- export const ModalBackdrop = styled.div.attrs({
4
- className: 'ModalBackdrop',
5
- })`
6
- position: fixed;
7
- z-index: 1000;
8
- top: 0;
9
- left: 0;
10
- right: 0;
11
- bottom: 0;
12
- background-color: rgba(0, 0, 0, 0.5);
13
- display: flex;
14
- justify-content: center;
15
- align-items: center;
16
- `;
17
-
18
- export type ModalContainerProps = {
19
- $width?: number;
20
- $height?: number;
21
- $zIndex?: number;
22
- $fullscreen?: boolean;
23
- };
24
-
25
- export const ModalContainer = styled.div.attrs({
26
- className: 'ModalContainer',
27
- })<ModalContainerProps>`
28
- background: var(--color-neutral-100);
29
- border-radius: var(--rounded-lg);
30
- box-shadow: var(--shadow-lg);
31
- display: flex;
32
- flex-direction: column;
33
- max-height: 100vh;
34
- overflow: hidden;
35
-
36
- position: fixed;
37
- z-index: 1001;
38
- ${({ $fullscreen, $width, $height }) =>
39
- $fullscreen
40
- ? css`
41
- top: 0;
42
- left: 0;
43
- right: 0;
44
- bottom: 0;
45
- margin: var(--space-4);
46
- `
47
- : css`
48
- top: 50%;
49
- left: 50%;
50
- transform: translate(-50%, -50%);
51
- width: ${$width ? `${$width}px` : 'auto'};
52
- height: ${$height ? `${$height}px` : 'auto'};
53
- `}
54
- `;
55
-
56
- export const ModalHeader = styled.div.attrs({ className: 'ModalHeader' })`
57
- font-weight: bold;
58
- font-size: var(--text-lg);
59
- padding: var(--space-2);
60
- background-color: var(--color-neutral-200);
61
- padding: var(--space-4);
62
- `;
63
-
64
- export const ModalMessage = styled.p.attrs({ className: 'ModalMessage' })`
65
- margin-bottom: 1rem;
66
- `;
67
-
68
- export const ModalContent = styled.div.attrs({ className: 'ModalContent' })`
69
- display: flex;
70
- flex-direction: column;
71
- flex: 1;
72
- overflow: auto;
73
- padding: var(--space-4);
74
- `;
75
-
76
- export const ModalContentWithIcon = styled.div.attrs({
77
- className: 'ModalContentWithIcon',
78
- })`
79
- display: flex;
80
- flex-direction: row;
81
- padding: var(--space-4);
82
- gap: var(--space-2);
83
-
84
- & > svg {
85
- margin: var(--space-2);
86
- width: var(--space-8);
87
- height: var(--space-8);
88
- }
89
- `;
90
-
91
- export const ModalFooter = styled.div.attrs({ className: 'ModalFooter' })`
92
- display: flex;
93
- flex-direction: row;
94
- justify-content: space-between;
95
- padding: var(--space-2);
96
- background-color: var(--color-neutral-200);
97
- padding: var(--space-4);
98
- `;
99
-
100
- export const ModalButtons = styled(ModalFooter).attrs({
101
- className: 'ModalButtons',
102
- })`
103
- display: flex;
104
- flex-direction: row;
105
- gap: var(--space-2);
106
-
107
- button.right:first-of-type {
108
- margin-left: auto;
109
- }
110
- `;
1
+ import styled, { css } from 'styled-components';
2
+
3
+ export const ModalBackdrop = styled.div.attrs({
4
+ className: 'ModalBackdrop',
5
+ })`
6
+ position: fixed;
7
+ z-index: 1000;
8
+ top: 0;
9
+ left: 0;
10
+ right: 0;
11
+ bottom: 0;
12
+ background-color: rgba(0, 0, 0, 0.5);
13
+ display: flex;
14
+ justify-content: center;
15
+ align-items: center;
16
+ `;
17
+
18
+ export type ModalContainerProps = {
19
+ $width?: number;
20
+ $height?: number;
21
+ $zIndex?: number;
22
+ $fullscreen?: boolean;
23
+ };
24
+
25
+ export const ModalContainer = styled.div.attrs({
26
+ className: 'ModalContainer',
27
+ })<ModalContainerProps>`
28
+ background: var(--color-neutral-100);
29
+ border-radius: var(--rounded-lg);
30
+ box-shadow: var(--shadow-lg);
31
+ display: flex;
32
+ flex-direction: column;
33
+ max-height: 100vh;
34
+ overflow: hidden;
35
+
36
+ position: fixed;
37
+ z-index: 1001;
38
+ ${({ $fullscreen, $width, $height }) =>
39
+ $fullscreen
40
+ ? css`
41
+ top: 0;
42
+ left: 0;
43
+ right: 0;
44
+ bottom: 0;
45
+ margin: var(--space-4);
46
+ `
47
+ : css`
48
+ top: 50%;
49
+ left: 50%;
50
+ transform: translate(-50%, -50%);
51
+ width: ${$width ? `${$width}px` : 'auto'};
52
+ height: ${$height ? `${$height}px` : 'auto'};
53
+ `}
54
+ `;
55
+
56
+ export const ModalHeader = styled.div.attrs({ className: 'ModalHeader' })`
57
+ font-weight: bold;
58
+ font-size: var(--text-lg);
59
+ padding: var(--space-2);
60
+ background-color: var(--color-neutral-200);
61
+ padding: var(--space-4);
62
+ `;
63
+
64
+ export const ModalMessage = styled.p.attrs({ className: 'ModalMessage' })`
65
+ margin-bottom: 1rem;
66
+ `;
67
+
68
+ export const ModalContent = styled.div.attrs({ className: 'ModalContent' })`
69
+ display: flex;
70
+ flex-direction: column;
71
+ flex: 1;
72
+ overflow: auto;
73
+ padding: var(--space-4);
74
+ `;
75
+
76
+ export const ModalContentWithIcon = styled.div.attrs({
77
+ className: 'ModalContentWithIcon',
78
+ })`
79
+ display: flex;
80
+ flex-direction: row;
81
+ padding: var(--space-4);
82
+ gap: var(--space-2);
83
+
84
+ & > svg {
85
+ margin: var(--space-2);
86
+ width: var(--space-8);
87
+ height: var(--space-8);
88
+ }
89
+ `;
90
+
91
+ export const ModalFooter = styled.div.attrs({ className: 'ModalFooter' })`
92
+ display: flex;
93
+ flex-direction: row;
94
+ justify-content: space-between;
95
+ padding: var(--space-2);
96
+ background-color: var(--color-neutral-200);
97
+ padding: var(--space-4);
98
+ `;
99
+
100
+ export const ModalButtons = styled(ModalFooter).attrs({
101
+ className: 'ModalButtons',
102
+ })`
103
+ display: flex;
104
+ flex-direction: row;
105
+ gap: var(--space-2);
106
+
107
+ button.right:first-of-type {
108
+ margin-left: auto;
109
+ }
110
+ `;
@@ -1,3 +1,3 @@
1
- export * from './Dropdown';
2
- export * from './Modal';
3
- export * from './Loading';
1
+ export * from './Dropdown';
2
+ export * from './Modal';
3
+ export * from './Loading';
@@ -1,14 +1,14 @@
1
- export type EnvType = 'dev' | 'test' | 'staging' | 'prod';
2
-
3
- export type Config = {
4
- webSocketUrl: string;
5
- httpServerUrl: `${string}/`;
6
- };
7
-
8
- type DeepPartial<T> = T extends object
9
- ? {
10
- [P in keyof T]?: DeepPartial<T[P]>;
11
- }
12
- : T;
13
-
14
- export type PartialConfig = DeepPartial<Config>;
1
+ export type EnvType = 'dev' | 'test' | 'staging' | 'prod';
2
+
3
+ export type Config = {
4
+ webSocketUrl: string;
5
+ httpServerUrl: `${string}/`;
6
+ };
7
+
8
+ type DeepPartial<T> = T extends object
9
+ ? {
10
+ [P in keyof T]?: DeepPartial<T[P]>;
11
+ }
12
+ : T;
13
+
14
+ export type PartialConfig = DeepPartial<Config>;
@@ -1,9 +1,9 @@
1
- import moment from 'moment';
2
-
3
- export const formatDate = (
4
- date: moment.MomentInput,
5
- format: string = 'DD/MM/YYYY'
6
- ): string => {
7
- const m = moment.utc(date);
8
- return m.isValid() ? m.format(format) : '';
9
- };
1
+ import moment from 'moment';
2
+
3
+ export const formatDate = (
4
+ date: moment.MomentInput,
5
+ format: string = 'DD/MM/YYYY'
6
+ ): string => {
7
+ const m = moment.utc(date);
8
+ return m.isValid() ? m.format(format) : '';
9
+ };
@@ -1,14 +1,14 @@
1
- let scrollBarSize: number[] | undefined = undefined;
2
-
3
- export const getScrollBarSize = () => {
4
- if (!scrollBarSize) {
5
- const el = document.createElement('div');
6
- el.style.cssText = 'overflow:scroll; visibility:hidden; position:absolute;';
7
- document.body.appendChild(el);
8
- const width = el.offsetWidth - el.clientWidth;
9
- const height = el.offsetHeight - el.clientHeight;
10
- el.remove();
11
- scrollBarSize = [width, height];
12
- }
13
- return scrollBarSize;
14
- };
1
+ let scrollBarSize: number[] | undefined = undefined;
2
+
3
+ export const getScrollBarSize = () => {
4
+ if (!scrollBarSize) {
5
+ const el = document.createElement('div');
6
+ el.style.cssText = 'overflow:scroll; visibility:hidden; position:absolute;';
7
+ document.body.appendChild(el);
8
+ const width = el.offsetWidth - el.clientWidth;
9
+ const height = el.offsetHeight - el.clientHeight;
10
+ el.remove();
11
+ scrollBarSize = [width, height];
12
+ }
13
+ return scrollBarSize;
14
+ };
@@ -1,20 +1,20 @@
1
- export const formatMoney = (number: number, decimals = 2, currency = 'EUR') =>
2
- new Intl.NumberFormat(navigator.language, {
3
- style: 'currency',
4
- currency,
5
- minimumFractionDigits: decimals,
6
- maximumFractionDigits: decimals,
7
- }).format(number);
8
-
9
- export const formatPercentage = (number: number, decimals = 2) =>
10
- new Intl.NumberFormat(navigator.language, {
11
- style: 'percent',
12
- minimumFractionDigits: decimals,
13
- maximumFractionDigits: decimals,
14
- }).format(number);
15
-
16
- export const formatNumber = (number: number, decimals = 2) =>
17
- new Intl.NumberFormat(navigator.language, {
18
- minimumFractionDigits: decimals,
19
- maximumFractionDigits: decimals,
20
- }).format(number);
1
+ export const formatMoney = (number: number, decimals = 2, currency = 'EUR') =>
2
+ new Intl.NumberFormat(navigator.language, {
3
+ style: 'currency',
4
+ currency,
5
+ minimumFractionDigits: decimals,
6
+ maximumFractionDigits: decimals,
7
+ }).format(number);
8
+
9
+ export const formatPercentage = (number: number, decimals = 2) =>
10
+ new Intl.NumberFormat(navigator.language, {
11
+ style: 'percent',
12
+ minimumFractionDigits: decimals,
13
+ maximumFractionDigits: decimals,
14
+ }).format(number);
15
+
16
+ export const formatNumber = (number: number, decimals = 2) =>
17
+ new Intl.NumberFormat(navigator.language, {
18
+ minimumFractionDigits: decimals,
19
+ maximumFractionDigits: decimals,
20
+ }).format(number);
@@ -1,2 +1,2 @@
1
- export * from './useElementSize';
2
- export * from './useWindowSize';
1
+ export * from './useElementSize';
2
+ export * from './useWindowSize';
@@ -1,24 +1,24 @@
1
- import { useEffect, useState } from 'react';
2
-
3
- export const useElementSize = (element: HTMLElement | null) => {
4
- const [size, setSize] = useState({ width: 0, height: 0 });
5
-
6
- useEffect(() => {
7
- if (!element) {
8
- return;
9
- }
10
-
11
- const observer = new ResizeObserver((entries) => {
12
- const entry = entries[0];
13
- const { width, height } = entry.contentRect;
14
- setSize({ width, height });
15
- });
16
-
17
- observer.observe(element);
18
- return () => {
19
- observer.disconnect();
20
- };
21
- }, [element]);
22
-
23
- return size;
24
- };
1
+ import { useEffect, useState } from 'react';
2
+
3
+ export const useElementSize = (element: HTMLElement | null) => {
4
+ const [size, setSize] = useState({ width: 0, height: 0 });
5
+
6
+ useEffect(() => {
7
+ if (!element) {
8
+ return;
9
+ }
10
+
11
+ const observer = new ResizeObserver((entries) => {
12
+ const entry = entries[0];
13
+ const { width, height } = entry.contentRect;
14
+ setSize({ width, height });
15
+ });
16
+
17
+ observer.observe(element);
18
+ return () => {
19
+ observer.disconnect();
20
+ };
21
+ }, [element]);
22
+
23
+ return size;
24
+ };
@@ -1,20 +1,20 @@
1
- import { useEffect, useState } from 'react';
2
-
3
- export const useWindowSize = () => {
4
- const [size, setSize] = useState({ width: 0, height: 0 });
5
-
6
- useEffect(() => {
7
- const handleResize = () => {
8
- setSize({ width: window.outerWidth, height: window.outerHeight });
9
- };
10
-
11
- window.addEventListener('resize', handleResize);
12
- handleResize();
13
-
14
- return () => {
15
- window.removeEventListener('resize', handleResize);
16
- };
17
- }, []);
18
-
19
- return size;
20
- };
1
+ import { useEffect, useState } from 'react';
2
+
3
+ export const useWindowSize = () => {
4
+ const [size, setSize] = useState({ width: 0, height: 0 });
5
+
6
+ useEffect(() => {
7
+ const handleResize = () => {
8
+ setSize({ width: window.outerWidth, height: window.outerHeight });
9
+ };
10
+
11
+ window.addEventListener('resize', handleResize);
12
+ handleResize();
13
+
14
+ return () => {
15
+ window.removeEventListener('resize', handleResize);
16
+ };
17
+ }, []);
18
+
19
+ return size;
20
+ };
package/src/index.ts CHANGED
@@ -1,7 +1,7 @@
1
- export * from './components';
2
- export * from './providers';
3
-
4
- export * from './Icons';
5
-
6
- export * from './config';
7
- export * from './services';
1
+ export * from './components';
2
+ export * from './providers';
3
+
4
+ export * from './Icons';
5
+
6
+ export * from './config';
7
+ export * from './services';
@@ -1,54 +1,54 @@
1
- import * as styles from './styles';
2
-
3
- import {
4
- FC,
5
- PropsWithChildren,
6
- ReactNode,
7
- ReactPortal,
8
- createContext,
9
- useCallback,
10
- useMemo,
11
- useRef,
12
- } from 'react';
13
-
14
- import { createPortal } from 'react-dom';
15
-
16
- export type PortalProps = {
17
- key: string;
18
- children: ReactNode;
19
- };
20
-
21
- export type PortalsContextType = {
22
- createPortal: (children: ReactNode) => ReactPortal | null;
23
- };
24
-
25
- export const PortalsContext = createContext<PortalsContextType>({
26
- createPortal: () => null,
27
- });
28
-
29
- export const PortalsProvider: FC<PropsWithChildren> = ({ children }) => {
30
- const containerRef = useRef<HTMLDivElement | null>(null);
31
-
32
- const createLocalPortal = useCallback(
33
- (children: ReactNode) =>
34
- createPortal(
35
- <styles.PortalContainer>{children}</styles.PortalContainer>,
36
- containerRef.current!
37
- ) ?? null,
38
- []
39
- );
40
-
41
- const value = useMemo(
42
- () => ({
43
- createPortal: createLocalPortal,
44
- }),
45
- [createLocalPortal]
46
- );
47
-
48
- return (
49
- <PortalsContext.Provider value={value}>
50
- {children}
51
- <styles.PortalsWrapper ref={containerRef} />
52
- </PortalsContext.Provider>
53
- );
54
- };
1
+ import * as styles from './styles';
2
+
3
+ import {
4
+ FC,
5
+ PropsWithChildren,
6
+ ReactNode,
7
+ ReactPortal,
8
+ createContext,
9
+ useCallback,
10
+ useMemo,
11
+ useRef,
12
+ } from 'react';
13
+
14
+ import { createPortal } from 'react-dom';
15
+
16
+ export type PortalProps = {
17
+ key: string;
18
+ children: ReactNode;
19
+ };
20
+
21
+ export type PortalsContextType = {
22
+ createPortal: (children: ReactNode) => ReactPortal | null;
23
+ };
24
+
25
+ export const PortalsContext = createContext<PortalsContextType>({
26
+ createPortal: () => null,
27
+ });
28
+
29
+ export const PortalsProvider: FC<PropsWithChildren> = ({ children }) => {
30
+ const containerRef = useRef<HTMLDivElement | null>(null);
31
+
32
+ const createLocalPortal = useCallback(
33
+ (children: ReactNode) =>
34
+ createPortal(
35
+ <styles.PortalContainer>{children}</styles.PortalContainer>,
36
+ containerRef.current!
37
+ ) ?? null,
38
+ []
39
+ );
40
+
41
+ const value = useMemo(
42
+ () => ({
43
+ createPortal: createLocalPortal,
44
+ }),
45
+ [createLocalPortal]
46
+ );
47
+
48
+ return (
49
+ <PortalsContext.Provider value={value}>
50
+ {children}
51
+ <styles.PortalsWrapper ref={containerRef} />
52
+ </PortalsContext.Provider>
53
+ );
54
+ };
@@ -1,27 +1,27 @@
1
- import styled from 'styled-components';
2
-
3
- export const BackdropContainer = styled.div.attrs({
4
- className: 'BackdropContainer',
5
- })`
6
- position: fixed;
7
- top: 0;
8
- left: 0;
9
- right: 0;
10
- bottom: 0;
11
- z-index: 1000;
12
- background-color: rgba(0, 0, 0, 0.5);
13
- display: flex;
14
- justify-content: center;
15
- align-items: center;
16
- `;
17
-
18
- export const PortalsWrapper = styled.div.attrs({
19
- className: 'PortalsWrapper',
20
- })`
21
- width: 0;
22
- height: 0;
23
- `;
24
-
25
- export const PortalContainer = styled.div.attrs({
26
- className: 'PortalContainer',
27
- })``;
1
+ import styled from 'styled-components';
2
+
3
+ export const BackdropContainer = styled.div.attrs({
4
+ className: 'BackdropContainer',
5
+ })`
6
+ position: fixed;
7
+ top: 0;
8
+ left: 0;
9
+ right: 0;
10
+ bottom: 0;
11
+ z-index: 1000;
12
+ background-color: rgba(0, 0, 0, 0.5);
13
+ display: flex;
14
+ justify-content: center;
15
+ align-items: center;
16
+ `;
17
+
18
+ export const PortalsWrapper = styled.div.attrs({
19
+ className: 'PortalsWrapper',
20
+ })`
21
+ width: 0;
22
+ height: 0;
23
+ `;
24
+
25
+ export const PortalContainer = styled.div.attrs({
26
+ className: 'PortalContainer',
27
+ })``;