masoneffect 0.1.19 → 0.1.21

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/package.json CHANGED
@@ -1,31 +1,32 @@
1
1
  {
2
2
  "name": "masoneffect",
3
- "version": "0.1.19",
3
+ "version": "0.1.21",
4
4
  "description": "파티클 모핑 효과를 제공하는 라이브러리 - React, Vue, 바닐라 JS 지원",
5
- "main": "dist/index.min.js",
6
- "module": "dist/index.esm.min.js",
5
+ "main": "dist/index.cjs",
6
+ "module": "dist/index.mjs",
7
7
  "types": "dist/index.d.ts",
8
8
  "exports": {
9
9
  ".": {
10
- "import": "./dist/index.esm.min.js",
11
- "require": "./dist/index.min.js",
10
+ "import": "./dist/index.mjs",
11
+ "require": "./dist/index.cjs",
12
12
  "types": "./dist/index.d.ts"
13
13
  },
14
14
  "./react": {
15
- "import": "./dist/react/MasonEffect.min.js",
16
- "require": "./dist/react/MasonEffect.min.cjs",
15
+ "import": "./dist/react/index.mjs",
16
+ "require": "./dist/react/index.cjs",
17
17
  "types": "./dist/react/index.d.ts"
18
18
  },
19
19
  "./vue": {
20
- "import": "./src/vue/MasonEffect.vue"
20
+ "import": "./dist/vue/index.mjs",
21
+ "require": "./dist/vue/index.cjs",
22
+ "types": "./dist/vue/index.d.ts"
21
23
  }
22
24
  },
23
25
  "files": [
24
- "dist",
25
- "src"
26
+ "dist"
26
27
  ],
27
28
  "scripts": {
28
- "build": "rollup -c rollup.config.mjs && node scripts/generate-react-types.js",
29
+ "build": "rollup -c rollup.config.mjs && vite build && node scripts/generate-react-types.js",
29
30
  "dev": "rollup -c rollup.config.mjs -w",
30
31
  "serve": "npx http-server . -p 8080 -o --cors",
31
32
  "dev:example": "npm run serve",
@@ -58,11 +59,14 @@
58
59
  "@rollup/plugin-typescript": "^11.1.5",
59
60
  "@types/react": "^19.2.3",
60
61
  "@types/react-dom": "^19.2.3",
62
+ "@vitejs/plugin-vue": "^5.0.0",
61
63
  "react": "^19.2.0",
62
64
  "react-dom": "^19.2.0",
63
65
  "rollup": "^4.9.0",
64
66
  "tslib": "^2.8.1",
65
- "typescript": "^5.3.3"
67
+ "typescript": "^5.3.3",
68
+ "vite": "^5.0.0",
69
+ "vite-plugin-dts": "^3.6.0"
66
70
  },
67
71
  "peerDependencies": {
68
72
  "react": ">=16.8.0 || >=19.0.0-0",
package/dist/index.esm.js DELETED
@@ -1,407 +0,0 @@
1
- /**
2
- * MasonEffect - 파티클 모핑 효과 라이브러리
3
- * 바닐라 JS 코어 클래스
4
- */
5
- // 디바운스 유틸리티 함수
6
- function debounce(func, wait) {
7
- let timeout = null;
8
- return function executedFunction(...args) {
9
- const later = () => {
10
- timeout = null;
11
- func.apply(this, args);
12
- };
13
- if (timeout !== null) {
14
- clearTimeout(timeout);
15
- }
16
- timeout = setTimeout(later, wait);
17
- };
18
- }
19
- class MasonEffect {
20
- constructor(container, options = {}) {
21
- // 컨테이너 요소
22
- this.container = typeof container === 'string'
23
- ? document.querySelector(container)
24
- : container;
25
- if (!this.container) {
26
- throw new Error('Container element not found');
27
- }
28
- // 설정값들
29
- this.config = {
30
- text: options.text || 'mason effect',
31
- densityStep: options.densityStep ?? 2,
32
- maxParticles: options.maxParticles ?? 3200,
33
- pointSize: options.pointSize ?? 0.5,
34
- ease: options.ease ?? 0.05,
35
- repelRadius: options.repelRadius ?? 150,
36
- repelStrength: options.repelStrength ?? 1,
37
- particleColor: options.particleColor || '#fff',
38
- fontFamily: options.fontFamily || 'Inter, system-ui, Arial',
39
- fontSize: options.fontSize || null,
40
- width: options.width || null,
41
- height: options.height || null,
42
- devicePixelRatio: options.devicePixelRatio ?? null,
43
- onReady: options.onReady || null,
44
- onUpdate: options.onUpdate || null,
45
- };
46
- // 캔버스 생성
47
- this.canvas = document.createElement('canvas');
48
- const ctx = this.canvas.getContext('2d');
49
- if (!ctx) {
50
- throw new Error('Canvas context not available');
51
- }
52
- this.ctx = ctx;
53
- this.container.appendChild(this.canvas);
54
- this.canvas.style.display = 'block';
55
- // 오프스크린 캔버스 (텍스트 렌더링용)
56
- this.offCanvas = document.createElement('canvas');
57
- const offCtx = this.offCanvas.getContext('2d');
58
- if (!offCtx) {
59
- throw new Error('Offscreen canvas context not available');
60
- }
61
- this.offCtx = offCtx;
62
- // 상태
63
- this.W = 0;
64
- this.H = 0;
65
- this.DPR = this.config.devicePixelRatio || Math.min(window.devicePixelRatio || 1, 1.8);
66
- this.particles = [];
67
- this.mouse = { x: 0, y: 0, down: false };
68
- this.animationId = null;
69
- this.isRunning = false;
70
- this.isVisible = false;
71
- this.intersectionObserver = null;
72
- // 디바운스 설정 (ms)
73
- this.debounceDelay = options.debounceDelay ?? 150;
74
- // 이벤트 핸들러 바인딩 (디바운스 적용 전에 바인딩)
75
- const boundHandleResize = this.handleResize.bind(this);
76
- this.handleResize = debounce(boundHandleResize, this.debounceDelay);
77
- this.handleMouseMove = this.handleMouseMove.bind(this);
78
- this.handleMouseLeave = this.handleMouseLeave.bind(this);
79
- this.handleMouseDown = this.handleMouseDown.bind(this);
80
- this.handleMouseUp = this.handleMouseUp.bind(this);
81
- // morph와 updateConfig를 위한 디바운스된 내부 메서드
82
- this._debouncedMorph = debounce(this._morphInternal.bind(this), this.debounceDelay);
83
- this._debouncedUpdateConfig = debounce(this._updateConfigInternal.bind(this), this.debounceDelay);
84
- // 초기화
85
- this.init();
86
- }
87
- init() {
88
- this.resize();
89
- this.setupEventListeners();
90
- this.setupIntersectionObserver();
91
- if (this.config.onReady) {
92
- this.config.onReady(this);
93
- }
94
- }
95
- setupIntersectionObserver() {
96
- // IntersectionObserver가 지원되지 않는 환경에서는 항상 재생
97
- if (typeof window === 'undefined' || typeof window.IntersectionObserver === 'undefined') {
98
- this.isVisible = true;
99
- this.start();
100
- return;
101
- }
102
- // 이미 설정되어 있다면 다시 만들지 않음
103
- if (this.intersectionObserver) {
104
- return;
105
- }
106
- this.intersectionObserver = new IntersectionObserver((entries) => {
107
- for (const entry of entries) {
108
- if (entry.target !== this.container)
109
- continue;
110
- if (entry.isIntersecting) {
111
- this.isVisible = true;
112
- this.start();
113
- }
114
- else {
115
- this.isVisible = false;
116
- this.stop();
117
- }
118
- }
119
- }, {
120
- threshold: 0.1, // 10% 이상 보일 때 동작
121
- });
122
- this.intersectionObserver.observe(this.container);
123
- }
124
- resize() {
125
- const width = this.config.width || this.container.clientWidth || window.innerWidth;
126
- const height = this.config.height || this.container.clientHeight || window.innerHeight * 0.7;
127
- // 최소 크기 보장
128
- if (width <= 0 || height <= 0) {
129
- return;
130
- }
131
- this.W = Math.floor(width * this.DPR);
132
- this.H = Math.floor(height * this.DPR);
133
- // 캔버스 크기 제한 (메모리 오류 방지)
134
- // getImageData는 최대 약 268MB (4096x4096x4)까지 지원
135
- const MAX_CANVAS_SIZE = 4096;
136
- if (this.W > MAX_CANVAS_SIZE || this.H > MAX_CANVAS_SIZE) {
137
- const scale = Math.min(MAX_CANVAS_SIZE / this.W, MAX_CANVAS_SIZE / this.H);
138
- this.W = Math.floor(this.W * scale);
139
- this.H = Math.floor(this.H * scale);
140
- this.DPR = this.DPR * scale;
141
- }
142
- this.canvas.width = this.W;
143
- this.canvas.height = this.H;
144
- this.canvas.style.width = width + 'px';
145
- this.canvas.style.height = height + 'px';
146
- // 크기가 유효할 때만 buildTargets 실행
147
- if (this.W > 0 && this.H > 0) {
148
- this.buildTargets();
149
- if (!this.particles.length) {
150
- this.initParticles();
151
- }
152
- }
153
- }
154
- buildTargets() {
155
- // 크기 검증
156
- if (this.W <= 0 || this.H <= 0) {
157
- return;
158
- }
159
- const text = this.config.text;
160
- this.offCanvas.width = this.W;
161
- this.offCanvas.height = this.H;
162
- this.offCtx.clearRect(0, 0, this.offCanvas.width, this.offCanvas.height);
163
- const base = Math.min(this.W, this.H);
164
- const fontSize = this.config.fontSize || Math.max(80, Math.floor(base * 0.18));
165
- this.offCtx.fillStyle = '#ffffff';
166
- this.offCtx.textAlign = 'center';
167
- this.offCtx.textBaseline = 'middle';
168
- this.offCtx.font = `400 ${fontSize}px ${this.config.fontFamily}`;
169
- // 글자 간격 계산 및 그리기
170
- const chars = text.split('');
171
- const spacing = fontSize * 0.05;
172
- const totalWidth = this.offCtx.measureText(text).width + spacing * (chars.length - 1);
173
- let x = this.W / 2 - totalWidth / 2;
174
- for (const ch of chars) {
175
- this.offCtx.fillText(ch, x + this.offCtx.measureText(ch).width / 2, this.H / 2);
176
- x += this.offCtx.measureText(ch).width + spacing;
177
- }
178
- // 픽셀 샘플링
179
- const step = Math.max(2, this.config.densityStep);
180
- const img = this.offCtx.getImageData(0, 0, this.W, this.H).data;
181
- const targets = [];
182
- for (let y = 0; y < this.H; y += step) {
183
- for (let x = 0; x < this.W; x += step) {
184
- const i = (y * this.W + x) * 4;
185
- if (img[i] + img[i + 1] + img[i + 2] > 600) {
186
- targets.push({ x, y });
187
- }
188
- }
189
- }
190
- // 파티클 수 제한
191
- while (targets.length > this.config.maxParticles) {
192
- targets.splice(Math.floor(Math.random() * targets.length), 1);
193
- }
194
- // 파티클 수 조정
195
- if (this.particles.length < targets.length) {
196
- const need = targets.length - this.particles.length;
197
- for (let i = 0; i < need; i++) {
198
- this.particles.push(this.makeParticle());
199
- }
200
- }
201
- else if (this.particles.length > targets.length) {
202
- this.particles.length = targets.length;
203
- }
204
- // 목표 좌표 할당
205
- for (let i = 0; i < this.particles.length; i++) {
206
- const p = this.particles[i];
207
- const t = targets[i];
208
- p.tx = t.x;
209
- p.ty = t.y;
210
- }
211
- }
212
- makeParticle() {
213
- // 캔버스 전체에 골고루 분포 (여백 없이)
214
- const sx = Math.random() * this.W;
215
- const sy = Math.random() * this.H;
216
- return {
217
- x: sx,
218
- y: sy,
219
- vx: 0,
220
- vy: 0,
221
- tx: sx,
222
- ty: sy,
223
- initialX: sx, // 초기 위치 저장 (scatter 시 돌아갈 위치)
224
- initialY: sy,
225
- j: Math.random() * Math.PI * 2,
226
- };
227
- }
228
- initParticles() {
229
- // 캔버스 전체에 골고루 분포 (여백 없이)
230
- for (const p of this.particles) {
231
- const sx = Math.random() * this.W;
232
- const sy = Math.random() * this.H;
233
- p.x = sx;
234
- p.y = sy;
235
- p.vx = p.vy = 0;
236
- // 초기 위치 저장 (scatter 시 돌아갈 위치)
237
- p.initialX = sx;
238
- p.initialY = sy;
239
- }
240
- }
241
- scatter() {
242
- // 각 파티클을 초기 위치로 돌아가도록 설정
243
- for (const p of this.particles) {
244
- // 초기 위치가 저장되어 있으면 그 위치로, 없으면 현재 위치 유지
245
- if (p.initialX !== undefined && p.initialY !== undefined) {
246
- p.tx = p.initialX;
247
- p.ty = p.initialY;
248
- }
249
- else {
250
- // 초기 위치가 없으면 현재 위치를 초기 위치로 저장
251
- p.initialX = p.x;
252
- p.initialY = p.y;
253
- p.tx = p.initialX;
254
- p.ty = p.initialY;
255
- }
256
- }
257
- }
258
- morph(textOrOptions) {
259
- // 즉시 실행이 필요한 경우 (예: 초기화 시)를 위해 내부 메서드 직접 호출
260
- // 일반적인 경우에는 디바운스 적용
261
- this._debouncedMorph(textOrOptions);
262
- }
263
- _morphInternal(textOrOptions) {
264
- // W와 H가 0이면 resize 먼저 실행
265
- if (this.W === 0 || this.H === 0) {
266
- this.resize();
267
- }
268
- if (typeof textOrOptions === 'string') {
269
- // 문자열인 경우: 기존 동작 유지
270
- this.config.text = textOrOptions;
271
- this.buildTargets();
272
- }
273
- else if (textOrOptions && typeof textOrOptions === 'object') {
274
- // 객체인 경우: 텍스트와 함께 다른 설정도 변경
275
- const needsRebuild = textOrOptions.text !== undefined;
276
- this.config = { ...this.config, ...textOrOptions };
277
- if (needsRebuild) {
278
- this.buildTargets();
279
- }
280
- }
281
- else {
282
- // null이거나 undefined인 경우: 현재 텍스트로 재빌드
283
- this.buildTargets();
284
- }
285
- }
286
- update() {
287
- this.ctx.clearRect(0, 0, this.W, this.H);
288
- for (const p of this.particles) {
289
- // 목표 좌표로 당기는 힘
290
- let ax = (p.tx - p.x) * this.config.ease;
291
- let ay = (p.ty - p.y) * this.config.ease;
292
- // 마우스 반발/흡입
293
- if (this.mouse.x || this.mouse.y) {
294
- const dx = p.x - this.mouse.x;
295
- const dy = p.y - this.mouse.y;
296
- const d2 = dx * dx + dy * dy;
297
- const r = this.config.repelRadius * this.DPR;
298
- if (d2 < r * r) {
299
- const d = Math.sqrt(d2) + 0.0001;
300
- const f = (this.mouse.down ? -1 : 1) * this.config.repelStrength * (1 - d / r);
301
- ax += (dx / d) * f * 6.0;
302
- ay += (dy / d) * f * 6.0;
303
- }
304
- }
305
- // 진동 효과
306
- p.j += 2;
307
- ax += Math.cos(p.j) * 0.05;
308
- ay += Math.sin(p.j * 1.3) * 0.05;
309
- // 속도와 위치 업데이트
310
- p.vx = (p.vx + ax) * Math.random();
311
- p.vy = (p.vy + ay) * Math.random();
312
- p.x += p.vx;
313
- p.y += p.vy;
314
- }
315
- // 파티클 그리기
316
- this.ctx.fillStyle = this.config.particleColor;
317
- const r = this.config.pointSize * this.DPR;
318
- for (const p of this.particles) {
319
- this.ctx.beginPath();
320
- this.ctx.arc(p.x, p.y, r, 0, Math.PI * 2);
321
- this.ctx.fill();
322
- }
323
- if (this.config.onUpdate) {
324
- this.config.onUpdate(this);
325
- }
326
- }
327
- animate() {
328
- if (!this.isRunning)
329
- return;
330
- this.update();
331
- this.animationId = requestAnimationFrame(() => this.animate());
332
- }
333
- start() {
334
- if (this.isRunning)
335
- return;
336
- this.isRunning = true;
337
- this.animate();
338
- }
339
- stop() {
340
- this.isRunning = false;
341
- if (this.animationId) {
342
- cancelAnimationFrame(this.animationId);
343
- this.animationId = null;
344
- }
345
- }
346
- setupEventListeners() {
347
- window.addEventListener('resize', this.handleResize);
348
- this.canvas.addEventListener('mousemove', this.handleMouseMove);
349
- this.canvas.addEventListener('mouseleave', this.handleMouseLeave);
350
- this.canvas.addEventListener('mousedown', this.handleMouseDown);
351
- window.addEventListener('mouseup', this.handleMouseUp);
352
- }
353
- removeEventListeners() {
354
- window.removeEventListener('resize', this.handleResize);
355
- this.canvas.removeEventListener('mousemove', this.handleMouseMove);
356
- this.canvas.removeEventListener('mouseleave', this.handleMouseLeave);
357
- this.canvas.removeEventListener('mousedown', this.handleMouseDown);
358
- window.removeEventListener('mouseup', this.handleMouseUp);
359
- }
360
- handleResize() {
361
- this.resize();
362
- }
363
- handleMouseMove(e) {
364
- const rect = this.canvas.getBoundingClientRect();
365
- this.mouse.x = (e.clientX - rect.left) * this.DPR;
366
- this.mouse.y = (e.clientY - rect.top) * this.DPR;
367
- }
368
- handleMouseLeave() {
369
- this.mouse.x = this.mouse.y = 0;
370
- }
371
- handleMouseDown() {
372
- this.mouse.down = true;
373
- }
374
- handleMouseUp() {
375
- this.mouse.down = false;
376
- }
377
- // 설정 업데이트
378
- updateConfig(newConfig) {
379
- // 디바운스 적용
380
- this._debouncedUpdateConfig(newConfig);
381
- }
382
- _updateConfigInternal(newConfig) {
383
- this.config = { ...this.config, ...newConfig };
384
- if (newConfig.text) {
385
- this.buildTargets();
386
- }
387
- }
388
- // 파괴 및 정리
389
- destroy() {
390
- this.stop();
391
- this.removeEventListeners();
392
- if (this.intersectionObserver) {
393
- this.intersectionObserver.disconnect();
394
- this.intersectionObserver = null;
395
- }
396
- if (this.canvas && this.canvas.parentNode) {
397
- this.canvas.parentNode.removeChild(this.canvas);
398
- }
399
- }
400
- }
401
-
402
- /**
403
- * MasonEffect - 메인 엔트리 포인트
404
- */
405
-
406
- export { MasonEffect, MasonEffect as default };
407
- //# sourceMappingURL=index.esm.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.esm.js","sources":["../src/core/index.ts","../src/index.ts"],"sourcesContent":[null,null],"names":[],"mappings":"AAAA;;;AAGG;AAiCH;AACA,SAAS,QAAQ,CACf,IAAO,EACP,IAAY,EAAA;IAEZ,IAAI,OAAO,GAAyC,IAAI;AACxD,IAAA,OAAO,SAAS,gBAAgB,CAAC,GAAG,IAAmB,EAAA;QACrD,MAAM,KAAK,GAAG,MAAK;YACjB,OAAO,GAAG,IAAI;AACd,YAAA,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC;AACxB,QAAA,CAAC;AACD,QAAA,IAAI,OAAO,KAAK,IAAI,EAAE;YACpB,YAAY,CAAC,OAAO,CAAC;QACvB;AACA,QAAA,OAAO,GAAG,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC;AACnC,IAAA,CAAC;AACH;MAEa,WAAW,CAAA;IAuBtB,WAAA,CAAY,SAA+B,EAAE,OAAA,GAA8B,EAAE,EAAA;;AAE3E,QAAA,IAAI,CAAC,SAAS,GAAG,OAAO,SAAS,KAAK;AACpC,cAAE,QAAQ,CAAC,aAAa,CAAC,SAAS;cAChC,SAAS;AAEb,QAAA,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;AACnB,YAAA,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC;QAChD;;QAGA,IAAI,CAAC,MAAM,GAAG;AACZ,YAAA,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,cAAc;AACpC,YAAA,WAAW,EAAE,OAAO,CAAC,WAAW,IAAI,CAAC;AACrC,YAAA,YAAY,EAAE,OAAO,CAAC,YAAY,IAAI,IAAI;AAC1C,YAAA,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,GAAG;AACnC,YAAA,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,IAAI;AAC1B,YAAA,WAAW,EAAE,OAAO,CAAC,WAAW,IAAI,GAAG;AACvC,YAAA,aAAa,EAAE,OAAO,CAAC,aAAa,IAAI,CAAC;AACzC,YAAA,aAAa,EAAE,OAAO,CAAC,aAAa,IAAI,MAAM;AAC9C,YAAA,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,yBAAyB;AAC3D,YAAA,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,IAAI;AAClC,YAAA,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,IAAI;AAC5B,YAAA,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,IAAI;AAC9B,YAAA,gBAAgB,EAAE,OAAO,CAAC,gBAAgB,IAAI,IAAI;AAClD,YAAA,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,IAAI;AAChC,YAAA,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,IAAI;SACb;;QAGvB,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC;QAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC;QACxC,IAAI,CAAC,GAAG,EAAE;AACR,YAAA,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC;QACjD;AACA,QAAA,IAAI,CAAC,GAAG,GAAG,GAAG;QACd,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO;;QAGnC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC;QACjD,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC;QAC9C,IAAI,CAAC,MAAM,EAAE;AACX,YAAA,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC;QAC3D;AACA,QAAA,IAAI,CAAC,MAAM,GAAG,MAAM;;AAGpB,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC;AACV,QAAA,IAAI,CAAC,CAAC,GAAG,CAAC;QACV,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,IAAI,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,gBAAgB,IAAI,CAAC,EAAE,GAAG,CAAC;AACtF,QAAA,IAAI,CAAC,SAAS,GAAG,EAAE;AACnB,QAAA,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE;AACxC,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI;AACvB,QAAA,IAAI,CAAC,SAAS,GAAG,KAAK;AACtB,QAAA,IAAI,CAAC,SAAS,GAAG,KAAK;AACtB,QAAA,IAAI,CAAC,oBAAoB,GAAG,IAAI;;QAGhC,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,IAAI,GAAG;;QAGjD,MAAM,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;QACtD,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,iBAAiB,EAAE,IAAI,CAAC,aAAa,CAAC;QACnE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;QACtD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC;QACxD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;QACtD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC;;AAGlD,QAAA,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC;AACnF,QAAA,IAAI,CAAC,sBAAsB,GAAG,QAAQ,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC;;QAGjG,IAAI,CAAC,IAAI,EAAE;IACb;IAEA,IAAI,GAAA;QACF,IAAI,CAAC,MAAM,EAAE;QACb,IAAI,CAAC,mBAAmB,EAAE;QAC1B,IAAI,CAAC,yBAAyB,EAAE;AAEhC,QAAA,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;AACvB,YAAA,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC;QAC3B;IACF;IAEA,yBAAyB,GAAA;;AAEvB,QAAA,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,OAAO,MAAM,CAAC,oBAAoB,KAAK,WAAW,EAAE;AACvF,YAAA,IAAI,CAAC,SAAS,GAAG,IAAI;YACrB,IAAI,CAAC,KAAK,EAAE;YACZ;QACF;;AAGA,QAAA,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B;QACF;QAEA,IAAI,CAAC,oBAAoB,GAAG,IAAI,oBAAoB,CAClD,CAAC,OAAO,KAAI;AACV,YAAA,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE;AAC3B,gBAAA,IAAI,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC,SAAS;oBAAE;AAErC,gBAAA,IAAI,KAAK,CAAC,cAAc,EAAE;AACxB,oBAAA,IAAI,CAAC,SAAS,GAAG,IAAI;oBACrB,IAAI,CAAC,KAAK,EAAE;gBACd;qBAAO;AACL,oBAAA,IAAI,CAAC,SAAS,GAAG,KAAK;oBACtB,IAAI,CAAC,IAAI,EAAE;gBACb;YACF;AACF,QAAA,CAAC,EACD;YACE,SAAS,EAAE,GAAG;AACf,SAAA,CACF;QAED,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC;IACnD;IAEA,MAAM,GAAA;AACJ,QAAA,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,IAAI,MAAM,CAAC,UAAU;AAClF,QAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY,IAAI,MAAM,CAAC,WAAW,GAAG,GAAG;;QAG5F,IAAI,KAAK,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,EAAE;YAC7B;QACF;AAEA,QAAA,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC;AACrC,QAAA,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC;;;QAItC,MAAM,eAAe,GAAG,IAAI;AAC5B,QAAA,IAAI,IAAI,CAAC,CAAC,GAAG,eAAe,IAAI,IAAI,CAAC,CAAC,GAAG,eAAe,EAAE;AACxD,YAAA,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,eAAe,GAAG,IAAI,CAAC,CAAC,EAAE,eAAe,GAAG,IAAI,CAAC,CAAC,CAAC;AAC1E,YAAA,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC;AACnC,YAAA,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC;YACnC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,KAAK;QAC7B;QAEA,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,GAAG,IAAI;QACtC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,GAAG,IAAI;;AAGxC,QAAA,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE;YAC5B,IAAI,CAAC,YAAY,EAAE;AACnB,YAAA,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;gBAC1B,IAAI,CAAC,aAAa,EAAE;YACtB;QACF;IACF;IAEA,YAAY,GAAA;;AAEV,QAAA,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE;YAC9B;QACF;AAEA,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI;QAC7B,IAAI,CAAC,SAAS,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;QAC7B,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;AAExE,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;QACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;AAC9E,QAAA,IAAI,CAAC,MAAM,CAAC,SAAS,GAAG,SAAS;AACjC,QAAA,IAAI,CAAC,MAAM,CAAC,SAAS,GAAG,QAAQ;AAChC,QAAA,IAAI,CAAC,MAAM,CAAC,YAAY,GAAG,QAAQ;AACnC,QAAA,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,CAAA,IAAA,EAAO,QAAQ,CAAA,GAAA,EAAM,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;;QAGhE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;AAC5B,QAAA,MAAM,OAAO,GAAG,QAAQ,GAAG,IAAI;QAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,KAAK,GAAG,OAAO,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACrF,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,UAAU,GAAG,CAAC;AAEnC,QAAA,KAAK,MAAM,EAAE,IAAI,KAAK,EAAE;AACtB,YAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AAC/E,YAAA,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,KAAK,GAAG,OAAO;QAClD;;AAGA,QAAA,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;QACjD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI;QAC/D,MAAM,OAAO,GAAoC,EAAE;AAEnD,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,EAAE;AACrC,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,EAAE;AACrC,gBAAA,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC;gBAC9B,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE;oBAC1C,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;gBACxB;YACF;QACF;;QAGA,OAAO,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE;AAChD,YAAA,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC/D;;QAGA,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE;YAC1C,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM;AACnD,YAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;gBAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YAC1C;QACF;aAAO,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE;YACjD,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM;QACxC;;AAGA,QAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC9C,MAAM,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;AAC3B,YAAA,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;AACpB,YAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AACV,YAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QACZ;IACF;IAEA,YAAY,GAAA;;QAEV,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC;QACjC,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC;QACjC,OAAO;AACL,YAAA,CAAC,EAAE,EAAE;AACL,YAAA,CAAC,EAAE,EAAE;AACL,YAAA,EAAE,EAAE,CAAC;AACL,YAAA,EAAE,EAAE,CAAC;AACL,YAAA,EAAE,EAAE,EAAE;AACN,YAAA,EAAE,EAAE,EAAE;YACN,QAAQ,EAAE,EAAE;AACZ,YAAA,QAAQ,EAAE,EAAE;YACZ,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC;SAC/B;IACH;IAEA,aAAa,GAAA;;AAEX,QAAA,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE;YAC9B,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC;YACjC,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC;AACjC,YAAA,CAAC,CAAC,CAAC,GAAG,EAAE;AACR,YAAA,CAAC,CAAC,CAAC,GAAG,EAAE;YACR,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC;;AAEf,YAAA,CAAC,CAAC,QAAQ,GAAG,EAAE;AACf,YAAA,CAAC,CAAC,QAAQ,GAAG,EAAE;QACjB;IACF;IAEA,OAAO,GAAA;;AAEL,QAAA,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE;;AAE9B,YAAA,IAAI,CAAC,CAAC,QAAQ,KAAK,SAAS,IAAI,CAAC,CAAC,QAAQ,KAAK,SAAS,EAAE;AACxD,gBAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ;AACjB,gBAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ;YACnB;iBAAO;;AAEL,gBAAA,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;AAChB,gBAAA,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;AAChB,gBAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ;AACjB,gBAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,QAAQ;YACnB;QACF;IACF;AAEA,IAAA,KAAK,CAAC,aAA2D,EAAA;;;AAG/D,QAAA,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC;IACrC;AAEA,IAAA,cAAc,CAAC,aAA2D,EAAA;;AAExE,QAAA,IAAI,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE;YAChC,IAAI,CAAC,MAAM,EAAE;QACf;AAEA,QAAA,IAAI,OAAO,aAAa,KAAK,QAAQ,EAAE;;AAErC,YAAA,IAAI,CAAC,MAAM,CAAC,IAAI,GAAG,aAAa;YAChC,IAAI,CAAC,YAAY,EAAE;QACrB;AAAO,aAAA,IAAI,aAAa,IAAI,OAAO,aAAa,KAAK,QAAQ,EAAE;;AAE7D,YAAA,MAAM,YAAY,GAAG,aAAa,CAAC,IAAI,KAAK,SAAS;AACrD,YAAA,IAAI,CAAC,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,aAAa,EAAE;YAClD,IAAI,YAAY,EAAE;gBAChB,IAAI,CAAC,YAAY,EAAE;YACrB;QACF;aAAO;;YAEL,IAAI,CAAC,YAAY,EAAE;QACrB;IACF;IAEA,MAAM,GAAA;AACJ,QAAA,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;AAExC,QAAA,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE;;AAE9B,YAAA,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI;AACxC,YAAA,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI;;AAGxC,YAAA,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE;gBAChC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC7B,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC7B,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE;gBAC5B,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG;AAC5C,gBAAA,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE;oBACd,MAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,MAAM;AAChC,oBAAA,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,aAAa,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;oBAC9E,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG;oBACxB,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,GAAG;gBAC1B;YACF;;AAGA,YAAA,CAAC,CAAC,CAAC,IAAI,CAAC;YACR,EAAE,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI;AAC1B,YAAA,EAAE,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI;;AAGhC,YAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE;AAClC,YAAA,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE;AAClC,YAAA,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE;AACX,YAAA,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE;QACb;;QAGA,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa;QAC9C,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG;AAC1C,QAAA,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE;AAC9B,YAAA,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE;YACpB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;AACzC,YAAA,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE;QACjB;AAEA,QAAA,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;AACxB,YAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC5B;IACF;IAEA,OAAO,GAAA;QACL,IAAI,CAAC,IAAI,CAAC,SAAS;YAAE;QACrB,IAAI,CAAC,MAAM,EAAE;AACb,QAAA,IAAI,CAAC,WAAW,GAAG,qBAAqB,CAAC,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;IAChE;IAEA,KAAK,GAAA;QACH,IAAI,IAAI,CAAC,SAAS;YAAE;AACpB,QAAA,IAAI,CAAC,SAAS,GAAG,IAAI;QACrB,IAAI,CAAC,OAAO,EAAE;IAChB;IAEA,IAAI,GAAA;AACF,QAAA,IAAI,CAAC,SAAS,GAAG,KAAK;AACtB,QAAA,IAAI,IAAI,CAAC,WAAW,EAAE;AACpB,YAAA,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC;AACtC,YAAA,IAAI,CAAC,WAAW,GAAG,IAAI;QACzB;IACF;IAEA,mBAAmB,GAAA;QACjB,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC;QACpD,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC;QAC/D,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC;QACjE,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC;QAC/D,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC;IACxD;IAEA,oBAAoB,GAAA;QAClB,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC;QACvD,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC;QAClE,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC;QACpE,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC;QAClE,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC;IAC3D;IAEA,YAAY,GAAA;QACV,IAAI,CAAC,MAAM,EAAE;IACf;AAEA,IAAA,eAAe,CAAC,CAAa,EAAA;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE;AAChD,QAAA,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,GAAG;AACjD,QAAA,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG;IAClD;IAEA,gBAAgB,GAAA;AACd,QAAA,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC;IACjC;IAEA,eAAe,GAAA;AACb,QAAA,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI;IACxB;IAEA,aAAa,GAAA;AACX,QAAA,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,KAAK;IACzB;;AAGA,IAAA,YAAY,CAAC,SAAsC,EAAA;;AAEjD,QAAA,IAAI,CAAC,sBAAsB,CAAC,SAAS,CAAC;IACxC;AAEA,IAAA,qBAAqB,CAAC,SAAsC,EAAA;AAC1D,QAAA,IAAI,CAAC,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,SAAS,EAAE;AAC9C,QAAA,IAAI,SAAS,CAAC,IAAI,EAAE;YAClB,IAAI,CAAC,YAAY,EAAE;QACrB;IACF;;IAGA,OAAO,GAAA;QACL,IAAI,CAAC,IAAI,EAAE;QACX,IAAI,CAAC,oBAAoB,EAAE;AAC3B,QAAA,IAAI,IAAI,CAAC,oBAAoB,EAAE;AAC7B,YAAA,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE;AACtC,YAAA,IAAI,CAAC,oBAAoB,GAAG,IAAI;QAClC;QACA,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YACzC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC;QACjD;IACF;AACD;;AC9fD;;AAEG;;;;"}
@@ -1 +0,0 @@
1
- function t(t,s){let i=null;return function(...h){null!==i&&clearTimeout(i),i=setTimeout(()=>{i=null,t.apply(this,h)},s)}}class s{constructor(s,i={}){if(this.container="string"==typeof s?document.querySelector(s):s,!this.container)throw Error("Container element not found");this.config={text:i.text||"mason effect",densityStep:i.densityStep??2,maxParticles:i.maxParticles??3200,pointSize:i.pointSize??.5,ease:i.ease??.05,repelRadius:i.repelRadius??150,repelStrength:i.repelStrength??1,particleColor:i.particleColor||"#fff",fontFamily:i.fontFamily||"Inter, system-ui, Arial",fontSize:i.fontSize||null,width:i.width||null,height:i.height||null,devicePixelRatio:i.devicePixelRatio??null,onReady:i.onReady||null,onUpdate:i.onUpdate||null},this.canvas=document.createElement("canvas");const h=this.canvas.getContext("2d");if(!h)throw Error("Canvas context not available");this.ctx=h,this.container.appendChild(this.canvas),this.canvas.style.display="block",this.offCanvas=document.createElement("canvas");const e=this.offCanvas.getContext("2d");if(!e)throw Error("Offscreen canvas context not available");this.offCtx=e,this.W=0,this.H=0,this.DPR=this.config.devicePixelRatio||Math.min(window.devicePixelRatio||1,1.8),this.particles=[],this.mouse={x:0,y:0,down:!1},this.animationId=null,this.isRunning=!1,this.isVisible=!1,this.intersectionObserver=null,this.debounceDelay=i.debounceDelay??150;const o=this.handleResize.bind(this);this.handleResize=t(o,this.debounceDelay),this.handleMouseMove=this.handleMouseMove.bind(this),this.handleMouseLeave=this.handleMouseLeave.bind(this),this.handleMouseDown=this.handleMouseDown.bind(this),this.handleMouseUp=this.handleMouseUp.bind(this),this.t=t(this.i.bind(this),this.debounceDelay),this.h=t(this.o.bind(this),this.debounceDelay),this.init()}init(){this.resize(),this.setupEventListeners(),this.setupIntersectionObserver(),this.config.onReady&&this.config.onReady(this)}setupIntersectionObserver(){if("undefined"==typeof window||void 0===window.IntersectionObserver)return this.isVisible=!0,void this.start();this.intersectionObserver||(this.intersectionObserver=new IntersectionObserver(t=>{for(const s of t)s.target===this.container&&(s.isIntersecting?(this.isVisible=!0,this.start()):(this.isVisible=!1,this.stop()))},{threshold:.1}),this.intersectionObserver.observe(this.container))}resize(){const t=this.config.width||this.container.clientWidth||window.innerWidth,s=this.config.height||this.container.clientHeight||.7*window.innerHeight;if(0>=t||0>=s)return;this.W=Math.floor(t*this.DPR),this.H=Math.floor(s*this.DPR);const i=4096;if(this.W>i||this.H>i){const t=Math.min(i/this.W,i/this.H);this.W=Math.floor(this.W*t),this.H=Math.floor(this.H*t),this.DPR=this.DPR*t}this.canvas.width=this.W,this.canvas.height=this.H,this.canvas.style.width=t+"px",this.canvas.style.height=s+"px",this.W>0&&this.H>0&&(this.buildTargets(),this.particles.length||this.initParticles())}buildTargets(){if(0>=this.W||0>=this.H)return;const t=this.config.text;this.offCanvas.width=this.W,this.offCanvas.height=this.H,this.offCtx.clearRect(0,0,this.offCanvas.width,this.offCanvas.height);const s=Math.min(this.W,this.H),i=this.config.fontSize||Math.max(80,Math.floor(.18*s));this.offCtx.fillStyle="#ffffff",this.offCtx.textAlign="center",this.offCtx.textBaseline="middle",this.offCtx.font=`400 ${i}px ${this.config.fontFamily}`;const h=t.split(""),e=.05*i,o=this.offCtx.measureText(t).width+e*(h.length-1);let n=this.W/2-o/2;for(const t of h)this.offCtx.fillText(t,n+this.offCtx.measureText(t).width/2,this.H/2),n+=this.offCtx.measureText(t).width+e;const a=Math.max(2,this.config.densityStep),r=this.offCtx.getImageData(0,0,this.W,this.H).data,l=[];for(let t=0;t<this.H;t+=a)for(let s=0;s<this.W;s+=a){const i=4*(t*this.W+s);r[i]+r[i+1]+r[i+2]>600&&l.push({x:s,y:t})}for(;l.length>this.config.maxParticles;)l.splice(Math.floor(Math.random()*l.length),1);if(this.particles.length<l.length){const t=l.length-this.particles.length;for(let s=0;t>s;s++)this.particles.push(this.makeParticle())}else this.particles.length>l.length&&(this.particles.length=l.length);for(let t=0;t<this.particles.length;t++){const s=this.particles[t],i=l[t];s.tx=i.x,s.ty=i.y}}makeParticle(){const t=Math.random()*this.W,s=Math.random()*this.H;return{x:t,y:s,vx:0,vy:0,tx:t,ty:s,initialX:t,initialY:s,j:Math.random()*Math.PI*2}}initParticles(){for(const t of this.particles){const s=Math.random()*this.W,i=Math.random()*this.H;t.x=s,t.y=i,t.vx=t.vy=0,t.initialX=s,t.initialY=i}}scatter(){for(const t of this.particles)void 0!==t.initialX&&void 0!==t.initialY?(t.tx=t.initialX,t.ty=t.initialY):(t.initialX=t.x,t.initialY=t.y,t.tx=t.initialX,t.ty=t.initialY)}morph(t){this.t(t)}i(t){if(0!==this.W&&0!==this.H||this.resize(),"string"==typeof t)this.config.text=t,this.buildTargets();else if(t&&"object"==typeof t){const s=void 0!==t.text;this.config={...this.config,...t},s&&this.buildTargets()}else this.buildTargets()}update(){this.ctx.clearRect(0,0,this.W,this.H);for(const t of this.particles){let s=(t.tx-t.x)*this.config.ease,i=(t.ty-t.y)*this.config.ease;if(this.mouse.x||this.mouse.y){const h=t.x-this.mouse.x,e=t.y-this.mouse.y,o=h*h+e*e,n=this.config.repelRadius*this.DPR;if(n*n>o){const t=Math.sqrt(o)+1e-4,a=(this.mouse.down?-1:1)*this.config.repelStrength*(1-t/n);s+=h/t*a*6,i+=e/t*a*6}}t.j+=2,s+=.05*Math.cos(t.j),i+=.05*Math.sin(1.3*t.j),t.vx=(t.vx+s)*Math.random(),t.vy=(t.vy+i)*Math.random(),t.x+=t.vx,t.y+=t.vy}this.ctx.fillStyle=this.config.particleColor;const t=this.config.pointSize*this.DPR;for(const s of this.particles)this.ctx.beginPath(),this.ctx.arc(s.x,s.y,t,0,2*Math.PI),this.ctx.fill();this.config.onUpdate&&this.config.onUpdate(this)}animate(){this.isRunning&&(this.update(),this.animationId=requestAnimationFrame(()=>this.animate()))}start(){this.isRunning||(this.isRunning=!0,this.animate())}stop(){this.isRunning=!1,this.animationId&&(cancelAnimationFrame(this.animationId),this.animationId=null)}setupEventListeners(){window.addEventListener("resize",this.handleResize),this.canvas.addEventListener("mousemove",this.handleMouseMove),this.canvas.addEventListener("mouseleave",this.handleMouseLeave),this.canvas.addEventListener("mousedown",this.handleMouseDown),window.addEventListener("mouseup",this.handleMouseUp)}removeEventListeners(){window.removeEventListener("resize",this.handleResize),this.canvas.removeEventListener("mousemove",this.handleMouseMove),this.canvas.removeEventListener("mouseleave",this.handleMouseLeave),this.canvas.removeEventListener("mousedown",this.handleMouseDown),window.removeEventListener("mouseup",this.handleMouseUp)}handleResize(){this.resize()}handleMouseMove(t){const s=this.canvas.getBoundingClientRect();this.mouse.x=(t.clientX-s.left)*this.DPR,this.mouse.y=(t.clientY-s.top)*this.DPR}handleMouseLeave(){this.mouse.x=this.mouse.y=0}handleMouseDown(){this.mouse.down=!0}handleMouseUp(){this.mouse.down=!1}updateConfig(t){this.h(t)}o(t){this.config={...this.config,...t},t.text&&this.buildTargets()}destroy(){this.stop(),this.removeEventListeners(),this.intersectionObserver&&(this.intersectionObserver.disconnect(),this.intersectionObserver=null),this.canvas&&this.canvas.parentNode&&this.canvas.parentNode.removeChild(this.canvas)}}export{s as MasonEffect,s as default};