@jayf0x/fluidity-js 0.1.5 → 0.1.7

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/dist/index.js CHANGED
@@ -1,18 +1,18 @@
1
- var jI = Object.defineProperty;
2
- var PI = (C, I, i) => I in C ? jI(C, I, { enumerable: !0, configurable: !0, writable: !0, value: i }) : C[I] = i;
3
- var BI = (C, I, i) => (PI(C, typeof I != "symbol" ? I + "" : I, i), i), LI = (C, I, i) => {
1
+ var $I = Object.defineProperty;
2
+ var Ig = (C, I, i) => I in C ? $I(C, I, { enumerable: !0, configurable: !0, writable: !0, value: i }) : C[I] = i;
3
+ var yI = (C, I, i) => (Ig(C, typeof I != "symbol" ? I + "" : I, i), i), UI = (C, I, i) => {
4
4
  if (!I.has(C))
5
5
  throw TypeError("Cannot " + i);
6
6
  };
7
- var g = (C, I, i) => (LI(C, I, "read from private field"), i ? i.call(C) : I.get(C)), n = (C, I, i) => {
7
+ var g = (C, I, i) => (UI(C, I, "read from private field"), i ? i.call(C) : I.get(C)), m = (C, I, i) => {
8
8
  if (I.has(C))
9
9
  throw TypeError("Cannot add the same private member more than once");
10
10
  I instanceof WeakSet ? I.add(C) : I.set(C, i);
11
- }, o = (C, I, i, e) => (LI(C, I, "write to private field"), e ? e.call(C, i) : I.set(C, i), i);
12
- var b = (C, I, i) => (LI(C, I, "access private method"), i);
13
- import { jsx as TI } from "react/jsx-runtime";
14
- import { useRef as bI, useEffect as Q, forwardRef as xI, useImperativeHandle as MI } from "react";
15
- const JI = {
11
+ }, l = (C, I, i, e) => (UI(C, I, "write to private field"), e ? e.call(C, i) : I.set(C, i), i);
12
+ var b = (C, I, i) => (UI(C, I, "access private method"), i);
13
+ import { jsx as NI } from "react/jsx-runtime";
14
+ import { useRef as mI, useEffect as j, forwardRef as zI, useImperativeHandle as QI } from "react";
15
+ const OI = {
16
16
  densityDissipation: 0.992,
17
17
  velocityDissipation: 0.93,
18
18
  pressureIterations: 1,
@@ -26,8 +26,8 @@ const JI = {
26
26
  glowColor: [0.7, 0.85, 1],
27
27
  algorithm: "standard",
28
28
  warpStrength: 0.015
29
- }, kI = {
30
- ...JI,
29
+ }, TI = {
30
+ ...OI,
31
31
  densityDissipation: 0.99,
32
32
  velocityDissipation: 0.98,
33
33
  pressureIterations: 3,
@@ -38,22 +38,23 @@ const JI = {
38
38
  specularExp: 1,
39
39
  shine: 0.1,
40
40
  glowColor: [0, 0.502, 1]
41
- }, EI = {
41
+ }, gg = { dpr: 1, sim: 0.5 }, HI = {
42
42
  backgroundColor: "#0a0a0a",
43
43
  backgroundSize: "cover",
44
44
  isMouseEnabled: !0,
45
- isWorkerEnabled: !0
46
- }, q = {
47
- ...EI,
45
+ isWorkerEnabled: !0,
46
+ quality: gg
47
+ }, iI = {
48
+ ...HI,
48
49
  effect: 0,
49
50
  imageSize: "cover"
50
- }, j = {
51
- ...EI,
51
+ }, $ = {
52
+ ...HI,
52
53
  fontSize: 100,
53
54
  color: "#ffffff",
54
55
  fontFamily: "sans-serif",
55
56
  fontWeight: 900
56
- }, _I = {
57
+ }, ig = {
57
58
  calm: {
58
59
  densityDissipation: 0.999,
59
60
  velocityDissipation: 0.98,
@@ -112,73 +113,73 @@ const JI = {
112
113
  waterColor: [0.06, 0.06, 0.06]
113
114
  }
114
115
  };
115
- function uI(C = {}, I, i = JI) {
116
- return { ...I ? { ...i, ..._I[I] } : i, ...C };
116
+ function pI(C = {}, I, i = OI) {
117
+ return { ...I ? { ...i, ...ig[I] } : i, ...C };
117
118
  }
118
- function RI(C, I, i, e, l = "cover") {
119
- let s;
120
- l === "cover" ? s = Math.max(i / C, e / I) : l === "contain" ? s = Math.min(i / C, e / I) : typeof l == "string" && l.endsWith("%") ? s = Math.min(i / C, e / I) * (parseFloat(l) / 100) : typeof l == "string" && l.endsWith("px") ? s = parseFloat(l) / Math.max(C, I) : typeof l == "number" ? s = l : s = Math.max(i / C, e / I);
121
- const t = C * s, m = I * s;
122
- return { x: (i - t) / 2, y: (e - m) / 2, drawW: t, drawH: m };
119
+ function vI(C, I, i, e, s = "cover") {
120
+ let o;
121
+ s === "cover" ? o = Math.max(i / C, e / I) : s === "contain" ? o = Math.min(i / C, e / I) : typeof s == "string" && s.endsWith("%") ? o = Math.min(i / C, e / I) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? o = parseFloat(s) / Math.max(C, I) : typeof s == "number" ? o = s : o = Math.max(i / C, e / I);
122
+ const t = C * o, u = I * o;
123
+ return { x: (i - t) / 2, y: (e - u) / 2, drawW: t, drawH: u };
123
124
  }
124
- function qI(C, I, i, e, l = null, s = "cover") {
125
- const { text: t, fontSize: m, color: r, fontFamily: a = "sans-serif", fontWeight: u = 900 } = e, S = new OffscreenCanvas(I, i), A = S.getContext("2d");
126
- ((K) => {
127
- if (l) {
128
- A.clearRect(0, 0, I, i), A.fillStyle = "black", A.fillRect(0, 0, I, i);
129
- const { x: D, y: c, drawW: w, drawH: d } = RI(
130
- l.width,
131
- l.height,
125
+ function Cg(C, I, i, e, s = null, o = "cover") {
126
+ const { text: t, fontSize: u, color: a, fontFamily: c = "sans-serif", fontWeight: n = 900 } = e, G = new OffscreenCanvas(I, i), d = G.getContext("2d");
127
+ ((F) => {
128
+ if (s) {
129
+ d.clearRect(0, 0, I, i), d.fillStyle = "black", d.fillRect(0, 0, I, i);
130
+ const { x: w, y: D, drawW: A, drawH: y } = vI(
131
+ s.width,
132
+ s.height,
132
133
  I,
133
134
  i,
134
- s
135
+ o
135
136
  );
136
- A.drawImage(l, D, c, w, d);
137
+ d.drawImage(s, w, D, A, y);
137
138
  } else
138
- A.fillStyle = "black", A.fillRect(0, 0, I, i);
139
- A.fillStyle = K, A.font = `${u} ${m}px ${a}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, I / 2, i / 2);
140
- })(r);
141
- const v = rI(C, S);
142
- A.fillStyle = "black", A.fillRect(0, 0, I, i), A.fillStyle = "white", A.font = `${u} ${m}px ${a}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(t, I / 2, i / 2);
143
- const Y = rI(C, S);
144
- return { backgroundTex: v, obstacleTex: Y, coverageTex: Y };
139
+ d.fillStyle = "black", d.fillRect(0, 0, I, i);
140
+ d.fillStyle = F, d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
141
+ })(a);
142
+ const W = BI(C, G);
143
+ d.fillStyle = "black", d.fillRect(0, 0, I, i), d.fillStyle = "white", d.font = `${n} ${u}px ${c}`, d.textAlign = "center", d.textBaseline = "middle", d.fillText(t, I / 2, i / 2);
144
+ const x = BI(C, G);
145
+ return { backgroundTex: W, obstacleTex: x, coverageTex: x };
145
146
  }
146
- function $I(C, I, i, e, l = 0, s = "cover", t = null, m = "cover") {
147
- const r = new OffscreenCanvas(i, e), a = r.getContext("2d"), { x: u, y: S, drawW: A, drawH: h } = RI(I.width, I.height, i, e, s);
148
- if (a.clearRect(0, 0, i, e), a.fillStyle = "black", a.fillRect(0, 0, i, e), t) {
147
+ function eg(C, I, i, e, s = 0, o = "cover", t = null, u = "cover") {
148
+ const a = new OffscreenCanvas(i, e), c = a.getContext("2d"), { x: n, y: G, drawW: d, drawH: h } = vI(I.width, I.height, i, e, o);
149
+ if (c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), t) {
149
150
  const {
150
- x: D,
151
- y: c,
152
- drawW: w,
153
- drawH: d
154
- } = RI(t.width, t.height, i, e, m);
155
- a.filter = `brightness(${l}) blur(8px)`, a.drawImage(t, D, c, w, d), a.filter = "none";
156
- }
157
- a.drawImage(I, u, S, A, h);
158
- const v = rI(C, r);
159
- a.clearRect(0, 0, i, e), a.fillStyle = "black", a.fillRect(0, 0, i, e), a.filter = `brightness(${l}) blur(8px)`, a.drawImage(I, u, S, A, h), a.filter = "none";
160
- const Y = rI(C, r);
161
- a.clearRect(0, 0, i, e), a.fillStyle = "black", a.fillRect(0, 0, i, e), a.fillStyle = "white", a.fillRect(
162
- Math.max(0, u),
163
- Math.max(0, S),
164
- Math.min(A, i - Math.max(0, u)),
165
- Math.min(h, e - Math.max(0, S))
151
+ x: w,
152
+ y: D,
153
+ drawW: A,
154
+ drawH: y
155
+ } = vI(t.width, t.height, i, e, u);
156
+ c.filter = `brightness(${s}) blur(8px)`, c.drawImage(t, w, D, A, y), c.filter = "none";
157
+ }
158
+ c.drawImage(I, n, G, d, h);
159
+ const W = BI(C, a);
160
+ c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(I, n, G, d, h), c.filter = "none";
161
+ const x = BI(C, a);
162
+ c.clearRect(0, 0, i, e), c.fillStyle = "black", c.fillRect(0, 0, i, e), c.fillStyle = "white", c.fillRect(
163
+ Math.max(0, n),
164
+ Math.max(0, G),
165
+ Math.min(d, i - Math.max(0, n)),
166
+ Math.min(h, e - Math.max(0, G))
166
167
  );
167
- const K = rI(C, r);
168
- return { backgroundTex: v, obstacleTex: Y, coverageTex: K };
168
+ const F = BI(C, a);
169
+ return { backgroundTex: W, obstacleTex: x, coverageTex: F };
169
170
  }
170
- function rI(C, I) {
171
+ function BI(C, I) {
171
172
  const i = C.createTexture();
172
173
  return C.bindTexture(C.TEXTURE_2D, i), C.pixelStorei(C.UNPACK_FLIP_Y_WEBGL, !0), C.texImage2D(C.TEXTURE_2D, 0, C.RGBA, C.RGBA, C.UNSIGNED_BYTE, I), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), i;
173
174
  }
174
- async function XI(C) {
175
+ async function kI(C) {
175
176
  const I = await fetch(C);
176
177
  if (!I.ok)
177
178
  throw new Error(`Failed to fetch image: ${C} (${I.status})`);
178
179
  const i = await I.blob();
179
180
  return createImageBitmap(i);
180
181
  }
181
- const P = (
182
+ const II = (
182
183
  /* glsl */
183
184
  `
184
185
  precision highp float;
@@ -195,7 +196,7 @@ const P = (
195
196
  gl_Position = vec4(aPosition, 0.0, 1.0);
196
197
  }
197
198
  `
198
- ), Ig = (
199
+ ), sg = (
199
200
  /* glsl */
200
201
  `
201
202
  precision highp float;
@@ -212,7 +213,7 @@ const P = (
212
213
  gl_FragColor = dissipation * texture2D(uSource, coord);
213
214
  }
214
215
  `
215
- ), gg = (
216
+ ), lg = (
216
217
  /* glsl */
217
218
  `
218
219
  precision highp float;
@@ -227,7 +228,7 @@ const P = (
227
228
  gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
228
229
  }
229
230
  `
230
- ), ig = (
231
+ ), og = (
231
232
  /* glsl */
232
233
  `
233
234
  precision highp float;
@@ -245,7 +246,7 @@ const P = (
245
246
  gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
246
247
  }
247
248
  `
248
- ), Cg = (
249
+ ), tg = (
249
250
  /* glsl */
250
251
  `
251
252
  precision highp float;
@@ -263,7 +264,7 @@ const P = (
263
264
  gl_FragColor = vec4(vel, 0.0, 1.0);
264
265
  }
265
266
  `
266
- ), eg = (
267
+ ), cg = (
267
268
  /* glsl */
268
269
  `
269
270
  precision highp float;
@@ -280,7 +281,7 @@ const P = (
280
281
  gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
281
282
  }
282
283
  `
283
- ), lg = (
284
+ ), ag = (
284
285
  /* glsl */
285
286
  `
286
287
  precision highp float;
@@ -294,7 +295,7 @@ const P = (
294
295
  gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
295
296
  }
296
297
  `
297
- ), sg = (
298
+ ), dg = (
298
299
  /* glsl */
299
300
  `
300
301
  precision highp float;
@@ -315,7 +316,7 @@ const P = (
315
316
  gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
316
317
  }
317
318
  `
318
- ), og = (
319
+ ), Ag = (
319
320
  /* glsl */
320
321
  `
321
322
  precision highp float;
@@ -416,37 +417,37 @@ const P = (
416
417
  }
417
418
  `
418
419
  );
419
- function tg(C) {
420
+ function mg(C) {
420
421
  const I = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
421
422
  let i = C.getContext("webgl2", I);
422
423
  const e = !!i;
423
424
  e || (i = C.getContext("webgl", I), i.getExtension("EXT_color_buffer_half_float"));
424
- const l = e ? null : i.getExtension("OES_texture_half_float"), s = e ? i.HALF_FLOAT : l.HALF_FLOAT_OES;
425
+ const s = e ? null : i.getExtension("OES_texture_half_float"), o = e ? i.HALF_FLOAT : s.HALF_FLOAT_OES;
425
426
  return i.getExtension("EXT_color_buffer_float"), i.getExtension("OES_texture_half_float_linear"), {
426
427
  gl: i,
427
428
  isWebGL2: e,
428
429
  ext: {
429
430
  internalFormat: e ? i.RGBA16F : i.RGBA,
430
431
  format: i.RGBA,
431
- type: s
432
+ type: o
432
433
  }
433
434
  };
434
435
  }
435
- class _ {
436
+ class gI {
436
437
  constructor(I, i, e) {
437
- BI(this, "program");
438
- BI(this, "uniforms", {});
439
- BI(this, "_gl");
438
+ yI(this, "program");
439
+ yI(this, "uniforms", {});
440
+ yI(this, "_gl");
440
441
  this._gl = I, this.program = I.createProgram(), I.attachShader(this.program, this._compile(I.VERTEX_SHADER, i)), I.attachShader(this.program, this._compile(I.FRAGMENT_SHADER, e)), I.linkProgram(this.program);
441
- const l = I.getProgramParameter(this.program, I.ACTIVE_UNIFORMS);
442
- for (let s = 0; s < l; s++) {
443
- const t = I.getActiveUniform(this.program, s).name;
442
+ const s = I.getProgramParameter(this.program, I.ACTIVE_UNIFORMS);
443
+ for (let o = 0; o < s; o++) {
444
+ const t = I.getActiveUniform(this.program, o).name;
444
445
  this.uniforms[t] = I.getUniformLocation(this.program, t);
445
446
  }
446
447
  }
447
448
  _compile(I, i) {
448
- const e = this._gl, l = e.createShader(I);
449
- return e.shaderSource(l, i), e.compileShader(l), l;
449
+ const e = this._gl, s = e.createShader(I);
450
+ return e.shaderSource(s, i), e.compileShader(s), s;
450
451
  }
451
452
  bind() {
452
453
  this._gl.useProgram(this.program);
@@ -455,117 +456,119 @@ class _ {
455
456
  this._gl.deleteProgram(this.program);
456
457
  }
457
458
  }
458
- function cg(C) {
459
+ function rg(C) {
459
460
  return {
460
- advection: new _(C, P, Ig),
461
- divergence: new _(C, P, gg),
462
- pressure: new _(C, P, ig),
463
- gradientSubtract: new _(C, P, Cg),
464
- splat: new _(C, P, eg),
465
- curl: new _(C, P, lg),
466
- vorticity: new _(C, P, sg),
467
- display: new _(C, P, og)
461
+ advection: new gI(C, II, sg),
462
+ divergence: new gI(C, II, lg),
463
+ pressure: new gI(C, II, og),
464
+ gradientSubtract: new gI(C, II, tg),
465
+ splat: new gI(C, II, cg),
466
+ curl: new gI(C, II, ag),
467
+ vorticity: new gI(C, II, dg),
468
+ display: new gI(C, II, Ag)
468
469
  };
469
470
  }
470
- function VI(C, I, i, e) {
471
+ function KI(C, I, i, e) {
471
472
  C.activeTexture(C.TEXTURE0);
472
- const l = C.createTexture();
473
- C.bindTexture(C.TEXTURE_2D, l), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), C.texImage2D(C.TEXTURE_2D, 0, I.internalFormat, i, e, 0, I.format, I.type, null);
474
- const s = C.createFramebuffer();
475
- return C.bindFramebuffer(C.FRAMEBUFFER, s), C.framebufferTexture2D(C.FRAMEBUFFER, C.COLOR_ATTACHMENT0, C.TEXTURE_2D, l, 0), { tex: l, fbo: s, width: i, height: e };
473
+ const s = C.createTexture();
474
+ C.bindTexture(C.TEXTURE_2D, s), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MIN_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_MAG_FILTER, C.LINEAR), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_S, C.CLAMP_TO_EDGE), C.texParameteri(C.TEXTURE_2D, C.TEXTURE_WRAP_T, C.CLAMP_TO_EDGE), C.texImage2D(C.TEXTURE_2D, 0, I.internalFormat, i, e, 0, I.format, I.type, null);
475
+ const o = C.createFramebuffer();
476
+ return C.bindFramebuffer(C.FRAMEBUFFER, o), C.framebufferTexture2D(C.FRAMEBUFFER, C.COLOR_ATTACHMENT0, C.TEXTURE_2D, s, 0), { tex: s, fbo: o, width: i, height: e };
476
477
  }
477
- function KI(C, I, i, e) {
478
- let l = VI(C, I, i, e), s = VI(C, I, i, e);
478
+ function WI(C, I, i, e) {
479
+ let s = KI(C, I, i, e), o = KI(C, I, i, e);
479
480
  return {
480
481
  get read() {
481
- return l;
482
+ return s;
482
483
  },
483
484
  get write() {
484
- return s;
485
+ return o;
485
486
  },
486
487
  swap() {
487
- [l, s] = [s, l];
488
+ [s, o] = [o, s];
488
489
  },
489
490
  dispose() {
490
- C.deleteTexture(l.tex), C.deleteFramebuffer(l.fbo), C.deleteTexture(s.tex), C.deleteFramebuffer(s.fbo);
491
+ C.deleteTexture(s.tex), C.deleteFramebuffer(s.fbo), C.deleteTexture(o.tex), C.deleteFramebuffer(o.fbo);
491
492
  }
492
493
  };
493
494
  }
494
- function dg(C) {
495
+ function ng(C) {
495
496
  const I = C.createBuffer();
496
497
  return C.bindBuffer(C.ARRAY_BUFFER, I), C.bufferData(C.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), C.STATIC_DRAW), C.vertexAttribPointer(0, 2, C.FLOAT, !1, 0, 0), C.enableVertexAttribArray(0), function(e) {
497
498
  C.bindFramebuffer(C.FRAMEBUFFER, e), C.drawArrays(C.TRIANGLE_FAN, 0, 4);
498
499
  };
499
500
  }
500
- const YI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (C) => setTimeout(C, 1e3 / 60), ag = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, DI = 0.016, Ag = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
501
- var iI, R, mI, CI, cI, y, W, $, II, f, H, Z, x, M, J, z, X, E, F, dI, eI, V, U, N, lI, GI, sI, AI, ZI, HI, gI, tI, oI, nI, hI, WI, SI, vI, pI, NI;
502
- class fI {
503
- constructor(I, i = {}) {
501
+ const xI = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (C) => setTimeout(C, 1e3 / 60), ug = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, MI = 0.016, Zg = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
502
+ var lI, X, SI, oI, rI, K, R, CI, eI, k, nI, P, H, B, E, J, N, _, v, z, f, uI, tI, L, Y, Q, cI, bI, aI, GI, LI, YI, sI, AI, dI, hI, VI, FI, wI, DI, RI, jI;
503
+ class EI {
504
+ constructor(I, i = {}, e = {}) {
504
505
  // ---------------------------------------------------------------------------
505
506
  // Private helpers
506
507
  // ---------------------------------------------------------------------------
507
- n(this, sI);
508
- n(this, ZI);
509
- n(this, gI);
510
- n(this, oI);
511
- n(this, hI);
512
- n(this, SI);
513
- n(this, pI);
514
- n(this, iI, void 0);
515
- n(this, R, void 0);
516
- n(this, mI, void 0);
517
- n(this, CI, void 0);
518
- n(this, cI, void 0);
519
- n(this, y, 0);
520
- n(this, W, 0);
521
- n(this, $, 0);
522
- n(this, II, 0);
523
- n(this, f, 1);
524
- n(this, H, null);
525
- n(this, Z, null);
526
- n(this, x, null);
527
- n(this, M, null);
528
- n(this, J, null);
529
- n(this, z, null);
530
- n(this, X, null);
531
- n(this, E, null);
508
+ m(this, aI);
509
+ m(this, LI);
510
+ m(this, sI);
511
+ m(this, dI);
512
+ m(this, VI);
513
+ m(this, wI);
514
+ m(this, RI);
515
+ m(this, lI, void 0);
516
+ m(this, X, void 0);
517
+ m(this, SI, void 0);
518
+ m(this, oI, void 0);
519
+ m(this, rI, void 0);
520
+ m(this, K, 0);
521
+ m(this, R, 0);
522
+ m(this, CI, 0);
523
+ m(this, eI, 0);
524
+ m(this, k, 1);
525
+ m(this, nI, 1);
526
+ m(this, P, 0.5);
527
+ m(this, H, null);
528
+ m(this, B, null);
529
+ m(this, E, null);
530
+ m(this, J, null);
531
+ m(this, N, null);
532
+ m(this, _, null);
533
+ m(this, v, null);
534
+ m(this, z, null);
532
535
  // binary content mask for transparent canvas support
533
- n(this, F, null);
536
+ m(this, f, null);
534
537
  // optional background image (from backgroundSrc prop)
535
- n(this, dI, "cover");
536
- n(this, eI, void 0);
537
- n(this, V, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
538
+ m(this, uI, "cover");
539
+ m(this, tI, void 0);
540
+ m(this, L, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
538
541
  // Stores source so textures can be rebuilt on resize
539
- n(this, U, null);
540
- n(this, N, null);
541
- n(this, lI, !1);
542
- n(this, GI, !1);
543
- o(this, iI, I), o(this, eI, uI(i));
544
- const { gl: e, ext: l } = tg(I);
545
- o(this, R, e), o(this, mI, l), o(this, CI, cg(e)), o(this, cI, dg(e)), e.clearColor(0, 0, 0, 0);
542
+ m(this, Y, null);
543
+ m(this, Q, null);
544
+ m(this, cI, !1);
545
+ m(this, bI, !1);
546
+ l(this, lI, I), l(this, nI, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, P, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, tI, pI(i));
547
+ const { gl: s, ext: o } = mg(I);
548
+ l(this, X, s), l(this, SI, o), l(this, oI, rg(s)), l(this, rI, ng(s)), s.clearColor(0, 0, 0, 0);
546
549
  }
547
550
  // ---------------------------------------------------------------------------
548
551
  // Public API
549
552
  // ---------------------------------------------------------------------------
550
553
  setTextSource(I) {
551
- o(this, U, { type: "text", opts: I }), b(this, sI, AI).call(this), b(this, gI, tI).call(this), b(this, oI, nI).call(this);
554
+ l(this, Y, { type: "text", opts: I }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
552
555
  }
553
556
  async setImageSource(I, i = 0, e = "cover") {
554
- const l = await XI(I);
555
- if (g(this, GI)) {
556
- l.close();
557
+ const s = await kI(I);
558
+ if (g(this, bI)) {
559
+ s.close();
557
560
  return;
558
561
  }
559
- o(this, U, { type: "image", bitmap: l, effect: i, size: e }), b(this, sI, AI).call(this), b(this, gI, tI).call(this), b(this, oI, nI).call(this);
562
+ l(this, Y, { type: "image", bitmap: s, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
560
563
  }
561
564
  setImageBitmap(I, i = 0, e = "cover") {
562
- o(this, U, { type: "image", bitmap: I, effect: i, size: e }), b(this, sI, AI).call(this), b(this, gI, tI).call(this), b(this, oI, nI).call(this);
565
+ l(this, Y, { type: "image", bitmap: I, effect: i, size: e }), b(this, aI, GI).call(this), b(this, sI, AI).call(this), b(this, dI, hI).call(this);
563
566
  }
564
567
  setBackground(I, i = "cover") {
565
- g(this, F) && g(this, F) !== I && g(this, F).close(), o(this, F, I), o(this, dI, i ?? "cover"), g(this, U) && g(this, y) > 0 && b(this, gI, tI).call(this);
568
+ g(this, f) && g(this, f) !== I && g(this, f).close(), l(this, f, I), l(this, uI, i ?? "cover"), g(this, Y) && g(this, K) > 0 && g(this, R) > 0 && b(this, sI, AI).call(this);
566
569
  }
567
570
  handleMove(I, i, e = 1) {
568
- g(this, V).moved = !0, g(this, V).dx = (I - g(this, V).targetX) * e, g(this, V).dy = (i - g(this, V).targetY) * e, g(this, V).targetX = I, g(this, V).targetY = i;
571
+ g(this, L).moved = !0, g(this, L).dx = (I - g(this, L).targetX) * e, g(this, L).dy = (i - g(this, L).targetY) * e, g(this, L).targetX = I, g(this, L).targetY = i;
569
572
  }
570
573
  /**
571
574
  * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
@@ -574,29 +577,32 @@ class fI {
574
577
  * where you want N independent injection points per frame without flooding the
575
578
  * mouse-state machine or the worker message queue.
576
579
  */
577
- splat(I, i, e, l, s = 1) {
578
- if (!g(this, lI) || g(this, y) === 0)
580
+ splat(I, i, e, s, o = 1) {
581
+ if (!g(this, cI) || g(this, K) === 0)
579
582
  return;
580
- const t = g(this, R), m = g(this, eI), { splat: r } = g(this, CI), a = g(this, cI);
581
- t.viewport(0, 0, g(this, $), g(this, II)), r.bind(), t.uniform1f(r.uniforms.aspectRatio, g(this, y) / g(this, W)), t.uniform2f(r.uniforms.point, I * g(this, f) / g(this, y), 1 - i * g(this, f) / g(this, W)), t.uniform1f(r.uniforms.radius, m.splatRadius), t.uniform1i(r.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, Z).read.tex), t.uniform3f(r.uniforms.color, e * m.splatForce * s, -l * m.splatForce * s, 0), a(g(this, Z).write.fbo), g(this, Z).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, H).read.tex), t.uniform3f(r.uniforms.color, s, s, s), a(g(this, H).write.fbo), g(this, H).swap();
583
+ const t = g(this, X), u = g(this, tI), { splat: a } = g(this, oI), c = g(this, rI);
584
+ t.viewport(0, 0, g(this, CI), g(this, eI)), a.bind(), t.uniform1f(a.uniforms.aspectRatio, g(this, K) / g(this, R)), t.uniform2f(a.uniforms.point, I * g(this, k) / g(this, K), 1 - i * g(this, k) / g(this, R)), t.uniform1f(a.uniforms.radius, u.splatRadius), t.uniform1i(a.uniforms.uTarget, 0), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, B).read.tex), t.uniform3f(a.uniforms.color, e * u.splatForce * o, -s * u.splatForce * o, 0), c(g(this, B).write.fbo), g(this, B).swap(), t.activeTexture(t.TEXTURE0), t.bindTexture(t.TEXTURE_2D, g(this, H).read.tex), t.uniform3f(a.uniforms.color, o, o, o), c(g(this, H).write.fbo), g(this, H).swap();
585
+ }
586
+ updateQuality(I) {
587
+ I.dpr !== void 0 && l(this, nI, Math.max(0.1, Math.min(1, I.dpr))), I.sim !== void 0 && l(this, P, Math.max(0.1, Math.min(1, I.sim)));
582
588
  }
583
589
  resize(I, i, e) {
584
- if (e !== void 0 ? o(this, f, e) : typeof window < "u" && window.devicePixelRatio && o(this, f, window.devicePixelRatio), I !== void 0 && I > 0) {
590
+ if (e !== void 0 ? l(this, k, e) : typeof window < "u" && window.devicePixelRatio && l(this, k, window.devicePixelRatio), I !== void 0 && I > 0) {
585
591
  if (i === void 0 || i <= 0)
586
592
  return;
587
- o(this, y, g(this, iI).width = I), o(this, W, g(this, iI).height = i), o(this, $, I >> 1), o(this, II, i >> 1), b(this, ZI, HI).call(this);
593
+ l(this, K, g(this, lI).width = I), l(this, R, g(this, lI).height = i), l(this, CI, Math.max(1, Math.round(I * g(this, P)))), l(this, eI, Math.max(1, Math.round(i * g(this, P)))), b(this, LI, YI).call(this);
588
594
  } else
589
- b(this, sI, AI).call(this);
590
- g(this, U) && b(this, gI, tI).call(this), b(this, oI, nI).call(this);
595
+ b(this, aI, GI).call(this);
596
+ g(this, Y) && b(this, sI, AI).call(this), b(this, dI, hI).call(this);
591
597
  }
592
598
  updateConfig(I) {
593
- Object.assign(g(this, eI), I);
599
+ Object.assign(g(this, tI), I);
594
600
  }
595
601
  destroy() {
596
- o(this, GI, !0), this.stop();
597
- const I = g(this, R);
598
- b(this, hI, WI).call(this), b(this, SI, vI).call(this), g(this, F) && (g(this, F).close(), o(this, F, null));
599
- for (const e of Object.values(g(this, CI)))
602
+ l(this, bI, !0), this.stop();
603
+ const I = g(this, X);
604
+ b(this, VI, FI).call(this), b(this, wI, DI).call(this), g(this, f) && (g(this, f).close(), l(this, f, null));
605
+ for (const e of Object.values(g(this, oI)))
600
606
  e.dispose();
601
607
  const i = I.getExtension("WEBGL_lose_context");
602
608
  i == null || i.loseContext();
@@ -605,118 +611,123 @@ class fI {
605
611
  // Loop control
606
612
  // ---------------------------------------------------------------------------
607
613
  start() {
608
- if (g(this, N) !== null)
614
+ if (g(this, Q) !== null)
609
615
  return;
610
616
  const I = () => {
611
- b(this, pI, NI).call(this), o(this, N, YI(I));
617
+ b(this, RI, jI).call(this), l(this, Q, xI(I));
612
618
  };
613
- o(this, N, YI(I));
619
+ l(this, Q, xI(I));
614
620
  }
615
621
  stop() {
616
- g(this, N) !== null && (ag(g(this, N)), o(this, N, null));
622
+ g(this, Q) !== null && (ug(g(this, Q)), l(this, Q, null));
617
623
  }
618
624
  get isRunning() {
619
- return g(this, N) !== null;
625
+ return g(this, Q) !== null;
620
626
  }
621
627
  }
622
- iI = new WeakMap(), R = new WeakMap(), mI = new WeakMap(), CI = new WeakMap(), cI = new WeakMap(), y = new WeakMap(), W = new WeakMap(), $ = new WeakMap(), II = new WeakMap(), f = new WeakMap(), H = new WeakMap(), Z = new WeakMap(), x = new WeakMap(), M = new WeakMap(), J = new WeakMap(), z = new WeakMap(), X = new WeakMap(), E = new WeakMap(), F = new WeakMap(), dI = new WeakMap(), eI = new WeakMap(), V = new WeakMap(), U = new WeakMap(), N = new WeakMap(), lI = new WeakMap(), GI = new WeakMap(), sI = new WeakSet(), AI = function() {
623
- const I = g(this, iI);
624
- "clientWidth" in I && I.clientWidth > 0 ? (o(this, f, typeof window < "u" && window.devicePixelRatio || 1), o(this, y, I.width = Math.round(I.clientWidth * g(this, f))), o(this, W, I.height = Math.round(I.clientHeight * g(this, f)))) : (o(this, y, I.width), o(this, W, I.height)), !(g(this, y) === 0 || g(this, W) === 0) && (o(this, $, g(this, y) >> 1), o(this, II, g(this, W) >> 1), b(this, ZI, HI).call(this));
625
- }, ZI = new WeakSet(), HI = function() {
626
- const I = g(this, R), i = g(this, mI), e = g(this, $), l = g(this, II);
627
- b(this, hI, WI).call(this), o(this, H, KI(I, i, e, l)), o(this, Z, KI(I, i, e, l)), o(this, M, KI(I, i, e, l)), o(this, x, VI(I, i, e, l)), o(this, J, VI(I, i, e, l));
628
- }, gI = new WeakSet(), tI = function() {
629
- if (!(!g(this, U) || g(this, y) === 0)) {
630
- if (b(this, SI, vI).call(this), g(this, U).type === "text") {
631
- const { backgroundTex: I, obstacleTex: i, coverageTex: e } = qI(
628
+ lI = new WeakMap(), X = new WeakMap(), SI = new WeakMap(), oI = new WeakMap(), rI = new WeakMap(), K = new WeakMap(), R = new WeakMap(), CI = new WeakMap(), eI = new WeakMap(), k = new WeakMap(), nI = new WeakMap(), P = new WeakMap(), H = new WeakMap(), B = new WeakMap(), E = new WeakMap(), J = new WeakMap(), N = new WeakMap(), _ = new WeakMap(), v = new WeakMap(), z = new WeakMap(), f = new WeakMap(), uI = new WeakMap(), tI = new WeakMap(), L = new WeakMap(), Y = new WeakMap(), Q = new WeakMap(), cI = new WeakMap(), bI = new WeakMap(), aI = new WeakSet(), GI = function() {
629
+ const I = g(this, lI);
630
+ "clientWidth" in I && I.clientWidth > 0 ? (l(this, k, (typeof window < "u" && window.devicePixelRatio || 1) * g(this, nI)), l(this, K, I.width = Math.round(I.clientWidth * g(this, k))), l(this, R, I.height = Math.round(I.clientHeight * g(this, k)))) : (l(this, K, I.width), l(this, R, I.height)), !(g(this, K) === 0 || g(this, R) === 0) && (l(this, CI, Math.max(1, Math.round(g(this, K) * g(this, P)))), l(this, eI, Math.max(1, Math.round(g(this, R) * g(this, P)))), b(this, LI, YI).call(this));
631
+ }, LI = new WeakSet(), YI = function() {
632
+ const I = g(this, X), i = g(this, SI), e = g(this, CI), s = g(this, eI);
633
+ b(this, VI, FI).call(this), l(this, H, WI(I, i, e, s)), l(this, B, WI(I, i, e, s)), l(this, J, WI(I, i, e, s)), l(this, E, KI(I, i, e, s)), l(this, N, KI(I, i, e, s));
634
+ }, sI = new WeakSet(), AI = function() {
635
+ if (!(!g(this, Y) || g(this, K) === 0 || g(this, R) === 0)) {
636
+ if (b(this, wI, DI).call(this), g(this, Y).type === "text") {
637
+ const { backgroundTex: I, obstacleTex: i, coverageTex: e } = Cg(
638
+ g(this, X),
639
+ g(this, K),
632
640
  g(this, R),
633
- g(this, y),
634
- g(this, W),
635
- g(this, U).opts,
636
- g(this, F),
637
- g(this, dI)
641
+ g(this, Y).opts,
642
+ g(this, f),
643
+ g(this, uI)
638
644
  );
639
- o(this, z, I), o(this, X, i), o(this, E, e);
645
+ l(this, _, I), l(this, v, i), l(this, z, e);
640
646
  } else {
641
- const { backgroundTex: I, obstacleTex: i, coverageTex: e } = $I(
647
+ const { backgroundTex: I, obstacleTex: i, coverageTex: e } = eg(
648
+ g(this, X),
649
+ g(this, Y).bitmap,
650
+ g(this, K),
642
651
  g(this, R),
643
- g(this, U).bitmap,
644
- g(this, y),
645
- g(this, W),
646
- g(this, U).effect,
647
- g(this, U).size,
648
- g(this, F),
649
- g(this, dI)
652
+ g(this, Y).effect,
653
+ g(this, Y).size,
654
+ g(this, f),
655
+ g(this, uI)
650
656
  );
651
- o(this, z, I), o(this, X, i), o(this, E, e);
657
+ l(this, _, I), l(this, v, i), l(this, z, e);
652
658
  }
653
- o(this, lI, !0);
659
+ l(this, cI, !0);
654
660
  }
655
- }, oI = new WeakSet(), nI = function() {
656
- g(this, lI) && !this.isRunning && this.start();
657
- }, hI = new WeakSet(), WI = function() {
661
+ }, dI = new WeakSet(), hI = function() {
662
+ g(this, cI) && !this.isRunning && this.start();
663
+ }, VI = new WeakSet(), FI = function() {
658
664
  var I, i, e;
659
- (I = g(this, H)) == null || I.dispose(), (i = g(this, Z)) == null || i.dispose(), (e = g(this, M)) == null || e.dispose(), g(this, x) && (g(this, R).deleteTexture(g(this, x).tex), g(this, R).deleteFramebuffer(g(this, x).fbo)), g(this, J) && (g(this, R).deleteTexture(g(this, J).tex), g(this, R).deleteFramebuffer(g(this, J).fbo)), o(this, H, o(this, Z, o(this, M, o(this, x, o(this, J, null)))));
660
- }, SI = new WeakSet(), vI = function() {
661
- g(this, z) && g(this, R).deleteTexture(g(this, z)), g(this, X) && g(this, R).deleteTexture(g(this, X)), g(this, E) && g(this, E) !== g(this, X) && g(this, R).deleteTexture(g(this, E)), o(this, z, o(this, X, o(this, E, null)));
662
- }, pI = new WeakSet(), NI = function() {
663
- if (!g(this, lI) || g(this, y) === 0 || !g(this, H) || !g(this, Z))
665
+ (I = g(this, H)) == null || I.dispose(), (i = g(this, B)) == null || i.dispose(), (e = g(this, J)) == null || e.dispose(), g(this, E) && (g(this, X).deleteTexture(g(this, E).tex), g(this, X).deleteFramebuffer(g(this, E).fbo)), g(this, N) && (g(this, X).deleteTexture(g(this, N).tex), g(this, X).deleteFramebuffer(g(this, N).fbo)), l(this, H, l(this, B, l(this, J, l(this, E, l(this, N, null)))));
666
+ }, wI = new WeakSet(), DI = function() {
667
+ g(this, _) && g(this, X).deleteTexture(g(this, _)), g(this, v) && g(this, X).deleteTexture(g(this, v)), g(this, z) && g(this, z) !== g(this, v) && g(this, X).deleteTexture(g(this, z)), l(this, _, l(this, v, l(this, z, null)));
668
+ }, RI = new WeakSet(), jI = function() {
669
+ if (!g(this, cI) || g(this, K) === 0 || !g(this, H) || !g(this, B))
664
670
  return;
665
- const I = g(this, R), i = g(this, eI), { advection: e, divergence: l, pressure: s, gradientSubtract: t, splat: m, curl: r, vorticity: a, display: u } = g(this, CI);
666
- g(this, V).x += (g(this, V).targetX - g(this, V).x) * 0.15, g(this, V).y += (g(this, V).targetY - g(this, V).y) * 0.15;
667
- const S = g(this, $), A = g(this, II), h = g(this, cI);
668
- I.viewport(0, 0, S, A), e.bind(), I.uniform2f(e.uniforms.texelSize, 1 / S, 1 / A), I.uniform1f(e.uniforms.dt, DI), I.uniform1i(e.uniforms.uObstacle, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, X)), I.uniform1f(e.uniforms.dissipation, i.velocityDissipation), I.uniform1i(e.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(e.uniforms.uSource, 1), h(g(this, Z).write.fbo), g(this, Z).swap(), I.uniform1f(e.uniforms.dissipation, i.densityDissipation), I.uniform1i(e.uniforms.uSource, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), h(g(this, H).write.fbo), g(this, H).swap(), r.bind(), I.uniform2f(r.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(r.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), h(g(this, J).fbo), a.bind(), I.uniform2f(a.uniforms.texelSize, 1 / S, 1 / A), I.uniform1f(a.uniforms.curl, i.curl), I.uniform1f(a.uniforms.dt, DI), I.uniform1i(a.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(a.uniforms.uCurl, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, J).tex), h(g(this, Z).write.fbo), g(this, Z).swap(), g(this, V).moved && (m.bind(), I.uniform1f(m.uniforms.aspectRatio, g(this, y) / g(this, W)), I.uniform2f(m.uniforms.point, g(this, V).x * g(this, f) / g(this, y), 1 - g(this, V).y * g(this, f) / g(this, W)), I.uniform1f(m.uniforms.radius, i.splatRadius), I.uniform1i(m.uniforms.uTarget, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform3f(m.uniforms.color, g(this, V).dx * i.splatForce, -g(this, V).dy * i.splatForce, 0), h(g(this, Z).write.fbo), g(this, Z).swap(), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.uniform3f(m.uniforms.color, 1, 1, 1), h(g(this, H).write.fbo), g(this, H).swap(), g(this, V).moved = !1), l.bind(), I.uniform2f(l.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(l.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(l.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, X)), h(g(this, x).fbo), s.bind(), I.uniform2f(s.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(s.uniforms.uDivergence, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, x).tex), I.uniform1i(s.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, X));
669
- for (let v = 0; v < i.pressureIterations; v++)
670
- I.uniform1i(s.uniforms.uPressure, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, M).read.tex), h(g(this, M).write.fbo), g(this, M).swap();
671
- t.bind(), I.uniform2f(t.uniforms.texelSize, 1 / S, 1 / A), I.uniform1i(t.uniforms.uPressure, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, M).read.tex), I.uniform1i(t.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(t.uniforms.uObstacle, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, X)), h(g(this, Z).write.fbo), g(this, Z).swap(), I.viewport(0, 0, g(this, y), g(this, W)), I.bindFramebuffer(I.FRAMEBUFFER, null), I.clear(I.COLOR_BUFFER_BIT), u.bind(), I.uniform2f(u.uniforms.texelSize, 1 / g(this, y), 1 / g(this, W)), I.uniform3fv(u.uniforms.uWaterColor, i.waterColor), I.uniform3fv(u.uniforms.uGlowColor, i.glowColor), I.uniform1f(u.uniforms.uRefraction, i.refraction), I.uniform1f(u.uniforms.uSpecularExp, i.specularExp), I.uniform1f(u.uniforms.uShine, i.shine), I.uniform1f(u.uniforms.uWarpStrength, i.warpStrength ?? 0.015), I.uniform1i(u.uniforms.uAlgorithm, Ag[i.algorithm] ?? 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, X)), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, z)), I.activeTexture(I.TEXTURE3), I.bindTexture(I.TEXTURE_2D, g(this, E)), I.activeTexture(I.TEXTURE4), I.bindTexture(I.TEXTURE_2D, g(this, Z).read.tex), I.uniform1i(u.uniforms.uTexture, 0), I.uniform1i(u.uniforms.uObstacle, 1), I.uniform1i(u.uniforms.uBackground, 2), I.uniform1i(u.uniforms.uCoverage, 3), I.uniform1i(u.uniforms.uVelocity, 4), h(null);
671
+ const I = g(this, X), i = g(this, tI), { advection: e, divergence: s, pressure: o, gradientSubtract: t, splat: u, curl: a, vorticity: c, display: n } = g(this, oI);
672
+ g(this, L).x += (g(this, L).targetX - g(this, L).x) * 0.15, g(this, L).y += (g(this, L).targetY - g(this, L).y) * 0.15;
673
+ const G = g(this, CI), d = g(this, eI), h = g(this, rI);
674
+ I.viewport(0, 0, G, d), e.bind(), I.uniform2f(e.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(e.uniforms.dt, MI), I.uniform1i(e.uniforms.uObstacle, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.uniform1f(e.uniforms.dissipation, i.velocityDissipation), I.uniform1i(e.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(e.uniforms.uSource, 1), h(g(this, B).write.fbo), g(this, B).swap(), I.uniform1f(e.uniforms.dissipation, i.densityDissipation), I.uniform1i(e.uniforms.uSource, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), h(g(this, H).write.fbo), g(this, H).swap(), a.bind(), I.uniform2f(a.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(a.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), h(g(this, N).fbo), c.bind(), I.uniform2f(c.uniforms.texelSize, 1 / G, 1 / d), I.uniform1f(c.uniforms.curl, i.curl), I.uniform1f(c.uniforms.dt, MI), I.uniform1i(c.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(c.uniforms.uCurl, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, N).tex), h(g(this, B).write.fbo), g(this, B).swap(), g(this, L).moved && (u.bind(), I.uniform1f(u.uniforms.aspectRatio, g(this, K) / g(this, R)), I.uniform2f(u.uniforms.point, g(this, L).x * g(this, k) / g(this, K), 1 - g(this, L).y * g(this, k) / g(this, R)), I.uniform1f(u.uniforms.radius, i.splatRadius), I.uniform1i(u.uniforms.uTarget, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform3f(u.uniforms.color, g(this, L).dx * i.splatForce, -g(this, L).dy * i.splatForce, 0), h(g(this, B).write.fbo), g(this, B).swap(), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.uniform3f(u.uniforms.color, 1, 1, 1), h(g(this, H).write.fbo), g(this, H).swap(), g(this, L).moved = !1), s.bind(), I.uniform2f(s.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(s.uniforms.uVelocity, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(s.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, E).fbo), o.bind(), I.uniform2f(o.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(o.uniforms.uDivergence, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, E).tex), I.uniform1i(o.uniforms.uObstacle, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v));
675
+ for (let W = 0; W < i.pressureIterations; W++)
676
+ I.uniform1i(o.uniforms.uPressure, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), h(g(this, J).write.fbo), g(this, J).swap();
677
+ t.bind(), I.uniform2f(t.uniforms.texelSize, 1 / G, 1 / d), I.uniform1i(t.uniforms.uPressure, 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, J).read.tex), I.uniform1i(t.uniforms.uVelocity, 1), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(t.uniforms.uObstacle, 2), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, v)), h(g(this, B).write.fbo), g(this, B).swap(), I.viewport(0, 0, g(this, K), g(this, R)), I.bindFramebuffer(I.FRAMEBUFFER, null), I.clear(I.COLOR_BUFFER_BIT), n.bind(), I.uniform2f(n.uniforms.texelSize, 1 / g(this, K), 1 / g(this, R)), I.uniform3fv(n.uniforms.uWaterColor, i.waterColor), I.uniform3fv(n.uniforms.uGlowColor, i.glowColor), I.uniform1f(n.uniforms.uRefraction, i.refraction), I.uniform1f(n.uniforms.uSpecularExp, i.specularExp), I.uniform1f(n.uniforms.uShine, i.shine), I.uniform1f(n.uniforms.uWarpStrength, i.warpStrength ?? 0.015), I.uniform1i(n.uniforms.uAlgorithm, Zg[i.algorithm] ?? 0), I.activeTexture(I.TEXTURE0), I.bindTexture(I.TEXTURE_2D, g(this, H).read.tex), I.activeTexture(I.TEXTURE1), I.bindTexture(I.TEXTURE_2D, g(this, v)), I.activeTexture(I.TEXTURE2), I.bindTexture(I.TEXTURE_2D, g(this, _)), I.activeTexture(I.TEXTURE3), I.bindTexture(I.TEXTURE_2D, g(this, z)), I.activeTexture(I.TEXTURE4), I.bindTexture(I.TEXTURE_2D, g(this, B).read.tex), I.uniform1i(n.uniforms.uTexture, 0), I.uniform1i(n.uniforms.uObstacle, 1), I.uniform1i(n.uniforms.uBackground, 2), I.uniform1i(n.uniforms.uCoverage, 3), I.uniform1i(n.uniforms.uVelocity, 4), h(null);
672
678
  };
673
- const zI = "var ye = Object.defineProperty;
var De = (i, e, r) => e in i ? ye(i, e, { enumerable: !0, configurable: !0, writable: !0, value: r }) : i[e] = r;
var se = (i, e, r) => (De(i, typeof e != "symbol" ? e + "" : e, r), r), he = (i, e, r) => {
  if (!e.has(i))
    throw TypeError("Cannot " + r);
};
var t = (i, e, r) => (he(i, e, "read from private field"), r ? r.call(i) : e.get(i)), l = (i, e, r) => {
  if (e.has(i))
    throw TypeError("Cannot add the same private member more than once");
  e instanceof WeakSet ? e.add(i) : e.set(i, r);
}, a = (i, e, r, o) => (he(i, e, "write to private field"), o ? o.call(i, r) : e.set(i, r), r);
var d = (i, e, r) => (he(i, e, "access private method"), r);
const ge = {
  densityDissipation: 0.992,
  velocityDissipation: 0.93,
  pressureIterations: 1,
  curl: 1e-4,
  splatRadius: 4e-3,
  splatForce: 0.91,
  refraction: 0.25,
  specularExp: 1.01,
  shine: 0.01,
  waterColor: [0, 0, 0],
  glowColor: [0.7, 0.85, 1],
  algorithm: "standard",
  warpStrength: 0.015
};
({
  ...ge
});
const Ue = {
  calm: {
    densityDissipation: 0.999,
    velocityDissipation: 0.98,
    curl: 1e-4,
    splatRadius: 3e-3,
    splatForce: 0.5,
    refraction: 0.15,
    shine: 5e-3,
    glowColor: [0.6, 0.85, 1],
    waterColor: [0, 0.02, 0.05]
  },
  sand: {
    densityDissipation: 0.997,
    velocityDissipation: 0.98,
    curl: 1,
    splatRadius: 0.01,
    splatForce: 0.9,
    refraction: 0.8,
    specularExp: 0.1,
    shine: 0.05,
    glowColor: [0.027, 0.027, 0.027],
    waterColor: [0.451, 0.329, 0.125]
  },
  wave: {
    densityDissipation: 0.994,
    velocityDissipation: 0.92,
    curl: 0.2,
    splatRadius: 5e-3,
    splatForce: 1.2,
    refraction: 0.35,
    shine: 0.03,
    glowColor: [0.5, 0.8, 1],
    waterColor: [0, 0.01, 0.03]
  },
  neon: {
    densityDissipation: 0.985,
    velocityDissipation: 0.93,
    curl: 0.05,
    splatRadius: 8e-3,
    splatForce: 1.5,
    refraction: 0.25,
    specularExp: 0.5,
    shine: 0.14,
    glowColor: [1, 0.2, 0.8],
    waterColor: [0.05, 0, 0.08]
  },
  smoke: {
    densityDissipation: 0.996,
    velocityDissipation: 0.97,
    curl: 0.04,
    splatRadius: 9e-3,
    splatForce: 0.8,
    refraction: 0.08,
    shine: 0,
    glowColor: [0.5, 0.5, 0.5],
    waterColor: [0.06, 0.06, 0.06]
  }
};
function _e(i = {}, e, r = ge) {
  return { ...e ? { ...r, ...Ue[e] } : r, ...i };
}
const P = (
  /* glsl */
  `
  precision highp float;
  attribute vec2 aPosition;
  varying vec2 vUv;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform vec2 texelSize;
  void main () {
    vUv = aPosition * 0.5 + 0.5;
    vL = vUv - vec2(texelSize.x, 0.0);
    vR = vUv + vec2(texelSize.x, 0.0);
    vT = vUv + vec2(0.0, texelSize.y);
    vB = vUv - vec2(0.0, texelSize.y);
    gl_Position = vec4(aPosition, 0.0, 1.0);
  }
`
), we = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uVelocity;
  uniform sampler2D uSource;
  uniform sampler2D uObstacle;
  uniform vec2 texelSize;
  uniform float dt;
  uniform float dissipation;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    vec2 coord = vUv - dt * texture2D(uVelocity, vUv).xy * texelSize;
    gl_FragColor = dissipation * texture2D(uSource, coord);
  }
`
), Ce = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    float L = texture2D(uObstacle, vL).r > 0.5 ? 0.0 : texture2D(uVelocity, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? 0.0 : texture2D(uVelocity, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? 0.0 : texture2D(uVelocity, vT).y;
    float B = texture2D(uObstacle, vB).r > 0.5 ? 0.0 : texture2D(uVelocity, vB).y;
    gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
  }
`
), Se = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uDivergence;
  uniform sampler2D uObstacle;
  void main () {
    float C = texture2D(uPressure, vUv).x;
    float L = texture2D(uObstacle, vL).r > 0.5 ? C : texture2D(uPressure, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? C : texture2D(uPressure, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? C : texture2D(uPressure, vT).x;
    float B = texture2D(uObstacle, vB).r > 0.5 ? C : texture2D(uPressure, vB).x;
    float div = texture2D(uDivergence, vUv).x;
    gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
  }
`
), Fe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    float L = texture2D(uPressure, vL).x;
    float R = texture2D(uPressure, vR).x;
    float T = texture2D(uPressure, vT).x;
    float B = texture2D(uPressure, vB).x;
    vec2 vel = texture2D(uVelocity, vUv).xy - vec2(R - L, T - B);
    gl_FragColor = vec4(vel, 0.0, 1.0);
  }
`
), Xe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uTarget;
  uniform float aspectRatio;
  uniform vec3 color;
  uniform vec2 point;
  uniform float radius;
  void main () {
    vec2 p = vUv - point.xy;
    p.x *= aspectRatio;
    vec3 splat = exp(-dot(p, p) / radius) * color;
    gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
  }
`
), Be = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  void main () {
    float L = texture2D(uVelocity, vL).y;
    float R = texture2D(uVelocity, vR).y;
    float T = texture2D(uVelocity, vT).x;
    float B = texture2D(uVelocity, vB).x;
    gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
  }
`
), Ae = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uCurl;
  uniform float curl;
  uniform float dt;
  void main () {
    float L = texture2D(uCurl, vL).x;
    float R = texture2D(uCurl, vR).x;
    float T = texture2D(uCurl, vT).x;
    float B = texture2D(uCurl, vB).x;
    float C = texture2D(uCurl, vUv).x;
    vec2 force = 0.5 * vec2(abs(T) - abs(B), abs(R) - abs(L));
    force /= length(force) + 0.0001;
    force *= curl * 30.0 * C;
    gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
  }
`
), Le = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;

  uniform sampler2D uTexture;
  uniform sampler2D uObstacle;
  uniform sampler2D uBackground;
  uniform sampler2D uCoverage;
  uniform sampler2D uVelocity;

  uniform vec2  texelSize;
  uniform vec3  uWaterColor;
  uniform vec3  uGlowColor;
  uniform float uRefraction;
  uniform float uSpecularExp;
  uniform float uShine;
  uniform float uWarpStrength;
  uniform int   uAlgorithm;

  void main () {
    float obs      = texture2D(uObstacle,  vUv).r;
    // Mask density inside obstacles so splats don't flicker the text/image content.
    float density  = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
    float coverage = texture2D(uCoverage,  vUv).r;

    float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dR = max(texture2D(uTexture, vUv + vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dT = max(texture2D(uTexture, vUv + vec2(0.0, texelSize.y * 2.0)).r, 0.0);
    float dB = max(texture2D(uTexture, vUv - vec2(0.0, texelSize.y * 2.0)).r, 0.0);

    vec3  normal   = normalize(vec3(dL - dR, dB - dT, 0.2));
    vec3  lightDir = normalize(vec3(0.5, 1.0, 0.5));
    vec3  halfV    = normalize(lightDir + vec3(0.0, 0.0, 1.0));
    float spec     = pow(max(dot(normal, halfV), 0.0), uSpecularExp) * uShine * density;

    // In transparent (non-coverage) areas the background texture is empty black canvas.
    // Replace it with uWaterColor so fluid colour is not contaminated by that black,
    // allowing the CSS backgroundColor to show through correctly via premultiplied alpha.
    vec3 bgRaw = texture2D(uBackground, vUv).rgb;
    vec3 bg    = mix(uWaterColor, bgRaw, coverage);
    vec3 color = bg;

    if (uAlgorithm == 1) {
      // ── glass ──────────────────────────────────────────────────────────────
      // Strong UV distortion only. Image bends but no colour overlay.
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 3.0, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = refrBg + spec * uGlowColor * 2.5;
      color = mix(color, bg * 0.6, obs * 0.3);

    } else if (uAlgorithm == 2) {
      // ── ink ────────────────────────────────────────────────────────────────
      // Dense opaque pigment that stains. Subtle refraction underneath.
      float inkD  = min(density * 4.0, 1.0);
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 0.4, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = mix(refrBg, uWaterColor + spec * uGlowColor, inkD);
      color = mix(color, bg * 0.5, obs * 0.15);

    } else if (uAlgorithm == 3) {
      // ── aurora ─────────────────────────────────────────────────────────────
      // Velocity field warps background UVs — liquid metal / lava-lamp feel.
      vec2  vel    = texture2D(uVelocity, vUv).xy;
      float velMag = clamp(length(vel) * 20.0, 0.0, 1.0);
      vec2  warpUv = clamp(vUv + vel * uWarpStrength, 0.0, 1.0);
      vec3  warpBg = mix(uWaterColor, texture2D(uBackground, warpUv).rgb, coverage);
      color  = mix(bg, warpBg, velMag * (1.0 - obs));
      color += spec * uGlowColor * velMag * 1.5;
      color += uWaterColor * density * 0.3;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else if (uAlgorithm == 4) {
      // ── ripple ─────────────────────────────────────────────────────────────
      // Exaggerated normal perturbation + Fresnel rim — calm water surface.
      vec2  rippleUv = clamp(vUv + normal.xy * uRefraction * density * 6.0, 0.0, 1.0);
      vec3  refrBg   = mix(uWaterColor, texture2D(uBackground, mix(vUv, rippleUv, 1.0 - obs)).rgb, coverage);
      float fresnel  = pow(clamp(1.0 - dot(normal, vec3(0.0, 0.0, 1.0)), 0.0, 1.0), 3.0) * density;
      color  = refrBg;
      color += fresnel * uGlowColor * 2.0;
      color += spec * uGlowColor * density * 2.0;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else {
      // ── standard (0) ───────────────────────────────────────────────────────
      // Original: colour overlay blended over refracted background.
      vec2 refrUv = vUv + normal.xy * uRefraction * density;
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color  = mix(refrBg, uWaterColor, min(density * 1.5, 0.8));
      color += spec * uGlowColor;
      color  = mix(color, bg * 0.5, obs * 0.2);
    }

    // Premultiplied alpha — transparent where there is neither content nor fluid,
    // letting the CSS backgroundColor on the container div show through.
    float alpha = clamp(max(density * 1.5, coverage), 0.0, 1.0);
    gl_FragColor = vec4(color * alpha, alpha);
  }
`
);
function Pe(i) {
  const e = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
  let r = i.getContext("webgl2", e);
  const o = !!r;
  o || (r = i.getContext("webgl", e), r.getExtension("EXT_color_buffer_half_float"));
  const s = o ? null : r.getExtension("OES_texture_half_float"), n = o ? r.HALF_FLOAT : s.HALF_FLOAT_OES;
  return r.getExtension("EXT_color_buffer_float"), r.getExtension("OES_texture_half_float_linear"), {
    gl: r,
    isWebGL2: o,
    ext: {
      internalFormat: o ? r.RGBA16F : r.RGBA,
      format: r.RGBA,
      type: n
    }
  };
}
class O {
  constructor(e, r, o) {
    se(this, "program");
    se(this, "uniforms", {});
    se(this, "_gl");
    this._gl = e, this.program = e.createProgram(), e.attachShader(this.program, this._compile(e.VERTEX_SHADER, r)), e.attachShader(this.program, this._compile(e.FRAGMENT_SHADER, o)), e.linkProgram(this.program);
    const s = e.getProgramParameter(this.program, e.ACTIVE_UNIFORMS);
    for (let n = 0; n < s; n++) {
      const u = e.getActiveUniform(this.program, n).name;
      this.uniforms[u] = e.getUniformLocation(this.program, u);
    }
  }
  _compile(e, r) {
    const o = this._gl, s = o.createShader(e);
    return o.shaderSource(s, r), o.compileShader(s), s;
  }
  bind() {
    this._gl.useProgram(this.program);
  }
  dispose() {
    this._gl.deleteProgram(this.program);
  }
}
function Oe(i) {
  return {
    advection: new O(i, P, we),
    divergence: new O(i, P, Ce),
    pressure: new O(i, P, Se),
    gradientSubtract: new O(i, P, Fe),
    splat: new O(i, P, Xe),
    curl: new O(i, P, Be),
    vorticity: new O(i, P, Ae),
    display: new O(i, P, Le)
  };
}
function ae(i, e, r, o) {
  i.activeTexture(i.TEXTURE0);
  const s = i.createTexture();
  i.bindTexture(i.TEXTURE_2D, s), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), i.texImage2D(i.TEXTURE_2D, 0, e.internalFormat, r, o, 0, e.format, e.type, null);
  const n = i.createFramebuffer();
  return i.bindFramebuffer(i.FRAMEBUFFER, n), i.framebufferTexture2D(i.FRAMEBUFFER, i.COLOR_ATTACHMENT0, i.TEXTURE_2D, s, 0), { tex: s, fbo: n, width: r, height: o };
}
function me(i, e, r, o) {
  let s = ae(i, e, r, o), n = ae(i, e, r, o);
  return {
    get read() {
      return s;
    },
    get write() {
      return n;
    },
    swap() {
      [s, n] = [n, s];
    },
    dispose() {
      i.deleteTexture(s.tex), i.deleteFramebuffer(s.fbo), i.deleteTexture(n.tex), i.deleteFramebuffer(n.fbo);
    }
  };
}
function ke(i) {
  const e = i.createBuffer();
  return i.bindBuffer(i.ARRAY_BUFFER, e), i.bufferData(i.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), i.STATIC_DRAW), i.vertexAttribPointer(0, 2, i.FLOAT, !1, 0, 0), i.enableVertexAttribArray(0), function(o) {
    i.bindFramebuffer(i.FRAMEBUFFER, o), i.drawArrays(i.TRIANGLE_FAN, 0, 4);
  };
}
function xe(i, e, r, o, s = "cover") {
  let n;
  s === "cover" ? n = Math.max(r / i, o / e) : s === "contain" ? n = Math.min(r / i, o / e) : typeof s == "string" && s.endsWith("%") ? n = Math.min(r / i, o / e) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? n = parseFloat(s) / Math.max(i, e) : typeof s == "number" ? n = s : n = Math.max(r / i, o / e);
  const u = i * n, T = e * n;
  return { x: (r - u) / 2, y: (o - T) / 2, drawW: u, drawH: T };
}
function Ie(i, e, r, o, s = null, n = "cover") {
  const { text: u, fontSize: T, color: E, fontFamily: c = "sans-serif", fontWeight: h = 900 } = o, R = new OffscreenCanvas(e, r), f = R.getContext("2d");
  ((ue) => {
    if (s) {
      f.clearRect(0, 0, e, r), f.fillStyle = "black", f.fillRect(0, 0, e, r);
      const { x: le, y: ce, drawW: fe, drawH: ve } = xe(
        s.width,
        s.height,
        e,
        r,
        n
      );
      f.drawImage(s, le, ce, fe, ve);
    } else
      f.fillStyle = "black", f.fillRect(0, 0, e, r);
    f.fillStyle = ue, f.font = `${h} ${T}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  })(E);
  const Y = Q(i, R);
  f.fillStyle = "black", f.fillRect(0, 0, e, r), f.fillStyle = "white", f.font = `${h} ${T}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  const oe = Q(i, R);
  return { backgroundTex: Y, obstacleTex: oe, coverageTex: oe };
}
function Me(i, e, r, o, s = 0, n = "cover", u = null, T = "cover") {
  const E = new OffscreenCanvas(r, o), c = E.getContext("2d"), { x: h, y: R, drawW: f, drawH: D } = xe(e.width, e.height, r, o, n);
  if (c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), u) {
    const {
      x: le,
      y: ce,
      drawW: fe,
      drawH: ve
    } = xe(u.width, u.height, r, o, T);
    c.filter = `brightness(${s}) blur(8px)`, c.drawImage(u, le, ce, fe, ve), c.filter = "none";
  }
  c.drawImage(e, h, R, f, D);
  const Y = Q(i, E);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(e, h, R, f, D), c.filter = "none";
  const oe = Q(i, E);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.fillStyle = "white", c.fillRect(
    Math.max(0, h),
    Math.max(0, R),
    Math.min(f, r - Math.max(0, h)),
    Math.min(D, o - Math.max(0, R))
  );
  const ue = Q(i, E);
  return { backgroundTex: Y, obstacleTex: oe, coverageTex: ue };
}
function Q(i, e) {
  const r = i.createTexture();
  return i.bindTexture(i.TEXTURE_2D, r), i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, !0), i.texImage2D(i.TEXTURE_2D, 0, i.RGBA, i.RGBA, i.UNSIGNED_BYTE, e), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), r;
}
async function Ve(i) {
  const e = await fetch(i);
  if (!e.ok)
    throw new Error(`Failed to fetch image: ${i} (${e.status})`);
  const r = await e.blob();
  return createImageBitmap(r);
}
const Ee = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (i) => setTimeout(i, 1e3 / 60), We = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, be = 0.016, Ge = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
var V, b, Z, W, H, p, y, k, I, w, g, v, S, F, X, L, U, B, C, j, G, x, _, A, z, ee, N, K, te, Te, M, q, $, J, re, de, ie, pe, ne, Re;
class ze {
  constructor(e, r = {}) {
    // ---------------------------------------------------------------------------
    // Private helpers
    // ---------------------------------------------------------------------------
    l(this, N);
    l(this, te);
    l(this, M);
    l(this, $);
    l(this, re);
    l(this, ie);
    l(this, ne);
    l(this, V, void 0);
    l(this, b, void 0);
    l(this, Z, void 0);
    l(this, W, void 0);
    l(this, H, void 0);
    l(this, p, 0);
    l(this, y, 0);
    l(this, k, 0);
    l(this, I, 0);
    l(this, w, 1);
    l(this, g, null);
    l(this, v, null);
    l(this, S, null);
    l(this, F, null);
    l(this, X, null);
    l(this, L, null);
    l(this, U, null);
    l(this, B, null);
    // binary content mask for transparent canvas support
    l(this, C, null);
    // optional background image (from backgroundSrc prop)
    l(this, j, "cover");
    l(this, G, void 0);
    l(this, x, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
    // Stores source so textures can be rebuilt on resize
    l(this, _, null);
    l(this, A, null);
    l(this, z, !1);
    l(this, ee, !1);
    a(this, V, e), a(this, G, _e(r));
    const { gl: o, ext: s } = Pe(e);
    a(this, b, o), a(this, Z, s), a(this, W, Oe(o)), a(this, H, ke(o)), o.clearColor(0, 0, 0, 0);
  }
  // ---------------------------------------------------------------------------
  // Public API
  // ---------------------------------------------------------------------------
  setTextSource(e) {
    a(this, _, { type: "text", opts: e }), d(this, N, K).call(this), d(this, M, q).call(this), d(this, $, J).call(this);
  }
  async setImageSource(e, r = 0, o = "cover") {
    const s = await Ve(e);
    if (t(this, ee)) {
      s.close();
      return;
    }
    a(this, _, { type: "image", bitmap: s, effect: r, size: o }), d(this, N, K).call(this), d(this, M, q).call(this), d(this, $, J).call(this);
  }
  setImageBitmap(e, r = 0, o = "cover") {
    a(this, _, { type: "image", bitmap: e, effect: r, size: o }), d(this, N, K).call(this), d(this, M, q).call(this), d(this, $, J).call(this);
  }
  setBackground(e, r = "cover") {
    t(this, C) && t(this, C) !== e && t(this, C).close(), a(this, C, e), a(this, j, r ?? "cover"), t(this, _) && t(this, p) > 0 && d(this, M, q).call(this);
  }
  handleMove(e, r, o = 1) {
    t(this, x).moved = !0, t(this, x).dx = (e - t(this, x).targetX) * o, t(this, x).dy = (r - t(this, x).targetY) * o, t(this, x).targetX = e, t(this, x).targetY = r;
  }
  /**
   * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
   * Safe to call multiple times per frame — each call writes directly to the FBOs.
   * Designed for programmatic use cases (e.g. particle systems, attractor paths)
   * where you want N independent injection points per frame without flooding the
   * mouse-state machine or the worker message queue.
   */
  splat(e, r, o, s, n = 1) {
    if (!t(this, z) || t(this, p) === 0)
      return;
    const u = t(this, b), T = t(this, G), { splat: E } = t(this, W), c = t(this, H);
    u.viewport(0, 0, t(this, k), t(this, I)), E.bind(), u.uniform1f(E.uniforms.aspectRatio, t(this, p) / t(this, y)), u.uniform2f(E.uniforms.point, e * t(this, w) / t(this, p), 1 - r * t(this, w) / t(this, y)), u.uniform1f(E.uniforms.radius, T.splatRadius), u.uniform1i(E.uniforms.uTarget, 0), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, v).read.tex), u.uniform3f(E.uniforms.color, o * T.splatForce * n, -s * T.splatForce * n, 0), c(t(this, v).write.fbo), t(this, v).swap(), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, g).read.tex), u.uniform3f(E.uniforms.color, n, n, n), c(t(this, g).write.fbo), t(this, g).swap();
  }
  resize(e, r, o) {
    if (o !== void 0 ? a(this, w, o) : typeof window < "u" && window.devicePixelRatio && a(this, w, window.devicePixelRatio), e !== void 0 && e > 0) {
      if (r === void 0 || r <= 0)
        return;
      a(this, p, t(this, V).width = e), a(this, y, t(this, V).height = r), a(this, k, e >> 1), a(this, I, r >> 1), d(this, te, Te).call(this);
    } else
      d(this, N, K).call(this);
    t(this, _) && d(this, M, q).call(this), d(this, $, J).call(this);
  }
  updateConfig(e) {
    Object.assign(t(this, G), e);
  }
  destroy() {
    a(this, ee, !0), this.stop();
    const e = t(this, b);
    d(this, re, de).call(this), d(this, ie, pe).call(this), t(this, C) && (t(this, C).close(), a(this, C, null));
    for (const o of Object.values(t(this, W)))
      o.dispose();
    const r = e.getExtension("WEBGL_lose_context");
    r == null || r.loseContext();
  }
  // ---------------------------------------------------------------------------
  // Loop control
  // ---------------------------------------------------------------------------
  start() {
    if (t(this, A) !== null)
      return;
    const e = () => {
      d(this, ne, Re).call(this), a(this, A, Ee(e));
    };
    a(this, A, Ee(e));
  }
  stop() {
    t(this, A) !== null && (We(t(this, A)), a(this, A, null));
  }
  get isRunning() {
    return t(this, A) !== null;
  }
}
V = new WeakMap(), b = new WeakMap(), Z = new WeakMap(), W = new WeakMap(), H = new WeakMap(), p = new WeakMap(), y = new WeakMap(), k = new WeakMap(), I = new WeakMap(), w = new WeakMap(), g = new WeakMap(), v = new WeakMap(), S = new WeakMap(), F = new WeakMap(), X = new WeakMap(), L = new WeakMap(), U = new WeakMap(), B = new WeakMap(), C = new WeakMap(), j = new WeakMap(), G = new WeakMap(), x = new WeakMap(), _ = new WeakMap(), A = new WeakMap(), z = new WeakMap(), ee = new WeakMap(), N = new WeakSet(), K = function() {
  const e = t(this, V);
  "clientWidth" in e && e.clientWidth > 0 ? (a(this, w, typeof window < "u" && window.devicePixelRatio || 1), a(this, p, e.width = Math.round(e.clientWidth * t(this, w))), a(this, y, e.height = Math.round(e.clientHeight * t(this, w)))) : (a(this, p, e.width), a(this, y, e.height)), !(t(this, p) === 0 || t(this, y) === 0) && (a(this, k, t(this, p) >> 1), a(this, I, t(this, y) >> 1), d(this, te, Te).call(this));
}, te = new WeakSet(), Te = function() {
  const e = t(this, b), r = t(this, Z), o = t(this, k), s = t(this, I);
  d(this, re, de).call(this), a(this, g, me(e, r, o, s)), a(this, v, me(e, r, o, s)), a(this, F, me(e, r, o, s)), a(this, S, ae(e, r, o, s)), a(this, X, ae(e, r, o, s));
}, M = new WeakSet(), q = function() {
  if (!(!t(this, _) || t(this, p) === 0)) {
    if (d(this, ie, pe).call(this), t(this, _).type === "text") {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Ie(
        t(this, b),
        t(this, p),
        t(this, y),
        t(this, _).opts,
        t(this, C),
        t(this, j)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    } else {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Me(
        t(this, b),
        t(this, _).bitmap,
        t(this, p),
        t(this, y),
        t(this, _).effect,
        t(this, _).size,
        t(this, C),
        t(this, j)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    }
    a(this, z, !0);
  }
}, $ = new WeakSet(), J = function() {
  t(this, z) && !this.isRunning && this.start();
}, re = new WeakSet(), de = function() {
  var e, r, o;
  (e = t(this, g)) == null || e.dispose(), (r = t(this, v)) == null || r.dispose(), (o = t(this, F)) == null || o.dispose(), t(this, S) && (t(this, b).deleteTexture(t(this, S).tex), t(this, b).deleteFramebuffer(t(this, S).fbo)), t(this, X) && (t(this, b).deleteTexture(t(this, X).tex), t(this, b).deleteFramebuffer(t(this, X).fbo)), a(this, g, a(this, v, a(this, F, a(this, S, a(this, X, null)))));
}, ie = new WeakSet(), pe = function() {
  t(this, L) && t(this, b).deleteTexture(t(this, L)), t(this, U) && t(this, b).deleteTexture(t(this, U)), t(this, B) && t(this, B) !== t(this, U) && t(this, b).deleteTexture(t(this, B)), a(this, L, a(this, U, a(this, B, null)));
}, ne = new WeakSet(), Re = function() {
  if (!t(this, z) || t(this, p) === 0 || !t(this, g) || !t(this, v))
    return;
  const e = t(this, b), r = t(this, G), { advection: o, divergence: s, pressure: n, gradientSubtract: u, splat: T, curl: E, vorticity: c, display: h } = t(this, W);
  t(this, x).x += (t(this, x).targetX - t(this, x).x) * 0.15, t(this, x).y += (t(this, x).targetY - t(this, x).y) * 0.15;
  const R = t(this, k), f = t(this, I), D = t(this, H);
  e.viewport(0, 0, R, f), o.bind(), e.uniform2f(o.uniforms.texelSize, 1 / R, 1 / f), e.uniform1f(o.uniforms.dt, be), e.uniform1i(o.uniforms.uObstacle, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.uniform1f(o.uniforms.dissipation, r.velocityDissipation), e.uniform1i(o.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(o.uniforms.uSource, 1), D(t(this, v).write.fbo), t(this, v).swap(), e.uniform1f(o.uniforms.dissipation, r.densityDissipation), e.uniform1i(o.uniforms.uSource, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, g).read.tex), D(t(this, g).write.fbo), t(this, g).swap(), E.bind(), e.uniform2f(E.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(E.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), D(t(this, X).fbo), c.bind(), e.uniform2f(c.uniforms.texelSize, 1 / R, 1 / f), e.uniform1f(c.uniforms.curl, r.curl), e.uniform1f(c.uniforms.dt, be), e.uniform1i(c.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(c.uniforms.uCurl, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, X).tex), D(t(this, v).write.fbo), t(this, v).swap(), t(this, x).moved && (T.bind(), e.uniform1f(T.uniforms.aspectRatio, t(this, p) / t(this, y)), e.uniform2f(T.uniforms.point, t(this, x).x * t(this, w) / t(this, p), 1 - t(this, x).y * t(this, w) / t(this, y)), e.uniform1f(T.uniforms.radius, r.splatRadius), e.uniform1i(T.uniforms.uTarget, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform3f(T.uniforms.color, t(this, x).dx * r.splatForce, -t(this, x).dy * r.splatForce, 0), D(t(this, v).write.fbo), t(this, v).swap(), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, g).read.tex), e.uniform3f(T.uniforms.color, 1, 1, 1), D(t(this, g).write.fbo), t(this, g).swap(), t(this, x).moved = !1), s.bind(), e.uniform2f(s.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(s.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(s.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, S).fbo), n.bind(), e.uniform2f(n.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(n.uniforms.uDivergence, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, S).tex), e.uniform1i(n.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U));
  for (let Y = 0; Y < r.pressureIterations; Y++)
    e.uniform1i(n.uniforms.uPressure, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), D(t(this, F).write.fbo), t(this, F).swap();
  u.bind(), e.uniform2f(u.uniforms.texelSize, 1 / R, 1 / f), e.uniform1i(u.uniforms.uPressure, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), e.uniform1i(u.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(u.uniforms.uObstacle, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, v).write.fbo), t(this, v).swap(), e.viewport(0, 0, t(this, p), t(this, y)), e.bindFramebuffer(e.FRAMEBUFFER, null), e.clear(e.COLOR_BUFFER_BIT), h.bind(), e.uniform2f(h.uniforms.texelSize, 1 / t(this, p), 1 / t(this, y)), e.uniform3fv(h.uniforms.uWaterColor, r.waterColor), e.uniform3fv(h.uniforms.uGlowColor, r.glowColor), e.uniform1f(h.uniforms.uRefraction, r.refraction), e.uniform1f(h.uniforms.uSpecularExp, r.specularExp), e.uniform1f(h.uniforms.uShine, r.shine), e.uniform1f(h.uniforms.uWarpStrength, r.warpStrength ?? 0.015), e.uniform1i(h.uniforms.uAlgorithm, Ge[r.algorithm] ?? 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, g).read.tex), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, L)), e.activeTexture(e.TEXTURE3), e.bindTexture(e.TEXTURE_2D, t(this, B)), e.activeTexture(e.TEXTURE4), e.bindTexture(e.TEXTURE_2D, t(this, v).read.tex), e.uniform1i(h.uniforms.uTexture, 0), e.uniform1i(h.uniforms.uObstacle, 1), e.uniform1i(h.uniforms.uBackground, 2), e.uniform1i(h.uniforms.uCoverage, 3), e.uniform1i(h.uniforms.uVelocity, 4), D(null);
};
let m = null;
self.onmessage = async (i) => {
  const { type: e, ...r } = i.data;
  try {
    switch (e) {
      case "init": {
        const { canvas: o, width: s, height: n, config: u, dpr: T } = r;
        o.width = s, o.height = n, m = new ze(o, u), m.resize(s, n, T || 1), self.postMessage({ type: "ready" });
        break;
      }
      case "setTextSource": {
        if (!m)
          return;
        m.setTextSource(r.opts);
        break;
      }
      case "setImageSource": {
        if (!m)
          return;
        await m.setImageSource(
          r.src,
          r.effect,
          r.size
        );
        break;
      }
      case "setImageBitmap": {
        if (!m)
          return;
        m.setImageBitmap(
          r.bitmap,
          r.effect,
          r.size
        );
        break;
      }
      case "setBackground": {
        if (!m)
          return;
        m.setBackground(r.bitmap, r.size);
        break;
      }
      case "splat": {
        if (!m)
          return;
        m.splat(
          r.x,
          r.y,
          r.vx,
          r.vy,
          r.strength ?? 1
        );
        break;
      }
      case "move": {
        if (!m)
          return;
        m.handleMove(r.x, r.y, r.strength ?? 1);
        break;
      }
      case "resize": {
        if (!m)
          return;
        m.resize(r.width, r.height, r.dpr);
        break;
      }
      case "updateConfig": {
        if (!m)
          return;
        m.updateConfig(r.config);
        break;
      }
      case "destroy": {
        m == null || m.destroy(), m = null;
        break;
      }
      default:
        console.warn("[fluidity-js worker] Unknown message type:", e);
    }
  } catch (o) {
    self.postMessage({ type: "error", message: (o == null ? void 0 : o.message) ?? String(o) });
  }
};
", FI = typeof window < "u" && window.Blob && new Blob([atob(zI)], { type: "text/javascript;charset=utf-8" });
674
- function ng() {
679
+ const PI = "var Ue = Object.defineProperty;
var _e = (i, e, r) => e in i ? Ue(i, e, { enumerable: !0, configurable: !0, writable: !0, value: r }) : i[e] = r;
var ne = (i, e, r) => (_e(i, typeof e != "symbol" ? e + "" : e, r), r), xe = (i, e, r) => {
  if (!e.has(i))
    throw TypeError("Cannot " + r);
};
var t = (i, e, r) => (xe(i, e, "read from private field"), r ? r.call(i) : e.get(i)), l = (i, e, r) => {
  if (e.has(i))
    throw TypeError("Cannot add the same private member more than once");
  e instanceof WeakSet ? e.add(i) : e.set(i, r);
}, a = (i, e, r, o) => (xe(i, e, "write to private field"), o ? o.call(i, r) : e.set(i, r), r);
var T = (i, e, r) => (xe(i, e, "access private method"), r);
const ye = {
  densityDissipation: 0.992,
  velocityDissipation: 0.93,
  pressureIterations: 1,
  curl: 1e-4,
  splatRadius: 4e-3,
  splatForce: 0.91,
  refraction: 0.25,
  specularExp: 1.01,
  shine: 0.01,
  waterColor: [0, 0, 0],
  glowColor: [0.7, 0.85, 1],
  algorithm: "standard",
  warpStrength: 0.015
};
({
  ...ye
});
const we = {
  calm: {
    densityDissipation: 0.999,
    velocityDissipation: 0.98,
    curl: 1e-4,
    splatRadius: 3e-3,
    splatForce: 0.5,
    refraction: 0.15,
    shine: 5e-3,
    glowColor: [0.6, 0.85, 1],
    waterColor: [0, 0.02, 0.05]
  },
  sand: {
    densityDissipation: 0.997,
    velocityDissipation: 0.98,
    curl: 1,
    splatRadius: 0.01,
    splatForce: 0.9,
    refraction: 0.8,
    specularExp: 0.1,
    shine: 0.05,
    glowColor: [0.027, 0.027, 0.027],
    waterColor: [0.451, 0.329, 0.125]
  },
  wave: {
    densityDissipation: 0.994,
    velocityDissipation: 0.92,
    curl: 0.2,
    splatRadius: 5e-3,
    splatForce: 1.2,
    refraction: 0.35,
    shine: 0.03,
    glowColor: [0.5, 0.8, 1],
    waterColor: [0, 0.01, 0.03]
  },
  neon: {
    densityDissipation: 0.985,
    velocityDissipation: 0.93,
    curl: 0.05,
    splatRadius: 8e-3,
    splatForce: 1.5,
    refraction: 0.25,
    specularExp: 0.5,
    shine: 0.14,
    glowColor: [1, 0.2, 0.8],
    waterColor: [0.05, 0, 0.08]
  },
  smoke: {
    densityDissipation: 0.996,
    velocityDissipation: 0.97,
    curl: 0.04,
    splatRadius: 9e-3,
    splatForce: 0.8,
    refraction: 0.08,
    shine: 0,
    glowColor: [0.5, 0.5, 0.5],
    waterColor: [0.06, 0.06, 0.06]
  }
};
function Se(i = {}, e, r = ye) {
  return { ...e ? { ...r, ...we[e] } : r, ...i };
}
const P = (
  /* glsl */
  `
  precision highp float;
  attribute vec2 aPosition;
  varying vec2 vUv;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform vec2 texelSize;
  void main () {
    vUv = aPosition * 0.5 + 0.5;
    vL = vUv - vec2(texelSize.x, 0.0);
    vR = vUv + vec2(texelSize.x, 0.0);
    vT = vUv + vec2(0.0, texelSize.y);
    vB = vUv - vec2(0.0, texelSize.y);
    gl_Position = vec4(aPosition, 0.0, 1.0);
  }
`
), Ce = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uVelocity;
  uniform sampler2D uSource;
  uniform sampler2D uObstacle;
  uniform vec2 texelSize;
  uniform float dt;
  uniform float dissipation;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    vec2 coord = vUv - dt * texture2D(uVelocity, vUv).xy * texelSize;
    gl_FragColor = dissipation * texture2D(uSource, coord);
  }
`
), Fe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    float L = texture2D(uObstacle, vL).r > 0.5 ? 0.0 : texture2D(uVelocity, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? 0.0 : texture2D(uVelocity, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? 0.0 : texture2D(uVelocity, vT).y;
    float B = texture2D(uObstacle, vB).r > 0.5 ? 0.0 : texture2D(uVelocity, vB).y;
    gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
  }
`
), Xe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uDivergence;
  uniform sampler2D uObstacle;
  void main () {
    float C = texture2D(uPressure, vUv).x;
    float L = texture2D(uObstacle, vL).r > 0.5 ? C : texture2D(uPressure, vL).x;
    float R = texture2D(uObstacle, vR).r > 0.5 ? C : texture2D(uPressure, vR).x;
    float T = texture2D(uObstacle, vT).r > 0.5 ? C : texture2D(uPressure, vT).x;
    float B = texture2D(uObstacle, vB).r > 0.5 ? C : texture2D(uPressure, vB).x;
    float div = texture2D(uDivergence, vUv).x;
    gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
  }
`
), Be = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uPressure;
  uniform sampler2D uVelocity;
  uniform sampler2D uObstacle;
  void main () {
    if (texture2D(uObstacle, vUv).r > 0.5) { gl_FragColor = vec4(0.0); return; }
    float L = texture2D(uPressure, vL).x;
    float R = texture2D(uPressure, vR).x;
    float T = texture2D(uPressure, vT).x;
    float B = texture2D(uPressure, vB).x;
    vec2 vel = texture2D(uVelocity, vUv).xy - vec2(R - L, T - B);
    gl_FragColor = vec4(vel, 0.0, 1.0);
  }
`
), Ae = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;
  uniform sampler2D uTarget;
  uniform float aspectRatio;
  uniform vec3 color;
  uniform vec2 point;
  uniform float radius;
  void main () {
    vec2 p = vUv - point.xy;
    p.x *= aspectRatio;
    vec3 splat = exp(-dot(p, p) / radius) * color;
    gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
  }
`
), Le = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  void main () {
    float L = texture2D(uVelocity, vL).y;
    float R = texture2D(uVelocity, vR).y;
    float T = texture2D(uVelocity, vT).x;
    float B = texture2D(uVelocity, vB).x;
    gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
  }
`
), Me = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv; varying vec2 vL; varying vec2 vR; varying vec2 vT; varying vec2 vB;
  uniform sampler2D uVelocity;
  uniform sampler2D uCurl;
  uniform float curl;
  uniform float dt;
  void main () {
    float L = texture2D(uCurl, vL).x;
    float R = texture2D(uCurl, vR).x;
    float T = texture2D(uCurl, vT).x;
    float B = texture2D(uCurl, vB).x;
    float C = texture2D(uCurl, vUv).x;
    vec2 force = 0.5 * vec2(abs(T) - abs(B), abs(R) - abs(L));
    force /= length(force) + 0.0001;
    force *= curl * 30.0 * C;
    gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
  }
`
), Pe = (
  /* glsl */
  `
  precision highp float;
  varying vec2 vUv;

  uniform sampler2D uTexture;
  uniform sampler2D uObstacle;
  uniform sampler2D uBackground;
  uniform sampler2D uCoverage;
  uniform sampler2D uVelocity;

  uniform vec2  texelSize;
  uniform vec3  uWaterColor;
  uniform vec3  uGlowColor;
  uniform float uRefraction;
  uniform float uSpecularExp;
  uniform float uShine;
  uniform float uWarpStrength;
  uniform int   uAlgorithm;

  void main () {
    float obs      = texture2D(uObstacle,  vUv).r;
    // Mask density inside obstacles so splats don't flicker the text/image content.
    float density  = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
    float coverage = texture2D(uCoverage,  vUv).r;

    float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dR = max(texture2D(uTexture, vUv + vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
    float dT = max(texture2D(uTexture, vUv + vec2(0.0, texelSize.y * 2.0)).r, 0.0);
    float dB = max(texture2D(uTexture, vUv - vec2(0.0, texelSize.y * 2.0)).r, 0.0);

    vec3  normal   = normalize(vec3(dL - dR, dB - dT, 0.2));
    vec3  lightDir = normalize(vec3(0.5, 1.0, 0.5));
    vec3  halfV    = normalize(lightDir + vec3(0.0, 0.0, 1.0));
    float spec     = pow(max(dot(normal, halfV), 0.0), uSpecularExp) * uShine * density;

    // In transparent (non-coverage) areas the background texture is empty black canvas.
    // Replace it with uWaterColor so fluid colour is not contaminated by that black,
    // allowing the CSS backgroundColor to show through correctly via premultiplied alpha.
    vec3 bgRaw = texture2D(uBackground, vUv).rgb;
    vec3 bg    = mix(uWaterColor, bgRaw, coverage);
    vec3 color = bg;

    if (uAlgorithm == 1) {
      // ── glass ──────────────────────────────────────────────────────────────
      // Strong UV distortion only. Image bends but no colour overlay.
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 3.0, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = refrBg + spec * uGlowColor * 2.5;
      color = mix(color, bg * 0.6, obs * 0.3);

    } else if (uAlgorithm == 2) {
      // ── ink ────────────────────────────────────────────────────────────────
      // Dense opaque pigment that stains. Subtle refraction underneath.
      float inkD  = min(density * 4.0, 1.0);
      vec2 refrUv = clamp(vUv + normal.xy * uRefraction * density * 0.4, 0.0, 1.0);
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color = mix(refrBg, uWaterColor + spec * uGlowColor, inkD);
      color = mix(color, bg * 0.5, obs * 0.15);

    } else if (uAlgorithm == 3) {
      // ── aurora ─────────────────────────────────────────────────────────────
      // Velocity field warps background UVs — liquid metal / lava-lamp feel.
      vec2  vel    = texture2D(uVelocity, vUv).xy;
      float velMag = clamp(length(vel) * 20.0, 0.0, 1.0);
      vec2  warpUv = clamp(vUv + vel * uWarpStrength, 0.0, 1.0);
      vec3  warpBg = mix(uWaterColor, texture2D(uBackground, warpUv).rgb, coverage);
      color  = mix(bg, warpBg, velMag * (1.0 - obs));
      color += spec * uGlowColor * velMag * 1.5;
      color += uWaterColor * density * 0.3;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else if (uAlgorithm == 4) {
      // ── ripple ─────────────────────────────────────────────────────────────
      // Exaggerated normal perturbation + Fresnel rim — calm water surface.
      vec2  rippleUv = clamp(vUv + normal.xy * uRefraction * density * 6.0, 0.0, 1.0);
      vec3  refrBg   = mix(uWaterColor, texture2D(uBackground, mix(vUv, rippleUv, 1.0 - obs)).rgb, coverage);
      float fresnel  = pow(clamp(1.0 - dot(normal, vec3(0.0, 0.0, 1.0)), 0.0, 1.0), 3.0) * density;
      color  = refrBg;
      color += fresnel * uGlowColor * 2.0;
      color += spec * uGlowColor * density * 2.0;
      color  = mix(color, bg * 0.5, obs * 0.2);

    } else {
      // ── standard (0) ───────────────────────────────────────────────────────
      // Original: colour overlay blended over refracted background.
      vec2 refrUv = vUv + normal.xy * uRefraction * density;
      vec3 refrBg = mix(uWaterColor, texture2D(uBackground, mix(vUv, refrUv, 1.0 - obs)).rgb, coverage);
      color  = mix(refrBg, uWaterColor, min(density * 1.5, 0.8));
      color += spec * uGlowColor;
      color  = mix(color, bg * 0.5, obs * 0.2);
    }

    // Premultiplied alpha — transparent where there is neither content nor fluid,
    // letting the CSS backgroundColor on the container div show through.
    float alpha = clamp(max(density * 1.5, coverage), 0.0, 1.0);
    gl_FragColor = vec4(color * alpha, alpha);
  }
`
);
function ke(i) {
  const e = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
  let r = i.getContext("webgl2", e);
  const o = !!r;
  o || (r = i.getContext("webgl", e), r.getExtension("EXT_color_buffer_half_float"));
  const s = o ? null : r.getExtension("OES_texture_half_float"), n = o ? r.HALF_FLOAT : s.HALF_FLOAT_OES;
  return r.getExtension("EXT_color_buffer_float"), r.getExtension("OES_texture_half_float_linear"), {
    gl: r,
    isWebGL2: o,
    ext: {
      internalFormat: o ? r.RGBA16F : r.RGBA,
      format: r.RGBA,
      type: n
    }
  };
}
class k {
  constructor(e, r, o) {
    ne(this, "program");
    ne(this, "uniforms", {});
    ne(this, "_gl");
    this._gl = e, this.program = e.createProgram(), e.attachShader(this.program, this._compile(e.VERTEX_SHADER, r)), e.attachShader(this.program, this._compile(e.FRAGMENT_SHADER, o)), e.linkProgram(this.program);
    const s = e.getProgramParameter(this.program, e.ACTIVE_UNIFORMS);
    for (let n = 0; n < s; n++) {
      const u = e.getActiveUniform(this.program, n).name;
      this.uniforms[u] = e.getUniformLocation(this.program, u);
    }
  }
  _compile(e, r) {
    const o = this._gl, s = o.createShader(e);
    return o.shaderSource(s, r), o.compileShader(s), s;
  }
  bind() {
    this._gl.useProgram(this.program);
  }
  dispose() {
    this._gl.deleteProgram(this.program);
  }
}
function Oe(i) {
  return {
    advection: new k(i, P, Ce),
    divergence: new k(i, P, Fe),
    pressure: new k(i, P, Xe),
    gradientSubtract: new k(i, P, Be),
    splat: new k(i, P, Ae),
    curl: new k(i, P, Le),
    vorticity: new k(i, P, Me),
    display: new k(i, P, Pe)
  };
}
function ue(i, e, r, o) {
  i.activeTexture(i.TEXTURE0);
  const s = i.createTexture();
  i.bindTexture(i.TEXTURE_2D, s), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), i.texImage2D(i.TEXTURE_2D, 0, e.internalFormat, r, o, 0, e.format, e.type, null);
  const n = i.createFramebuffer();
  return i.bindFramebuffer(i.FRAMEBUFFER, n), i.framebufferTexture2D(i.FRAMEBUFFER, i.COLOR_ATTACHMENT0, i.TEXTURE_2D, s, 0), { tex: s, fbo: n, width: r, height: o };
}
function de(i, e, r, o) {
  let s = ue(i, e, r, o), n = ue(i, e, r, o);
  return {
    get read() {
      return s;
    },
    get write() {
      return n;
    },
    swap() {
      [s, n] = [n, s];
    },
    dispose() {
      i.deleteTexture(s.tex), i.deleteFramebuffer(s.fbo), i.deleteTexture(n.tex), i.deleteFramebuffer(n.fbo);
    }
  };
}
function Ie(i) {
  const e = i.createBuffer();
  return i.bindBuffer(i.ARRAY_BUFFER, e), i.bufferData(i.ARRAY_BUFFER, new Float32Array([-1, -1, -1, 1, 1, 1, 1, -1]), i.STATIC_DRAW), i.vertexAttribPointer(0, 2, i.FLOAT, !1, 0, 0), i.enableVertexAttribArray(0), function(o) {
    i.bindFramebuffer(i.FRAMEBUFFER, o), i.drawArrays(i.TRIANGLE_FAN, 0, 4);
  };
}
function Te(i, e, r, o, s = "cover") {
  let n;
  s === "cover" ? n = Math.max(r / i, o / e) : s === "contain" ? n = Math.min(r / i, o / e) : typeof s == "string" && s.endsWith("%") ? n = Math.min(r / i, o / e) * (parseFloat(s) / 100) : typeof s == "string" && s.endsWith("px") ? n = parseFloat(s) / Math.max(i, e) : typeof s == "number" ? n = s : n = Math.max(r / i, o / e);
  const u = i * n, d = e * n;
  return { x: (r - u) / 2, y: (o - d) / 2, drawW: u, drawH: d };
}
function Ve(i, e, r, o, s = null, n = "cover") {
  const { text: u, fontSize: d, color: p, fontFamily: c = "sans-serif", fontWeight: m = 900 } = o, y = new OffscreenCanvas(e, r), f = y.getContext("2d");
  ((ce) => {
    if (s) {
      f.clearRect(0, 0, e, r), f.fillStyle = "black", f.fillRect(0, 0, e, r);
      const { x: fe, y: he, drawW: ve, drawH: me } = Te(
        s.width,
        s.height,
        e,
        r,
        n
      );
      f.drawImage(s, fe, he, ve, me);
    } else
      f.fillStyle = "black", f.fillRect(0, 0, e, r);
    f.fillStyle = ce, f.font = `${m} ${d}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  })(p);
  const H = ee(i, y);
  f.fillStyle = "black", f.fillRect(0, 0, e, r), f.fillStyle = "white", f.font = `${m} ${d}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  const ae = ee(i, y);
  return { backgroundTex: H, obstacleTex: ae, coverageTex: ae };
}
function We(i, e, r, o, s = 0, n = "cover", u = null, d = "cover") {
  const p = new OffscreenCanvas(r, o), c = p.getContext("2d"), { x: m, y, drawW: f, drawH: D } = Te(e.width, e.height, r, o, n);
  if (c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), u) {
    const {
      x: fe,
      y: he,
      drawW: ve,
      drawH: me
    } = Te(u.width, u.height, r, o, d);
    c.filter = `brightness(${s}) blur(8px)`, c.drawImage(u, fe, he, ve, me), c.filter = "none";
  }
  c.drawImage(e, m, y, f, D);
  const H = ee(i, p);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.filter = `brightness(${s}) blur(8px)`, c.drawImage(e, m, y, f, D), c.filter = "none";
  const ae = ee(i, p);
  c.clearRect(0, 0, r, o), c.fillStyle = "black", c.fillRect(0, 0, r, o), c.fillStyle = "white", c.fillRect(
    Math.max(0, m),
    Math.max(0, y),
    Math.min(f, r - Math.max(0, m)),
    Math.min(D, o - Math.max(0, y))
  );
  const ce = ee(i, p);
  return { backgroundTex: H, obstacleTex: ae, coverageTex: ce };
}
function ee(i, e) {
  const r = i.createTexture();
  return i.bindTexture(i.TEXTURE_2D, r), i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, !0), i.texImage2D(i.TEXTURE_2D, 0, i.RGBA, i.RGBA, i.UNSIGNED_BYTE, e), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MIN_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_MAG_FILTER, i.LINEAR), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_S, i.CLAMP_TO_EDGE), i.texParameteri(i.TEXTURE_2D, i.TEXTURE_WRAP_T, i.CLAMP_TO_EDGE), r;
}
async function Ge(i) {
  const e = await fetch(i);
  if (!e.ok)
    throw new Error(`Failed to fetch image: ${i} (${e.status})`);
  const r = await e.blob();
  return createImageBitmap(r);
}
const ge = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (i) => setTimeout(i, 1e3 / 60), ze = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, Re = 0.016, Ne = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
var W, g, te, G, q, E, b, O, I, w, Q, L, R, h, C, F, X, M, U, B, S, K, z, x, _, A, N, re, $, J, ie, pe, V, j, Y, Z, oe, Ee, se, be, le, De;
class $e {
  constructor(e, r = {}, o = {}) {
    // ---------------------------------------------------------------------------
    // Private helpers
    // ---------------------------------------------------------------------------
    l(this, $);
    l(this, ie);
    l(this, V);
    l(this, Y);
    l(this, oe);
    l(this, se);
    l(this, le);
    l(this, W, void 0);
    l(this, g, void 0);
    l(this, te, void 0);
    l(this, G, void 0);
    l(this, q, void 0);
    l(this, E, 0);
    l(this, b, 0);
    l(this, O, 0);
    l(this, I, 0);
    l(this, w, 1);
    l(this, Q, 1);
    l(this, L, 0.5);
    l(this, R, null);
    l(this, h, null);
    l(this, C, null);
    l(this, F, null);
    l(this, X, null);
    l(this, M, null);
    l(this, U, null);
    l(this, B, null);
    // binary content mask for transparent canvas support
    l(this, S, null);
    // optional background image (from backgroundSrc prop)
    l(this, K, "cover");
    l(this, z, void 0);
    l(this, x, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
    // Stores source so textures can be rebuilt on resize
    l(this, _, null);
    l(this, A, null);
    l(this, N, !1);
    l(this, re, !1);
    a(this, W, e), a(this, Q, Math.max(0.1, Math.min(1, o.dpr ?? 1))), a(this, L, Math.max(0.1, Math.min(1, o.sim ?? 0.5))), a(this, z, Se(r));
    const { gl: s, ext: n } = ke(e);
    a(this, g, s), a(this, te, n), a(this, G, Oe(s)), a(this, q, Ie(s)), s.clearColor(0, 0, 0, 0);
  }
  // ---------------------------------------------------------------------------
  // Public API
  // ---------------------------------------------------------------------------
  setTextSource(e) {
    a(this, _, { type: "text", opts: e }), T(this, $, J).call(this), T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  async setImageSource(e, r = 0, o = "cover") {
    const s = await Ge(e);
    if (t(this, re)) {
      s.close();
      return;
    }
    a(this, _, { type: "image", bitmap: s, effect: r, size: o }), T(this, $, J).call(this), T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  setImageBitmap(e, r = 0, o = "cover") {
    a(this, _, { type: "image", bitmap: e, effect: r, size: o }), T(this, $, J).call(this), T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  setBackground(e, r = "cover") {
    t(this, S) && t(this, S) !== e && t(this, S).close(), a(this, S, e), a(this, K, r ?? "cover"), t(this, _) && t(this, E) > 0 && t(this, b) > 0 && T(this, V, j).call(this);
  }
  handleMove(e, r, o = 1) {
    t(this, x).moved = !0, t(this, x).dx = (e - t(this, x).targetX) * o, t(this, x).dy = (r - t(this, x).targetY) * o, t(this, x).targetX = e, t(this, x).targetY = r;
  }
  /**
   * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
   * Safe to call multiple times per frame — each call writes directly to the FBOs.
   * Designed for programmatic use cases (e.g. particle systems, attractor paths)
   * where you want N independent injection points per frame without flooding the
   * mouse-state machine or the worker message queue.
   */
  splat(e, r, o, s, n = 1) {
    if (!t(this, N) || t(this, E) === 0)
      return;
    const u = t(this, g), d = t(this, z), { splat: p } = t(this, G), c = t(this, q);
    u.viewport(0, 0, t(this, O), t(this, I)), p.bind(), u.uniform1f(p.uniforms.aspectRatio, t(this, E) / t(this, b)), u.uniform2f(p.uniforms.point, e * t(this, w) / t(this, E), 1 - r * t(this, w) / t(this, b)), u.uniform1f(p.uniforms.radius, d.splatRadius), u.uniform1i(p.uniforms.uTarget, 0), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, h).read.tex), u.uniform3f(p.uniforms.color, o * d.splatForce * n, -s * d.splatForce * n, 0), c(t(this, h).write.fbo), t(this, h).swap(), u.activeTexture(u.TEXTURE0), u.bindTexture(u.TEXTURE_2D, t(this, R).read.tex), u.uniform3f(p.uniforms.color, n, n, n), c(t(this, R).write.fbo), t(this, R).swap();
  }
  updateQuality(e) {
    e.dpr !== void 0 && a(this, Q, Math.max(0.1, Math.min(1, e.dpr))), e.sim !== void 0 && a(this, L, Math.max(0.1, Math.min(1, e.sim)));
  }
  resize(e, r, o) {
    if (o !== void 0 ? a(this, w, o) : typeof window < "u" && window.devicePixelRatio && a(this, w, window.devicePixelRatio), e !== void 0 && e > 0) {
      if (r === void 0 || r <= 0)
        return;
      a(this, E, t(this, W).width = e), a(this, b, t(this, W).height = r), a(this, O, Math.max(1, Math.round(e * t(this, L)))), a(this, I, Math.max(1, Math.round(r * t(this, L)))), T(this, ie, pe).call(this);
    } else
      T(this, $, J).call(this);
    t(this, _) && T(this, V, j).call(this), T(this, Y, Z).call(this);
  }
  updateConfig(e) {
    Object.assign(t(this, z), e);
  }
  destroy() {
    a(this, re, !0), this.stop();
    const e = t(this, g);
    T(this, oe, Ee).call(this), T(this, se, be).call(this), t(this, S) && (t(this, S).close(), a(this, S, null));
    for (const o of Object.values(t(this, G)))
      o.dispose();
    const r = e.getExtension("WEBGL_lose_context");
    r == null || r.loseContext();
  }
  // ---------------------------------------------------------------------------
  // Loop control
  // ---------------------------------------------------------------------------
  start() {
    if (t(this, A) !== null)
      return;
    const e = () => {
      T(this, le, De).call(this), a(this, A, ge(e));
    };
    a(this, A, ge(e));
  }
  stop() {
    t(this, A) !== null && (ze(t(this, A)), a(this, A, null));
  }
  get isRunning() {
    return t(this, A) !== null;
  }
}
W = new WeakMap(), g = new WeakMap(), te = new WeakMap(), G = new WeakMap(), q = new WeakMap(), E = new WeakMap(), b = new WeakMap(), O = new WeakMap(), I = new WeakMap(), w = new WeakMap(), Q = new WeakMap(), L = new WeakMap(), R = new WeakMap(), h = new WeakMap(), C = new WeakMap(), F = new WeakMap(), X = new WeakMap(), M = new WeakMap(), U = new WeakMap(), B = new WeakMap(), S = new WeakMap(), K = new WeakMap(), z = new WeakMap(), x = new WeakMap(), _ = new WeakMap(), A = new WeakMap(), N = new WeakMap(), re = new WeakMap(), $ = new WeakSet(), J = function() {
  const e = t(this, W);
  "clientWidth" in e && e.clientWidth > 0 ? (a(this, w, (typeof window < "u" && window.devicePixelRatio || 1) * t(this, Q)), a(this, E, e.width = Math.round(e.clientWidth * t(this, w))), a(this, b, e.height = Math.round(e.clientHeight * t(this, w)))) : (a(this, E, e.width), a(this, b, e.height)), !(t(this, E) === 0 || t(this, b) === 0) && (a(this, O, Math.max(1, Math.round(t(this, E) * t(this, L)))), a(this, I, Math.max(1, Math.round(t(this, b) * t(this, L)))), T(this, ie, pe).call(this));
}, ie = new WeakSet(), pe = function() {
  const e = t(this, g), r = t(this, te), o = t(this, O), s = t(this, I);
  T(this, oe, Ee).call(this), a(this, R, de(e, r, o, s)), a(this, h, de(e, r, o, s)), a(this, F, de(e, r, o, s)), a(this, C, ue(e, r, o, s)), a(this, X, ue(e, r, o, s));
}, V = new WeakSet(), j = function() {
  if (!(!t(this, _) || t(this, E) === 0 || t(this, b) === 0)) {
    if (T(this, se, be).call(this), t(this, _).type === "text") {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Ve(
        t(this, g),
        t(this, E),
        t(this, b),
        t(this, _).opts,
        t(this, S),
        t(this, K)
      );
      a(this, M, e), a(this, U, r), a(this, B, o);
    } else {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = We(
        t(this, g),
        t(this, _).bitmap,
        t(this, E),
        t(this, b),
        t(this, _).effect,
        t(this, _).size,
        t(this, S),
        t(this, K)
      );
      a(this, M, e), a(this, U, r), a(this, B, o);
    }
    a(this, N, !0);
  }
}, Y = new WeakSet(), Z = function() {
  t(this, N) && !this.isRunning && this.start();
}, oe = new WeakSet(), Ee = function() {
  var e, r, o;
  (e = t(this, R)) == null || e.dispose(), (r = t(this, h)) == null || r.dispose(), (o = t(this, F)) == null || o.dispose(), t(this, C) && (t(this, g).deleteTexture(t(this, C).tex), t(this, g).deleteFramebuffer(t(this, C).fbo)), t(this, X) && (t(this, g).deleteTexture(t(this, X).tex), t(this, g).deleteFramebuffer(t(this, X).fbo)), a(this, R, a(this, h, a(this, F, a(this, C, a(this, X, null)))));
}, se = new WeakSet(), be = function() {
  t(this, M) && t(this, g).deleteTexture(t(this, M)), t(this, U) && t(this, g).deleteTexture(t(this, U)), t(this, B) && t(this, B) !== t(this, U) && t(this, g).deleteTexture(t(this, B)), a(this, M, a(this, U, a(this, B, null)));
}, le = new WeakSet(), De = function() {
  if (!t(this, N) || t(this, E) === 0 || !t(this, R) || !t(this, h))
    return;
  const e = t(this, g), r = t(this, z), { advection: o, divergence: s, pressure: n, gradientSubtract: u, splat: d, curl: p, vorticity: c, display: m } = t(this, G);
  t(this, x).x += (t(this, x).targetX - t(this, x).x) * 0.15, t(this, x).y += (t(this, x).targetY - t(this, x).y) * 0.15;
  const y = t(this, O), f = t(this, I), D = t(this, q);
  e.viewport(0, 0, y, f), o.bind(), e.uniform2f(o.uniforms.texelSize, 1 / y, 1 / f), e.uniform1f(o.uniforms.dt, Re), e.uniform1i(o.uniforms.uObstacle, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.uniform1f(o.uniforms.dissipation, r.velocityDissipation), e.uniform1i(o.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(o.uniforms.uSource, 1), D(t(this, h).write.fbo), t(this, h).swap(), e.uniform1f(o.uniforms.dissipation, r.densityDissipation), e.uniform1i(o.uniforms.uSource, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, R).read.tex), D(t(this, R).write.fbo), t(this, R).swap(), p.bind(), e.uniform2f(p.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(p.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), D(t(this, X).fbo), c.bind(), e.uniform2f(c.uniforms.texelSize, 1 / y, 1 / f), e.uniform1f(c.uniforms.curl, r.curl), e.uniform1f(c.uniforms.dt, Re), e.uniform1i(c.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(c.uniforms.uCurl, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, X).tex), D(t(this, h).write.fbo), t(this, h).swap(), t(this, x).moved && (d.bind(), e.uniform1f(d.uniforms.aspectRatio, t(this, E) / t(this, b)), e.uniform2f(d.uniforms.point, t(this, x).x * t(this, w) / t(this, E), 1 - t(this, x).y * t(this, w) / t(this, b)), e.uniform1f(d.uniforms.radius, r.splatRadius), e.uniform1i(d.uniforms.uTarget, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform3f(d.uniforms.color, t(this, x).dx * r.splatForce, -t(this, x).dy * r.splatForce, 0), D(t(this, h).write.fbo), t(this, h).swap(), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, R).read.tex), e.uniform3f(d.uniforms.color, 1, 1, 1), D(t(this, R).write.fbo), t(this, R).swap(), t(this, x).moved = !1), s.bind(), e.uniform2f(s.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(s.uniforms.uVelocity, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(s.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, C).fbo), n.bind(), e.uniform2f(n.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(n.uniforms.uDivergence, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, C).tex), e.uniform1i(n.uniforms.uObstacle, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U));
  for (let H = 0; H < r.pressureIterations; H++)
    e.uniform1i(n.uniforms.uPressure, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), D(t(this, F).write.fbo), t(this, F).swap();
  u.bind(), e.uniform2f(u.uniforms.texelSize, 1 / y, 1 / f), e.uniform1i(u.uniforms.uPressure, 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, F).read.tex), e.uniform1i(u.uniforms.uVelocity, 1), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(u.uniforms.uObstacle, 2), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, U)), D(t(this, h).write.fbo), t(this, h).swap(), e.viewport(0, 0, t(this, E), t(this, b)), e.bindFramebuffer(e.FRAMEBUFFER, null), e.clear(e.COLOR_BUFFER_BIT), m.bind(), e.uniform2f(m.uniforms.texelSize, 1 / t(this, E), 1 / t(this, b)), e.uniform3fv(m.uniforms.uWaterColor, r.waterColor), e.uniform3fv(m.uniforms.uGlowColor, r.glowColor), e.uniform1f(m.uniforms.uRefraction, r.refraction), e.uniform1f(m.uniforms.uSpecularExp, r.specularExp), e.uniform1f(m.uniforms.uShine, r.shine), e.uniform1f(m.uniforms.uWarpStrength, r.warpStrength ?? 0.015), e.uniform1i(m.uniforms.uAlgorithm, Ne[r.algorithm] ?? 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, R).read.tex), e.activeTexture(e.TEXTURE1), e.bindTexture(e.TEXTURE_2D, t(this, U)), e.activeTexture(e.TEXTURE2), e.bindTexture(e.TEXTURE_2D, t(this, M)), e.activeTexture(e.TEXTURE3), e.bindTexture(e.TEXTURE_2D, t(this, B)), e.activeTexture(e.TEXTURE4), e.bindTexture(e.TEXTURE_2D, t(this, h).read.tex), e.uniform1i(m.uniforms.uTexture, 0), e.uniform1i(m.uniforms.uObstacle, 1), e.uniform1i(m.uniforms.uBackground, 2), e.uniform1i(m.uniforms.uCoverage, 3), e.uniform1i(m.uniforms.uVelocity, 4), D(null);
};
let v = null;
self.onmessage = async (i) => {
  const { type: e, ...r } = i.data;
  try {
    switch (e) {
      case "init": {
        const { canvas: o, width: s, height: n, config: u, dpr: d, quality: p } = r;
        o.width = s, o.height = n, v = new $e(o, u, p ?? {}), v.resize(s, n, d || 1), self.postMessage({ type: "ready" });
        break;
      }
      case "setTextSource": {
        if (!v)
          return;
        v.setTextSource(r.opts);
        break;
      }
      case "setImageSource": {
        if (!v)
          return;
        await v.setImageSource(
          r.src,
          r.effect,
          r.size
        );
        break;
      }
      case "setImageBitmap": {
        if (!v)
          return;
        v.setImageBitmap(
          r.bitmap,
          r.effect,
          r.size
        );
        break;
      }
      case "setBackground": {
        if (!v)
          return;
        v.setBackground(r.bitmap, r.size);
        break;
      }
      case "splat": {
        if (!v)
          return;
        v.splat(
          r.x,
          r.y,
          r.vx,
          r.vy,
          r.strength ?? 1
        );
        break;
      }
      case "move": {
        if (!v)
          return;
        v.handleMove(r.x, r.y, r.strength ?? 1);
        break;
      }
      case "resize": {
        if (!v)
          return;
        v.resize(r.width, r.height, r.dpr);
        break;
      }
      case "updateQuality": {
        if (!v)
          return;
        v.updateQuality(r.quality);
        break;
      }
      case "updateConfig": {
        if (!v)
          return;
        v.updateConfig(r.config);
        break;
      }
      case "destroy": {
        v == null || v.destroy(), v = null;
        break;
      }
      default:
        console.warn("[fluidity-js worker] Unknown message type:", e);
    }
  } catch (o) {
    self.postMessage({ type: "error", message: (o == null ? void 0 : o.message) ?? String(o) });
  }
};
", JI = typeof window < "u" && window.Blob && new Blob([atob(PI)], { type: "text/javascript;charset=utf-8" });
680
+ function Gg() {
675
681
  let C;
676
682
  try {
677
- if (C = FI && (window.URL || window.webkitURL).createObjectURL(FI), !C)
683
+ if (C = JI && (window.URL || window.webkitURL).createObjectURL(JI), !C)
678
684
  throw "";
679
685
  return new Worker(C);
680
686
  } catch {
681
- return new Worker("data:application/javascript;base64," + zI, { type: "module" });
687
+ return new Worker("data:application/javascript;base64," + PI, { type: "module" });
682
688
  } finally {
683
689
  C && (window.URL || window.webkitURL).revokeObjectURL(C);
684
690
  }
685
691
  }
686
- const rg = typeof Worker < "u" && typeof OffscreenCanvas < "u";
687
- var p, k, aI, wI, yI, QI;
688
- class ug {
689
- constructor(I, { isWorkerEnabled: i = !0, config: e = {} } = {}) {
692
+ const hg = typeof Worker < "u" && typeof OffscreenCanvas < "u";
693
+ var p, U, ZI, T, O, XI, _I;
694
+ class Bg {
695
+ constructor(I, {
696
+ isWorkerEnabled: i = !0,
697
+ quality: e = {},
698
+ config: s = {}
699
+ } = {}) {
690
700
  // ---------------------------------------------------------------------------
691
701
  // Private
692
702
  // ---------------------------------------------------------------------------
693
- n(this, yI);
694
- n(this, p, null);
695
- n(this, k, null);
696
- n(this, aI, void 0);
697
- n(this, wI, void 0);
698
- o(this, wI, I), o(this, aI, i && rg), g(this, aI) ? b(this, yI, QI).call(this, I, e) : o(this, k, new fI(I, e));
703
+ m(this, XI);
704
+ m(this, p, null);
705
+ m(this, U, null);
706
+ m(this, ZI, void 0);
707
+ m(this, T, void 0);
708
+ m(this, O, void 0);
709
+ l(this, T, Math.max(0.1, Math.min(1, e.dpr ?? 1))), l(this, O, Math.max(0.1, Math.min(1, e.sim ?? 0.5))), l(this, ZI, i && hg), g(this, ZI) ? b(this, XI, _I).call(this, I, s) : l(this, U, new EI(I, s, { dpr: g(this, T), sim: g(this, O) }));
699
710
  }
700
711
  // ---------------------------------------------------------------------------
701
712
  // Source setters
702
713
  // ---------------------------------------------------------------------------
703
714
  setTextSource(I) {
704
- g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, k).setTextSource(I);
715
+ g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, U).setTextSource(I);
705
716
  }
706
- setImageSource(I, i = q.effect, e = q.imageSize) {
717
+ setImageSource(I, i = iI.effect, e = iI.imageSize) {
707
718
  if (g(this, p)) {
708
- const l = new URL(I, location.href).href;
709
- g(this, p).postMessage({ type: "setImageSource", src: l, effect: i, size: e });
719
+ const s = new URL(I, location.href).href;
720
+ g(this, p).postMessage({ type: "setImageSource", src: s, effect: i, size: e });
710
721
  } else
711
- g(this, k).setImageSource(I, i, e);
722
+ g(this, U).setImageSource(I, i, e);
712
723
  }
713
724
  setBackground(I, i = "cover") {
714
725
  var e;
715
726
  if (g(this, p)) {
716
- const l = I ? [I] : [];
717
- g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, l);
727
+ const s = I ? [I] : [];
728
+ g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, s);
718
729
  } else
719
- (e = g(this, k)) == null || e.setBackground(I ?? null, i);
730
+ (e = g(this, U)) == null || e.setBackground(I ?? null, i);
720
731
  }
721
732
  // ---------------------------------------------------------------------------
722
733
  // Interaction
@@ -725,165 +736,185 @@ class ug {
725
736
  * Immediately injects one splat at (x, y) with explicit velocity (vx, vy).
726
737
  * Safe to call multiple times per frame. See FluidSimulation.splat for details.
727
738
  */
728
- splat(I, i, e, l, s = 1) {
729
- g(this, p) ? g(this, p).postMessage({ type: "splat", x: I, y: i, vx: e, vy: l, strength: s }) : g(this, k).splat(I, i, e, l, s);
739
+ splat(I, i, e, s, o = 1) {
740
+ g(this, p) ? g(this, p).postMessage({ type: "splat", x: I, y: i, vx: e, vy: s, strength: o }) : g(this, U).splat(I, i, e, s, o);
730
741
  }
731
742
  handleMove(I, i, e = 1) {
732
- g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this, k).handleMove(I, i, e);
743
+ g(this, p) ? g(this, p).postMessage({ type: "move", x: I, y: i, strength: e }) : g(this, U).handleMove(I, i, e);
733
744
  }
734
745
  // ---------------------------------------------------------------------------
735
746
  // Config + control
736
747
  // ---------------------------------------------------------------------------
748
+ updateQuality(I) {
749
+ l(this, T, Math.max(0.1, Math.min(1, I.dpr ?? g(this, T)))), l(this, O, Math.max(0.1, Math.min(1, I.sim ?? g(this, O)))), g(this, p) ? g(this, p).postMessage({ type: "updateQuality", quality: { dpr: g(this, T), sim: g(this, O) } }) : g(this, U).updateQuality(I);
750
+ }
737
751
  updateConfig(I) {
738
- g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, k).updateConfig(I);
752
+ g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, U).updateConfig(I);
739
753
  }
740
754
  resize(I, i) {
741
- if (g(this, p)) {
742
- const e = typeof window < "u" && window.devicePixelRatio || 1;
743
- g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e });
744
- } else
745
- g(this, k).resize(I, i);
755
+ const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T);
756
+ g(this, p) ? g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e }) : g(this, U).resize(I, i, e);
746
757
  }
747
758
  destroy() {
748
759
  var I;
749
760
  if (g(this, p)) {
750
761
  const i = g(this, p);
751
- o(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
762
+ l(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
752
763
  } else
753
- (I = g(this, k)) == null || I.destroy(), o(this, k, null);
764
+ (I = g(this, U)) == null || I.destroy(), l(this, U, null);
754
765
  }
755
766
  }
756
- p = new WeakMap(), k = new WeakMap(), aI = new WeakMap(), wI = new WeakMap(), yI = new WeakSet(), QI = function(I, i) {
757
- const e = typeof window < "u" && window.devicePixelRatio || 1, l = Math.round(I.clientWidth * e), s = Math.round(I.clientHeight * e);
758
- I.width = l, I.height = s;
767
+ p = new WeakMap(), U = new WeakMap(), ZI = new WeakMap(), T = new WeakMap(), O = new WeakMap(), XI = new WeakSet(), _I = function(I, i) {
768
+ const e = (typeof window < "u" && window.devicePixelRatio || 1) * g(this, T), s = Math.round(I.clientWidth * e), o = Math.round(I.clientHeight * e);
769
+ I.width = s, I.height = o;
759
770
  let t;
760
771
  try {
761
772
  t = I.transferControlToOffscreen();
762
773
  } catch {
763
774
  console.warn(
764
775
  "[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
765
- ), o(this, aI, !1), o(this, k, new fI(I, i));
776
+ ), l(this, ZI, !1), l(this, U, new EI(I, i, { dpr: g(this, T), sim: g(this, O) }));
766
777
  return;
767
778
  }
768
- const m = o(this, p, new ng());
769
- m.onerror = (r) => {
770
- console.error("[fluidity-js] Worker error:", r.message);
771
- }, m.onmessage = (r) => {
772
- r.data.type === "error" && console.error("[fluidity-js] Simulation error:", r.data.message);
773
- }, m.postMessage({ type: "init", canvas: t, width: l, height: s, config: i, dpr: e }, [t]);
779
+ const u = l(this, p, new Gg());
780
+ u.onerror = (a) => {
781
+ console.error("[fluidity-js] Worker error:", a.message);
782
+ }, u.onmessage = (a) => {
783
+ a.data.type === "error" && console.error("[fluidity-js] Simulation error:", a.data.message);
784
+ }, u.postMessage(
785
+ { type: "init", canvas: t, width: s, height: o, config: i, dpr: e, quality: { dpr: g(this, T), sim: g(this, O) } },
786
+ [t]
787
+ );
774
788
  };
775
- function OI(C, { isWorkerEnabled: I = !0, config: i = {} } = {}) {
776
- const e = bI(null), l = bI({ isWorkerEnabled: I, config: i });
777
- return Q(() => {
778
- const s = C.current;
779
- if (!s)
789
+ function qI(C, { isWorkerEnabled: I = !0, quality: i = {}, config: e = {} } = {}) {
790
+ const s = mI(null), o = mI({ isWorkerEnabled: I, quality: i, config: e }), t = mI(Math.max(0.1, Math.min(1, i.dpr ?? 1))), u = mI({
791
+ dpr: i.dpr,
792
+ sim: i.sim
793
+ });
794
+ return j(() => {
795
+ const a = C.current;
796
+ if (!a)
780
797
  return;
781
- const t = document.createElement("canvas");
782
- t.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", s.appendChild(t);
783
- const m = window.devicePixelRatio || 1, r = s.getBoundingClientRect(), a = Math.round((r.width || s.clientWidth) * m) || 0, u = Math.round((r.height || s.clientHeight) * m) || 0;
784
- a > 0 && (t.width = a, t.height = u);
785
- const { isWorkerEnabled: S, config: A } = l.current, h = new ug(t, { isWorkerEnabled: S, config: A });
786
- e.current = h;
787
- const v = new ResizeObserver((Y) => {
788
- for (const K of Y) {
789
- const D = window.devicePixelRatio || 1, { inlineSize: c, blockSize: w } = K.contentBoxSize[0];
790
- h.resize(Math.round(c * D), Math.round(w * D));
798
+ const c = document.createElement("canvas");
799
+ c.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", a.appendChild(c);
800
+ const { isWorkerEnabled: n, quality: G, config: d } = o.current, h = (window.devicePixelRatio || 1) * t.current, W = a.getBoundingClientRect(), x = Math.round((W.width || a.clientWidth) * h) || 0, F = Math.round((W.height || a.clientHeight) * h) || 0;
801
+ x > 0 && (c.width = x, c.height = F), F === 0 && console.warn(
802
+ "[fluidity-js] Container has zero height simulation will not render. Avoid height:auto or percentage heights without a sized ancestor. Use explicit pixel values instead."
803
+ );
804
+ const w = new Bg(c, { isWorkerEnabled: n, quality: G, config: d });
805
+ s.current = w;
806
+ const D = new ResizeObserver((A) => {
807
+ for (const y of A) {
808
+ const r = (window.devicePixelRatio || 1) * t.current, { inlineSize: Z, blockSize: V } = y.contentBoxSize[0];
809
+ w.resize(Math.round(Z * r), Math.round(V * r));
791
810
  }
792
811
  });
793
- return v.observe(s), () => {
794
- v.disconnect(), h.destroy(), t.remove(), e.current = null;
812
+ return D.observe(a), () => {
813
+ D.disconnect(), w.destroy(), c.remove(), s.current = null;
795
814
  };
796
- }, []), e;
815
+ }, []), j(() => {
816
+ t.current = Math.max(0.1, Math.min(1, i.dpr ?? 1));
817
+ const a = u.current;
818
+ u.current = { dpr: i.dpr, sim: i.sim };
819
+ const c = s.current, n = C.current;
820
+ if (!c || !n || a.dpr === i.dpr && a.sim === i.sim)
821
+ return;
822
+ c.updateQuality(i);
823
+ const G = (window.devicePixelRatio || 1) * t.current, d = n.clientWidth, h = n.clientHeight;
824
+ d > 0 && h > 0 && c.resize(Math.round(d * G), Math.round(h * G));
825
+ }, [i.dpr, i.sim]), s;
797
826
  }
798
- const hg = xI(function({
827
+ const Lg = zI(function({
799
828
  text: I,
800
- fontSize: i = j.fontSize,
801
- color: e = j.color,
802
- fontFamily: l = j.fontFamily,
803
- fontWeight: s = j.fontWeight,
829
+ fontSize: i = $.fontSize,
830
+ color: e = $.color,
831
+ fontFamily: s = $.fontFamily,
832
+ fontWeight: o = $.fontWeight,
804
833
  className: t,
805
- style: m,
806
- config: r,
807
- preset: a,
808
- algorithm: u,
809
- backgroundColor: S = j.backgroundColor,
810
- backgroundSrc: A,
811
- backgroundSize: h = j.backgroundSize,
812
- isMouseEnabled: v = j.isMouseEnabled,
813
- isWorkerEnabled: Y = j.isWorkerEnabled
814
- }, K) {
815
- const D = bI(null), c = OI(D, {
816
- isWorkerEnabled: Y,
817
- config: uI({ ...r, ...u ? { algorithm: u } : {} }, a, kI)
834
+ style: u,
835
+ config: a,
836
+ preset: c,
837
+ algorithm: n,
838
+ backgroundColor: G = $.backgroundColor,
839
+ backgroundSrc: d,
840
+ backgroundSize: h = $.backgroundSize,
841
+ isMouseEnabled: W = $.isMouseEnabled,
842
+ isWorkerEnabled: x = $.isWorkerEnabled,
843
+ quality: F = HI.quality
844
+ }, w) {
845
+ const D = mI(null), A = qI(D, {
846
+ isWorkerEnabled: x,
847
+ quality: F,
848
+ config: pI({ ...a, ...n ? { algorithm: n } : {} }, c, TI)
818
849
  });
819
- MI(
820
- K,
850
+ QI(
851
+ w,
821
852
  () => ({
822
853
  reset() {
823
- var d;
824
- (d = c.current) == null || d.setTextSource({ text: I, fontSize: i, color: e, fontFamily: l, fontWeight: s });
854
+ var r;
855
+ (r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
825
856
  },
826
- move({ x: d, y: G, strength: L = 1 }) {
827
- var B;
828
- (B = c.current) == null || B.handleMove(d, G, L);
857
+ move(r, Z, V = 1) {
858
+ var S;
859
+ (S = A.current) == null || S.handleMove(r, Z, V);
829
860
  },
830
- splat(d, G, L, B, T = 1) {
831
- var O;
832
- (O = c.current) == null || O.splat(d, G, L, B, T);
861
+ splat(r, Z, V, S, M = 1) {
862
+ var q;
863
+ (q = A.current) == null || q.splat(r, Z, V, S, M);
833
864
  },
834
- updateConfig(d) {
835
- var G;
836
- (G = c.current) == null || G.updateConfig(d);
865
+ updateConfig(r) {
866
+ var Z;
867
+ (Z = A.current) == null || Z.updateConfig(r);
837
868
  }
838
869
  }),
839
- [I, i, e, l, s]
840
- ), Q(() => {
841
- var d;
842
- (d = c.current) == null || d.setTextSource({ text: I, fontSize: i, color: e, fontFamily: l, fontWeight: s });
843
- }, [I, i, e, l, s]);
844
- const w = JSON.stringify(r);
845
- return Q(() => {
846
- var d;
847
- (d = c.current) == null || d.updateConfig(
848
- uI({ ...r, ...u !== void 0 ? { algorithm: u } : {} }, a, kI)
870
+ [I, i, e, s, o]
871
+ ), j(() => {
872
+ var r;
873
+ (r = A.current) == null || r.setTextSource({ text: I, fontSize: i, color: e, fontFamily: s, fontWeight: o });
874
+ }, [I, i, e, s, o]);
875
+ const y = JSON.stringify(a);
876
+ return j(() => {
877
+ var r;
878
+ (r = A.current) == null || r.updateConfig(
879
+ pI({ ...a, ...n !== void 0 ? { algorithm: n } : {} }, c, TI)
849
880
  );
850
- }, [a, u, w]), Q(() => {
851
- var G;
852
- if (!A) {
853
- (G = c.current) == null || G.setBackground(null);
881
+ }, [c, n, y]), j(() => {
882
+ var Z;
883
+ if (!d) {
884
+ (Z = A.current) == null || Z.setBackground(null);
854
885
  return;
855
886
  }
856
- let d = !1;
857
- return XI(A).then((L) => {
858
- var B;
859
- if (d) {
860
- L.close();
887
+ let r = !1;
888
+ return kI(d).then((V) => {
889
+ var S;
890
+ if (r) {
891
+ V.close();
861
892
  return;
862
893
  }
863
- (B = c.current) == null || B.setBackground(L, h);
864
- }).catch((L) => console.error("[fluidity-js] backgroundSrc load failed:", L)), () => {
865
- d = !0;
894
+ (S = A.current) == null || S.setBackground(V, h);
895
+ }).catch((V) => console.error("[fluidity-js] backgroundSrc load failed:", V)), () => {
896
+ r = !0;
866
897
  };
867
- }, [A, h]), Q(() => {
868
- if (!v)
898
+ }, [d, h]), j(() => {
899
+ if (!W)
869
900
  return;
870
- const d = D.current;
871
- if (!d)
901
+ const r = D.current;
902
+ if (!r)
872
903
  return;
873
- const G = (B) => {
874
- var O;
875
- const T = d.getBoundingClientRect();
876
- (O = c.current) == null || O.handleMove(B.clientX - T.left, B.clientY - T.top, 2);
877
- }, L = (B) => {
878
- var UI;
879
- B.preventDefault();
880
- const T = d.getBoundingClientRect(), O = B.touches[0];
881
- (UI = c.current) == null || UI.handleMove(O.clientX - T.left, O.clientY - T.top, 1);
904
+ const Z = (S) => {
905
+ var q;
906
+ const M = r.getBoundingClientRect();
907
+ (q = A.current) == null || q.handleMove(S.clientX - M.left, S.clientY - M.top, 2);
908
+ }, V = (S) => {
909
+ var fI;
910
+ S.preventDefault();
911
+ const M = r.getBoundingClientRect(), q = S.touches[0];
912
+ (fI = A.current) == null || fI.handleMove(q.clientX - M.left, q.clientY - M.top, 1);
882
913
  };
883
- return d.addEventListener("mousemove", G), d.addEventListener("touchmove", L, { passive: !1 }), () => {
884
- d.removeEventListener("mousemove", G), d.removeEventListener("touchmove", L);
914
+ return r.addEventListener("mousemove", Z), r.addEventListener("touchmove", V, { passive: !1 }), () => {
915
+ r.removeEventListener("mousemove", Z), r.removeEventListener("touchmove", V);
885
916
  };
886
- }, [v]), /* @__PURE__ */ TI(
917
+ }, [W]), /* @__PURE__ */ NI(
887
918
  "div",
888
919
  {
889
920
  ref: D,
@@ -893,125 +924,127 @@ const hg = xI(function({
893
924
  display: "block",
894
925
  width: "100%",
895
926
  height: "100%",
896
- background: S,
897
- ...m
927
+ background: G,
928
+ ...u
898
929
  }
899
930
  }
900
931
  );
901
- }), Sg = xI(function({
932
+ }), Vg = zI(function({
902
933
  src: I,
903
- effect: i = q.effect,
904
- imageSize: e = q.imageSize,
905
- className: l,
906
- style: s,
934
+ effect: i = iI.effect,
935
+ imageSize: e = iI.imageSize,
936
+ className: s,
937
+ style: o,
907
938
  config: t,
908
- preset: m,
909
- algorithm: r,
910
- backgroundColor: a = q.backgroundColor,
911
- backgroundSrc: u,
912
- backgroundSize: S = q.backgroundSize,
913
- isMouseEnabled: A = q.isMouseEnabled,
914
- isWorkerEnabled: h = q.isWorkerEnabled
915
- }, v) {
916
- const Y = bI(null), K = OI(Y, {
939
+ preset: u,
940
+ algorithm: a,
941
+ backgroundColor: c = iI.backgroundColor,
942
+ backgroundSrc: n,
943
+ backgroundSize: G = iI.backgroundSize,
944
+ isMouseEnabled: d = iI.isMouseEnabled,
945
+ isWorkerEnabled: h = iI.isWorkerEnabled,
946
+ quality: W = HI.quality
947
+ }, x) {
948
+ const F = mI(null), w = qI(F, {
917
949
  isWorkerEnabled: h,
918
- config: uI({ ...t, ...r ? { algorithm: r } : {} }, m)
950
+ quality: W,
951
+ config: pI({ ...t, ...a ? { algorithm: a } : {} }, u)
919
952
  });
920
- MI(
921
- v,
953
+ QI(
954
+ x,
922
955
  () => ({
923
956
  reset() {
924
- var c;
925
- I && ((c = K.current) == null || c.setImageSource(I, i, e));
957
+ var A;
958
+ I && ((A = w.current) == null || A.setImageSource(I, i, e));
926
959
  },
927
- move({ x: c, y: w, strength: d = 1 }) {
928
- var G;
929
- (G = K.current) == null || G.handleMove(c, w, d);
960
+ move(A, y, r = 1) {
961
+ var Z;
962
+ (Z = w.current) == null || Z.handleMove(A, y, r);
930
963
  },
931
- splat(c, w, d, G, L = 1) {
932
- var B;
933
- (B = K.current) == null || B.splat(c, w, d, G, L);
964
+ splat(A, y, r, Z, V = 1) {
965
+ var S;
966
+ (S = w.current) == null || S.splat(A, y, r, Z, V);
934
967
  },
935
- updateConfig(c) {
936
- var w;
937
- (w = K.current) == null || w.updateConfig(c);
968
+ updateConfig(A) {
969
+ var y;
970
+ (y = w.current) == null || y.updateConfig(A);
938
971
  }
939
972
  }),
940
973
  [I, i, e]
941
- ), Q(() => {
942
- var c;
943
- I && ((c = K.current) == null || c.setImageSource(I, i, e));
974
+ ), j(() => {
975
+ var A;
976
+ I && ((A = w.current) == null || A.setImageSource(I, i, e));
944
977
  }, [I, i, e]);
945
978
  const D = JSON.stringify(t);
946
- return Q(() => {
947
- var c;
948
- (c = K.current) == null || c.updateConfig(
949
- uI({ ...t, ...r !== void 0 ? { algorithm: r } : {} }, m)
979
+ return j(() => {
980
+ var A;
981
+ (A = w.current) == null || A.updateConfig(
982
+ pI({ ...t, ...a !== void 0 ? { algorithm: a } : {} }, u)
950
983
  );
951
- }, [m, r, D]), Q(() => {
952
- var w;
953
- if (!u) {
954
- (w = K.current) == null || w.setBackground(null);
984
+ }, [u, a, D]), j(() => {
985
+ var y;
986
+ if (!n) {
987
+ (y = w.current) == null || y.setBackground(null);
955
988
  return;
956
989
  }
957
- let c = !1;
958
- return XI(u).then((d) => {
959
- var G;
960
- if (c) {
961
- d.close();
990
+ let A = !1;
991
+ return kI(n).then((r) => {
992
+ var Z;
993
+ if (A) {
994
+ r.close();
962
995
  return;
963
996
  }
964
- (G = K.current) == null || G.setBackground(d, S);
965
- }).catch((d) => console.error("[fluidity-js] backgroundSrc load failed:", d)), () => {
966
- c = !0;
997
+ (Z = w.current) == null || Z.setBackground(r, G);
998
+ }).catch((r) => console.error("[fluidity-js] backgroundSrc load failed:", r)), () => {
999
+ A = !0;
967
1000
  };
968
- }, [u, S]), Q(() => {
969
- if (!A)
1001
+ }, [n, G]), j(() => {
1002
+ if (!d)
970
1003
  return;
971
- const c = Y.current;
972
- if (!c)
1004
+ const A = F.current;
1005
+ if (!A)
973
1006
  return;
974
- const w = (G) => {
975
- var B;
976
- const L = c.getBoundingClientRect();
977
- (B = K.current) == null || B.handleMove(G.clientX - L.left, G.clientY - L.top, 2);
978
- }, d = (G) => {
979
- var T;
980
- G.preventDefault();
981
- const L = c.getBoundingClientRect(), B = G.touches[0];
982
- (T = K.current) == null || T.handleMove(B.clientX - L.left, B.clientY - L.top, 1);
1007
+ const y = (Z) => {
1008
+ var S;
1009
+ const V = A.getBoundingClientRect();
1010
+ (S = w.current) == null || S.handleMove(Z.clientX - V.left, Z.clientY - V.top, 2);
1011
+ }, r = (Z) => {
1012
+ var M;
1013
+ Z.preventDefault();
1014
+ const V = A.getBoundingClientRect(), S = Z.touches[0];
1015
+ (M = w.current) == null || M.handleMove(S.clientX - V.left, S.clientY - V.top, 1);
983
1016
  };
984
- return c.addEventListener("mousemove", w), c.addEventListener("touchmove", d, { passive: !1 }), () => {
985
- c.removeEventListener("mousemove", w), c.removeEventListener("touchmove", d);
1017
+ return A.addEventListener("mousemove", y), A.addEventListener("touchmove", r, { passive: !1 }), () => {
1018
+ A.removeEventListener("mousemove", y), A.removeEventListener("touchmove", r);
986
1019
  };
987
- }, [A]), /* @__PURE__ */ TI(
1020
+ }, [d]), /* @__PURE__ */ NI(
988
1021
  "div",
989
1022
  {
990
- ref: Y,
991
- className: l,
1023
+ ref: F,
1024
+ className: s,
992
1025
  style: {
993
1026
  position: "relative",
994
1027
  display: "block",
995
1028
  width: "100%",
996
1029
  height: "100%",
997
- background: a,
998
- ...s
1030
+ background: c,
1031
+ ...o
999
1032
  }
1000
1033
  }
1001
1034
  );
1002
1035
  });
1003
1036
  export {
1004
- JI as DEFAULT_CONFIG,
1005
- kI as DEFAULT_CONFIG_TEXT,
1006
- q as DEFAULT_PROPS_IMAGE,
1007
- EI as DEFAULT_PROPS_SHARED,
1008
- j as DEFAULT_PROPS_TEXT,
1009
- ug as FluidController,
1010
- Sg as FluidImage,
1011
- fI as FluidSimulation,
1012
- hg as FluidText,
1013
- _I as PRESETS,
1014
- XI as loadImageBitmap,
1015
- uI as mergeConfig,
1016
- OI as useFluid
1037
+ OI as DEFAULT_CONFIG,
1038
+ TI as DEFAULT_CONFIG_TEXT,
1039
+ iI as DEFAULT_PROPS_IMAGE,
1040
+ HI as DEFAULT_PROPS_SHARED,
1041
+ $ as DEFAULT_PROPS_TEXT,
1042
+ Bg as FluidController,
1043
+ Vg as FluidImage,
1044
+ EI as FluidSimulation,
1045
+ Lg as FluidText,
1046
+ ig as PRESETS,
1047
+ kI as loadImageBitmap,
1048
+ pI as mergeConfig,
1049
+ qI as useFluid
1017
1050
  };