open-grid 1.0.2 → 1.0.6

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/CHANGELOG.md ADDED
@@ -0,0 +1,265 @@
1
+ # Changelog
2
+
3
+ All notable changes to OPEN_GRID will be documented in this file.
4
+
5
+ ## [1.0.5] - 2026-06-24
6
+
7
+ ### Changed
8
+ - **런타임 의존성 0 (zero runtime dependencies)** — Excel 내보내기에 쓰이는 `xlsx`·`xlsx-js-style`을
9
+ `dependencies` → `devDependencies`로 옮겼다. 이들은 **빌드 시 `dist/`에 번들로 포함**되므로
10
+ (`src`의 `import('xlsx-js-style')`가 빌드 과정에서 `dist/xlsx.min-*.js` 청크로 변환됨),
11
+ 설치하는 쪽에서 별도로 받을 필요가 없다 — `npm install open-grid`는 외부 런타임 의존성을
12
+ 하나도 끌어오지 않는다. **Excel 내보내기는 번들된 SheetJS로 그대로 동작**한다(설치 불필요).
13
+ 코드·동작 변경 없음(의존성 분류만 정정). 번들된 SheetJS는 Apache-2.0이며 `NOTICE`/`THIRD_PARTY_LICENSES.txt`로 귀속 표기됨.
14
+
15
+ ## [1.0.4] - 2026-06-24
16
+
17
+ ### Changed
18
+ - **소개 문구(intro) 추가** — README 상단과 npm `description`에 제품 소개 문구를 추가하고
19
+ npm 배지 버전 표기를 현행화했다. 코드·기능 변경 없음(문서/메타데이터만).
20
+ ("zero-dependency **core**" — Excel 내보내기는 SheetJS를 번들하므로 "코어 무의존"으로 정확히 표기.)
21
+
22
+ ## [1.0.3] - 2026-06-24
23
+
24
+ ### Changed
25
+ - **라이선스 준수 내역을 배포 패키지에 명시** — 발행 tarball에 `CHANGELOG.md`를 포함하고,
26
+ README·변경 이력에 1.0.2의 라이선스 컴플라이언스 조치(아래)를 명확히 기재했다.
27
+ 코드·기능 변경 없음(문서/배포 메타데이터만).
28
+
29
+ ## [1.0.2] - 2026-06-24
30
+
31
+ ### Fixed — 라이선스 컴플라이언스 (잠재적 라이선스 위반 소지 해소)
32
+ - **문제** — Excel 내보내기 기능에 쓰이는 `xlsx`(SheetJS Community Edition)와
33
+ `xlsx-js-style`는 **Apache License 2.0** 라이선스이며 빌드 결과물(`dist/`)에 번들되어
34
+ 함께 배포된다. 그런데 1.0.1까지의 배포 패키지에는 OPEN_GRID 자체의 **MIT LICENSE만**
35
+ 들어 있고, Apache-2.0가 재배포 시 요구하는 **라이선스 사본과 저작권 귀속 고지가 누락**
36
+ 되어 있었다(Apache-2.0 §4(a)·§4(c) 미충족 → **잠재적 라이선스 위반 소지**).
37
+ - **해결** — 배포 패키지에 다음을 추가하고 `files`에 포함해 함께 배포한다:
38
+ - `THIRD_PARTY_LICENSES.txt` — Apache License 2.0 **전문** + 번들 구성요소 식별·저작권 고지
39
+ - `NOTICE` — SheetJS LLC(`xlsx`) 및 SheetJS LLC·Brent Ely(`xlsx-js-style`) 저작권 귀속
40
+ - README에 "Third-party licenses" 안내 추가
41
+ - **영향 범위** — OPEN_GRID 본체 라이선스(MIT)와 코드는 **변경 없음**. MIT와 Apache-2.0는
42
+ 서로 호환되어 **라이선스 충돌은 없으며**, 누락돼 있던 Apache-2.0 **귀속 의무만 충족**시킨
43
+ 조치다.
44
+
45
+ ## [1.0.1] - 2026-06-24
46
+
47
+ ### Fixed
48
+ - **그리드 초기화 크래시 수정** — `summary` 푸터를 사용하는 그리드를 생성할 때
49
+ `Cannot read properties of undefined (reading 'getStrategy')` 로 초기화가 실패하던 문제.
50
+ 생성자에서 OverrideKernel 부착(및 strategy resolver 배선)을 최초 마운트 **이전**으로
51
+ 옮겨, 초기 푸터/그룹 렌더가 strategy 슬롯을 조회할 때 커널이 항상 준비되도록 했다.
52
+ (피벗·집계 푸터·그룹 합계 등 `summary`/`footer` 옵션을 쓰는 모든 구성에 영향.)
53
+
54
+ ## [1.0.0] - 2026-06-23
55
+
56
+ 첫 정식 메이저 릴리스. 본문(코어) 코드 무수정으로 동작을 확장하는 `grid.override()` API와 헤더 줄바꿈을 추가.
57
+
58
+ ### Added
59
+ - **`grid.override()` — 본문 무수정 동작 확장 API** (신규 `src/core/OverrideKernel.ts`)
60
+ - `grid.override(name, (orig, ...args) => result)` — 메서드 래핑. `orig()`는 `super`처럼 항상 호출 가능.
61
+ 합성 순서는 FIFO 좌측폴드(나중에 건 것이 가장 바깥), 재진입 깊이 32 + 사이클 가드.
62
+ - `grid.override.strategy(slot, fn)` — 6개 알고리즘 슬롯 교체: 정렬 비교(sortComparator),
63
+ 필터 술어(filterPredicate), 표시 포맷터(displayFormatter), 엑셀 직렬화(cellSerializer),
64
+ 그룹 키(groupKeyFn), 집계 연산(summaryOp).
65
+ - `grid.restore(name)` / `grid.restoreAll()` — 원복. `destroy()` 시 자동 전체 복원.
66
+ - `OpenGrid.defaultOverride(name, fn)` / `OpenGrid.defaults.strategy(slot, fn)` — 전역(앞으로 생성될 모든 그리드) 기본 오버라이드.
67
+ - 오류는 기본(strict) 그대로 전파. 기존 메서드 본문은 한 줄도 수정하지 않음(C1 원칙 준수).
68
+ - **헤더 줄바꿈** — `ColumnDef.headerWrap?: boolean` + 헤더 문자열 `\n` 줄바꿈 + 헤더 높이 자동 확장.
69
+ - **override 데모 32종 × 5 프레임워크**(Vanilla/React/Vue/jQuery/Angular) — `examples/override/`, 허브 포함.
70
+ - **그리드 튜닝 참고자료 페이지** — 아키텍처/시퀀스 UML 다이어그램 기반 내부 동작 설명.
71
+ - **AI 에이전트용 override 가이드**(KO/EN) + 개발 가이드 override 챕터.
72
+
73
+ ### Tests
74
+ - override 코어 + 헤더 줄바꿈 단위 테스트 추가. 전체 테스트 통과(회귀 0).
75
+
76
+ ## [0.3.2] - 2026-06-18
77
+
78
+ ### Fixed
79
+ - **셀 줄바꿈(col.wrap)이 실제로 꺾이지 않던 문제** — `.og-cell--wrap` 는 셀에 적용됐지만, 내부 텍스트
80
+ span(`.og-cell-text`)을 렌더러가 인라인 `white-space:nowrap` 으로 렌더해 클래스만으로는 못 이겼다.
81
+ `.og-cell--wrap .og-cell-text/.og-cell-date { white-space: normal !important; text-overflow: clip !important }`
82
+ 로 인라인을 무력화. e2e 도 셀이 아닌 **내부 span + 실제 줄 수**를 검증하도록 강화.
83
+ (npm `open-grid@0.3.1` 은 이 수정 직전에 발행되어 wrap 미동작 → **0.3.2 로 재발행**, npm latest = 0.3.2.)
84
+
85
+ ## [0.3.1] - 2026-06-17
86
+
87
+ ### Fixed
88
+ - **Host CSS isolation — 임베드 시 호스트 테마 CSS inbound 상속으로 레이아웃/색상 깨짐** (foxnail.kr/WordPress 통합에서 발견)
89
+ - 원인: 헤더가 실제 `<table>`/`<th>` 라서, 임베드 호스트(WordPress 등)의 element/높은 특이도 셀렉터
90
+ (`th,td`, `.entry-content th`, `.fn-post-content th` 등)가 그리드 헤더로 침범 — `line-height`, `border`,
91
+ `background`, `color`, `table{margin}` 등이 새어들어와 헤더가 깨지거나 호스트 색(navy/white)으로 칠해짐.
92
+ 바디는 `<div>` 라 안전. (헤더 `<th>` 는 element 셀렉터라 그리드의 클래스/상속값을 이김)
93
+ - `src/core/GridRenderer.ts` — 헤더 `<th>` 의 모든 시각 속성을 **인라인으로 고정**(인라인이 호스트 셀렉터를 이김):
94
+ `background`/`color`/`line-height`/`font-size`/`vertical-align`/`border-top·left` (data + extra/rownumber/check 컬럼 전부).
95
+ 헤더 `<table>` 에 `og-header-table` 클래스 부여 + 인라인 `margin:0;border-spacing:0`.
96
+ - `src/styles/base.css` — `.og-container { line-height: normal }` (바디 셀 메트릭 격리) 및 헤더 클래스 기본 방어.
97
+ - **WordPress 전역 스타일 `:where([style*="border-color"]){border-style:solid}` 대응** — 그리드 인라인 보더가
98
+ `var(--og-border-color)` 를 참조해 "border-color" 문자열에 매칭되면, 폭 미지정 변에 `medium`(3px) 보더가
99
+ 강제돼 헤더(`.og-header`)·그룹행·병합셀의 좌/우/상에 굵은 선이 생기고 바디 컬럼선과 어긋나던 문제 수정.
100
+ `GridRenderer.ts` 의 단일변 인라인 보더에 `border:0` 선행(미지정 변 폭 0 명시). 테마 무관(전 테마 동일 적용).
101
+ - **컨텍스트메뉴 위치 — 임베드 호스트의 transform 조상 아래에서 마우스 좌표를 벗어남** (그리드 너비 확대 시 두드러짐)
102
+ - `src/core/ContextMenu.ts` — 메뉴를 그리드 컨테이너 대신 `document.body` 에 부착 → `position:fixed` 가
103
+ 항상 뷰포트 기준으로 동작. 테마 변수 보존을 위해 `data-og-theme` 복사 + `.og-context-menu` 에 `--og-cm-*` 정의 확장.
104
+
105
+ ### Added
106
+ - **셀 툴팁** — `column.tooltip`(문자열|함수) 또는 그리드 옵션 `tooltips: true`(모든 셀에 값 자동 노출).
107
+ 헤더 셀도 `title` 노출(잘린 헤더 가독성).
108
+ - **셀 줄바꿈(wrap)** — `column.wrap: true` 시 nowrap+ellipsis 대신 여러 줄 표시(`white-space:normal`).
109
+ 가상 스크롤 고정 행 높이와 함께 `rowHeight` 확대 권장.
110
+ - 회귀 테스트: `test/e2e/host-isolation.spec.ts` + 적대적 호스트 픽스처 `examples/host-isolation/`
111
+ (line-height/border/margin/색상 격리 + 컨텍스트메뉴 transform 조상 + 툴팁/wrap, before/after 변별 — 10 케이스).
112
+
113
+ ## [0.3.0] - 2026-06-05
114
+
115
+ ### Added
116
+ - **개발 가이드 DB화 완성** — 39개 섹션 전체 SQLite DB화 (G1~G6)
117
+ - G1: 시작하기 (npm 설치, 퀵스타트, 기본 설정)
118
+ - G2: 데이터/옵션 (컬럼 정의, 데이터 옵션, 선택/체크박스/DnD/상태 관리)
119
+ - G3: 편집/이벤트 (셀 편집, 셀 타입, 마스킹, 병합, 이벤트, 트리거)
120
+ - G4: 그룹/페이징 (그룹, 트리, 푸터, 페이지네이션, 파인드바, 키보드)
121
+ - G5: 고급/내보내기 (피벗, 워크시트, SAP, XML, 수식, 조직도, Excel/CSV/인쇄)
122
+ - G6: 스타일/API (테마, 커스텀, 폰트, 사이징, 접근성, 그리드/컬럼/이벤트 API)
123
+ - **전 프레임워크 데모 완성** — React / Vue / jQuery / Angular / Vanilla 각 49개 섹션
124
+ - Angular A~H: AngularJS 1.x CDN 기반, `$scope.$apply` 없이 ng-show/ng-hide 패턴
125
+ - **Guide 렌더러** — `lang='html'` 감지 시 innerHTML 직접 주입 방식으로 전환 (pre/code 래핑 없음)
126
+
127
+ ## [0.2.0] - 2026-06-04
128
+
129
+ ### Fixed
130
+ - **Formula 셀 클릭 버그** — `CellEventHandler.ts`: formula 컬럼 cellClick 시 `e.value`가 `undefined`이던 문제 수정
131
+ - `row[col.field]` 대신 `evaluateFormula()`로 직접 계산 후 주입
132
+
133
+ ### Added
134
+ - **React 데모** — `demo-react/index.php` 신규 (React 18 CDN, `useRef+useEffect+createRoot` 패턴)
135
+ - React 프레임워크 전 섹션(A~H, 49개) DB 삽입 완료
136
+ - 선택/필터셀렉트 API 버그 수정 (`getSelections()`, `valueMap` 기반 표시)
137
+
138
+ ## [0.1.2] - 2026-05-30
139
+
140
+ ### Added (Sprint 29 추가분)
141
+ - **변경 추적 API 보강**
142
+ - `getChanges()` — `{ added, edited, removed }` 한 번에 반환. edited 행에 `_changedFields` 포함
143
+ - `getEditedRows()` — 수정된 행만 반환 (기존 `getChangedRows()` 개선판)
144
+ - `getChangedColumns()` — `{ row, fields, diff[] }` 형태로 컬럼 단위 diff 반환 (oldValue/newValue 포함)
145
+ - `getOriginalRow(rowIndex)` — 수정 전 원본 행 데이터 반환
146
+ - **합계 / 소계 (Footer)**
147
+ - `setFooter(FooterDef[])` — 런타임 푸터 설정 (SUM/AVG/MIN/MAX/COUNT)
148
+ - `getFooterValue(field)` — 특정 필드 집계 결과 조회
149
+ - `getFooterData()` — 전체 집계 데이터 배열 조회
150
+ - OGDecimal 기반 정밀 계산 — 소수점 누적 오류 없음 (0.1 × 10 = 정확히 1.00)
151
+ - 데이터 수정/추가/삭제 시 푸터 자동 재계산
152
+ - **Guide** — Ch26(변경 추적), Ch27(합계/소계) 추가 → 총 27챕터
153
+ - **Vanilla 데모** — '변경 추적' 섹션, '합계/소계' 섹션 추가
154
+
155
+ ## [0.1.1] - 2026-05-30
156
+
157
+ ### Added (Sprint 29)
158
+ - **columnReorder** — `columnReorder: true` 옵션으로 헤더 드래그 컬럼 순서 변경 지원
159
+ - `onColumnReorder` 이벤트 콜백 (`{ fromIndex, toIndex, field }`)
160
+ - 드래그 중 시각 피드백 (`og-col-dragging` / `og-col-drop-over` CSS 클래스)
161
+ - **Guide** — 개발 가이드 4개 챕터 신규 추가 (Ch22~Ch25)
162
+ - Ch22: 데이터 마스킹 (10종 타입, 셀/컬럼 단위 해제, maskOnExport)
163
+ - Ch23: 조직도 (OrgChart API, setData, expandAll/collapseAll, 테마 연동)
164
+ - Ch24: 페이지네이션 (API, 서버사이드, React/Vue 예제)
165
+ - Ch25: 키보드 단축키 (WCAG 2.2 준수 표, aria-label 설정)
166
+ - **E2E Tests** — sprint29.spec.ts 25개 시나리오 추가
167
+ - checkColumn 선택/해제, 컨텍스트 메뉴 렌더링/닫힘, 테마 전환(data-og-theme), 키보드 네비게이션, 셀 편집, 정렬(aria-sort)
168
+
169
+ ### Changed
170
+ - `GridRenderer` 내부 콜백에 `onColDragStart` / `onColDrop` / `getColDragIdx` 추가
171
+
172
+ ## [0.1.0] - 2026-05-24
173
+
174
+ ### Added
175
+ - **Core Engine**
176
+ - `OpenGrid` class — main grid instance with `new OpenGrid(container, options)` API
177
+ - `DataLayer` — CRUD, state tracking (added/edited/removed), sort, filter
178
+ - `VirtualScroll` — rAF-based rendering with row pooling (100k+ rows)
179
+ - `ColumnLayout` — group headers, frozen columns, flex widths
180
+ - `EventEmitter` — on/once/off/emit event system
181
+
182
+ - **Cell Renderers** (8 types)
183
+ - text, number (format), date, checkbox, button, badge, link, template
184
+
185
+ - **Cell Editors** (5 types)
186
+ - text, number, select, date, checkbox
187
+ - Inline editing: click / dblclick / F2 entry, Enter/Tab/Esc exit
188
+
189
+ - **Grouping + Summary**
190
+ - `groupBy(fields[])` — multi-level hierarchical grouping
191
+ - `summary` option — SUM / AVG / MIN / MAX / COUNT per column
192
+ - `expandAll()` / `collapseAll()` / `clearGroup()`
193
+
194
+ - **Tree Grid**
195
+ - `enableTree()` / `disableTree()` — flat-to-tree via `treeId` / `treeParentId`
196
+ - `expandNodes(ids)` / `expandAllNodes()` / `collapseAllNodes()`
197
+ - Indent + toggle arrow rendering per depth level
198
+
199
+ - **Cell Merge**
200
+ - `mergeCells([{row, col, rowSpan?, colSpan?}])` — manual merge
201
+ - `autoMerge(fields[])` — auto rowSpan for consecutive identical values
202
+ - `clearMerge()` — remove all merges
203
+
204
+ - **Row Drag & Drop**
205
+ - `draggable: true` option
206
+ - Ghost row + drop indicator
207
+ - `reorderRow(from, to)` public API
208
+ - `onRowDrop` callback
209
+
210
+ - **Filter UI**
211
+ - Column header filter icon
212
+ - 9 operators: `=`, `!=`, `contains`, `startsWith`, `endsWith`, `>`, `<`, `>=`, `<=`
213
+
214
+ - **Export**
215
+ - `exportExcel(options?)` — SheetJS xlsx (dynamic import, code-split)
216
+ - `exportCsv(options?)` — BOM-aware CSV
217
+ - `exportJson(options?)` — JSON download
218
+
219
+ - **Pagination**
220
+ - `pagination: true` + `pageSize` option
221
+ - Page size selector (10/20/50/100/200)
222
+ - First/Prev/Next/Last navigation
223
+
224
+ - **Keyboard Navigation**
225
+ - Arrow keys — cell navigation
226
+ - Tab / Shift+Tab — next/prev cell
227
+ - F2 / Enter — start edit
228
+ - Escape — cancel edit / clear focus
229
+ - Ctrl+C / Ctrl+V — clipboard
230
+
231
+ - **UI**
232
+ - Column resize (drag)
233
+ - Multi-sort (Shift+click)
234
+ - Dark theme (`theme: 'dark'`)
235
+ - CSS Variables — full theme customization
236
+ - `setTheme(theme)` / `setThemeVar(key, value)`
237
+
238
+ - **Vue 3 Component** (`open-grid/vue`)
239
+ - Composition API, `defineProps` / `defineEmits`
240
+ - Reactive `data` / `columns` watchers
241
+ - `grid` instance exposed via `defineExpose`
242
+
243
+ - **React 18 Component** (`open-grid/react`)
244
+ - Hooks-based (`useRef`, `useEffect`)
245
+ - `OpenGridReact` + `OpenGridWithRef` (forwardRef)
246
+ - `stateColumn`, `draggable`, `onRowDrop` props
247
+
248
+ - **API Naming** — distinctive, self-consistent method names
249
+ - `readCell`, `writeCell` for cell access
250
+ - `orderBy` for sorting
251
+ - `jumpToRow` for scrolling
252
+ - `getSelections` for selection
253
+ - (40+ purpose-built method names)
254
+
255
+ ### Performance
256
+ - Multi-sort 100k rows: 1789ms → **40ms** (44× improvement via Schwartzian transform)
257
+ - Single sort 100k rows: ~38ms
258
+ - Filter 100k rows: ~17ms
259
+ - Group build 100k rows: ~3ms (5 groups)
260
+ - Tree build 100k rows: ~25ms
261
+
262
+ ### Tests
263
+ - 124 unit tests across 7 test files
264
+ - EventEmitter (7), DataLayer (14), GroupEngine (18), TreeEngine (20),
265
+ MergeEngine (16), CellEditor (23), CellRenderer (26)
package/README.md CHANGED
@@ -1,10 +1,15 @@
1
1
  # OPEN_GRID
