@tipp/ui 1.4.6 → 1.4.8

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 (43) hide show
  1. package/dist/atoms/field-error-wrapper.js +2 -2
  2. package/dist/atoms/index.js +33 -33
  3. package/dist/atoms/pagination.js +2 -2
  4. package/dist/chunk-3CUUEWNJ.js +97 -0
  5. package/dist/chunk-3CUUEWNJ.js.map +1 -0
  6. package/dist/chunk-4GIK4KLW.js +190 -0
  7. package/dist/chunk-4GIK4KLW.js.map +1 -0
  8. package/dist/chunk-6E3RZKWT.js +340 -0
  9. package/dist/chunk-6E3RZKWT.js.map +1 -0
  10. package/dist/chunk-PCWEW2UL.js +80 -0
  11. package/dist/chunk-PCWEW2UL.js.map +1 -0
  12. package/dist/chunk-QAG24J3T.js +128 -0
  13. package/dist/chunk-QAG24J3T.js.map +1 -0
  14. package/dist/chunk-T5CA7NEI.js +164 -0
  15. package/dist/chunk-T5CA7NEI.js.map +1 -0
  16. package/dist/chunk-VR6Y66LP.js +190 -0
  17. package/dist/chunk-VR6Y66LP.js.map +1 -0
  18. package/dist/chunk-ZQLHJD5Q.js +192 -0
  19. package/dist/chunk-ZQLHJD5Q.js.map +1 -0
  20. package/dist/index.cjs +11 -9
  21. package/dist/index.cjs.map +1 -1
  22. package/dist/index.js +66 -66
  23. package/dist/molecules/date-picker/index.js +2 -2
  24. package/dist/molecules/expand-table/index.cjs +11 -9
  25. package/dist/molecules/expand-table/index.cjs.map +1 -1
  26. package/dist/molecules/expand-table/index.d.cts +1 -0
  27. package/dist/molecules/expand-table/index.d.ts +1 -0
  28. package/dist/molecules/expand-table/index.js +19 -19
  29. package/dist/molecules/expand-table/row.cjs +4 -4
  30. package/dist/molecules/expand-table/row.cjs.map +1 -1
  31. package/dist/molecules/expand-table/row.d.cts +2 -1
  32. package/dist/molecules/expand-table/row.d.ts +2 -1
  33. package/dist/molecules/expand-table/row.js +16 -16
  34. package/dist/molecules/index.cjs +11 -9
  35. package/dist/molecules/index.cjs.map +1 -1
  36. package/dist/molecules/index.js +26 -26
  37. package/dist/molecules/learning-post.js +4 -4
  38. package/dist/molecules/navigation.js +16 -16
  39. package/dist/molecules/stepper.js +3 -3
  40. package/dist/molecules/tag-selector.js +16 -16
  41. package/package.json +1 -1
  42. package/src/molecules/expand-table/index.tsx +7 -4
  43. package/src/molecules/expand-table/row.tsx +6 -3
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  FieldErrorWrapper
3
- } from "../chunk-QDZS4B6A.js";
4
- import "../chunk-52MVZ6AN.js";
3
+ } from "../chunk-DJN2IEY6.js";
5
4
  import "../chunk-25HMMI7R.js";
5
+ import "../chunk-52MVZ6AN.js";
6
6
  import "../chunk-N552FDTV.js";
7
7
  export {
8
8
  FieldErrorWrapper
@@ -1,4 +1,10 @@
1
1
  import "../chunk-76JGDATZ.js";
2
+ import {
3
+ Spinner
4
+ } from "../chunk-FR2GDOU2.js";
5
+ import {
6
+ Strong
7
+ } from "../chunk-74DX4CU7.js";
2
8
  import {
3
9
  Switch
4
10
  } from "../chunk-OYM4XCHQ.js";
@@ -18,6 +24,12 @@ import {
18
24
  ToastContainer,
19
25
  toast
20
26
  } from "../chunk-CYYWMYE7.js";
27
+ import {
28
+ RadioGroup
29
+ } from "../chunk-6DJOIRMF.js";
30
+ import {
31
+ Radio
32
+ } from "../chunk-FPD73OHW.js";
21
33
  import {
22
34
  ScrollArea
23
35
  } from "../chunk-ZKZDVS7G.js";
@@ -37,17 +49,17 @@ import {
37
49
  Skeleton
38
50
  } from "../chunk-5H3YPCZK.js";
39
51
  import {
40
- Spinner
41
- } from "../chunk-FR2GDOU2.js";
52
+ Inset
53
+ } from "../chunk-XQOL7UBI.js";
42
54
  import {
43
- Strong
44
- } from "../chunk-74DX4CU7.js";
55
+ Kbd
56
+ } from "../chunk-TULWX7D6.js";
45
57
  import {
46
58
  Link
47
59
  } from "../chunk-SIM6HKVI.js";
