@uniai-fe/ui-legacy 0.1.5 → 0.1.7

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 (103) hide show
  1. package/README.md +3 -1
  2. package/package.json +37 -38
  3. package/src/button/index.tsx +12 -12
  4. package/src/components.tsx +2 -2
  5. package/src/icon/icon.scss +1 -1
  6. package/src/icon/index.tsx +4 -4
  7. package/src/icon/styled.tsx +2 -2
  8. package/src/index.scss +2 -2
  9. package/src/index.tsx +0 -2
  10. package/src/types/index.d.ts +2 -2
  11. package/src/chart/chart.scss +0 -11
  12. package/src/chart/components/Contents.tsx +0 -17
  13. package/src/chart/components/control/Button.tsx +0 -39
  14. package/src/chart/components/control/Container.tsx +0 -27
  15. package/src/chart/components/control/Provider.tsx +0 -117
  16. package/src/chart/components/control/index.tsx +0 -12
  17. package/src/chart/components/custom/ActivePieSector.tsx +0 -29
  18. package/src/chart/components/graphs/ArcGauge.tsx +0 -58
  19. package/src/chart/components/graphs/ArcMeter.tsx +0 -112
  20. package/src/chart/components/graphs/Area.tsx +0 -132
  21. package/src/chart/components/graphs/Bar.tsx +0 -179
  22. package/src/chart/components/graphs/Doughnut.tsx +0 -90
  23. package/src/chart/components/graphs/Line.tsx +0 -123
  24. package/src/chart/components/graphs/index.tsx +0 -17
  25. package/src/chart/components/ticks/XAxis.tsx +0 -39
  26. package/src/chart/components/ticks/index.tsx +0 -7
  27. package/src/chart/index.tsx +0 -17
  28. package/src/chart/styled.tsx +0 -3
  29. package/src/chart/styles/scss/arc-gauge.scss +0 -11
  30. package/src/chart/styles/scss/arc-meter.scss +0 -6
  31. package/src/chart/styles/scss/control.scss +0 -34
  32. package/src/chart/styles/scss/filter.scss +0 -0
  33. package/src/chart/styles/scss/graph.scss +0 -3
  34. package/src/chart/styles/scss/legend.scss +0 -35
  35. package/src/chart/styles/scss/level.color.scss +0 -7
  36. package/src/chart/styles/scss/tick.scss +0 -48
  37. package/src/chart/styles/scss/tooltip.scss +0 -70
  38. package/src/chart/styles/styled/arc-gauge.ts +0 -65
  39. package/src/chart/styles/styled/arc-meter.ts +0 -42
  40. package/src/chart/styles/styled/common.ts +0 -14
  41. package/src/chart/styles/styled/control.ts +0 -31
  42. package/src/chart/styles/styled/legend.ts +0 -11
  43. package/src/chart/svg/gauge-track.min.svg +0 -1
  44. package/src/chart/utils/getLevel.ts +0 -23
  45. package/src/icon/components/chart/Control.tsx +0 -40
  46. package/src/icon/components/chart/index.tsx +0 -7
  47. package/src/icon/components/health-score/HealthScore.tsx +0 -46
  48. package/src/icon/components/health-score/index.tsx +0 -3
  49. package/src/icon/styles/scss/chart.scss +0 -3
  50. package/src/icon/styles/styled/chart.ts +0 -17
  51. package/src/icon/svg/chart/control/pan-left.svg +0 -4
  52. package/src/icon/svg/chart/control/pan-right.svg +0 -4
  53. package/src/icon/svg/chart/control/zoom-in.svg +0 -4
  54. package/src/icon/svg/chart/control/zoom-out.svg +0 -4
  55. package/src/styled.template.tsx +0 -5
  56. package/src/template/compare/compare.scss +0 -1
  57. package/src/template/compare/components/box/Container.tsx +0 -33
  58. package/src/template/compare/components/box/TextStrong.tsx +0 -15
  59. package/src/template/compare/components/box/TextSub.tsx +0 -15
  60. package/src/template/compare/components/box/index.tsx +0 -11
  61. package/src/template/compare/components/button/Remove.tsx +0 -28
  62. package/src/template/compare/components/button/index.tsx +0 -5
  63. package/src/template/compare/components/chart/Container.tsx +0 -33
  64. package/src/template/compare/components/chart/graph/Container.tsx +0 -15
  65. package/src/template/compare/components/chart/graph/Item.tsx +0 -13
  66. package/src/template/compare/components/chart/index.tsx +0 -16
  67. package/src/template/compare/components/chart/legend/Container.tsx +0 -23
  68. package/src/template/compare/components/chart/legend/Section.tsx +0 -31
  69. package/src/template/compare/components/select-list/Container.tsx +0 -15
  70. package/src/template/compare/components/select-list/Header.tsx +0 -15
  71. package/src/template/compare/components/select-list/Item.tsx +0 -15
  72. package/src/template/compare/components/select-list/List.tsx +0 -18
  73. package/src/template/compare/components/select-list/index.tsx +0 -13
  74. package/src/template/compare/index.tsx +0 -13
  75. package/src/template/compare/styled.tsx +0 -17
  76. package/src/template/compare/styles/scss/variables.scss +0 -17
  77. package/src/template/compare/styles/styled-components/chart/graph.ts +0 -26
  78. package/src/template/compare/styles/styled-components/chart/layout.ts +0 -38
  79. package/src/template/compare/styles/styled-components/chart/legend.ts +0 -64
  80. package/src/template/compare/styles/styled-components/common.ts +0 -57
  81. package/src/template/compare/styles/styled-components/select-list.ts +0 -36
  82. package/src/template/filter/components/Container.tsx +0 -39
  83. package/src/template/filter/components/Group.tsx +0 -100
  84. package/src/template/filter/components/ToggleButton.tsx +0 -27
  85. package/src/template/filter/index.tsx +0 -5
  86. package/src/template/filter/styled.tsx +0 -3
  87. package/src/template/filter/styles/styled-components/filter.ts +0 -66
  88. package/src/template/health-score/components/Chart.tsx +0 -38
  89. package/src/template/health-score/index.tsx +0 -3
  90. package/src/template/health-score/styled.tsx +0 -3
  91. package/src/template/health-score/styles/styled/chart.ts +0 -26
  92. package/src/template.tsx +0 -5
  93. package/src/types/chart/axis.d.ts +0 -15
  94. package/src/types/chart/control.d.ts +0 -109
  95. package/src/types/chart/data.d.ts +0 -41
  96. package/src/types/chart/dot.d.ts +0 -3
  97. package/src/types/chart/index.d.ts +0 -7
  98. package/src/types/chart/legend.d.ts +0 -124
  99. package/src/types/chart/props.d.ts +0 -271
  100. package/src/types/chart/tick.d.ts +0 -30
  101. package/src/types/template/compare/chart.d.ts +0 -8
  102. package/src/types/template/filter.d.ts +0 -39
  103. package/src/types/template/index.d.ts +0 -2
