@mint-ui/map 1.2.0-test.1 → 1.2.0-test.11
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 +7 -7
- package/dist/components/mint-map/core/MintMapController.d.ts +1 -0
- package/dist/components/mint-map/core/MintMapCore.js +2 -0
- package/dist/components/mint-map/core/advanced/index.d.ts +1 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/WoongCanvasLayer.d.ts +93 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/WoongCanvasLayer.js +1138 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/index.d.ts +3 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/context.d.ts +8 -7
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/context.js +11 -2
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/performance.js +343 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/renderer.d.ts +59 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/renderer.js +226 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/types.d.ts +21 -11
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/types.js +14 -0
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/utils.d.ts +15 -6
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/utils.js +182 -0
- package/dist/components/mint-map/core/wrapper/MapMarkerWrapper.js +22 -1
- package/dist/components/mint-map/google/GoogleMintMapController.d.ts +1 -0
- package/dist/components/mint-map/google/GoogleMintMapController.js +8 -0
- package/dist/components/mint-map/kakao/KakaoMintMapController.d.ts +1 -0
- package/dist/components/mint-map/kakao/KakaoMintMapController.js +8 -0
- package/dist/components/mint-map/naver/NaverMintMapController.d.ts +3 -0
- package/dist/components/mint-map/naver/NaverMintMapController.js +41 -3
- package/dist/index.es.js +1925 -14
- package/dist/index.js +23 -0
- package/dist/index.umd.js +1942 -17
- package/package.json +1 -1
- package/.claude/settings.local.json +0 -16
- package/dist/components/mint-map/core/advanced/woongCanvas/WoongKonvaMarker.d.ts +0 -48
package/README.md
CHANGED
|
@@ -129,7 +129,7 @@ npm pack
|
|
|
129
129
|
#### 5. NPM에 배포
|
|
130
130
|
스코프 패키지(`@mint-ui/map`)는 기본적으로 private이므로 public으로 배포해야 합니다.
|
|
131
131
|
```bash
|
|
132
|
-
npm publish
|
|
132
|
+
npm publish
|
|
133
133
|
```
|
|
134
134
|
|
|
135
135
|
#### 6. 배포 완료 확인
|
|
@@ -154,7 +154,7 @@ npm version patch
|
|
|
154
154
|
npm pack
|
|
155
155
|
|
|
156
156
|
# 5단계: 배포
|
|
157
|
-
npm publish
|
|
157
|
+
npm publish
|
|
158
158
|
```
|
|
159
159
|
|
|
160
160
|
### 현재 패키지 정보
|
|
@@ -185,7 +185,7 @@ npm publish --access public
|
|
|
185
185
|
npm run build
|
|
186
186
|
|
|
187
187
|
# test tag로 배포
|
|
188
|
-
npm publish
|
|
188
|
+
npm publish --tag test
|
|
189
189
|
```
|
|
190
190
|
|
|
191
191
|
3. **변경사항 커밋 및 푸시**
|
|
@@ -202,7 +202,7 @@ npm publish --access public
|
|
|
202
202
|
|
|
203
203
|
# 빌드 및 배포
|
|
204
204
|
npm run build
|
|
205
|
-
npm publish
|
|
205
|
+
npm publish --tag test
|
|
206
206
|
|
|
207
207
|
# 커밋 및 푸시
|
|
208
208
|
git add .
|
|
@@ -215,7 +215,7 @@ npm publish --access public
|
|
|
215
215
|
git checkout -b 1.2.0-test.2
|
|
216
216
|
npm version 1.2.0-test.2 --no-git-tag-version
|
|
217
217
|
npm run build
|
|
218
|
-
npm publish
|
|
218
|
+
npm publish --tag test
|
|
219
219
|
git add .
|
|
220
220
|
git commit -m "chore: release 1.2.0-test.2"
|
|
221
221
|
git push origin 1.2.0-test.2
|
|
@@ -234,7 +234,7 @@ npm publish --access public
|
|
|
234
234
|
|
|
235
235
|
# 빌드 및 배포
|
|
236
236
|
npm run build
|
|
237
|
-
npm publish
|
|
237
|
+
npm publish
|
|
238
238
|
|
|
239
239
|
# main에 푸시
|
|
240
240
|
git push origin main
|
|
@@ -267,5 +267,5 @@ npm install @mint-ui/map@1.2.0-test.1
|
|
|
267
267
|
### 주의사항
|
|
268
268
|
- 배포하기 전에 반드시 `npm run build`를 실행해야 합니다
|
|
269
269
|
- 버전은 한 번 배포하면 되돌릴 수 없으니 신중하게 결정하세요
|
|
270
|
-
- 스코프 패키지는
|
|
270
|
+
- 스코프 패키지는 `` 옵션을 반드시 붙여야 합니다
|
|
271
271
|
- test tag로 배포할 때는 `--no-git-tag-version` 옵션을 사용하여 git tag 생성을 방지합니다
|
|
@@ -24,6 +24,7 @@ export declare abstract class MintMapController {
|
|
|
24
24
|
abstract updateMarker(marker: Marker, options: MarkerOptions): void;
|
|
25
25
|
abstract clearDrawable(drawable: Drawable): boolean;
|
|
26
26
|
abstract markerToTheTop(marker: Marker): void;
|
|
27
|
+
abstract restoreMarkerZIndex(marker: Marker): void;
|
|
27
28
|
abstract isMapDragged(): boolean;
|
|
28
29
|
abstract setMapDragged(value: boolean): void;
|
|
29
30
|
abstract setMarkerZIndex(marker: Marker, zIndex: number): void;
|
|
@@ -8,9 +8,11 @@ var React = require('react');
|
|
|
8
8
|
var MapTypes = require('../types/MapTypes.js');
|
|
9
9
|
var MintMapProvider = require('./provider/MintMapProvider.js');
|
|
10
10
|
var MintMapCore_module = require('./MintMapCore.module.scss.js');
|
|
11
|
+
require('./advanced/woongCanvas/shared/types.js');
|
|
11
12
|
require('../types/MapDrawables.js');
|
|
12
13
|
require('../types/MapEventTypes.js');
|
|
13
14
|
var context = require('./advanced/woongCanvas/shared/context.js');
|
|
15
|
+
require('./advanced/woongCanvas/shared/performance.js');
|
|
14
16
|
|
|
15
17
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
16
18
|
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { MarkerOptions } from "../../../types";
|
|
3
|
+
import { KonvaCanvasMarkerData, CanvasDataType, CustomRenderBase, CustomRenderAnimation, CustomRenderEvent } from "./shared";
|
|
4
|
+
export { KonvaMarkerProvider, LRUCache, SpatialHashGrid, CanvasDataType } from "./shared";
|
|
5
|
+
export type { KonvaCanvasMarkerOption, Paths, KonvaCanvasMarkerData, CustomRenderBase, CustomRenderAnimation, CustomRenderEvent, RenderUtils, RenderBaseParams, RenderAnimationParams, RenderEventParams } from "./shared";
|
|
6
|
+
/**
|
|
7
|
+
* 공통 Props (MARKER와 POLYGON 모두 사용)
|
|
8
|
+
*/
|
|
9
|
+
interface WoongCanvasLayerBaseProps<T> extends Pick<MarkerOptions, 'zIndex' | 'anchor' | 'visible'> {
|
|
10
|
+
/** 렌더링할 마커 데이터 배열 */
|
|
11
|
+
markers: KonvaCanvasMarkerData<T>[];
|
|
12
|
+
/** 마커 클릭 시 호출되는 콜백 (선택) */
|
|
13
|
+
onClick?: (payload: KonvaCanvasMarkerData<T>, selectedIds: Set<string>) => void;
|
|
14
|
+
/** 마커에 마우스 오버 시 호출되는 콜백 (선택) */
|
|
15
|
+
onMouseOver?: (payload: KonvaCanvasMarkerData<T>) => void;
|
|
16
|
+
/** 마커에서 마우스 아웃 시 호출되는 콜백 (선택) */
|
|
17
|
+
onMouseOut?: (payload: KonvaCanvasMarkerData<T>) => void;
|
|
18
|
+
/** 다중 선택 활성화 여부 (기본: false) */
|
|
19
|
+
enableMultiSelect?: boolean;
|
|
20
|
+
/** hover 시 마커를 최상단으로 표시 (기본: false) */
|
|
21
|
+
topOnHover?: boolean;
|
|
22
|
+
/** 뷰포트 컬링 활성화 여부 (기본: true) */
|
|
23
|
+
enableViewportCulling?: boolean;
|
|
24
|
+
/** 뷰포트 컬링 여유 공간 (기본: 100px) */
|
|
25
|
+
cullingMargin?: number;
|
|
26
|
+
/** LRU 캐시 최대 크기 (기본: 10000) */
|
|
27
|
+
maxCacheSize?: number;
|
|
28
|
+
/** 외부에서 제어하는 선택된 항목 배열 (선택) */
|
|
29
|
+
selectedItems?: KonvaCanvasMarkerData<T>[];
|
|
30
|
+
/** 외부에서 전달된 단일 선택 아이템 (특별한 효과용) */
|
|
31
|
+
selectedItem?: KonvaCanvasMarkerData<T> | null;
|
|
32
|
+
/** 상호작용 비활성화 (hover, click 등 모든 이벤트 차단) */
|
|
33
|
+
disableInteraction?: boolean;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* MARKER 타입 Props - 커스텀 렌더링 필수
|
|
37
|
+
*/
|
|
38
|
+
interface WoongCanvasLayerPropsForMarker<T> extends WoongCanvasLayerBaseProps<T> {
|
|
39
|
+
/** 데이터 타입 */
|
|
40
|
+
dataType: CanvasDataType.MARKER;
|
|
41
|
+
/** Base Layer 렌더링 함수 (필수) */
|
|
42
|
+
renderBase: CustomRenderBase<T>;
|
|
43
|
+
/** Animation Layer 렌더링 함수 (선택, 애니메이션용) */
|
|
44
|
+
renderAnimation?: CustomRenderAnimation<T>;
|
|
45
|
+
/** Event Layer 렌더링 함수 (선택) */
|
|
46
|
+
renderEvent?: CustomRenderEvent<T>;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* POLYGON 타입 Props - 스타일 속성으로 내부 처리
|
|
50
|
+
*/
|
|
51
|
+
interface WoongCanvasLayerPropsForPolygon<T> extends WoongCanvasLayerBaseProps<T> {
|
|
52
|
+
/** 데이터 타입 */
|
|
53
|
+
dataType: CanvasDataType.POLYGON;
|
|
54
|
+
/** 기본 폴리곤 채우기 색상 (필수) */
|
|
55
|
+
baseFillColor: string;
|
|
56
|
+
/** 기본 폴리곤 테두리 색상 (필수) */
|
|
57
|
+
baseStrokeColor: string;
|
|
58
|
+
/** 기본 폴리곤 테두리 두께 (필수) */
|
|
59
|
+
baseLineWidth: number;
|
|
60
|
+
/** 선택된 폴리곤 채우기 색상 (필수) */
|
|
61
|
+
selectedFillColor: string;
|
|
62
|
+
/** 선택된 폴리곤 테두리 색상 (필수) */
|
|
63
|
+
selectedStrokeColor: string;
|
|
64
|
+
/** 선택된 폴리곤 테두리 두께 (필수) */
|
|
65
|
+
selectedLineWidth: number;
|
|
66
|
+
/** 마지막 선택된 폴리곤 채우기 색상 (선택, 기본값: selectedFillColor) */
|
|
67
|
+
activeFillColor?: string;
|
|
68
|
+
/** 마지막 선택된 폴리곤 테두리 색상 (선택, 기본값: selectedStrokeColor) */
|
|
69
|
+
activeStrokeColor?: string;
|
|
70
|
+
/** 마지막 선택된 폴리곤 테두리 두께 (선택, 기본값: selectedLineWidth) */
|
|
71
|
+
activeLineWidth?: number;
|
|
72
|
+
/** Hover 시 폴리곤 채우기 색상 (선택, 기본값: selectedFillColor) */
|
|
73
|
+
hoveredFillColor?: string;
|
|
74
|
+
/** Hover 시 폴리곤 테두리 색상 (선택, 기본값: selectedStrokeColor) */
|
|
75
|
+
hoveredStrokeColor?: string;
|
|
76
|
+
/** Hover 시 폴리곤 테두리 두께 (선택, 기본값: selectedLineWidth) */
|
|
77
|
+
hoveredLineWidth?: number;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* 최종 Props 타입 - Discriminated Union
|
|
81
|
+
*/
|
|
82
|
+
export declare type WoongCanvasLayerProps<T> = WoongCanvasLayerPropsForMarker<T> | WoongCanvasLayerPropsForPolygon<T>;
|
|
83
|
+
/**
|
|
84
|
+
* 🔥 React.memo 최적화: 마커 배열과 selectedItems 변경 체크
|
|
85
|
+
*
|
|
86
|
+
* 비교 전략:
|
|
87
|
+
* 1. markers 배열 비교
|
|
88
|
+
* 2. selectedItems 배열 비교 (외부 제어)
|
|
89
|
+
*
|
|
90
|
+
* 주의: JSON.stringify() 사용 금지! (매우 느림)
|
|
91
|
+
*/
|
|
92
|
+
declare const WoongCanvasLayer: <T>(props: WoongCanvasLayerProps<T>) => React.ReactPortal;
|
|
93
|
+
export default WoongCanvasLayer;
|