kelt-ui-kit-react 1.2.0 → 1.2.1

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 +2 -3
  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 +5 -6
  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 +8 -9
  9. package/dist/badge/Badge.d.ts +8 -9
  10. package/dist/badge/Badge.view.d.ts +1 -1
  11. package/dist/button/Button.d.ts +1 -2
  12. package/dist/button/Button.view.d.ts +1 -1
  13. package/dist/button/button.interface.d.ts +17 -18
  14. package/dist/button/buttonActions/ButtonActions.d.ts +10 -11
  15. package/dist/card/Card.d.ts +12 -13
  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 +13 -14
  19. package/dist/card/cardAction.interface.d.ts +8 -9
  20. package/dist/card/hook/useCardInteractions.d.ts +8 -8
  21. package/dist/carousel/Carousel.d.ts +14 -15
  22. package/dist/carousel/Carousel.view.d.ts +1 -1
  23. package/dist/damier/Damier.d.ts +9 -10
  24. package/dist/damier/Damier.view.d.ts +1 -1
  25. package/dist/damier/damierCell/DamierCell.d.ts +6 -7
  26. package/dist/damier/damierCell/damierCell.interface.d.ts +6 -6
  27. package/dist/dataTable/DataTable.d.ts +15 -16
  28. package/dist/dataTable/DataTable.view.d.ts +1 -1
  29. package/dist/dataTable/dataTable.interface.d.ts +30 -31
  30. package/dist/datePicker/DatePicker.d.ts +7 -8
  31. package/dist/datePicker/DatePicker.view.d.ts +1 -1
  32. package/dist/expands/Expands.d.ts +9 -10
  33. package/dist/expands/Expands.view.d.ts +1 -1
  34. package/dist/expands/expand/expand.d.ts +8 -9
  35. package/dist/expands/expand/expand.interface.d.ts +9 -9
  36. package/dist/filAriane/FilAriane.d.ts +8 -9
  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 +23 -24
  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 +29 -30
  43. package/dist/form/textArea/TextArea.d.ts +12 -13
  44. package/dist/form/textArea/TextArea.view.d.ts +1 -1
  45. package/dist/grid/Grid.d.ts +7 -8
  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 +5 -6
  50. package/dist/grid/grid.interface.d.ts +8 -8
  51. package/dist/grid/row/Row.d.ts +7 -8
  52. package/dist/header/Header.d.ts +1 -2
  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 +1 -2
  57. package/dist/icon/Icons.view.d.ts +1 -1
  58. package/dist/icon/icon.interface.d.ts +4 -5
  59. package/dist/icon/iconSize.enum.d.ts +7 -7
  60. package/dist/index.d.ts +31 -32
  61. package/dist/index.html +18 -18
  62. package/dist/index.js +1 -1
  63. package/dist/loader/Loader.d.ts +7 -8
  64. package/dist/loader/Loader.view.d.ts +1 -1
  65. package/dist/main.d.ts +0 -1
  66. package/dist/manifest.json +25 -25
  67. package/dist/menus/Menus.d.ts +5 -6
  68. package/dist/menus/Menus.view.d.ts +1 -1
  69. package/dist/menus/menu/Menu.d.ts +6 -7
  70. package/dist/menus/menu/menu.interface.d.ts +10 -10
  71. package/dist/modal/Modal.d.ts +12 -13
  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 +18 -19
  75. package/dist/overlayPanel/OverlayPanel.view.d.ts +1 -1
  76. package/dist/overlayPanel/overlay.context.d.ts +9 -10
  77. package/dist/overlayPanel/overlayPanelStyled/OverlayPanelStyled.d.ts +7 -7
  78. package/dist/quantity/Quantity.d.ts +10 -11
  79. package/dist/robots.txt +3 -3
  80. package/dist/search/Search.d.ts +21 -22
  81. package/dist/search/Search.view.d.ts +1 -1
  82. package/dist/select/Select.d.ts +13 -14
  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 +12 -13
  86. package/dist/sidebar/Sidebar.view.d.ts +1 -1
  87. package/dist/sidebarData/SidebarData.d.ts +6 -7
  88. package/dist/sidebarData/SidebarData.view.d.ts +1 -1
  89. package/dist/style.css +1 -1
  90. package/dist/toaster/Toaster.d.ts +1 -2
  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 +202 -202
  132. package/src/dataTable/DataTable.view.tsx +59 -59
  133. package/src/dataTable/dataTable.css +14 -14
  134. package/src/dataTable/dataTable.interface.ts +29 -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 +67 -65
  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/index.ts CHANGED
