@tipp/ui 1.0.21 → 1.0.22

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 (47) hide show
  1. package/dist/atoms/drawer.js +2 -2
  2. package/dist/atoms/field-error-wrapper.js +2 -2
  3. package/dist/atoms/index.cjs +84 -154
  4. package/dist/atoms/index.cjs.map +1 -1
  5. package/dist/atoms/index.d.cts +1 -1
  6. package/dist/atoms/index.d.ts +1 -1
  7. package/dist/atoms/index.js +54 -58
  8. package/dist/atoms/pagination.js +3 -3
  9. package/dist/chunk-AGMMAML3.js +1 -0
  10. package/dist/chunk-AGMMAML3.js.map +1 -0
  11. package/dist/chunk-HHEG6S3Q.js +91 -0
  12. package/dist/chunk-HHEG6S3Q.js.map +1 -0
  13. package/dist/chunk-KHHXN3CH.js +1 -0
  14. package/dist/chunk-KHHXN3CH.js.map +1 -0
  15. package/dist/chunk-KSCEKSVS.js +91 -0
  16. package/dist/chunk-KSCEKSVS.js.map +1 -0
  17. package/dist/chunk-ZUAJNIBO.js +104 -0
  18. package/dist/chunk-ZUAJNIBO.js.map +1 -0
  19. package/dist/icon.d.cts +1 -1
  20. package/dist/icon.d.ts +1 -1
  21. package/dist/index.cjs +193 -193
  22. package/dist/index.cjs.map +1 -1
  23. package/dist/index.d.cts +2 -2
  24. package/dist/index.d.ts +2 -2
  25. package/dist/index.js +65 -65
  26. package/dist/molecules/date-picker/index.cjs +170 -0
  27. package/dist/molecules/date-picker/index.cjs.map +1 -0
  28. package/dist/molecules/date-picker/index.d.cts +10 -0
  29. package/dist/molecules/date-picker/index.d.ts +10 -0
  30. package/dist/molecules/date-picker/index.js +12 -0
  31. package/dist/molecules/date-picker/index.js.map +1 -0
  32. package/dist/molecules/expand-table/index.cjs +72 -158
  33. package/dist/molecules/expand-table/index.cjs.map +1 -1
  34. package/dist/molecules/expand-table/index.js +25 -26
  35. package/dist/molecules/expand-table/row.cjs +47 -133
  36. package/dist/molecules/expand-table/row.cjs.map +1 -1
  37. package/dist/molecules/expand-table/row.js +24 -25
  38. package/dist/molecules/index.cjs +153 -151
  39. package/dist/molecules/index.cjs.map +1 -1
  40. package/dist/molecules/index.js +32 -29
  41. package/dist/molecules/navigation.cjs +40 -126
  42. package/dist/molecules/navigation.cjs.map +1 -1
  43. package/dist/molecules/navigation.js +25 -26
  44. package/package.json +1 -1
  45. package/src/atoms/index.ts +1 -2
  46. package/src/{atoms → molecules}/date-picker/index.tsx +3 -3
  47. package/src/molecules/index.ts +1 -0
