@j-solution/components 1.8.0 → 1.9.0

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 (79) hide show
  1. package/README.md +413 -415
  2. package/assets/jwms-portal-frontend-Ct2Tc7yj.css +1 -0
  3. package/assets/styles/j-components.css +1 -1
  4. package/assets/styles/themes.css +422 -422
  5. package/components/atoms/JButton.vue.cjs +1 -1
  6. package/components/atoms/JButton.vue.js +1 -1
  7. package/components/atoms/JButton.vue2.cjs.map +1 -1
  8. package/components/atoms/JButton.vue2.js.map +1 -1
  9. package/components/atoms/JLabel.vue.cjs.map +1 -1
  10. package/components/atoms/JLabel.vue.js.map +1 -1
  11. package/components/molecules/JTabs.vue.cjs +1 -1
  12. package/components/molecules/JTabs.vue.js +1 -1
  13. package/components/molecules/JTabs.vue2.cjs.map +1 -1
  14. package/components/molecules/JTabs.vue2.js.map +1 -1
  15. package/components/organisms/JDynamicTabs.vue.cjs.map +1 -1
  16. package/components/organisms/JDynamicTabs.vue.js.map +1 -1
  17. package/components/organisms/JFilterBar.vue.cjs +1 -1
  18. package/components/organisms/JFilterBar.vue.js +2 -2
  19. package/components/organisms/JFilterBar.vue2.cjs +1 -1
  20. package/components/organisms/JFilterBar.vue2.cjs.map +1 -1
  21. package/components/organisms/JFilterBar.vue2.js +14 -12
  22. package/components/organisms/JFilterBar.vue2.js.map +1 -1
  23. package/components/organisms/JPageContainer.vue.cjs.map +1 -1
  24. package/components/organisms/JPageContainer.vue.js.map +1 -1
  25. package/components/organisms/JSidebar/JSidebar.vue.cjs +2 -0
  26. package/components/organisms/JSidebar/JSidebar.vue.cjs.map +1 -0
  27. package/components/organisms/JSidebar/JSidebar.vue.js +189 -0
  28. package/components/organisms/JSidebar/JSidebar.vue.js.map +1 -0
  29. package/components/organisms/JSidebar/JSidebar.vue2.cjs +2 -0
  30. package/components/organisms/JSidebar/JSidebar.vue2.cjs.map +1 -0
  31. package/components/organisms/JSidebar/JSidebar.vue2.js +5 -0
  32. package/components/organisms/JSidebar/JSidebar.vue2.js.map +1 -0
  33. package/components/organisms/JSidebar/JSidebarGroup.vue.cjs +2 -0
  34. package/components/organisms/JSidebar/JSidebarGroup.vue.cjs.map +1 -0
  35. package/components/organisms/JSidebar/JSidebarGroup.vue.js +89 -0
  36. package/components/organisms/JSidebar/JSidebarGroup.vue.js.map +1 -0
  37. package/components/organisms/JSidebar/JSidebarGroup.vue2.cjs +2 -0
  38. package/components/organisms/JSidebar/JSidebarGroup.vue2.cjs.map +1 -0
  39. package/components/organisms/JSidebar/JSidebarGroup.vue2.js +5 -0
  40. package/components/organisms/JSidebar/JSidebarGroup.vue2.js.map +1 -0
  41. package/components/organisms/JSidebar/JSidebarItem.vue.cjs +2 -0
  42. package/components/organisms/JSidebar/JSidebarItem.vue.cjs.map +1 -0
  43. package/components/organisms/JSidebar/JSidebarItem.vue.js +79 -0
  44. package/components/organisms/JSidebar/JSidebarItem.vue.js.map +1 -0
  45. package/components/organisms/JSidebar/JSidebarItem.vue2.cjs +2 -0
  46. package/components/organisms/JSidebar/JSidebarItem.vue2.cjs.map +1 -0
  47. package/components/organisms/JSidebar/JSidebarItem.vue2.js +5 -0
  48. package/components/organisms/JSidebar/JSidebarItem.vue2.js.map +1 -0
  49. package/components/shadcn/Card.vue.cjs.map +1 -1
  50. package/components/shadcn/Card.vue.js.map +1 -1
  51. package/components/shadcn/CardContent.vue.cjs.map +1 -1
  52. package/components/shadcn/CardContent.vue.js.map +1 -1
  53. package/components/shadcn/CardHeader.vue.cjs.map +1 -1
  54. package/components/shadcn/CardHeader.vue.js.map +1 -1
  55. package/components/shadcn/Input.vue.cjs.map +1 -1
  56. package/components/shadcn/Input.vue.js.map +1 -1
  57. package/components/shadcn/SelectTrigger.vue.cjs.map +1 -1
  58. package/components/shadcn/SelectTrigger.vue.js.map +1 -1
  59. package/components/shadcn/TabsContent.vue.cjs.map +1 -1
  60. package/components/shadcn/TabsContent.vue.js.map +1 -1
  61. package/components/shadcn/Textarea.vue.cjs.map +1 -1
  62. package/components/shadcn/Textarea.vue.js.map +1 -1
  63. package/components/shadcn/index.cjs.map +1 -1
  64. package/components/shadcn/index.js.map +1 -1
  65. package/components/templates/JLayout.vue.cjs.map +1 -1
  66. package/components/templates/JLayout.vue.js.map +1 -1
  67. package/components/templates/JLayoutSimple.vue.cjs +1 -1
  68. package/components/templates/JLayoutSimple.vue.cjs.map +1 -1
  69. package/components/templates/JLayoutSimple.vue.js +36 -30
  70. package/components/templates/JLayoutSimple.vue.js.map +1 -1
  71. package/index.cjs +1 -1
  72. package/index.js +22 -20
  73. package/package.json +1 -1
  74. package/types/index.d.ts +119 -61
  75. package/types/sidebar.types.cjs +2 -0
  76. package/types/sidebar.types.cjs.map +1 -0
  77. package/types/sidebar.types.js +5 -0
  78. package/types/sidebar.types.js.map +1 -0
  79. package/assets/jwms-portal-frontend-BtHTA-UF.css +0 -1