2
2
 
3
+ **Meet Open Grid** — the ultra-light data grid with a **zero-dependency core** that fits
4
+ effortlessly into any tech stack. React, Vue, Angular, jQuery, or pure JavaScript — it just
5
+ works. MIT-licensed for full commercial freedom, endlessly customizable, and enhanced with an
6
+ AI-friendly override guide so you can push your grid further than ever.
7
+
3
8
  High-performance, framework-agnostic data grid with virtual scrolling, inline editing, grouping, tree view, drag-and-drop, change tracking, footer aggregation, and column reorder.
4
9
 
5
10
  [![License: MIT](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE)
6
11
  [![TypeScript](https://img.shields.io/badge/TypeScript-5.x-blue)](https://www.typescriptlang.org/)
7
- [![npm](https://img.shields.io/badge/npm-0.4.0-orange)](https://www.npmjs.com/package/open-grid)
12
+ [![npm](https://img.shields.io/badge/npm-1.0.4-orange)](https://www.npmjs.com/package/open-grid)
8
13
 
9
14
  📖 **[개발 가이드](https://foxnail.kr/open-grid/demo/v2/guide/index.php)** — 설치부터 고급 API까지 단계별 가이드
10
15
  🔗 **[데모/홈페이지](https://foxnail.kr/open-grid/demo/v2/index.php)**
@@ -366,6 +371,17 @@ CSS 변수로 완전한 테마 커스터마이즈 가능:
366
371
 
367
372
  MIT © OPEN_GRID Contributors
368
373
 
374
+ ### Zero runtime dependencies (Excel still works out of the box)
375
+
376
+ `npm install open-grid` pulls **no external runtime dependencies** — the core grid is fully
377
+ self-contained.
378
+
379
+ **Excel export works out of the box, with nothing extra to install.** It uses SheetJS
380
+ (`xlsx-js-style`), which is **bundled inside the package** (in `dist/`) and loaded on demand
381
+ only when you actually export. You do **not** need to add `xlsx`/`xlsx-js-style` to your
382
+ project — they ship inside OPEN_GRID. (They are listed under `devDependencies` because they are
383
+ needed to *build* the bundle, not to *use* it.)
384
+
369
385
  ### Third-party licenses
370
386
 
371
387
  The bundled Excel export uses **SheetJS Community Edition (`xlsx`)** and
@@ -373,3 +389,11 @@ The bundled Excel export uses **SheetJS Community Edition (`xlsx`)** and
373
389
  (© SheetJS LLC, and Brent Ely for the style fork). Their attribution notices
374
390
  and the full license text are included in [`NOTICE`](NOTICE) and
375
391
  [`THIRD_PARTY_LICENSES.txt`](THIRD_PARTY_LICENSES.txt).
392
+
393
+ > **As of 1.0.2**, these `NOTICE` and `THIRD_PARTY_LICENSES.txt` files are shipped
394
+ > inside the published package to satisfy the Apache-2.0 attribution requirements
395
+ > for the bundled components — resolving a potential license-compliance gap in
396
+ > earlier releases (≤ 1.0.1), which shipped only the MIT license without the
397
+ > required Apache-2.0 notices. OPEN_GRID's own MIT license is unchanged; MIT and
398
+ > Apache-2.0 are compatible, so this was an attribution fix only. See
399
+ > [`CHANGELOG.md`](CHANGELOG.md) for details.
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "open-grid",
3
- "version": "1.0.2",
4
- "description": "High-performance, framework-agnostic data grid with Vue 3 and React 18 support",
3
+ "version": "1.0.6",
4
+ "description": "Ultra-light data grid with a zero-dependency core — works with React, Vue, Angular, jQuery, or vanilla JS. MIT-licensed, endlessly customizable, with an AI-friendly override guide.",
5
5
  "type": "module",
6
6
  "main": "dist/open-grid.cjs",
7
7
  "module": "dist/open-grid.js",
@@ -27,6 +27,7 @@
27
27
  "files": [
28
28
  "dist",
29
29
  "README.md",
30
+ "CHANGELOG.md",
30
31
  "LICENSE",
31
32
  "NOTICE",
32
33
  "THIRD_PARTY_LICENSES.txt"
@@ -80,9 +81,7 @@
80
81
  "vite": "^5.2.0",
81
82
  "vite-plugin-dts": "^4.5.4",
82
83
  "vitest": "^1.6.0",
83
- "vue": "^3.4.0"
84
- },
85
- "dependencies": {
84
+ "vue": "^3.4.0",
86
85
  "xlsx": "^0.18.5",
87
86
  "xlsx-js-style": "^1.2.0"
88
87
  },
@@ -98,5 +97,12 @@
98
97
  ],
99
98
  "license": "MIT",
100
99
  "author": "OPEN_GRID Contributors",
101
- "homepage": "https://foxnail.kr/open-grid/demo/v2/index.php"
100
+ "homepage": "https://foxnail.kr/open-grid/demo/v2/index.php",
101
+ "repository": {
102
+ "type": "git",
103
+ "url": "git+https://github.com/farmerkweon/OpenGrid.git"
104
+ },
105
+ "bugs": {
106
+ "url": "https://github.com/farmerkweon/OpenGrid/issues"
107
+ }
102
108
  }