@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,86 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useRef } from "react";
|
|
3
|
+
import { initOrbitalResonance, drawOrbitalResonance, resetOrbitalResonance, } from "../engines/orbitalResonance";
|
|
4
|
+
export const orbitalResonanceDefaults = {
|
|
5
|
+
seed: 9999,
|
|
6
|
+
bodyCount: 5,
|
|
7
|
+
resonanceRatios: [1, 2, 3, 5, 8],
|
|
8
|
+
simSpeed: 1.0,
|
|
9
|
+
trailLength: 200,
|
|
10
|
+
trailWeight: 1.5,
|
|
11
|
+
bodySize: 8,
|
|
12
|
+
centerSize: 12,
|
|
13
|
+
fadeTrails: true,
|
|
14
|
+
fadeAmount: 8,
|
|
15
|
+
bgColor: "#0a0a0a",
|
|
16
|
+
colorA: "#ff6b35",
|
|
17
|
+
colorB: "#f7931e",
|
|
18
|
+
colorC: "#fdc830",
|
|
19
|
+
colorD: "#50b8e8",
|
|
20
|
+
};
|
|
21
|
+
export function OrbitalResonance(props) {
|
|
22
|
+
const { className, style, ...params } = props;
|
|
23
|
+
const merged = { ...orbitalResonanceDefaults, ...params };
|
|
24
|
+
const canvasRef = useRef(null);
|
|
25
|
+
const stateRef = useRef(null);
|
|
26
|
+
const paramsRef = useRef(merged);
|
|
27
|
+
paramsRef.current = merged;
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
const canvas = canvasRef.current;
|
|
30
|
+
if (!canvas)
|
|
31
|
+
return;
|
|
32
|
+
const ctx = canvas.getContext("2d");
|
|
33
|
+
if (!ctx)
|
|
34
|
+
return;
|
|
35
|
+
let animId;
|
|
36
|
+
let running = true;
|
|
37
|
+
let isVisible = false;
|
|
38
|
+
function resizeCanvas() {
|
|
39
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
40
|
+
const w = Math.floor(canvas.clientWidth * dpr);
|
|
41
|
+
const h = Math.floor(canvas.clientHeight * dpr);
|
|
42
|
+
if (canvas.width !== w || canvas.height !== h) {
|
|
43
|
+
canvas.width = w;
|
|
44
|
+
canvas.height = h;
|
|
45
|
+
stateRef.current = initOrbitalResonance(w, h, paramsRef.current);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
resizeCanvas();
|
|
49
|
+
stateRef.current = initOrbitalResonance(canvas.width, canvas.height, paramsRef.current);
|
|
50
|
+
const loop = () => {
|
|
51
|
+
if (!running || !isVisible)
|
|
52
|
+
return;
|
|
53
|
+
if (stateRef.current) {
|
|
54
|
+
drawOrbitalResonance(ctx, stateRef.current, paramsRef.current);
|
|
55
|
+
}
|
|
56
|
+
animId = requestAnimationFrame(loop);
|
|
57
|
+
};
|
|
58
|
+
const io = new IntersectionObserver((entries) => {
|
|
59
|
+
entries.forEach((entry) => {
|
|
60
|
+
isVisible = entry.isIntersecting;
|
|
61
|
+
if (isVisible) {
|
|
62
|
+
if (typeof animId !== "undefined") {
|
|
63
|
+
cancelAnimationFrame(animId);
|
|
64
|
+
}
|
|
65
|
+
animId = requestAnimationFrame(loop);
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
io.observe(canvas);
|
|
70
|
+
const ro = new ResizeObserver(resizeCanvas);
|
|
71
|
+
ro.observe(canvas);
|
|
72
|
+
return () => {
|
|
73
|
+
running = false;
|
|
74
|
+
cancelAnimationFrame(animId);
|
|
75
|
+
ro.disconnect();
|
|
76
|
+
io.disconnect();
|
|
77
|
+
};
|
|
78
|
+
}, []);
|
|
79
|
+
useEffect(() => {
|
|
80
|
+
if (!stateRef.current)
|
|
81
|
+
return;
|
|
82
|
+
resetOrbitalResonance(stateRef.current, merged);
|
|
83
|
+
}, [merged.seed]); // eslint-disable-line react-hooks/exhaustive-deps
|
|
84
|
+
return (_jsx("canvas", { ref: canvasRef, className: className, style: { display: "block", width: "100%", height: "100%", ...style } }));
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=OrbitalResonance.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OrbitalResonance.js","sourceRoot":"","sources":["../../../src/components/backgrounds/OrbitalResonance.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { type CSSProperties } from "react";
|
|
2
|
+
export interface PhotonBurstParams {
|
|
3
|
+
/** Seed for initial photon placement. */
|
|
4
|
+
seed?: number;
|
|
5
|
+
/** Ambient photon count. */
|
|
6
|
+
count?: number;
|
|
7
|
+
/** Overall animation speed multiplier. */
|
|
8
|
+
speed?: number;
|
|
9
|
+
/** Noise field scale (affects drift pattern size). */
|
|
10
|
+
noiseScale?: number;
|
|
11
|
+
/** Trail fade opacity per frame (lower = longer trails). */
|
|
12
|
+
trailOpacity?: number;
|
|
13
|
+
/** Particles emitted per click burst. */
|
|
14
|
+
burstSize?: number;
|
|
15
|
+
/** Cursor gravitational pull strength. */
|
|
16
|
+
cursorGravity?: number;
|
|
17
|
+
}
|
|
18
|
+
export declare const photonBurstDefaults: Required<PhotonBurstParams>;
|
|
19
|
+
export interface PhotonBurstProps extends PhotonBurstParams {
|
|
20
|
+
className?: string;
|
|
21
|
+
style?: CSSProperties;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* PhotonBurst — cosmic photon particle background with click-to-burst.
|
|
25
|
+
*
|
|
26
|
+
* Ambient photons drift through a dark void following Perlin noise currents,
|
|
27
|
+
* glowing with a spectral aurora palette. Move the cursor to bend nearby
|
|
28
|
+
* photon paths with gravitational pull. Click anywhere to detonate a radial
|
|
29
|
+
* burst of photons whose hues cycle through the full visible spectrum as they
|
|
30
|
+
* radiate outward.
|
|
31
|
+
*
|
|
32
|
+
* @example
|
|
33
|
+
* <PhotonBurst
|
|
34
|
+
* count={1000}
|
|
35
|
+
* burstSize={36}
|
|
36
|
+
* cursorGravity={0.25}
|
|
37
|
+
* style={{ position: "absolute", inset: 0 }}
|
|
38
|
+
* />
|
|
39
|
+
*/
|
|
40
|
+
export declare function PhotonBurst(props: PhotonBurstProps): import("react/jsx-runtime").JSX.Element;
|
|
41
|
+
//# sourceMappingURL=PhotonBurst.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PhotonBurst.d.ts","sourceRoot":"","sources":["../../../src/components/backgrounds/PhotonBurst.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAqB,KAAK,aAAa,EAAE,MAAM,OAAO,CAAC;AAW9D,MAAM,WAAW,iBAAiB;IAChC,yCAAyC;IACzC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,4BAA4B;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,0CAA0C;IAC1C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,sDAAsD;IACtD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,4DAA4D;IAC5D,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,yCAAyC;IACzC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,0CAA0C;IAC1C,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,eAAO,MAAM,mBAAmB,EAAE,QAAQ,CAAC,iBAAiB,CAQ3D,CAAC;AAIF,MAAM,WAAW,gBAAiB,SAAQ,iBAAiB;IACzD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB;AAID;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,gBAAgB,2CAiJlD"}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useRef } from "react";
|
|
3
|
+
import { initPhotonBurst, drawPhotonBurst, resetPhotonBurst, spawnAtClick as photonSpawnAtClick, } from "../engines/photonBurst";
|
|
4
|
+
export const photonBurstDefaults = {
|
|
5
|
+
seed: 42731,
|
|
6
|
+
count: 800,
|
|
7
|
+
speed: 1.0,
|
|
8
|
+
noiseScale: 0.0025,
|
|
9
|
+
trailOpacity: 12,
|
|
10
|
+
burstSize: 28,
|
|
11
|
+
cursorGravity: 0.18,
|
|
12
|
+
};
|
|
13
|
+
// ── Component ────────────────────────────────────────────────────────────────
|
|
14
|
+
/**
|
|
15
|
+
* PhotonBurst — cosmic photon particle background with click-to-burst.
|
|
16
|
+
*
|
|
17
|
+
* Ambient photons drift through a dark void following Perlin noise currents,
|
|
18
|
+
* glowing with a spectral aurora palette. Move the cursor to bend nearby
|
|
19
|
+
* photon paths with gravitational pull. Click anywhere to detonate a radial
|
|
20
|
+
* burst of photons whose hues cycle through the full visible spectrum as they
|
|
21
|
+
* radiate outward.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* <PhotonBurst
|
|
25
|
+
* count={1000}
|
|
26
|
+
* burstSize={36}
|
|
27
|
+
* cursorGravity={0.25}
|
|
28
|
+
* style={{ position: "absolute", inset: 0 }}
|
|
29
|
+
* />
|
|
30
|
+
*/
|
|
31
|
+
export function PhotonBurst(props) {
|
|
32
|
+
const { className, style, ...params } = props;
|
|
33
|
+
const merged = { ...photonBurstDefaults, ...params };
|
|
34
|
+
const canvasRef = useRef(null);
|
|
35
|
+
const stateRef = useRef(null);
|
|
36
|
+
const paramsRef = useRef(merged);
|
|
37
|
+
paramsRef.current = merged;
|
|
38
|
+
// EFFECT 1 — setup loop, observers, pointer listeners (runs once)
|
|
39
|
+
useEffect(() => {
|
|
40
|
+
const canvas = canvasRef.current;
|
|
41
|
+
if (!canvas)
|
|
42
|
+
return;
|
|
43
|
+
const ctx = canvas.getContext("2d");
|
|
44
|
+
if (!ctx)
|
|
45
|
+
return;
|
|
46
|
+
let animId;
|
|
47
|
+
let running = true;
|
|
48
|
+
let isVisible = false;
|
|
49
|
+
// Mutable closure object — tracks cursor position in canvas pixel space
|
|
50
|
+
const mouse = { pos: undefined };
|
|
51
|
+
function resizeCanvas() {
|
|
52
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
53
|
+
const w = Math.floor(canvas.clientWidth * dpr);
|
|
54
|
+
const h = Math.floor(canvas.clientHeight * dpr);
|
|
55
|
+
if (canvas.width !== w || canvas.height !== h) {
|
|
56
|
+
canvas.width = w;
|
|
57
|
+
canvas.height = h;
|
|
58
|
+
ctx.fillStyle = "rgb(6,6,16)";
|
|
59
|
+
ctx.fillRect(0, 0, w, h);
|
|
60
|
+
stateRef.current = initPhotonBurst(w, h, paramsRef.current);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
resizeCanvas();
|
|
64
|
+
stateRef.current = initPhotonBurst(canvas.width, canvas.height, paramsRef.current);
|
|
65
|
+
// ── Pointer listeners ──────────────────────────────────────────────────
|
|
66
|
+
const onMouseMove = (e) => {
|
|
67
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
68
|
+
const rect = canvas.getBoundingClientRect();
|
|
69
|
+
mouse.pos = {
|
|
70
|
+
x: (e.clientX - rect.left) * dpr,
|
|
71
|
+
y: (e.clientY - rect.top) * dpr,
|
|
72
|
+
};
|
|
73
|
+
};
|
|
74
|
+
const onMouseLeave = () => { mouse.pos = undefined; };
|
|
75
|
+
const onClick = (e) => {
|
|
76
|
+
if (!stateRef.current)
|
|
77
|
+
return;
|
|
78
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
79
|
+
const rect = canvas.getBoundingClientRect();
|
|
80
|
+
photonSpawnAtClick(stateRef.current, (e.clientX - rect.left) * dpr, (e.clientY - rect.top) * dpr, paramsRef.current);
|
|
81
|
+
};
|
|
82
|
+
const onTouchMove = (e) => {
|
|
83
|
+
e.preventDefault();
|
|
84
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
85
|
+
const t = e.touches[0];
|
|
86
|
+
const rect = canvas.getBoundingClientRect();
|
|
87
|
+
mouse.pos = {
|
|
88
|
+
x: (t.clientX - rect.left) * dpr,
|
|
89
|
+
y: (t.clientY - rect.top) * dpr,
|
|
90
|
+
};
|
|
91
|
+
};
|
|
92
|
+
const onTouchStart = (e) => {
|
|
93
|
+
e.preventDefault();
|
|
94
|
+
if (!stateRef.current)
|
|
95
|
+
return;
|
|
96
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
97
|
+
const t = e.touches[0];
|
|
98
|
+
const rect = canvas.getBoundingClientRect();
|
|
99
|
+
photonSpawnAtClick(stateRef.current, (t.clientX - rect.left) * dpr, (t.clientY - rect.top) * dpr, paramsRef.current);
|
|
100
|
+
};
|
|
101
|
+
canvas.addEventListener("mousemove", onMouseMove);
|
|
102
|
+
canvas.addEventListener("mouseleave", onMouseLeave);
|
|
103
|
+
canvas.addEventListener("click", onClick);
|
|
104
|
+
canvas.addEventListener("touchmove", onTouchMove, { passive: false });
|
|
105
|
+
canvas.addEventListener("touchstart", onTouchStart, { passive: false });
|
|
106
|
+
// ── Animation loop ─────────────────────────────────────────────────────
|
|
107
|
+
const loop = () => {
|
|
108
|
+
if (!running || !isVisible)
|
|
109
|
+
return;
|
|
110
|
+
if (stateRef.current) {
|
|
111
|
+
drawPhotonBurst(ctx, stateRef.current, paramsRef.current, mouse.pos);
|
|
112
|
+
}
|
|
113
|
+
animId = requestAnimationFrame(loop);
|
|
114
|
+
};
|
|
115
|
+
const io = new IntersectionObserver((entries) => {
|
|
116
|
+
entries.forEach((entry) => {
|
|
117
|
+
isVisible = entry.isIntersecting;
|
|
118
|
+
if (isVisible) {
|
|
119
|
+
if (typeof animId !== "undefined")
|
|
120
|
+
cancelAnimationFrame(animId);
|
|
121
|
+
animId = requestAnimationFrame(loop);
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
io.observe(canvas);
|
|
126
|
+
const ro = new ResizeObserver(resizeCanvas);
|
|
127
|
+
ro.observe(canvas);
|
|
128
|
+
return () => {
|
|
129
|
+
running = false;
|
|
130
|
+
cancelAnimationFrame(animId);
|
|
131
|
+
ro.disconnect();
|
|
132
|
+
io.disconnect();
|
|
133
|
+
canvas.removeEventListener("mousemove", onMouseMove);
|
|
134
|
+
canvas.removeEventListener("mouseleave", onMouseLeave);
|
|
135
|
+
canvas.removeEventListener("click", onClick);
|
|
136
|
+
canvas.removeEventListener("touchmove", onTouchMove);
|
|
137
|
+
canvas.removeEventListener("touchstart", onTouchStart);
|
|
138
|
+
};
|
|
139
|
+
}, []); // eslint-disable-line react-hooks/exhaustive-deps
|
|
140
|
+
// EFFECT 2 — structural reset when seed or count changes
|
|
141
|
+
useEffect(() => {
|
|
142
|
+
const canvas = canvasRef.current;
|
|
143
|
+
const ctx = canvas?.getContext("2d");
|
|
144
|
+
if (!canvas || !ctx || !stateRef.current)
|
|
145
|
+
return;
|
|
146
|
+
stateRef.current = resetPhotonBurst(ctx, stateRef.current, merged);
|
|
147
|
+
}, [merged.seed, merged.count]); // eslint-disable-line react-hooks/exhaustive-deps
|
|
148
|
+
return (_jsx("canvas", { ref: canvasRef, className: className, style: { display: "block", width: "100%", height: "100%", ...style } }));
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=PhotonBurst.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PhotonBurst.js","sourceRoot":"","sources":["../../../src/components/backgrounds/PhotonBurst.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phyllotaxis Dream
|
|
3
|
+
* Golden angle spiral growth
|
|
4
|
+
*/
|
|
5
|
+
import { type CSSProperties } from "react";
|
|
6
|
+
export interface PhyllotaxisDreamParams {
|
|
7
|
+
seed?: number;
|
|
8
|
+
numPoints?: number;
|
|
9
|
+
spread?: number;
|
|
10
|
+
angleScale?: number;
|
|
11
|
+
morph?: number;
|
|
12
|
+
rotSpeed?: number;
|
|
13
|
+
dotSize?: number;
|
|
14
|
+
bgColor?: string;
|
|
15
|
+
colorA?: string;
|
|
16
|
+
colorB?: string;
|
|
17
|
+
colorC?: string;
|
|
18
|
+
}
|
|
19
|
+
export declare const phyllotaxisDreamDefaults: Required<PhyllotaxisDreamParams>;
|
|
20
|
+
export interface PhyllotaxisDreamProps extends PhyllotaxisDreamParams {
|
|
21
|
+
className?: string;
|
|
22
|
+
style?: CSSProperties;
|
|
23
|
+
}
|
|
24
|
+
export declare function PhyllotaxisDream(props: PhyllotaxisDreamProps): import("react/jsx-runtime").JSX.Element;
|
|
25
|
+
//# sourceMappingURL=PhyllotaxisDream.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PhyllotaxisDream.d.ts","sourceRoot":"","sources":["../../../src/components/backgrounds/PhyllotaxisDream.tsx"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAqB,KAAK,aAAa,EAAE,MAAM,OAAO,CAAC;AAQ9D,MAAM,WAAW,sBAAsB;IACrC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,eAAO,MAAM,wBAAwB,EAAE,QAAQ,CAAC,sBAAsB,CAYrE,CAAC;AAEF,MAAM,WAAW,qBAAsB,SAAQ,sBAAsB;IACnE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,qBAAqB,2CA+E5D"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Phyllotaxis Dream
|
|
4
|
+
* Golden angle spiral growth
|
|
5
|
+
*/
|
|
6
|
+
import { useEffect, useRef } from "react";
|
|
7
|
+
import { initPhyllotaxisDream, drawPhyllotaxisDream, resetPhyllotaxisDream, } from "../engines/phyllotaxisDream";
|
|
8
|
+
export const phyllotaxisDreamDefaults = {
|
|
9
|
+
seed: 42731,
|
|
10
|
+
numPoints: 800,
|
|
11
|
+
spread: 4.5,
|
|
12
|
+
angleScale: 1.0,
|
|
13
|
+
morph: 1.0,
|
|
14
|
+
rotSpeed: 1.0,
|
|
15
|
+
dotSize: 6,
|
|
16
|
+
bgColor: "#0a0a0a",
|
|
17
|
+
colorA: "#ff6b35",
|
|
18
|
+
colorB: "#f7931e",
|
|
19
|
+
colorC: "#fdc830",
|
|
20
|
+
};
|
|
21
|
+
export function PhyllotaxisDream(props) {
|
|
22
|
+
const { className, style, ...params } = props;
|
|
23
|
+
const merged = { ...phyllotaxisDreamDefaults, ...params };
|
|
24
|
+
const canvasRef = useRef(null);
|
|
25
|
+
const stateRef = useRef(null);
|
|
26
|
+
const paramsRef = useRef(merged);
|
|
27
|
+
paramsRef.current = merged;
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
const canvas = canvasRef.current;
|
|
30
|
+
if (!canvas)
|
|
31
|
+
return;
|
|
32
|
+
const ctx = canvas.getContext("2d", { alpha: false });
|
|
33
|
+
if (!ctx)
|
|
34
|
+
return;
|
|
35
|
+
let animId;
|
|
36
|
+
let running = true;
|
|
37
|
+
let isVisible = false;
|
|
38
|
+
function resizeCanvas() {
|
|
39
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
40
|
+
const w = Math.floor(canvas.clientWidth * dpr);
|
|
41
|
+
const h = Math.floor(canvas.clientHeight * dpr);
|
|
42
|
+
if (canvas.width !== w || canvas.height !== h) {
|
|
43
|
+
canvas.width = w;
|
|
44
|
+
canvas.height = h;
|
|
45
|
+
stateRef.current = initPhyllotaxisDream(w, h, paramsRef.current);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
resizeCanvas();
|
|
49
|
+
stateRef.current = initPhyllotaxisDream(canvas.width, canvas.height, paramsRef.current);
|
|
50
|
+
const loop = () => {
|
|
51
|
+
if (!running || !isVisible)
|
|
52
|
+
return;
|
|
53
|
+
if (stateRef.current) {
|
|
54
|
+
drawPhyllotaxisDream(ctx, stateRef.current, paramsRef.current);
|
|
55
|
+
}
|
|
56
|
+
animId = requestAnimationFrame(loop);
|
|
57
|
+
};
|
|
58
|
+
const io = new IntersectionObserver((entries) => {
|
|
59
|
+
entries.forEach((entry) => {
|
|
60
|
+
isVisible = entry.isIntersecting;
|
|
61
|
+
if (isVisible) {
|
|
62
|
+
if (typeof animId !== "undefined") {
|
|
63
|
+
cancelAnimationFrame(animId);
|
|
64
|
+
}
|
|
65
|
+
animId = requestAnimationFrame(loop);
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
io.observe(canvas);
|
|
70
|
+
const ro = new ResizeObserver(resizeCanvas);
|
|
71
|
+
ro.observe(canvas);
|
|
72
|
+
return () => {
|
|
73
|
+
running = false;
|
|
74
|
+
cancelAnimationFrame(animId);
|
|
75
|
+
ro.disconnect();
|
|
76
|
+
io.disconnect();
|
|
77
|
+
};
|
|
78
|
+
}, []);
|
|
79
|
+
useEffect(() => {
|
|
80
|
+
const canvas = canvasRef.current;
|
|
81
|
+
const ctx = canvas?.getContext("2d");
|
|
82
|
+
if (!canvas || !ctx || !stateRef.current)
|
|
83
|
+
return;
|
|
84
|
+
resetPhyllotaxisDream(stateRef.current, paramsRef.current);
|
|
85
|
+
}, [merged.seed]); // eslint-disable-line react-hooks/exhaustive-deps
|
|
86
|
+
return (_jsx("canvas", { ref: canvasRef, className: className, style: { display: "block", width: "100%", height: "100%", ...style } }));
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=PhyllotaxisDream.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PhyllotaxisDream.js","sourceRoot":"","sources":["../../../src/components/backgrounds/PhyllotaxisDream.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type CSSProperties } from "react";
|
|
2
|
+
import { type PlasmaFieldParams } from "../engines/plasmaField";
|
|
3
|
+
export type { PlasmaFieldParams };
|
|
4
|
+
export interface PlasmaFieldProps extends PlasmaFieldParams {
|
|
5
|
+
className?: string;
|
|
6
|
+
style?: CSSProperties;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* PlasmaField — WebGL2 domain-warped fBm plasma background.
|
|
10
|
+
*
|
|
11
|
+
* Renders a full-screen fragment shader: three-octave fractional Brownian
|
|
12
|
+
* motion with domain warping at true pixel resolution. Color shifts
|
|
13
|
+
* smoothly through three parameterizable stops over time.
|
|
14
|
+
*
|
|
15
|
+
* Requires WebGL2 support (all modern browsers since 2017). Gracefully
|
|
16
|
+
* renders nothing on unsupported environments with a console warning.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* <PlasmaField
|
|
20
|
+
* style={{ position: "absolute", inset: 0 }}
|
|
21
|
+
* colorA="#0d1b6e"
|
|
22
|
+
* colorB="#c0146c"
|
|
23
|
+
* colorC="#f5a623"
|
|
24
|
+
* speed={1.2}
|
|
25
|
+
* />
|
|
26
|
+
*/
|
|
27
|
+
export declare function PlasmaField(props: PlasmaFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
28
|
+
//# sourceMappingURL=PlasmaField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PlasmaField.d.ts","sourceRoot":"","sources":["../../../src/components/backgrounds/PlasmaField.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAqB,KAAK,aAAa,EAAE,MAAM,OAAO,CAAC;AAC9D,OAAO,EAML,KAAK,iBAAiB,EACvB,MAAM,wBAAwB,CAAC;AAEhC,YAAY,EAAE,iBAAiB,EAAE,CAAC;AAElC,MAAM,WAAW,gBAAiB,SAAQ,iBAAiB;IACzD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,gBAAgB,2CA4GlD"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useRef } from "react";
|
|
3
|
+
import { initPlasmaField, drawPlasmaField, resetPlasmaField, plasmaFieldDefaults, } from "../engines/plasmaField";
|
|
4
|
+
/**
|
|
5
|
+
* PlasmaField — WebGL2 domain-warped fBm plasma background.
|
|
6
|
+
*
|
|
7
|
+
* Renders a full-screen fragment shader: three-octave fractional Brownian
|
|
8
|
+
* motion with domain warping at true pixel resolution. Color shifts
|
|
9
|
+
* smoothly through three parameterizable stops over time.
|
|
10
|
+
*
|
|
11
|
+
* Requires WebGL2 support (all modern browsers since 2017). Gracefully
|
|
12
|
+
* renders nothing on unsupported environments with a console warning.
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* <PlasmaField
|
|
16
|
+
* style={{ position: "absolute", inset: 0 }}
|
|
17
|
+
* colorA="#0d1b6e"
|
|
18
|
+
* colorB="#c0146c"
|
|
19
|
+
* colorC="#f5a623"
|
|
20
|
+
* speed={1.2}
|
|
21
|
+
* />
|
|
22
|
+
*/
|
|
23
|
+
export function PlasmaField(props) {
|
|
24
|
+
const { className, style, ...params } = props;
|
|
25
|
+
const merged = { ...plasmaFieldDefaults, ...params };
|
|
26
|
+
const canvasRef = useRef(null);
|
|
27
|
+
const stateRef = useRef(null);
|
|
28
|
+
// Always-current params ref — loop reads this, no loop restart needed
|
|
29
|
+
const paramsRef = useRef(merged);
|
|
30
|
+
paramsRef.current = merged;
|
|
31
|
+
// EFFECT 1: Setup — runs once. Acquires WebGL2 context, starts loop,
|
|
32
|
+
// attaches ResizeObserver and IntersectionObserver.
|
|
33
|
+
useEffect(() => {
|
|
34
|
+
const canvas = canvasRef.current;
|
|
35
|
+
if (!canvas)
|
|
36
|
+
return;
|
|
37
|
+
const gl = canvas.getContext("webgl2");
|
|
38
|
+
if (!gl) {
|
|
39
|
+
console.warn("PlasmaField: WebGL2 is not supported in this environment. " +
|
|
40
|
+
"The component will not render.");
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
let animId;
|
|
44
|
+
let running = true;
|
|
45
|
+
let isVisible = false;
|
|
46
|
+
function resizeCanvas() {
|
|
47
|
+
const dpr = Math.min(window.devicePixelRatio || 1, 2);
|
|
48
|
+
const w = Math.floor(canvas.clientWidth * dpr);
|
|
49
|
+
const h = Math.floor(canvas.clientHeight * dpr);
|
|
50
|
+
if (canvas.width !== w || canvas.height !== h) {
|
|
51
|
+
canvas.width = w;
|
|
52
|
+
canvas.height = h;
|
|
53
|
+
gl.viewport(0, 0, w, h);
|
|
54
|
+
if (stateRef.current) {
|
|
55
|
+
stateRef.current.width = w;
|
|
56
|
+
stateRef.current.height = h;
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
stateRef.current = initPlasmaField(gl, w, h, paramsRef.current);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
resizeCanvas();
|
|
64
|
+
if (!stateRef.current) {
|
|
65
|
+
stateRef.current = initPlasmaField(gl, canvas.width, canvas.height, paramsRef.current);
|
|
66
|
+
}
|
|
67
|
+
const loop = () => {
|
|
68
|
+
if (!running || !isVisible)
|
|
69
|
+
return;
|
|
70
|
+
if (stateRef.current) {
|
|
71
|
+
drawPlasmaField(gl, stateRef.current, paramsRef.current);
|
|
72
|
+
}
|
|
73
|
+
animId = requestAnimationFrame(loop);
|
|
74
|
+
};
|
|
75
|
+
// Pause when off-screen
|
|
76
|
+
const io = new IntersectionObserver((entries) => {
|
|
77
|
+
entries.forEach((entry) => {
|
|
78
|
+
isVisible = entry.isIntersecting;
|
|
79
|
+
if (isVisible) {
|
|
80
|
+
if (typeof animId !== "undefined")
|
|
81
|
+
cancelAnimationFrame(animId);
|
|
82
|
+
animId = requestAnimationFrame(loop);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
io.observe(canvas);
|
|
87
|
+
const ro = new ResizeObserver(resizeCanvas);
|
|
88
|
+
ro.observe(canvas);
|
|
89
|
+
return () => {
|
|
90
|
+
running = false;
|
|
91
|
+
cancelAnimationFrame(animId);
|
|
92
|
+
ro.disconnect();
|
|
93
|
+
io.disconnect();
|
|
94
|
+
// Null state so remount (React Strict Mode) re-initializes cleanly.
|
|
95
|
+
// Do NOT call loseContext() here — it permanently invalidates the canvas
|
|
96
|
+
// context, causing shader compile failures on remount.
|
|
97
|
+
stateRef.current = null;
|
|
98
|
+
};
|
|
99
|
+
}, []); // intentionally empty — loop reads paramsRef
|
|
100
|
+
// EFFECT 2: Structural reset — re-initializes when seed or scale change,
|
|
101
|
+
// as these are baked into the shader's noise domain.
|
|
102
|
+
// Visual-only params (colors, speed, contrast) update live via paramsRef.
|
|
103
|
+
const isFirstPlasmaRender = useRef(true);
|
|
104
|
+
useEffect(() => {
|
|
105
|
+
if (isFirstPlasmaRender.current) {
|
|
106
|
+
isFirstPlasmaRender.current = false;
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
const canvas = canvasRef.current;
|
|
110
|
+
const gl = canvas?.getContext("webgl2");
|
|
111
|
+
if (!canvas || !gl || !stateRef.current)
|
|
112
|
+
return;
|
|
113
|
+
stateRef.current = resetPlasmaField(gl, stateRef.current, merged);
|
|
114
|
+
}, [merged.seed, merged.scale]); // eslint-disable-line react-hooks/exhaustive-deps
|
|
115
|
+
return (_jsx("canvas", { ref: canvasRef, className: className, style: { display: "block", width: "100%", height: "100%", ...style } }));
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=PlasmaField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PlasmaField.js","sourceRoot":"","sources":["../../../src/components/backgrounds/PlasmaField.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { type CSSProperties } from "react";
|
|
2
|
+
export interface PrismaticWaveParams {
|
|
3
|
+
/** Seed for deterministic source placement. */
|
|
4
|
+
seed?: number;
|
|
5
|
+
/** Number of circular wave sources. */
|
|
6
|
+
sources?: number;
|
|
7
|
+
/** Base wave spatial frequency. */
|
|
8
|
+
frequency?: number;
|
|
9
|
+
/** Wave propagation speed. */
|
|
10
|
+
waveSpeed?: number;
|
|
11
|
+
/** Pixel grid cell size (lower = sharper, heavier). */
|
|
12
|
+
resolution?: number;
|
|
13
|
+
/** Hue range swept across the wave amplitude (degrees). */
|
|
14
|
+
dispersion?: number;
|
|
15
|
+
/** Starting hue offset (degrees, 0–360). */
|
|
16
|
+
hueOffset?: number;
|
|
17
|
+
/** Colour saturation 0–1. */
|
|
18
|
+
saturation?: number;
|
|
19
|
+
/** Peak pixel lightness 0–1. */
|
|
20
|
+
brightness?: number;
|
|
21
|
+
/** Cursor lens warp strength (0 = off). */
|
|
22
|
+
lensStrength?: number;
|
|
23
|
+
}
|
|
24
|
+
export declare const prismaticWaveDefaults: Required<PrismaticWaveParams>;
|
|
25
|
+
export interface PrismaticWaveProps extends PrismaticWaveParams {
|
|
26
|
+
className?: string;
|
|
27
|
+
style?: CSSProperties;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* PrismaticWave — wave-interference background with spectral colour dispersion.
|
|
31
|
+
*
|
|
32
|
+
* Multiple circular wave sources drift and interfere; their superposition is
|
|
33
|
+
* mapped to a full spectral hue sweep (red → violet), like white light through
|
|
34
|
+
* a prism. Move the cursor to bend the chromatic bands with a diverging lens
|
|
35
|
+
* warp. Click anywhere to plant a new persistent wave source.
|
|
36
|
+
*
|
|
37
|
+
* @example
|
|
38
|
+
* <PrismaticWave
|
|
39
|
+
* sources={6}
|
|
40
|
+
* dispersion={280}
|
|
41
|
+
* lensStrength={1.2}
|
|
42
|
+
* style={{ position: "absolute", inset: 0 }}
|
|
43
|
+
* />
|
|
44
|
+
*/
|
|
45
|
+
export declare function PrismaticWave(props: PrismaticWaveProps): import("react/jsx-runtime").JSX.Element;
|
|
46
|
+
//# sourceMappingURL=PrismaticWave.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PrismaticWave.d.ts","sourceRoot":"","sources":["../../../src/components/backgrounds/PrismaticWave.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAqB,KAAK,aAAa,EAAE,MAAM,OAAO,CAAC;AAW9D,MAAM,WAAW,mBAAmB;IAClC,+CAA+C;IAC/C,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,uCAAuC;IACvC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,mCAAmC;IACnC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,8BAA8B;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uDAAuD;IACvD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,2DAA2D;IAC3D,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,4CAA4C;IAC5C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6BAA6B;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gCAAgC;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,2CAA2C;IAC3C,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,eAAO,MAAM,qBAAqB,EAAE,QAAQ,CAAC,mBAAmB,CAW/D,CAAC;AAIF,MAAM,WAAW,kBAAmB,SAAQ,mBAAmB;IAC7D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB;AAID;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,kBAAkB,2CAiJtD"}
|