package/README.md CHANGED
@@ -1,416 +1,414 @@
1
- # J-Component
2
-
3
- > Vue.js 3 기반 Atomic Design 패턴 컴포넌트 라이브러리
4
-
5
- ## 📋 프로젝트 개요
6
-
7
- J-Component는 Vue.js 3와 TypeScript를 기반으로 한 재사용 가능한 UI 컴포넌트 라이브러리입니다. shadcn/ui 디자인 시스템과 Atomic Design 패턴을 적용하여 일관성 있고 확장 가능한 컴포넌트를 제공합니다.
8
-
9
- ## 🚀 현재 버전: v1.8.0
10
-
11
- **최신 업데이트 (2026년 2월 20일)**
12
- - **신규 컴포넌트**: JSectionTitle(atom), JEmptyState(molecule), JShuttle(organism) 추가
13
- - **커스터마이징 API 일관성 개선**: JTabs/JDynamicTabs `className` `class` 통일, JTitlebar/JLabel/JFormField/JGrid/JFilterBar에 `class` prop 추가
14
- - **UI 컴팩트 디자인 강화**: `rounded-md` `rounded-sm` 통일, TabsList 하단 보더 스타일, Card/PageContainer 패딩 축소
15
- - **JSplitter 핸들 스타일 추가**: hover/active 시각적 피드백, 커서 변경
16
- - **JDynamicMenuItem 스타일 개선**: primary 색상 활성 상태, 트리 라인 표시
17
-
18
- [전체 릴리즈 노트 보기](./RELEASE_NOTES.md)
19
-
20
- ## 🛠️ 기술 스택
21
-
22
- ### 핵심 프레임워크
23
- - **Vue.js 3.5** - 프론트엔드 프레임워크
24
- - **TypeScript 5.9** - 타입 시스템
25
- - **Vite 7** - 빌드 도구
26
-
27
- ### UI & 스타일링
28
- - **TailwindCSS 3.4** - 유틸리티 CSS 프레임워크
29
- - **shadcn/ui** - 디자인 시스템 (radix-vue 기반)
30
- - **Lucide Icons** - 아이콘 라이브러리
31
-
32
- ### 개발 도구
33
- - **Storybook 9** - 컴포넌트 문서화 테스트
34
- - Docs 탭: 다양한 스키마/도메인 예시 자동 미리보기 지원
35
- - 테마 셀렉터: 8가지 tweakcn 테마 지원 (Default, Slate, Rose, Blue, Green, Purple, Orange, Vescrow)
36
- - 다크모드 토글: 라이트/다크 모드 실시간 전환
37
- - **ESLint 9** - 코드 품질 검사
38
- - **Prettier** - 코드 포맷팅
39
-
40
- ## 📁 프로젝트 구조
41
-
42
- ```
43
- jwms-portal-frontend/
44
- ├── src/
45
- │ ├── components/ # Atomic Design Components
46
- │ │ ├── atoms/ # 기본 UI 요소 (JButton, JInput, JIcon 등)
47
- │ │ ├── molecules/ # atoms의 조합 (JFormField, JCard, JAlert 등)
48
- │ │ ├── organisms/ # molecules의 조합 (JModal, JDynamicTabs, JDynamicForm 등)
49
- ├── shadcn/ # shadcn 컴포넌트 래핑
50
- │ └── templates/ # 페이지 레이아웃
51
- │ ├── stories/ # Storybook 스토리
52
- ├── types/ # TypeScript 타입 정의
53
- ├── composables/ # Vue Composition Functions
54
- └── services/ # API 서비스
55
- ├── docs/ # 컴포넌트 사용 가이드
56
- └── dist/ # 빌드 결과물
57
- ```
58
-
59
- ## 🚀 시작하기
60
-
61
- ### 설치
62
-
63
- ```bash
64
- # 저장소 클론
65
- git clone <repository-url>
66
- cd J-Component
67
-
68
- # 의존성 설치
69
- cd jwms-portal-frontend
70
- npm install
71
- # 또는
72
- pnpm install
73
- ```
74
-
75
- ### 개발 서버 실행
76
-
77
- ```bash
78
- # 개발 서버 시작 (http://localhost:5173)
79
- npm run dev
80
- ```
81
-
82
- ### Storybook 실행
83
-
84
- ```bash
85
- # Storybook 시작 (http://localhost:6006)
86
- npm run storybook
87
- ```
88
-
89
- **Storybook 기능:**
90
- - 다양한 레이아웃/스키마(검색, 개인정보, 섹션, Wizard 등)와 Args/Docs 자동 문서 예시 확인 가능
91
- - 툴바에서 테마 선택 (Default, Slate, Rose, Blue, Green)
92
- - 다크모드 토글로 라이트/다크 모드 전환
93
-
94
- ### 빌드
95
-
96
- ```bash
97
- # 프로덕션 빌드
98
- npm run build
99
-
100
- # 빌드 결과 미리보기
101
- npm run preview
102
- ```
103
-
104
- ## 📚 주요 컴포넌트
105
-
106
- ### Atoms (기본 요소)
107
- - **JButton** - 버튼 컴포넌트
108
- - **JInput** - 입력 필드
109
- - **JIcon** - 아이콘 컴포넌트
110
- - **JLabel** - 라벨 컴포넌트
111
- - **JBadge** - 배지 컴포넌트
112
- - **JProgress** - 진행률 표시
113
- - **JSpinner** - 로딩 스피너
114
- - **JGrid** - AG Grid 기반 데이터 그리드 컴포넌트 (Enterprise 기능 지원: 그룹핑, 피벗, Excel 내보내기)
115
-
116
- ### Molecules (조합 요소)
117
- - **JFormField** - 필드 래퍼
118
- - **JCard** - 카드 컴포넌트
119
- - **JAlert** - 알림 컴포넌트
120
- - **JAccordion** - 아코디언 컴포넌트
121
- - **JContextMenu** - 컨텍스트 메뉴
122
- - **JSearchAddr** - 주소 검색 컴포넌트
123
- - **JTabs** - 컴포넌트 ( 전환 이벤트 처리 개선, component 속성 활용 지원)
124
- - **JButtonGroup** - 버튼 그룹 컴포넌트 (구분선 자동 표시 지원)
125
- - **JTitlebar** - 타이틀바 컴포넌트 (제목, 설명, 팝오버 기능)
126
-
127
- ### Organisms (복합 요소)
128
- - **JModal** - 모달 컴포넌트 (size prop 지원: sm, md, lg, xl, 2xl, full)
129
- - **JDynamicTabs** - 동적 관리
130
- - **JDynamicForm** - 스키마 기반 동적 (기본/섹션/다단계, Docs 탭/다양한 예시 참조)
131
- - **JFormModal** - JDynamicForm 기반 동적 모달 컴포넌트 (size prop 지원)
132
- - **JSearchPanel** - JDynamicForm 기반 재사용 가능한 검색 패널 (Collapsible, 조건 요약, 초기화 기능 지원)
133
- - **JSidebarAdvanced** - 고급 사이드바 (검색, 즐겨찾기, 다단계 메뉴 지원)
134
- - **JSidebarSimple** - 간단한 사이드바 (다단계 메뉴, 검색 지원)
135
-
136
- ### Templates (레이아웃)
137
- - **JLayoutAdvanced** - 고급 레이아웃 (JHeader + JSidebarAdvanced + JDynamicTabs 조합)
138
- - **JLayoutSimple** - 간단한 레이아웃 (JHeader + JSidebarSimple + JPageContainer 조합)
139
-
140
- ## 📖 사용 예시
141
-
142
- > 💡 **컴포넌트 사용 가이드**: [사용 가이드](./docs/USAGE_GUIDE.md)에서 JDynamicTabs 경로 기반 컴포넌트 로딩 방법 등 상세 가이드를 확인하세요.
143
-
144
- ### NPM 패키지 사용 (권장)
145
-
146
- ```vue
147
- <template>
148
- <div class="p-4">
149
- <JButton variant="primary" @click="handleClick">
150
- 클릭하세요
151
- </JButton>
152
-
153
- <JFormField label="이름" required>
154
- <JInput v-model="name" placeholder="이름을 입력하세요" />
155
- </JFormField>
156
-
157
- <JAlert type="info" title="알림">
158
- 이것은 정보 알림입니다.
159
- </JAlert>
160
- </div>
161
- </template>
162
-
163
- <script setup>
164
- import { ref } from 'vue'
165
- import { JButton, JFormField, JInput, JAlert } from '@j-solution/components'
166
- // CSS는 자동으로 포함됩니다 - 별도 import 불필요
167
-
168
- const name = ref('')
169
-
170
- const handleClick = () => {
171
- console.log('버튼 클릭됨')
172
- }
173
- </script>
174
- ```
175
-
176
- > 💡 **참고**: NPM 패키지는 패키지 진입점에서 CSS가 자동으로 import되므로, 컴포넌트만 import하면 스타일이 자동으로 적용됩니다.
177
-
178
- ### Standard 방식 사용 (파일 복사)
179
-
180
- ```vue
181
- <template>
182
- <div class="p-4">
183
- <JButton variant="primary" @click="handleClick">
184
- 클릭하세요
185
- </JButton>
186
-
187
- <JFormField label="이름" required>
188
- <JInput v-model="name" placeholder="이름을 입력하세요" />
189
- </JFormField>
190
-
191
- <JAlert type="info" title="알림">
192
- 이것은 정보 알림입니다.
193
- </JAlert>
194
- </div>
195
- </template>
196
-
197
- <script setup>
198
- import { ref } from 'vue'
199
- import { JButton, JFormField, JInput, JAlert } from '@/components'
200
-
201
- const name = ref('')
202
-
203
- const handleClick = () => {
204
- console.log('버튼 클릭됨')
205
- }
206
- </script>
207
- ```
208
-
209
- ### 주소 검색 컴포넌트
210
-
211
- ```vue
212
- <template>
213
- <JSearchAddr
214
- v-model="address"
215
- @select="handleAddressSelect"
216
- placeholder="주소를 검색하세요"
217
- />
218
- </template>
219
-
220
- <script setup>
221
- import { ref } from 'vue'
222
- import { JSearchAddr } from '@/components/molecules'
223
-
224
- const address = ref('')
225
-
226
- const handleAddressSelect = (selectedAddress) => {
227
- console.log('선택된 주소:', selectedAddress)
228
- }
229
- </script>
230
- ```
231
-
232
- ## 📚 문서 가이드
233
-
234
- > **모든 문서는 이 README.md를 기준으로 연결되어 있습니다.**
235
-
236
- ### 📖 주요 문서
237
-
238
- | 문서 | 설명 | 대상 |
239
- |------|------|------|
240
- | **[설치 가이드](./docs/INSTALLATION_GUIDE.md)** | 처음 설치하는 방법 | Standard 방식, NPM 방식 설치 가이드 |
241
- | **[업데이트 가이드](./docs/UPDATE_GUIDE.md)** | 버전 업데이트 방법 | Standard 방식, NPM 방식 업데이트 가이드 |
242
- | **[사용 가이드](./docs/USAGE_GUIDE.md)** | 컴포넌트 사용 방법 | 컴포넌트 목록, 사용 예시, 권장사항 |
243
- | **[릴리즈 노트](./RELEASE_NOTES.md)** | 버전별 변경사항 | 모든 버전의 변경 이력 |
244
-
245
- ### 📦 패키지 문서
246
-
247
- 패키지에 포함된 문서들 (원본: `docs/` 디렉토리):
248
-
249
- - **`packages/v{version}/README.md`**: 패키지 소개 및 설치 방법
250
- - **`packages/v{version}/USAGE_GUIDE.md`**: 컴포넌트 사용 가이드
251
- - **`packages/v{version}/UPDATE_GUIDE.md`**: 버전 업데이트 가이드
252
-
253
- > 💡 **참고**: 패키지 문서는 `docs/` 디렉토리의 원본을 기반으로 패키징 시 자동으로 포함됩니다.
254
-
255
- ### 🗺️ 문서 구조
256
-
257
- ```
258
- J-Component/
259
- ├── README.md # 메인 문서 (이 파일)
260
- ├── RELEASE_NOTES.md # 릴리즈 노트
261
- ├── docs/ # 문서 원본
262
- ├── INSTALLATION_GUIDE.md # 설치 가이드
263
- │ ├── UPDATE_GUIDE.md # 업데이트 가이드
264
- └── USAGE_GUIDE.md # 사용 가이드
265
- └── packages/ # 배포 패키지
266
- └── v{version}/
267
- ├── README.md # (docs에서 복사)
268
- ├── USAGE_GUIDE.md # (docs에서 복사)
269
- └── UPDATE_GUIDE.md # (docs에서 복사)
270
- ```
271
-
272
- ---
273
-
274
- ## 📦 컴포넌트 패키징 배포
275
-
276
- > **⚠️ 중요**: 패키지를 생성하거나 버전을 업데이트하기 전에 **반드시** 다음 문서를 참조하세요:
277
- > - **상세 가이드**: [`jwms-portal-frontend/PACKAGING.md`](./jwms-portal-frontend/PACKAGING.md)
278
- > - **빠른 참조**: [`PACKAGING_GUIDE.md`](./PACKAGING_GUIDE.md)
279
-
280
- J-Component는 **두 가지 배포 방식**을 지원합니다:
281
-
282
- ### 🚀 통합 패키징 (권장)
283
-
284
- **하나의 명령어로 두 가지 방식 모두 생성:**
285
-
286
- ```bash
287
- cd jwms-portal-frontend
288
- npm run package
289
- ```
290
-
291
- 명령어는 다음을 자동으로 실행합니다:
292
- 1. **Standard 방식**: `packages/v{version}/` 디렉토리에 파일 복사 방식 패키지 생성
293
- 2. **NPM 방식**: `dist/npm/` 디렉토리에 npm 패키지 생성
294
-
295
- ### 1) Standard 방식 (파일 복사)
296
-
297
- - **출력 위치**: `packages/v{version}/`
298
- - **사용 방법**: 타겟 프로젝트에 파일을 직접 복사하여 사용
299
- - **특징**:
300
- - 기존 프로젝트 구조와 동일
301
- - Git에 커밋 가능 (버전별 스냅샷)
302
- - `packages/latest/standard/`에 최신 버전 포인터 제공
303
-
304
- ### 2) NPM 방식 (npm 패키지)
305
-
306
- - **출력 위치**: `dist/npm/`
307
- - **사용 방법**:
308
- - 로컬 테스트: `npm install file:../path/to/dist/npm`
309
- - npm 레지스트리: `npm install @j-solution/components` (배포 후)
310
- - **특징**:
311
- - ES Module + CommonJS + TypeScript 타입 정의 포함
312
- - 가상 모듈 자동 인라인 처리
313
- - `dist` 디렉토리는 `.gitignore`에 포함 (빌드 시 자동 생성)
314
-
315
- #### NPM 패키지 배포
316
-
317
- ```bash
318
- # 로컬에서 빌드 및 배포
319
- cd jwms-portal-frontend/dist/npm
320
- npm publish --access public
321
- # 또는
322
- pnpm publish --access public
323
- ```
324
-
325
- #### 자동 배포 (GitHub Actions)
326
- - GitHub에서 Release를 생성하면 자동으로 npm 레지스트리에 배포
327
- - `.github/workflows/publish-npm.yml` 워크플로우 자동 실행
328
- - `NPM_TOKEN` 시크릿 필요
329
-
330
- ### ⚠️ 중요 사항
331
-
332
- - **v1.0.0부터 namespaced 방식 지원 중단**
333
- - 기존: standard, namespaced, npm (3가지)
334
- - 현재: standard, npm (2가지)
335
- - namespaced 방식은 npm 방식으로 대체됨
336
-
337
- ### 개별 패키징
338
-
339
- 필요한 경우 개별로 실행할 수 있습니다:
340
-
341
- ```bash
342
- # Standard 방식만
343
- npm run package:standard
344
-
345
- # NPM 방식만
346
- npm run package:npm
347
- ```
348
-
349
- 자세한 내용: [PACKAGING.md](./jwms-portal-frontend/PACKAGING.md)
350
-
351
- > 💡 **설치 및 업데이트 방법**: [설치 가이드](./docs/INSTALLATION_GUIDE.md) 및 [업데이트 가이드](./docs/UPDATE_GUIDE.md)를 참고하세요.
352
-
353
- ### 패키지 다운로드
354
-
355
- 패키지 폴더만 다운로드하는 방법 (전체 리포지토리 클론 불필요):
356
-
357
- **⭐ 추천: Git Sparse Checkout** (패키지 폴더만 다운로드):
358
- ```bash
359
- # Public 리포지토리
360
- git clone --depth 1 --filter=blob:none --sparse <repository-url>
361
- cd J-Component
362
- git sparse-checkout set packages/v1.0.0
363
- # 또는 packages/latest/standard
364
-
365
- # Private 리포지토리 (인증 필요)
366
- git clone --depth 1 --filter=blob:none --sparse git@github.com:<username>/<repository>.git
367
- cd J-Component
368
- git sparse-checkout set packages/v1.0.0
369
- ```
370
-
371
- **다른 방법들**:
372
- - GitHub 인터페이스에서 특정 디렉토리 ZIP 다운로드
373
- - GitHub API 사용
374
- - Git Submodule 사용
375
-
376
- > **📝 참고**: 각 패키지의 `README.md`에 상세한 다운로드 방법이 안내되어 있습니다.
377
-
378
- ## 🔧 개발 가이드
379
-
380
- ### 컴포넌트 작성 규칙
381
-
382
- 1. **Atomic Design 패턴** 준수
383
- 2. **TypeScript** 타입 정의 필수
384
- 3. **Props** 인터페이스 정의
385
- 4. **Storybook** 스토리 작성
386
- 5. **Tailwind CSS** 스타일링
387
-
388
- ### 컴포넌트 템플릿
389
-
390
- ```vue
391
- <template>
392
- <div class="j-component">
393
- <!-- 컴포넌트 내용 -->
394
- </div>
395
- </template>
396
-
397
- <script setup lang="ts">
398
- interface Props {
399
- variant?: 'primary' | 'secondary'
400
- size?: 'sm' | 'md' | 'lg'
401
- disabled?: boolean
402
- }
403
-
404
- interface Emits {
405
- (e: 'click', value: string): void
406
- }
407
-
408
- const props = withDefaults(defineProps<Props>(), {
409
- variant: 'primary',
410
- size: 'md',
411
- disabled: false
412
- })
413
-
414
- const emit = defineEmits<Emits>()
415
- </script>
1
+ # J-Component
2
+
3
+ > Vue.js 3 기반 Atomic Design 패턴 컴포넌트 라이브러리
4
+
5
+ ## 📋 프로젝트 개요
6
+
7
+ J-Component는 Vue.js 3와 TypeScript를 기반으로 한 재사용 가능한 UI 컴포넌트 라이브러리입니다. shadcn/ui 디자인 시스템과 Atomic Design 패턴을 적용하여 일관성 있고 확장 가능한 컴포넌트를 제공합니다.
8
+
9
+ ## 🚀 현재 버전: v1.9.0
10
+
11
+ **최신 업데이트 (2026년 2월 20일)**
12
+ - **JSidebar 통합 컴포넌트 추가**: DB 트리 기반 사이드바 (접힘/펼침, 검색, 즐겨찾기, provide/inject 상태 공유)
13
+ - **JFilterBar 반응형 그리드**: 필터 필드 자동 그리드 레이아웃 (4→3→2→1열 반응형)
14
+ - **JLayoutSimple 리팩토링**: JSidebarSimpleJSidebar 통합 컴포넌트로 교체, activePath/storageKey prop 추가
15
+
16
+ [전체 릴리즈 노트 보기](./RELEASE_NOTES.md)
17
+
18
+ ## 🛠️ 기술 스택
19
+
20
+ ### 핵심 프레임워크
21
+ - **Vue.js 3.5** - 프론트엔드 프레임워크
22
+ - **TypeScript 5.9** - 타입 시스템
23
+ - **Vite 7** - 빌드 도구
24
+
25
+ ### UI & 스타일링
26
+ - **TailwindCSS 3.4** - 유틸리티 CSS 프레임워크
27
+ - **shadcn/ui** - 디자인 시스템 (radix-vue 기반)
28
+ - **Lucide Icons** - 아이콘 라이브러리
29
+
30
+ ### 개발 도구
31
+ - **Storybook 9** - 컴포넌트 문서화 및 테스트
32
+ - Docs 탭: 다양한 폼 스키마/도메인 예시 자동 미리보기 지원
33
+ - 테마 셀렉터: 8가지 tweakcn 테마 지원 (Default, Slate, Rose, Blue, Green, Purple, Orange, Vescrow)
34
+ - 다크모드 토글: 라이트/다크 모드 실시간 전환
35
+ - **ESLint 9** - 코드 품질 검사
36
+ - **Prettier** - 코드 포맷팅
37
+
38
+ ## 📁 프로젝트 구조
39
+
40
+ ```
41
+ jwms-portal-frontend/
42
+ ├── src/
43
+ │ ├── components/ # Atomic Design Components
44
+ │ │ ├── atoms/ # 기본 UI 요소 (JButton, JInput, JIcon 등)
45
+ ├── molecules/ # atoms의 조합 (JFormField, JCard, JAlert 등)
46
+ │ │ ├── organisms/ # molecules의 조합 (JModal, JDynamicTabs, JDynamicForm 등)
47
+ │ │ ├── shadcn/ # shadcn 컴포넌트 래핑
48
+ │ │ └── templates/ # 페이지 레이아웃
49
+ │ ├── stories/ # Storybook 스토리
50
+ ├── types/ # TypeScript 타입 정의
51
+ │ ├── composables/ # Vue Composition Functions
52
+ └── services/ # API 서비스
53
+ ├── docs/ # 컴포넌트 사용 가이드
54
+ └── dist/ # 빌드 결과물
55
+ ```
56
+
57
+ ## 🚀 시작하기
58
+
59
+ ### 설치
60
+
61
+ ```bash
62
+ # 저장소 클론
63
+ git clone <repository-url>
64
+ cd J-Component
65
+
66
+ # 의존성 설치
67
+ cd jwms-portal-frontend
68
+ npm install
69
+ # 또는
70
+ pnpm install
71
+ ```
72
+
73
+ ### 개발 서버 실행
74
+
75
+ ```bash
76
+ # 개발 서버 시작 (http://localhost:5173)
77
+ npm run dev
78
+ ```
79
+
80
+ ### Storybook 실행
81
+
82
+ ```bash
83
+ # Storybook 시작 (http://localhost:6006)
84
+ npm run storybook
85
+ ```
86
+
87
+ **Storybook 기능:**
88
+ - 다양한 폼 레이아웃/스키마(검색, 개인정보, 섹션, Wizard 등)와 Args/Docs 자동 문서 예시 확인 가능
89
+ - 툴바에서 테마 선택 (Default, Slate, Rose, Blue, Green)
90
+ - 다크모드 토글로 라이트/다크 모드 전환
91
+
92
+ ### 빌드
93
+
94
+ ```bash
95
+ # 프로덕션 빌드
96
+ npm run build
97
+
98
+ # 빌드 결과 미리보기
99
+ npm run preview
100
+ ```
101
+
102
+ ## 📚 주요 컴포넌트
103
+
104
+ ### Atoms (기본 요소)
105
+ - **JButton** - 버튼 컴포넌트
106
+ - **JInput** - 입력 필드
107
+ - **JIcon** - 아이콘 컴포넌트
108
+ - **JLabel** - 라벨 컴포넌트
109
+ - **JBadge** - 배지 컴포넌트
110
+ - **JProgress** - 진행률 표시
111
+ - **JSpinner** - 로딩 스피너
112
+ - **JGrid** - AG Grid 기반 데이터 그리드 컴포넌트 (Enterprise 기능 지원: 그룹핑, 피벗, Excel 내보내기)
113
+
114
+ ### Molecules (조합 요소)
115
+ - **JFormField** - 폼 필드 래퍼
116
+ - **JCard** - 카드 컴포넌트
117
+ - **JAlert** - 알림 컴포넌트
118
+ - **JAccordion** - 아코디언 컴포넌트
119
+ - **JContextMenu** - 컨텍스트 메뉴
120
+ - **JSearchAddr** - 주소 검색 컴포넌트
121
+ - **JTabs** - 컴포넌트 (탭 전환 이벤트 처리 개선, component 속성 활용 지원)
122
+ - **JButtonGroup** - 버튼 그룹 컴포넌트 (구분선 자동 표시 지원)
123
+ - **JTitlebar** - 타이틀바 컴포넌트 (제목, 설명, 팝오버 기능)
124
+
125
+ ### Organisms (복합 요소)
126
+ - **JModal** - 모달 컴포넌트 (size prop 지원: sm, md, lg, xl, 2xl, full)
127
+ - **JDynamicTabs** - 동적 탭 관리
128
+ - **JDynamicForm** - 스키마 기반 동적 폼(기본/섹션/다단계, Docs 탭/다양한 예시 참조)
129
+ - **JFormModal** - JDynamicForm 기반 동적 모달 컴포넌트 (size prop 지원)
130
+ - **JSearchPanel** - JDynamicForm 기반 재사용 가능한 검색 패널 (Collapsible, 조건 요약, 초기화 기능 지원)
131
+ - **JSidebarAdvanced** - 고급 사이드바 (검색, 즐겨찾기, 다단계 메뉴 지원)
132
+ - **JSidebarSimple** - 간단한 사이드바 (다단계 메뉴, 검색 지원)
133
+
134
+ ### Templates (레이아웃)
135
+ - **JLayoutAdvanced** - 고급 레이아웃 (JHeader + JSidebarAdvanced + JDynamicTabs 조합)
136
+ - **JLayoutSimple** - 간단한 레이아웃 (JHeader + JSidebarSimple + JPageContainer 조합)
137
+
138
+ ## 📖 사용 예시
139
+
140
+ > 💡 **컴포넌트 사용 가이드**: [사용 가이드](./docs/USAGE_GUIDE.md)에서 JDynamicTabs 경로 기반 컴포넌트 로딩 방법 등 상세 가이드를 확인하세요.
141
+
142
+ ### NPM 패키지 사용 (권장)
143
+
144
+ ```vue
145
+ <template>
146
+ <div class="p-4">
147
+ <JButton variant="primary" @click="handleClick">
148
+ 클릭하세요
149
+ </JButton>
150
+
151
+ <JFormField label="이름" required>
152
+ <JInput v-model="name" placeholder="이름을 입력하세요" />
153
+ </JFormField>
154
+
155
+ <JAlert type="info" title="알림">
156
+ 이것은 정보 알림입니다.
157
+ </JAlert>
158
+ </div>
159
+ </template>
160
+
161
+ <script setup>
162
+ import { ref } from 'vue'
163
+ import { JButton, JFormField, JInput, JAlert } from '@j-solution/components'
164
+ // CSS는 자동으로 포함됩니다 - 별도 import 불필요
165
+
166
+ const name = ref('')
167
+
168
+ const handleClick = () => {
169
+ console.log('버튼 클릭됨')
170
+ }
171
+ </script>
172
+ ```
173
+
174
+ > 💡 **참고**: NPM 패키지는 패키지 진입점에서 CSS가 자동으로 import되므로, 컴포넌트만 import하면 스타일이 자동으로 적용됩니다.
175
+
176
+ ### Standard 방식 사용 (파일 복사)
177
+
178
+ ```vue
179
+ <template>
180
+ <div class="p-4">
181
+ <JButton variant="primary" @click="handleClick">
182
+ 클릭하세요
183
+ </JButton>
184
+
185
+ <JFormField label="이름" required>
186
+ <JInput v-model="name" placeholder="이름을 입력하세요" />
187
+ </JFormField>
188
+
189
+ <JAlert type="info" title="알림">
190
+ 이것은 정보 알림입니다.
191
+ </JAlert>
192
+ </div>
193
+ </template>
194
+
195
+ <script setup>
196
+ import { ref } from 'vue'
197
+ import { JButton, JFormField, JInput, JAlert } from '@/components'
198
+
199
+ const name = ref('')
200
+
201
+ const handleClick = () => {
202
+ console.log('버튼 클릭됨')
203
+ }
204
+ </script>
205
+ ```
206
+
207
+ ### 주소 검색 컴포넌트
208
+
209
+ ```vue
210
+ <template>
211
+ <JSearchAddr
212
+ v-model="address"
213
+ @select="handleAddressSelect"
214
+ placeholder="주소를 검색하세요"
215
+ />
216
+ </template>
217
+
218
+ <script setup>
219
+ import { ref } from 'vue'
220
+ import { JSearchAddr } from '@/components/molecules'
221
+
222
+ const address = ref('')
223
+
224
+ const handleAddressSelect = (selectedAddress) => {
225
+ console.log('선택된 주소:', selectedAddress)
226
+ }
227
+ </script>
228
+ ```
229
+
230
+ ## 📚 문서 가이드
231
+
232
+ > **모든 문서는 이 README.md를 기준으로 연결되어 있습니다.**
233
+
234
+ ### 📖 주요 문서
235
+
236
+ | 문서 | 설명 | 대상 |
237
+ |------|------|------|
238
+ | **[설치 가이드](./docs/INSTALLATION_GUIDE.md)** | 처음 설치하는 방법 | Standard 방식, NPM 방식 설치 가이드 |
239
+ | **[업데이트 가이드](./docs/UPDATE_GUIDE.md)** | 버전 업데이트 방법 | Standard 방식, NPM 방식 업데이트 가이드 |
240
+ | **[사용 가이드](./docs/USAGE_GUIDE.md)** | 컴포넌트 사용 방법 | 컴포넌트 목록, 사용 예시, 권장사항 |
241
+ | **[릴리즈 노트](./RELEASE_NOTES.md)** | 버전별 변경사항 | 모든 버전의 변경 이력 |
242
+
243
+ ### 📦 패키지 문서
244
+
245
+ 패키지에 포함된 문서들 (원본: `docs/` 디렉토리):
246
+
247
+ - **`packages/v{version}/README.md`**: 패키지 소개 설치 방법
248
+ - **`packages/v{version}/USAGE_GUIDE.md`**: 컴포넌트 사용 가이드
249
+ - **`packages/v{version}/UPDATE_GUIDE.md`**: 버전 업데이트 가이드
250
+
251
+ > 💡 **참고**: 패키지 문서는 `docs/` 디렉토리의 원본을 기반으로 패키징 시 자동으로 포함됩니다.
252
+
253
+ ### 🗺️ 문서 구조
254
+
255
+ ```
256
+ J-Component/
257
+ ├── README.md # 메인 문서 (이 파일)
258
+ ├── RELEASE_NOTES.md # 릴리즈 노트
259
+ ├── docs/ # 문서 원본
260
+ ├── INSTALLATION_GUIDE.md # 설치 가이드
261
+ ├── UPDATE_GUIDE.md # 업데이트 가이드
262
+ └── USAGE_GUIDE.md # 사용 가이드
263
+ └── packages/ # 배포 패키지
264
+ └── v{version}/
265
+ ├── README.md # (docs에서 복사)
266
+ ├── USAGE_GUIDE.md # (docs에서 복사)
267
+ └── UPDATE_GUIDE.md # (docs에서 복사)
268
+ ```
269
+
270
+ ---
271
+
272
+ ## 📦 컴포넌트 패키징 및 배포
273
+
274
+ > **⚠️ 중요**: 패키지를 생성하거나 버전을 업데이트하기 전에 **반드시** 다음 문서를 참조하세요:
275
+ > - **상세 가이드**: [`jwms-portal-frontend/PACKAGING.md`](./jwms-portal-frontend/PACKAGING.md)
276
+ > - **빠른 참조**: [`PACKAGING_GUIDE.md`](./PACKAGING_GUIDE.md)
277
+
278
+ J-Component는 **두 가지 배포 방식**을 지원합니다:
279
+
280
+ ### 🚀 통합 패키징 (권장)
281
+
282
+ **하나의 명령어로 가지 방식 모두 생성:**
283
+
284
+ ```bash
285
+ cd jwms-portal-frontend
286
+ npm run package
287
+ ```
288
+
289
+ 이 명령어는 다음을 자동으로 실행합니다:
290
+ 1. **Standard 방식**: `packages/v{version}/` 디렉토리에 파일 복사 방식 패키지 생성
291
+ 2. **NPM 방식**: `dist/npm/` 디렉토리에 npm 패키지 생성
292
+
293
+ ### 1) Standard 방식 (파일 복사)
294
+
295
+ - **출력 위치**: `packages/v{version}/`
296
+ - **사용 방법**: 타겟 프로젝트에 파일을 직접 복사하여 사용
297
+ - **특징**:
298
+ - 기존 프로젝트 구조와 동일
299
+ - Git에 커밋 가능 (버전별 스냅샷)
300
+ - `packages/latest/standard/`에 최신 버전 포인터 제공
301
+
302
+ ### 2) NPM 방식 (npm 패키지)
303
+
304
+ - **출력 위치**: `dist/npm/`
305
+ - **사용 방법**:
306
+ - 로컬 테스트: `npm install file:../path/to/dist/npm`
307
+ - npm 레지스트리: `npm install @j-solution/components` (배포 후)
308
+ - **특징**:
309
+ - ES Module + CommonJS + TypeScript 타입 정의 포함
310
+ - 가상 모듈 자동 인라인 처리
311
+ - `dist` 디렉토리는 `.gitignore`에 포함 (빌드 자동 생성)
312
+
313
+ #### NPM 패키지 배포
314
+
315
+ ```bash
316
+ # 로컬에서 빌드 및 배포
317
+ cd jwms-portal-frontend/dist/npm
318
+ npm publish --access public
319
+ # 또는
320
+ pnpm publish --access public
321
+ ```
322
+
323
+ #### 자동 배포 (GitHub Actions)
324
+ - GitHub에서 Release를 생성하면 자동으로 npm 레지스트리에 배포
325
+ - `.github/workflows/publish-npm.yml` 워크플로우 자동 실행
326
+ - `NPM_TOKEN` 시크릿 필요
327
+
328
+ ### ⚠️ 중요 사항
329
+
330
+ - **v1.0.0부터 namespaced 방식 지원 중단**
331
+ - 기존: standard, namespaced, npm (3가지)
332
+ - 현재: standard, npm (2가지)
333
+ - namespaced 방식은 npm 방식으로 대체됨
334
+
335
+ ### 개별 패키징
336
+
337
+ 필요한 경우 개별로 실행할 수 있습니다:
338
+
339
+ ```bash
340
+ # Standard 방식만
341
+ npm run package:standard
342
+
343
+ # NPM 방식만
344
+ npm run package:npm
345
+ ```
346
+
347
+ 자세한 내용: [PACKAGING.md](./jwms-portal-frontend/PACKAGING.md)
348
+
349
+ > 💡 **설치 및 업데이트 방법**: [설치 가이드](./docs/INSTALLATION_GUIDE.md) 및 [업데이트 가이드](./docs/UPDATE_GUIDE.md)를 참고하세요.
350
+
351
+ ### 패키지 다운로드
352
+
353
+ 패키지 폴더만 다운로드하는 방법 (전체 리포지토리 클론 불필요):
354
+
355
+ **⭐ 추천: Git Sparse Checkout** (패키지 폴더만 다운로드):
356
+ ```bash
357
+ # Public 리포지토리
358
+ git clone --depth 1 --filter=blob:none --sparse <repository-url>
359
+ cd J-Component
360
+ git sparse-checkout set packages/v1.0.0
361
+ # 또는 packages/latest/standard
362
+
363
+ # Private 리포지토리 (인증 필요)
364
+ git clone --depth 1 --filter=blob:none --sparse git@github.com:<username>/<repository>.git
365
+ cd J-Component
366
+ git sparse-checkout set packages/v1.0.0
367
+ ```
368
+
369
+ **다른 방법들**:
370
+ - GitHub 웹 인터페이스에서 특정 디렉토리 ZIP 다운로드
371
+ - GitHub API 사용
372
+ - Git Submodule 사용
373
+
374
+ > **📝 참고**: 각 패키지의 `README.md`에 상세한 다운로드 방법이 안내되어 있습니다.
375
+
376
+ ## 🔧 개발 가이드
377
+
378
+ ### 컴포넌트 작성 규칙
379
+
380
+ 1. **Atomic Design 패턴** 준수
381
+ 2. **TypeScript** 타입 정의 필수
382
+ 3. **Props** 인터페이스 정의
383
+ 4. **Storybook** 스토리 작성
384
+ 5. **Tailwind CSS** 스타일링
385
+
386
+ ### 컴포넌트 템플릿
387
+
388
+ ```vue
389
+ <template>
390
+ <div class="j-component">
391
+ <!-- 컴포넌트 내용 -->
392
+ </div>
393
+ </template>
394
+
395
+ <script setup lang="ts">
396
+ interface Props {
397
+ variant?: 'primary' | 'secondary'
398
+ size?: 'sm' | 'md' | 'lg'
399
+ disabled?: boolean
400
+ }
401
+
402
+ interface Emits {
403
+ (e: 'click', value: string): void
404
+ }
405
+
406
+ const props = withDefaults(defineProps<Props>(), {
407
+ variant: 'primary',
408
+ size: 'md',
409
+ disabled: false
410
+ })
411
+
412
+ const emit = defineEmits<Emits>()
413
+ </script>
416
414
  ```