@tipp/ui 1.2.21 → 1.3.1

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 (156) hide show
  1. package/dist/atoms/field-error-wrapper.js +2 -2
  2. package/dist/atoms/index.js +57 -57
  3. package/dist/atoms/pagination.js +2 -2
  4. package/dist/chunk-2UZBUVJL.js +123 -0
  5. package/dist/chunk-2UZBUVJL.js.map +1 -0
  6. package/dist/chunk-3AEOJKJI.js +123 -0
  7. package/dist/chunk-3AEOJKJI.js.map +1 -0
  8. package/dist/chunk-4LZTPZ5T.js +340 -0
  9. package/dist/chunk-4LZTPZ5T.js.map +1 -0
  10. package/dist/chunk-5X3BCQPR.js +128 -0
  11. package/dist/chunk-5X3BCQPR.js.map +1 -0
  12. package/dist/chunk-645IUNKJ.js +164 -0
  13. package/dist/chunk-645IUNKJ.js.map +1 -0
  14. package/dist/chunk-6F2NKWN6.js +128 -0
  15. package/dist/chunk-6F2NKWN6.js.map +1 -0
  16. package/dist/chunk-6IPYGPBK.js +145 -0
  17. package/dist/chunk-6IPYGPBK.js.map +1 -0
  18. package/dist/chunk-6QQPOAYW.js +145 -0
  19. package/dist/chunk-6QQPOAYW.js.map +1 -0
  20. package/dist/chunk-6YBBHIKU.js +340 -0
  21. package/dist/chunk-6YBBHIKU.js.map +1 -0
  22. package/dist/chunk-6ZAP2Q6K.js +1 -0
  23. package/dist/chunk-6ZAP2Q6K.js.map +1 -0
  24. package/dist/chunk-73RRM3PM.js +123 -0
  25. package/dist/chunk-73RRM3PM.js.map +1 -0
  26. package/dist/chunk-75PG3OYR.js +183 -0
  27. package/dist/chunk-75PG3OYR.js.map +1 -0
  28. package/dist/chunk-A5QAIT36.js +173 -0
  29. package/dist/chunk-A5QAIT36.js.map +1 -0
  30. package/dist/chunk-AQOEKDWM.js +145 -0
  31. package/dist/chunk-AQOEKDWM.js.map +1 -0
  32. package/dist/chunk-BVNXAZ4W.js +15 -0
  33. package/dist/chunk-BVNXAZ4W.js.map +1 -0
  34. package/dist/chunk-C2X3WJR3.js +183 -0
  35. package/dist/chunk-C2X3WJR3.js.map +1 -0
  36. package/dist/chunk-C4ELQHF2.js +145 -0
  37. package/dist/chunk-C4ELQHF2.js.map +1 -0
  38. package/dist/chunk-CG4SCRPG.js +123 -0
  39. package/dist/chunk-CG4SCRPG.js.map +1 -0
  40. package/dist/chunk-CTKB7XD7.js +173 -0
  41. package/dist/chunk-CTKB7XD7.js.map +1 -0
  42. package/dist/chunk-DGIUCAZZ.js +164 -0
  43. package/dist/chunk-DGIUCAZZ.js.map +1 -0
  44. package/dist/chunk-DYKEZ7NH.js +123 -0
  45. package/dist/chunk-DYKEZ7NH.js.map +1 -0
  46. package/dist/chunk-EMCXUIHP.js +161 -0
  47. package/dist/chunk-EMCXUIHP.js.map +1 -0
  48. package/dist/chunk-FA5LZP3V.js +161 -0
  49. package/dist/chunk-FA5LZP3V.js.map +1 -0
  50. package/dist/chunk-FIIIEJLL.js +164 -0
  51. package/dist/chunk-FIIIEJLL.js.map +1 -0
  52. package/dist/chunk-FYUX53KS.js +340 -0
  53. package/dist/chunk-FYUX53KS.js.map +1 -0
  54. package/dist/chunk-G3F273US.js +161 -0
  55. package/dist/chunk-G3F273US.js.map +1 -0
  56. package/dist/chunk-GNHIR74H.js +340 -0
  57. package/dist/chunk-GNHIR74H.js.map +1 -0
  58. package/dist/chunk-GOMNN3RB.js +164 -0
  59. package/dist/chunk-GOMNN3RB.js.map +1 -0
  60. package/dist/chunk-HLFIBPJT.js +123 -0
  61. package/dist/chunk-HLFIBPJT.js.map +1 -0
  62. package/dist/chunk-IE7LZPQS.js +161 -0
  63. package/dist/chunk-IE7LZPQS.js.map +1 -0
  64. package/dist/chunk-IM7DSIK2.js +128 -0
  65. package/dist/chunk-IM7DSIK2.js.map +1 -0
  66. package/dist/chunk-J3EDICNX.js +176 -0
  67. package/dist/chunk-J3EDICNX.js.map +1 -0
  68. package/dist/chunk-J75G72IG.js +123 -0
  69. package/dist/chunk-J75G72IG.js.map +1 -0
  70. package/dist/chunk-JOGHKB3I.js +123 -0
  71. package/dist/chunk-JOGHKB3I.js.map +1 -0
  72. package/dist/chunk-K5YOXMCZ.js +183 -0
  73. package/dist/chunk-K5YOXMCZ.js.map +1 -0
  74. package/dist/chunk-LCFIXFMZ.js +161 -0
  75. package/dist/chunk-LCFIXFMZ.js.map +1 -0
  76. package/dist/chunk-LPIEJIKD.js +130 -0
  77. package/dist/chunk-LPIEJIKD.js.map +1 -0
  78. package/dist/chunk-MV5RAZYM.js +130 -0
  79. package/dist/chunk-MV5RAZYM.js.map +1 -0
  80. package/dist/chunk-NFAO4ZOY.js +145 -0
  81. package/dist/chunk-NFAO4ZOY.js.map +1 -0
  82. package/dist/chunk-NFNLPXUN.js +161 -0
  83. package/dist/chunk-NFNLPXUN.js.map +1 -0
  84. package/dist/chunk-OAFZJPCX.js +127 -0
  85. package/dist/chunk-OAFZJPCX.js.map +1 -0
  86. package/dist/chunk-P3M2VZEC.js +169 -0
  87. package/dist/chunk-P3M2VZEC.js.map +1 -0
  88. package/dist/chunk-QQC7RJJV.js +145 -0
  89. package/dist/chunk-QQC7RJJV.js.map +1 -0
  90. package/dist/chunk-R4OEICEH.js +173 -0
  91. package/dist/chunk-R4OEICEH.js.map +1 -0
  92. package/dist/chunk-S7N3OJMB.js +164 -0
  93. package/dist/chunk-S7N3OJMB.js.map +1 -0
  94. package/dist/chunk-SJJRMOZT.js +123 -0
  95. package/dist/chunk-SJJRMOZT.js.map +1 -0
  96. package/dist/chunk-SK42QINW.js +183 -0
  97. package/dist/chunk-SK42QINW.js.map +1 -0
  98. package/dist/chunk-TVPONI3Y.js +340 -0
  99. package/dist/chunk-TVPONI3Y.js.map +1 -0
  100. package/dist/chunk-UNETGTV5.js +161 -0
  101. package/dist/chunk-UNETGTV5.js.map +1 -0
  102. package/dist/chunk-URPUEA3G.js +130 -0
  103. package/dist/chunk-URPUEA3G.js.map +1 -0
  104. package/dist/chunk-VCWF3AHX.js +173 -0
  105. package/dist/chunk-VCWF3AHX.js.map +1 -0
  106. package/dist/chunk-VEM3E4QK.js +175 -0
  107. package/dist/chunk-VEM3E4QK.js.map +1 -0
  108. package/dist/chunk-VGORTGYC.js +176 -0
  109. package/dist/chunk-VGORTGYC.js.map +1 -0
  110. package/dist/chunk-WB5DTU6Y.js +123 -0
  111. package/dist/chunk-WB5DTU6Y.js.map +1 -0
  112. package/dist/chunk-WHOLYNTB.js +123 -0
  113. package/dist/chunk-WHOLYNTB.js.map +1 -0
  114. package/dist/chunk-XNP73UIK.js +164 -0
  115. package/dist/chunk-XNP73UIK.js.map +1 -0
  116. package/dist/chunk-Y4QN32UT.js +340 -0
  117. package/dist/chunk-Y4QN32UT.js.map +1 -0
  118. package/dist/chunk-YD47UTWW.js +97 -0
  119. package/dist/chunk-YD47UTWW.js.map +1 -0
  120. package/dist/chunk-YDYRNWR7.js +128 -0
  121. package/dist/chunk-YDYRNWR7.js.map +1 -0
  122. package/dist/chunk-YQSWQ7WB.js +169 -0
  123. package/dist/chunk-YQSWQ7WB.js.map +1 -0
  124. package/dist/index.cjs +134 -4
  125. package/dist/index.cjs.map +1 -1
  126. package/dist/index.css +2055 -0
  127. package/dist/index.css.map +1 -1
  128. package/dist/index.d.cts +2 -1
  129. package/dist/index.d.ts +2 -1
  130. package/dist/index.js +85 -81
  131. package/dist/molecules/date-picker/index.js +2 -2
  132. package/dist/molecules/expand-table/index.js +25 -25
  133. package/dist/molecules/expand-table/row.js +24 -24
  134. package/dist/molecules/index.cjs +181 -38
  135. package/dist/molecules/index.cjs.map +1 -1
  136. package/dist/molecules/index.d.cts +3 -0
  137. package/dist/molecules/index.d.ts +3 -0
  138. package/dist/molecules/index.js +38 -33
  139. package/dist/molecules/learning-post.cjs +339 -0
  140. package/dist/molecules/learning-post.cjs.map +1 -0
  141. package/dist/molecules/learning-post.d.cts +22 -0
  142. package/dist/molecules/learning-post.d.ts +22 -0
  143. package/dist/molecules/learning-post.js +17 -0
  144. package/dist/molecules/learning-post.js.map +1 -0
  145. package/dist/molecules/navigation.js +25 -25
  146. package/dist/molecules/stepper.js +3 -3
  147. package/dist/molecules/tag-selector.js +25 -25
  148. package/dist/theme/theme-provider.cjs.map +1 -1
  149. package/dist/theme/theme-provider.d.cts +1 -1
  150. package/dist/theme/theme-provider.d.ts +1 -1
  151. package/dist/theme/theme-provider.js +1 -1
  152. package/dist/utils/index.js +3 -3
  153. package/package.json +3 -3
  154. package/src/molecules/index.ts +2 -1
  155. package/src/molecules/learning-post.tsx +143 -0
  156. package/src/theme/theme-provider.tsx +1 -1
