@jayf0x/fluidity-js 0.1.4 → 0.1.6

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

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

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

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

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

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

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

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

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

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

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

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

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