kelt-ui-kit-react 1.2.4 → 1.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 (215) hide show
  1. package/README.md +46 -46
  2. package/dist/App.d.ts +3 -2
  3. package/dist/App.menu.d.ts +10 -10
  4. package/dist/App.routes.d.ts +1 -1
  5. package/dist/_core/hooks/ImageChecker.d.ts +6 -5
  6. package/dist/_core/hooks/useIsMobile.d.ts +1 -1
  7. package/dist/action/Action.view.d.ts +1 -1
  8. package/dist/action/ButtonAction.d.ts +9 -8
  9. package/dist/badge/Badge.d.ts +9 -8
  10. package/dist/badge/Badge.view.d.ts +1 -1
  11. package/dist/button/Button.d.ts +2 -1
  12. package/dist/button/Button.view.d.ts +1 -1
  13. package/dist/button/button.interface.d.ts +18 -17
  14. package/dist/button/buttonActions/ButtonActions.d.ts +11 -10
  15. package/dist/card/Card.d.ts +13 -12
  16. package/dist/card/Card.view.d.ts +1 -1
  17. package/dist/card/card.interface.d.ts +10 -10
  18. package/dist/card/cardAction/CardAction.d.ts +14 -13
  19. package/dist/card/cardAction.interface.d.ts +9 -8
  20. package/dist/card/hook/useCardInteractions.d.ts +8 -8
  21. package/dist/carousel/Carousel.d.ts +15 -14
  22. package/dist/carousel/Carousel.view.d.ts +1 -1
  23. package/dist/damier/Damier.d.ts +10 -9
  24. package/dist/damier/Damier.view.d.ts +1 -1
  25. package/dist/damier/damierCell/DamierCell.d.ts +7 -6
  26. package/dist/damier/damierCell/damierCell.interface.d.ts +6 -6
  27. package/dist/dataTable/DataTable.d.ts +18 -17
  28. package/dist/dataTable/DataTable.view.d.ts +1 -1
  29. package/dist/dataTable/dataTable.interface.d.ts +32 -30
  30. package/dist/datePicker/DatePicker.d.ts +8 -7
  31. package/dist/datePicker/DatePicker.view.d.ts +1 -1
  32. package/dist/expands/Expands.d.ts +10 -9
  33. package/dist/expands/Expands.view.d.ts +1 -1
  34. package/dist/expands/expand/expand.d.ts +9 -8
  35. package/dist/expands/expand/expand.interface.d.ts +9 -9
  36. package/dist/filAriane/FilAriane.d.ts +9 -8
  37. package/dist/filAriane/FilAriane.view.d.ts +1 -1
  38. package/dist/filAriane/filAriane.interface.d.ts +6 -6
  39. package/dist/form/Form.d.ts +24 -23
  40. package/dist/form/Form.view.d.ts +1 -1
  41. package/dist/form/form.enum.d.ts +11 -11
  42. package/dist/form/form.interface.d.ts +30 -29
  43. package/dist/form/textArea/TextArea.d.ts +13 -12
  44. package/dist/form/textArea/TextArea.view.d.ts +1 -1
  45. package/dist/grid/Grid.d.ts +8 -7
  46. package/dist/grid/Grid.view.d.ts +1 -1
  47. package/dist/grid/col/Col.d.ts +10 -10
  48. package/dist/grid/col/colStyled/ColStyled.d.ts +9 -9
  49. package/dist/grid/container/Container.d.ts +6 -5
  50. package/dist/grid/grid.interface.d.ts +8 -8
  51. package/dist/grid/row/Row.d.ts +8 -7
  52. package/dist/header/Header.d.ts +2 -1
  53. package/dist/header/Header.view.d.ts +1 -1
  54. package/dist/header/header.interface.d.ts +9 -9
  55. package/dist/home/Home.d.ts +1 -1
  56. package/dist/icon/Icon.d.ts +2 -1
  57. package/dist/icon/Icons.view.d.ts +1 -1
  58. package/dist/icon/icon.interface.d.ts +5 -4
  59. package/dist/icon/iconSize.enum.d.ts +7 -7
  60. package/dist/index.d.ts +32 -31
  61. package/dist/index.html +18 -18
  62. package/dist/index.js +66 -65
  63. package/dist/loader/Loader.d.ts +8 -7
  64. package/dist/loader/Loader.view.d.ts +1 -1
  65. package/dist/main.d.ts +1 -0
  66. package/dist/manifest.json +25 -25
  67. package/dist/menus/Menus.d.ts +6 -5
  68. package/dist/menus/Menus.view.d.ts +1 -1
  69. package/dist/menus/menu/Menu.d.ts +7 -6
  70. package/dist/menus/menu/menu.interface.d.ts +10 -10
  71. package/dist/modal/Modal.d.ts +13 -12
  72. package/dist/modal/Modal.view.d.ts +1 -1
  73. package/dist/notFound/NotFound.d.ts +1 -1
  74. package/dist/overlayPanel/OverlayPanel.d.ts +19 -18
  75. package/dist/overlayPanel/OverlayPanel.view.d.ts +1 -1
  76. package/dist/overlayPanel/overlay.context.d.ts +10 -9
  77. package/dist/overlayPanel/overlayPanelStyled/OverlayPanelStyled.d.ts +7 -7
  78. package/dist/quantity/Quantity.d.ts +11 -10
  79. package/dist/robots.txt +3 -3
  80. package/dist/search/Search.d.ts +22 -21
  81. package/dist/search/Search.view.d.ts +1 -1
  82. package/dist/select/Select.d.ts +14 -13
  83. package/dist/select/Select.view.d.ts +1 -1
  84. package/dist/select/selectOption.interface.d.ts +4 -4
  85. package/dist/sidebar/Sidebar.d.ts +13 -12
  86. package/dist/sidebar/Sidebar.view.d.ts +1 -1
  87. package/dist/sidebarData/SidebarData.d.ts +7 -6
  88. package/dist/sidebarData/SidebarData.view.d.ts +1 -1
  89. package/dist/style.css +1 -1
  90. package/dist/toaster/Toaster.d.ts +2 -1
  91. package/dist/toaster/Toaster.view.d.ts +1 -1
  92. package/dist/toaster/store/useToasterStore.d.ts +18 -18
  93. package/index.html +19 -19
  94. package/package.json +55 -55
  95. package/public/index.html +18 -18
  96. package/public/manifest.json +25 -25
  97. package/public/robots.txt +3 -3
  98. package/src/App.css +11 -11
  99. package/src/App.menu.tsx +209 -209
  100. package/src/App.routes.tsx +16 -16
  101. package/src/App.tsx +28 -28
  102. package/src/_core/hooks/ImageChecker.tsx +26 -26
  103. package/src/_core/hooks/useIsMobile.ts +18 -18
  104. package/src/action/Action.view.tsx +21 -21
  105. package/src/action/ButtonAction.tsx +32 -32
  106. package/src/action/action.css +20 -20
  107. package/src/badge/Badge.tsx +34 -34
  108. package/src/badge/Badge.view.tsx +15 -15
  109. package/src/badge/badge.css +55 -55
  110. package/src/button/Button.tsx +44 -44
  111. package/src/button/Button.view.tsx +61 -61
  112. package/src/button/button.css +53 -53
  113. package/src/button/button.interface.tsx +20 -20
  114. package/src/button/buttonActions/ButtonActions.tsx +101 -101
  115. package/src/card/Card.tsx +125 -125
  116. package/src/card/Card.view.tsx +73 -73
  117. package/src/card/card.css +145 -145
  118. package/src/card/card.interface.tsx +9 -9
  119. package/src/card/cardAction/CardAction.tsx +135 -135
  120. package/src/card/cardAction/cardAction.css +10 -10
  121. package/src/card/cardAction.interface.tsx +10 -10
  122. package/src/card/hook/useCardInteractions.tsx +30 -30
  123. package/src/carousel/Carousel.css +44 -44
  124. package/src/carousel/Carousel.tsx +115 -115
  125. package/src/carousel/Carousel.view.tsx +13 -13
  126. package/src/damier/Damier.tsx +55 -55
  127. package/src/damier/Damier.view.tsx +31 -31
  128. package/src/damier/damier.css +44 -44
  129. package/src/damier/damierCell/DamierCell.tsx +18 -18
  130. package/src/damier/damierCell/damierCell.interface.tsx +5 -5
  131. package/src/dataTable/DataTable.tsx +242 -241
  132. package/src/dataTable/DataTable.view.tsx +59 -59
  133. package/src/dataTable/dataTable.css +17 -17
  134. package/src/dataTable/dataTable.interface.ts +30 -29
  135. package/src/datePicker/DatePicker.tsx +110 -110
  136. package/src/datePicker/DatePicker.view.tsx +9 -9
  137. package/src/datePicker/datePicker.css +77 -77
  138. package/src/expands/Expands.tsx +42 -42
  139. package/src/expands/Expands.view.tsx +90 -90
  140. package/src/expands/expand/expand.interface.tsx +8 -8
  141. package/src/expands/expand/expand.tsx +75 -75
  142. package/src/expands/expands.css +97 -97
  143. package/src/filAriane/FilAriane.tsx +57 -57
  144. package/src/filAriane/FilAriane.view.tsx +28 -28
  145. package/src/filAriane/filAriane.css +22 -22
  146. package/src/filAriane/filAriane.interface.tsx +6 -6
  147. package/src/form/Form.tsx +175 -175
  148. package/src/form/Form.view.tsx +47 -47
  149. package/src/form/form.css +37 -37
  150. package/src/form/form.enum.ts +11 -11
  151. package/src/form/form.interface.tsx +31 -31
  152. package/src/form/textArea/TextArea.tsx +53 -53
  153. package/src/form/textArea/TextArea.view.tsx +34 -34
  154. package/src/form/textArea/textArea.css +9 -9
  155. package/src/grid/Grid.tsx +21 -21
  156. package/src/grid/Grid.view.tsx +24 -24
  157. package/src/grid/col/Col.tsx +15 -15
  158. package/src/grid/col/colStyled/ColStyled.tsx +41 -41
  159. package/src/grid/container/Container.tsx +8 -8
  160. package/src/grid/container/container.css +5 -5
  161. package/src/grid/grid.interface.tsx +7 -7
  162. package/src/grid/row/Row.tsx +12 -12
  163. package/src/grid/row/row.css +18 -18
  164. package/src/header/Header.tsx +51 -51
  165. package/src/header/Header.view.tsx +5 -5
  166. package/src/header/header.css +26 -26
  167. package/src/header/header.interface.tsx +8 -8
  168. package/src/home/Home.tsx +3 -3
  169. package/src/icon/Icon.tsx +6 -6
  170. package/src/icon/Icons.view.tsx +29 -29
  171. package/src/icon/icon.css +20 -20
  172. package/src/icon/icon.interface.tsx +6 -6
  173. package/src/icon/iconSize.enum.ts +7 -7
  174. package/src/index.css +502 -502
  175. package/src/index.ts +33 -33
  176. package/src/loader/Loader.tsx +37 -37
  177. package/src/loader/Loader.view.tsx +20 -20
  178. package/src/loader/loader.css +30 -30
  179. package/src/main.tsx +10 -10
  180. package/src/menus/Menus.tsx +42 -42
  181. package/src/menus/Menus.view.tsx +39 -39
  182. package/src/menus/menu/Menu.tsx +17 -17
  183. package/src/menus/menu/menu.interface.tsx +9 -9
  184. package/src/menus/menus.css +47 -47
  185. package/src/modal/Modal.tsx +53 -53
  186. package/src/modal/Modal.view.tsx +25 -25
  187. package/src/modal/modal.css +71 -70
  188. package/src/notFound/NotFound.tsx +3 -3
  189. package/src/overlayPanel/OverlayPanel.tsx +189 -189
  190. package/src/overlayPanel/OverlayPanel.view.tsx +25 -25
  191. package/src/overlayPanel/overlay.context.tsx +28 -28
  192. package/src/overlayPanel/overlayPanel.css +35 -35
  193. package/src/overlayPanel/overlayPanelStyled/OverlayPanelStyled.tsx +18 -18
  194. package/src/quantity/Quantity.tsx +103 -103
  195. package/src/quantity/quantity.css +26 -26
  196. package/src/search/Search.tsx +161 -161
  197. package/src/search/Search.view.tsx +14 -14
  198. package/src/search/search.css +59 -59
  199. package/src/select/Select.tsx +53 -53
  200. package/src/select/Select.view.tsx +71 -71
  201. package/src/select/select.css +51 -51
  202. package/src/select/selectOption.interface.ts +4 -4
  203. package/src/sidebar/Sidebar.tsx +111 -111
  204. package/src/sidebar/Sidebar.view.tsx +17 -17
  205. package/src/sidebar/sidebar.css +87 -87
  206. package/src/sidebarData/SidebarData.tsx +19 -19
  207. package/src/sidebarData/SidebarData.view.tsx +19 -19
  208. package/src/sidebarData/sidebarData.css +27 -27
  209. package/src/toaster/Toaster.tsx +47 -47
  210. package/src/toaster/Toaster.view.tsx +3 -3
  211. package/src/toaster/store/useToasterStore.tsx +39 -39
  212. package/src/toaster/toaster.css +57 -57
  213. package/tsconfig.json +28 -28
  214. package/vite.config.ts +20 -20
  215. package/vite.config.ts.timestamp-1733262892554-a13dfef6e8a29.mjs +24 -24
