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
@@ -1,90 +1,90 @@
1
- import { useCallback, useEffect, useMemo, useRef, useState } from "react";
2
- import { Button } from "../button/Button";
3
- import { Search } from "../search/Search";
4
- import { ExpandInterface } from "./expand/expand.interface";
5
- import { Expands } from "./Expands";
6
-
7
- export const ExpandsView = (): JSX.Element => {
8
- const searchRef = useRef<{
9
- clearInput: (name: string) => void;
10
- resetForm: () => void;
11
- focusInitialElement: () => void;
12
- }>(null);
13
- const [currentId, setCurrentId] = useState<number>(2);
14
-
15
- const handleRefocus = () => {
16
- searchRef.current?.focusInitialElement();
17
- };
18
- const mockItems: ExpandInterface[] = useMemo(
19
- () => [
20
- {
21
- id: 1,
22
- title: "Client",
23
- description: "Description 1",
24
- headerContent: currentId === 1 && (
25
- <Search ref={searchRef} focus={true} />
26
- ),
27
- footer: <button>Valider</button>,
28
- },
29
- {
30
- id: 2,
31
- title: "Produits",
32
- description: "Description 2",
33
- headerContent: currentId === 2 && (
34
- <Search ref={searchRef} focus={true} />
35
- ),
36
- content: (
37
- <Button title={"Go to produits"} onClick={() => setCurrentId(3)} />
38
- ),
39
- },
40
- {
41
- id: 3,
42
- title: "Total",
43
- description: "Description 3",
44
- },
45
- ],
46
- [currentId]
47
- );
48
- const [currentItem, setCurrentItem] = useState<ExpandInterface>(mockItems[0]);
49
- useEffect(() => {
50
- setTimeout(() => {
51
- searchRef.current?.focusInitialElement();
52
- }, 0);
53
- }, [searchRef, currentItem]);
54
- useEffect(() => {
55
- const item = mockItems.find((item) => item.id === currentId);
56
- if (item) {
57
- setCurrentItem(item);
58
- }
59
- }, [currentId, setCurrentItem]);
60
-
61
- const goToProduits = useCallback(() => {
62
- setCurrentItem(mockItems[2]);
63
- }, [setCurrentItem]);
64
-
65
- const onChange = useCallback(
66
- (item: ExpandInterface) => {
67
- if (item.id) {
68
- setCurrentId(item.id);
69
- }
70
- },
71
- [setCurrentId]
72
- );
73
- return (
74
- <div className="d-flex flex-column" style={{ height: "100%" }}>
75
- <div className="mb-2">
76
- <Button title={"Go to produits"} onClick={goToProduits} />
77
-
78
- <Button onClick={handleRefocus} title="Re-focus" />
79
- </div>
80
- <div className="flex-1">
81
- <Expands
82
- onChange={onChange}
83
- currentItem={currentItem}
84
- items={mockItems}
85
- />
86
- ;
87
- </div>
88
- </div>
89
- );
90
- };
1
+ import { useCallback, useEffect, useMemo, useRef, useState } from "react";
2
+ import { Button } from "../button/Button";
3
+ import { Search } from "../search/Search";
4
+ import { ExpandInterface } from "./expand/expand.interface";
5
+ import { Expands } from "./Expands";
6
+
7
+ export const ExpandsView = (): JSX.Element => {
8
+ const searchRef = useRef<{
9
+ clearInput: (name: string) => void;
10
+ resetForm: () => void;
11
+ focusInitialElement: () => void;
12
+ }>(null);
13
+ const [currentId, setCurrentId] = useState<number>(2);
14
+
15
+ const handleRefocus = () => {
16
+ searchRef.current?.focusInitialElement();
17
+ };
18
+ const mockItems: ExpandInterface[] = useMemo(
19
+ () => [
20
+ {
21
+ id: 1,
22
+ title: "Client",
23
+ description: "Description 1",
24
+ headerContent: currentId === 1 && (
25
+ <Search ref={searchRef} focus={true} />
26
+ ),
27
+ footer: <button>Valider</button>,
28
+ },
29
+ {
30
+ id: 2,
31
+ title: "Produits",
32
+ description: "Description 2",
33
+ headerContent: currentId === 2 && (
34
+ <Search ref={searchRef} focus={true} />
35
+ ),
36
+ content: (
37
+ <Button title={"Go to produits"} onClick={() => setCurrentId(3)} />
38
+ ),
39
+ },
40
+ {
41
+ id: 3,
42
+ title: "Total",
43
+ description: "Description 3",
44
+ },
45
+ ],
46
+ [currentId]
47
+ );
48
+ const [currentItem, setCurrentItem] = useState<ExpandInterface>(mockItems[0]);
49
+ useEffect(() => {
50
+ setTimeout(() => {
51
+ searchRef.current?.focusInitialElement();
52
+ }, 0);
53
+ }, [searchRef, currentItem]);
54
+ useEffect(() => {
55
+ const item = mockItems.find((item) => item.id === currentId);
56
+ if (item) {
57
+ setCurrentItem(item);
58
+ }
59
+ }, [currentId, setCurrentItem]);
60
+
61
+ const goToProduits = useCallback(() => {
62
+ setCurrentItem(mockItems[2]);
63
+ }, [setCurrentItem]);
64
+
65
+ const onChange = useCallback(
66
+ (item: ExpandInterface) => {
67
+ if (item.id) {
68
+ setCurrentId(item.id);
69
+ }
70
+ },
71
+ [setCurrentId]
72
+ );
73
+ return (
74
+ <div className="d-flex flex-column" style={{ height: "100%" }}>
75
+ <div className="mb-2">
76
+ <Button title={"Go to produits"} onClick={goToProduits} />
77
+
78
+ <Button onClick={handleRefocus} title="Re-focus" />
79
+ </div>
80
+ <div className="flex-1">
81
+ <Expands
82
+ onChange={onChange}
83
+ currentItem={currentItem}
84
+ items={mockItems}
85
+ />
86
+ ;
87
+ </div>
88
+ </div>
89
+ );
90
+ };
@@ -1,8 +1,8 @@
1
- export interface ExpandInterface {
2
- id?: number;
3
- title: string | React.ReactNode;
4
- description?: string | React.ReactNode;
5
- content?: React.ReactNode;
6
- headerContent?: React.ReactNode;
7
- footer?: JSX.Element;
8
- }
1
+ export interface ExpandInterface {
2
+ id?: number;
3
+ title: string | React.ReactNode;
4
+ description?: string | React.ReactNode;
5
+ content?: React.ReactNode;
6
+ headerContent?: React.ReactNode;
7
+ footer?: JSX.Element;
8
+ }
@@ -1,75 +1,75 @@
1
- import { useCallback, useEffect, useState } from "react";
2
- import { Icon } from "../../icon/Icon";
3
- import { ExpandInterface } from "./expand.interface";
4
-
5
- export type ExpandProps = {
6
- currentExpand?: ExpandInterface;
7
- item: ExpandInterface;
8
- className?: string;
9
- showArrow?: boolean;
10
- onChange: (item: ExpandInterface) => void;
11
- };
12
- export const Expand = ({
13
- currentExpand,
14
- item,
15
- className,
16
- showArrow = true,
17
- onChange,
18
- }: ExpandProps): JSX.Element => {
19
- const [active, setActive] = useState<boolean>(false);
20
- useEffect(() => {
21
- if (item && currentExpand) {
22
- if (currentExpand.id === item.id) {
23
- if (!active) {
24
- setActive(true);
25
- }
26
- } else {
27
- setActive(false);
28
- }
29
- } else {
30
- setActive(false);
31
- }
32
- }, [currentExpand, setActive, item]);
33
-
34
- const handleChange = useCallback(
35
- (e: React.MouseEvent<HTMLDivElement, MouseEvent>) => {
36
- e.stopPropagation();
37
- if (onChange) {
38
- onChange(item);
39
- }
40
- },
41
- [onChange, item]
42
- );
43
- return (
44
- <div
45
- onClick={handleChange}
46
- className={`expand ${active ? "expand--active" : ""} ${className ?? ""}`}
47
- >
48
- <div className={`expand-header`}>
49
- <div className="expand-header-content">
50
- <div className="expand-header-content-default">
51
- {active && showArrow && (
52
- <Icon classIcon="bi bi-chevron-down mr-2"></Icon>
53
- )}
54
- {!active && showArrow && (
55
- <Icon classIcon="bi bi-chevron-right mr-2"></Icon>
56
- )}
57
- <span className="flex-1 expand-header-title-left">
58
- {item.title}
59
- </span>
60
- {item.description && (
61
- <span className="expand-header-title-right">
62
- {item.description}
63
- </span>
64
- )}
65
- </div>
66
- </div>
67
- </div>
68
- <div className="expand-body">
69
- <div>{item.headerContent}</div>
70
- {item.content}
71
- </div>
72
- {item.footer && <div className="expand-footer">{item.footer}</div>}
73
- </div>
74
- );
75
- };
1
+ import { useCallback, useEffect, useState } from "react";
2
+ import { Icon } from "../../icon/Icon";
3
+ import { ExpandInterface } from "./expand.interface";
4
+
5
+ export type ExpandProps = {
6
+ currentExpand?: ExpandInterface;
7
+ item: ExpandInterface;
8
+ className?: string;
9
+ showArrow?: boolean;
10
+ onChange: (item: ExpandInterface) => void;
11
+ };
12
+ export const Expand = ({
13
+ currentExpand,
14
+ item,
15
+ className,
16
+ showArrow = true,
17
+ onChange,
18
+ }: ExpandProps): JSX.Element => {
19
+ const [active, setActive] = useState<boolean>(false);
20
+ useEffect(() => {
21
+ if (item && currentExpand) {
22
+ if (currentExpand.id === item.id) {
23
+ if (!active) {
24
+ setActive(true);
25
+ }
26
+ } else {
27
+ setActive(false);
28
+ }
29
+ } else {
30
+ setActive(false);
31
+ }
32
+ }, [currentExpand, setActive, item]);
33
+
34
+ const handleChange = useCallback(
35
+ (e: React.MouseEvent<HTMLDivElement, MouseEvent>) => {
36
+ e.stopPropagation();
37
+ if (onChange) {
38
+ onChange(item);
39
+ }
40
+ },
41
+ [onChange, item]
42
+ );
43
+ return (
44
+ <div
45
+ onClick={handleChange}
46
+ className={`expand ${active ? "expand--active" : ""} ${className ?? ""}`}
47
+ >
48
+ <div className={`expand-header`}>
49
+ <div className="expand-header-content">
50
+ <div className="expand-header-content-default">
51
+ {active && showArrow && (
52
+ <Icon classIcon="bi bi-chevron-down mr-2"></Icon>
53
+ )}
54
+ {!active && showArrow && (
55
+ <Icon classIcon="bi bi-chevron-right mr-2"></Icon>
56
+ )}
57
+ <span className="flex-1 expand-header-title-left">
58
+ {item.title}
59
+ </span>
60
+ {item.description && (
61
+ <span className="expand-header-title-right">
62
+ {item.description}
63
+ </span>
64
+ )}
65
+ </div>
66
+ </div>
67
+ </div>
68
+ <div className="expand-body">
69
+ <div>{item.headerContent}</div>
70
+ {item.content}
71
+ </div>
72
+ {item.footer && <div className="expand-footer">{item.footer}</div>}
73
+ </div>
74
+ );
75
+ };
@@ -1,97 +1,97 @@
1
- .expands {
2
- display: flex;
3
- height: 100%;
4
- flex-direction: column;
5
-
6
- .expand {
7
- border: 1px solid #cfbdbd;
8
- overflow: hidden;
9
- margin-bottom: 1rem;
10
- border-radius: 4px;
11
- display: flex;
12
- flex-direction: column;
13
- background-color: #fff;
14
- cursor: pointer;
15
-
16
- &:last-child {
17
- margin-bottom: 0;
18
- }
19
-
20
- .expand-header-content {
21
- display: flex;
22
- width: 100%;
23
- align-items: center;
24
-
25
- .expand-header-content-default {
26
- display: flex;
27
- width: 100%;
28
- align-items: center;
29
- }
30
- }
31
-
32
- .expand-header-custom {
33
- .expand-header--children {
34
- display: none;
35
- }
36
- }
37
-
38
- &.expand--active {
39
- height: 300px;
40
- flex: 1;
41
- min-height: 200px;
42
- .expand-header {
43
- background-color: #1d3758;
44
- color: #fff;
45
- }
46
- .expand-header-custom {
47
- .expand-header--children {
48
- display: flex;
49
- }
50
-
51
- .expand-header--values {
52
- display: none;
53
- }
54
- }
55
-
56
- & .expand-body {
57
- display: flex;
58
- }
59
- }
60
-
61
- & .expand-header {
62
- cursor: pointer;
63
- display: flex;
64
- align-items: center;
65
- padding: 15px;
66
- color: #333;
67
- background-color: #fff;
68
- &.expand-header-custom {
69
- margin-bottom: 1rem;
70
- }
71
-
72
- .expand-header-title-right {
73
- font-size: 0.85rem;
74
- font-weight: 600;
75
- }
76
-
77
- .expand-header-title-left {
78
- margin-right: 0.5rem;
79
- text-transform: uppercase;
80
- font-size: 14px;
81
- font-weight: 500;
82
- }
83
- }
84
- & .expand-footer {
85
- padding: 15px;
86
- }
87
- & .expand-body {
88
- display: none;
89
- flex: 1;
90
- width: 100%;
91
- padding-top: 1rem;
92
- padding: 15px;
93
- overflow: auto;
94
- flex-direction: column;
95
- }
96
- }
97
- }
1
+ .expands {
2
+ display: flex;
3
+ height: 100%;
4
+ flex-direction: column;
5
+
6
+ .expand {
7
+ border: 1px solid #cfbdbd;
8
+ overflow: hidden;
9
+ margin-bottom: 1rem;
10
+ border-radius: 4px;
11
+ display: flex;
12
+ flex-direction: column;
13
+ background-color: #fff;
14
+ cursor: pointer;
15
+
16
+ &:last-child {
17
+ margin-bottom: 0;
18
+ }
19
+
20
+ .expand-header-content {
21
+ display: flex;
22
+ width: 100%;
23
+ align-items: center;
24
+
25
+ .expand-header-content-default {
26
+ display: flex;
27
+ width: 100%;
28
+ align-items: center;
29
+ }
30
+ }
31
+
32
+ .expand-header-custom {
33
+ .expand-header--children {
34
+ display: none;
35
+ }
36
+ }
37
+
38
+ &.expand--active {
39
+ height: 300px;
40
+ flex: 1;
41
+ min-height: 200px;
42
+ .expand-header {
43
+ background-color: #1d3758;
44
+ color: #fff;
45
+ }
46
+ .expand-header-custom {
47
+ .expand-header--children {
48
+ display: flex;
49
+ }
50
+
51
+ .expand-header--values {
52
+ display: none;
53
+ }
54
+ }
55
+
56
+ & .expand-body {
57
+ display: flex;
58
+ }
59
+ }
60
+
61
+ & .expand-header {
62
+ cursor: pointer;
63
+ display: flex;
64
+ align-items: center;
65
+ padding: 15px;
66
+ color: #333;
67
+ background-color: #fff;
68
+ &.expand-header-custom {
69
+ margin-bottom: 1rem;
70
+ }
71
+
72
+ .expand-header-title-right {
73
+ font-size: 0.85rem;
74
+ font-weight: 600;
75
+ }
76
+
77
+ .expand-header-title-left {
78
+ margin-right: 0.5rem;
79
+ text-transform: uppercase;
80
+ font-size: 14px;
81
+ font-weight: 500;
82
+ }
83
+ }
84
+ & .expand-footer {
85
+ padding: 15px;
86
+ }
87
+ & .expand-body {
88
+ display: none;
89
+ flex: 1;
90
+ width: 100%;
91
+ padding-top: 1rem;
92
+ padding: 15px;
93
+ overflow: auto;
94
+ flex-direction: column;
95
+ }
96
+ }
97
+ }
@@ -1,57 +1,57 @@
1
- import { useCallback } from "react";
2
- import "./filAriane.css";
3
- import { FilArianeInterface } from "./filAriane.interface";
4
- type FilArianeProps = {
5
- filArianes?: FilArianeInterface[];
6
- currentFil?: number;
7
- title?: string;
8
- onClick?: (fil?: FilArianeInterface) => void;
9
- };
10
- export const FilAriane = ({
11
- filArianes,
12
- onClick,
13
- currentFil,
14
- title,
15
- }: FilArianeProps) => {
16
- const handleClick = useCallback(
17
- (e: React.MouseEvent<HTMLAnchorElement>, fil?: FilArianeInterface) => {
18
- if (!fil?.url) {
19
- e.preventDefault();
20
- }
21
- if (onClick) {
22
- onClick(fil);
23
- }
24
- },
25
- [onClick]
26
- );
27
- return (
28
- <div className="filArianes">
29
- {title && (
30
- <small className="filAriane font-weight-bold text-uppercase">
31
- {title} <i className="filAriane-chevron bi bi-caret-right-fill"></i>
32
- </small>
33
- )}
34
- {filArianes?.map((filAriane, index) => {
35
- return (
36
- <div
37
- key={index}
38
- className={`filAriane ${
39
- filAriane.id === currentFil && "filAriane--active"
40
- }`}
41
- >
42
- <a
43
- href={filAriane.url || "#"}
44
- onClick={(e) => handleClick(e, filAriane)}
45
- >
46
- {filAriane.title}
47
- </a>
48
-
49
- {!filAriane.isLast && (
50
- <i className="filAriane-chevron bi bi-caret-right-fill"></i>
51
- )}
52
- </div>
53
- );
54
- })}
55
- </div>
56
- );
57
- };
1
+ import { useCallback } from "react";
2
+ import "./filAriane.css";
3
+ import { FilArianeInterface } from "./filAriane.interface";
4
+ type FilArianeProps = {
5
+ filArianes?: FilArianeInterface[];
6
+ currentFil?: number;
7
+ title?: string;
8
+ onClick?: (fil?: FilArianeInterface) => void;
9
+ };
10
+ export const FilAriane = ({
11
+ filArianes,
12
+ onClick,
13
+ currentFil,
14
+ title,
15
+ }: FilArianeProps) => {
16
+ const handleClick = useCallback(
17
+ (e: React.MouseEvent<HTMLAnchorElement>, fil?: FilArianeInterface) => {
18
+ if (!fil?.url) {
19
+ e.preventDefault();
20
+ }
21
+ if (onClick) {
22
+ onClick(fil);
23
+ }
24
+ },
25
+ [onClick]
26
+ );
27
+ return (
28
+ <div className="filArianes">
29
+ {title && (
30
+ <small className="filAriane font-weight-bold text-uppercase">
31
+ {title} <i className="filAriane-chevron bi bi-caret-right-fill"></i>
32
+ </small>
33
+ )}
34
+ {filArianes?.map((filAriane, index) => {
35
+ return (
36
+ <div
37
+ key={index}
38
+ className={`filAriane ${
39
+ filAriane.id === currentFil && "filAriane--active"
40
+ }`}
41
+ >
42
+ <a
43
+ href={filAriane.url || "#"}
44
+ onClick={(e) => handleClick(e, filAriane)}
45
+ >
46
+ {filAriane.title}
47
+ </a>
48
+
49
+ {!filAriane.isLast && (
50
+ <i className="filAriane-chevron bi bi-caret-right-fill"></i>
51
+ )}
52
+ </div>
53
+ );
54
+ })}
55
+ </div>
56
+ );
57
+ };