summaryrefslogtreecommitdiff
path: root/internal/generator/templates/themes/dos/theme.js
diff options
context:
space:
mode:
Diffstat (limited to 'internal/generator/templates/themes/dos/theme.js')
-rw-r--r--internal/generator/templates/themes/dos/theme.js157
1 files changed, 157 insertions, 0 deletions
diff --git a/internal/generator/templates/themes/dos/theme.js b/internal/generator/templates/themes/dos/theme.js
new file mode 100644
index 0000000..1d913ac
--- /dev/null
+++ b/internal/generator/templates/themes/dos/theme.js
@@ -0,0 +1,157 @@
+
+ (function(){
+ if(document.documentElement.classList.contains('sno-splash-skip'))return;
+ var cv=document.getElementById('splash-gl-canvas');
+ if(!cv||typeof THREE==='undefined')return;
+ var raf,ren,sc,ca,drops=[],t0=performance.now();
+ function cleanup(){window.removeEventListener('resize',sz);if(raf)cancelAnimationFrame(raf);raf=null;if(ren)ren.dispose();ren=null;window._snonuxSplashWebGLCleanup=null;}
+ window._snonuxSplashWebGLCleanup=cleanup;
+ function sz(){var w=cv.clientWidth||2,h=cv.clientHeight||2;if(ren)ren.setSize(w,h,false);if(ca){ca.aspect=w/h;ca.updateProjectionMatrix();}}
+ ren=new THREE.WebGLRenderer({canvas:cv,antialias:false,alpha:true});ren.setClearColor(0,0);ren.setPixelRatio(1);
+ sc=new THREE.Scene();ca=new THREE.PerspectiveCamera(50,1,0.1,80);ca.position.z=20;
+ var geo=new THREE.PlaneGeometry(0.22,0.32);
+ for(var i=0;i<60;i++){
+ var mat=new THREE.MeshBasicMaterial({color:0x55ff55,transparent:true,opacity:0.3+Math.random()*0.4});
+ var m=new THREE.Mesh(geo,mat);
+ m.position.set((Math.random()-0.5)*28, Math.random()*22-11, (Math.random()-0.5)*5);
+ m.userData.speed=0.5+Math.random()*1.5;
+ sc.add(m); drops.push(m);
+ }
+ sz();window.addEventListener('resize',sz);
+ function loop(now){raf=requestAnimationFrame(loop);
+ for(var i=0;i<drops.length;i++){
+ drops[i].position.y-=drops[i].userData.speed*0.06;
+ if(drops[i].position.y<-12) drops[i].position.y=12;
+ }
+ ren.render(sc,ca);}
+ raf=requestAnimationFrame(loop);
+ })();
+
+
+ (function() {
+ var _wild = false, _snoTOffset = 0, _snoLastT = 0;
+ var scene, camera, renderer, clock;
+ var columns = [];
+
+ function initThree() {
+ scene = new THREE.Scene();
+ scene.background = new THREE.Color(0x000088);
+
+ camera = new THREE.PerspectiveCamera(60, window.innerWidth/window.innerHeight, 0.1, 200);
+ camera.position.set(0, 0, 40);
+
+ renderer = new THREE.WebGLRenderer({ canvas: document.getElementById('three-canvas'), antialias: false });
+ renderer.setSize(window.innerWidth, window.innerHeight);
+ renderer.setPixelRatio(1);
+ clock = new THREE.Clock();
+
+ var geo = new THREE.PlaneGeometry(0.35, 0.5);
+
+ for (var c = 0; c < 30; c++) {
+ var col = [];
+ var x = (c - 15) * 2.2;
+ var speed = 1.5 + Math.random() * 3;
+ var startY = Math.random() * 60 - 30;
+ for (var r = 0; r < 8; r++) {
+ var brightness = 1.0 - (r / 8) * 0.7;
+ var color = new THREE.Color(brightness * 0.33, brightness, brightness * 0.33);
+ var mat = new THREE.MeshBasicMaterial({ color: color, transparent: true, opacity: brightness * 0.5 });
+ var mesh = new THREE.Mesh(geo, mat);
+ mesh.position.set(x, startY - r * 0.7, 0);
+ scene.add(mesh);
+ col.push({ mesh: mesh, offset: r * 0.7 });
+ }
+ columns.push({ chars: col, x: x, speed: speed, y: startY });
+ }
+
+ window.addEventListener('resize', onResize);
+ animate();
+ }
+
+ function onResize() {
+ camera.aspect = window.innerWidth / window.innerHeight;
+ camera.updateProjectionMatrix();
+ renderer.setSize(window.innerWidth, window.innerHeight);
+ }
+
+ function animate() {
+ requestAnimationFrame(animate);
+ var realT = clock.getElapsedTime();
+ _snoTOffset += (realT - _snoLastT) * (_wild ? 9 : 0);
+ _snoLastT = realT;
+ var t = realT + _snoTOffset;
+ for (var c = 0; c < columns.length; c++) {
+ var col = columns[c];
+ var y = col.y - t * col.speed;
+ y = ((y % 60) + 60) % 60 - 30;
+ for (var r = 0; r < col.chars.length; r++) {
+ col.chars[r].mesh.position.y = y - col.chars[r].offset;
+ // Wild: each char jitters horizontally like corrupted RAM
+ if (_wild) { col.chars[r].mesh.position.x = col.x + (Math.random() - 0.5) * 2.5; }
+ else { col.chars[r].mesh.position.x = col.x; }
+ }
+ }
+ // Wild: camera lunges forward/back and sways like a CRT meltdown
+ if (_wild) {
+ camera.position.z = 40 + Math.sin(realT * 0.41) * 14;
+ camera.position.x = Math.sin(realT * 0.37) * 8;
+ camera.fov = 60 + Math.sin(realT * 0.53) * 16;
+ camera.updateProjectionMatrix();
+ } else {
+ camera.position.z = 40;
+ camera.position.x = 0;
+ if (camera.fov !== 60) { camera.fov = 60; camera.updateProjectionMatrix(); }
+ }
+ renderer.render(scene, camera);
+ }
+
+ initThree();
+
+ // DOS nav/wild effects — CRT glitch on navigate, system crash rain on wild
+ window.snonuxOpenEffect = function() {
+ // Slide in like a dialog box appearing on DOS screen
+ var modal = document.getElementById('post-modal');
+ if (modal) { modal.classList.add('sno-modal-slide'); setTimeout(function() { modal.classList.remove('sno-modal-slide'); }, 360); }
+ // CRT scan flash from top
+ var d = document.createElement('div');
+ d.style.cssText = 'position:fixed;top:0;left:0;right:0;height:4px;z-index:997;pointer-events:none;background:rgba(85,255,255,0.7);box-shadow:0 0 8px rgba(85,255,255,0.5);transition:top 0.28s linear,opacity 0.1s 0.28s';
+ document.body.appendChild(d);
+ setTimeout(function() { d.style.top='100vh'; setTimeout(function() { d.style.opacity='0'; setTimeout(function() { d.remove(); }, 120); }, 280); }, 15);
+ };
+ window.snonuxCloseEffect = function() {
+ var ov = document.querySelector('.overlay');
+ if (ov) { ov.classList.add('sno-fx-glitch'); setTimeout(function() { ov.classList.remove('sno-fx-glitch'); }, 280); }
+ };
+ window.snonuxScrollEffect = function(dir) {
+ var isDown = dir === 'down';
+ var thick = _wild ? '14px' : '5px';
+ var d = document.createElement('div');
+ // DOS/CRT: grey-to-white scanline
+ d.style.cssText = 'position:fixed;left:0;right:0;height:' + thick + ';z-index:9000;pointer-events:none;' +
+ 'background:linear-gradient(90deg,transparent,rgba(180,180,180,0.9),rgba(255,255,255,0.9),rgba(180,180,180,0.9),transparent);' +
+ (isDown ? 'top:0;' : 'bottom:0;') +
+ 'transition:transform 0.28s ease,opacity 0.28s ease;';
+ document.body.appendChild(d);
+ setTimeout(function() { d.style.transform = isDown ? 'translateY(100vh)' : 'translateY(-100vh)'; d.style.opacity='0'; }, 16);
+ setTimeout(function() { d.remove(); }, 360);
+ };
+ window.snonuxWildToggle = function() {
+ _wild = !_wild;
+ var b = document.getElementById('sno-wild-badge');
+ if (b) b.classList.toggle('sno-wild-on', _wild);
+ };
+ window.snonuxNavEffect = function() {
+ // CRT horizontal glitch
+ var ov = document.querySelector('.overlay');
+ if (ov) { ov.classList.add('sno-fx-glitch'); setTimeout(function() { ov.classList.remove('sno-fx-glitch'); }, 300); }
+ var d = document.createElement('div');
+ d.style.cssText = 'position:fixed;inset:0;z-index:998;pointer-events:none;background:rgba(85,255,85,0.12);transition:opacity 0.15s';
+ document.body.appendChild(d);
+ setTimeout(function() { d.style.opacity='0'; setTimeout(function() { d.remove(); }, 180); }, 25);
+ };
+ window.snonuxPageEffect = function() {
+ // System crash — scanline strobe
+ var ov = document.querySelector('.overlay');
+ if (ov) { ov.classList.add('sno-fx-glitch'); setTimeout(function() { ov.classList.remove('sno-fx-glitch'); setTimeout(function() { ov.classList.add('sno-fx-glitch'); setTimeout(function() { ov.classList.remove('sno-fx-glitch'); }, 280); }, 40); }, 310); }
+ };
+ })();