@jayf0x/fluidity-js 0.1.4 → 0.1.5

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 Qg = Object.defineProperty;
2
- var jg = (i, g, C) => g in i ? Qg(i, g, { enumerable: !0, configurable: !0, writable: !0, value: C }) : i[g] = C;
3
- var Bg = (i, g, C) => (jg(i, typeof g != "symbol" ? g + "" : g, C), C), yg = (i, g, C) => {
4
- if (!g.has(i))
5
- throw TypeError("Cannot " + C);
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) => {
4
+ if (!I.has(C))
5
+ throw TypeError("Cannot " + i);
6
6
  };
7
- var I = (i, g, C) => (yg(i, g, "read from private field"), C ? C.call(i) : g.get(i)), u = (i, g, C) => {
8
- if (g.has(i))
7
+ var g = (C, I, i) => (LI(C, I, "read from private field"), i ? i.call(C) : I.get(C)), n = (C, I, i) => {
8
+ if (I.has(C))
9
9
  throw TypeError("Cannot add the same private member more than once");
10
- g instanceof WeakSet ? g.add(i) : g.set(i, C);
11
- }, t = (i, g, C, e) => (yg(i, g, "write to private field"), e ? e.call(i, C) : g.set(i, C), C);
12
- var p = (i, g, C) => (yg(i, g, "access private method"), C);
13
- import { jsx as Tg } from "react/jsx-runtime";
14
- import { useRef as Sg, useEffect as N, forwardRef as xg, useImperativeHandle as Dg } from "react";
15
- const Mg = {
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 = {
16
16
  densityDissipation: 0.992,
17
17
  velocityDissipation: 0.93,
18
18
  pressureIterations: 1,
@@ -26,8 +26,8 @@ const Mg = {
26
26
  glowColor: [0.7, 0.85, 1],
27
27
  algorithm: "standard",
28
28
  warpStrength: 0.015
29
- }, Hg = {
30
- ...Mg,
29
+ }, kI = {
30
+ ...JI,
31
31
  densityDissipation: 0.99,
32
32
  velocityDissipation: 0.98,
33
33
  pressureIterations: 3,
@@ -38,22 +38,22 @@ const Mg = {
38
38
  specularExp: 1,
39
39
  shine: 0.1,
40
40
  glowColor: [0, 0.502, 1]
41
- }, Jg = {
41
+ }, EI = {
42
42
  backgroundColor: "#0a0a0a",
43
43
  backgroundSize: "cover",
44
44
  isMouseEnabled: !0,
45
45
  isWorkerEnabled: !0
46
46
  }, q = {
47
- ...Jg,
47
+ ...EI,
48
48
  effect: 0,
49
49
  imageSize: "cover"
50
50
  }, j = {
51
- ...Jg,
51
+ ...EI,
52
52
  fontSize: 100,
53
53
  color: "#ffffff",
54
54
  fontFamily: "sans-serif",
55
55
  fontWeight: 900
56
- }, Pg = {
56
+ }, _I = {
57
57
  calm: {
58
58
  densityDissipation: 0.999,
59
59
  velocityDissipation: 0.98,
@@ -65,17 +65,17 @@ const Mg = {
65
65
  glowColor: [0.6, 0.85, 1],
66
66
  waterColor: [0, 0.02, 0.05]
67
67
  },
68
- storm: {
69
- densityDissipation: 0.97,
70
- velocityDissipation: 0.88,
71
- curl: 0.45,
72
- splatRadius: 0.012,
73
- splatForce: 3,
74
- refraction: 0.6,
75
- shine: 0.08,
76
- glowColor: [0.2, 0.3, 0.8],
77
- waterColor: [0, 0, 0.1],
78
- pressureIterations: 150
68
+ sand: {
69
+ densityDissipation: 0.997,
70
+ velocityDissipation: 0.98,
71
+ curl: 1,
72
+ splatRadius: 0.01,
73
+ splatForce: 0.9,
74
+ refraction: 0.8,
75
+ specularExp: 0.1,
76
+ shine: 0.05,
77
+ glowColor: [0.027, 0.027, 0.027],
78
+ waterColor: [0.451, 0.329, 0.125]
79
79
  },
80
80
  wave: {
81
81
  densityDissipation: 0.994,
@@ -85,7 +85,6 @@ const Mg = {
85
85
  splatForce: 1.2,
86
86
  refraction: 0.35,
87
87
  shine: 0.03,
88
- pressureIterations: 5,
89
88
  glowColor: [0.5, 0.8, 1],
90
89
  waterColor: [0, 0.01, 0.03]
91
90
  },
@@ -113,71 +112,71 @@ const Mg = {
113
112
  waterColor: [0.06, 0.06, 0.06]
114
113
  }
115
114
  };
116
- function rg(i = {}, g, C = Mg) {
117
- return { ...g ? { ...C, ...Pg[g] } : C, ...i };
115
+ function uI(C = {}, I, i = JI) {
116
+ return { ...I ? { ...i, ..._I[I] } : i, ...C };
118
117
  }
119
- function Lg(i, g, C, e, o = "cover") {
118
+ function RI(C, I, i, e, l = "cover") {
120
119
  let s;
121
- o === "cover" ? s = Math.max(C / i, e / g) : o === "contain" ? s = Math.min(C / i, e / g) : typeof o == "string" && o.endsWith("%") ? s = Math.min(C / i, e / g) * (parseFloat(o) / 100) : typeof o == "string" && o.endsWith("px") ? s = parseFloat(o) / Math.max(i, g) : typeof o == "number" ? s = o : s = Math.max(C / i, e / g);
122
- const l = i * s, n = g * s;
123
- return { x: (C - l) / 2, y: (e - n) / 2, drawW: l, drawH: n };
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 };
124
123
  }
125
- function _g(i, g, C, e, o = null, s = "cover") {
126
- const { text: l, fontSize: n, color: r, fontFamily: a = "sans-serif", fontWeight: Z = 900 } = e, h = new OffscreenCanvas(g, C), A = h.getContext("2d");
127
- ((w) => {
128
- if (o) {
129
- A.clearRect(0, 0, g, C), A.fillStyle = "black", A.fillRect(0, 0, g, C);
130
- const { x: F, y: c, drawW: K, drawH: d } = Lg(
131
- o.width,
132
- o.height,
133
- g,
134
- C,
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,
132
+ I,
133
+ i,
135
134
  s
136
135
  );
137
- A.drawImage(o, F, c, K, d);
136
+ A.drawImage(l, D, c, w, d);
138
137
  } else
139
- A.fillStyle = "black", A.fillRect(0, 0, g, C);
140
- A.shadowColor = w, A.fillStyle = w, A.font = `${Z} ${n}px ${a}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(l, g / 2, C / 2);
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);
141
140
  })(r);
142
- const X = ug(i, h);
143
- A.fillStyle = "black", A.fillRect(0, 0, g, C), A.fillStyle = "white", A.font = `${Z} ${n}px ${a}`, A.textAlign = "center", A.textBaseline = "middle", A.fillText(l, g / 2, C / 2);
144
- const Y = ug(i, h);
145
- return { backgroundTex: X, obstacleTex: Y, coverageTex: Y };
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 };
146
145
  }
147
- function qg(i, g, C, e, o = 0, s = "cover", l = null, n = "cover") {
148
- const r = new OffscreenCanvas(C, e), a = r.getContext("2d"), { x: Z, y: h, drawW: A, drawH: m } = Lg(g.width, g.height, C, e, s);
149
- if (a.clearRect(0, 0, C, e), a.fillStyle = "black", a.fillRect(0, 0, C, e), l) {
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) {
150
149
  const {
151
- x: F,
150
+ x: D,
152
151
  y: c,
153
- drawW: K,
152
+ drawW: w,
154
153
  drawH: d
155
- } = Lg(l.width, l.height, C, e, n);
156
- a.filter = `brightness(${o}) blur(8px)`, a.drawImage(l, F, c, K, d), a.filter = "none";
157
- }
158
- a.drawImage(g, Z, h, A, m);
159
- const X = ug(i, r);
160
- a.clearRect(0, 0, C, e), a.fillStyle = "black", a.fillRect(0, 0, C, e), a.filter = `brightness(${o}) blur(8px)`, a.drawImage(g, Z, h, A, m), a.filter = "none";
161
- const Y = ug(i, r);
162
- a.clearRect(0, 0, C, e), a.fillStyle = "black", a.fillRect(0, 0, C, e), a.fillStyle = "white", a.fillRect(
163
- Math.max(0, Z),
164
- Math.max(0, h),
165
- Math.min(A, C - Math.max(0, Z)),
166
- Math.min(m, e - Math.max(0, h))
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))
167
166
  );
168
- const w = ug(i, r);
169
- return { backgroundTex: X, obstacleTex: Y, coverageTex: w };
167
+ const K = rI(C, r);
168
+ return { backgroundTex: v, obstacleTex: Y, coverageTex: K };
170
169
  }
171
- function ug(i, g) {
172
- const C = i.createTexture();
173
- return i.bindTexture(i.TEXTURE_2D, C), i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, !0), i.texImage2D(i.TEXTURE_2D, 0, i.RGBA, i.RGBA, i.UNSIGNED_BYTE, g), 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), C;
170
+ function rI(C, I) {
171
+ const i = C.createTexture();
172
+ 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;
174
173
  }
175
- async function Xg(i) {
176
- const g = await fetch(i);
177
- if (!g.ok)
178
- throw new Error(`Failed to fetch image: ${i} (${g.status})`);
179
- const C = await g.blob();
180
- return createImageBitmap(C);
174
+ async function XI(C) {
175
+ const I = await fetch(C);
176
+ if (!I.ok)
177
+ throw new Error(`Failed to fetch image: ${C} (${I.status})`);
178
+ const i = await I.blob();
179
+ return createImageBitmap(i);
181
180
  }
182
181
  const P = (
183
182
  /* glsl */
@@ -196,7 +195,7 @@ const P = (
196
195
  gl_Position = vec4(aPosition, 0.0, 1.0);
197
196
  }
198
197
  `
199
- ), $g = (
198
+ ), Ig = (
200
199
  /* glsl */
201
200
  `
202
201
  precision highp float;
@@ -213,7 +212,7 @@ const P = (
213
212
  gl_FragColor = dissipation * texture2D(uSource, coord);
214
213
  }
215
214
  `
216
- ), gI = (
215
+ ), gg = (
217
216
  /* glsl */
218
217
  `
219
218
  precision highp float;
@@ -228,7 +227,7 @@ const P = (
228
227
  gl_FragColor = vec4(0.5 * (R - L + T - B), 0.0, 0.0, 1.0);
229
228
  }
230
229
  `
231
- ), II = (
230
+ ), ig = (
232
231
  /* glsl */
233
232
  `
234
233
  precision highp float;
@@ -246,7 +245,7 @@ const P = (
246
245
  gl_FragColor = vec4((L + R + B + T - div) * 0.25, 0.0, 0.0, 1.0);
247
246
  }
248
247
  `
249
- ), CI = (
248
+ ), Cg = (
250
249
  /* glsl */
251
250
  `
252
251
  precision highp float;
@@ -264,7 +263,7 @@ const P = (
264
263
  gl_FragColor = vec4(vel, 0.0, 1.0);
265
264
  }
266
265
  `
267
- ), iI = (
266
+ ), eg = (
268
267
  /* glsl */
269
268
  `
270
269
  precision highp float;
@@ -281,7 +280,7 @@ const P = (
281
280
  gl_FragColor = vec4(texture2D(uTarget, vUv).xyz + splat, 1.0);
282
281
  }
283
282
  `
284
- ), eI = (
283
+ ), lg = (
285
284
  /* glsl */
286
285
  `
287
286
  precision highp float;
@@ -295,7 +294,7 @@ const P = (
295
294
  gl_FragColor = vec4(0.5 * (R - L - T + B), 0.0, 0.0, 1.0);
296
295
  }
297
296
  `
298
- ), oI = (
297
+ ), sg = (
299
298
  /* glsl */
300
299
  `
301
300
  precision highp float;
@@ -316,7 +315,7 @@ const P = (
316
315
  gl_FragColor = vec4(texture2D(uVelocity, vUv).xy + force * dt, 0.0, 1.0);
317
316
  }
318
317
  `
319
- ), sI = (
318
+ ), og = (
320
319
  /* glsl */
321
320
  `
322
321
  precision highp float;
@@ -338,8 +337,9 @@ const P = (
338
337
  uniform int uAlgorithm;
339
338
 
340
339
  void main () {
341
- float density = max(texture2D(uTexture, vUv).r, 0.0);
342
340
  float obs = texture2D(uObstacle, vUv).r;
341
+ // Mask density inside obstacles so splats don't flicker the text/image content.
342
+ float density = max(texture2D(uTexture, vUv).r, 0.0) * (1.0 - step(0.5, obs));
343
343
  float coverage = texture2D(uCoverage, vUv).r;
344
344
 
345
345
  float dL = max(texture2D(uTexture, vUv - vec2(texelSize.x * 2.0, 0.0)).r, 0.0);
@@ -416,37 +416,37 @@ const P = (
416
416
  }
417
417
  `
418
418
  );
419
- function tI(i) {
420
- const g = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
421
- let C = i.getContext("webgl2", g);
422
- const e = !!C;
423
- e || (C = i.getContext("webgl", g), C.getExtension("EXT_color_buffer_half_float"));
424
- const o = e ? null : C.getExtension("OES_texture_half_float"), s = e ? C.HALF_FLOAT : o.HALF_FLOAT_OES;
425
- return C.getExtension("EXT_color_buffer_float"), C.getExtension("OES_texture_half_float_linear"), {
426
- gl: C,
419
+ function tg(C) {
420
+ const I = { alpha: !0, depth: !1, stencil: !1, antialias: !0, preserveDrawingBuffer: !1 };
421
+ let i = C.getContext("webgl2", I);
422
+ const e = !!i;
423
+ 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
+ return i.getExtension("EXT_color_buffer_float"), i.getExtension("OES_texture_half_float_linear"), {
426
+ gl: i,
427
427
  isWebGL2: e,
428
428
  ext: {
429
- internalFormat: e ? C.RGBA16F : C.RGBA,
430
- format: C.RGBA,
429
+ internalFormat: e ? i.RGBA16F : i.RGBA,
430
+ format: i.RGBA,
431
431
  type: s
432
432
  }
433
433
  };
434
434
  }
435
435
  class _ {
436
- constructor(g, C, e) {
437
- Bg(this, "program");
438
- Bg(this, "uniforms", {});
439
- Bg(this, "_gl");
440
- this._gl = g, this.program = g.createProgram(), g.attachShader(this.program, this._compile(g.VERTEX_SHADER, C)), g.attachShader(this.program, this._compile(g.FRAGMENT_SHADER, e)), g.linkProgram(this.program);
441
- const o = g.getProgramParameter(this.program, g.ACTIVE_UNIFORMS);
442
- for (let s = 0; s < o; s++) {
443
- const l = g.getActiveUniform(this.program, s).name;
444
- this.uniforms[l] = g.getUniformLocation(this.program, l);
436
+ constructor(I, i, e) {
437
+ BI(this, "program");
438
+ BI(this, "uniforms", {});
439
+ BI(this, "_gl");
440
+ 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;
444
+ this.uniforms[t] = I.getUniformLocation(this.program, t);
445
445
  }
446
446
  }
447
- _compile(g, C) {
448
- const e = this._gl, o = e.createShader(g);
449
- return e.shaderSource(o, C), e.compileShader(o), o;
447
+ _compile(I, i) {
448
+ const e = this._gl, l = e.createShader(I);
449
+ return e.shaderSource(l, i), e.compileShader(l), l;
450
450
  }
451
451
  bind() {
452
452
  this._gl.useProgram(this.program);
@@ -455,112 +455,117 @@ class _ {
455
455
  this._gl.deleteProgram(this.program);
456
456
  }
457
457
  }
458
- function lI(i) {
458
+ function cg(C) {
459
459
  return {
460
- advection: new _(i, P, $g),
461
- divergence: new _(i, P, gI),
462
- pressure: new _(i, P, II),
463
- gradientSubtract: new _(i, P, CI),
464
- splat: new _(i, P, iI),
465
- curl: new _(i, P, eI),
466
- vorticity: new _(i, P, oI),
467
- display: new _(i, P, sI)
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)
468
468
  };
469
469
  }
470
- function bg(i, g, C, e) {
471
- i.activeTexture(i.TEXTURE0);
472
- const o = i.createTexture();
473
- i.bindTexture(i.TEXTURE_2D, o), 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, g.internalFormat, C, e, 0, g.format, g.type, null);
474
- const s = i.createFramebuffer();
475
- return i.bindFramebuffer(i.FRAMEBUFFER, s), i.framebufferTexture2D(i.FRAMEBUFFER, i.COLOR_ATTACHMENT0, i.TEXTURE_2D, o, 0), { tex: o, fbo: s, width: C, height: e };
470
+ function VI(C, I, i, e) {
471
+ 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 };
476
476
  }
477
- function wg(i, g, C, e) {
478
- let o = bg(i, g, C, e), s = bg(i, g, C, e);
477
+ function KI(C, I, i, e) {
478
+ let l = VI(C, I, i, e), s = VI(C, I, i, e);
479
479
  return {
480
480
  get read() {
481
- return o;
481
+ return l;
482
482
  },
483
483
  get write() {
484
484
  return s;
485
485
  },
486
486
  swap() {
487
- [o, s] = [s, o];
487
+ [l, s] = [s, l];
488
488
  },
489
489
  dispose() {
490
- i.deleteTexture(o.tex), i.deleteFramebuffer(o.fbo), i.deleteTexture(s.tex), i.deleteFramebuffer(s.fbo);
490
+ C.deleteTexture(l.tex), C.deleteFramebuffer(l.fbo), C.deleteTexture(s.tex), C.deleteFramebuffer(s.fbo);
491
491
  }
492
492
  };
493
493
  }
494
- function cI(i) {
495
- const g = i.createBuffer();
496
- return i.bindBuffer(i.ARRAY_BUFFER, g), 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(e) {
497
- i.bindFramebuffer(i.FRAMEBUFFER, e), i.drawArrays(i.TRIANGLE_FAN, 0, 4);
494
+ function dg(C) {
495
+ const I = C.createBuffer();
496
+ 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
+ C.bindFramebuffer(C.FRAMEBUFFER, e), C.drawArrays(C.TRIANGLE_FAN, 0, 4);
498
498
  };
499
499
  }
500
- const kg = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (i) => setTimeout(i, 1e3 / 60), dI = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, Yg = 0.016, aI = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
501
- var Cg, U, Zg, ig, lg, y, R, $, gg, f, v, B, D, M, J, z, W, E, T, cg, eg, b, H, O, og, sg, Ag, ng, Ug, Ig, tg, dg, hg, Gg, Rg, mg, vg, pg, Eg;
502
- class Fg {
503
- constructor(g, C = {}) {
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 = {}) {
504
504
  // ---------------------------------------------------------------------------
505
505
  // Private helpers
506
506
  // ---------------------------------------------------------------------------
507
- u(this, sg);
508
- u(this, ng);
509
- u(this, Ig);
510
- u(this, dg);
511
- u(this, Gg);
512
- u(this, mg);
513
- u(this, pg);
514
- u(this, Cg, void 0);
515
- u(this, U, void 0);
516
- u(this, Zg, void 0);
517
- u(this, ig, void 0);
518
- u(this, lg, void 0);
519
- u(this, y, 0);
520
- u(this, R, 0);
521
- u(this, $, 0);
522
- u(this, gg, 0);
523
- u(this, f, 1);
524
- u(this, v, null);
525
- u(this, B, null);
526
- u(this, D, null);
527
- u(this, M, null);
528
- u(this, J, null);
529
- u(this, z, null);
530
- u(this, W, null);
531
- u(this, E, null);
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);
532
532
  // binary content mask for transparent canvas support
533
- u(this, T, null);
533
+ n(this, F, null);
534
534
  // optional background image (from backgroundSrc prop)
535
- u(this, cg, "cover");
536
- u(this, eg, void 0);
537
- u(this, b, { x: 0, y: 0, dx: 0, dy: 0, targetX: 0, targetY: 0, moved: !1 });
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
538
  // Stores source so textures can be rebuilt on resize
539
- u(this, H, null);
540
- u(this, O, null);
541
- u(this, og, !1);
542
- t(this, Cg, g), t(this, eg, rg(C));
543
- const { gl: e, ext: o } = tI(g);
544
- t(this, U, e), t(this, Zg, o), t(this, ig, lI(e)), t(this, lg, cI(e)), e.clearColor(0, 0, 0, 0);
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);
545
546
  }
546
547
  // ---------------------------------------------------------------------------
547
548
  // Public API
548
549
  // ---------------------------------------------------------------------------
549
- setTextSource(g) {
550
- t(this, H, { type: "text", opts: g }), p(this, sg, Ag).call(this), p(this, Ig, tg).call(this), p(this, dg, hg).call(this);
550
+ 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);
551
552
  }
552
- async setImageSource(g, C = 0, e = "cover") {
553
- const o = await Xg(g);
554
- t(this, H, { type: "image", bitmap: o, effect: C, size: e }), p(this, sg, Ag).call(this), p(this, Ig, tg).call(this), p(this, dg, hg).call(this);
553
+ async setImageSource(I, i = 0, e = "cover") {
554
+ const l = await XI(I);
555
+ if (g(this, GI)) {
556
+ l.close();
557
+ return;
558
+ }
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);
555
560
  }
556
- setImageBitmap(g, C = 0, e = "cover") {
557
- t(this, H, { type: "image", bitmap: g, effect: C, size: e }), p(this, sg, Ag).call(this), p(this, Ig, tg).call(this), p(this, dg, hg).call(this);
561
+ 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);
558
563
  }
559
- setBackground(g, C = "cover") {
560
- I(this, T) && I(this, T) !== g && I(this, T).close(), t(this, T, g), t(this, cg, C ?? "cover"), I(this, H) && I(this, y) > 0 && p(this, Ig, tg).call(this);
564
+ 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);
561
566
  }
562
- handleMove(g, C, e = 1) {
563
- I(this, b).moved = !0, I(this, b).dx = (g - I(this, b).targetX) * e, I(this, b).dy = (C - I(this, b).targetY) * e, I(this, b).targetX = g, I(this, b).targetY = C;
567
+ 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;
564
569
  }
565
570
  /**
566
571
  * Immediately applies one fluid splat at (x, y) with explicit velocity (vx, vy).
@@ -569,149 +574,149 @@ class Fg {
569
574
  * where you want N independent injection points per frame without flooding the
570
575
  * mouse-state machine or the worker message queue.
571
576
  */
572
- splat(g, C, e, o, s = 1) {
573
- if (!I(this, og) || I(this, y) === 0)
577
+ splat(I, i, e, l, s = 1) {
578
+ if (!g(this, lI) || g(this, y) === 0)
574
579
  return;
575
- const l = I(this, U), n = I(this, eg), { splat: r } = I(this, ig), a = I(this, lg);
576
- l.viewport(0, 0, I(this, $), I(this, gg)), r.bind(), l.uniform1f(r.uniforms.aspectRatio, I(this, y) / I(this, R)), l.uniform2f(r.uniforms.point, g * I(this, f) / I(this, y), 1 - C * I(this, f) / I(this, R)), l.uniform1f(r.uniforms.radius, n.splatRadius), l.uniform1i(r.uniforms.uTarget, 0), l.activeTexture(l.TEXTURE0), l.bindTexture(l.TEXTURE_2D, I(this, B).read.tex), l.uniform3f(r.uniforms.color, e * n.splatForce * s, -o * n.splatForce * s, 0), a(I(this, B).write.fbo), I(this, B).swap(), l.activeTexture(l.TEXTURE0), l.bindTexture(l.TEXTURE_2D, I(this, v).read.tex), l.uniform3f(r.uniforms.color, s, s, s), a(I(this, v).write.fbo), I(this, v).swap();
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();
577
582
  }
578
- resize(g, C, e) {
579
- if (e !== void 0 ? t(this, f, e) : typeof window < "u" && window.devicePixelRatio && t(this, f, window.devicePixelRatio), g !== void 0 && g > 0) {
580
- if (C === void 0 || C <= 0)
583
+ 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) {
585
+ if (i === void 0 || i <= 0)
581
586
  return;
582
- t(this, y, I(this, Cg).width = g), t(this, R, I(this, Cg).height = C), t(this, $, g >> 1), t(this, gg, C >> 1), p(this, ng, Ug).call(this);
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);
583
588
  } else
584
- p(this, sg, Ag).call(this);
585
- I(this, H) && p(this, Ig, tg).call(this);
589
+ b(this, sI, AI).call(this);
590
+ g(this, U) && b(this, gI, tI).call(this), b(this, oI, nI).call(this);
586
591
  }
587
- updateConfig(g) {
588
- Object.assign(I(this, eg), g);
592
+ updateConfig(I) {
593
+ Object.assign(g(this, eI), I);
589
594
  }
590
595
  destroy() {
591
- this.stop();
592
- const g = I(this, U);
593
- p(this, Gg, Rg).call(this), p(this, mg, vg).call(this), I(this, T) && (I(this, T).close(), t(this, T, null));
594
- for (const e of Object.values(I(this, ig)))
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)))
595
600
  e.dispose();
596
- const C = g.getExtension("WEBGL_lose_context");
597
- C == null || C.loseContext();
601
+ const i = I.getExtension("WEBGL_lose_context");
602
+ i == null || i.loseContext();
598
603
  }
599
604
  // ---------------------------------------------------------------------------
600
605
  // Loop control
601
606
  // ---------------------------------------------------------------------------
602
607
  start() {
603
- if (I(this, O) !== null)
608
+ if (g(this, N) !== null)
604
609
  return;
605
- const g = () => {
606
- p(this, pg, Eg).call(this), t(this, O, kg(g));
610
+ const I = () => {
611
+ b(this, pI, NI).call(this), o(this, N, YI(I));
607
612
  };
608
- t(this, O, kg(g));
613
+ o(this, N, YI(I));
609
614
  }
610
615
  stop() {
611
- I(this, O) !== null && (dI(I(this, O)), t(this, O, null));
616
+ g(this, N) !== null && (ag(g(this, N)), o(this, N, null));
612
617
  }
613
618
  get isRunning() {
614
- return I(this, O) !== null;
619
+ return g(this, N) !== null;
615
620
  }
616
621
  }
617
- Cg = new WeakMap(), U = new WeakMap(), Zg = new WeakMap(), ig = new WeakMap(), lg = new WeakMap(), y = new WeakMap(), R = new WeakMap(), $ = new WeakMap(), gg = new WeakMap(), f = new WeakMap(), v = new WeakMap(), B = new WeakMap(), D = new WeakMap(), M = new WeakMap(), J = new WeakMap(), z = new WeakMap(), W = new WeakMap(), E = new WeakMap(), T = new WeakMap(), cg = new WeakMap(), eg = new WeakMap(), b = new WeakMap(), H = new WeakMap(), O = new WeakMap(), og = new WeakMap(), sg = new WeakSet(), Ag = function() {
618
- const g = I(this, Cg);
619
- "clientWidth" in g && g.clientWidth > 0 ? (t(this, f, typeof window < "u" && window.devicePixelRatio || 1), t(this, y, g.width = Math.round(g.clientWidth * I(this, f))), t(this, R, g.height = Math.round(g.clientHeight * I(this, f)))) : (t(this, y, g.width), t(this, R, g.height)), !(I(this, y) === 0 || I(this, R) === 0) && (t(this, $, I(this, y) >> 1), t(this, gg, I(this, R) >> 1), p(this, ng, Ug).call(this));
620
- }, ng = new WeakSet(), Ug = function() {
621
- const g = I(this, U), C = I(this, Zg), e = I(this, $), o = I(this, gg);
622
- p(this, Gg, Rg).call(this), t(this, v, wg(g, C, e, o)), t(this, B, wg(g, C, e, o)), t(this, M, wg(g, C, e, o)), t(this, D, bg(g, C, e, o)), t(this, J, bg(g, C, e, o));
623
- }, Ig = new WeakSet(), tg = function() {
624
- if (!(!I(this, H) || I(this, y) === 0)) {
625
- if (p(this, mg, vg).call(this), I(this, H).type === "text") {
626
- const { backgroundTex: g, obstacleTex: C, coverageTex: e } = _g(
627
- I(this, U),
628
- I(this, y),
629
- I(this, R),
630
- I(this, H).opts,
631
- I(this, T),
632
- I(this, cg)
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(
632
+ g(this, R),
633
+ g(this, y),
634
+ g(this, W),
635
+ g(this, U).opts,
636
+ g(this, F),
637
+ g(this, dI)
633
638
  );
634
- t(this, z, g), t(this, W, C), t(this, E, e);
639
+ o(this, z, I), o(this, X, i), o(this, E, e);
635
640
  } else {
636
- const { backgroundTex: g, obstacleTex: C, coverageTex: e } = qg(
637
- I(this, U),
638
- I(this, H).bitmap,
639
- I(this, y),
640
- I(this, R),
641
- I(this, H).effect,
642
- I(this, H).size,
643
- I(this, T),
644
- I(this, cg)
641
+ const { backgroundTex: I, obstacleTex: i, coverageTex: e } = $I(
642
+ 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)
645
650
  );
646
- t(this, z, g), t(this, W, C), t(this, E, e);
651
+ o(this, z, I), o(this, X, i), o(this, E, e);
647
652
  }
648
- t(this, og, !0);
649
- }
650
- }, dg = new WeakSet(), hg = function() {
651
- I(this, og) && !this.isRunning && this.start();
652
- }, Gg = new WeakSet(), Rg = function() {
653
- var g, C, e;
654
- (g = I(this, v)) == null || g.dispose(), (C = I(this, B)) == null || C.dispose(), (e = I(this, M)) == null || e.dispose(), I(this, D) && (I(this, U).deleteTexture(I(this, D).tex), I(this, U).deleteFramebuffer(I(this, D).fbo)), I(this, J) && (I(this, U).deleteTexture(I(this, J).tex), I(this, U).deleteFramebuffer(I(this, J).fbo)), t(this, v, t(this, B, t(this, M, t(this, D, t(this, J, null)))));
655
- }, mg = new WeakSet(), vg = function() {
656
- I(this, z) && I(this, U).deleteTexture(I(this, z)), I(this, W) && I(this, U).deleteTexture(I(this, W)), I(this, E) && I(this, E) !== I(this, W) && I(this, U).deleteTexture(I(this, E)), t(this, z, t(this, W, t(this, E, null)));
657
- }, pg = new WeakSet(), Eg = function() {
658
- if (!I(this, og) || I(this, y) === 0)
653
+ o(this, lI, !0);
654
+ }
655
+ }, oI = new WeakSet(), nI = function() {
656
+ g(this, lI) && !this.isRunning && this.start();
657
+ }, hI = new WeakSet(), WI = function() {
658
+ 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))
659
664
  return;
660
- const g = I(this, U), C = I(this, eg), { advection: e, divergence: o, pressure: s, gradientSubtract: l, splat: n, curl: r, vorticity: a, display: Z } = I(this, ig);
661
- I(this, b).x += (I(this, b).targetX - I(this, b).x) * 0.15, I(this, b).y += (I(this, b).targetY - I(this, b).y) * 0.15;
662
- const h = I(this, $), A = I(this, gg), m = I(this, lg);
663
- g.viewport(0, 0, h, A), e.bind(), g.uniform2f(e.uniforms.texelSize, 1 / h, 1 / A), g.uniform1f(e.uniforms.dt, Yg), g.uniform1i(e.uniforms.uObstacle, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, W)), g.uniform1f(e.uniforms.dissipation, C.velocityDissipation), g.uniform1i(e.uniforms.uVelocity, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, B).read.tex), g.uniform1i(e.uniforms.uSource, 1), m(I(this, B).write.fbo), I(this, B).swap(), g.uniform1f(e.uniforms.dissipation, C.densityDissipation), g.uniform1i(e.uniforms.uSource, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, v).read.tex), m(I(this, v).write.fbo), I(this, v).swap(), r.bind(), g.uniform2f(r.uniforms.texelSize, 1 / h, 1 / A), g.uniform1i(r.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, B).read.tex), m(I(this, J).fbo), a.bind(), g.uniform2f(a.uniforms.texelSize, 1 / h, 1 / A), g.uniform1f(a.uniforms.curl, C.curl), g.uniform1f(a.uniforms.dt, Yg), g.uniform1i(a.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, B).read.tex), g.uniform1i(a.uniforms.uCurl, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, J).tex), m(I(this, B).write.fbo), I(this, B).swap(), I(this, b).moved && (n.bind(), g.uniform1f(n.uniforms.aspectRatio, I(this, y) / I(this, R)), g.uniform2f(n.uniforms.point, I(this, b).x * I(this, f) / I(this, y), 1 - I(this, b).y * I(this, f) / I(this, R)), g.uniform1f(n.uniforms.radius, C.splatRadius), g.uniform1i(n.uniforms.uTarget, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, B).read.tex), g.uniform3f(n.uniforms.color, I(this, b).dx * C.splatForce, -I(this, b).dy * C.splatForce, 0), m(I(this, B).write.fbo), I(this, B).swap(), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, v).read.tex), g.uniform3f(n.uniforms.color, 1, 1, 1), m(I(this, v).write.fbo), I(this, v).swap(), I(this, b).moved = !1), o.bind(), g.uniform2f(o.uniforms.texelSize, 1 / h, 1 / A), g.uniform1i(o.uniforms.uVelocity, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, B).read.tex), g.uniform1i(o.uniforms.uObstacle, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, W)), m(I(this, D).fbo), s.bind(), g.uniform2f(s.uniforms.texelSize, 1 / h, 1 / A), g.uniform1i(s.uniforms.uDivergence, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, D).tex), g.uniform1i(s.uniforms.uObstacle, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, W));
664
- for (let X = 0; X < C.pressureIterations; X++)
665
- g.uniform1i(s.uniforms.uPressure, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, M).read.tex), m(I(this, M).write.fbo), I(this, M).swap();
666
- l.bind(), g.uniform2f(l.uniforms.texelSize, 1 / h, 1 / A), g.uniform1i(l.uniforms.uPressure, 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, M).read.tex), g.uniform1i(l.uniforms.uVelocity, 1), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, B).read.tex), g.uniform1i(l.uniforms.uObstacle, 2), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, W)), m(I(this, B).write.fbo), I(this, B).swap(), g.viewport(0, 0, I(this, y), I(this, R)), g.bindFramebuffer(g.FRAMEBUFFER, null), g.clear(g.COLOR_BUFFER_BIT), Z.bind(), g.uniform2f(Z.uniforms.texelSize, 1 / I(this, y), 1 / I(this, R)), g.uniform3fv(Z.uniforms.uWaterColor, C.waterColor), g.uniform3fv(Z.uniforms.uGlowColor, C.glowColor), g.uniform1f(Z.uniforms.uRefraction, C.refraction), g.uniform1f(Z.uniforms.uSpecularExp, C.specularExp), g.uniform1f(Z.uniforms.uShine, C.shine), g.uniform1f(Z.uniforms.uWarpStrength, C.warpStrength ?? 0.015), g.uniform1i(Z.uniforms.uAlgorithm, aI[C.algorithm] ?? 0), g.activeTexture(g.TEXTURE0), g.bindTexture(g.TEXTURE_2D, I(this, v).read.tex), g.activeTexture(g.TEXTURE1), g.bindTexture(g.TEXTURE_2D, I(this, W)), g.activeTexture(g.TEXTURE2), g.bindTexture(g.TEXTURE_2D, I(this, z)), g.activeTexture(g.TEXTURE3), g.bindTexture(g.TEXTURE_2D, I(this, E)), g.activeTexture(g.TEXTURE4), g.bindTexture(g.TEXTURE_2D, I(this, B).read.tex), g.uniform1i(Z.uniforms.uTexture, 0), g.uniform1i(Z.uniforms.uObstacle, 1), g.uniform1i(Z.uniforms.uBackground, 2), g.uniform1i(Z.uniforms.uCoverage, 3), g.uniform1i(Z.uniforms.uVelocity, 4), m(null);
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);
667
672
  };
