2025-02-12 08:00:45 -05:00
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8">
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
|
|
<title>Document</title>
|
|
|
|
</head>
|
2024-08-01 08:23:47 -04:00
|
|
|
<body>
|
2025-02-12 16:57:41 -05:00
|
|
|
<script src="https://vanjs.org/code/van-1.5.3.nomodule.min.js"></script>
|
2025-02-14 07:58:29 -05:00
|
|
|
<script>
|
|
|
|
//@ts-check
|
|
|
|
// hmr
|
|
|
|
const HMR = globalThis.HMR = {
|
|
|
|
Time: 0,
|
|
|
|
/** @type {Record<string, string>} */
|
|
|
|
Temp:{},
|
|
|
|
Tick()
|
|
|
|
{
|
|
|
|
for(const k in HMR.Temp)
|
|
|
|
{
|
|
|
|
sessionStorage.setItem(k, HMR.Temp[k]);
|
|
|
|
}
|
|
|
|
HMR.Temp = {};
|
|
|
|
HMR.Time = 0;
|
|
|
|
},
|
|
|
|
/** @type {(key:string, value:string)=>void} */
|
|
|
|
Save(key, value)
|
|
|
|
{
|
|
|
|
this.Temp[key] = value;
|
|
|
|
if(!this.Time)
|
|
|
|
{
|
|
|
|
this.Time = setTimeout(this.Tick, 500);
|
|
|
|
}
|
|
|
|
console.log("SAVE", key, value);
|
|
|
|
},
|
|
|
|
/** @type {(key:string)=>string|null} */
|
|
|
|
Load(key)
|
|
|
|
{
|
|
|
|
const value = sessionStorage.getItem(key);
|
|
|
|
console.log("LOAD", key, value);
|
|
|
|
return value;
|
|
|
|
},
|
|
|
|
|
|
|
|
/** @type {string|undefined} */
|
|
|
|
_ID: undefined,
|
|
|
|
_index: 0,
|
|
|
|
/** @type {(id:string|undefined = undefined)=>void} */
|
|
|
|
StartID(id)
|
|
|
|
{
|
|
|
|
this._index = 0;
|
|
|
|
this._ID = id;
|
|
|
|
},
|
|
|
|
NextID()
|
|
|
|
{
|
|
|
|
return this._ID ? this._ID + "_" + (this._index++) + "_" : "";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//bind Van
|
|
|
|
const origninalState = globalThis.van.state;
|
|
|
|
globalThis.van.state =(value, key="")=>
|
|
|
|
{
|
|
|
|
const type = typeof value;
|
|
|
|
let reader =d=>d;
|
|
|
|
let writer =d=>d?.toString() || null;
|
|
|
|
|
|
|
|
switch(type)
|
|
|
|
{
|
|
|
|
case "boolean" :
|
|
|
|
reader =(data)=> data === "true"; break;
|
|
|
|
case "number" :
|
|
|
|
reader = parseFloat; break;
|
|
|
|
case "object" :
|
|
|
|
reader = JSON.parse;
|
|
|
|
writer = JSON.stringify;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
const fullKey = "HMR_" + HMR.NextID() + key;
|
|
|
|
const stringValue = HMR.Load(fullKey);
|
|
|
|
const signal = origninalState((stringValue ? reader(stringValue) : value));
|
|
|
|
van.derive(()=>HMR.Save(fullKey, writer(signal.val)));
|
|
|
|
|
|
|
|
return signal;
|
|
|
|
};
|
|
|
|
|
|
|
|
</script>
|
2025-02-13 14:27:41 -05:00
|
|
|
<script src="./gale.js"></script>
|
2025-02-12 08:00:45 -05:00
|
|
|
<script type="module" src="app.js"></script>
|
2024-08-01 08:23:47 -04:00
|
|
|
</body>
|
|
|
|
</html>
|