kelt-ui-kit-react 1.2.4 → 1.2.5

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 +31 -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 +1 -1
  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 +241 -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 +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 +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
@@ -1,44 +1,44 @@
1
- .carousel {
2
- display: flex;
3
- align-items: center;
4
- .carousel-container {
5
- position: relative;
6
- width: 100%;
7
- overflow: hidden;
8
- }
9
-
10
- .carousel-slides-wrapper {
11
- display: flex;
12
- transition: transform 0.5s ease-in-out;
13
- }
14
-
15
- .carousel-slide {
16
- min-width: 100%;
17
- box-sizing: border-box;
18
- }
19
-
20
- .carousel-control {
21
- border-radius: 50%;
22
- border: 1px solid #696868;
23
- width: 34px;
24
- display: flex;
25
- height: 30px;
26
- align-items: center;
27
- cursor: pointer;
28
- justify-content: center;
29
- &.disabled {
30
- opacity: 0.5;
31
- pointer-events: none;
32
- }
33
- .bi {
34
- color: #696868;
35
- font-size: 1rem;
36
- }
37
- &.prev {
38
- margin-right: 0.5rem;
39
- }
40
- &.next {
41
- margin-left: 0.5rem;
42
- }
43
- }
44
- }
1
+ .carousel {
2
+ display: flex;
3
+ align-items: center;
4
+ .carousel-container {
5
+ position: relative;
6
+ width: 100%;
7
+ overflow: hidden;
8
+ }
9
+
10
+ .carousel-slides-wrapper {
11
+ display: flex;
12
+ transition: transform 0.5s ease-in-out;
13
+ }
14
+
15
+ .carousel-slide {
16
+ min-width: 100%;
17
+ box-sizing: border-box;
18
+ }
19
+
20
+ .carousel-control {
21
+ border-radius: 50%;
22
+ border: 1px solid #696868;
23
+ width: 34px;
24
+ display: flex;
25
+ height: 30px;
26
+ align-items: center;
27
+ cursor: pointer;
28
+ justify-content: center;
29
+ &.disabled {
30
+ opacity: 0.5;
31
+ pointer-events: none;
32
+ }
33
+ .bi {
34
+ color: #696868;
35
+ font-size: 1rem;
36
+ }
37
+ &.prev {
38
+ margin-right: 0.5rem;
39
+ }
40
+ &.next {
41
+ margin-left: 0.5rem;
42
+ }
43
+ }
44
+ }
@@ -1,115 +1,115 @@
1
- import React, { ReactNode, useCallback, useEffect, useState } from "react";
2
- import { Icon } from "../icon/Icon";
3
- import "./Carousel.css";
4
- interface Breakpoints {
5
- sm?: number;
6
- md?: number;
7
- lg?: number;
8
- xl?: number;
9
- }
10
- interface CarouselProps {
11
- children: ReactNode[];
12
- showControls?: boolean; // Afficher les boutons précédent/suivant
13
- itemsToScroll?: number; // Nombre d'éléments à défiler par mouvement
14
- breakpoints?: Breakpoints; // Nombre d'éléments à afficher en fonction de la largeur de l'écran
15
- }
16
-
17
- export const Carousel: React.FC<CarouselProps> = ({
18
- children,
19
- showControls = true,
20
- itemsToScroll = 1,
21
- breakpoints = {
22
- sm: 2,
23
- md: 3,
24
- lg: 4,
25
- xl: 5,
26
- },
27
- }) => {
28
- const [currentIndex, setCurrentIndex] = useState(0);
29
- const totalItems = children.length;
30
- const [itemsToShow, setItemsToShow] = useState(1);
31
- useEffect(() => {
32
- const updateItemsToShow = () => {
33
- const width = window.innerWidth;
34
- if (breakpoints.xl && width >= 1200) {
35
- return setItemsToShow(breakpoints.xl);
36
- }
37
- if (breakpoints.lg && width >= 992) {
38
- return setItemsToShow(breakpoints.lg);
39
- }
40
- if (breakpoints.md && width >= 768) {
41
- return setItemsToShow(breakpoints.md);
42
- }
43
- if (breakpoints.sm && width >= 576) {
44
- return setItemsToShow(breakpoints.sm);
45
- }
46
- };
47
-
48
- updateItemsToShow();
49
- window.addEventListener("resize", updateItemsToShow);
50
- return () => window.removeEventListener("resize", updateItemsToShow);
51
- }, [breakpoints]);
52
- const nextSlide = useCallback(
53
- (e: React.MouseEvent) => {
54
- e.preventDefault();
55
- setCurrentIndex((prevIndex) =>
56
- Math.min(prevIndex + itemsToScroll, totalItems - itemsToShow)
57
- );
58
- },
59
- [setCurrentIndex]
60
- );
61
-
62
- const prevSlide = useCallback(
63
- (e: React.MouseEvent) => {
64
- e.preventDefault();
65
- setCurrentIndex((prevIndex) => Math.max(prevIndex - itemsToScroll, 0));
66
- },
67
- [setCurrentIndex]
68
- );
69
- const isNextDisabled =
70
- currentIndex + itemsToScroll >= totalItems - itemsToShow + 1;
71
- const allItemsVisible = totalItems <= itemsToShow;
72
- const isPrevDisabled = currentIndex <= 0;
73
- return (
74
- <div className="carousel">
75
- {showControls && !allItemsVisible && (
76
- <div
77
- className={`carousel-control prev ${isPrevDisabled && `disabled`}`}
78
- onClick={prevSlide}
79
- >
80
- <Icon classIcon="bi-chevron-left" />
81
- </div>
82
- )}
83
- <div className="carousel-container">
84
- <div
85
- className="carousel-slides-wrapper"
86
- style={{
87
- display: "flex",
88
- transform: `translateX(-${(currentIndex * 100) / itemsToShow}%)`,
89
- transition: "transform 0.5s ease-in-out",
90
- }}
91
- >
92
- {React.Children.map(children, (child) => (
93
- <div
94
- className="carousel-slide"
95
- style={{
96
- minWidth: `${100 / itemsToShow}%`,
97
- boxSizing: "border-box",
98
- }}
99
- >
100
- {child}
101
- </div>
102
- ))}
103
- </div>
104
- </div>
105
- {showControls && !allItemsVisible && (
106
- <div
107
- className={`carousel-control next ${isNextDisabled && `disabled`}`}
108
- onClick={nextSlide}
109
- >
110
- <Icon classIcon="bi-chevron-right" />
111
- </div>
112
- )}
113
- </div>
114
- );
115
- };
1
+ import React, { ReactNode, useCallback, useEffect, useState } from "react";
2
+ import { Icon } from "../icon/Icon";
3
+ import "./Carousel.css";
4
+ interface Breakpoints {
5
+ sm?: number;
6
+ md?: number;
7
+ lg?: number;
8
+ xl?: number;
9
+ }
10
+ interface CarouselProps {
11
+ children: ReactNode[];
12
+ showControls?: boolean; // Afficher les boutons précédent/suivant
13
+ itemsToScroll?: number; // Nombre d'éléments à défiler par mouvement
14
+ breakpoints?: Breakpoints; // Nombre d'éléments à afficher en fonction de la largeur de l'écran
15
+ }
16
+
17
+ export const Carousel: React.FC<CarouselProps> = ({
18
+ children,
19
+ showControls = true,
20
+ itemsToScroll = 1,
21
+ breakpoints = {
22
+ sm: 2,
23
+ md: 3,
24
+ lg: 4,
25
+ xl: 5,
26
+ },
27
+ }) => {
28
+ const [currentIndex, setCurrentIndex] = useState(0);
29
+ const totalItems = children.length;
30
+ const [itemsToShow, setItemsToShow] = useState(1);
31
+ useEffect(() => {
32
+ const updateItemsToShow = () => {
33
+ const width = window.innerWidth;
34
+ if (breakpoints.xl && width >= 1200) {
35
+ return setItemsToShow(breakpoints.xl);
36
+ }
37
+ if (breakpoints.lg && width >= 992) {
38
+ return setItemsToShow(breakpoints.lg);
39
+ }
40
+ if (breakpoints.md && width >= 768) {
41
+ return setItemsToShow(breakpoints.md);
42
+ }
43
+ if (breakpoints.sm && width >= 576) {
44
+ return setItemsToShow(breakpoints.sm);
45
+ }
46
+ };
47
+
48
+ updateItemsToShow();
49
+ window.addEventListener("resize", updateItemsToShow);
50
+ return () => window.removeEventListener("resize", updateItemsToShow);
51
+ }, [breakpoints]);
52
+ const nextSlide = useCallback(
53
+ (e: React.MouseEvent) => {
54
+ e.preventDefault();
55
+ setCurrentIndex((prevIndex) =>
56
+ Math.min(prevIndex + itemsToScroll, totalItems - itemsToShow)
57
+ );
58
+ },
59
+ [setCurrentIndex]
60
+ );
61
+
62
+ const prevSlide = useCallback(
63
+ (e: React.MouseEvent) => {
64
+ e.preventDefault();
65
+ setCurrentIndex((prevIndex) => Math.max(prevIndex - itemsToScroll, 0));
66
+ },
67
+ [setCurrentIndex]
68
+ );
69
+ const isNextDisabled =
70
+ currentIndex + itemsToScroll >= totalItems - itemsToShow + 1;
71
+ const allItemsVisible = totalItems <= itemsToShow;
72
+ const isPrevDisabled = currentIndex <= 0;
73
+ return (
74
+ <div className="carousel">
75
+ {showControls && !allItemsVisible && (
76
+ <div
77
+ className={`carousel-control prev ${isPrevDisabled && `disabled`}`}
78
+ onClick={prevSlide}
79
+ >
80
+ <Icon classIcon="bi-chevron-left" />
81
+ </div>
82
+ )}
83
+ <div className="carousel-container">
84
+ <div
85
+ className="carousel-slides-wrapper"
86
+ style={{
87
+ display: "flex",
88
+ transform: `translateX(-${(currentIndex * 100) / itemsToShow}%)`,
89
+ transition: "transform 0.5s ease-in-out",
90
+ }}
91
+ >
92
+ {React.Children.map(children, (child) => (
93
+ <div
94
+ className="carousel-slide"
95
+ style={{
96
+ minWidth: `${100 / itemsToShow}%`,
97
+ boxSizing: "border-box",
98
+ }}
99
+ >
100
+ {child}
101
+ </div>
102
+ ))}
103
+ </div>
104
+ </div>
105
+ {showControls && !allItemsVisible && (
106
+ <div
107
+ className={`carousel-control next ${isNextDisabled && `disabled`}`}
108
+ onClick={nextSlide}
109
+ >
110
+ <Icon classIcon="bi-chevron-right" />
111
+ </div>
112
+ )}
113
+ </div>
114
+ );
115
+ };
@@ -1,13 +1,13 @@
1
- import { Carousel } from "./Carousel";
2
-
3
- export const CarouselView = () => {
4
- return (
5
- <Carousel showControls>
6
- <div style={{ background: "red" }}>Slide 1</div>
7
- <div style={{ background: "blue" }}>Slide 2</div>
8
- <div style={{ background: "green" }}>Slide 3</div>
9
- <div style={{ background: "orange" }}>Slide 4</div>
10
- <div style={{ background: "purple" }}>Slide 5</div>
11
- </Carousel>
12
- );
13
- };
1
+ import { Carousel } from "./Carousel";
2
+
3
+ export const CarouselView = () => {
4
+ return (
5
+ <Carousel showControls>
6
+ <div style={{ background: "red" }}>Slide 1</div>
7
+ <div style={{ background: "blue" }}>Slide 2</div>
8
+ <div style={{ background: "green" }}>Slide 3</div>
9
+ <div style={{ background: "orange" }}>Slide 4</div>
10
+ <div style={{ background: "purple" }}>Slide 5</div>
11
+ </Carousel>
12
+ );
13
+ };
@@ -1,55 +1,55 @@
1
- import { useEffect, useMemo, useState } from "react";
2
- import "./damier.css";
3
- import { DamierCell } from "./damierCell/DamierCell";
4
- import { DamierCellInterface } from "./damierCell/damierCell.interface";
5
- interface DamierProps {
6
- cols?: number;
7
- rows?: number;
8
- page?: number;
9
- damierCells?: DamierCellInterface[];
10
- onClick?: (cell: DamierCellInterface) => void;
11
- }
12
- export const Damier = ({
13
- cols,
14
- rows,
15
- damierCells = [],
16
- page = 1,
17
- onClick,
18
- }: DamierProps) => {
19
- const nbCols = useMemo(() => cols ?? 9, [cols]);
20
- const nbRows = useMemo(() => rows ?? 9, [rows]);
21
- const [currentPage, setCurrentPage] = useState(1);
22
- useEffect(() => {
23
- setCurrentPage(page);
24
- }, [page]);
25
- // Génération des cases du damier
26
- const grid = useMemo(() => {
27
- const rowsArray = [];
28
- for (let row = 0; row < nbRows; row++) {
29
- const colsArray = [];
30
- for (let col = 0; col < nbCols; col++) {
31
- const position = col + row * nbCols;
32
- const cell = damierCells?.find(
33
- (cell) => cell.position === position + 1
34
- );
35
- if (!cell) {
36
- colsArray.push(
37
- <div key={`${row}-${col}`} className="cell cell--empty"></div>
38
- );
39
- } else {
40
- colsArray.push(
41
- <DamierCell onClick={onClick} key={`${row}-${col}`} cell={cell} />
42
- );
43
- }
44
- }
45
- rowsArray.push(
46
- <div key={row} className="row">
47
- {colsArray}
48
- </div>
49
- );
50
- }
51
- return rowsArray;
52
- }, [nbCols, nbRows, currentPage]);
53
-
54
- return <div className="damier">{grid}</div>;
55
- };
1
+ import { useEffect, useMemo, useState } from "react";
2
+ import "./damier.css";
3
+ import { DamierCell } from "./damierCell/DamierCell";
4
+ import { DamierCellInterface } from "./damierCell/damierCell.interface";
5
+ interface DamierProps {
6
+ cols?: number;
7
+ rows?: number;
8
+ page?: number;
9
+ damierCells?: DamierCellInterface[];
10
+ onClick?: (cell: DamierCellInterface) => void;
11
+ }
12
+ export const Damier = ({
13
+ cols,
14
+ rows,
15
+ damierCells = [],
16
+ page = 1,
17
+ onClick,
18
+ }: DamierProps) => {
19
+ const nbCols = useMemo(() => cols ?? 9, [cols]);
20
+ const nbRows = useMemo(() => rows ?? 9, [rows]);
21
+ const [currentPage, setCurrentPage] = useState(1);
22
+ useEffect(() => {
23
+ setCurrentPage(page);
24
+ }, [page]);
25
+ // Génération des cases du damier
26
+ const grid = useMemo(() => {
27
+ const rowsArray = [];
28
+ for (let row = 0; row < nbRows; row++) {
29
+ const colsArray = [];
30
+ for (let col = 0; col < nbCols; col++) {
31
+ const position = col + row * nbCols;
32
+ const cell = damierCells?.find(
33
+ (cell) => cell.position === position + 1
34
+ );
35
+ if (!cell) {
36
+ colsArray.push(
37
+ <div key={`${row}-${col}`} className="cell cell--empty"></div>
38
+ );
39
+ } else {
40
+ colsArray.push(
41
+ <DamierCell onClick={onClick} key={`${row}-${col}`} cell={cell} />
42
+ );
43
+ }
44
+ }
45
+ rowsArray.push(
46
+ <div key={row} className="row">
47
+ {colsArray}
48
+ </div>
49
+ );
50
+ }
51
+ return rowsArray;
52
+ }, [nbCols, nbRows, currentPage]);
53
+
54
+ return <div className="damier">{grid}</div>;
55
+ };
@@ -1,31 +1,31 @@
1
- import { useState } from "react";
2
- import { Button } from "../button/Button";
3
- import { Damier } from "./Damier";
4
- import { DamierCellInterface } from "./damierCell/damierCell.interface";
5
-
6
- export const DamierView = () => {
7
- const [page, setPage] = useState(1);
8
- const items: DamierCellInterface[] = [
9
- {
10
- position: 2,
11
- child: <div>2</div>,
12
- },
13
- {
14
- position: 12,
15
- child: <div>12</div>,
16
- },
17
- {
18
- position: 83,
19
- child: <div>82</div>,
20
- },
21
- ];
22
-
23
- return (
24
- <>
25
- <Button onClick={() => setPage(page - 1)} title="previous" />
26
- <Button onClick={() => setPage(page + 1)} title="next" />
27
-
28
- <Damier damierCells={items} page={page} />
29
- </>
30
- );
31
- };
1
+ import { useState } from "react";
2
+ import { Button } from "../button/Button";
3
+ import { Damier } from "./Damier";
4
+ import { DamierCellInterface } from "./damierCell/damierCell.interface";
5
+
6
+ export const DamierView = () => {
7
+ const [page, setPage] = useState(1);
8
+ const items: DamierCellInterface[] = [
9
+ {
10
+ position: 2,
11
+ child: <div>2</div>,
12
+ },
13
+ {
14
+ position: 12,
15
+ child: <div>12</div>,
16
+ },
17
+ {
18
+ position: 83,
19
+ child: <div>82</div>,
20
+ },
21
+ ];
22
+
23
+ return (
24
+ <>
25
+ <Button onClick={() => setPage(page - 1)} title="previous" />
26
+ <Button onClick={() => setPage(page + 1)} title="next" />
27
+
28
+ <Damier damierCells={items} page={page} />
29
+ </>
30
+ );
31
+ };
@@ -1,44 +1,44 @@
1
- .damier {
2
- display: flex;
3
- flex-direction: column;
4
- width: fit-content;
5
- margin-bottom: 1rem;
6
- width: 100%;
7
- --sizeDamier: 630;
8
- .row {
9
- display: flex;
10
- height: 90px;
11
- width: calc(var(--sizeDamier) / 9);
12
- min-height: 40px;
13
- }
14
-
15
- .cell {
16
- width: 100%;
17
- height: 100%;
18
- overflow: hidden;
19
- border: 1px solid #d1c1c1;
20
- margin: 0.15rem;
21
- display: flex;
22
- align-items: center;
23
- justify-content: center;
24
- background-color: #fff;
25
- &.cell--empty {
26
- background: #f9f9f9;
27
- }
28
- &:not(.cell--empty) {
29
- cursor: pointer;
30
- }
31
- }
32
- }
33
-
34
- @media (min-width: 768px) {
35
- .damier {
36
- --sizeDamier: 990;
37
- .row {
38
- height: calc(100vh / 9.6);
39
- }
40
- .cell {
41
- height: calc(100vh / 9) - 1;
42
- }
43
- }
44
- }
1
+ .damier {
2
+ display: flex;
3
+ flex-direction: column;
4
+ width: fit-content;
5
+ margin-bottom: 1rem;
6
+ width: 100%;
7
+ --sizeDamier: 630;
8
+ .row {
9
+ display: flex;
10
+ height: 90px;
11
+ width: calc(var(--sizeDamier) / 9);
12
+ min-height: 40px;
13
+ }
14
+
15
+ .cell {
16
+ width: 100%;
17
+ height: 100%;
18
+ overflow: hidden;
19
+ border: 1px solid #d1c1c1;
20
+ margin: 0.15rem;
21
+ display: flex;
22
+ align-items: center;
23
+ justify-content: center;
24
+ background-color: #fff;
25
+ &.cell--empty {
26
+ background: #f9f9f9;
27
+ }
28
+ &:not(.cell--empty) {
29
+ cursor: pointer;
30
+ }
31
+ }
32
+ }
33
+
34
+ @media (min-width: 768px) {
35
+ .damier {
36
+ --sizeDamier: 990;
37
+ .row {
38
+ height: calc(100vh / 9.6);
39
+ }
40
+ .cell {
41
+ height: calc(100vh / 9) - 1;
42
+ }
43
+ }
44
+ }
@@ -1,18 +1,18 @@
1
- import { DamierCellInterface } from "./damierCell.interface";
2
-
3
- interface DamierCellProps {
4
- cell: DamierCellInterface;
5
- onClick?: (cell: DamierCellInterface) => void;
6
- }
7
- export const DamierCell = ({ cell, onClick }: DamierCellProps) => {
8
- const handleClick = () => {
9
- if (onClick) {
10
- onClick(cell);
11
- }
12
- };
13
- return (
14
- <div className="cell" onClick={handleClick}>
15
- {cell.child}
16
- </div>
17
- );
18
- };
1
+ import { DamierCellInterface } from "./damierCell.interface";
2
+
3
+ interface DamierCellProps {
4
+ cell: DamierCellInterface;
5
+ onClick?: (cell: DamierCellInterface) => void;
6
+ }
7
+ export const DamierCell = ({ cell, onClick }: DamierCellProps) => {
8
+ const handleClick = () => {
9
+ if (onClick) {
10
+ onClick(cell);
11
+ }
12
+ };
13
+ return (
14
+ <div className="cell" onClick={handleClick}>
15
+ {cell.child}
16
+ </div>
17
+ );
18
+ };
@@ -1,5 +1,5 @@
1
- export interface DamierCellInterface {
2
- child?: JSX.Element;
3
- position?: number;
4
- id?: number;
5
- }
1
+ export interface DamierCellInterface {
2
+ child?: JSX.Element;
3
+ position?: number;
4
+ id?: number;
5
+ }