668
- const Og = "var Re = Object.defineProperty;
var ye = (i, e, r) => e in i ? Re(i, e, { enumerable: !0, configurable: !0, writable: !0, value: r }) : i[e] = r;
var oe = (i, e, r) => (ye(i, typeof e != "symbol" ? e + "" : e, r), r), ve = (i, e, r) => {
  if (!e.has(i))
    throw TypeError("Cannot " + r);
};
var t = (i, e, r) => (ve(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) => (ve(i, e, "write to private field"), o ? o.call(i, r) : e.set(i, r), r);
var d = (i, e, r) => (ve(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 De = {
  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]
  },
  storm: {
    densityDissipation: 0.97,
    velocityDissipation: 0.88,
    curl: 0.45,
    splatRadius: 0.012,
    splatForce: 3,
    refraction: 0.6,
    shine: 0.08,
    glowColor: [0.2, 0.3, 0.8],
    waterColor: [0, 0, 0.1],
    pressureIterations: 150
  },
  wave: {
    densityDissipation: 0.994,
    velocityDissipation: 0.92,
    curl: 0.2,
    splatRadius: 5e-3,
    splatForce: 1.2,
    refraction: 0.35,
    shine: 0.03,
    pressureIterations: 5,
    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 Ue(i = {}, e, r = ge) {
  return { ...e ? { ...r, ...De[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);
  }
`
), _e = (
  /* 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);
  }
`
), we = (
  /* 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);
  }
`
), Ce = (
  /* 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);
  }
`
), 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 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);
  }
`
), Fe = (
  /* 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);
  }
`
), Xe = (
  /* 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);
  }
`
), Be = (
  /* 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);
  }
`
), Ae = (
  /* 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 density  = max(texture2D(uTexture,   vUv).r, 0.0);
    float obs      = texture2D(uObstacle,  vUv).r;
    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 Le(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) {
    oe(this, "program");
    oe(this, "uniforms", {});
    oe(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 Pe(i) {
  return {
    advection: new O(i, P, _e),
    divergence: new O(i, P, we),
    pressure: new O(i, P, Ce),
    gradientSubtract: new O(i, P, Se),
    splat: new O(i, P, Fe),
    curl: new O(i, P, Xe),
    vorticity: new O(i, P, Be),
    display: new O(i, P, Ae)
  };
}
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 he(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 Oe(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 me(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 ke(i, e, r, o, s = null, n = "cover") {
  const { text: u, fontSize: T, color: E, fontFamily: c = "sans-serif", fontWeight: h = 900 } = o, b = new OffscreenCanvas(e, r), f = b.getContext("2d");
  ((ie) => {
    if (s) {
      f.clearRect(0, 0, e, r), f.fillStyle = "black", f.fillRect(0, 0, e, r);
      const { x: ue, y: le, drawW: ce, drawH: fe } = me(
        s.width,
        s.height,
        e,
        r,
        n
      );
      f.drawImage(s, ue, le, ce, fe);
    } else
      f.fillStyle = "black", f.fillRect(0, 0, e, r);
    f.shadowColor = ie, f.fillStyle = ie, f.font = `${h} ${T}px ${c}`, f.textAlign = "center", f.textBaseline = "middle", f.fillText(u, e / 2, r / 2);
  })(E);
  const $ = J(i, b);
  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 re = J(i, b);
  return { backgroundTex: $, obstacleTex: re, coverageTex: re };
}
function Ie(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: b, drawW: f, drawH: D } = me(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: ue,
      y: le,
      drawW: ce,
      drawH: fe
    } = me(u.width, u.height, r, o, T);
    c.filter = `brightness(${s}) blur(8px)`, c.drawImage(u, ue, le, ce, fe), c.filter = "none";
  }
  c.drawImage(e, h, b, f, D);
  const $ = J(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, b, f, D), c.filter = "none";
  const re = J(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, b),
    Math.min(f, r - Math.max(0, h)),
    Math.min(D, o - Math.max(0, b))
  );
  const ie = J(i, E);
  return { backgroundTex: $, obstacleTex: re, coverageTex: ie };
}
function J(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 Me(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 pe = typeof requestAnimationFrame < "u" ? requestAnimationFrame.bind(globalThis) : (i) => setTimeout(i, 1e3 / 60), Ve = typeof cancelAnimationFrame < "u" ? cancelAnimationFrame.bind(globalThis) : clearTimeout, Ee = 0.016, We = { standard: 0, glass: 1, ink: 2, aurora: 3, ripple: 4 };
var V, g, Q, W, q, p, R, k, I, w, y, v, S, F, X, L, U, B, C, H, G, x, _, A, z, N, K, Z, xe, M, Y, j, se, ee, Te, te, de, ne, be;
class Ge {
  constructor(e, r = {}) {
    // ---------------------------------------------------------------------------
    // Private helpers
    // ---------------------------------------------------------------------------
    l(this, N);
    l(this, Z);
    l(this, M);
    l(this, j);
    l(this, ee);
    l(this, te);
    l(this, ne);
    l(this, V, void 0);
    l(this, g, void 0);
    l(this, Q, void 0);
    l(this, W, void 0);
    l(this, q, void 0);
    l(this, p, 0);
    l(this, R, 0);
    l(this, k, 0);
    l(this, I, 0);
    l(this, w, 1);
    l(this, y, 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, H, "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);
    a(this, V, e), a(this, G, Ue(r));
    const { gl: o, ext: s } = Le(e);
    a(this, g, o), a(this, Q, s), a(this, W, Pe(o)), a(this, q, Oe(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, Y).call(this), d(this, j, se).call(this);
  }
  async setImageSource(e, r = 0, o = "cover") {
    const s = await Me(e);
    a(this, _, { type: "image", bitmap: s, effect: r, size: o }), d(this, N, K).call(this), d(this, M, Y).call(this), d(this, j, se).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, Y).call(this), d(this, j, se).call(this);
  }
  setBackground(e, r = "cover") {
    t(this, C) && t(this, C) !== e && t(this, C).close(), a(this, C, e), a(this, H, r ?? "cover"), t(this, _) && t(this, p) > 0 && d(this, M, Y).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, g), T = t(this, G), { splat: E } = t(this, W), c = t(this, q);
    u.viewport(0, 0, t(this, k), t(this, I)), E.bind(), u.uniform1f(E.uniforms.aspectRatio, t(this, p) / t(this, R)), u.uniform2f(E.uniforms.point, e * t(this, w) / t(this, p), 1 - r * t(this, w) / t(this, R)), 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, y).read.tex), u.uniform3f(E.uniforms.color, n, n, n), c(t(this, y).write.fbo), t(this, y).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, R, t(this, V).height = r), a(this, k, e >> 1), a(this, I, r >> 1), d(this, Z, xe).call(this);
    } else
      d(this, N, K).call(this);
    t(this, _) && d(this, M, Y).call(this);
  }
  updateConfig(e) {
    Object.assign(t(this, G), e);
  }
  destroy() {
    this.stop();
    const e = t(this, g);
    d(this, ee, Te).call(this), d(this, te, de).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, be).call(this), a(this, A, pe(e));
    };
    a(this, A, pe(e));
  }
  stop() {
    t(this, A) !== null && (Ve(t(this, A)), a(this, A, null));
  }
  get isRunning() {
    return t(this, A) !== null;
  }
}
V = new WeakMap(), g = new WeakMap(), Q = new WeakMap(), W = new WeakMap(), q = new WeakMap(), p = new WeakMap(), R = new WeakMap(), k = new WeakMap(), I = new WeakMap(), w = new WeakMap(), y = 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(), H = new WeakMap(), G = new WeakMap(), x = new WeakMap(), _ = new WeakMap(), A = new WeakMap(), z = 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, R, e.height = Math.round(e.clientHeight * t(this, w)))) : (a(this, p, e.width), a(this, R, e.height)), !(t(this, p) === 0 || t(this, R) === 0) && (a(this, k, t(this, p) >> 1), a(this, I, t(this, R) >> 1), d(this, Z, xe).call(this));
}, Z = new WeakSet(), xe = function() {
  const e = t(this, g), r = t(this, Q), o = t(this, k), s = t(this, I);
  d(this, ee, Te).call(this), a(this, y, he(e, r, o, s)), a(this, v, he(e, r, o, s)), a(this, F, he(e, r, o, s)), a(this, S, ae(e, r, o, s)), a(this, X, ae(e, r, o, s));
}, M = new WeakSet(), Y = function() {
  if (!(!t(this, _) || t(this, p) === 0)) {
    if (d(this, te, de).call(this), t(this, _).type === "text") {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = ke(
        t(this, g),
        t(this, p),
        t(this, R),
        t(this, _).opts,
        t(this, C),
        t(this, H)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    } else {
      const { backgroundTex: e, obstacleTex: r, coverageTex: o } = Ie(
        t(this, g),
        t(this, _).bitmap,
        t(this, p),
        t(this, R),
        t(this, _).effect,
        t(this, _).size,
        t(this, C),
        t(this, H)
      );
      a(this, L, e), a(this, U, r), a(this, B, o);
    }
    a(this, z, !0);
  }
}, j = new WeakSet(), se = function() {
  t(this, z) && !this.isRunning && this.start();
}, ee = new WeakSet(), Te = function() {
  var e, r, o;
  (e = t(this, y)) == null || e.dispose(), (r = t(this, v)) == null || r.dispose(), (o = t(this, F)) == null || o.dispose(), t(this, S) && (t(this, g).deleteTexture(t(this, S).tex), t(this, g).deleteFramebuffer(t(this, S).fbo)), t(this, X) && (t(this, g).deleteTexture(t(this, X).tex), t(this, g).deleteFramebuffer(t(this, X).fbo)), a(this, y, a(this, v, a(this, F, a(this, S, a(this, X, null)))));
}, te = new WeakSet(), de = function() {
  t(this, L) && t(this, g).deleteTexture(t(this, L)), 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, L, a(this, U, a(this, B, null)));
}, ne = new WeakSet(), be = function() {
  if (!t(this, z) || t(this, p) === 0)
    return;
  const e = t(this, g), 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 b = t(this, k), f = t(this, I), D = t(this, q);
  e.viewport(0, 0, b, f), o.bind(), e.uniform2f(o.uniforms.texelSize, 1 / b, 1 / f), e.uniform1f(o.uniforms.dt, Ee), 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, y).read.tex), D(t(this, y).write.fbo), t(this, y).swap(), E.bind(), e.uniform2f(E.uniforms.texelSize, 1 / b, 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 / b, 1 / f), e.uniform1f(c.uniforms.curl, r.curl), e.uniform1f(c.uniforms.dt, Ee), 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, R)), 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, R)), 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, y).read.tex), e.uniform3f(T.uniforms.color, 1, 1, 1), D(t(this, y).write.fbo), t(this, y).swap(), t(this, x).moved = !1), s.bind(), e.uniform2f(s.uniforms.texelSize, 1 / b, 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 / b, 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 $ = 0; $ < r.pressureIterations; $++)
    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 / b, 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, R)), 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, R)), 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, We[r.algorithm] ?? 0), e.activeTexture(e.TEXTURE0), e.bindTexture(e.TEXTURE_2D, t(this, y).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 Ge(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) });
  }
};
", fg = typeof window < "u" && window.Blob && new Blob([atob(Og)], { type: "text/javascript;charset=utf-8" });
669
- function AI() {
670
- let i;
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() {
675
+ let C;
671
676
  try {
672
- if (i = fg && (window.URL || window.webkitURL).createObjectURL(fg), !i)
677
+ if (C = FI && (window.URL || window.webkitURL).createObjectURL(FI), !C)
673
678
  throw "";
674
- return new Worker(i);
679
+ return new Worker(C);
675
680
  } catch {
676
- return new Worker("data:application/javascript;base64," + Og, { type: "module" });
681
+ return new Worker("data:application/javascript;base64," + zI, { type: "module" });
677
682
  } finally {
678
- i && (window.URL || window.webkitURL).revokeObjectURL(i);
683
+ C && (window.URL || window.webkitURL).revokeObjectURL(C);
679
684
  }
680
685
  }
681
- const uI = typeof Worker < "u" && typeof OffscreenCanvas < "u";
682
- var V, k, ag, Vg, Kg, zg;
683
- class rI {
684
- constructor(g, { isWorkerEnabled: C = !0, config: e = {} } = {}) {
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 = {} } = {}) {
685
690
  // ---------------------------------------------------------------------------
686
691
  // Private
687
692
  // ---------------------------------------------------------------------------
688
- u(this, Kg);
689
- u(this, V, null);
690
- u(this, k, null);
691
- u(this, ag, void 0);
692
- u(this, Vg, void 0);
693
- t(this, Vg, g), t(this, ag, C && uI), I(this, ag) ? p(this, Kg, zg).call(this, g, e) : t(this, k, new Fg(g, e));
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));
694
699
  }
695
700
  // ---------------------------------------------------------------------------
696
701
  // Source setters
697
702
  // ---------------------------------------------------------------------------
698
- setTextSource(g) {
699
- I(this, V) ? I(this, V).postMessage({ type: "setTextSource", opts: g }) : I(this, k).setTextSource(g);
703
+ setTextSource(I) {
704
+ g(this, p) ? g(this, p).postMessage({ type: "setTextSource", opts: I }) : g(this, k).setTextSource(I);
700
705
  }
701
- setImageSource(g, C = q.effect, e = q.imageSize) {
702
- if (I(this, V)) {
703
- const o = new URL(g, location.href).href;
704
- I(this, V).postMessage({ type: "setImageSource", src: o, effect: C, size: e });
706
+ setImageSource(I, i = q.effect, e = q.imageSize) {
707
+ 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 });
705
710
  } else
706
- I(this, k).setImageSource(g, C, e);
711
+ g(this, k).setImageSource(I, i, e);
707
712
  }
708
- setBackground(g, C = "cover") {
713
+ setBackground(I, i = "cover") {
709
714
  var e;
710
- if (I(this, V)) {
711
- const o = g ? [g] : [];
712
- I(this, V).postMessage({ type: "setBackground", bitmap: g ?? null, size: C }, o);
715
+ if (g(this, p)) {
716
+ const l = I ? [I] : [];
717
+ g(this, p).postMessage({ type: "setBackground", bitmap: I ?? null, size: i }, l);
713
718
  } else
714
- (e = I(this, k)) == null || e.setBackground(g ?? null, C);
719
+ (e = g(this, k)) == null || e.setBackground(I ?? null, i);
715
720
  }
716
721
  // ---------------------------------------------------------------------------
717
722
  // Interaction
@@ -720,270 +725,270 @@ class rI {
720
725
  * Immediately injects one splat at (x, y) with explicit velocity (vx, vy).
721
726
  * Safe to call multiple times per frame. See FluidSimulation.splat for details.
722
727
  */
723
- splat(g, C, e, o, s = 1) {
724
- I(this, V) ? I(this, V).postMessage({ type: "splat", x: g, y: C, vx: e, vy: o, strength: s }) : I(this, k).splat(g, C, e, o, s);
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);
725
730
  }
726
- handleMove(g, C, e = 1) {
727
- I(this, V) ? I(this, V).postMessage({ type: "move", x: g, y: C, strength: e }) : I(this, k).handleMove(g, C, e);
731
+ 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);
728
733
  }
729
734
  // ---------------------------------------------------------------------------
730
735
  // Config + control
731
736
  // ---------------------------------------------------------------------------
732
- updateConfig(g) {
733
- I(this, V) ? I(this, V).postMessage({ type: "updateConfig", config: g }) : I(this, k).updateConfig(g);
737
+ updateConfig(I) {
738
+ g(this, p) ? g(this, p).postMessage({ type: "updateConfig", config: I }) : g(this, k).updateConfig(I);
734
739
  }
735
- resize(g, C) {
736
- if (I(this, V)) {
740
+ resize(I, i) {
741
+ if (g(this, p)) {
737
742
  const e = typeof window < "u" && window.devicePixelRatio || 1;
738
- I(this, V).postMessage({ type: "resize", width: g, height: C, dpr: e });
743
+ g(this, p).postMessage({ type: "resize", width: I, height: i, dpr: e });
739
744
  } else
740
- I(this, k).resize(g, C);
745
+ g(this, k).resize(I, i);
741
746
  }
742
747
  destroy() {
743
- var g;
744
- if (I(this, V)) {
745
- const C = I(this, V);
746
- t(this, V, null), C.postMessage({ type: "destroy" }), setTimeout(() => C.terminate(), 50);
748
+ var I;
749
+ if (g(this, p)) {
750
+ const i = g(this, p);
751
+ o(this, p, null), i.postMessage({ type: "destroy" }), setTimeout(() => i.terminate(), 50);
747
752
  } else
748
- (g = I(this, k)) == null || g.destroy(), t(this, k, null);
753
+ (I = g(this, k)) == null || I.destroy(), o(this, k, null);
749
754
  }
750
755
  }
751
- V = new WeakMap(), k = new WeakMap(), ag = new WeakMap(), Vg = new WeakMap(), Kg = new WeakSet(), zg = function(g, C) {
752
- const e = typeof window < "u" && window.devicePixelRatio || 1, o = Math.round(g.clientWidth * e), s = Math.round(g.clientHeight * e);
753
- g.width = o, g.height = s;
754
- let l;
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;
759
+ let t;
755
760
  try {
756
- l = g.transferControlToOffscreen();
761
+ t = I.transferControlToOffscreen();
757
762
  } catch {
758
763
  console.warn(
759
764
  "[fluidity-js] OffscreenCanvas transfer failed — falling back to main-thread mode. This is expected in React StrictMode development."
760
- ), t(this, ag, !1), t(this, k, new Fg(g, C));
765
+ ), o(this, aI, !1), o(this, k, new fI(I, i));
761
766
  return;
762
767
  }
763
- const n = t(this, V, new AI());
764
- n.onerror = (r) => {
768
+ const m = o(this, p, new ng());
769
+ m.onerror = (r) => {
765
770
  console.error("[fluidity-js] Worker error:", r.message);
766
- }, n.onmessage = (r) => {
771
+ }, m.onmessage = (r) => {
767
772
  r.data.type === "error" && console.error("[fluidity-js] Simulation error:", r.data.message);
768
- }, n.postMessage({ type: "init", canvas: l, width: o, height: s, config: C, dpr: e }, [l]);
773
+ }, m.postMessage({ type: "init", canvas: t, width: l, height: s, config: i, dpr: e }, [t]);
769
774
  };
770
- function Ng(i, { isWorkerEnabled: g = !0, config: C = {} } = {}) {
771
- const e = Sg(null), o = Sg({ isWorkerEnabled: g, config: C });
772
- return N(() => {
773
- const s = i.current;
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;
774
779
  if (!s)
775
780
  return;
776
- const l = document.createElement("canvas");
777
- l.style.cssText = "position:absolute;inset:0;width:100%;height:100%;display:block;", s.appendChild(l);
778
- const n = window.devicePixelRatio || 1, r = s.getBoundingClientRect(), a = Math.round((r.width || s.clientWidth) * n) || 0, Z = Math.round((r.height || s.clientHeight) * n) || 0;
779
- a > 0 && (l.width = a, l.height = Z);
780
- const { isWorkerEnabled: h, config: A } = o.current, m = new rI(l, { isWorkerEnabled: h, config: A });
781
- e.current = m;
782
- const X = new ResizeObserver((Y) => {
783
- for (const w of Y) {
784
- const F = window.devicePixelRatio || 1, { inlineSize: c, blockSize: K } = w.contentBoxSize[0];
785
- m.resize(Math.round(c * F), Math.round(K * F));
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));
786
791
  }
787
792
  });
788
- return X.observe(s), () => {
789
- X.disconnect(), m.destroy(), l.remove(), e.current = null;
793
+ return v.observe(s), () => {
794
+ v.disconnect(), h.destroy(), t.remove(), e.current = null;
790
795
  };
791
796
  }, []), e;
792
797
  }
793
- const mI = xg(function({
794
- text: g,
795
- fontSize: C = j.fontSize,
798
+ const hg = xI(function({
799
+ text: I,
800
+ fontSize: i = j.fontSize,
796
801
  color: e = j.color,
797
- fontFamily: o = j.fontFamily,
802
+ fontFamily: l = j.fontFamily,
798
803
  fontWeight: s = j.fontWeight,
799
- className: l,
800
- style: n,
804
+ className: t,
805
+ style: m,
801
806
  config: r,
802
807
  preset: a,
803
- algorithm: Z,
804
- backgroundColor: h = j.backgroundColor,
808
+ algorithm: u,
809
+ backgroundColor: S = j.backgroundColor,
805
810
  backgroundSrc: A,
806
- backgroundSize: m = j.backgroundSize,
807
- isMouseEnabled: X = j.isMouseEnabled,
811
+ backgroundSize: h = j.backgroundSize,
812
+ isMouseEnabled: v = j.isMouseEnabled,
808
813
  isWorkerEnabled: Y = j.isWorkerEnabled
809
- }, w) {
810
- const F = Sg(null), c = Ng(F, {
814
+ }, K) {
815
+ const D = bI(null), c = OI(D, {
811
816
  isWorkerEnabled: Y,
812
- config: rg({ ...r, ...Z ? { algorithm: Z } : {} }, a, Hg)
817
+ config: uI({ ...r, ...u ? { algorithm: u } : {} }, a, kI)
813
818
  });
814
- Dg(
815
- w,
819
+ MI(
820
+ K,
816
821
  () => ({
817
822
  reset() {
818
823
  var d;
819
- (d = c.current) == null || d.setTextSource({ text: g, fontSize: C, color: e, fontFamily: o, fontWeight: s });
824
+ (d = c.current) == null || d.setTextSource({ text: I, fontSize: i, color: e, fontFamily: l, fontWeight: s });
820
825
  },
821
826
  move({ x: d, y: G, strength: L = 1 }) {
822
- var S;
823
- (S = c.current) == null || S.handleMove(d, G, L);
827
+ var B;
828
+ (B = c.current) == null || B.handleMove(d, G, L);
824
829
  },
825
- splat(d, G, L, S, x = 1) {
826
- var Q;
827
- (Q = c.current) == null || Q.splat(d, G, L, S, x);
830
+ splat(d, G, L, B, T = 1) {
831
+ var O;
832
+ (O = c.current) == null || O.splat(d, G, L, B, T);
828
833
  },
829
834
  updateConfig(d) {
830
835
  var G;
831
836
  (G = c.current) == null || G.updateConfig(d);
832
837
  }
833
838
  }),
834
- [g, C, e, o, s]
835
- ), N(() => {
839
+ [I, i, e, l, s]
840
+ ), Q(() => {
836
841
  var d;
837
- (d = c.current) == null || d.setTextSource({ text: g, fontSize: C, color: e, fontFamily: o, fontWeight: s });
838
- }, [g, C, e, o, s]);
839
- const K = JSON.stringify(r);
840
- return N(() => {
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(() => {
841
846
  var d;
842
847
  (d = c.current) == null || d.updateConfig(
843
- rg({ ...r, ...Z !== void 0 ? { algorithm: Z } : {} }, a, Hg)
848
+ uI({ ...r, ...u !== void 0 ? { algorithm: u } : {} }, a, kI)
844
849
  );
845
- }, [a, Z, K]), N(() => {
850
+ }, [a, u, w]), Q(() => {
846
851
  var G;
847
852
  if (!A) {
848
853
  (G = c.current) == null || G.setBackground(null);
849
854
  return;
850
855
  }
851
856
  let d = !1;
852
- return Xg(A).then((L) => {
853
- var S;
857
+ return XI(A).then((L) => {
858
+ var B;
854
859
  if (d) {
855
860
  L.close();
856
861
  return;
857
862
  }
858
- (S = c.current) == null || S.setBackground(L, m);
863
+ (B = c.current) == null || B.setBackground(L, h);
859
864
  }).catch((L) => console.error("[fluidity-js] backgroundSrc load failed:", L)), () => {
860
865
  d = !0;
861
866
  };
862
- }, [A, m]), N(() => {
863
- if (!X)
867
+ }, [A, h]), Q(() => {
868
+ if (!v)
864
869
  return;
865
- const d = F.current;
870
+ const d = D.current;
866
871
  if (!d)
867
872
  return;
868
- const G = (S) => {
869
- var Q;
870
- const x = d.getBoundingClientRect();
871
- (Q = c.current) == null || Q.handleMove(S.clientX - x.left, S.clientY - x.top, 2);
872
- }, L = (S) => {
873
- var Wg;
874
- S.preventDefault();
875
- const x = d.getBoundingClientRect(), Q = S.touches[0];
876
- (Wg = c.current) == null || Wg.handleMove(Q.clientX - x.left, Q.clientY - x.top, 1);
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);
877
882
  };
878
883
  return d.addEventListener("mousemove", G), d.addEventListener("touchmove", L, { passive: !1 }), () => {
879
884
  d.removeEventListener("mousemove", G), d.removeEventListener("touchmove", L);
880
885
  };
881
- }, [X]), /* @__PURE__ */ Tg(
886
+ }, [v]), /* @__PURE__ */ TI(
882
887
  "div",
883
888
  {
884
- ref: F,
885
- className: l,
889
+ ref: D,
890
+ className: t,
886
891
  style: {
887
892
  position: "relative",
888
893
  display: "block",
889
894
  width: "100%",
890
895
  height: "100%",
891
- background: h,
892
- ...n
896
+ background: S,
897
+ ...m
893
898
  }
894
899
  }
895
900
  );
896
- }), BI = xg(function({
897
- src: g,
898
- effect: C = q.effect,
901
+ }), Sg = xI(function({
902
+ src: I,
903
+ effect: i = q.effect,
899
904
  imageSize: e = q.imageSize,
900
- className: o,
905
+ className: l,
901
906
  style: s,
902
- config: l,
903
- preset: n,
907
+ config: t,
908
+ preset: m,
904
909
  algorithm: r,
905
910
  backgroundColor: a = q.backgroundColor,
906
- backgroundSrc: Z,
907
- backgroundSize: h = q.backgroundSize,
911
+ backgroundSrc: u,
912
+ backgroundSize: S = q.backgroundSize,
908
913
  isMouseEnabled: A = q.isMouseEnabled,
909
- isWorkerEnabled: m = q.isWorkerEnabled
910
- }, X) {
911
- const Y = Sg(null), w = Ng(Y, {
912
- isWorkerEnabled: m,
913
- config: rg({ ...l, ...r ? { algorithm: r } : {} }, n)
914
+ isWorkerEnabled: h = q.isWorkerEnabled
915
+ }, v) {
916
+ const Y = bI(null), K = OI(Y, {
917
+ isWorkerEnabled: h,
918
+ config: uI({ ...t, ...r ? { algorithm: r } : {} }, m)
914
919
  });
915
- Dg(
916
- X,
920
+ MI(
921
+ v,
917
922
  () => ({
918
923
  reset() {
919
924
  var c;
920
- g && ((c = w.current) == null || c.setImageSource(g, C, e));
925
+ I && ((c = K.current) == null || c.setImageSource(I, i, e));
921
926
  },
922
- move({ x: c, y: K, strength: d = 1 }) {
927
+ move({ x: c, y: w, strength: d = 1 }) {
923
928
  var G;
924
- (G = w.current) == null || G.handleMove(c, K, d);
929
+ (G = K.current) == null || G.handleMove(c, w, d);
925
930
  },
926
- splat(c, K, d, G, L = 1) {
927
- var S;
928
- (S = w.current) == null || S.splat(c, K, d, G, L);
931
+ splat(c, w, d, G, L = 1) {
932
+ var B;
933
+ (B = K.current) == null || B.splat(c, w, d, G, L);
929
934
  },
930
935
  updateConfig(c) {
931
- var K;
932
- (K = w.current) == null || K.updateConfig(c);
936
+ var w;
937
+ (w = K.current) == null || w.updateConfig(c);
933
938
  }
934
939
  }),
935
- [g, C, e]
936
- ), N(() => {
940
+ [I, i, e]
941
+ ), Q(() => {
937
942
  var c;
938
- g && ((c = w.current) == null || c.setImageSource(g, C, e));
939
- }, [g, C, e]);
940
- const F = JSON.stringify(l);
941
- return N(() => {
943
+ I && ((c = K.current) == null || c.setImageSource(I, i, e));
944
+ }, [I, i, e]);
945
+ const D = JSON.stringify(t);
946
+ return Q(() => {
942
947
  var c;
943
- (c = w.current) == null || c.updateConfig(
944
- rg({ ...l, ...r !== void 0 ? { algorithm: r } : {} }, n)
948
+ (c = K.current) == null || c.updateConfig(
949
+ uI({ ...t, ...r !== void 0 ? { algorithm: r } : {} }, m)
945
950
  );
946
- }, [n, r, F]), N(() => {
947
- var K;
948
- if (!Z) {
949
- (K = w.current) == null || K.setBackground(null);
951
+ }, [m, r, D]), Q(() => {
952
+ var w;
953
+ if (!u) {
954
+ (w = K.current) == null || w.setBackground(null);
950
955
  return;
951
956
  }
952
957
  let c = !1;
953
- return Xg(Z).then((d) => {
958
+ return XI(u).then((d) => {
954
959
  var G;
955
960
  if (c) {
956
961
  d.close();
957
962
  return;
958
963
  }
959
- (G = w.current) == null || G.setBackground(d, h);
964
+ (G = K.current) == null || G.setBackground(d, S);
960
965
  }).catch((d) => console.error("[fluidity-js] backgroundSrc load failed:", d)), () => {
961
966
  c = !0;
962
967
  };
963
- }, [Z, h]), N(() => {
968
+ }, [u, S]), Q(() => {
964
969
  if (!A)
965
970
  return;
966
971
  const c = Y.current;
967
972
  if (!c)
968
973
  return;
969
- const K = (G) => {
970
- var S;
974
+ const w = (G) => {
975
+ var B;
971
976
  const L = c.getBoundingClientRect();
972
- (S = w.current) == null || S.handleMove(G.clientX - L.left, G.clientY - L.top, 2);
977
+ (B = K.current) == null || B.handleMove(G.clientX - L.left, G.clientY - L.top, 2);
973
978
  }, d = (G) => {
974
- var x;
979
+ var T;
975
980
  G.preventDefault();
976
- const L = c.getBoundingClientRect(), S = G.touches[0];
977
- (x = w.current) == null || x.handleMove(S.clientX - L.left, S.clientY - L.top, 1);
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);
978
983
  };
979
- return c.addEventListener("mousemove", K), c.addEventListener("touchmove", d, { passive: !1 }), () => {
980
- c.removeEventListener("mousemove", K), c.removeEventListener("touchmove", d);
984
+ return c.addEventListener("mousemove", w), c.addEventListener("touchmove", d, { passive: !1 }), () => {
985
+ c.removeEventListener("mousemove", w), c.removeEventListener("touchmove", d);
981
986
  };
982
- }, [A]), /* @__PURE__ */ Tg(
987
+ }, [A]), /* @__PURE__ */ TI(
983
988
  "div",
984
989
  {
985
990
  ref: Y,
986
- className: o,
991
+ className: l,
987
992
  style: {
988
993
  position: "relative",
989
994
  display: "block",
@@ -996,17 +1001,17 @@ const mI = xg(function({
996
1001
  );
997
1002
  });
998
1003
  export {
999
- Mg as DEFAULT_CONFIG,
1000
- Hg as DEFAULT_CONFIG_TEXT,
1004
+ JI as DEFAULT_CONFIG,
1005
+ kI as DEFAULT_CONFIG_TEXT,
1001
1006
  q as DEFAULT_PROPS_IMAGE,
1002
- Jg as DEFAULT_PROPS_SHARED,
1007
+ EI as DEFAULT_PROPS_SHARED,
1003
1008
  j as DEFAULT_PROPS_TEXT,
1004
- rI as FluidController,
1005
- BI as FluidImage,
1006
- Fg as FluidSimulation,
1007
- mI as FluidText,
1008
- Pg as PRESETS,
1009
- Xg as loadImageBitmap,
1010
- rg as mergeConfig,
1011
- Ng as useFluid
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
1012
1017
  };