@addev-be/ui 0.2.6 → 0.2.8

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 (68) hide show
  1. package/assets/icons/arrow-down-1-9.svg +1 -0
  2. package/assets/icons/arrow-down-big-small.svg +1 -0
  3. package/assets/icons/arrow-up-9-1.svg +1 -0
  4. package/assets/icons/arrow-up-big-small.svg +1 -0
  5. package/assets/icons/chevron-down.svg +1 -0
  6. package/assets/icons/ellipsis.svg +1 -0
  7. package/assets/icons/sigma.svg +1 -0
  8. package/assets/icons/table-footer-slash.svg +5 -0
  9. package/assets/icons/table-footer.svg +4 -0
  10. package/assets/icons/table.svg +1 -0
  11. package/assets/icons/tally.svg +1 -0
  12. package/assets/icons/x-bar.svg +4 -0
  13. package/dist/Icons.d.ts +13 -1
  14. package/dist/Icons.js +25 -1
  15. package/dist/components/data/AdvancedRequestDataGrid/index.js +3 -3
  16. package/dist/components/data/DataGrid/DataGridColumnsModal/hooks.js +2 -1
  17. package/dist/components/data/DataGrid/DataGridFilterMenu/index.js +85 -7
  18. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.d.ts +3 -9
  19. package/dist/components/data/DataGrid/DataGridFilterMenu/styles.js +10 -37
  20. package/dist/components/data/DataGrid/DataGridFooter.d.ts +1 -1
  21. package/dist/components/data/DataGrid/DataGridFooter.js +35 -12
  22. package/dist/components/data/DataGrid/DataGridHeader.js +1 -1
  23. package/dist/components/data/DataGrid/DataGridHeaderCell.js +6 -22
  24. package/dist/components/data/DataGrid/helpers/columns.d.ts +1 -1
  25. package/dist/components/data/DataGrid/helpers/columns.js +71 -16
  26. package/dist/components/data/DataGrid/hooks/useDataGrid.d.ts +1 -1
  27. package/dist/components/data/DataGrid/hooks/useDataGrid.js +60 -30
  28. package/dist/components/data/DataGrid/hooks/useDataGridCopy.d.ts +2 -2
  29. package/dist/components/data/DataGrid/hooks/useDataGridCopy.js +41 -39
  30. package/dist/components/data/DataGrid/index.d.ts +4 -2
  31. package/dist/components/data/DataGrid/index.js +22 -12
  32. package/dist/components/data/DataGrid/styles.d.ts +8 -4
  33. package/dist/components/data/DataGrid/styles.js +27 -17
  34. package/dist/components/data/DataGrid/types.d.ts +8 -1
  35. package/dist/components/data/SqlRequestDataGrid/helpers/columns.d.ts +1 -1
  36. package/dist/components/data/SqlRequestDataGrid/helpers/columns.js +24 -11
  37. package/dist/components/data/SqlRequestDataGrid/index.js +105 -33
  38. package/dist/components/ui/ContextMenu/index.d.ts +11 -0
  39. package/dist/components/ui/ContextMenu/index.js +58 -0
  40. package/dist/components/ui/ContextMenu/styles.d.ts +18 -0
  41. package/dist/components/ui/ContextMenu/styles.js +56 -0
  42. package/dist/services/advancedRequests.d.ts +1 -1
  43. package/dist/services/sqlRequests.d.ts +9 -4
  44. package/dist/services/sqlRequests.js +1 -0
  45. package/package.json +1 -1
  46. package/src/Icons.tsx +24 -0
  47. package/src/components/data/AdvancedRequestDataGrid/index.tsx +3 -5
  48. package/src/components/data/DataGrid/DataGridColumnsModal/hooks.tsx +2 -1
  49. package/src/components/data/DataGrid/DataGridFilterMenu/index.tsx +180 -22
  50. package/src/components/data/DataGrid/DataGridFilterMenu/styles.ts +13 -64
  51. package/src/components/data/DataGrid/DataGridFooter.tsx +20 -22
  52. package/src/components/data/DataGrid/DataGridHeader.tsx +5 -5
  53. package/src/components/data/DataGrid/DataGridHeaderCell.tsx +3 -38
  54. package/src/components/data/DataGrid/FilterValuesScroller.tsx +33 -27
  55. package/src/components/data/DataGrid/helpers/columns.tsx +103 -8
  56. package/src/components/data/DataGrid/helpers/filters.ts +29 -19
  57. package/src/components/data/DataGrid/hooks/useDataGrid.tsx +58 -17
  58. package/src/components/data/DataGrid/hooks/useDataGridCopy.ts +35 -30
  59. package/src/components/data/DataGrid/index.tsx +22 -14
  60. package/src/components/data/DataGrid/styles.ts +50 -9
  61. package/src/components/data/DataGrid/types.ts +24 -3
  62. package/src/components/data/SqlRequestDataGrid/helpers/columns.tsx +39 -3
  63. package/src/components/data/SqlRequestDataGrid/index.tsx +116 -21
  64. package/src/components/ui/ContextMenu/index.tsx +79 -0
  65. package/src/components/ui/ContextMenu/styles.ts +119 -0
  66. package/src/services/advancedRequests.ts +1 -1
  67. package/src/services/sqlRequests.ts +16 -5
  68. package/tsconfig.tsbuildinfo +1 -1