@@ -0,0 +1,104 @@
1
+ import {
2
+ IconButton
3
+ } from "./chunk-O3DNDMV3.js";
4
+ import {
5
+ Flex
6
+ } from "./chunk-25HMMI7R.js";
7
+ import {
8
+ Typo
9
+ } from "./chunk-O3XTRD7R.js";
10
+ import {
11
+ ChevronLeftIcon,
12
+ ChevronRightIcon
13
+ } from "./chunk-7PM2WTEA.js";
14
+ import {
15
+ __spreadProps,
16
+ __spreadValues
17
+ } from "./chunk-N552FDTV.js";
18
+
19
+ // src/atoms/pagination.tsx
20
+ import { useCallback, useEffect, useMemo, useState } from "react";
21
+ import { jsx, jsxs } from "react/jsx-runtime";
22
+ function Pagination(props) {
23
+ const { onChange, count = 0 } = props;
24
+ const siblingCount = 2;
25
+ const [page, setPage] = useState(() => props.page || props.defaultPage || 1);
26
+ const visibleItems = useMemo(() => {
27
+ let start = Math.max(1, page - siblingCount);
28
+ let end = Math.min(count, page + siblingCount);
29
+ if (page - siblingCount <= 0 && end < count) {
30
+ end = Math.min(count, end + Math.abs(page - siblingCount) + 1);
31
+ } else if (page + siblingCount > count && start > 1) {
32
+ start = Math.max(1, start - (page + siblingCount - count));
33
+ }
34
+ return Array.from({ length: end - start + 1 }, (_, i) => i + start);
35
+ }, [count, page]);
36
+ useEffect(() => {
37
+ onChange == null ? void 0 : onChange(page);
38
+ }, [onChange, page]);
39
+ useEffect(() => {
40
+ if (props.page) {
41
+ setPage(props.page);
42
+ }
43
+ }, [props.page]);
44
+ const onClickPrev = useCallback(() => {
45
+ setPage((prev) => Math.max(1, prev - 1));
46
+ }, []);
47
+ const onClickNext = useCallback(() => {
48
+ setPage((prev) => Math.min(count, prev + 1));
49
+ }, [count]);
50
+ const moveButtonProps = {
51
+ variant: "ghost",
52
+ size: "3",
53
+ style: { borderRadius: "50%" }
54
+ };
55
+ const iconSize = {
56
+ height: 24,
57
+ width: 24
58
+ };
59
+ const prevDisabled = useMemo(() => {
60
+ return page - siblingCount <= 1;
61
+ }, [page]);
62
+ const nextDisabled = useMemo(() => {
63
+ return page + siblingCount >= count;
64
+ }, [count, page]);
65
+ return /* @__PURE__ */ jsxs(Flex, { align: "center", className: "tipp-pagination", gap: "4", children: [
66
+ /* @__PURE__ */ jsx(
67
+ IconButton,
68
+ __spreadProps(__spreadValues({
69
+ disabled: prevDisabled,
70
+ onClick: onClickPrev
71
+ }, moveButtonProps), {
72
+ children: /* @__PURE__ */ jsx(ChevronLeftIcon, __spreadValues({}, iconSize))
73
+ })
74
+ ),
75
+ /* @__PURE__ */ jsx(Flex, { gap: "1", children: visibleItems.map((item) => {
76
+ return /* @__PURE__ */ jsx(
77
+ "button",
78
+ {
79
+ className: `page-button ${item === page ? "active" : ""}`,
80
+ onClick: () => {
81
+ setPage(item);
82
+ },
83
+ type: "button",
84
+ children: /* @__PURE__ */ jsx(Typo, { variant: "body", children: item })
85
+ },
86
+ item
87
+ );
88
+ }) }),
89
+ /* @__PURE__ */ jsx(
90
+ IconButton,
91
+ __spreadProps(__spreadValues({
92
+ disabled: nextDisabled,
93
+ onClick: onClickNext
94
+ }, moveButtonProps), {
95
+ children: /* @__PURE__ */ jsx(ChevronRightIcon, __spreadValues({}, iconSize))
96
+ })
97
+ )
98
+ ] });
99
+ }
100
+
101
+ export {
102
+ Pagination
103
+ };
104
+ //# sourceMappingURL=chunk-ZUAJNIBO.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/atoms/pagination.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { ChevronLeftIcon, ChevronRightIcon } from '../icon';\nimport type { IconButtonProps } from './icon-button';\nimport { IconButton } from './icon-button';\nimport { Flex } from './flex';\nimport { Typo } from './typo';\n\nexport interface PaginationProps {\n /** 현재 선택된 페이지 */\n page?: number;\n /** 기본 선택 페이지, page보다 낮은 우선 순위를 갖는다 */\n defaultPage?: number;\n /** 선택한 페이지 변경 이벤트 cb */\n onChange?: (page: number) => void;\n /** 전체 페이지의 수 */\n count?: number;\n}\n\nexport function Pagination(props: PaginationProps): React.ReactNode {\n const { onChange, count = 0 } = props;\n const siblingCount = 2;\n\n const [page, setPage] = useState(() => props.page || props.defaultPage || 1);\n\n const visibleItems = useMemo(() => {\n let start = Math.max(1, page - siblingCount);\n let end = Math.min(count, page + siblingCount);\n if (page - siblingCount <= 0 && end < count) {\n end = Math.min(count, end + Math.abs(page - siblingCount) + 1);\n } else if (page + siblingCount > count && start > 1) {\n start = Math.max(1, start - (page + siblingCount - count));\n }\n\n return Array.from({ length: end - start + 1 }, (_, i) => i + start);\n }, [count, page]);\n\n useEffect(() => {\n onChange?.(page);\n }, [onChange, page]);\n\n useEffect(() => {\n if (props.page) {\n setPage(props.page);\n }\n }, [props.page]);\n\n const onClickPrev = useCallback(() => {\n setPage((prev) => Math.max(1, prev - 1));\n }, []);\n\n const onClickNext = useCallback(() => {\n setPage((prev) => Math.min(count, prev + 1));\n }, [count]);\n\n const moveButtonProps: IconButtonProps = {\n variant: 'ghost',\n size: '3',\n style: { borderRadius: '50%' },\n };\n\n const iconSize = {\n height: 24,\n width: 24,\n };\n\n const prevDisabled = useMemo(() => {\n return page - siblingCount <= 1;\n }, [page]);\n\n const nextDisabled = useMemo(() => {\n return page + siblingCount >= count;\n }, [count, page]);\n\n return (\n <Flex align=\"center\" className=\"tipp-pagination\" gap=\"4\">\n <IconButton\n disabled={prevDisabled}\n onClick={onClickPrev}\n {...moveButtonProps}\n >\n <ChevronLeftIcon {...iconSize} />\n </IconButton>\n <Flex gap=\"1\">\n {visibleItems.map((item) => {\n return (\n <button\n className={`page-button ${item === page ? 'active' : ''}`}\n key={item}\n onClick={() => {\n setPage(item);\n }}\n type=\"button\"\n >\n <Typo variant=\"body\">{item}</Typo>\n </button>\n );\n })}\n </Flex>\n <IconButton\n disabled={nextDisabled}\n onClick={onClickNext}\n {...moveButtonProps}\n >\n <ChevronRightIcon {...iconSize} />\n </IconButton>\n </Flex>\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA,SAAgB,aAAa,WAAW,SAAS,gBAAgB;AA0E7D,SAMI,KANJ;AAxDG,SAAS,WAAW,OAAyC;AAClE,QAAM,EAAE,UAAU,QAAQ,EAAE,IAAI;AAChC,QAAM,eAAe;AAErB,QAAM,CAAC,MAAM,OAAO,IAAI,SAAS,MAAM,MAAM,QAAQ,MAAM,eAAe,CAAC;AAE3E,QAAM,eAAe,QAAQ,MAAM;AACjC,QAAI,QAAQ,KAAK,IAAI,GAAG,OAAO,YAAY;AAC3C,QAAI,MAAM,KAAK,IAAI,OAAO,OAAO,YAAY;AAC7C,QAAI,OAAO,gBAAgB,KAAK,MAAM,OAAO;AAC3C,YAAM,KAAK,IAAI,OAAO,MAAM,KAAK,IAAI,OAAO,YAAY,IAAI,CAAC;AAAA,IAC/D,WAAW,OAAO,eAAe,SAAS,QAAQ,GAAG;AACnD,cAAQ,KAAK,IAAI,GAAG,SAAS,OAAO,eAAe,MAAM;AAAA,IAC3D;AAEA,WAAO,MAAM,KAAK,EAAE,QAAQ,MAAM,QAAQ,EAAE,GAAG,CAAC,GAAG,MAAM,IAAI,KAAK;AAAA,EACpE,GAAG,CAAC,OAAO,IAAI,CAAC;AAEhB,YAAU,MAAM;AACd,yCAAW;AAAA,EACb,GAAG,CAAC,UAAU,IAAI,CAAC;AAEnB,YAAU,MAAM;AACd,QAAI,MAAM,MAAM;AACd,cAAQ,MAAM,IAAI;AAAA,IACpB;AAAA,EACF,GAAG,CAAC,MAAM,IAAI,CAAC;AAEf,QAAM,cAAc,YAAY,MAAM;AACpC,YAAQ,CAAC,SAAS,KAAK,IAAI,GAAG,OAAO,CAAC,CAAC;AAAA,EACzC,GAAG,CAAC,CAAC;AAEL,QAAM,cAAc,YAAY,MAAM;AACpC,YAAQ,CAAC,SAAS,KAAK,IAAI,OAAO,OAAO,CAAC,CAAC;AAAA,EAC7C,GAAG,CAAC,KAAK,CAAC;AAEV,QAAM,kBAAmC;AAAA,IACvC,SAAS;AAAA,IACT,MAAM;AAAA,IACN,OAAO,EAAE,cAAc,MAAM;AAAA,EAC/B;AAEA,QAAM,WAAW;AAAA,IACf,QAAQ;AAAA,IACR,OAAO;AAAA,EACT;AAEA,QAAM,eAAe,QAAQ,MAAM;AACjC,WAAO,OAAO,gBAAgB;AAAA,EAChC,GAAG,CAAC,IAAI,CAAC;AAET,QAAM,eAAe,QAAQ,MAAM;AACjC,WAAO,OAAO,gBAAgB;AAAA,EAChC,GAAG,CAAC,OAAO,IAAI,CAAC;AAEhB,SACE,qBAAC,QAAK,OAAM,UAAS,WAAU,mBAAkB,KAAI,KACnD;AAAA;AAAA,MAAC;AAAA;AAAA,QACC,UAAU;AAAA,QACV,SAAS;AAAA,SACL,kBAHL;AAAA,QAKC,8BAAC,oCAAoB,SAAU;AAAA;AAAA,IACjC;AAAA,IACA,oBAAC,QAAK,KAAI,KACP,uBAAa,IAAI,CAAC,SAAS;AAC1B,aACE;AAAA,QAAC;AAAA;AAAA,UACC,WAAW,eAAe,SAAS,OAAO,WAAW,EAAE;AAAA,UAEvD,SAAS,MAAM;AACb,oBAAQ,IAAI;AAAA,UACd;AAAA,UACA,MAAK;AAAA,UAEL,8BAAC,QAAK,SAAQ,QAAQ,gBAAK;AAAA;AAAA,QANtB;AAAA,MAOP;AAAA,IAEJ,CAAC,GACH;AAAA,IACA;AAAA,MAAC;AAAA;AAAA,QACC,UAAU;AAAA,QACV,SAAS;AAAA,SACL,kBAHL;AAAA,QAKC,8BAAC,qCAAqB,SAAU;AAAA;AAAA,IAClC;AAAA,KACF;AAEJ;","names":[]}
package/dist/icon.d.cts CHANGED
@@ -1,3 +1,3 @@
1
- export { BarChartIcon, BookmarkFilledIcon, BookmarkIcon, ChatBubbleIcon, ChevronLeftIcon, ChevronRightIcon, ClipboardIcon, Cross1Icon, DotsHorizontalIcon, DotsVerticalIcon, ExclamationTriangleIcon, ExitIcon, GearIcon, InfoCircledIcon, MagnifyingGlassIcon, MixerHorizontalIcon, Pencil1Icon, PersonIcon, PlusIcon } from '@radix-ui/react-icons';
1
+ export { BarChartIcon, BookmarkFilledIcon, BookmarkIcon, ChatBubbleIcon, ChevronDownIcon, ChevronLeftIcon, ChevronRightIcon, ChevronUpIcon, ClipboardIcon, Cross1Icon, DotsHorizontalIcon, DotsVerticalIcon, ExclamationTriangleIcon, ExitIcon, GearIcon, InfoCircledIcon, Link2Icon, MagnifyingGlassIcon, MixerHorizontalIcon, Pencil1Icon, PersonIcon, PlusIcon } from '@radix-ui/react-icons';
2
2
  import '@radix-ui/themes';
