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