48
60
  import {
49
61
  Pagination
50
- } from "../chunk-IM7DSIK2.js";
62
+ } from "../chunk-5X3BCQPR.js";
51
63
  import {
52
64
  Popover
53
65
  } from "../chunk-5AVBYDPB.js";
@@ -61,11 +73,11 @@ import {
61
73
  RadioCards
62
74
  } from "../chunk-6IVCARWS.js";
63
75
  import {
64
- RadioGroup
65
- } from "../chunk-6DJOIRMF.js";
76
+ FieldErrorWrapper
77
+ } from "../chunk-DJN2IEY6.js";
66
78
  import {
67
- Radio
68
- } from "../chunk-FPD73OHW.js";
79
+ Flex
80
+ } from "../chunk-25HMMI7R.js";
69
81
  import {
70
82
  Form
71
83
  } from "../chunk-2CVXGGI5.js";
@@ -82,11 +94,11 @@ import {
82
94
  IconButton
83
95
  } from "../chunk-O3DNDMV3.js";
84
96
  import {
85
- Inset
86
- } from "../chunk-XQOL7UBI.js";
97
+ Collapse
98
+ } from "../chunk-LZJR77Q2.js";
87
99
  import {
88
- Kbd
89
- } from "../chunk-TULWX7D6.js";
100
+ Container
101
+ } from "../chunk-Q37G2GS6.js";
90
102
  import {
91
103
  DataList
92
104
  } from "../chunk-VTJZMOSP.js";
@@ -108,18 +120,18 @@ import {
108
120
  import {
109
121
  Tooltip
110
122
  } from "../chunk-ACVANQJ4.js";
123
+ import {
124
+ Typo
125
+ } from "../chunk-52MVZ6AN.js";
111
126
  import {
112
127
  Em
113
128
  } from "../chunk-2DZ2Y3JI.js";
114
129
  import {
115
- FieldErrorWrapper
116
- } from "../chunk-QDZS4B6A.js";
117
- import {
118
- Typo
119
- } from "../chunk-52MVZ6AN.js";
130
+ Box
131
+ } from "../chunk-4Y5BEXVN.js";
120
132
  import {
121
- Flex
122
- } from "../chunk-25HMMI7R.js";
133
+ Button
134
+ } from "../chunk-P3YCIJUP.js";
123
135
  import {
124
136
  Callout
125
137
  } from "../chunk-B6XJN6EC.js";
