@dano796/react-reart 0.1.0
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/LICENSE.md +25 -0
- package/README.md +222 -0
- package/cli/build-registry.mjs +128 -0
- package/cli/index.js +396 -0
- package/cli/registry.json +873 -0
- package/dist/components/BackgroundStudio.d.ts +10 -0
- package/dist/components/BackgroundStudio.d.ts.map +1 -0
- package/dist/components/BackgroundStudio.js +268 -0
- package/dist/components/BackgroundStudio.js.map +1 -0
- package/dist/components/FlowCurrents.d.ts +24 -0
- package/dist/components/FlowCurrents.d.ts.map +1 -0
- package/dist/components/FlowCurrents.js +79 -0
- package/dist/components/FlowCurrents.js.map +1 -0
- package/dist/components/GeoPulse.d.ts +20 -0
- package/dist/components/GeoPulse.d.ts.map +1 -0
- package/dist/components/GeoPulse.js +72 -0
- package/dist/components/GeoPulse.js.map +1 -0
- package/dist/components/GravityStorm.d.ts +20 -0
- package/dist/components/GravityStorm.d.ts.map +1 -0
- package/dist/components/GravityStorm.js +72 -0
- package/dist/components/GravityStorm.js.map +1 -0
- package/dist/components/WaveEther.d.ts +21 -0
- package/dist/components/WaveEther.d.ts.map +1 -0
- package/dist/components/WaveEther.js +73 -0
- package/dist/components/WaveEther.js.map +1 -0
- package/dist/components/backgrounds/AmbientMesh.d.ts +38 -0
- package/dist/components/backgrounds/AmbientMesh.d.ts.map +1 -0
- package/dist/components/backgrounds/AmbientMesh.js +101 -0
- package/dist/components/backgrounds/AmbientMesh.js.map +1 -0
- package/dist/components/backgrounds/ArborealGrowth.d.ts +26 -0
- package/dist/components/backgrounds/ArborealGrowth.d.ts.map +1 -0
- package/dist/components/backgrounds/ArborealGrowth.js +78 -0
- package/dist/components/backgrounds/ArborealGrowth.js.map +1 -0
- package/dist/components/backgrounds/CliffordAttractor.d.ts +24 -0
- package/dist/components/backgrounds/CliffordAttractor.d.ts.map +1 -0
- package/dist/components/backgrounds/CliffordAttractor.js +86 -0
- package/dist/components/backgrounds/CliffordAttractor.js.map +1 -0
- package/dist/components/backgrounds/CrystallineDrift.d.ts +33 -0
- package/dist/components/backgrounds/CrystallineDrift.d.ts.map +1 -0
- package/dist/components/backgrounds/CrystallineDrift.js +101 -0
- package/dist/components/backgrounds/CrystallineDrift.js.map +1 -0
- package/dist/components/backgrounds/DifferentialGrowth.d.ts +9 -0
- package/dist/components/backgrounds/DifferentialGrowth.d.ts.map +1 -0
- package/dist/components/backgrounds/DifferentialGrowth.js +82 -0
- package/dist/components/backgrounds/DifferentialGrowth.js.map +1 -0
- package/dist/components/backgrounds/DoublePendulum.d.ts +9 -0
- package/dist/components/backgrounds/DoublePendulum.d.ts.map +1 -0
- package/dist/components/backgrounds/DoublePendulum.js +81 -0
- package/dist/components/backgrounds/DoublePendulum.js.map +1 -0
- package/dist/components/backgrounds/DragonCurve.d.ts +27 -0
- package/dist/components/backgrounds/DragonCurve.d.ts.map +1 -0
- package/dist/components/backgrounds/DragonCurve.js +79 -0
- package/dist/components/backgrounds/DragonCurve.js.map +1 -0
- package/dist/components/backgrounds/DragonFold.d.ts +31 -0
- package/dist/components/backgrounds/DragonFold.d.ts.map +1 -0
- package/dist/components/backgrounds/DragonFold.js +94 -0
- package/dist/components/backgrounds/DragonFold.js.map +1 -0
- package/dist/components/backgrounds/EmberCascade.d.ts +24 -0
- package/dist/components/backgrounds/EmberCascade.d.ts.map +1 -0
- package/dist/components/backgrounds/EmberCascade.js +88 -0
- package/dist/components/backgrounds/EmberCascade.js.map +1 -0
- package/dist/components/backgrounds/FibonacciVortex.d.ts +42 -0
- package/dist/components/backgrounds/FibonacciVortex.d.ts.map +1 -0
- package/dist/components/backgrounds/FibonacciVortex.js +151 -0
- package/dist/components/backgrounds/FibonacciVortex.js.map +1 -0
- package/dist/components/backgrounds/FlowCurrents.d.ts +35 -0
- package/dist/components/backgrounds/FlowCurrents.d.ts.map +1 -0
- package/dist/components/backgrounds/FlowCurrents.js +97 -0
- package/dist/components/backgrounds/FlowCurrents.js.map +1 -0
- package/dist/components/backgrounds/FractalNoiseTerrain.d.ts +9 -0
- package/dist/components/backgrounds/FractalNoiseTerrain.d.ts.map +1 -0
- package/dist/components/backgrounds/FractalNoiseTerrain.js +85 -0
- package/dist/components/backgrounds/FractalNoiseTerrain.js.map +1 -0
- package/dist/components/backgrounds/FractalTree.d.ts +35 -0
- package/dist/components/backgrounds/FractalTree.d.ts.map +1 -0
- package/dist/components/backgrounds/FractalTree.js +98 -0
- package/dist/components/backgrounds/FractalTree.js.map +1 -0
- package/dist/components/backgrounds/GeoPulse.d.ts +31 -0
- package/dist/components/backgrounds/GeoPulse.d.ts.map +1 -0
- package/dist/components/backgrounds/GeoPulse.js +89 -0
- package/dist/components/backgrounds/GeoPulse.js.map +1 -0
- package/dist/components/backgrounds/GravityStorm.d.ts +30 -0
- package/dist/components/backgrounds/GravityStorm.d.ts.map +1 -0
- package/dist/components/backgrounds/GravityStorm.js +89 -0
- package/dist/components/backgrounds/GravityStorm.js.map +1 -0
- package/dist/components/backgrounds/HarmonicLattice.d.ts +26 -0
- package/dist/components/backgrounds/HarmonicLattice.d.ts.map +1 -0
- package/dist/components/backgrounds/HarmonicLattice.js +89 -0
- package/dist/components/backgrounds/HarmonicLattice.js.map +1 -0
- package/dist/components/backgrounds/HexRipple.d.ts +44 -0
- package/dist/components/backgrounds/HexRipple.d.ts.map +1 -0
- package/dist/components/backgrounds/HexRipple.js +149 -0
- package/dist/components/backgrounds/HexRipple.js.map +1 -0
- package/dist/components/backgrounds/KochCrystal.d.ts +27 -0
- package/dist/components/backgrounds/KochCrystal.d.ts.map +1 -0
- package/dist/components/backgrounds/KochCrystal.js +79 -0
- package/dist/components/backgrounds/KochCrystal.js.map +1 -0
- package/dist/components/backgrounds/LissajousWeave.d.ts +23 -0
- package/dist/components/backgrounds/LissajousWeave.d.ts.map +1 -0
- package/dist/components/backgrounds/LissajousWeave.js +86 -0
- package/dist/components/backgrounds/LissajousWeave.js.map +1 -0
- package/dist/components/backgrounds/MoireLattice.d.ts +9 -0
- package/dist/components/backgrounds/MoireLattice.d.ts.map +1 -0
- package/dist/components/backgrounds/MoireLattice.js +81 -0
- package/dist/components/backgrounds/MoireLattice.js.map +1 -0
- package/dist/components/backgrounds/NebulaVeil.d.ts +28 -0
- package/dist/components/backgrounds/NebulaVeil.d.ts.map +1 -0
- package/dist/components/backgrounds/NebulaVeil.js +121 -0
- package/dist/components/backgrounds/NebulaVeil.js.map +1 -0
- package/dist/components/backgrounds/NeuralWeave.d.ts +9 -0
- package/dist/components/backgrounds/NeuralWeave.d.ts.map +1 -0
- package/dist/components/backgrounds/NeuralWeave.js +81 -0
- package/dist/components/backgrounds/NeuralWeave.js.map +1 -0
- package/dist/components/backgrounds/OrbitalResonance.d.ts +9 -0
- package/dist/components/backgrounds/OrbitalResonance.d.ts.map +1 -0
- package/dist/components/backgrounds/OrbitalResonance.js +86 -0
- package/dist/components/backgrounds/OrbitalResonance.js.map +1 -0
- package/dist/components/backgrounds/PhotonBurst.d.ts +41 -0
- package/dist/components/backgrounds/PhotonBurst.d.ts.map +1 -0
- package/dist/components/backgrounds/PhotonBurst.js +150 -0
- package/dist/components/backgrounds/PhotonBurst.js.map +1 -0
- package/dist/components/backgrounds/PhyllotaxisDream.d.ts +25 -0
- package/dist/components/backgrounds/PhyllotaxisDream.d.ts.map +1 -0
- package/dist/components/backgrounds/PhyllotaxisDream.js +88 -0
- package/dist/components/backgrounds/PhyllotaxisDream.js.map +1 -0
- package/dist/components/backgrounds/PlasmaField.d.ts +28 -0
- package/dist/components/backgrounds/PlasmaField.d.ts.map +1 -0
- package/dist/components/backgrounds/PlasmaField.js +117 -0
- package/dist/components/backgrounds/PlasmaField.js.map +1 -0
- package/dist/components/backgrounds/PrismaticWave.d.ts +46 -0
- package/dist/components/backgrounds/PrismaticWave.d.ts.map +1 -0
- package/dist/components/backgrounds/PrismaticWave.js +152 -0
- package/dist/components/backgrounds/PrismaticWave.js.map +1 -0
- package/dist/components/backgrounds/ReactionDiffusion.d.ts +9 -0
- package/dist/components/backgrounds/ReactionDiffusion.d.ts.map +1 -0
- package/dist/components/backgrounds/ReactionDiffusion.js +79 -0
- package/dist/components/backgrounds/ReactionDiffusion.js.map +1 -0
- package/dist/components/backgrounds/RecursiveSubdivision.d.ts +9 -0
- package/dist/components/backgrounds/RecursiveSubdivision.d.ts.map +1 -0
- package/dist/components/backgrounds/RecursiveSubdivision.js +84 -0
- package/dist/components/backgrounds/RecursiveSubdivision.js.map +1 -0
- package/dist/components/backgrounds/RecursiveTunnel.d.ts +44 -0
- package/dist/components/backgrounds/RecursiveTunnel.d.ts.map +1 -0
- package/dist/components/backgrounds/RecursiveTunnel.js +155 -0
- package/dist/components/backgrounds/RecursiveTunnel.js.map +1 -0
- package/dist/components/backgrounds/SierpinskiChaos.d.ts +32 -0
- package/dist/components/backgrounds/SierpinskiChaos.d.ts.map +1 -0
- package/dist/components/backgrounds/SierpinskiChaos.js +95 -0
- package/dist/components/backgrounds/SierpinskiChaos.js.map +1 -0
- package/dist/components/backgrounds/SierpinskiDust.d.ts +47 -0
- package/dist/components/backgrounds/SierpinskiDust.d.ts.map +1 -0
- package/dist/components/backgrounds/SierpinskiDust.js +148 -0
- package/dist/components/backgrounds/SierpinskiDust.js.map +1 -0
- package/dist/components/backgrounds/Spirograph.d.ts +24 -0
- package/dist/components/backgrounds/Spirograph.d.ts.map +1 -0
- package/dist/components/backgrounds/Spirograph.js +86 -0
- package/dist/components/backgrounds/Spirograph.js.map +1 -0
- package/dist/components/backgrounds/TideHarmonics.d.ts +9 -0
- package/dist/components/backgrounds/TideHarmonics.d.ts.map +1 -0
- package/dist/components/backgrounds/TideHarmonics.js +80 -0
- package/dist/components/backgrounds/TideHarmonics.js.map +1 -0
- package/dist/components/backgrounds/VoronoiMosaic.d.ts +9 -0
- package/dist/components/backgrounds/VoronoiMosaic.d.ts.map +1 -0
- package/dist/components/backgrounds/VoronoiMosaic.js +76 -0
- package/dist/components/backgrounds/VoronoiMosaic.js.map +1 -0
- package/dist/components/backgrounds/VortexBloom.d.ts +36 -0
- package/dist/components/backgrounds/VortexBloom.d.ts.map +1 -0
- package/dist/components/backgrounds/VortexBloom.js +101 -0
- package/dist/components/backgrounds/VortexBloom.js.map +1 -0
- package/dist/components/backgrounds/WaveEther.d.ts +32 -0
- package/dist/components/backgrounds/WaveEther.d.ts.map +1 -0
- package/dist/components/backgrounds/WaveEther.js +91 -0
- package/dist/components/backgrounds/WaveEther.js.map +1 -0
- package/dist/components/backgrounds/archived/CliffordAttractor.d.ts +24 -0
- package/dist/components/backgrounds/archived/CliffordAttractor.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/CliffordAttractor.js +86 -0
- package/dist/components/backgrounds/archived/CliffordAttractor.js.map +1 -0
- package/dist/components/backgrounds/archived/CrystallineDrift.d.ts +33 -0
- package/dist/components/backgrounds/archived/CrystallineDrift.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/CrystallineDrift.js +101 -0
- package/dist/components/backgrounds/archived/CrystallineDrift.js.map +1 -0
- package/dist/components/backgrounds/archived/DifferentialGrowth.d.ts +9 -0
- package/dist/components/backgrounds/archived/DifferentialGrowth.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/DifferentialGrowth.js +82 -0
- package/dist/components/backgrounds/archived/DifferentialGrowth.js.map +1 -0
- package/dist/components/backgrounds/archived/DoublePendulum.d.ts +9 -0
- package/dist/components/backgrounds/archived/DoublePendulum.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/DoublePendulum.js +81 -0
- package/dist/components/backgrounds/archived/DoublePendulum.js.map +1 -0
- package/dist/components/backgrounds/archived/EmberCascade.d.ts +24 -0
- package/dist/components/backgrounds/archived/EmberCascade.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/EmberCascade.js +88 -0
- package/dist/components/backgrounds/archived/EmberCascade.js.map +1 -0
- package/dist/components/backgrounds/archived/GravityStorm.d.ts +30 -0
- package/dist/components/backgrounds/archived/GravityStorm.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/GravityStorm.js +89 -0
- package/dist/components/backgrounds/archived/GravityStorm.js.map +1 -0
- package/dist/components/backgrounds/archived/ReactionDiffusion.d.ts +9 -0
- package/dist/components/backgrounds/archived/ReactionDiffusion.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/ReactionDiffusion.js +79 -0
- package/dist/components/backgrounds/archived/ReactionDiffusion.js.map +1 -0
- package/dist/components/backgrounds/archived/Spirograph.d.ts +24 -0
- package/dist/components/backgrounds/archived/Spirograph.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/Spirograph.js +86 -0
- package/dist/components/backgrounds/archived/Spirograph.js.map +1 -0
- package/dist/components/backgrounds/archived/VortexBloom.d.ts +36 -0
- package/dist/components/backgrounds/archived/VortexBloom.d.ts.map +1 -0
- package/dist/components/backgrounds/archived/VortexBloom.js +101 -0
- package/dist/components/backgrounds/archived/VortexBloom.js.map +1 -0
- package/dist/components/engines/ambientMesh.d.ts +31 -0
- package/dist/components/engines/ambientMesh.d.ts.map +1 -0
- package/dist/components/engines/ambientMesh.js +123 -0
- package/dist/components/engines/ambientMesh.js.map +1 -0
- package/dist/components/engines/arborealGrowth.d.ts +49 -0
- package/dist/components/engines/arborealGrowth.d.ts.map +1 -0
- package/dist/components/engines/arborealGrowth.js +220 -0
- package/dist/components/engines/arborealGrowth.js.map +1 -0
- package/dist/components/engines/archived/cliffordAttractor.d.ts +31 -0
- package/dist/components/engines/archived/cliffordAttractor.d.ts.map +1 -0
- package/dist/components/engines/archived/cliffordAttractor.js +71 -0
- package/dist/components/engines/archived/cliffordAttractor.js.map +1 -0
- package/dist/components/engines/archived/crystallineDrift.d.ts +31 -0
- package/dist/components/engines/archived/crystallineDrift.d.ts.map +1 -0
- package/dist/components/engines/archived/crystallineDrift.js +117 -0
- package/dist/components/engines/archived/crystallineDrift.js.map +1 -0
- package/dist/components/engines/archived/differentialGrowth.d.ts +39 -0
- package/dist/components/engines/archived/differentialGrowth.d.ts.map +1 -0
- package/dist/components/engines/archived/differentialGrowth.js +139 -0
- package/dist/components/engines/archived/differentialGrowth.js.map +1 -0
- package/dist/components/engines/archived/doublePendulum.d.ts +41 -0
- package/dist/components/engines/archived/doublePendulum.d.ts.map +1 -0
- package/dist/components/engines/archived/doublePendulum.js +97 -0
- package/dist/components/engines/archived/doublePendulum.js.map +1 -0
- package/dist/components/engines/archived/emberCascade.d.ts +45 -0
- package/dist/components/engines/archived/emberCascade.d.ts.map +1 -0
- package/dist/components/engines/archived/emberCascade.js +137 -0
- package/dist/components/engines/archived/emberCascade.js.map +1 -0
- package/dist/components/engines/archived/gravityStorm.d.ts +39 -0
- package/dist/components/engines/archived/gravityStorm.d.ts.map +1 -0
- package/dist/components/engines/archived/gravityStorm.js +124 -0
- package/dist/components/engines/archived/gravityStorm.js.map +1 -0
- package/dist/components/engines/archived/reactionDiffusion.d.ts +32 -0
- package/dist/components/engines/archived/reactionDiffusion.d.ts.map +1 -0
- package/dist/components/engines/archived/reactionDiffusion.js +99 -0
- package/dist/components/engines/archived/reactionDiffusion.js.map +1 -0
- package/dist/components/engines/archived/spirograph.d.ts +31 -0
- package/dist/components/engines/archived/spirograph.d.ts.map +1 -0
- package/dist/components/engines/archived/spirograph.js +82 -0
- package/dist/components/engines/archived/spirograph.js.map +1 -0
- package/dist/components/engines/archived/vortexBloom.d.ts +49 -0
- package/dist/components/engines/archived/vortexBloom.d.ts.map +1 -0
- package/dist/components/engines/archived/vortexBloom.js +151 -0
- package/dist/components/engines/archived/vortexBloom.js.map +1 -0
- package/dist/components/engines/cliffordAttractor.d.ts +31 -0
- package/dist/components/engines/cliffordAttractor.d.ts.map +1 -0
- package/dist/components/engines/cliffordAttractor.js +71 -0
- package/dist/components/engines/cliffordAttractor.js.map +1 -0
- package/dist/components/engines/crystallineDrift.d.ts +31 -0
- package/dist/components/engines/crystallineDrift.d.ts.map +1 -0
- package/dist/components/engines/crystallineDrift.js +117 -0
- package/dist/components/engines/crystallineDrift.js.map +1 -0
- package/dist/components/engines/differentialGrowth.d.ts +39 -0
- package/dist/components/engines/differentialGrowth.d.ts.map +1 -0
- package/dist/components/engines/differentialGrowth.js +139 -0
- package/dist/components/engines/differentialGrowth.js.map +1 -0
- package/dist/components/engines/doublePendulum.d.ts +41 -0
- package/dist/components/engines/doublePendulum.d.ts.map +1 -0
- package/dist/components/engines/doublePendulum.js +97 -0
- package/dist/components/engines/doublePendulum.js.map +1 -0
- package/dist/components/engines/dragonCurve.d.ts +46 -0
- package/dist/components/engines/dragonCurve.d.ts.map +1 -0
- package/dist/components/engines/dragonCurve.js +178 -0
- package/dist/components/engines/dragonCurve.js.map +1 -0
- package/dist/components/engines/dragonFold.d.ts +28 -0
- package/dist/components/engines/dragonFold.d.ts.map +1 -0
- package/dist/components/engines/dragonFold.js +166 -0
- package/dist/components/engines/dragonFold.js.map +1 -0
- package/dist/components/engines/emberCascade.d.ts +45 -0
- package/dist/components/engines/emberCascade.d.ts.map +1 -0
- package/dist/components/engines/emberCascade.js +137 -0
- package/dist/components/engines/emberCascade.js.map +1 -0
- package/dist/components/engines/fibonacciVortex.d.ts +70 -0
- package/dist/components/engines/fibonacciVortex.d.ts.map +1 -0
- package/dist/components/engines/fibonacciVortex.js +144 -0
- package/dist/components/engines/fibonacciVortex.js.map +1 -0
- package/dist/components/engines/flowCurrents.d.ts +34 -0
- package/dist/components/engines/flowCurrents.d.ts.map +1 -0
- package/dist/components/engines/flowCurrents.js +89 -0
- package/dist/components/engines/flowCurrents.js.map +1 -0
- package/dist/components/engines/fractalNoiseTerrain.d.ts +32 -0
- package/dist/components/engines/fractalNoiseTerrain.d.ts.map +1 -0
- package/dist/components/engines/fractalNoiseTerrain.js +89 -0
- package/dist/components/engines/fractalNoiseTerrain.js.map +1 -0
- package/dist/components/engines/fractalTree.d.ts +20 -0
- package/dist/components/engines/fractalTree.d.ts.map +1 -0
- package/dist/components/engines/fractalTree.js +92 -0
- package/dist/components/engines/fractalTree.js.map +1 -0
- package/dist/components/engines/geoPulse.d.ts +33 -0
- package/dist/components/engines/geoPulse.d.ts.map +1 -0
- package/dist/components/engines/geoPulse.js +116 -0
- package/dist/components/engines/geoPulse.js.map +1 -0
- package/dist/components/engines/gravityStorm.d.ts +39 -0
- package/dist/components/engines/gravityStorm.d.ts.map +1 -0
- package/dist/components/engines/gravityStorm.js +124 -0
- package/dist/components/engines/gravityStorm.js.map +1 -0
- package/dist/components/engines/harmonicLattice.d.ts +38 -0
- package/dist/components/engines/harmonicLattice.d.ts.map +1 -0
- package/dist/components/engines/harmonicLattice.js +87 -0
- package/dist/components/engines/harmonicLattice.js.map +1 -0
- package/dist/components/engines/hexRipple.d.ts +61 -0
- package/dist/components/engines/hexRipple.d.ts.map +1 -0
- package/dist/components/engines/hexRipple.js +157 -0
- package/dist/components/engines/hexRipple.js.map +1 -0
- package/dist/components/engines/kochCrystal.d.ts +47 -0
- package/dist/components/engines/kochCrystal.d.ts.map +1 -0
- package/dist/components/engines/kochCrystal.js +177 -0
- package/dist/components/engines/kochCrystal.js.map +1 -0
- package/dist/components/engines/lissajousWeave.d.ts +38 -0
- package/dist/components/engines/lissajousWeave.d.ts.map +1 -0
- package/dist/components/engines/lissajousWeave.js +83 -0
- package/dist/components/engines/lissajousWeave.js.map +1 -0
- package/dist/components/engines/moireLattice.d.ts +28 -0
- package/dist/components/engines/moireLattice.d.ts.map +1 -0
- package/dist/components/engines/moireLattice.js +47 -0
- package/dist/components/engines/moireLattice.js.map +1 -0
- package/dist/components/engines/nebulaVeil.d.ts +38 -0
- package/dist/components/engines/nebulaVeil.d.ts.map +1 -0
- package/dist/components/engines/nebulaVeil.js +177 -0
- package/dist/components/engines/nebulaVeil.js.map +1 -0
- package/dist/components/engines/neuralWeave.d.ts +53 -0
- package/dist/components/engines/neuralWeave.d.ts.map +1 -0
- package/dist/components/engines/neuralWeave.js +165 -0
- package/dist/components/engines/neuralWeave.js.map +1 -0
- package/dist/components/engines/orbitalResonance.d.ts +50 -0
- package/dist/components/engines/orbitalResonance.d.ts.map +1 -0
- package/dist/components/engines/orbitalResonance.js +94 -0
- package/dist/components/engines/orbitalResonance.js.map +1 -0
- package/dist/components/engines/photonBurst.d.ts +43 -0
- package/dist/components/engines/photonBurst.d.ts.map +1 -0
- package/dist/components/engines/photonBurst.js +204 -0
- package/dist/components/engines/photonBurst.js.map +1 -0
- package/dist/components/engines/phyllotaxisDream.d.ts +28 -0
- package/dist/components/engines/phyllotaxisDream.d.ts.map +1 -0
- package/dist/components/engines/phyllotaxisDream.js +75 -0
- package/dist/components/engines/phyllotaxisDream.js.map +1 -0
- package/dist/components/engines/plasmaField.d.ts +44 -0
- package/dist/components/engines/plasmaField.d.ts.map +1 -0
- package/dist/components/engines/plasmaField.js +227 -0
- package/dist/components/engines/plasmaField.js.map +1 -0
- package/dist/components/engines/prismaticWave.d.ts +39 -0
- package/dist/components/engines/prismaticWave.d.ts.map +1 -0
- package/dist/components/engines/prismaticWave.js +158 -0
- package/dist/components/engines/prismaticWave.js.map +1 -0
- package/dist/components/engines/reactionDiffusion.d.ts +32 -0
- package/dist/components/engines/reactionDiffusion.d.ts.map +1 -0
- package/dist/components/engines/reactionDiffusion.js +99 -0
- package/dist/components/engines/reactionDiffusion.js.map +1 -0
- package/dist/components/engines/recursiveSubdivision.d.ts +40 -0
- package/dist/components/engines/recursiveSubdivision.d.ts.map +1 -0
- package/dist/components/engines/recursiveSubdivision.js +133 -0
- package/dist/components/engines/recursiveSubdivision.js.map +1 -0
- package/dist/components/engines/recursiveTunnel.d.ts +66 -0
- package/dist/components/engines/recursiveTunnel.d.ts.map +1 -0
- package/dist/components/engines/recursiveTunnel.js +152 -0
- package/dist/components/engines/recursiveTunnel.js.map +1 -0
- package/dist/components/engines/sierpinskiChaos.d.ts +41 -0
- package/dist/components/engines/sierpinskiChaos.d.ts.map +1 -0
- package/dist/components/engines/sierpinskiChaos.js +118 -0
- package/dist/components/engines/sierpinskiChaos.js.map +1 -0
- package/dist/components/engines/sierpinskiDust.d.ts +72 -0
- package/dist/components/engines/sierpinskiDust.d.ts.map +1 -0
- package/dist/components/engines/sierpinskiDust.js +152 -0
- package/dist/components/engines/sierpinskiDust.js.map +1 -0
- package/dist/components/engines/spirograph.d.ts +31 -0
- package/dist/components/engines/spirograph.d.ts.map +1 -0
- package/dist/components/engines/spirograph.js +82 -0
- package/dist/components/engines/spirograph.js.map +1 -0
- package/dist/components/engines/tideHarmonics.d.ts +37 -0
- package/dist/components/engines/tideHarmonics.d.ts.map +1 -0
- package/dist/components/engines/tideHarmonics.js +71 -0
- package/dist/components/engines/tideHarmonics.js.map +1 -0
- package/dist/components/engines/voronoiMosaic.d.ts +37 -0
- package/dist/components/engines/voronoiMosaic.d.ts.map +1 -0
- package/dist/components/engines/voronoiMosaic.js +130 -0
- package/dist/components/engines/voronoiMosaic.js.map +1 -0
- package/dist/components/engines/vortexBloom.d.ts +49 -0
- package/dist/components/engines/vortexBloom.d.ts.map +1 -0
- package/dist/components/engines/vortexBloom.js +151 -0
- package/dist/components/engines/vortexBloom.js.map +1 -0
- package/dist/components/engines/waveEther.d.ts +30 -0
- package/dist/components/engines/waveEther.d.ts.map +1 -0
- package/dist/components/engines/waveEther.js +74 -0
- package/dist/components/engines/waveEther.js.map +1 -0
- package/dist/components/schemas/index.d.ts +131 -0
- package/dist/components/schemas/index.d.ts.map +1 -0
- package/dist/components/schemas/index.js +478 -0
- package/dist/components/schemas/index.js.map +1 -0
- package/dist/components/utils/noise.d.ts +38 -0
- package/dist/components/utils/noise.d.ts.map +1 -0
- package/dist/components/utils/noise.js +132 -0
- package/dist/components/utils/noise.js.map +1 -0
- package/dist/engines/flowCurrents.d.ts +34 -0
- package/dist/engines/flowCurrents.d.ts.map +1 -0
- package/dist/engines/flowCurrents.js +89 -0
- package/dist/engines/flowCurrents.js.map +1 -0
- package/dist/engines/geoPulse.d.ts +33 -0
- package/dist/engines/geoPulse.d.ts.map +1 -0
- package/dist/engines/geoPulse.js +116 -0
- package/dist/engines/geoPulse.js.map +1 -0
- package/dist/engines/gravityStorm.d.ts +39 -0
- package/dist/engines/gravityStorm.d.ts.map +1 -0
- package/dist/engines/gravityStorm.js +124 -0
- package/dist/engines/gravityStorm.js.map +1 -0
- package/dist/engines/waveEther.d.ts +30 -0
- package/dist/engines/waveEther.d.ts.map +1 -0
- package/dist/engines/waveEther.js +74 -0
- package/dist/engines/waveEther.js.map +1 -0
- package/dist/index.d.ts +46 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +138 -0
- package/dist/index.js.map +1 -0
- package/dist/registry/index.d.ts +59 -0
- package/dist/registry/index.d.ts.map +1 -0
- package/dist/registry/index.js +669 -0
- package/dist/registry/index.js.map +1 -0
- package/dist/schemas/index.d.ts +93 -0
- package/dist/schemas/index.d.ts.map +1 -0
- package/dist/schemas/index.js +83 -0
- package/dist/schemas/index.js.map +1 -0
- package/dist/utils/noise.d.ts +37 -0
- package/dist/utils/noise.d.ts.map +1 -0
- package/dist/utils/noise.js +129 -0
- package/dist/utils/noise.js.map +1 -0
- package/package.json +68 -0
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Koch Crystal engine — Koch snowflake fractal background.
|
|
3
|
+
*
|
|
4
|
+
* L-System:
|
|
5
|
+
* Axiom: F++F++F (equilateral triangle)
|
|
6
|
+
* Rule: F → F-F++F-F
|
|
7
|
+
* Angle: 60°
|
|
8
|
+
*
|
|
9
|
+
* Net triangle side stays constant at ~60% of min(width, height) across all
|
|
10
|
+
* depths (step = side / 3^depth), so the snowflake always fits the canvas.
|
|
11
|
+
* After drawing completes the canvas fades and a new generation starts with
|
|
12
|
+
* the snowflake rotated 10° for visual variety.
|
|
13
|
+
*/
|
|
14
|
+
import { SeededRandom, hexToRgb, lerp, rgba } from "../utils/noise";
|
|
15
|
+
export const kochCrystalDefaults = {
|
|
16
|
+
seed: 1234,
|
|
17
|
+
maxDepth: 4,
|
|
18
|
+
noiseAmt: 0.04,
|
|
19
|
+
growSpeed: 60,
|
|
20
|
+
glowIntensity: 0.8,
|
|
21
|
+
bgColor: "#030819",
|
|
22
|
+
innerColor: "#122898",
|
|
23
|
+
outerColor: "#6a9bcc",
|
|
24
|
+
glowColor: "#c4e0ff",
|
|
25
|
+
};
|
|
26
|
+
const HOLD_FRAMES = 180;
|
|
27
|
+
const FADE_FRAMES = 80;
|
|
28
|
+
// ── L-System ──────────────────────────────────────────────────────────────────
|
|
29
|
+
function expandKoch(depth) {
|
|
30
|
+
let s = "F++F++F";
|
|
31
|
+
for (let i = 0; i < depth; i++) {
|
|
32
|
+
let next = "";
|
|
33
|
+
for (const ch of s) {
|
|
34
|
+
if (ch === "F")
|
|
35
|
+
next += "F-F++F-F";
|
|
36
|
+
else
|
|
37
|
+
next += ch;
|
|
38
|
+
}
|
|
39
|
+
s = next;
|
|
40
|
+
if (s.length > 200000)
|
|
41
|
+
break;
|
|
42
|
+
}
|
|
43
|
+
return s;
|
|
44
|
+
}
|
|
45
|
+
function interpretKoch(lstr, sx, sy, startAngleDeg, step, noiseAmt, rng) {
|
|
46
|
+
const segs = [];
|
|
47
|
+
let x = sx, y = sy, a = startAngleDeg;
|
|
48
|
+
for (const ch of lstr) {
|
|
49
|
+
if (ch === "F") {
|
|
50
|
+
// Slight noise warp for organic feel
|
|
51
|
+
const na = a + (rng.random() - 0.5) * noiseAmt * 60 * 2;
|
|
52
|
+
const nx = x + step * Math.cos((na * Math.PI) / 180);
|
|
53
|
+
const ny = y + step * Math.sin((na * Math.PI) / 180);
|
|
54
|
+
segs.push({ x1: x, y1: y, x2: nx, y2: ny, idx: segs.length });
|
|
55
|
+
x = nx;
|
|
56
|
+
y = ny;
|
|
57
|
+
}
|
|
58
|
+
else if (ch === "+") {
|
|
59
|
+
a += 60;
|
|
60
|
+
}
|
|
61
|
+
else if (ch === "-") {
|
|
62
|
+
a -= 60;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return segs;
|
|
66
|
+
}
|
|
67
|
+
function buildSnowflake(width, height, p, rotOffset) {
|
|
68
|
+
const rng = new SeededRandom(p.seed);
|
|
69
|
+
const lstr = expandKoch(p.maxDepth);
|
|
70
|
+
// Net triangle side S stays fixed: step = S / 3^depth
|
|
71
|
+
const S = Math.min(width, height) * 0.58;
|
|
72
|
+
const step = S / Math.pow(3, p.maxDepth);
|
|
73
|
+
// Place triangle so its centroid lands at canvas center.
|
|
74
|
+
// Triangle verts (starting east, downward-pointing in canvas coords):
|
|
75
|
+
// V1=(sx, sy), V2=(sx+S, sy), V3=(sx+S/2, sy + S*√3/2)
|
|
76
|
+
// Centroid: (sx+S/2, sy + S*√3/6) → sy = cy - S*√3/6
|
|
77
|
+
const sx = width / 2 - S / 2;
|
|
78
|
+
const sy = height / 2 - S * 0.2887; // √3/6 ≈ 0.2887
|
|
79
|
+
return interpretKoch(lstr, sx, sy, rotOffset, step, p.noiseAmt, rng);
|
|
80
|
+
}
|
|
81
|
+
// ── Public API ────────────────────────────────────────────────────────────────
|
|
82
|
+
export function initKochCrystal(width, height, params = {}) {
|
|
83
|
+
const p = { ...kochCrystalDefaults, ...params };
|
|
84
|
+
const segs = buildSnowflake(width, height, p, 0);
|
|
85
|
+
return {
|
|
86
|
+
segs,
|
|
87
|
+
drawIdx: 0,
|
|
88
|
+
phase: "drawing",
|
|
89
|
+
holdFrames: HOLD_FRAMES,
|
|
90
|
+
fadeAlpha: 0,
|
|
91
|
+
genRot: 0,
|
|
92
|
+
width,
|
|
93
|
+
height,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
export function drawKochCrystal(ctx, state, params = {}) {
|
|
97
|
+
const p = { ...kochCrystalDefaults, ...params };
|
|
98
|
+
const { segs, width, height } = state;
|
|
99
|
+
if (state.phase === "drawing") {
|
|
100
|
+
const innerC = hexToRgb(p.innerColor);
|
|
101
|
+
const outerC = hexToRgb(p.outerColor);
|
|
102
|
+
const glowC = hexToRgb(p.glowColor);
|
|
103
|
+
const total = segs.length;
|
|
104
|
+
const gi = p.glowIntensity;
|
|
105
|
+
const end = Math.min(state.drawIdx + p.growSpeed, total);
|
|
106
|
+
ctx.lineCap = "round";
|
|
107
|
+
for (let i = state.drawIdx; i < end; i++) {
|
|
108
|
+
const seg = segs[i];
|
|
109
|
+
const t = total > 1 ? seg.idx / (total - 1) : 0;
|
|
110
|
+
const r = lerp(innerC.r, outerC.r, t);
|
|
111
|
+
const g = lerp(innerC.g, outerC.g, t);
|
|
112
|
+
const b = lerp(innerC.b, outerC.b, t);
|
|
113
|
+
const sw = Math.max(0.4, lerp(2.2, 0.55, t));
|
|
114
|
+
if (gi > 0) {
|
|
115
|
+
// Outer diffuse halo (uses glowColor for cooler tint)
|
|
116
|
+
ctx.strokeStyle = rgba(glowC.r, glowC.g, glowC.b, Math.round(9 * gi));
|
|
117
|
+
ctx.lineWidth = sw * 9;
|
|
118
|
+
ctx.beginPath();
|
|
119
|
+
ctx.moveTo(seg.x1, seg.y1);
|
|
120
|
+
ctx.lineTo(seg.x2, seg.y2);
|
|
121
|
+
ctx.stroke();
|
|
122
|
+
// Mid glow in segment color
|
|
123
|
+
ctx.strokeStyle = rgba(r, g, b, Math.round(38 * gi));
|
|
124
|
+
ctx.lineWidth = sw * 3.2;
|
|
125
|
+
ctx.beginPath();
|
|
126
|
+
ctx.moveTo(seg.x1, seg.y1);
|
|
127
|
+
ctx.lineTo(seg.x2, seg.y2);
|
|
128
|
+
ctx.stroke();
|
|
129
|
+
}
|
|
130
|
+
ctx.strokeStyle = rgba(r, g, b, 218);
|
|
131
|
+
ctx.lineWidth = sw;
|
|
132
|
+
ctx.beginPath();
|
|
133
|
+
ctx.moveTo(seg.x1, seg.y1);
|
|
134
|
+
ctx.lineTo(seg.x2, seg.y2);
|
|
135
|
+
ctx.stroke();
|
|
136
|
+
}
|
|
137
|
+
state.drawIdx = end;
|
|
138
|
+
if (state.drawIdx >= segs.length) {
|
|
139
|
+
state.phase = "holding";
|
|
140
|
+
state.holdFrames = HOLD_FRAMES;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
else if (state.phase === "holding") {
|
|
144
|
+
state.holdFrames--;
|
|
145
|
+
if (state.holdFrames <= 0) {
|
|
146
|
+
state.phase = "fading";
|
|
147
|
+
state.fadeAlpha = 0;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
else if (state.phase === "fading") {
|
|
151
|
+
state.fadeAlpha += 255 / FADE_FRAMES;
|
|
152
|
+
const bg = hexToRgb(p.bgColor);
|
|
153
|
+
ctx.fillStyle = rgba(bg.r, bg.g, bg.b, Math.min(255, Math.round(state.fadeAlpha)));
|
|
154
|
+
ctx.fillRect(0, 0, width, height);
|
|
155
|
+
if (state.fadeAlpha >= 255) {
|
|
156
|
+
state.phase = "resetting";
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
else if (state.phase === "resetting") {
|
|
160
|
+
// Rotate 10° each generation so the snowflake slowly pirouettes
|
|
161
|
+
state.genRot = (state.genRot + 10) % 360;
|
|
162
|
+
state.segs = buildSnowflake(width, height, p, state.genRot);
|
|
163
|
+
state.drawIdx = 0;
|
|
164
|
+
state.phase = "drawing";
|
|
165
|
+
const bg = hexToRgb(p.bgColor);
|
|
166
|
+
ctx.fillStyle = `rgb(${bg.r},${bg.g},${bg.b})`;
|
|
167
|
+
ctx.fillRect(0, 0, width, height);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
export function resetKochCrystal(ctx, state, params = {}) {
|
|
171
|
+
const p = { ...kochCrystalDefaults, ...params };
|
|
172
|
+
const bg = hexToRgb(p.bgColor);
|
|
173
|
+
ctx.fillStyle = `rgb(${bg.r},${bg.g},${bg.b})`;
|
|
174
|
+
ctx.fillRect(0, 0, state.width, state.height);
|
|
175
|
+
return initKochCrystal(state.width, state.height, p);
|
|
176
|
+
}
|
|
177
|
+
//# sourceMappingURL=kochCrystal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kochCrystal.js","sourceRoot":"","sources":["../../../src/components/engines/kochCrystal.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Lissajous Weave Engine
|
|
3
|
+
* Harmonic phase tapestry with multiple frequency ratios
|
|
4
|
+
*/
|
|
5
|
+
import { SeededRandom } from "../utils/noise";
|
|
6
|
+
export interface LissajousWeaveParams {
|
|
7
|
+
seed: number;
|
|
8
|
+
curveCount: number;
|
|
9
|
+
freqMax: number;
|
|
10
|
+
radius: number;
|
|
11
|
+
phaseSpeed: number;
|
|
12
|
+
bgColor: string;
|
|
13
|
+
colorA: string;
|
|
14
|
+
colorB: string;
|
|
15
|
+
colorC: string;
|
|
16
|
+
}
|
|
17
|
+
interface FreqPair {
|
|
18
|
+
a: number;
|
|
19
|
+
b: number;
|
|
20
|
+
}
|
|
21
|
+
export interface LissajousWeaveState {
|
|
22
|
+
activePairs: FreqPair[];
|
|
23
|
+
palette: Array<{
|
|
24
|
+
r: number;
|
|
25
|
+
g: number;
|
|
26
|
+
b: number;
|
|
27
|
+
}>;
|
|
28
|
+
rng: SeededRandom;
|
|
29
|
+
frameCount: number;
|
|
30
|
+
width: number;
|
|
31
|
+
height: number;
|
|
32
|
+
needsClear?: boolean;
|
|
33
|
+
}
|
|
34
|
+
export declare function initLissajousWeave(width: number, height: number, params: LissajousWeaveParams): LissajousWeaveState;
|
|
35
|
+
export declare function drawLissajousWeave(ctx: CanvasRenderingContext2D, state: LissajousWeaveState, params: LissajousWeaveParams): void;
|
|
36
|
+
export declare function resetLissajousWeave(state: LissajousWeaveState, params: LissajousWeaveParams): void;
|
|
37
|
+
export {};
|
|
38
|
+
//# sourceMappingURL=lissajousWeave.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lissajousWeave.d.ts","sourceRoot":"","sources":["../../../src/components/engines/lissajousWeave.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,YAAY,EAAkB,MAAM,gBAAgB,CAAC;AAE9D,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,QAAQ;IAChB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX;AAED,MAAM,WAAW,mBAAmB;IAClC,WAAW,EAAE,QAAQ,EAAE,CAAC;IACxB,OAAO,EAAE,KAAK,CAAC;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACpD,GAAG,EAAE,YAAY,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,oBAAoB,GAC3B,mBAAmB,CA6BrB;AAED,wBAAgB,kBAAkB,CAChC,GAAG,EAAE,wBAAwB,EAC7B,KAAK,EAAE,mBAAmB,EAC1B,MAAM,EAAE,oBAAoB,GAC3B,IAAI,CAoDN;AAED,wBAAgB,mBAAmB,CACjC,KAAK,EAAE,mBAAmB,EAC1B,MAAM,EAAE,oBAAoB,GAC3B,IAAI,CAON"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Lissajous Weave Engine
|
|
3
|
+
* Harmonic phase tapestry with multiple frequency ratios
|
|
4
|
+
*/
|
|
5
|
+
import { SeededRandom, hexToRgb, rgba } from "../utils/noise";
|
|
6
|
+
export function initLissajousWeave(width, height, params) {
|
|
7
|
+
const rng = new SeededRandom(params.seed);
|
|
8
|
+
// Build all possible frequency pairs
|
|
9
|
+
const all = [];
|
|
10
|
+
for (let a = 1; a <= params.freqMax; a++) {
|
|
11
|
+
for (let b = 1; b <= params.freqMax; b++) {
|
|
12
|
+
all.push({ a, b });
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
// Shuffle and select
|
|
16
|
+
all.sort(() => rng.random() - 0.5);
|
|
17
|
+
const activePairs = all.slice(0, Math.min(params.curveCount, all.length));
|
|
18
|
+
const palette = [
|
|
19
|
+
hexToRgb(params.colorA),
|
|
20
|
+
hexToRgb(params.colorB),
|
|
21
|
+
hexToRgb(params.colorC),
|
|
22
|
+
];
|
|
23
|
+
return {
|
|
24
|
+
activePairs,
|
|
25
|
+
palette,
|
|
26
|
+
rng,
|
|
27
|
+
frameCount: 0,
|
|
28
|
+
width,
|
|
29
|
+
height,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
export function drawLissajousWeave(ctx, state, params) {
|
|
33
|
+
const { activePairs, palette, frameCount, width, height } = state;
|
|
34
|
+
const bg = hexToRgb(params.bgColor);
|
|
35
|
+
// Clear canvas completely if needed (on reset)
|
|
36
|
+
if (state.needsClear) {
|
|
37
|
+
ctx.fillStyle = rgba(bg.r, bg.g, bg.b, 255);
|
|
38
|
+
ctx.fillRect(0, 0, width, height);
|
|
39
|
+
state.needsClear = false;
|
|
40
|
+
}
|
|
41
|
+
// Fade background
|
|
42
|
+
ctx.fillStyle = rgba(bg.r, bg.g, bg.b, 18);
|
|
43
|
+
ctx.fillRect(0, 0, width, height);
|
|
44
|
+
const cx = width / 2;
|
|
45
|
+
const cy = height / 2;
|
|
46
|
+
const phase = frameCount * params.phaseSpeed * 0.009;
|
|
47
|
+
// Draw each Lissajous curve
|
|
48
|
+
for (let i = 0; i < activePairs.length; i++) {
|
|
49
|
+
const { a, b } = activePairs[i];
|
|
50
|
+
const delta = phase + (i / activePairs.length) * Math.PI * 2;
|
|
51
|
+
const col = palette[i % palette.length];
|
|
52
|
+
const alpha = 200 - (i / activePairs.length) * 130; // 200 to 70
|
|
53
|
+
const weight = 1.6 - (i / activePairs.length) * 1.1; // 1.6 to 0.5
|
|
54
|
+
ctx.strokeStyle = rgba(col.r, col.g, col.b, alpha);
|
|
55
|
+
ctx.lineWidth = weight;
|
|
56
|
+
ctx.beginPath();
|
|
57
|
+
const totalSteps = 700 * Math.max(a, b);
|
|
58
|
+
let firstPoint = true;
|
|
59
|
+
for (let k = 0; k <= totalSteps; k++) {
|
|
60
|
+
const t = (k / totalSteps) * Math.PI * 2;
|
|
61
|
+
const x = cx + params.radius * Math.sin(a * t + delta);
|
|
62
|
+
const y = cy + params.radius * Math.sin(b * t);
|
|
63
|
+
if (firstPoint) {
|
|
64
|
+
ctx.moveTo(x, y);
|
|
65
|
+
firstPoint = false;
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
ctx.lineTo(x, y);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
ctx.stroke();
|
|
72
|
+
}
|
|
73
|
+
state.frameCount++;
|
|
74
|
+
}
|
|
75
|
+
export function resetLissajousWeave(state, params) {
|
|
76
|
+
const newState = initLissajousWeave(state.width, state.height, params);
|
|
77
|
+
state.activePairs = newState.activePairs;
|
|
78
|
+
state.palette = newState.palette;
|
|
79
|
+
state.rng = newState.rng;
|
|
80
|
+
state.frameCount = 0;
|
|
81
|
+
state.needsClear = true;
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=lissajousWeave.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lissajousWeave.js","sourceRoot":"","sources":["../../../src/components/engines/lissajousWeave.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Moire Lattice Engine
|
|
3
|
+
* Rotating line grids creating interference patterns
|
|
4
|
+
*/
|
|
5
|
+
import { PerlinNoise, SeededRandom } from "../utils/noise";
|
|
6
|
+
export interface MoireLatticeParams {
|
|
7
|
+
seed: number;
|
|
8
|
+
gridCount: number;
|
|
9
|
+
lineSpacing: number;
|
|
10
|
+
lineWeight: number;
|
|
11
|
+
lineAlpha: number;
|
|
12
|
+
rotSpeed: number;
|
|
13
|
+
bgColor: string;
|
|
14
|
+
colorA: string;
|
|
15
|
+
colorB: string;
|
|
16
|
+
colorC: string;
|
|
17
|
+
}
|
|
18
|
+
export interface MoireLatticeState {
|
|
19
|
+
rng: SeededRandom;
|
|
20
|
+
noise: PerlinNoise;
|
|
21
|
+
time: number;
|
|
22
|
+
width: number;
|
|
23
|
+
height: number;
|
|
24
|
+
}
|
|
25
|
+
export declare function initMoireLattice(width: number, height: number, params: MoireLatticeParams): MoireLatticeState;
|
|
26
|
+
export declare function drawMoireLattice(ctx: CanvasRenderingContext2D, state: MoireLatticeState, params: MoireLatticeParams): void;
|
|
27
|
+
export declare function resetMoireLattice(state: MoireLatticeState, params: MoireLatticeParams): void;
|
|
28
|
+
//# sourceMappingURL=moireLattice.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"moireLattice.d.ts","sourceRoot":"","sources":["../../../src/components/engines/moireLattice.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAkB,MAAM,gBAAgB,CAAC;AAE3E,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,YAAY,CAAC;IAClB,KAAK,EAAE,WAAW,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,kBAAkB,GACzB,iBAAiB,CAInB;AAED,wBAAgB,gBAAgB,CAC9B,GAAG,EAAE,wBAAwB,EAC7B,KAAK,EAAE,iBAAiB,EACxB,MAAM,EAAE,kBAAkB,GACzB,IAAI,CAsCN;AAED,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,iBAAiB,EACxB,MAAM,EAAE,kBAAkB,GACzB,IAAI,CAKN"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Moire Lattice Engine
|
|
3
|
+
* Rotating line grids creating interference patterns
|
|
4
|
+
*/
|
|
5
|
+
import { PerlinNoise, SeededRandom, hexToRgb, rgba } from "../utils/noise";
|
|
6
|
+
export function initMoireLattice(width, height, params) {
|
|
7
|
+
const rng = new SeededRandom(params.seed);
|
|
8
|
+
const noise = new PerlinNoise(params.seed);
|
|
9
|
+
return { rng, noise, time: 0, width, height };
|
|
10
|
+
}
|
|
11
|
+
export function drawMoireLattice(ctx, state, params) {
|
|
12
|
+
const { width, height } = state;
|
|
13
|
+
// Clear background
|
|
14
|
+
const bg = hexToRgb(params.bgColor);
|
|
15
|
+
ctx.fillStyle = `rgb(${bg.r},${bg.g},${bg.b})`;
|
|
16
|
+
ctx.fillRect(0, 0, width, height);
|
|
17
|
+
const palette = [hexToRgb(params.colorA), hexToRgb(params.colorB), hexToRgb(params.colorC)];
|
|
18
|
+
const diag = Math.sqrt(width ** 2 + height ** 2);
|
|
19
|
+
const t = state.time * params.rotSpeed * 0.0008;
|
|
20
|
+
ctx.save();
|
|
21
|
+
ctx.translate(width / 2, height / 2);
|
|
22
|
+
for (let g = 0; g < params.gridCount; g++) {
|
|
23
|
+
const angle = (g / params.gridCount) * Math.PI + t * (1 + g * 0.41);
|
|
24
|
+
const col = palette[g % palette.length];
|
|
25
|
+
ctx.strokeStyle = rgba(col.r, col.g, col.b, params.lineAlpha);
|
|
26
|
+
ctx.lineWidth = params.lineWeight;
|
|
27
|
+
ctx.save();
|
|
28
|
+
ctx.rotate(angle);
|
|
29
|
+
const num = Math.ceil(diag / params.lineSpacing) + 2;
|
|
30
|
+
for (let i = -num; i <= num; i++) {
|
|
31
|
+
ctx.beginPath();
|
|
32
|
+
ctx.moveTo(-diag, i * params.lineSpacing);
|
|
33
|
+
ctx.lineTo(diag, i * params.lineSpacing);
|
|
34
|
+
ctx.stroke();
|
|
35
|
+
}
|
|
36
|
+
ctx.restore();
|
|
37
|
+
}
|
|
38
|
+
ctx.restore();
|
|
39
|
+
state.time++;
|
|
40
|
+
}
|
|
41
|
+
export function resetMoireLattice(state, params) {
|
|
42
|
+
const newState = initMoireLattice(state.width, state.height, params);
|
|
43
|
+
state.rng = newState.rng;
|
|
44
|
+
state.noise = newState.noise;
|
|
45
|
+
state.time = 0;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=moireLattice.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"moireLattice.js","sourceRoot":"","sources":["../../../src/components/engines/moireLattice.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* NebulaVeil engine — OGL (WebGL wrapper) background.
|
|
3
|
+
*
|
|
4
|
+
* Renders three superimposed simplex noise planes at different frequencies
|
|
5
|
+
* that interfere to produce a volumetric, cloud-like nebula curtain.
|
|
6
|
+
* Unlike a single aurora sweep, NebulaVeil uses a radial gradient mapped
|
|
7
|
+
* through the interference pattern — the center of mass of the three noise
|
|
8
|
+
* planes determines luminosity, creating depth through layering rather than
|
|
9
|
+
* a horizontal band.
|
|
10
|
+
*
|
|
11
|
+
* Architecture: OGL Renderer + Program + Mesh (Triangle geometry).
|
|
12
|
+
* The Renderer is created inside init and stored in state. The React wrapper
|
|
13
|
+
* receives a container HTMLElement; OGL appends its canvas to it.
|
|
14
|
+
* No context is passed to draw/reset — the renderer is self-contained in state.
|
|
15
|
+
*/
|
|
16
|
+
import { Renderer, Program, Mesh } from "ogl";
|
|
17
|
+
export interface NebulaVeilParams {
|
|
18
|
+
colorA?: string;
|
|
19
|
+
colorB?: string;
|
|
20
|
+
colorC?: string;
|
|
21
|
+
speed?: number;
|
|
22
|
+
amplitude?: number;
|
|
23
|
+
density?: number;
|
|
24
|
+
blend?: number;
|
|
25
|
+
}
|
|
26
|
+
export interface NebulaVeilState {
|
|
27
|
+
renderer: Renderer;
|
|
28
|
+
mesh: Mesh;
|
|
29
|
+
program: Program;
|
|
30
|
+
time: number;
|
|
31
|
+
width: number;
|
|
32
|
+
height: number;
|
|
33
|
+
}
|
|
34
|
+
export declare const nebulaVeilDefaults: Required<NebulaVeilParams>;
|
|
35
|
+
export declare function initNebulaVeil(container: HTMLElement, width: number, height: number, params?: NebulaVeilParams): NebulaVeilState;
|
|
36
|
+
export declare function drawNebulaVeil(state: NebulaVeilState, params?: NebulaVeilParams): void;
|
|
37
|
+
export declare function resetNebulaVeil(state: NebulaVeilState, params?: NebulaVeilParams): NebulaVeilState;
|
|
38
|
+
//# sourceMappingURL=nebulaVeil.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nebulaVeil.d.ts","sourceRoot":"","sources":["../../../src/components/engines/nebulaVeil.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAY,MAAM,KAAK,CAAC;AA+GxD,MAAM,WAAW,gBAAgB;IAC/B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,QAAQ,EAAE,QAAQ,CAAC;IACnB,IAAI,EAAE,IAAI,CAAC;IACX,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,kBAAkB,EAAE,QAAQ,CAAC,gBAAgB,CAQzD,CAAC;AAIF,wBAAgB,cAAc,CAC5B,SAAS,EAAE,WAAW,EACtB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,MAAM,GAAE,gBAAqB,GAC5B,eAAe,CAgCjB;AAED,wBAAgB,cAAc,CAC5B,KAAK,EAAE,eAAe,EACtB,MAAM,GAAE,gBAAqB,GAC5B,IAAI,CAcN;AAED,wBAAgB,eAAe,CAC7B,KAAK,EAAE,eAAe,EACtB,MAAM,GAAE,gBAAqB,GAC5B,eAAe,CAQjB"}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* NebulaVeil engine — OGL (WebGL wrapper) background.
|
|
3
|
+
*
|
|
4
|
+
* Renders three superimposed simplex noise planes at different frequencies
|
|
5
|
+
* that interfere to produce a volumetric, cloud-like nebula curtain.
|
|
6
|
+
* Unlike a single aurora sweep, NebulaVeil uses a radial gradient mapped
|
|
7
|
+
* through the interference pattern — the center of mass of the three noise
|
|
8
|
+
* planes determines luminosity, creating depth through layering rather than
|
|
9
|
+
* a horizontal band.
|
|
10
|
+
*
|
|
11
|
+
* Architecture: OGL Renderer + Program + Mesh (Triangle geometry).
|
|
12
|
+
* The Renderer is created inside init and stored in state. The React wrapper
|
|
13
|
+
* receives a container HTMLElement; OGL appends its canvas to it.
|
|
14
|
+
* No context is passed to draw/reset — the renderer is self-contained in state.
|
|
15
|
+
*/
|
|
16
|
+
import { Renderer, Program, Mesh, Triangle } from "ogl";
|
|
17
|
+
// ─── Helpers ─────────────────────────────────────────────────────────────────
|
|
18
|
+
function hexToArr(hex) {
|
|
19
|
+
const h = hex.replace("#", "");
|
|
20
|
+
return [
|
|
21
|
+
parseInt(h.slice(0, 2), 16) / 255,
|
|
22
|
+
parseInt(h.slice(2, 4), 16) / 255,
|
|
23
|
+
parseInt(h.slice(4, 6), 16) / 255,
|
|
24
|
+
];
|
|
25
|
+
}
|
|
26
|
+
// ─── GLSL Sources ─────────────────────────────────────────────────────────────
|
|
27
|
+
// OGL does NOT prepend "#version 300 es" — it compiles shader source as-is.
|
|
28
|
+
// Use GLSL ES 1.00 syntax: "attribute" for vertex input, "gl_FragColor" for output.
|
|
29
|
+
// GLSL ES 1.00 is backward-compatible with WebGL2 contexts.
|
|
30
|
+
const VERT = /* glsl */ `
|
|
31
|
+
attribute vec2 position;
|
|
32
|
+
void main() {
|
|
33
|
+
gl_Position = vec4(position, 0.0, 1.0);
|
|
34
|
+
}
|
|
35
|
+
`;
|
|
36
|
+
// Three-layer simplex-like value noise nebula shader.
|
|
37
|
+
// Algorithm:
|
|
38
|
+
// Layer A — low frequency noise → large luminous cloud structures
|
|
39
|
+
// Layer B — medium frequency, phase-shifted in time → mid-scale wisps
|
|
40
|
+
// Layer C — high frequency, opposing phase → fine nebula texture
|
|
41
|
+
// Interference: sum the three layers, apply radial gradient for depth.
|
|
42
|
+
// Color: map the summed intensity through a three-stop palette.
|
|
43
|
+
const FRAG = /* glsl */ `
|
|
44
|
+
precision highp float;
|
|
45
|
+
|
|
46
|
+
uniform float uTime;
|
|
47
|
+
uniform vec2 uResolution;
|
|
48
|
+
uniform vec3 uColorA;
|
|
49
|
+
uniform vec3 uColorB;
|
|
50
|
+
uniform vec3 uColorC;
|
|
51
|
+
uniform float uAmplitude;
|
|
52
|
+
uniform float uDensity;
|
|
53
|
+
uniform float uBlend;
|
|
54
|
+
|
|
55
|
+
// ---- Value noise ----
|
|
56
|
+
float hash(vec2 p) {
|
|
57
|
+
return fract(sin(dot(p, vec2(127.1, 311.7))) * 43758.5453123);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
float noise(vec2 p) {
|
|
61
|
+
vec2 i = floor(p);
|
|
62
|
+
vec2 f = fract(p);
|
|
63
|
+
vec2 u = f * f * (3.0 - 2.0 * f);
|
|
64
|
+
return mix(
|
|
65
|
+
mix(hash(i + vec2(0,0)), hash(i + vec2(1,0)), u.x),
|
|
66
|
+
mix(hash(i + vec2(0,1)), hash(i + vec2(1,1)), u.x),
|
|
67
|
+
u.y
|
|
68
|
+
);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
// Two-octave fBm
|
|
72
|
+
float fbm(vec2 p) {
|
|
73
|
+
return noise(p) * 0.6 + noise(p * 2.1 + vec2(5.2, 1.3)) * 0.3 + noise(p * 4.3 + vec2(2.7, 8.1)) * 0.1;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
void main() {
|
|
77
|
+
vec2 uv = gl_FragCoord.xy / uResolution;
|
|
78
|
+
// Center-origin, aspect-corrected
|
|
79
|
+
vec2 centered = (uv - 0.5) * vec2(uResolution.x / uResolution.y, 1.0);
|
|
80
|
+
|
|
81
|
+
float d = uDensity;
|
|
82
|
+
|
|
83
|
+
// Layer A — large structures, slow drift
|
|
84
|
+
float layerA = fbm(centered * d + vec2(uTime * 0.07, uTime * 0.04));
|
|
85
|
+
|
|
86
|
+
// Layer B — medium wisps, different axis
|
|
87
|
+
float layerB = fbm(centered * d * 1.8 + vec2(-uTime * 0.05 + 3.1, uTime * 0.09 + 7.3));
|
|
88
|
+
|
|
89
|
+
// Layer C — fine texture, opposing motion
|
|
90
|
+
float layerC = fbm(centered * d * 3.2 + vec2(uTime * 0.03 + 9.7, -uTime * 0.06 + 4.1));
|
|
91
|
+
|
|
92
|
+
// Interference sum — weighted blend controlled by uBlend
|
|
93
|
+
float nebula = layerA * (1.0 - uBlend * 0.4)
|
|
94
|
+
+ layerB * uBlend * 0.3
|
|
95
|
+
+ layerC * (1.0 - uBlend) * 0.2;
|
|
96
|
+
|
|
97
|
+
nebula = clamp(nebula * uAmplitude, 0.0, 1.0);
|
|
98
|
+
|
|
99
|
+
// Radial vignette — attenuates at edges for depth illusion
|
|
100
|
+
float r = length(centered);
|
|
101
|
+
float vignette = 1.0 - smoothstep(0.35, 0.9, r);
|
|
102
|
+
nebula *= vignette;
|
|
103
|
+
|
|
104
|
+
// Three-stop color gradient through intensity
|
|
105
|
+
vec3 col;
|
|
106
|
+
if (nebula < 0.5) {
|
|
107
|
+
col = mix(uColorA, uColorB, nebula * 2.0);
|
|
108
|
+
} else {
|
|
109
|
+
col = mix(uColorB, uColorC, (nebula - 0.5) * 2.0);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
// Dark background with nebula on top
|
|
113
|
+
vec3 bg = vec3(0.02, 0.02, 0.05);
|
|
114
|
+
col = mix(bg, col, nebula);
|
|
115
|
+
|
|
116
|
+
gl_FragColor = vec4(col, 1.0);
|
|
117
|
+
}
|
|
118
|
+
`;
|
|
119
|
+
export const nebulaVeilDefaults = {
|
|
120
|
+
colorA: "#0a0a2e",
|
|
121
|
+
colorB: "#7b2fbe",
|
|
122
|
+
colorC: "#00d4ff",
|
|
123
|
+
speed: 1.0,
|
|
124
|
+
amplitude: 2.0,
|
|
125
|
+
density: 2.2,
|
|
126
|
+
blend: 0.6,
|
|
127
|
+
};
|
|
128
|
+
// ─── Engine functions ─────────────────────────────────────────────────────────
|
|
129
|
+
export function initNebulaVeil(container, width, height, params = {}) {
|
|
130
|
+
const p = { ...nebulaVeilDefaults, ...params };
|
|
131
|
+
const renderer = new Renderer({ alpha: false, antialias: false });
|
|
132
|
+
const gl = renderer.gl;
|
|
133
|
+
renderer.setSize(width, height);
|
|
134
|
+
container.appendChild(gl.canvas);
|
|
135
|
+
const geometry = new Triangle(gl);
|
|
136
|
+
const caArr = hexToArr(p.colorA);
|
|
137
|
+
const cbArr = hexToArr(p.colorB);
|
|
138
|
+
const ccArr = hexToArr(p.colorC);
|
|
139
|
+
const program = new Program(gl, {
|
|
140
|
+
vertex: VERT,
|
|
141
|
+
fragment: FRAG,
|
|
142
|
+
uniforms: {
|
|
143
|
+
uTime: { value: 0 },
|
|
144
|
+
uResolution: { value: [width, height] },
|
|
145
|
+
uColorA: { value: caArr },
|
|
146
|
+
uColorB: { value: cbArr },
|
|
147
|
+
uColorC: { value: ccArr },
|
|
148
|
+
uAmplitude: { value: p.amplitude },
|
|
149
|
+
uDensity: { value: p.density },
|
|
150
|
+
uBlend: { value: p.blend },
|
|
151
|
+
},
|
|
152
|
+
});
|
|
153
|
+
const mesh = new Mesh(gl, { geometry, program });
|
|
154
|
+
return { renderer, mesh, program, time: 0, width, height };
|
|
155
|
+
}
|
|
156
|
+
export function drawNebulaVeil(state, params = {}) {
|
|
157
|
+
const p = { ...nebulaVeilDefaults, ...params };
|
|
158
|
+
state.time += 0.016 * p.speed;
|
|
159
|
+
state.program.uniforms.uTime.value = state.time;
|
|
160
|
+
state.program.uniforms.uAmplitude.value = p.amplitude;
|
|
161
|
+
state.program.uniforms.uDensity.value = p.density;
|
|
162
|
+
state.program.uniforms.uBlend.value = p.blend;
|
|
163
|
+
state.program.uniforms.uColorA.value = hexToArr(p.colorA);
|
|
164
|
+
state.program.uniforms.uColorB.value = hexToArr(p.colorB);
|
|
165
|
+
state.program.uniforms.uColorC.value = hexToArr(p.colorC);
|
|
166
|
+
state.renderer.render({ scene: state.mesh });
|
|
167
|
+
}
|
|
168
|
+
export function resetNebulaVeil(state, params = {}) {
|
|
169
|
+
const container = state.renderer.gl.canvas.parentElement;
|
|
170
|
+
// Release GPU context and remove the canvas OGL appended
|
|
171
|
+
state.renderer.gl.getExtension("WEBGL_lose_context")?.loseContext();
|
|
172
|
+
if (state.renderer.gl.canvas.parentNode === container) {
|
|
173
|
+
container.removeChild(state.renderer.gl.canvas);
|
|
174
|
+
}
|
|
175
|
+
return initNebulaVeil(container, state.width, state.height, params);
|
|
176
|
+
}
|
|
177
|
+
//# sourceMappingURL=nebulaVeil.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nebulaVeil.js","sourceRoot":"","sources":["../../../src/components/engines/nebulaVeil.ts"],"names":[],"mappings":"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"}
|