@@ -0,0 +1,79 @@
1
+ import { Divider, MenuContainer, MenuItemContainer, SubMenu } from './styles';
2
+ import {
3
+ FC,
4
+ HTMLAttributes,
5
+ PropsWithChildren,
6
+ useCallback,
7
+ useRef,
8
+ useState,
9
+ } from 'react';
10
+
11
+ type ContextMenuFC = FC<PropsWithChildren<HTMLAttributes<HTMLDivElement>>> & {
12
+ Item: typeof MenuItemContainer;
13
+ ParentItem: typeof ParentMenuItem;
14
+ Divider: typeof Divider;
15
+ SubMenu: typeof SubMenu;
16
+ };
17
+
18
+ export const ContextMenu: ContextMenuFC = ({ children }) => {
19
+ return (
20
+ <MenuContainer onClick={(e) => e.stopPropagation()}>
21
+ {children}
22
+ </MenuContainer>
23
+ );
24
+ };
25
+
26
+ export const ParentMenuItem: FC<HTMLAttributes<HTMLDivElement>> = ({
27
+ children,
28
+ ...props
29
+ }) => {
30
+ const [isOpened, setIsOpened] = useState(false);
31
+ const [isSubMenuLeft, setIsSubMenuLeft] = useState(false);
32
+ const [currentTimeout, setCurrentTimeout] = useState<number | null>(null);
33
+ const containerRef = useRef<HTMLDivElement | null>(null);
34
+
35
+ const stopTimeout = useCallback(() => {
36
+ if (currentTimeout) {
37
+ clearTimeout(currentTimeout);
38
+ }
39
+ setCurrentTimeout(null);
40
+ }, [currentTimeout]);
41
+
42
+ const startTimeout = useCallback(
43
+ (open: boolean) => {
44
+ stopTimeout();
45
+ setCurrentTimeout(
46
+ window.setTimeout(
47
+ () => {
48
+ const rect = containerRef.current?.getBoundingClientRect();
49
+ setIsSubMenuLeft(!!rect && rect.right + 280 > window.innerWidth);
50
+ setIsOpened(open);
51
+ },
52
+ open ? 100 : 300
53
+ )
54
+ );
55
+ },
56
+ [stopTimeout]
57
+ );
58
+
59
+ const open = useCallback(() => startTimeout(true), [startTimeout]);
60
+ const close = useCallback(() => startTimeout(false), [startTimeout]);
61
+
62
+ return (
63
+ <MenuItemContainer
64
+ ref={containerRef}
65
+ {...props}
66
+ className={`${isOpened ? 'opened' : ''} ${isSubMenuLeft ? 'left' : ''}`}
67
+ onMouseEnter={open}
68
+ onMouseLeave={close}
69
+ $withArrow
70
+ >
71
+ {children}
72
+ </MenuItemContainer>
73
+ );
74
+ };
75
+
76
+ ContextMenu.Item = MenuItemContainer;
77
+ ContextMenu.ParentItem = ParentMenuItem;
78
+ ContextMenu.Divider = Divider;
79
+ ContextMenu.SubMenu = SubMenu;
@@ -0,0 +1,119 @@
1
+ import styled, { css } from 'styled-components';
2
+
3
+ import { ThemeColor } from '../../../providers/ThemeProvider/types';
4
+
5
+ const menuContainerCss = css`
6
+ position: absolute;
7
+ color: var(--color-neutral-900);
8
+ border-radius: var(--rounded-md);
9
+ padding: var(--space-1) 0;
10
+ box-shadow: var(--shadow-lg);
11
+ background-color: var(--color-neutral-100);
12
+ min-width: 20em;
13
+ outline: 1px solid var(--color-neutral-200);
14
+ display: flex;
15
+ flex-direction: column;
16
+ `;
17
+
18
+ export const MenuContainer = styled.div.attrs({
19
+ className: 'MenuContainer',
20
+ })`
21
+ ${menuContainerCss}
22
+ inset: 0;
23
+ `;
24
+ MenuContainer.displayName = 'MenuContainer';
25
+
26
+ export const SubMenu = styled.div.attrs({
27
+ className: 'SubMenu',
28
+ })`
29
+ ${menuContainerCss}
30
+ top: 0;
31
+ left: 100%;
32
+ margin-top: -var(--space-1);
33
+ `;
34
+ SubMenu.displayName = 'SubMenu';
35
+
36
+ export const MenuItemContainer = styled.div.attrs({
37
+ className: 'MenuItemContainer',
38
+ })<{
39
+ $color?: ThemeColor;
40
+ disabled?: boolean;
41
+ $withArrow?: boolean;
42
+ $opened?: boolean;
43
+ }>`
44
+ position: relative;
45
+ display: flex;
46
+ align-items: center;
47
+ font-family: var(--font-sans);
48
+ font-weight: normal;
49
+ text-align: left;
50
+ padding: var(--space-1) var(--space-2);
51
+ font-size: var(--text-base);
52
+ line-height: var(--leading-6);
53
+ border: none;
54
+ cursor: pointer;
55
+
56
+ ${({ $withArrow }) =>
57
+ $withArrow &&
58
+ css`
59
+ &::after {
60
+ content: '';
61
+ position: absolute;
62
+ right: var(--space-2);
63
+ top: 50%;
64
+ transform: translateY(-50%);
65
+ border: 4px solid transparent;
66
+ border-left-color: var(--color-neutral-600);
67
+ }
68
+ `}
69
+
70
+ ${({ $color, disabled }) =>
71
+ disabled
72
+ ? css`
73
+ color: var(--color-neutral-300);
74
+ background-color: var(--color-neutral-100);
75
+ cursor: default;
76
+ `
77
+ : $color
78
+ ? css`
79
+ color: var(--color-${$color}-600);
80
+ background-color: var(--color-neutral-100);
81
+ &:hover {
82
+ background-color: var(--color-${$color}-200);
83
+ }
84
+ `
85
+ : css`
86
+ color: var(--color-neutral-900);
87
+ background-color: var(--color-neutral-100);
88
+ &:hover {
89
+ background-color: var(--color-neutral-200);
90
+ }
91
+ `}
92
+
93
+ svg {
94
+ fill: currentColor;
95
+ width: var(--space-4);
96
+ height: var(--space-4);
97
+ margin-right: var(--space-2);
98
+ }
99
+
100
+ & > ${SubMenu} {
101
+ display: none;
102
+ margin-top: calc(0px - var(--space-1));
103
+ }
104
+ &.opened > ${SubMenu} {
105
+ display: block;
106
+ }
107
+ &.opened.left > ${SubMenu} {
108
+ left: auto;
109
+ right: 100%;
110
+ }
111
+ `;
112
+ MenuItemContainer.displayName = 'MenuItemContainer';
113
+
114
+ export const Divider = styled.div.attrs({
115
+ className: 'Divider',
116
+ })`
117
+ border-top: 1px solid var(--color-neutral-200);
118
+ margin: var(--space-1) 0;
119
+ `;
@@ -81,7 +81,7 @@ export type AdvancedRequestRow<R> = {
81
81
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
82
82
  export type AdvancedResponseDTO<T = any> = {
83
83
  data: AdvancedRequestRow<T>[];
84
- total?: number;
84
+ count?: number;
85
85
  };
86
86
 
87
87
  export type AdvancedRequestFieldDTO =
@@ -58,30 +58,36 @@ export type ConditionDTO = {
58
58
 
59
59
  export type OrderByDTO = {
60
60
  field: string;
61
+ type: string;
61
62
  direction?: 'ASC' | 'DESC';
62
63
  };
63
64
 
65
+ export type SqlRequestFooterFunction = 'sum' | 'avg' | 'count' | 'max' | 'min';
66
+
64
67
  export type SqlRequestDTO = {
65
68
  columns?: string[];
66
69
  returnColumns?: string[];
70
+ columnTypes?: string[];
71
+ totalColumns?: Record<string, SqlRequestFooterFunction>;
67
72
  conditions?: ConditionDTO[];
68
73
  orderBy?: OrderByDTO[];
69
74
  start?: number;
70
75
  length?: number;
71
- getTotal?: boolean;
76
+ getCount?: boolean;
72
77
  unique?: boolean;
73
78
  };
74
79
 
75
80
  export type SqlRequestRow<R> = {
76
- [K in keyof R]: R[K] extends string | number | null
81
+ [K in keyof R]: R[K] extends string | number | null | undefined
77
82
  ? R[K]
78
- : string | number | null;
83
+ : string | number | null | undefined;
79
84
  };
80
85
 
81
86
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
82
87
  export type SqlResponseDTO<T = any> = {
83
88
  data: SqlRequestRow<T>[];
84
- total?: number;
89
+ count?: number;
90
+ totals?: Record<string, string | number | null | undefined>;
85
91
  };
86
92
 
87
93
  type SqlRequestHandler<T> = (
@@ -91,9 +97,14 @@ type SqlRequestHandler<T> = (
91
97
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
92
98
  export const useSqlRequestHandler = <T = any>(
93
99
  name: string
94
- ): [SqlRequestHandler<T>, SqlRequestHandler<{ Id: string }>] => [
100
+ ): [
101
+ SqlRequestHandler<T>,
102
+ SqlRequestHandler<{ Id: string }>,
103
+ SqlRequestHandler<Partial<T>>
104
+ ] => [
95
105
  useWebSocketRequestHandler<SqlRequestDTO, SqlResponseDTO<T>>(name),
96
106
  useWebSocketRequestHandler<SqlRequestDTO, SqlResponseDTO<{ Id: string }>>(
97
107
  name
98
108
  ),
109
+ useWebSocketRequestHandler<SqlRequestDTO, SqlResponseDTO<Partial<T>>>(name),
99
110
  ];
@@ -1 +1 @@
1
- {"root":["./src/icons.tsx","./src/index.ts","./src/typings.d.ts","./src/components/index.ts","./src/components/data/index.ts","./src/components/data/advancedrequestdatagrid/index.tsx","./src/components/data/advancedrequestdatagrid/types.ts","./src/components/data/advancedrequestdatagrid/helpers/advancedrequests.ts","./src/components/data/advancedrequestdatagrid/helpers/columns.tsx","./src/components/data/advancedrequestdatagrid/helpers/index.ts","./src/components/data/datagrid/datagridcell.tsx","./src/components/data/datagrid/datagrideditablecell.tsx","./src/components/data/datagrid/datagridfooter.tsx","./src/components/data/datagrid/datagridheader.tsx","./src/components/data/datagrid/datagridheadercell.tsx","./src/components/data/datagrid/filtervaluesscroller.tsx","./src/components/data/datagrid/virtualscroller.tsx","./src/components/data/datagrid/index.tsx","./src/components/data/datagrid/styles.ts","./src/components/data/datagrid/types.ts","./src/components/data/datagrid/datagridcolumnsmodal/helpers.ts","./src/components/data/datagrid/datagridcolumnsmodal/hooks.tsx","./src/components/data/datagrid/datagridcolumnsmodal/index.tsx","./src/components/data/datagrid/datagridcolumnsmodal/styles.ts","./src/components/data/datagrid/datagridfiltermenu/hooks.tsx","./src/components/data/datagrid/datagridfiltermenu/index.tsx","./src/components/data/datagrid/datagridfiltermenu/styles.ts","./src/components/data/datagrid/filtermodalcontent/index.tsx","./src/components/data/datagrid/filtermodalcontent/styles.ts","./src/components/data/datagrid/helpers/columns.tsx","./src/components/data/datagrid/helpers/filters.ts","./src/components/data/datagrid/helpers/index.ts","./src/components/data/datagrid/hooks/index.ts","./src/components/data/datagrid/hooks/usedatagrid.tsx","./src/components/data/datagrid/hooks/usedatagridcopy.ts","./src/components/data/datagrid/hooks/usedatagridsettings.ts","./src/components/data/sqlrequestdatagrid/index.tsx","./src/components/data/sqlrequestdatagrid/types.ts","./src/components/data/sqlrequestdatagrid/helpers/columns.tsx","./src/components/data/sqlrequestdatagrid/helpers/index.ts","./src/components/data/sqlrequestdatagrid/helpers/sqlrequests.ts","./src/components/forms/button.tsx","./src/components/forms/iconbutton.tsx","./src/components/forms/indeterminatecheckbox.tsx","./src/components/forms/select.tsx","./src/components/forms/index.ts","./src/components/forms/styles.ts","./src/components/layout/index.ts","./src/components/layout/dropdown/index.tsx","./src/components/layout/dropdown/styles.ts","./src/components/layout/loading/index.tsx","./src/components/layout/loading/styles.ts","./src/components/layout/modal/index.tsx","./src/components/layout/modal/styles.ts","./src/config/index.ts","./src/helpers/dates.ts","./src/helpers/getscrollbarsize.ts","./src/helpers/numbers.ts","./src/hooks/index.ts","./src/hooks/useelementsize.ts","./src/hooks/usewindowsize.ts","./src/providers/hooks.ts","./src/providers/index.ts","./src/providers/portalsprovider/index.tsx","./src/providers/portalsprovider/styles.ts","./src/providers/settingsprovider/index.tsx","./src/providers/themeprovider/themeprovider.ts","./src/providers/themeprovider/defaulttheme.ts","./src/providers/themeprovider/index.ts","./src/providers/themeprovider/types.ts","./src/providers/uiproviders/index.tsx","./src/providers/uiproviders/styles.ts","./src/services/httpservice.ts","./src/services/websocketservice.ts","./src/services/advancedrequests.ts","./src/services/base.ts","./src/services/hooks.ts","./src/services/index.ts","./src/services/sqlrequests.ts"],"version":"5.6.2"}
1
+ {"root":["./src/icons.tsx","./src/index.ts","./src/typings.d.ts","./src/components/index.ts","./src/components/data/index.ts","./src/components/data/advancedrequestdatagrid/index.tsx","./src/components/data/advancedrequestdatagrid/types.ts","./src/components/data/advancedrequestdatagrid/helpers/advancedrequests.ts","./src/components/data/advancedrequestdatagrid/helpers/columns.tsx","./src/components/data/advancedrequestdatagrid/helpers/index.ts","./src/components/data/datagrid/datagridcell.tsx","./src/components/data/datagrid/datagrideditablecell.tsx","./src/components/data/datagrid/datagridfooter.tsx","./src/components/data/datagrid/datagridheader.tsx","./src/components/data/datagrid/datagridheadercell.tsx","./src/components/data/datagrid/filtervaluesscroller.tsx","./src/components/data/datagrid/virtualscroller.tsx","./src/components/data/datagrid/index.tsx","./src/components/data/datagrid/styles.ts","./src/components/data/datagrid/types.ts","./src/components/data/datagrid/datagridcolumnsmodal/helpers.ts","./src/components/data/datagrid/datagridcolumnsmodal/hooks.tsx","./src/components/data/datagrid/datagridcolumnsmodal/index.tsx","./src/components/data/datagrid/datagridcolumnsmodal/styles.ts","./src/components/data/datagrid/datagridfiltermenu/hooks.tsx","./src/components/data/datagrid/datagridfiltermenu/index.tsx","./src/components/data/datagrid/datagridfiltermenu/styles.ts","./src/components/data/datagrid/filtermodalcontent/index.tsx","./src/components/data/datagrid/filtermodalcontent/styles.ts","./src/components/data/datagrid/helpers/columns.tsx","./src/components/data/datagrid/helpers/filters.ts","./src/components/data/datagrid/helpers/index.ts","./src/components/data/datagrid/hooks/index.ts","./src/components/data/datagrid/hooks/usedatagrid.tsx","./src/components/data/datagrid/hooks/usedatagridcopy.ts","./src/components/data/datagrid/hooks/usedatagridsettings.ts","./src/components/data/sqlrequestdatagrid/index.tsx","./src/components/data/sqlrequestdatagrid/types.ts","./src/components/data/sqlrequestdatagrid/helpers/columns.tsx","./src/components/data/sqlrequestdatagrid/helpers/index.ts","./src/components/data/sqlrequestdatagrid/helpers/sqlrequests.ts","./src/components/forms/button.tsx","./src/components/forms/iconbutton.tsx","./src/components/forms/indeterminatecheckbox.tsx","./src/components/forms/select.tsx","./src/components/forms/index.ts","./src/components/forms/styles.ts","./src/components/layout/index.ts","./src/components/layout/dropdown/index.tsx","./src/components/layout/dropdown/styles.ts","./src/components/layout/loading/index.tsx","./src/components/layout/loading/styles.ts","./src/components/layout/modal/index.tsx","./src/components/layout/modal/styles.ts","./src/components/ui/contextmenu/index.tsx","./src/components/ui/contextmenu/styles.ts","./src/config/index.ts","./src/helpers/dates.ts","./src/helpers/getscrollbarsize.ts","./src/helpers/numbers.ts","./src/hooks/index.ts","./src/hooks/useelementsize.ts","./src/hooks/usewindowsize.ts","./src/providers/hooks.ts","./src/providers/index.ts","./src/providers/portalsprovider/index.tsx","./src/providers/portalsprovider/styles.ts","./src/providers/settingsprovider/index.tsx","./src/providers/themeprovider/themeprovider.ts","./src/providers/themeprovider/defaulttheme.ts","./src/providers/themeprovider/index.ts","./src/providers/themeprovider/types.ts","./src/providers/uiproviders/index.tsx","./src/providers/uiproviders/styles.ts","./src/services/httpservice.ts","./src/services/websocketservice.ts","./src/services/advancedrequests.ts","./src/services/base.ts","./src/services/hooks.ts","./src/services/index.ts","./src/services/sqlrequests.ts"],"version":"5.6.2"}