package/src/card/card.css CHANGED
@@ -1,145 +1,145 @@
1
- .card {
2
- border: 1px solid #cfbdbd;
3
- border-radius: 10px;
4
- padding: 1rem;
5
- max-width: 200px;
6
- height: 100%;
7
- overflow: hidden;
8
- position: relative;
9
- flex-wrap: wrap;
10
-
11
- .card-overlay {
12
- display: none;
13
- position: absolute;
14
- background-color: rgba(0, 0, 0, 0.1);
15
- width: 100%;
16
- left: 0;
17
- right: 0;
18
- top: 0;
19
- bottom: 0;
20
- pointer-events: none;
21
- }
22
- .bi-three-dots-vertical {
23
- display: none;
24
- }
25
- .card-custom-action {
26
- display: flex;
27
- flex: 1;
28
- justify-content: start;
29
- align-items: center;
30
- }
31
-
32
- .bi-trash3 {
33
- font-size: 1rem;
34
- }
35
- .card-text {
36
- width: 100%;
37
- }
38
- .card-footer {
39
- display: flex;
40
- flex: 1;
41
- align-items: center;
42
- justify-content: space-between;
43
- }
44
- &.card--horizontal {
45
- display: flex;
46
- flex-direction: row;
47
- align-items: center;
48
- min-height: 56px;
49
- max-width: initial;
50
- .card-img {
51
- margin-right: 0.5rem;
52
- }
53
-
54
- .card-content {
55
- flex: 1;
56
- min-width: 200px;
57
- }
58
-
59
- .card-title {
60
- width: calc(100% - 20px);
61
- margin-bottom: 1rem;
62
- }
63
- .card-action {
64
- position: absolute;
65
- right: 10px;
66
- top: 10px;
67
- }
68
- .card-prix {
69
- flex: 1;
70
- display: flex;
71
- justify-content: flex-end;
72
- }
73
- }
74
-
75
- &:not(.card--horizontal) {
76
- .card-title {
77
- margin-bottom: 1rem;
78
- }
79
- }
80
-
81
- .card-img {
82
- width: 30px;
83
-
84
- img {
85
- width: 100%;
86
- }
87
- }
88
-
89
- .card-title {
90
- font-size: 14px;
91
- font-weight: 600;
92
- }
93
-
94
- .card-content {
95
- font-size: 14px;
96
- font-weight: 400;
97
- display: none;
98
- }
99
- }
100
- @container (min-width: 992px) {
101
- .card {
102
- .card-custom-action {
103
- justify-content: end;
104
- }
105
- .bi-three-dots-vertical {
106
- display: block;
107
- }
108
- .bi-three-dots {
109
- display: none;
110
- }
111
- &.card--horizontal {
112
- .card-actions {
113
- margin-left: 0.5rem;
114
- }
115
- .card-footer {
116
- display: flex;
117
- flex: 1;
118
- justify-content: space-between;
119
- }
120
- .card-text {
121
- width: 300px;
122
- display: flex;
123
- align-items: center;
124
- }
125
- .card-content {
126
- display: flex;
127
- }
128
- .card-title {
129
- min-width: auto;
130
- width: auto;
131
- margin-right: 1rem;
132
- margin-bottom: 0;
133
- }
134
- .card-prix {
135
- flex: inherit;
136
- min-width: auto;
137
- }
138
- .card-action {
139
- position: relative;
140
- right: initial;
141
- top: initial;
142
- }
143
- }
144
- }
145
- }
1
+ .card {
2
+ border: 1px solid #cfbdbd;
3
+ border-radius: 10px;
4
+ padding: 1rem;
5
+ max-width: 200px;
6
+ height: 100%;
7
+ overflow: hidden;
8
+ position: relative;
9
+ flex-wrap: wrap;
10
+
11
+ .card-overlay {
12
+ display: none;
13
+ position: absolute;
14
+ background-color: rgba(0, 0, 0, 0.1);
15
+ width: 100%;
16
+ left: 0;
17
+ right: 0;
18
+ top: 0;
19
+ bottom: 0;
20
+ pointer-events: none;
21
+ }
22
+ .bi-three-dots-vertical {
23
+ display: none;
24
+ }
25
+ .card-custom-action {
26
+ display: flex;
27
+ flex: 1;
28
+ justify-content: start;
29
+ align-items: center;
30
+ }
31
+
32
+ .bi-trash3 {
33
+ font-size: 1rem;
34
+ }
35
+ .card-text {
36
+ width: 100%;
37
+ }
38
+ .card-footer {
39
+ display: flex;
40
+ flex: 1;
41
+ align-items: center;
42
+ justify-content: space-between;
43
+ }
44
+ &.card--horizontal {
45
+ display: flex;
46
+ flex-direction: row;
47
+ align-items: center;
48
+ min-height: 56px;
49
+ max-width: initial;
50
+ .card-img {
51
+ margin-right: 0.5rem;
52
+ }
53
+
54
+ .card-content {
55
+ flex: 1;
56
+ min-width: 200px;
57
+ }
58
+
59
+ .card-title {
60
+ width: calc(100% - 20px);
61
+ margin-bottom: 1rem;
62
+ }
63
+ .card-action {
64
+ position: absolute;
65
+ right: 10px;
66
+ top: 10px;
67
+ }
68
+ .card-prix {
69
+ flex: 1;
70
+ display: flex;
71
+ justify-content: flex-end;
72
+ }
73
+ }
74
+
75
+ &:not(.card--horizontal) {
76
+ .card-title {
77
+ margin-bottom: 1rem;
78
+ }
79
+ }
80
+
81
+ .card-img {
82
+ width: 30px;
83
+
84
+ img {
85
+ width: 100%;
86
+ }
87
+ }
88
+
89
+ .card-title {
90
+ font-size: 14px;
91
+ font-weight: 600;
92
+ }
93
+
94
+ .card-content {
95
+ font-size: 14px;
96
+ font-weight: 400;
97
+ display: none;
98
+ }
99
+ }
100
+ @container (min-width: 992px) {
101
+ .card {
102
+ .card-custom-action {
103
+ justify-content: end;
104
+ }
105
+ .bi-three-dots-vertical {
106
+ display: block;
107
+ }
108
+ .bi-three-dots {
109
+ display: none;
110
+ }
111
+ &.card--horizontal {
112
+ .card-actions {
113
+ margin-left: 0.5rem;
114
+ }
115
+ .card-footer {
116
+ display: flex;
117
+ flex: 1;
118
+ justify-content: space-between;
119
+ }
120
+ .card-text {
121
+ width: 300px;
122
+ display: flex;
123
+ align-items: center;
124
+ }
125
+ .card-content {
126
+ display: flex;
127
+ }
128
+ .card-title {
129
+ min-width: auto;
130
+ width: auto;
131
+ margin-right: 1rem;
132
+ margin-bottom: 0;
133
+ }
134
+ .card-prix {
135
+ flex: inherit;
136
+ min-width: auto;
137
+ }
138
+ .card-action {
139
+ position: relative;
140
+ right: initial;
141
+ top: initial;
142
+ }
143
+ }
144
+ }
145
+ }
@@ -1,9 +1,9 @@
1
- export interface CardInterface {
2
- id?: number | string;
3
- uuid?: string;
4
- title: string | JSX.Element;
5
- description?: string | JSX.Element;
6
- image?: string;
7
- prix?: string | JSX.Element;
8
- quantity?: number;
9
- }
1
+ export interface CardInterface {
2
+ id?: number | string;
3
+ uuid?: string;
4
+ title: string | JSX.Element;
5
+ description?: string | JSX.Element;
6
+ image?: string;
7
+ prix?: string | JSX.Element;
8
+ quantity?: number;
9
+ }
@@ -1,135 +1,135 @@
1
- import { useCallback, useEffect, useMemo, useRef, useState } from "react";
2
- import { Button } from "../../button/Button";
3
- import { Icon } from "../../icon/Icon";
4
- import { IconSizeEnum } from "../../icon/iconSize.enum";
5
- import { MenuInterface } from "../../menus/menu/menu.interface";
6
- import { Menus } from "../../menus/Menus";
7
- import { OverlayPanel } from "../../overlayPanel/OverlayPanel";
8
- import { CardInterface } from "../card.interface";
9
- import { CardActionInterface } from "../cardAction.interface";
10
- import "./cardAction.css";
11
- export type PositionOverlay =
12
- | "left"
13
- | "right"
14
- | "topLeft"
15
- | "topRight"
16
- | "bottomLeft"
17
- | "bottomRight";
18
- export type CardActionProps = {
19
- actions: CardActionInterface[];
20
- item?: CardInterface;
21
- openActions?: boolean;
22
- positions?: { top: number; left: number };
23
- positionOverlay?: PositionOverlay;
24
- setOpenActions?: (open: boolean) => void;
25
- };
26
-
27
- export const CardAction = ({
28
- actions,
29
- openActions,
30
- item,
31
- positions,
32
- positionOverlay,
33
- setOpenActions,
34
- }: CardActionProps) => {
35
- const overlaypanelRef = useRef<{
36
- setCoords?: (coords: { top: number; left: number }) => void;
37
- }>(null);
38
- const [position, setPosition] = useState<PositionOverlay | undefined>(
39
- positionOverlay
40
- );
41
- const refButton = useRef<HTMLDivElement>(null);
42
- const [openOverlay, setOpenOverlay] = useState(openActions ?? false);
43
- useEffect(() => {
44
- if (openActions) {
45
- setOpenOverlay(openActions);
46
- }
47
- }, [openActions]);
48
-
49
- const handleChangeOverlay = useCallback(
50
- (e: any, openOverlay: boolean) => {
51
- if (actions.length === 0) return;
52
- e.preventDefault();
53
- setPosition("bottomRight");
54
-
55
- if (setOpenActions) {
56
- setOpenActions(openOverlay);
57
- }
58
- },
59
- [setPosition, setOpenActions]
60
- );
61
-
62
- const closeOverlay = useCallback(() => {
63
- setPosition(undefined);
64
- setOpenOverlay(false);
65
- if (setOpenActions) {
66
- setOpenActions(false);
67
- }
68
- }, [setOpenOverlay, setPosition, setOpenActions]);
69
-
70
- const overlayMenu: MenuInterface[] = useMemo(() => {
71
- return actions
72
- ?.filter((a) => a.type === "menu")
73
- .map((a, index) => {
74
- let label = a.label || "";
75
- if (a.setLabel && item) {
76
- label = a.setLabel(item);
77
- }
78
- return {
79
- id: index,
80
- icon: a.icon,
81
- name: a.label,
82
- children: (
83
- <Button
84
- classIcon={a.icon}
85
- key={index}
86
- disabled={item && a.disabled ? a.disabled(item) : false}
87
- sizeIcon={IconSizeEnum.LARGE}
88
- onClick={(e) => {
89
- e.stopPropagation();
90
- closeOverlay();
91
- a.onClick && item && a.onClick(item);
92
- }}
93
- title={label}
94
- />
95
- ),
96
- };
97
- }) as MenuInterface[];
98
- }, [actions]);
99
- return (
100
- <div className="card-actions">
101
- <div
102
- ref={refButton}
103
- className={`card-action ${
104
- actions.filter((a) => a.type === "menu").length ? "visible" : "hidden"
105
- }`}
106
- onClick={(e) => handleChangeOverlay(e, !openOverlay)}
107
- >
108
- <Icon
109
- size={IconSizeEnum.MEDIUM}
110
- classIcon={"bi-three-dots-vertical cursor-pointer"}
111
- />
112
- <Icon
113
- size={IconSizeEnum.MEDIUM}
114
- classIcon={"bi-three-dots cursor-pointer"}
115
- />
116
- </div>
117
-
118
- {openOverlay && refButton.current && (
119
- <OverlayPanel
120
- position={position}
121
- show={openOverlay}
122
- ref={overlaypanelRef}
123
- closeOverlay={closeOverlay}
124
- coordonnees={positions}
125
- referenceElement={refButton.current}
126
- children={
127
- <div>
128
- <Menus className="card-action-menu" items={overlayMenu} />
129
- </div>
130
- }
131
- />
132
- )}
133
- </div>
134
- );
135
- };
1
+ import { useCallback, useEffect, useMemo, useRef, useState } from "react";
2
+ import { Button } from "../../button/Button";
3
+ import { Icon } from "../../icon/Icon";
4
+ import { IconSizeEnum } from "../../icon/iconSize.enum";
5
+ import { MenuInterface } from "../../menus/menu/menu.interface";
6
+ import { Menus } from "../../menus/Menus";
7
+ import { OverlayPanel } from "../../overlayPanel/OverlayPanel";
8
+ import { CardInterface } from "../card.interface";
9
+ import { CardActionInterface } from "../cardAction.interface";
10
+ import "./cardAction.css";
11
+ export type PositionOverlay =
12
+ | "left"
13
+ | "right"
14
+ | "topLeft"
15
+ | "topRight"
16
+ | "bottomLeft"
17
+ | "bottomRight";
18
+ export type CardActionProps = {
19
+ actions: CardActionInterface[];
20
+ item?: CardInterface;
21
+ openActions?: boolean;
22
+ positions?: { top: number; left: number };
23
+ positionOverlay?: PositionOverlay;
24
+ setOpenActions?: (open: boolean) => void;
25
+ };
26
+
27
+ export const CardAction = ({
28
+ actions,
29
+ openActions,
30
+ item,
31
+ positions,
32
+ positionOverlay,
33
+ setOpenActions,
34
+ }: CardActionProps) => {
35
+ const overlaypanelRef = useRef<{
36
+ setCoords?: (coords: { top: number; left: number }) => void;
37
+ }>(null);
38
+ const [position, setPosition] = useState<PositionOverlay | undefined>(
39
+ positionOverlay
40
+ );
41
+ const refButton = useRef<HTMLDivElement>(null);
42
+ const [openOverlay, setOpenOverlay] = useState(openActions ?? false);
43
+ useEffect(() => {
44
+ if (openActions) {
45
+ setOpenOverlay(openActions);
46
+ }
47
+ }, [openActions]);
48
+
49
+ const handleChangeOverlay = useCallback(
50
+ (e: any, openOverlay: boolean) => {
51
+ if (actions.length === 0) return;
52
+ e.preventDefault();
53
+ setPosition("bottomRight");
54
+
55
+ if (setOpenActions) {
56
+ setOpenActions(openOverlay);
57
+ }
58
+ },
59
+ [setPosition, setOpenActions]
60
+ );
61
+
62
+ const closeOverlay = useCallback(() => {
63
+ setPosition(undefined);
64
+ setOpenOverlay(false);
65
+ if (setOpenActions) {
66
+ setOpenActions(false);
67
+ }
68
+ }, [setOpenOverlay, setPosition, setOpenActions]);
69
+
70
+ const overlayMenu: MenuInterface[] = useMemo(() => {
71
+ return actions
72
+ ?.filter((a) => a.type === "menu")
73
+ .map((a, index) => {
74
+ let label = a.label || "";
75
+ if (a.setLabel && item) {
76
+ label = a.setLabel(item);
77
+ }
78
+ return {
79
+ id: index,
80
+ icon: a.icon,
81
+ name: a.label,
82
+ children: (
83
+ <Button
84
+ classIcon={a.icon}
85
+ key={index}
86
+ disabled={item && a.disabled ? a.disabled(item) : false}
87
+ sizeIcon={IconSizeEnum.LARGE}
88
+ onClick={(e) => {
89
+ e.stopPropagation();
90
+ closeOverlay();
91
+ a.onClick && item && a.onClick(item);
92
+ }}
93
+ title={label}
94
+ />
95
+ ),
96
+ };
97
+ }) as MenuInterface[];
98
+ }, [actions]);
99
+ return (
100
+ <div className="card-actions">
101
+ <div
102
+ ref={refButton}
103
+ className={`card-action ${
104
+ actions.filter((a) => a.type === "menu").length ? "visible" : "hidden"
105
+ }`}
106
+ onClick={(e) => handleChangeOverlay(e, !openOverlay)}
107
+ >
108
+ <Icon
109
+ size={IconSizeEnum.MEDIUM}
110
+ classIcon={"bi-three-dots-vertical cursor-pointer"}
111
+ />
112
+ <Icon
113
+ size={IconSizeEnum.MEDIUM}
114
+ classIcon={"bi-three-dots cursor-pointer"}
115
+ />
116
+ </div>
117
+
118
+ {openOverlay && refButton.current && (
119
+ <OverlayPanel
120
+ position={position}
121
+ show={openOverlay}
122
+ ref={overlaypanelRef}
123
+ closeOverlay={closeOverlay}
124
+ coordonnees={positions}
125
+ referenceElement={refButton.current}
126
+ children={
127
+ <div>
128
+ <Menus className="card-action-menu" items={overlayMenu} />
129
+ </div>
130
+ }
131
+ />
132
+ )}
133
+ </div>
134
+ );
135
+ };
@@ -1,10 +1,10 @@
1
- .card-action-menu {
2
- min-width: 150px;
3
- max-width: 300px;
4
- padding: 0.25rem;
5
-
6
- button {
7
- font-size: 0.85rem;
8
- padding: 1rem 0rem !important;
9
- }
10
- }
1
+ .card-action-menu {
2
+ min-width: 150px;
3
+ max-width: 300px;
4
+ padding: 0.25rem;
5
+
6
+ button {
7
+ font-size: 0.85rem;
8
+ padding: 1rem 0rem !important;
9
+ }
10
+ }
@@ -1,10 +1,10 @@
1
- import { CardInterface } from "./card.interface";
2
-
3
- export interface CardActionInterface {
4
- icon: string;
5
- label?: string;
6
- disabled?: (item: CardInterface) => boolean;
7
- onClick: (item: CardInterface) => void;
8
- setLabel?: (item: CardInterface) => string;
9
- type?: "menu" | "link";
10
- }
1
+ import { CardInterface } from "./card.interface";
2
+
3
+ export interface CardActionInterface {
4
+ icon: string;
5
+ label?: string;
6
+ disabled?: (item: CardInterface) => boolean;
7
+ onClick: (item: CardInterface) => void;
8
+ setLabel?: (item: CardInterface) => string;
9
+ type?: "menu" | "link";
10
+ }
@@ -1,30 +1,30 @@
1
- import { useEffect, useRef, useState } from "react";
2
-
3
- // Hook personnalisé pour détecter les clics en dehors et le survol
4
- export const useCardInteractions = (callback: () => void) => {
5
- const ref = useRef<HTMLDivElement>(null);
6
- const [isHovered, setIsHovered] = useState(false);
7
-
8
- useEffect(() => {
9
- const handleClickOutside = (event: MouseEvent) => {
10
- if (ref.current && !ref.current.contains(event.target as Node)) {
11
- callback();
12
- }
13
- };
14
-
15
- document.addEventListener("mousedown", handleClickOutside);
16
- return () => {
17
- document.removeEventListener("mousedown", handleClickOutside);
18
- };
19
- }, [callback]);
20
-
21
- const mouseHandlers = {
22
- onMouseEnter: () => setIsHovered(true),
23
- onMouseLeave: () => {
24
- setIsHovered(false);
25
- callback(); // Déclenche le callback quand la souris quitte la carte
26
- },
27
- };
28
-
29
- return { ref, isHovered, mouseHandlers };
30
- };
1
+ import { useEffect, useRef, useState } from "react";
2
+
3
+ // Hook personnalisé pour détecter les clics en dehors et le survol
4
+ export const useCardInteractions = (callback: () => void) => {
5
+ const ref = useRef<HTMLDivElement>(null);
6
+ const [isHovered, setIsHovered] = useState(false);
7
+
8
+ useEffect(() => {
9
+ const handleClickOutside = (event: MouseEvent) => {
10
+ if (ref.current && !ref.current.contains(event.target as Node)) {
11
+ callback();
12
+ }
13
+ };
14
+
15
+ document.addEventListener("mousedown", handleClickOutside);
16
+ return () => {
17
+ document.removeEventListener("mousedown", handleClickOutside);
18
+ };
19
+ }, [callback]);
20
+
21
+ const mouseHandlers = {
22
+ onMouseEnter: () => setIsHovered(true),
23
+ onMouseLeave: () => {
24
+ setIsHovered(false);
25
+ callback(); // Déclenche le callback quand la souris quitte la carte
26
+ },
27
+ };
28
+
29
+ return { ref, isHovered, mouseHandlers };
30
+ };