@@ -1,100 +0,0 @@
1
- "use client";
2
-
3
- import { useCallback } from "react";
4
- import { useFormContext, useWatch } from "react-hook-form";
5
-
6
- import InputCheckbox from "../../../form-field/input/components/click/Checkbox";
7
- import StyledFilter from "../styles/styled-components/filter";
8
-
9
- import type { FilterGroupDataType, FilterStateFormType } from "../../../types";
10
-
11
- export default function FilterGroup({
12
- groupKey,
13
- categoryKey,
14
- categoryName,
15
- items,
16
- }: FilterGroupDataType) {
17
- const { register, control, getValues, setValue } =
18
- useFormContext<FilterStateFormType>();
19
-
20
- // 현재 그룹 선택 현황
21
- const checkState = useWatch({ control, name: `filter.${categoryKey}` });
22
-
23
- // 전체선택 클릭 이벤트
24
- const onCheckAll = useCallback(
25
- (e: React.ChangeEvent<HTMLInputElement>) => {
26
- const { checked } = e.target;
27
- setValue(`filter.${categoryKey}.all`, checked);
28
-
29
- // 하위항목에 all check상태 일괄 적용
30
- const keys = items.map(({ value }) => value);
31
-
32
- keys.forEach(dataKey => {
33
- setValue(`filter.${categoryKey}.${dataKey}`, checked);
34
- });
35
- },
36
- [categoryKey, items, setValue],
37
- );
38
-
39
- // 하위항목 선택 클릭 이벤트
40
- const onCheckEach = useCallback(
41
- (e: React.ChangeEvent<HTMLInputElement>, dataKey: string) => {
42
- // 클릭한 항목 선택 업데이트
43
- const { checked: thisChecked } = e.target;
44
- setValue(`filter.${categoryKey}.${dataKey}`, thisChecked);
45
-
46
- // 전체 선택상태
47
- const currentCheckedAll = getValues(`filter.${categoryKey}.all`);
48
-
49
- // 나머지 하위항목 선택상태
50
- const others = Object.fromEntries(
51
- Object.entries(checkState).filter(
52
- ([key]) => !["all", dataKey].includes(key),
53
- ),
54
- );
55
- // 현재 항목을 클릭함으로써, 모든 하위항목이 모두 체크되었는지 확인
56
- const isCheckedAllByEach =
57
- thisChecked && Object.values(others).every(checked => checked);
58
-
59
- // 현재 전체선택 체크상태와 다르면 업데이트
60
- if (currentCheckedAll !== isCheckedAllByEach)
61
- setValue(`filter.${categoryKey}.all`, isCheckedAllByEach);
62
- },
63
- [categoryKey, checkState, getValues, setValue],
64
- );
65
-
66
- return (
67
- <StyledFilter.Group.Container>
68
- <StyledFilter.Group.Title>
69
- <InputCheckbox
70
- label={{
71
- name: <span>{categoryName}</span>,
72
- position: "right",
73
- hide: false,
74
- }}
75
- selectorId={`${categoryKey}/all`}
76
- dataKey={`${categoryKey}/all`}
77
- register={register(`filter.${categoryKey}.all`)}
78
- state={{ checked: checkState.all }}
79
- onCustomChange={onCheckAll}
80
- />
81
- </StyledFilter.Group.Title>
82
- {items.map(({ value: dataKey, name }) => (
83
- <StyledFilter.Group.Item key={`${groupKey}/${dataKey}`}>
84
- <InputCheckbox
85
- label={{
86
- name: <span>{name}</span>,
87
- position: "right",
88
- hide: false,
89
- }}
90
- selectorId={`${categoryKey}/${dataKey}`}
91
- dataKey={`${categoryKey}/${dataKey}`}
92
- register={register(`filter.${categoryKey}.${dataKey}`)}
93
- state={{ checked: checkState[dataKey] }}
94
- onCustomChange={e => onCheckEach(e, dataKey)}
95
- />
96
- </StyledFilter.Group.Item>
97
- ))}
98
- </StyledFilter.Group.Container>
99
- );
100
- }
@@ -1,27 +0,0 @@
1
- "use client";
2
-
3
- import ButtonDefault from "../../../button/components/base/Default";
4
- import IconButton from "../../../icon/components/button";
5
- import StyledFilter from "../styles/styled-components/filter";
6
-
7
- export default function FilterToggleButton({
8
- clickEvent,
9
- }: {
10
- clickEvent: () => void;
11
- }) {
12
- return (
13
- <StyledFilter.Button
14
- as={ButtonDefault}
15
- className="filter-button"
16
- styleOptions={{
17
- priorityType: "pale",
18
- fillType: "outline",
19
- sizeType: "small",
20
- }}
21
- clickEvent={clickEvent}
22
- >
23
- <IconButton.Filter />
24
- <span>필터</span>
25
- </StyledFilter.Button>
26
- );
27
- }
@@ -1,5 +0,0 @@
1
- import FilterContainer from "./components/Container";
2
-
3
- const Filter = FilterContainer;
4
-
5
- export default Filter;
@@ -1,3 +0,0 @@
1
- import StyledFilter from "./styles/styled-components/filter";
2
-
3
- export default StyledFilter;
@@ -1,66 +0,0 @@
1
- "use client";
2
-
3
- import { styled } from "styled-components";
4
- import StyledDropdown from "../../../../dropdown/styled";
5
- import Button from "../../../../button";
6
-
7
- const FilterButton = styled(Button.Default)`
8
- margin: 0;
9
- figure {
10
- margin-right: 4px;
11
- }
12
- `;
13
- const Parent = styled(StyledDropdown.parent)`
14
- --dropdown-padding-vertical: 15px;
15
- --dropdown-padding-horizontal: 15px;
16
-
17
- --dropdown-border-top-radius: 4px;
18
- --dropdown-border-bottom-radius: 4px;
19
-
20
- --field-item-width: fit-content;
21
- --field-item-wrapper-width: fit-content;
22
- --field-item-flex-wrap: nowrap;
23
-
24
- ${StyledDropdown.wrapper} {
25
- display: flex;
26
- }
27
- `;
28
-
29
- const GroupContainer = styled.dl`
30
- width: fit-content;
31
- margin-right: 15px;
32
- padding-right: 15px;
33
- border-right: 1px solid var(--color_30);
34
-
35
- &:last-child {
36
- margin-right: 0;
37
- padding-right: 0;
38
- border-right: 0;
39
- }
40
- `;
41
-
42
- const GroupTitle = styled.dt`
43
- padding-bottom: 10px;
44
- border-bottom: 1px solid var(--color_30);
45
- span {
46
- font-size: 16px;
47
- }
48
- `;
49
-
50
- const GroupItem = styled.dd`
51
- margin-top: 5px;
52
- `;
53
-
54
- const Group = {
55
- Container: GroupContainer,
56
- Title: GroupTitle,
57
- Item: GroupItem,
58
- };
59
-
60
- const StyledFilter = {
61
- Parent,
62
- Button: FilterButton,
63
- Group,
64
- };
65
-
66
- export default StyledFilter;
@@ -1,38 +0,0 @@
1
- "use client";
2
-
3
- import { useCallback } from "react";
4
- import Chart from "../../../chart";
5
- import StyledHealthScore from "../styles/styled/chart";
6
- import Button from "../../../button";
7
-
8
- export default function HealthScoreChart({
9
- title,
10
- score,
11
- details,
12
- }: {
13
- title: string;
14
- score: number | "";
15
- details?: React.ReactNode[];
16
- }) {
17
- const onOpen = useCallback(() => {
18
- console.log(details);
19
- }, [details]);
20
-
21
- return (
22
- <StyledHealthScore.container>
23
- <Chart.Graph.ArcMeter
24
- data={{ name: title, value: score || "" }}
25
- max={100}
26
- />
27
- <StyledHealthScore.title>
28
- <h5>{title}</h5>
29
- <Button.Tooltip
30
- size={18}
31
- priorityType="primary"
32
- fillType="solid"
33
- clickEvent={onOpen}
34
- />
35
- </StyledHealthScore.title>
36
- </StyledHealthScore.container>
37
- );
38
- }
@@ -1,3 +0,0 @@
1
- import HealthScoreChart from "./components/Chart";
2
-
3
- export default HealthScoreChart;
@@ -1,3 +0,0 @@
1
- import StyledHealthScore from "./styles/styled/chart";
2
-
3
- export default StyledHealthScore;
@@ -1,26 +0,0 @@
1
- "use client";
2
-
3
- import { styled } from "styled-components";
4
- import Chart from "../../../../chart";
5
-
6
- const container = styled(Chart.ContentsContainer)``;
7
-
8
- const title = styled.div`
9
- width: 100%;
10
- margin-top: 10px;
11
- display: flex;
12
- align-items: center;
13
- justify-content: center;
14
- h5 {
15
- font-size: 20px;
16
- color: var(--color_90);
17
- font-weight: 600;
18
- }
19
- `;
20
-
21
- const StyledHealthScore = {
22
- container,
23
- title,
24
- };
25
-
26
- export default StyledHealthScore;
package/src/template.tsx DELETED
@@ -1,5 +0,0 @@
1
- import HealthScoreChart from "./template/health-score";
2
- import Compare from "./template/compare";
3
- import Filter from "./template/filter";
4
-
5
- export { HealthScoreChart, Compare, Filter };
@@ -1,15 +0,0 @@
1
- /**
2
- * 차트 y축 카테고리별 생성 데이터
3
- * @property {string} key - 렌더링 키
4
- * @property {string} axisCategory - y축 id
5
- */
6
- export interface ChartYAxisDataType {
7
- /**
8
- * 렌더링 키
9
- */
10
- key: string;
11
- /**
12
- * y축 id
13
- */
14
- axisCategory: string;
15
- }
@@ -1,109 +0,0 @@
1
- /**
2
- * 차트 제어 타입
3
- * @desc
4
- * - zoom-in: 확대
5
- * - zoom-out: 축소
6
- * - pan-left: 왼쪽으로 이동
7
- * - pan-right: 오른쪽으로 이동
8
- */
9
- export type ChartControlRole =
10
- | "zoom-in"
11
- | "zoom-out"
12
- | "pan-left"
13
- | "pan-right";
14
-
15
- /**
16
- * 차트 제어 범위
17
- */
18
- export type ChartControlRange = {
19
- [edge: string]: number;
20
- start: number;
21
- end: number;
22
- };
23
- /**
24
- * 차트 제어 데이터 컨텍스트
25
- * @desc
26
- * - originData: 차트 데이터 원본
27
- * - indexRange: 현재 X축 범위 [시작 인덱스, 끝 인덱스]
28
- * - setIndexRange: X축 범위 업데이트 함수
29
- */
30
- export type ChartControlContext<ChartData extends object = object> = {
31
- /**
32
- * 차트 데이터 원본
33
- */
34
- originData: ChartData[];
35
- /**
36
- * 현재 X축 범위
37
- * @desc
38
- * - [시작 인덱스, 끝 인덱스]
39
- */
40
- indexRange: ChartControlRange;
41
- /**
42
- * X축 범위 업데이트
43
- * @desc
44
- * - [시작 인덱스, 끝 인덱스]
45
- */
46
- setIndexRange: React.Dispatch<React.SetStateAction<ChartControlRange>>;
47
- };
48
-
49
- /**
50
- * 차트 제어 도구; 확대/축소 (zoom)
51
- */
52
- export type ChartControlMethodZoom = {
53
- [direction: string]: () => void;
54
- in: () => void;
55
- out: () => void;
56
- };
57
- /**
58
- * 차트 제어 도구; 좌우 이동 (pan)
59
- */
60
- export type ChartControlMethodPan = {
61
- [direction: string]: () => void;
62
- left: () => void;
63
- right: () => void;
64
- };
65
- /**
66
- * 차트 제어 도구; 동작 함수
67
- */
68
- export type ChartControlMethod = {
69
- zoom: ChartControlMethodZoom;
70
- pan: ChartControlMethodPan;
71
- };
72
-
73
- /**
74
- * 차트 제어 도구; 확대/축소 비활성화 상태
75
- */
76
- export type ChartControlDisabledZoom = {
77
- [direction: string]: boolean;
78
- in: boolean;
79
- out: boolean;
80
- };
81
- /**
82
- * 차트 제어 도구; 좌우 이동 상태
83
- */
84
- export type ChartControlDisabledPan = {
85
- [direction: string]: boolean;
86
- left: boolean;
87
- right: boolean;
88
- };
89
- /**
90
- * 차트 제어 도구; 상태
91
- */
92
- export type ChartControlDisabled = {
93
- zoom: ChartControlDisabledZoom;
94
- pan: ChartControlDisabledPan;
95
- };
96
-
97
- /**
98
- * 차트 제어 도구
99
- */
100
- export type ChartControlReturn = {
101
- /**
102
- * 동작 함수
103
- */
104
- method: ChartControlMethod;
105
- /**
106
- * 비활성화 상태
107
- */
108
- disabled: ChartControlDisabled;
109
- };
@@ -1,41 +0,0 @@
1
- /**
2
- * 차트 데이터; 1차원 데이터
3
- */
4
- export type ChartCoreDataSingleType = {
5
- /**
6
- * 임의의 차트 데이터
7
- */
8
- [dataKey: string]: number | string | null;
9
- /**
10
- * 데이터 명칭
11
- */
12
- name: string;
13
- /**
14
- * 데이터 값
15
- */
16
- value: number | null;
17
- /**
18
- * 데이터 단위
19
- */
20
- unit: string;
21
- /**
22
- * 데이터 색상
23
- */
24
- fill: string;
25
- /**
26
- * pie 차트의 경우, 데이터 트랙
27
- * - 데이터 총량 또는 게이지 최대값
28
- */
29
- track?: number;
30
- };
31
-
32
- /**
33
- * 차트 데이터; 2차원 데이터
34
- */
35
- export type ChartCoreDataAxisType = {
36
- /**
37
- * 차트 시그니처 데이터
38
- * number | string | null
39
- */
40
- [dataKey: string]: number | string | null;
41
- };
@@ -1,3 +0,0 @@
1
- import type { Props } from "recharts/types/shape/Dot";
2
-
3
- export type ChartDotProps = Props;
@@ -1,7 +0,0 @@
1
- export type * from "./legend";
2
- export type * from "./axis";
3
- export type * from "./data";
4
- export type * from "./props";
5
- export type * from "./tick";
6
- export type * from "./dot";
7
- export type * from "./control";
@@ -1,124 +0,0 @@
1
- /**
2
- * <Area /> 차트 그라디언트 컬러 데이터
3
- */
4
- export type AreaGradientOptions = {
5
- /**
6
- * 렌더링 키
7
- */
8
- key: string;
9
- /**
10
- * 컬러 위치값
11
- */
12
- offset: string;
13
- /**
14
- * 컬러
15
- * - rgba
16
- * - hex + alpha
17
- */
18
- color: string;
19
- };
20
- /**
21
- * <Area /> 차트 그라디언트 옵션
22
- */
23
- export type AreaGradientProps = {
24
- /**
25
- * <linearGradient id="selectorId" />
26
- * <Area fill="url(#selectorId)" />
27
- */
28
- selectorId: string;
29
- gradient: AreaGradientOptions[];
30
- };
31
-
32
- /**
33
- * 차트 레전드; 기본 타입
34
- * @property {string} key - 렌더링 키
35
- * @property {string} axisCategory - y축 id
36
- * @property {string} code - 데이터 키
37
- * @property {string} name - 데이터 명칭
38
- * @property {string} [nameJsx] - 데이터 명칭
39
- * @property {string} unit - 데이터 단위
40
- * @property {string} color - 데이터 컬러
41
- * @property {string} [strokeColor] - 테두리 컬러
42
- * @property {string} [strokeStyle] - 테두리 스타일
43
- * @property {boolean} active - 데이터 활성화 여부 (레전드 토글 등)
44
- * @property {boolean} [highlight] - 포커스 구분
45
- */
46
- export interface ChartLegendBaseType {
47
- /**
48
- * 렌더링 키
49
- */
50
- key: string;
51
- /**
52
- * y축 id
53
- */
54
- axisCategory: string;
55
- /**
56
- * 데이터 키
57
- */
58
- code: string;
59
- /**
60
- * 커스텀 Dot
61
- */
62
- dot?: React.ReactNode;
63
- /**
64
- * 데이터 명칭
65
- */
66
- name: string;
67
- /**
68
- * 데이터 명칭 (JSX)
69
- */
70
- nameJsx?: React.ReactNode;
71
- /**
72
- * 데이터 단위
73
- */
74
- unit: string;
75
- /**
76
- * 데이터 컬러
77
- */
78
- color: string;
79
- /**
80
- * 데이터 활성화 여부 (레전드 토글 등)
81
- */
82
- active: boolean;
83
- // ------------------------------ style option 개편 필요
84
- /**
85
- * 테두리 컬러
86
- */
87
- strokeColor?: string;
88
- /**
89
- * 테두리 스타일
90
- */
91
- strokeStyle?: string;
92
- /**
93
- * 테두리 두께
94
- */
95
- strokeWidth?: number;
96
- /**
97
- * 포커스 구분
98
- */
99
- highlight?: boolean;
100
- /**
101
- * 투명도
102
- */
103
- opacity?: number;
104
- }
105
-
106
- /**
107
- * 차트 레전드; 데이터 포함 타입
108
- * @property {string} key - 렌더링 키
109
- * @property {string} axisCategory - y축 id
110
- * @property {string} code - 데이터 키
111
- * @property {string} name - 데이터 명칭
112
- * @property {React.ReactNode} value - 데이터값 표현
113
- * @property {string} unit - 데이터 단위
114
- * @property {string} color - 데이터 컬러
115
- * @property {boolean} active - 데이터 활성화 여부 (레전드 토글 등)
116
- * @property {boolean} [highlight] - 포커스 구분
117
- */
118
- export type ChartLegendDataType = ChartLegendBaseType & {
119
- /**
120
- * 표현될 데이터 값
121
- * - 단순 number, null로는 표현하기 힘든, 복합적인 표현 방식을 고려
122
- */
123
- value: React.ReactNode;
124
- };