@@ -1,33 +1,33 @@
1
- import "bootstrap-icons/font/bootstrap-icons.css";
2
- import "./index.css";
3
- export { useIsMobile } from "./_core/hooks/useIsMobile";
4
- export { ButtonAction } from "./action/ButtonAction";
5
- export { Badge } from "./badge/Badge";
6
- export { Button } from "./button/Button";
7
- export { ButtonActions } from "./button/buttonActions/ButtonActions";
8
- export { Card } from "./card/Card";
9
- export { Carousel } from "./carousel/Carousel";
10
- export { Damier } from "./damier/Damier";
11
- export { DataTable } from "./dataTable/DataTable";
12
- export { DatePicker } from "./datePicker/DatePicker";
13
- export { Expands } from "./expands/Expands";
14
- export { FilAriane } from "./filAriane/FilAriane";
15
- export { DynamicForm } from "./form/Form";
16
- export { TypeInputEnum } from "./form/form.enum";
17
- export { TextArea } from "./form/textArea/TextArea";
18
- export { Grid } from "./grid/Grid";
19
- export { Header } from "./header/Header";
20
- export { Icon } from "./icon/Icon";
21
- export { IconSizeEnum } from "./icon/iconSize.enum";
22
- export { Loader } from "./loader/Loader";
23
- export { Menus } from "./menus/Menus";
24
- export { Modal } from "./modal/Modal";
25
- export { OverlayProvider } from "./overlayPanel/overlay.context";
26
- export { OverlayPanel } from "./overlayPanel/OverlayPanel";
27
- export { Quantity } from "./quantity/Quantity";
28
- export { Search } from "./search/Search";
29
- export { Select } from "./select/Select";
30
- export { Sidebar } from "./sidebar/Sidebar";
31
- export { SidebarData } from "./sidebarData/SidebarData";
32
- export { useToasterStore } from "./toaster/store/useToasterStore";
33
- export { Toaster } from "./toaster/Toaster";
1
+ import "bootstrap-icons/font/bootstrap-icons.css";
2
+ import "./index.css";
3
+ export { useIsMobile } from "./_core/hooks/useIsMobile";
4
+ export { ButtonAction } from "./action/ButtonAction";
5
+ export { Badge } from "./badge/Badge";
6
+ export { Button } from "./button/Button";
7
+ export { ButtonActions } from "./button/buttonActions/ButtonActions";
8
+ export { Card } from "./card/Card";
9
+ export { Carousel } from "./carousel/Carousel";
10
+ export { Damier } from "./damier/Damier";
11
+ export { DataTable } from "./dataTable/DataTable";
12
+ export { DatePicker } from "./datePicker/DatePicker";
13
+ export { Expands } from "./expands/Expands";
14
+ export { FilAriane } from "./filAriane/FilAriane";
15
+ export { DynamicForm } from "./form/Form";
16
+ export { TypeInputEnum } from "./form/form.enum";
17
+ export { TextArea } from "./form/textArea/TextArea";
18
+ export { Grid } from "./grid/Grid";
19
+ export { Header } from "./header/Header";
20
+ export { Icon } from "./icon/Icon";
21
+ export { IconSizeEnum } from "./icon/iconSize.enum";
22
+ export { Loader } from "./loader/Loader";
23
+ export { Menus } from "./menus/Menus";
24
+ export { Modal } from "./modal/Modal";
25
+ export { OverlayProvider } from "./overlayPanel/overlay.context";
26
+ export { OverlayPanel } from "./overlayPanel/OverlayPanel";
27
+ export { Quantity } from "./quantity/Quantity";
28
+ export { Search } from "./search/Search";
29
+ export { Select } from "./select/Select";
30
+ export { Sidebar } from "./sidebar/Sidebar";
31
+ export { SidebarData } from "./sidebarData/SidebarData";
32
+ export { useToasterStore } from "./toaster/store/useToasterStore";
33
+ export { Toaster } from "./toaster/Toaster";
@@ -1,37 +1,37 @@
1
- import { createPortal } from "react-dom";
2
- import { IconSizeEnum } from "../icon/iconSize.enum";
3
- import "./loader.css";
4
- export type LoaderProps = {
5
- display: boolean;
6
- message?: string;
7
- size?: IconSizeEnum;
8
- full?: true;
9
- };
10
- export const Loader = ({ display, full, message }: LoaderProps) => (
11
- <>
12
- {display && !full && (
13
- <div className={`d-flex flex-column align-items-center`}>
14
- {message && <span className="mb-3">{message}</span>}
15
- <div className="position-relative">
16
- <span className="loader"></span>
17
- </div>
18
- </div>
19
- )}
20
-
21
- {display &&
22
- full &&
23
- createPortal(
24
- <div className="loader-overlay">
25
- <div>
26
- <div className={`d-flex flex-column align-items-center`}>
27
- {message && <span className="mb-3">{message}</span>}
28
- <div className="position-relative">
29
- <span className="loader"></span>
30
- </div>
31
- </div>
32
- </div>
33
- </div>,
34
- document.body
35
- )}
36
- </>
37
- );
1
+ import { createPortal } from "react-dom";
2
+ import { IconSizeEnum } from "../icon/iconSize.enum";
3
+ import "./loader.css";
4
+ export type LoaderProps = {
5
+ display: boolean;
6
+ message?: string;
7
+ size?: IconSizeEnum;
8
+ full?: true;
9
+ };
10
+ export const Loader = ({ display, full, message }: LoaderProps) => (
11
+ <>
12
+ {display && !full && (
13
+ <div className={`d-flex flex-column align-items-center`}>
14
+ {message && <span className="mb-3">{message}</span>}
15
+ <div className="position-relative">
16
+ <span className="loader"></span>
17
+ </div>
18
+ </div>
19
+ )}
20
+
21
+ {display &&
22
+ full &&
23
+ createPortal(
24
+ <div className="loader-overlay">
25
+ <div>
26
+ <div className={`d-flex flex-column align-items-center`}>
27
+ {message && <span className="mb-3">{message}</span>}
28
+ <div className="position-relative">
29
+ <span className="loader"></span>
30
+ </div>
31
+ </div>
32
+ </div>
33
+ </div>,
34
+ document.body
35
+ )}
36
+ </>
37
+ );
@@ -1,20 +1,20 @@
1
- import { useState } from "react";
2
- import { Button } from "../button/Button";
3
- import { IconSizeEnum } from "../icon/iconSize.enum";
4
- import { Loader } from "./Loader";
5
-
6
- export const LoaderView = () => {
7
- const [display, setDisplay] = useState(false);
8
-
9
- return (
10
- <>
11
- <Button title={"loader-overlay"} onClick={() => setDisplay(!display)} />
12
- <Loader
13
- size={IconSizeEnum.EXTRA_LARGE}
14
- display={!display}
15
- message={"Loading..."}
16
- />
17
- <Loader display={display} message={"Loading..."} full={true} />
18
- </>
19
- );
20
- };
1
+ import { useState } from "react";
2
+ import { Button } from "../button/Button";
3
+ import { IconSizeEnum } from "../icon/iconSize.enum";
4
+ import { Loader } from "./Loader";
5
+
6
+ export const LoaderView = () => {
7
+ const [display, setDisplay] = useState(false);
8
+
9
+ return (
10
+ <>
11
+ <Button title={"loader-overlay"} onClick={() => setDisplay(!display)} />
12
+ <Loader
13
+ size={IconSizeEnum.EXTRA_LARGE}
14
+ display={!display}
15
+ message={"Loading..."}
16
+ />
17
+ <Loader display={display} message={"Loading..."} full={true} />
18
+ </>
19
+ );
20
+ };
@@ -1,30 +1,30 @@
1
- .loader {
2
- width: 48px;
3
- height: 48px;
4
- border-radius: 50%;
5
- display: inline-block;
6
- border-top: 3px solid var(--primary-color);
7
- border-right: 3px solid transparent;
8
- -webkit-animation: rotation 1s linear infinite;
9
- animation: rotation 1s linear infinite;
10
- }
11
- .loader-overlay {
12
- position: fixed;
13
- top: 0;
14
- left: 0;
15
- right: 0;
16
- bottom: 0;
17
- background-color: rgba(0, 0, 0, 0.5);
18
- display: flex;
19
- justify-content: center;
20
- align-items: center;
21
- z-index: 1000;
22
- }
23
- @keyframes rotation {
24
- 0% {
25
- transform: rotate(0deg);
26
- }
27
- 100% {
28
- transform: rotate(360deg);
29
- }
30
- }
1
+ .loader {
2
+ width: 48px;
3
+ height: 48px;
4
+ border-radius: 50%;
5
+ display: inline-block;
6
+ border-top: 3px solid var(--primary-color);
7
+ border-right: 3px solid transparent;
8
+ -webkit-animation: rotation 1s linear infinite;
9
+ animation: rotation 1s linear infinite;
10
+ }
11
+ .loader-overlay {
12
+ position: fixed;
13
+ top: 0;
14
+ left: 0;
15
+ right: 0;
16
+ bottom: 0;
17
+ background-color: rgba(0, 0, 0, 0.5);
18
+ display: flex;
19
+ justify-content: center;
20
+ align-items: center;
21
+ z-index: 1000;
22
+ }
23
+ @keyframes rotation {
24
+ 0% {
25
+ transform: rotate(0deg);
26
+ }
27
+ 100% {
28
+ transform: rotate(360deg);
29
+ }
30
+ }
package/src/main.tsx CHANGED
@@ -1,10 +1,10 @@
1
- import "bootstrap-icons/font/bootstrap-icons.css";
2
- import React from "react";
3
- import ReactDOM from "react-dom/client";
4
- import App from "./App";
5
- import "./index.css";
6
- ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
7
- <React.StrictMode>
8
- <App />
9
- </React.StrictMode>
10
- );
1
+ import "bootstrap-icons/font/bootstrap-icons.css";
2
+ import React from "react";
3
+ import ReactDOM from "react-dom/client";
4
+ import App from "./App";
5
+ import "./index.css";
6
+ ReactDOM.createRoot(document.getElementById("root") as HTMLElement).render(
7
+ <React.StrictMode>
8
+ <App />
9
+ </React.StrictMode>
10
+ );
@@ -1,42 +1,42 @@
1
- import { useCallback, useState } from "react";
2
- import { Menu } from "./menu/Menu";
3
- import { MenuInterface } from "./menu/menu.interface";
4
- import "./menus.css";
5
-
6
- export type ExpandProps = {
7
- items: MenuInterface[];
8
- className?: string;
9
- };
10
-
11
- export const Menus = (props: ExpandProps) => {
12
- const [currentItem, setCurrentItem] = useState<MenuInterface | null>(null);
13
-
14
- const onChange = useCallback((item: MenuInterface) => {
15
- setCurrentItem(item);
16
- }, []);
17
-
18
- const renderMenuItems = (items: MenuInterface[]) => (
19
- <ul>
20
- {items.map((item) => (
21
- <li key={item.id}>
22
- <Menu
23
- item={item}
24
- onChange={onChange}
25
- active={currentItem?.id === item.id}
26
- />
27
- {item.subMenu && item.subMenu.length > 0 && (
28
- <div className="ml-3 mt-1 submenu">
29
- {renderMenuItems(item.subMenu)}
30
- </div>
31
- )}
32
- </li>
33
- ))}
34
- </ul>
35
- );
36
-
37
- return (
38
- <div className={`menu ${props.className || ""}`}>
39
- {renderMenuItems(props.items)}
40
- </div>
41
- );
42
- };
1
+ import { useCallback, useState } from "react";
2
+ import { Menu } from "./menu/Menu";
3
+ import { MenuInterface } from "./menu/menu.interface";
4
+ import "./menus.css";
5
+
6
+ export type ExpandProps = {
7
+ items: MenuInterface[];
8
+ className?: string;
9
+ };
10
+
11
+ export const Menus = (props: ExpandProps) => {
12
+ const [currentItem, setCurrentItem] = useState<MenuInterface | null>(null);
13
+
14
+ const onChange = useCallback((item: MenuInterface) => {
15
+ setCurrentItem(item);
16
+ }, []);
17
+
18
+ const renderMenuItems = (items: MenuInterface[]) => (
19
+ <ul>
20
+ {items.map((item) => (
21
+ <li key={item.id}>
22
+ <Menu
23
+ item={item}
24
+ onChange={onChange}
25
+ active={currentItem?.id === item.id}
26
+ />
27
+ {item.subMenu && item.subMenu.length > 0 && (
28
+ <div className="ml-3 mt-1 submenu">
29
+ {renderMenuItems(item.subMenu)}
30
+ </div>
31
+ )}
32
+ </li>
33
+ ))}
34
+ </ul>
35
+ );
36
+
37
+ return (
38
+ <div className={`menu ${props.className || ""}`}>
39
+ {renderMenuItems(props.items)}
40
+ </div>
41
+ );
42
+ };
@@ -1,39 +1,39 @@
1
- import { NavLink } from "react-router-dom";
2
- import { MenuInterface } from "./menu/menu.interface";
3
- import { Menus } from "./Menus";
4
- import { Button } from "../button/Button";
5
- import { useCallback } from "react";
6
-
7
- export const MenusView = (): JSX.Element => {
8
- const buttonAction = useCallback((e: React.MouseEvent) => {
9
- console.log("Button clicked", e);
10
- }, []);
11
- const mockItems: MenuInterface[] = [
12
- {
13
- id: 1,
14
- name: "Menu 1",
15
- children: "Menu 1",
16
- active: true,
17
- subMenu : [{
18
- id: 1,
19
- name: "Menu 1",
20
- children: <NavLink to="/expands">Menu 1</NavLink>,
21
- active: true,
22
- }]
23
- },
24
- {
25
- id: 2,
26
- name: "Menu 2",
27
- children: <Button onClick={buttonAction} title={"deconnexion"} />,
28
- active: false,
29
- },
30
- {
31
- id: 3,
32
- children: <NavLink to="/expands">Menu 1</NavLink>,
33
- name: "Menu 3",
34
- active: false,
35
- },
36
- ];
37
-
38
- return <Menus items={mockItems} />;
39
- };
1
+ import { NavLink } from "react-router-dom";
2
+ import { MenuInterface } from "./menu/menu.interface";
3
+ import { Menus } from "./Menus";
4
+ import { Button } from "../button/Button";
5
+ import { useCallback } from "react";
6
+
7
+ export const MenusView = (): JSX.Element => {
8
+ const buttonAction = useCallback((e: React.MouseEvent) => {
9
+ console.log("Button clicked", e);
10
+ }, []);
11
+ const mockItems: MenuInterface[] = [
12
+ {
13
+ id: 1,
14
+ name: "Menu 1",
15
+ children: "Menu 1",
16
+ active: true,
17
+ subMenu : [{
18
+ id: 1,
19
+ name: "Menu 1",
20
+ children: <NavLink to="/expands">Menu 1</NavLink>,
21
+ active: true,
22
+ }]
23
+ },
24
+ {
25
+ id: 2,
26
+ name: "Menu 2",
27
+ children: <Button onClick={buttonAction} title={"deconnexion"} />,
28
+ active: false,
29
+ },
30
+ {
31
+ id: 3,
32
+ children: <NavLink to="/expands">Menu 1</NavLink>,
33
+ name: "Menu 3",
34
+ active: false,
35
+ },
36
+ ];
37
+
38
+ return <Menus items={mockItems} />;
39
+ };
@@ -1,17 +1,17 @@
1
- import { MenuInterface } from "./menu.interface";
2
-
3
- export type MenuProps = {
4
- active: boolean;
5
- item: MenuInterface;
6
- onChange: (item: MenuInterface) => void;
7
- };
8
- export const Menu = (props: MenuProps): JSX.Element => {
9
- return (
10
- <div
11
- onClick={() => props.onChange(props.item)}
12
- className={props.active ? "expand expand--active" : "expand"}
13
- >
14
- {props.item.children}
15
- </div>
16
- );
17
- };
1
+ import { MenuInterface } from "./menu.interface";
2
+
3
+ export type MenuProps = {
4
+ active: boolean;
5
+ item: MenuInterface;
6
+ onChange: (item: MenuInterface) => void;
7
+ };
8
+ export const Menu = (props: MenuProps): JSX.Element => {
9
+ return (
10
+ <div
11
+ onClick={() => props.onChange(props.item)}
12
+ className={props.active ? "expand expand--active" : "expand"}
13
+ >
14
+ {props.item.children}
15
+ </div>
16
+ );
17
+ };
@@ -1,9 +1,9 @@
1
- export interface MenuInterface {
2
- id?: number;
3
- name: string;
4
- icon?: string;
5
- active?: boolean;
6
- disabled?: boolean;
7
- children?: React.ReactNode;
8
- subMenu?: MenuInterface[];
9
- }
1
+ export interface MenuInterface {
2
+ id?: number;
3
+ name: string;
4
+ icon?: string;
5
+ active?: boolean;
6
+ disabled?: boolean;
7
+ children?: React.ReactNode;
8
+ subMenu?: MenuInterface[];
9
+ }
@@ -1,47 +1,47 @@
1
- .menu {
2
- width: 200px;
3
- padding: 2rem;
4
- .submenu{
5
- li{
6
- a{
7
- font-size : 0.9rem;
8
- }
9
- }
10
- }
11
- ul {
12
- list-style: none;
13
- padding: 0;
14
- margin: 0;
15
- display: flex;
16
- flex-direction: column;
17
- flex-wrap: wrap;
18
- justify-content: center;
19
-
20
- li {
21
- button {
22
- background: transparent;
23
- color: #000;
24
- font-weight: 300;
25
- padding: 0px;
26
- border-radius: 0px;
27
- min-width: auto;
28
- margin: 0;
29
- justify-content: normal;
30
-
31
- &:hover {
32
- color: #f00;
33
- }
34
- }
35
-
36
- a {
37
- text-decoration: none;
38
- color: #000;
39
- font-weight: 300;
40
-
41
- &:hover {
42
- color: #f00;
43
- }
44
- }
45
- }
46
- }
47
- }
1
+ .menu {
2
+ width: 200px;
3
+ padding: 2rem;
4
+ .submenu{
5
+ li{
6
+ a{
7
+ font-size : 0.9rem;
8
+ }
9
+ }
10
+ }
11
+ ul {
12
+ list-style: none;
13
+ padding: 0;
14
+ margin: 0;
15
+ display: flex;
16
+ flex-direction: column;
17
+ flex-wrap: wrap;
18
+ justify-content: center;
19
+
20
+ li {
21
+ button {
22
+ background: transparent;
23
+ color: #000;
24
+ font-weight: 300;
25
+ padding: 0px;
26
+ border-radius: 0px;
27
+ min-width: auto;
28
+ margin: 0;
29
+ justify-content: normal;
30
+
31
+ &:hover {
32
+ color: #f00;
33
+ }
34
+ }
35
+
36
+ a {
37
+ text-decoration: none;
38
+ color: #000;
39
+ font-weight: 300;
40
+
41
+ &:hover {
42
+ color: #f00;
43
+ }
44
+ }
45
+ }
46
+ }
47
+ }