@@ -138,12 +150,7 @@ import {
138
150
  import {
139
151
  Code
140
152
  } from "../chunk-OHMOP5PV.js";
141
- import {
142
- Collapse
143
- } from "../chunk-LZJR77Q2.js";
144
- import {
145
- Container
146
- } from "../chunk-Q37G2GS6.js";
153
+ import "../chunk-66C4U3BG.js";
147
154
  import {
148
155
  AlertDialog
149
156
  } from "../chunk-J242TTFH.js";
@@ -162,13 +169,6 @@ import {
162
169
  import {
163
170
  Blockquote
164
171
  } from "../chunk-YGL6SWKN.js";
165
- import {
166
- Box
167
- } from "../chunk-4Y5BEXVN.js";
168
- import {
169
- Button
170
- } from "../chunk-P3YCIJUP.js";
171
- import "../chunk-66C4U3BG.js";
172
172
  import "../chunk-N552FDTV.js";
173
173
  export {
174
174
  AlertDialog,
@@ -1,9 +1,9 @@
1
1
  import {
2
2
  Pagination
3
- } from "../chunk-IM7DSIK2.js";
3
+ } from "../chunk-5X3BCQPR.js";
4
+ import "../chunk-25HMMI7R.js";
4
5
  import "../chunk-O3DNDMV3.js";
5
6
  import "../chunk-52MVZ6AN.js";
6
- import "../chunk-25HMMI7R.js";
7
7
  import "../chunk-66C4U3BG.js";
8
8
  import "../chunk-N552FDTV.js";
9
9
  export {
@@ -0,0 +1,97 @@
1
+ import {
2
+ IconButton
3
+ } from "./chunk-O3DNDMV3.js";
4
+ import {
5
+ ChevronLeftIcon,
6
+ ChevronRightIcon
7
+ } from "./chunk-66C4U3BG.js";
8
+ import {
9
+ Heading
10
+ } from "./chunk-HK224ADT.js";
11
+ import {
12
+ Flex
13
+ } from "./chunk-25HMMI7R.js";
14
+ import {
15
+ __objRest,
16
+ __spreadProps,
17
+ __spreadValues
18
+ } from "./chunk-N552FDTV.js";
19
+
20
+ // src/molecules/date-picker/index.tsx
21
+ import { forwardRef } from "react";
22
+ import * as RDP from "react-datepicker";
23
+ import { registerLocale, setDefaultLocale } from "react-datepicker";
24
+ import { ko as fnKo } from "date-fns/locale";
25
+ import { jsx, jsxs } from "react/jsx-runtime";
26
+ registerLocale("ko", fnKo);
27
+ setDefaultLocale("ko");
28
+ var ReactDatePicker = RDP.default.default || RDP.default || RDP;
29
+ var DatePicker = forwardRef(
30
+ (props, ref) => {
31
+ const _a = props, { size = "medium" } = _a, rest = __objRest(_a, ["size"]);
32
+ return /* @__PURE__ */ jsx(
33
+ ReactDatePicker,
34
+ __spreadProps(__spreadValues({
35
+ dateFormat: "YYYY/MM/dd",
36
+ nextMonthButtonLabel: "\uB2E4\uC74C \uB2EC",
37
+ placeholderText: "YYYY/mm/dd",
38
+ previousMonthButtonLabel: "\uC774\uC804 \uB2EC",
39
+ ref,
40
+ renderCustomHeader,
41
+ showPopperArrow: false,
42
+ timeIntervals: 10
43
+ }, rest), {
44
+ calendarClassName: `tipp_datePicker_calendar ${rest.calendarClassName || ""}`,
45
+ timeCaption: "\uC2DC\uAC04",
46
+ wrapperClassName: `tipp_datePicker ${size} ${rest.wrapperClassName || ""}`
47
+ })
48
+ );
49
+ }
50
+ );
51
+ DatePicker.displayName = "DatePicker";
52
+ var renderCustomHeader = (props) => {
53
+ const {
54
+ date,
55
+ decreaseMonth,
56
+ increaseMonth,
57
+ prevMonthButtonDisabled,
58
+ nextMonthButtonDisabled
59
+ } = props;
60
+ const year = date.getFullYear();
61
+ const month = date.getMonth();
62
+ return /* @__PURE__ */ jsxs(Flex, { align: "center", justify: "between", pb: "2", pl: "2", pr: "2", children: [
63
+ /* @__PURE__ */ jsx(
64
+ IconButton,
65
+ {
66
+ disabled: prevMonthButtonDisabled,
67
+ onClick: decreaseMonth,
68
+ variant: "ghost",
69
+ children: /* @__PURE__ */ jsx(ChevronLeftIcon, {})
70
+ }
71
+ ),
72
+ /* @__PURE__ */ jsxs(Flex, { gap: "3", children: [
73
+ /* @__PURE__ */ jsxs(Heading, { variant: "heading4", weight: "regular", children: [
74
+ year,
75
+ "\uB144"
76
+ ] }),
77
+ /* @__PURE__ */ jsxs(Heading, { variant: "heading4", weight: "regular", children: [
78
+ month + 1,
79
+ "\uC6D4"
80
+ ] })
81
+ ] }),
82
+ /* @__PURE__ */ jsx(
83
+ IconButton,
84
+ {
85
+ disabled: nextMonthButtonDisabled,
86
+ onClick: increaseMonth,
87
+ variant: "ghost",
88
+ children: /* @__PURE__ */ jsx(ChevronRightIcon, {})
89
+ }
90
+ )
91
+ ] });
92
+ };
93
+
94
+ export {
95
+ DatePicker
96
+ };
97
+ //# sourceMappingURL=chunk-3CUUEWNJ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/date-picker/index.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any -- ReactPicker의 렌더러가 object를 return함 버그를 해결하기 위해 강제 assertion 사용 */\n/* eslint-disable @typescript-eslint/no-unsafe-member-access -- ReactPicker의 렌더러가 object를 return함 버그를 해결하기 위해 강제 assertion 사용 */\nimport type { ElementRef } from 'react';\nimport React, { forwardRef } from 'react';\nimport type { DatePickerProps as ReactDatePickerProps } from 'react-datepicker';\nimport * as RDP from 'react-datepicker';\nimport { registerLocale, setDefaultLocale } from 'react-datepicker';\nimport { ko as fnKo } from 'date-fns/locale';\nimport { IconButton } from '../../atoms/icon-button';\nimport { Flex } from '../../atoms/flex';\nimport { ChevronLeftIcon, ChevronRightIcon } from '../../icon';\nimport { Heading } from '../../atoms/heading';\n\nregisterLocale('ko', fnKo);\nsetDefaultLocale('ko');\n\nexport type DatePickerProps = ReactDatePickerProps & {\n size?: 'small' | 'medium' | 'large';\n};\ntype DatePickerRef = ElementRef<typeof ReactDatePicker>;\n\nconst ReactDatePicker = ((RDP.default as any).default ||\n (RDP.default as any) ||\n (RDP as any)) as typeof RDP.default;\n\nexport const DatePicker = forwardRef<DatePickerRef, DatePickerProps>(\n (props, ref): React.ReactElement => {\n const { size = 'medium', ...rest } = props;\n return (\n <ReactDatePicker\n dateFormat=\"YYYY/MM/dd\"\n nextMonthButtonLabel=\"다음 달\"\n placeholderText=\"YYYY/mm/dd\"\n previousMonthButtonLabel=\"이전 달\"\n ref={ref}\n renderCustomHeader={renderCustomHeader}\n showPopperArrow={false}\n timeIntervals={10}\n {...rest}\n calendarClassName={`tipp_datePicker_calendar ${rest.calendarClassName || ''}`}\n timeCaption=\"시간\"\n wrapperClassName={`tipp_datePicker ${size} ${rest.wrapperClassName || ''}`}\n />\n );\n }\n);\n\nDatePicker.displayName = 'DatePicker';\n\nconst renderCustomHeader: ReactDatePickerProps['renderCustomHeader'] = (\n props\n) => {\n const {\n date,\n decreaseMonth,\n increaseMonth,\n prevMonthButtonDisabled,\n nextMonthButtonDisabled,\n } = props;\n\n const year = date.getFullYear();\n const month = date.getMonth();\n\n return (\n <Flex align=\"center\" justify=\"between\" pb=\"2\" pl=\"2\" pr=\"2\">\n <IconButton\n disabled={prevMonthButtonDisabled}\n onClick={decreaseMonth}\n variant=\"ghost\"\n >\n <ChevronLeftIcon />\n </IconButton>\n <Flex gap=\"3\">\n <Heading variant=\"heading4\" weight=\"regular\">\n {year}년\n </Heading>\n <Heading variant=\"heading4\" weight=\"regular\">\n {month + 1}월\n </Heading>\n </Flex>\n\n <IconButton\n disabled={nextMonthButtonDisabled}\n onClick={increaseMonth}\n variant=\"ghost\"\n >\n <ChevronRightIcon />\n </IconButton>\n </Flex>\n );\n};\n\n// DatePicker.displayName = 'DatePicker';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAGA,SAAgB,kBAAkB;AAElC,YAAY,SAAS;AACrB,SAAS,gBAAgB,wBAAwB;AACjD,SAAS,MAAM,YAAY;AAsBrB,cA4CE,YA5CF;AAhBN,eAAe,MAAM,IAAI;AACzB,iBAAiB,IAAI;AAOrB,IAAM,kBAAwB,YAAgB,WACvC,eACJ;AAEI,IAAM,aAAa;AAAA,EACxB,CAAC,OAAO,QAA4B;AAClC,UAAqC,YAA7B,SAAO,SA3BnB,IA2ByC,IAAT,iBAAS,IAAT,CAApB;AACR,WACE;AAAA,MAAC;AAAA;AAAA,QACC,YAAW;AAAA,QACX,sBAAqB;AAAA,QACrB,iBAAgB;AAAA,QAChB,0BAAyB;AAAA,QACzB;AAAA,QACA;AAAA,QACA,iBAAiB;AAAA,QACjB,eAAe;AAAA,SACX,OATL;AAAA,QAUC,mBAAmB,4BAA4B,KAAK,qBAAqB,EAAE;AAAA,QAC3E,aAAY;AAAA,QACZ,kBAAkB,mBAAmB,IAAI,IAAI,KAAK,oBAAoB,EAAE;AAAA;AAAA,IAC1E;AAAA,EAEJ;AACF;AAEA,WAAW,cAAc;AAEzB,IAAM,qBAAiE,CACrE,UACG;AACH,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI;AAEJ,QAAM,OAAO,KAAK,YAAY;AAC9B,QAAM,QAAQ,KAAK,SAAS;AAE5B,SACE,qBAAC,QAAK,OAAM,UAAS,SAAQ,WAAU,IAAG,KAAI,IAAG,KAAI,IAAG,KACtD;AAAA;AAAA,MAAC;AAAA;AAAA,QACC,UAAU;AAAA,QACV,SAAS;AAAA,QACT,SAAQ;AAAA,QAER,8BAAC,mBAAgB;AAAA;AAAA,IACnB;AAAA,IACA,qBAAC,QAAK,KAAI,KACR;AAAA,2BAAC,WAAQ,SAAQ,YAAW,QAAO,WAChC;AAAA;AAAA,QAAK;AAAA,SACR;AAAA,MACA,qBAAC,WAAQ,SAAQ,YAAW,QAAO,WAChC;AAAA,gBAAQ;AAAA,QAAE;AAAA,SACb;AAAA,OACF;AAAA,IAEA;AAAA,MAAC;AAAA;AAAA,QACC,UAAU;AAAA,QACV,SAAS;AAAA,QACT,SAAQ;AAAA,QAER,8BAAC,oBAAiB;AAAA;AAAA,IACpB;AAAA,KACF;AAEJ;","names":[]}
@@ -0,0 +1,190 @@
1
+ import {
2
+ Row
3
+ } from "./chunk-SOMDO7V4.js";
4
+ import {
5
+ TriangleArrowDownIcon
6
+ } from "./chunk-BSTJBBEX.js";
7
+ import {
8
+ TriangleArrowUpIcon
9
+ } from "./chunk-NDUKDKGB.js";
10
+ import {
11
+ Spinner
12
+ } from "./chunk-FR2GDOU2.js";
13
+ import {
14
+ Pagination
15
+ } from "./chunk-QAG24J3T.js";
16
+ import {
17
+ Typo
18
+ } from "./chunk-52MVZ6AN.js";
19
+ import {
20
+ Flex
21
+ } from "./chunk-25HMMI7R.js";
22
+
23
+ // src/molecules/expand-table/index.tsx
24
+ import {
25
+ flexRender,
26
+ getCoreRowModel,
27
+ useReactTable,
28
+ getSortedRowModel,
29
+ createColumnHelper,
30
+ getPaginationRowModel
31
+ } from "@tanstack/react-table";
32
+ import { useCallback, useMemo, useState } from "react";
33
+ import { jsx, jsxs } from "react/jsx-runtime";
34
+ function ExpandTable(props) {
35
+ const {
36
+ data,
37
+ columns,
38
+ ExpandComp,
39
+ placeholder,
40
+ onRowClick,
41
+ tableStyle,
42
+ showPagination,
43
+ isLoading,
44
+ pageIndex = 0,
45
+ pageSize = 10,
46
+ siblingCount = 2,
47
+ getRowStyle
48
+ } = props;
49
+ const defaultAlign = "left";
50
+ const [pagination, setPagination] = useState({
51
+ pageIndex: pageIndex || 0,
52
+ pageSize: pageSize || 9999
53
+ });
54
+ const [sorting, setSorting] = useState([]);
55
+ const { getRowModel, getHeaderGroups, setPageIndex } = useReactTable({
56
+ data: data || [],
57
+ columns,
58
+ getCoreRowModel: getCoreRowModel(),
59
+ getSortedRowModel: getSortedRowModel(),
60
+ state: {
61
+ sorting,
62
+ pagination
63
+ },
64
+ onSortingChange: setSorting,
65
+ getPaginationRowModel: getPaginationRowModel(),
66
+ onPaginationChange: setPagination
67
+ });
68
+ const gridColTemp = useMemo(() => {
69
+ return columns.map((col) => {
70
+ var _a;
71
+ if ((_a = col.meta) == null ? void 0 : _a.autoSize)
72
+ return "1fr";
73
+ return `${col.size || 150}px`;
74
+ }).join(" ");
75
+ }, [columns]);
76
+ const rowModels = getRowModel();
77
+ const onChangePagination = useCallback(
78
+ (page) => {
79
+ setPageIndex(page - 1);
80
+ },
81
+ [setPageIndex]
82
+ );
83
+ const helpCompRender = useCallback(
84
+ (rowLength) => {
85
+ if (isLoading) {
86
+ return /* @__PURE__ */ jsx(
87
+ Flex,
88
+ {
89
+ align: "center",
90
+ height: "100%",
91
+ justify: "center",
92
+ p: "5",
93
+ width: "100%",
94
+ children: /* @__PURE__ */ jsx(Spinner, {})
95
+ }
96
+ );
97
+ }
98
+ if (rowLength === 0) {
99
+ return /* @__PURE__ */ jsx("div", { className: "tr", children: /* @__PURE__ */ jsx(Flex, { align: "center", justify: "center", children: placeholder || /* @__PURE__ */ jsx(Typo, { color: "gray", mb: "6", mt: "6", variant: "body", children: "\uB370\uC774\uD130\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4" }) }) }, "expand_placeholder");
100
+ }
101
+ return null;
102
+ },
103
+ [isLoading, placeholder]
104
+ );
105
+ const pageCount = useMemo(() => {
106
+ if (!data)
107
+ return 0;
108
+ return Math.ceil(data.length / pageSize);
109
+ }, [data, pageSize]);
110
+ return /* @__PURE__ */ jsxs("div", { className: "expand-table", style: tableStyle, children: [
111
+ /* @__PURE__ */ jsx("div", { className: "thead", children: getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx(
112
+ "div",
113
+ {
114
+ className: "tr",
115
+ style: { gridTemplateColumns: gridColTemp },
116
+ children: headerGroup.headers.map((header) => {
117
+ var _a;
118
+ const sortable = header.column.getCanSort();
119
+ const sortedState = header.column.getIsSorted();
120
+ const justifyContent = ((_a = header.column.columnDef.meta) == null ? void 0 : _a.align) || defaultAlign;
121
+ return /* @__PURE__ */ jsx("div", { className: `${justifyContent} th`, children: /* @__PURE__ */ jsxs(
122
+ "button",
123
+ {
124
+ onClick: header.column.getToggleSortingHandler(),
125
+ style: sortable ? { cursor: "pointer" } : { cursor: "default" },
126
+ type: "button",
127
+ children: [
128
+ /* @__PURE__ */ jsx(Typo, { variant: "body", children: flexRender(
129
+ header.column.columnDef.header,
130
+ header.getContext()
131
+ ) }),
132
+ sortable ? /* @__PURE__ */ jsxs(
133
+ Flex,
134
+ {
135
+ direction: "column",
136
+ style: { marginLeft: "var(--space-2)" },
137
+ children: [
138
+ /* @__PURE__ */ jsx(
139
+ TriangleArrowUpIcon,
140
+ {
141
+ color: sortedState === "asc" ? "var(--iris-10)" : "var(--iris-6)"
142
+ }
143
+ ),
144
+ /* @__PURE__ */ jsx(
145
+ TriangleArrowDownIcon,
146
+ {
147
+ color: sortedState === "desc" ? "var(--iris-10)" : "var(--iris-6)"
148
+ }
149
+ )
150
+ ]
151
+ }
152
+ ) : null
153
+ ]
154
+ }
155
+ ) }, header.id);
156
+ })
157
+ },
158
+ headerGroup.id
159
+ )) }),
160
+ /* @__PURE__ */ jsx("div", { className: "tbody", children: helpCompRender(rowModels.rows.length) || rowModels.rows.map((row) => {
161
+ return /* @__PURE__ */ jsx(
162
+ Row,
163
+ {
164
+ ExpandComp,
165
+ defaultAlign,
166
+ getRowStyle,
167
+ gridColTemp,
168
+ onRowClick,
169
+ row
170
+ },
171
+ `row_${row.id}`
172
+ );
173
+ }) }),
174
+ showPagination ? /* @__PURE__ */ jsx(Flex, { justify: "end", pt: "3", width: "100%", children: /* @__PURE__ */ jsx(
175
+ Pagination,
176
+ {
177
+ count: pageCount,
178
+ onChange: onChangePagination,
179
+ page: pagination.pageIndex + 1,
180
+ siblingCount
181
+ }
182
+ ) }) : null
183
+ ] });
184
+ }
185
+
186
+ export {
187
+ createColumnHelper,
188
+ ExpandTable
189
+ };
190
+ //# sourceMappingURL=chunk-4GIK4KLW.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/molecules/expand-table/index.tsx"],"sourcesContent":["import type {\n ColumnDef,\n SortingState,\n RowData,\n Row as RowType,\n PaginationState,\n} from '@tanstack/react-table';\nimport type { CSSProperties } from 'react';\nimport {\n flexRender,\n getCoreRowModel,\n useReactTable,\n getSortedRowModel,\n createColumnHelper,\n getPaginationRowModel,\n} from '@tanstack/react-table';\nimport React, { useCallback, useMemo, useState } from 'react';\nimport { Flex, Pagination, Spinner, Typo } from '../../atoms';\nimport { TriangleArrowDownIcon } from '../../icons/down';\nimport { TriangleArrowUpIcon } from '../../icons/up';\nimport { Row, type ExpandComp, type OnRowClick } from './row';\n\nexport type { ExpandComp, OnRowClick, ColumnDef, RowType as Row };\nexport { createColumnHelper };\n\nexport interface ExpandTableProps<Datum extends RowData> {\n /** 렌더할 데이터 배열 */\n data?: Datum[];\n /** 테이블 컬럼의 메타 데이터 */\n columns: ColumnDef<Datum>[];\n /** Row의 open이 true인 경우 하단의 collapse에 렌더할 컴포넌트 */\n ExpandComp?: ExpandComp<Datum>;\n /** 데이테가 없을 시 화면에 표시할 컴포넌트 */\n placeholder?: React.ReactNode;\n /** 행 클릭 시 실행할 콜백 */\n onRowClick?: OnRowClick<Datum>;\n getRowStyle?: (data: Datum) => CSSProperties;\n tableStyle?: CSSProperties;\n isLoading?: boolean;\n\n /** pagination - 표시 유무 */\n showPagination?: boolean;\n /** pagination - 현재 선택된 페이지, 0부터 시작 */\n pageIndex?: number;\n /** pagination - 한 페이지에 표시될 컬럼 개수 */\n pageSize?: number;\n /** pagination - */\n siblingCount?: number;\n}\n\nexport function ExpandTable<Datum extends RowData>(\n props: ExpandTableProps<Datum>\n): React.ReactNode {\n const {\n data,\n columns,\n ExpandComp,\n placeholder,\n onRowClick,\n tableStyle,\n showPagination,\n isLoading,\n pageIndex = 0,\n pageSize = 10,\n siblingCount = 2,\n getRowStyle,\n } = props;\n const defaultAlign = 'left';\n const [pagination, setPagination] = useState<PaginationState>({\n pageIndex: pageIndex || 0,\n pageSize: pageSize || 9999,\n });\n\n const [sorting, setSorting] = useState<SortingState>([]);\n const { getRowModel, getHeaderGroups, setPageIndex } = useReactTable({\n data: data || [],\n columns,\n getCoreRowModel: getCoreRowModel(),\n getSortedRowModel: getSortedRowModel(),\n state: {\n sorting,\n pagination,\n },\n onSortingChange: setSorting,\n getPaginationRowModel: getPaginationRowModel(),\n onPaginationChange: setPagination,\n });\n\n const gridColTemp = useMemo<string>(() => {\n return columns\n .map((col) => {\n if (col.meta?.autoSize) return '1fr';\n return `${col.size || 150}px`;\n })\n .join(' ');\n }, [columns]);\n\n const rowModels = getRowModel();\n\n const onChangePagination = useCallback(\n (page: number) => {\n setPageIndex(page - 1);\n },\n [setPageIndex]\n );\n\n const helpCompRender = useCallback(\n (rowLength: number) => {\n if (isLoading) {\n return (\n <Flex\n align=\"center\"\n height=\"100%\"\n justify=\"center\"\n p=\"5\"\n width=\"100%\"\n >\n <Spinner />\n </Flex>\n );\n }\n if (rowLength === 0) {\n return (\n <div className=\"tr\" key=\"expand_placeholder\">\n <Flex align=\"center\" justify=\"center\">\n {placeholder || (\n <Typo color=\"gray\" mb=\"6\" mt=\"6\" variant=\"body\">\n 데이터가 없습니다\n </Typo>\n )}\n </Flex>\n </div>\n );\n }\n return null;\n },\n [isLoading, placeholder]\n );\n\n const pageCount = useMemo(() => {\n if (!data) return 0;\n return Math.ceil(data.length / pageSize);\n }, [data, pageSize]);\n\n return (\n <div className=\"expand-table\" style={tableStyle}>\n <div className=\"thead\">\n {getHeaderGroups().map((headerGroup) => (\n <div\n className=\"tr\"\n key={headerGroup.id}\n style={{ gridTemplateColumns: gridColTemp }}\n >\n {headerGroup.headers.map((header) => {\n const sortable = header.column.getCanSort();\n const sortedState = header.column.getIsSorted();\n const justifyContent =\n header.column.columnDef.meta?.align || defaultAlign;\n\n return (\n <div className={`${justifyContent} th`} key={header.id}>\n <button\n onClick={header.column.getToggleSortingHandler()}\n style={\n sortable ? { cursor: 'pointer' } : { cursor: 'default' }\n }\n type=\"button\"\n >\n <Typo variant=\"body\">\n {flexRender(\n header.column.columnDef.header,\n header.getContext()\n )}\n </Typo>\n {sortable ? (\n <Flex\n direction=\"column\"\n style={{ marginLeft: 'var(--space-2)' }}\n >\n <TriangleArrowUpIcon\n color={\n sortedState === 'asc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n <TriangleArrowDownIcon\n color={\n sortedState === 'desc'\n ? 'var(--iris-10)'\n : 'var(--iris-6)'\n }\n />\n </Flex>\n ) : null}\n </button>\n </div>\n );\n })}\n </div>\n ))}\n </div>\n <div className=\"tbody\">\n {/* 조건에 따라 placeholder 또는 loading 렌더*/}\n {helpCompRender(rowModels.rows.length) ||\n rowModels.rows.map((row) => {\n return (\n <Row\n ExpandComp={ExpandComp}\n defaultAlign={defaultAlign}\n getRowStyle={getRowStyle}\n gridColTemp={gridColTemp}\n key={`row_${row.id}`}\n onRowClick={onRowClick}\n row={row}\n />\n );\n })}\n </div>\n\n {showPagination ? (\n <Flex justify=\"end\" pt=\"3\" width=\"100%\">\n <Pagination\n count={pageCount}\n onChange={onChangePagination}\n page={pagination.pageIndex + 1}\n siblingCount={siblingCount}\n />\n </Flex>\n ) : null}\n </div>\n );\n}\n"],"mappings":"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","names":[]}