3
3
  import '@radix-ui/themes/dist/cjs/props/index.js';
package/dist/icon.d.ts CHANGED
@@ -1,3 +1,3 @@
1
- export { BarChartIcon, BookmarkFilledIcon, BookmarkIcon, ChatBubbleIcon, ChevronLeftIcon, ChevronRightIcon, ClipboardIcon, Cross1Icon, DotsHorizontalIcon, DotsVerticalIcon, ExclamationTriangleIcon, ExitIcon, GearIcon, InfoCircledIcon, MagnifyingGlassIcon, MixerHorizontalIcon, Pencil1Icon, PersonIcon, PlusIcon } from '@radix-ui/react-icons';
1
+ export { BarChartIcon, BookmarkFilledIcon, BookmarkIcon, ChatBubbleIcon, ChevronDownIcon, ChevronLeftIcon, ChevronRightIcon, ChevronUpIcon, ClipboardIcon, Cross1Icon, DotsHorizontalIcon, DotsVerticalIcon, ExclamationTriangleIcon, ExitIcon, GearIcon, InfoCircledIcon, Link2Icon, MagnifyingGlassIcon, MixerHorizontalIcon, Pencil1Icon, PersonIcon, PlusIcon } from '@radix-ui/react-icons';
2
2
  import '@radix-ui/themes';
3
3
  import '@radix-ui/themes/dist/cjs/props/index.js';