@@ -1,10 +1,10 @@
1
1
  import "../chunk-DRBRT57F.js";
2
- import {
3
- getCellAlign
4
- } from "../chunk-A7CXRZIO.js";
5
2
  import {
6
3
  scrollTo
7
4
  } from "../chunk-ZXQZRIRS.js";
5
+ import {
6
+ getCellAlign
7
+ } from "../chunk-A7CXRZIO.js";
8
8
  import "../chunk-N552FDTV.js";
9
9
  export {
10
10
  getCellAlign,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tipp/ui",
3
- "version": "1.2.21",
3
+ "version": "1.3.1",
4
4
  "private": false,
5
5
  "sideEffects": false,
6
6
  "type": "module",
@@ -54,8 +54,8 @@
54
54
  "postcss-nesting": "12.0.2",
55
55
  "tsup": "^8.0.2",
56
56
  "typescript": "^5.3.3",
57
- "@tipp/eslint-config": "1.0.0",
58
- "@tipp/typescript-config": "1.0.0"
57
+ "@tipp/typescript-config": "1.0.0",
58
+ "@tipp/eslint-config": "1.0.0"
59
59
  },
60
60
  "scripts": {
61
61
  "build": "pnpm run build:js && pnpm run build:css",
@@ -5,4 +5,5 @@ export * from './dot-navigation';
5
5
 
6
6
  export * from './stepper';
7
7
 
8
- export * from './tag-selector';
8
+ export * from './tag-selector';
9
+ export * from './learning-post';
@@ -0,0 +1,143 @@
1
+ import React from 'react';
2
+ import type { ThemeProviderProps } from '../theme/theme-provider';
3
+ import { ThemeProvider } from '../theme/theme-provider';
4
+ import { Grid } from '../atoms/grid';
5
+ import { Flex } from '../atoms/flex';
6
+ import { Heading } from '../atoms/heading';
7
+ import { Typo } from '../atoms/typo';
8
+ import { AspectRatio } from '../atoms/aspect-ratio';
9
+ import { Badge } from '../atoms/badge';
10
+ import { Box } from '../atoms/box';
11
+ import { Button } from '../atoms/button';
12
+
13
+ interface Tag {
14
+ name?: string;
15
+ id: string;
16
+ }
17
+ export interface LearningPostProps {
18
+ defaultThemeProps?: Partial<ThemeProviderProps>;
19
+ html?: string;
20
+ title?: string;
21
+ metaDescription?: string;
22
+ /** 섬네일에 해당하는 이미지 컴포넌트 */
23
+ imageComp?: React.ReactElement;
24
+ tags?: Tag[];
25
+ children?: React.ReactElement;
26
+ onPageBack?: () => void;
27
+ }
28
+
29
+ export function LearningPost(props: LearningPostProps): React.ReactNode {
30
+ const {
31
+ defaultThemeProps,
32
+ html,
33
+ tags,
34
+ title,
35
+ metaDescription,
36
+ imageComp,
37
+ onPageBack,
38
+ children,
39
+ } = props;
40
+ return (
41
+ <ThemeProvider
42
+ {...defaultThemeProps}
43
+ accentColor="iris"
44
+ scaling="110%"
45
+ style={{}}
46
+ >
47
+ {html ? (
48
+ <Grid
49
+ columns={{ initial: '1', md: '130px 1fr 130px' }}
50
+ gap={{ initial: '2', md: '5' }}
51
+ height="100%"
52
+ justify="center"
53
+ pb="160px"
54
+ position="relative"
55
+ px="4"
56
+ width="100%"
57
+ >
58
+ <div />
59
+ <Flex
60
+ align="center"
61
+ direction="column"
62
+ maxWidth="880px"
63
+ mt={{ initial: '3', md: '8' }}
64
+ overflow="hidden"
65
+ width="100%"
66
+ >
67
+ <Grid align="start" columns={{ initial: '1', sm: '2' }} gap="2">
68
+ <Grid
69
+ gap="3"
70
+ mb={{ initial: '4', sm: '0' }}
71
+ style={{ alignSelf: 'flex-start' }}
72
+ >
73
+ <Heading
74
+ style={{
75
+ fontSize: '2.4rem',
76
+ lineHeight: 1.25,
77
+ wordBreak: 'keep-all',
78
+ }}
79
+ variant="heading1"
80
+ >
81
+ {title}
82
+ </Heading>
83
+ <Typo>{metaDescription}</Typo>
84
+ <Flex gap="1" wrap="wrap">
85
+ {tags?.map((el) => {
86
+ if (el.name?.startsWith('filter')) return;
87
+ return (
88
+ <Badge key={el.id} size="large" variant="solid">
89
+ {el.name}
90
+ </Badge>
91
+ );
92
+ })}
93
+ </Flex>
94
+ </Grid>
95
+
96
+ <AspectRatio
97
+ ratio={5 / 3}
98
+ style={{
99
+ overflow: 'hidden',
100
+ borderRadius: 'var(--radius-4)',
101
+ objectFit: 'cover',
102
+ }}
103
+ >
104
+ {imageComp}
105
+ </AspectRatio>
106
+ </Grid>
107
+
108
+ <Box mt="5" width="100%">
109
+ <div
110
+ className="gh-content"
111
+ dangerouslySetInnerHTML={{ __html: html }}
112
+ />
113
+ </Box>
114
+ </Flex>
115
+ {children}
116
+ </Grid>
117
+ ) : (
118
+ <Flex
119
+ align="center"
120
+ direction="column"
121
+ gap="6"
122
+ height="100%"
123
+ justify="center"
124
+ width="100%"
125
+ >
126
+ <Heading variant="heading1">콘텐츠를 찾을 수 없습니다.</Heading>
127
+ <Heading
128
+ align="center"
129
+ color="gray"
130
+ variant="heading4"
131
+ weight="regular"
132
+ >
133
+ {`요청하신 콘텐츠를 찾을 수 없습니다.
134
+ 잠시 후 다시 시도해주세요.`}
135
+ </Heading>
136
+ <Button onClick={onPageBack} size="large">
137
+ 뒤로가기
138
+ </Button>
139
+ </Flex>
140
+ )}
141
+ </ThemeProvider>
142
+ );
143
+ }
@@ -3,7 +3,7 @@ import { Theme } from '@radix-ui/themes';
3
3
 
4
4
  type ThemeProps = React.ComponentProps<typeof Theme>;
5
5
 
6
- interface ThemeProviderProps extends ThemeProps {
6
+ export interface ThemeProviderProps extends ThemeProps {
7
7
  children: React.ReactNode;
8
8
  }
9
9