@addev-be/ui 0.2.5 → 0.2.7

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 (166) hide show
  1. package/assets/icons/arrow-down-1-9.svg +1 -0
  2. package/assets/icons/arrow-down-a-z.svg +1 -1
  3. package/assets/icons/arrow-down-big-small.svg +1 -0
  4. package/assets/icons/arrow-up-9-1.svg +1 -0
  5. package/assets/icons/arrow-up-big-small.svg +1 -0
  6. package/assets/icons/arrow-up-z-a.svg +1 -1
  7. package/assets/icons/check.svg +1 -1
  8. package/assets/icons/chevron-down.svg +1 -0
  9. package/assets/icons/down.svg +1 -1
  10. package/assets/icons/ellipsis.svg +1 -0
  11. package/assets/icons/filter-full.svg +1 -1
  12. package/assets/icons/filter.svg +1 -1
  13. package/assets/icons/hashtag.svg +1 -1
  14. package/assets/icons/image-slash.svg +1 -1
  15. package/assets/icons/left.svg +1 -1
  16. package/assets/icons/magnifier.svg +1 -1
  17. package/assets/icons/phone.svg +1 -1
  18. package/assets/icons/right.svg +1 -1
  19. package/assets/icons/sigma.svg +1 -0
  20. package/assets/icons/spinner-third.svg +1 -1
  21. package/assets/icons/table-columns.svg +1 -1
  22. package/assets/icons/table-footer-slash.svg +5 -0
  23. package/assets/icons/table-footer.svg +4 -0
  24. package/assets/icons/table.svg +1 -0
  25. package/assets/icons/tally.svg +1 -0
  26. package/assets/icons/up.svg +1 -1
  27. package/assets/icons/user-tie.svg +1 -1
  28. package/assets/icons/x-bar.svg +4 -0
  29. package/dist/Icons.d.ts +13 -1
  30. package/dist/Icons.js +25 -1
  31. package/dist/components/data/AdvancedRequestDataGrid/index.js +3 -3
  32. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.d.ts +1 -2
  33. package/dist/components/data/DataGrid/AdvancedRequestDataGrid.js +3 -5
  34. package/dist/components/data/DataGrid/DataGridCell.d.ts +1 -1
  35. package/dist/components/data/DataGrid/DataGridCell.js +5 -5
  36. package/dist/components/data/DataGrid/DataGridColumnsModal/hooks.js +2 -1
  37. package/dist/components/data/DataGrid/DataGridEditableCell.js +2 -7
  38. package/dist/components/data/DataGrid/DataGridFilterMenu/index.js +90 -10
  39. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.d.ts +3 -9
  40. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.js +10 -37
  41. package/dist/components/data/DataGrid/DataGridFooter.d.ts +1 -1
  42. package/dist/components/data/DataGrid/DataGridFooter.js +35 -22
  43. package/dist/components/data/DataGrid/DataGridHeader.js +1 -3
  44. package/dist/components/data/DataGrid/DataGridHeaderCell.js +8 -23
  45. package/dist/components/data/DataGrid/FilterModalContent/index.d.ts +5 -5
  46. package/dist/components/data/DataGrid/FilterModalContent/index.js +11 -9
  47. package/dist/components/data/DataGrid/FilterValuesScroller.d.ts +8 -7
  48. package/dist/components/data/DataGrid/FilterValuesScroller.js +5 -6
  49. package/dist/components/data/DataGrid/helpers/columns.d.ts +1 -1
  50. package/dist/components/data/DataGrid/helpers/columns.js +72 -20
  51. package/dist/components/data/DataGrid/helpers/filters.d.ts +4 -3
  52. package/dist/components/data/DataGrid/helpers/filters.js +13 -5
  53. package/dist/components/data/DataGrid/hooks/useDataGrid.d.ts +1 -1
  54. package/dist/components/data/DataGrid/hooks/useDataGrid.js +60 -30
  55. package/dist/components/data/DataGrid/hooks/useDataGridCopy.d.ts +2 -2
  56. package/dist/components/data/DataGrid/hooks/useDataGridCopy.js +41 -40
  57. package/dist/components/data/DataGrid/hooks/useDataGridSettings.js +0 -1
  58. package/dist/components/data/DataGrid/index.d.ts +4 -2
  59. package/dist/components/data/DataGrid/index.js +38 -17
  60. package/dist/components/data/DataGrid/styles.d.ts +12 -5
  61. package/dist/components/data/DataGrid/styles.js +31 -18
  62. package/dist/components/data/DataGrid/types.d.ts +28 -16
  63. package/dist/components/data/SqlRequestDataGrid/helpers/columns.d.ts +1 -1
  64. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +30 -19
  65. package/dist/components/data/SqlRequestDataGrid/index.js +125 -37
  66. package/dist/components/data/SqlRequestDataGrid/types.d.ts +1 -0
  67. package/dist/components/data/index.d.ts +2 -0
  68. package/dist/components/data/index.js +2 -0
  69. package/dist/components/ui/ContextMenu/index.d.ts +11 -0
  70. package/dist/components/ui/ContextMenu/index.js +58 -0
  71. package/dist/components/ui/ContextMenu/styles.d.ts +18 -0
  72. package/dist/components/ui/ContextMenu/styles.js +56 -0
  73. package/dist/helpers/dates.d.ts +2 -0
  74. package/dist/helpers/dates.js +13 -0
  75. package/dist/services/advancedRequests.d.ts +1 -1
  76. package/dist/services/sqlRequests.d.ts +9 -4
  77. package/dist/services/sqlRequests.js +1 -0
  78. package/package.json +1 -1
  79. package/src/Icons.tsx +104 -80
  80. package/src/components/data/AdvancedRequestDataGrid/helpers/advancedRequests.ts +93 -93
  81. package/src/components/data/AdvancedRequestDataGrid/helpers/columns.tsx +262 -262
  82. package/src/components/data/AdvancedRequestDataGrid/helpers/index.ts +2 -2
  83. package/src/components/data/AdvancedRequestDataGrid/index.tsx +267 -269
  84. package/src/components/data/AdvancedRequestDataGrid/types.ts +47 -47
  85. package/src/components/data/DataGrid/DataGridCell.tsx +73 -73
  86. package/src/components/data/DataGrid/DataGridColumnsModal/helpers.ts +14 -14
  87. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +59 -58
  88. package/src/components/data/DataGrid/DataGridColumnsModal/index.tsx +181 -181
  89. package/src/components/data/DataGrid/DataGridColumnsModal/styles.ts +104 -104
  90. package/src/components/data/DataGrid/DataGridEditableCell.tsx +43 -54
  91. package/src/components/data/DataGrid/DataGridFilterMenu/hooks.tsx +75 -75
  92. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +364 -190
  93. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +49 -100
  94. package/src/components/data/DataGrid/DataGridFooter.tsx +42 -64
  95. package/src/components/data/DataGrid/DataGridHeader.tsx +126 -126
  96. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +132 -167
  97. package/src/components/data/DataGrid/FilterModalContent/index.tsx +124 -125
  98. package/src/components/data/DataGrid/FilterModalContent/styles.ts +22 -22
  99. package/src/components/data/DataGrid/FilterValuesScroller.tsx +133 -131
  100. package/src/components/data/DataGrid/VirtualScroller.tsx +46 -46
  101. package/src/components/data/DataGrid/helpers/columns.tsx +287 -196
  102. package/src/components/data/DataGrid/helpers/filters.ts +220 -207
  103. package/src/components/data/DataGrid/helpers/index.ts +2 -2
  104. package/src/components/data/DataGrid/hooks/index.ts +30 -30
  105. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +305 -264
  106. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +170 -165
  107. package/src/components/data/DataGrid/hooks/useDataGridSettings.ts +48 -48
  108. package/src/components/data/DataGrid/index.tsx +139 -132
  109. package/src/components/data/DataGrid/styles.ts +347 -326
  110. package/src/components/data/DataGrid/types.ts +260 -240
  111. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +259 -224
  112. package/src/components/data/SqlRequestDataGrid/helpers/index.ts +2 -2
  113. package/src/components/data/SqlRequestDataGrid/helpers/sqlRequests.ts +16 -16
  114. package/src/components/data/SqlRequestDataGrid/index.tsx +347 -252
  115. package/src/components/data/SqlRequestDataGrid/types.ts +47 -47
  116. package/src/components/data/index.ts +8 -8
  117. package/src/components/forms/Button.tsx +99 -99
  118. package/src/components/forms/IconButton.tsx +56 -56
  119. package/src/components/forms/IndeterminateCheckbox.tsx +46 -46
  120. package/src/components/forms/Select.tsx +40 -40
  121. package/src/components/forms/index.ts +5 -5
  122. package/src/components/forms/styles.ts +20 -20
  123. package/src/components/index.ts +3 -3
  124. package/src/components/layout/Dropdown/index.tsx +79 -79
  125. package/src/components/layout/Dropdown/styles.ts +44 -44
  126. package/src/components/layout/Loading/index.tsx +29 -29
  127. package/src/components/layout/Loading/styles.ts +29 -29
  128. package/src/components/layout/Modal/index.tsx +51 -51
  129. package/src/components/layout/Modal/styles.ts +110 -110
  130. package/src/components/layout/index.ts +3 -3
  131. package/src/components/ui/ContextMenu/index.tsx +73 -0
  132. package/src/components/ui/ContextMenu/styles.ts +115 -0
  133. package/src/config/index.ts +14 -14
  134. package/src/helpers/dates.ts +9 -9
  135. package/src/helpers/getScrollbarSize.ts +14 -14
  136. package/src/helpers/numbers.ts +20 -20
  137. package/src/hooks/index.ts +2 -2
  138. package/src/hooks/useElementSize.ts +24 -24
  139. package/src/hooks/useWindowSize.ts +20 -20
  140. package/src/index.ts +7 -7
  141. package/src/providers/PortalsProvider/index.tsx +54 -54
  142. package/src/providers/PortalsProvider/styles.ts +27 -27
  143. package/src/providers/SettingsProvider/index.tsx +70 -70
  144. package/src/providers/ThemeProvider/ThemeProvider.ts +55 -55
  145. package/src/providers/ThemeProvider/defaultTheme.ts +444 -444
  146. package/src/providers/ThemeProvider/index.ts +3 -3
  147. package/src/providers/ThemeProvider/types.ts +123 -123
  148. package/src/providers/UiProviders/index.tsx +65 -65
  149. package/src/providers/UiProviders/styles.ts +10 -10
  150. package/src/providers/hooks.ts +8 -8
  151. package/src/providers/index.ts +5 -5
  152. package/src/services/HttpService.ts +80 -80
  153. package/src/services/WebSocketService.ts +147 -147
  154. package/src/services/advancedRequests.ts +101 -101
  155. package/src/services/base.ts +31 -31
  156. package/src/services/hooks.ts +23 -23
  157. package/src/services/index.ts +2 -2
  158. package/src/services/sqlRequests.ts +110 -99
  159. package/src/styles/animations.scss +30 -30
  160. package/src/styles/index.scss +42 -42
  161. package/src/typings.d.ts +6 -6
  162. package/tsconfig.tsbuildinfo +1 -1
  163. package/dist/components/data/DataGrid/helpers.d.ts +0 -28
  164. package/dist/components/data/DataGrid/helpers.js +0 -436
  165. package/dist/config/types.d.ts +0 -11
  166. package/dist/config/types.js +0 -2
@@ -1,132 +1,139 @@
1
- import * as styles from './styles';
2
-
3
- import { DataGridCell } from './DataGridCell';
4
- import { DataGridFooter } from './DataGridFooter';
5
- import { DataGridHeader } from './DataGridHeader';
6
- import { DataGridProps } from './types';
7
- import { VirtualScroller } from './VirtualScroller';
8
- import { useCallback } from 'react';
9
- import { useDataGrid } from './hooks';
10
-
11
- /* eslint-disable @typescript-eslint/no-explicit-any */
12
- /* eslint-disable @typescript-eslint/no-unnecessary-type-constraint */
13
-
14
- export const DataGrid = <R,>(props: DataGridProps<R>) => {
15
- const {
16
- className,
17
- // onRowDoubleClick,
18
- onVisibleRowsChange,
19
- } = props;
20
- const [contextProps, DataGridContext] = useDataGrid(props);
21
- const {
22
- selectedKeys,
23
- setSelectedKeys,
24
- columns,
25
- visibleColumns,
26
- rowHeight = 32,
27
- headerRowHeight = 40,
28
- scrollableRef,
29
- onScroll,
30
- rowKeyGetter,
31
- } = contextProps;
32
-
33
- const hasFooter = Object.values(columns).some((col) => col.footer);
34
-
35
- const setRowSelection = useCallback(
36
- (row: R, selected: boolean) => {
37
- const key = rowKeyGetter(row);
38
- if (selected) {
39
- if (!selectedKeys.includes(key))
40
- setSelectedKeys([...selectedKeys, key]);
41
- } else {
42
- setSelectedKeys(selectedKeys.filter((p) => p !== key));
43
- }
44
- },
45
- [rowKeyGetter, selectedKeys, setSelectedKeys]
46
- );
47
-
48
- const rowTemplate = useCallback(
49
- (row: R, rowIndex: number) => {
50
- if (!row) {
51
- return (
52
- <styles.DataGridRow key={`loading-row-${rowIndex}`}>
53
- {!!props.selectable && (
54
- <styles.LoadingCell className="animate-pulse">
55
- <div />
56
- </styles.LoadingCell>
57
- )}
58
- {visibleColumns.map((_, index) => (
59
- <styles.LoadingCell
60
- className="animate-pulse"
61
- key={`loading-${rowIndex}-${index}`}
62
- >
63
- <div />
64
- </styles.LoadingCell>
65
- ))}
66
- </styles.DataGridRow>
67
- );
68
- }
69
- const key = rowKeyGetter(row);
70
- const { className, style } = props.rowClassNameGetter?.(row) ?? {
71
- className: '',
72
- style: undefined,
73
- };
74
- return (
75
- <styles.DataGridRow key={key}>
76
- {!!props.selectable && (
77
- <styles.SelectionCell key="__select_checkbox__">
78
- <input
79
- type="checkbox"
80
- value={key as string}
81
- checked={selectedKeys.includes(key)}
82
- onChange={(e) => setRowSelection(row, e.target.checked)}
83
- />
84
- </styles.SelectionCell>
85
- )}
86
- {visibleColumns.map(([key, col], index) => (
87
- <DataGridCell
88
- key={`loading-${rowIndex}-${index}`}
89
- {...(index === 0 ? { className, style } : {})}
90
- row={row}
91
- rowIndex={rowIndex}
92
- column={col}
93
- columnIndex={index}
94
- context={DataGridContext}
95
- columnKey={key}
96
- />
97
- ))}
98
- </styles.DataGridRow>
99
- );
100
- },
101
- [
102
- DataGridContext,
103
- props,
104
- rowKeyGetter,
105
- selectedKeys,
106
- setRowSelection,
107
- visibleColumns,
108
- ]
109
- );
110
-
111
- return (
112
- <DataGridContext.Provider value={contextProps}>
113
- <styles.DataGridContainer
114
- ref={scrollableRef}
115
- onScroll={onScroll}
116
- $headerRowHeight={headerRowHeight}
117
- $rowHeight={rowHeight}
118
- $rowsCount={contextProps.sortedRows.length}
119
- className={className}
120
- >
121
- <DataGridHeader context={DataGridContext} />
122
- <VirtualScroller
123
- onRangeChange={onVisibleRowsChange}
124
- hasFooter={hasFooter}
125
- rowTemplate={rowTemplate}
126
- context={DataGridContext}
127
- />
128
- {hasFooter && <DataGridFooter context={DataGridContext} />}
129
- </styles.DataGridContainer>
130
- </DataGridContext.Provider>
131
- );
132
- };
1
+ import * as styles from './styles';
2
+
3
+ import { DataGridContextProps, DataGridProps } from './types';
4
+
5
+ import { DataGridCell } from './DataGridCell';
6
+ import { DataGridFooter } from './DataGridFooter';
7
+ import { DataGridHeader } from './DataGridHeader';
8
+ import { VirtualScroller } from './VirtualScroller';
9
+ import { useCallback } from 'react';
10
+ import { useDataGrid } from './hooks';
11
+
12
+ /* eslint-disable @typescript-eslint/no-explicit-any */
13
+ /* eslint-disable @typescript-eslint/no-unnecessary-type-constraint */
14
+
15
+ export const DataGrid = <R,>({
16
+ contextOverride,
17
+ ...props
18
+ }: DataGridProps<R> & {
19
+ contextOverride?: Partial<DataGridContextProps<R>>;
20
+ }) => {
21
+ const {
22
+ className,
23
+ // onRowDoubleClick,
24
+ onVisibleRowsChange,
25
+ } = props;
26
+ const [contextProps, DataGridContext] = useDataGrid(props, contextOverride);
27
+ const {
28
+ selectedKeys,
29
+ setSelectedKeys,
30
+ columns,
31
+ visibleColumns,
32
+ rowHeight = 32,
33
+ headerRowHeight = 40,
34
+ scrollableRef,
35
+ onScroll,
36
+ rowKeyGetter,
37
+ } = contextProps;
38
+
39
+ const hasFooter = Object.values(columns).some((col) => col.footer);
40
+
41
+ const toggleSelection = useCallback(
42
+ (key: string) => {
43
+ if (selectedKeys.includes(key)) {
44
+ setSelectedKeys(selectedKeys.filter((p) => p !== key));
45
+ } else {
46
+ setSelectedKeys([...selectedKeys, key]);
47
+ }
48
+ },
49
+ [selectedKeys, setSelectedKeys]
50
+ );
51
+
52
+ const rowTemplate = useCallback(
53
+ (row: R, rowIndex: number) => {
54
+ if (!row) {
55
+ return (
56
+ <styles.DataGridRow key={`loading-row-${rowIndex}`}>
57
+ {!!props.selectable && (
58
+ <styles.LoadingCell className="animate-pulse">
59
+ <div />
60
+ </styles.LoadingCell>
61
+ )}
62
+ {visibleColumns.map((_, index) => (
63
+ <styles.LoadingCell
64
+ className="animate-pulse"
65
+ key={`loading-${rowIndex}-${index}`}
66
+ >
67
+ <div />
68
+ </styles.LoadingCell>
69
+ ))}
70
+ </styles.DataGridRow>
71
+ );
72
+ }
73
+ const key = rowKeyGetter(row);
74
+ const { className, style } = props.rowClassNameGetter?.(row) ?? {
75
+ className: '',
76
+ style: undefined,
77
+ };
78
+ return (
79
+ <styles.DataGridRow key={key}>
80
+ {!!props.selectable && (
81
+ <styles.SelectionCell
82
+ key="__select_checkbox__"
83
+ onClick={() => toggleSelection(key)}
84
+ >
85
+ <input
86
+ type="checkbox"
87
+ value={key as string}
88
+ checked={selectedKeys.includes(key)}
89
+ readOnly
90
+ />
91
+ </styles.SelectionCell>
92
+ )}
93
+ {visibleColumns.map(([key, col], index) => (
94
+ <DataGridCell
95
+ key={`loading-${rowIndex}-${index}`}
96
+ {...(index === 0 ? { className, style } : {})}
97
+ row={row}
98
+ rowIndex={rowIndex}
99
+ column={col}
100
+ columnIndex={index}
101
+ context={DataGridContext}
102
+ columnKey={key}
103
+ />
104
+ ))}
105
+ </styles.DataGridRow>
106
+ );
107
+ },
108
+ [
109
+ DataGridContext,
110
+ props,
111
+ rowKeyGetter,
112
+ selectedKeys,
113
+ toggleSelection,
114
+ visibleColumns,
115
+ ]
116
+ );
117
+
118
+ return (
119
+ <DataGridContext.Provider value={contextProps}>
120
+ <styles.DataGridContainer
121
+ ref={scrollableRef}
122
+ onScroll={onScroll}
123
+ $headerRowHeight={headerRowHeight}
124
+ $rowHeight={rowHeight}
125
+ $rowsCount={contextProps.sortedRows.length}
126
+ className={className}
127
+ >
128
+ <DataGridHeader context={DataGridContext} />
129
+ <VirtualScroller
130
+ onRangeChange={onVisibleRowsChange}
131
+ hasFooter={hasFooter}
132
+ rowTemplate={rowTemplate}
133
+ context={DataGridContext}
134
+ />
135
+ {hasFooter && <DataGridFooter context={DataGridContext} />}
136
+ </styles.DataGridContainer>
137
+ </DataGridContext.Provider>
138
+ );
139
+ };