memorio
Version:
Memorio, State + Observer and Store for a easy life
2 lines (1 loc) • 13.8 kB
JavaScript
var l=(e,r)=>()=>(e&&(r=e(e=0)),r);var q={};var v=l(()=>{"use strict";idb.db.create=(e,r=1)=>{idb.db.support();let o=indexedDB.open(e,r);o.onerror=()=>{console.error(`IndexedDB error: ${o.errorCode}`)},o.onsuccess=()=>{console.debug("Successful database connection")},o.onupgradeneeded=()=>{console.debug("Database created")},idb.db.list()}});var J={};var y=l(()=>{"use strict";idb.db.list=()=>(indexedDB.databases().then(e=>e).then(e=>{e&&(idbases=e)}).catch(e=>{console.error(e)}),idb.db.size(),idbases);setInterval(()=>{idb.db.list()},1e3)});var C={};var h=l(()=>{"use strict";idb.db.exist=e=>idbases?.find(r=>r.name===e)!==void 0});var R={};var j=l(()=>{"use strict";idb.db.quota=()=>navigator.storage.estimate()});var V={};var S=l(()=>{"use strict";idb.db.delete=e=>{if(console.log(`Remove ${e}...`),!!idb.db.exist(e))if(typeof layerpro=="function"){confirm(`Are you sure to remove "${e}" database?`,()=>{setTimeout(()=>{indexedDB.deleteDatabase(e),console.debug(`${e} removed`),idb.db.list()},1e3)},()=>alert("Operation cancelled."));return}else{confirm(`Are you sure to remove "${e}" database?`)?setTimeout(()=>{indexedDB.deleteDatabase(e),console.debug(`${e} removed`),idb.db.list()},1e3):alert("Operation cancelled.");return}}});var L={};var O=l(()=>{"use strict";idb.db.size=()=>{idbases?.map(e=>{if(!idb.db.exist(e))return null;let r=dphelper.array.findindex(idbases,e.name),o=indexedDB?.open(e.name,idb.db.version(e.name));return o.onerror=i=>console.error("Error on IndexedDB"),o.onsuccess=i=>{let t=i.target.result,s=[...t.objectStoreNames];((a,c)=>{let d=a.reduce((u,b)=>(u.push(idb.table.size(c,b)),u),[]);d.map(u=>{let b=u.reduce((z,B)=>z+B,0);return Number.parseInt(dphelper.dev.byteSize(b)),null}),idbases[r].size=d.length>0?d:0})(s,t)},null})}});var M={};var x=l(()=>{"use strict";idb.db.version=e=>{let r=0;for(let o of idbases){o.name===e&&(r=o.version);break}return r}});var Y={};var w=l(()=>{"use strict";idb.db.support=()=>{if("indexedDB"in window)return!0;console.error("Your browser doesn't support IndexedBD")}});var F={};var P=l(()=>{"use strict";idb.table.create=(e,r)=>{try{let o=Number(idb.db.version(e))+1,i=indexedDB.open(e,o);try{i.onupgradeneeded=t=>{let s=t.target,n=s.result,a=n.createObjectStore(r,{keyPath:"id",unique:!0,autoincrement:!0});a.createIndex("id","id"),a.createIndex("data","data"),n.close(),i?.result?.close(),i=void 0,idb.db.list()}}catch(t){console.error(">>",t);return}}catch(o){console.error(">>>",o);return}return!1}});var U={};var T=l(()=>{"use strict";idb.table.size=(e,r)=>(idb.db.list(),new Promise((o,i)=>{if(e==null)return i();let t=event,s=0;e=t.target.result;let n=e.transaction([r]).objectStore(r).openCursor();n.onsuccess=(a=>{let c=a.target.result;if(c){let d=c.value,u=JSON.stringify(d);s+=u.length,c.continue()}else o(s)}).bind(void 0),n.onerror=a=>i(`error in ${r}: ${a}`)}))});var k={};var D=l(()=>{"use strict";idb.data.delete=(e,r,o)=>{if(!idb.db.exist(e))return;let i=indexedDB.open(e,idb.db.version(e));i.onsuccess=()=>{let t=i.result,s=t.transaction(r,"readwrite");s.objectStore(r).put(o),i.onerror=a=>{console.debug(a,`Database insert error: ${a.target.errorCode}`)},s.onerror=a=>{console.debug(event,`Database insert error: ${a.target.errorCode}`)},t.close(),idb.db.list(),console.debug("Store inserted")}};idb.data.delete.all=(e,r)=>{idb.db.list();let o=indexedDB.open(e);o.onsuccess=i=>{let s=i.target.result.transaction(r).objectStore(r).set({});s.onsuccess=n=>{console.log(n)}}}});var G={};var E=l(()=>{"use strict";idb.data.set=(e,r,o)=>{if(!idb.exist(e))return;let i=indexedDB.open(e,idb.version(e));i.onsuccess=()=>{let t=i.result,s=t.transaction(r,"readwrite");s.objectStore(r).put(o),i.onerror=a=>{console.debug(a,`Database insert error: ${a.target.errorCode}`)},s.onerror=a=>{console.debug(event,`Database insert error: ${a.target.errorCode}`)},t.close(),idb.databases(),console.debug("IndexDB inserted")}}});var W={};var I,$=l(()=>{"use strict";idb.data.get=(e,r,o)=>{idb.db.list();let i=indexedDB.open(e);return i.onsuccess=t=>{let s=t.target.result,n=s.transaction(r).objectStore(r).get(o);n.onsuccess=a=>(I=n.result,n.result)},I}});import"dphelper.types";var p={name:"memorio",version:"1.7.0",type:"module",private:!1,main:"index.js",types:"index.d.ts",typings:"./types/*",description:"Memorio, State + Observer and Store for a easy life ",copyright:"Dario Passariello, BigLogic ca - a51.dev is a BigLogic project",homepage:"https://a51.gitbook.io/memorio",author:{name:"Dario Passariello",url:"https://dario.passariello.ca/",email:"dariopassariello@gmail.com"},support:{name:"Dario Passariello",url:"https://github.com/passariello/",email:"dariopassariello@gmail.com"},contributors:[{name:"Dario Passariello",email:"dariopassarielloa@gmail.com"},{name:"Valeria Cala Scaglitta",email:"valeriacalascaglitta@gmail.com"}],keywords:["biglogic","a51","memorio","state","store","observer","useObserver","dario","passariello"],funding:[{type:"patreon",url:"https://www.patreon.com/passariello"}],typing:["types/*"],scripts:{build:"node ./esbuild.config.mjs",watch:'nodemon --watch * --exec "npm run build "',test:"cd tests/jest && npm run test","-----------":"","npm:publish":"npm run build && npm publish ./dist"},dependencies:{"dphelper.types":"0.0.20"},devDependencies:{"@babel/eslint-parser":"^7.28.5","@eslint/js":"9.39.2","@testing-library/jest-dom":"6.9.1","@types/jest":"30.0.0","@types/node":"25.0.3","@typescript-eslint/parser":"8.51.0","@typescript-eslint/eslint-plugin":"8.51.0",cssnano:"7.1.2",esbuild:"0.27.2","esbuild-node-externals":"1.20.1","esbuild-plugin-alias":"0.2.1","esbuild-plugin-clean":"1.0.1","esbuild-plugin-copy":"2.1.1","esbuild-sass-plugin":"3.3.1","esbuild-scss-modules-plugin":"1.1.1",eslint:"9.39.2",jest:"30.2.0","jest-environment-jsdom":"30.2.0","ts-jest":"29.4.6","ts-loader":"^9.5.4","ts-node":"10.9.2",tslib:"^2.8.1",typescript:"5.9.3"}};Object.defineProperty(globalThis,"memorio",{value:{},writable:!1,configurable:!0,enumerable:!1});Object.defineProperty(globalThis,"events",{value:{},writable:!0,enumerable:!1});Object.defineProperty(memorio,"version",{writable:!1,enumerable:!1,value:p.version});var f=["list","state","store","idb","observer","useObserver","remove","removeAll"];Object.defineProperty(memorio,"dispatch",{writable:!1,enumerable:!1,value:{set:(e,r={})=>{dispatchEvent(new CustomEvent(String(e),r))},listen:(e,r=null,o=!1)=>{observer.list?.[e]?.length>0&&observer.remove(e);let i=t=>r?setTimeout(()=>r(t),1):null;globalThis.addEventListener(e,i),globalThis.events[e]=i},remove:e=>{globalThis.removeEventListener(e,globalThis.events[e]),delete globalThis.events[e]}}});memorio.propertyName=function(e,r){return String(r).replace("() => ","")};Object.defineProperty(memorio,"objPath",{writable:!1,enumerable:!1,value:(e,r,o=".")=>r.concat(e).join(o)});var g=(e,r,o=[])=>{let i=t=>{let s=t.split(".");s.forEach((n,a)=>{let c=s.slice(0,a+1).join(".");globalThis.memorio.dispatch.set(c,{detail:{name:c}})})};return new Proxy(e,{get(t,s){if(s==="list")return console.log('Some state could be hidden when you use "state.list". Use "state" to see the complete list '),JSON.parse(JSON.stringify(state));if(s==="remove")return function(n){return delete t[n],!0};if(s==="removeAll")return function(){try{for(let n in t)typeof t[n]!="function"&&!["list","remove","removeAll"].includes(n)&&(Object.isFrozen(t[n])||delete t[n],delete t[n])}catch(n){console.error(n)}};if(Object.isFrozen(t[s]))return t[s];try{let n=Reflect.get(t,s);return n&&typeof n=="object"&&["Array","Object"].includes(n.constructor.name)?g(n,r,o.concat(s)):n}catch(n){console.error("Error: ",n);return}},set(t,s,n){if(f.includes(s))return console.error("key "+s+" is protected"),!1;if(t[s]&&typeof t[s]=="object"&&Object.isFrozen(t[s]))return console.error(`Error: state '${s}' is locked`),!1;try{let a=globalThis.memorio.objPath(s,o);return r({action:"set",path:a,target:t,newValue:n,previousValue:Reflect.get(t,s)}),i("state."+a),Reflect.set(t,s,n),t[s]&&typeof t[s]=="object"&&Reflect.defineProperty(t[s],"lock",{value(){Object.defineProperty(t,s,{writable:!1,enumerable:!1}),Object.freeze(t[s])}}),!0}catch(a){console.error("Error in set trap:",a);return}},deleteProperty(t,s){try{let n=globalThis.memorio.objPath(s,o);return r({action:"delete",path:n,target:t}),Reflect.deleteProperty(t,s)}catch(n){console.error("Error in deleteProperty trap:",n);return}}})};globalThis?.state?globalThis.state=state:globalThis.state=g({},()=>{});var m=new WeakSet;m.add(state);setInterval(()=>{if(!m.has(state)){alert("Memorio state is compromised, check if you override it and please reload the page");for(let e=1;e<99999;e++)clearInterval(e);stop()}},1e3);Object.defineProperty(globalThis,"state",{enumerable:!1,configurable:!0});globalThis.observer||(globalThis.observer=null);Object.defineProperty(globalThis,"observer",{enumerable:!1,configurable:!0});observer=(e,r=null,o=!0)=>{try{if(!(t=>t.split(".")[0]!=="state"?(console.error(`Observer Error: You need to declare 'state.' or 'store.'. The '${t}' string is incorrect!`),!1):!0)(e))return}catch(i){console.error(i);return}if(!e&&!r){console.error("Observer Error: You need to setup observer correctly, Some parameters are missed!");return}if(!e&&r){console.error("Observer Error: You need to declare what state need to be monitored as string like 'state.test'.");return}if(e&&!r){let i=(String(e),{detail:{name:String(e)}});globalThis.observer.list[e]&&globalThis.memorio.dispatch.remove(i),globalThis.observer.list[e]||globalThis.memorio.dispatch.listen(i),console.debug("called: ",e);return}if(e&&r){if(typeof e!="string"||typeof r!="function"){console.error("Observer Error: name of state need to be a 'string' like 'state.test' and the callback need to be a 'function'");return}globalThis.observer.list[e]&&globalThis.memorio.dispatch.remove(e,r,o),globalThis.observer.list[e]||globalThis.memorio.dispatch.listen(e,r,o);return}};Object.defineProperties(observer,{list:{get:()=>globalThis.events},remove:{value:e=>{e&&(globalThis.memorio.dispatch.remove(e),delete globalThis.events[e])}},removeAll:{get:()=>{Object.entries(observer.list).forEach(e=>{globalThis.events[e[0]]})}}});Object.freeze(observer);globalThis.useObserver||(globalThis.useObserver=null);Object.defineProperty(globalThis,"useObserver",{enumerable:!1,configurable:!0});useObserver=(e,r)=>{let o=memorio.propertyName(state,r);try{return observer(o,()=>e()),!0}catch(i){console.error(i);return}};Object.freeze(useObserver);Object.defineProperty(globalThis,"store",{value:new Proxy({},{}),enumerable:!1,configurable:!0});Object.defineProperties(store,{get:{value(e){if(e){try{let r=localStorage.getItem(e);return r&&JSON.parse(r)}catch(r){console.error(`Error parsing store item '${e}':`,r)}return null}}},set:{value(e,r){if(e){try{r==null?localStorage.setItem(e,JSON.stringify(null)):typeof r=="object"||typeof r=="number"||typeof r=="boolean"||typeof r=="string"?localStorage.setItem(e,JSON.stringify(r)):typeof r=="function"&&console.error("It's not secure to store functions.")}catch(o){console.error(`Error setting store item '${e}':`,o)}return null}}},remove:{value(e){if(e)return localStorage.getItem(e)?(localStorage.removeItem(e),!0):!1}},delete:{value(e){return store.remove(e),!0}},removeAll:{value(){return localStorage.clear(),!0}},clearAll:{value(){return store.removeAll(),!0}},quota:{value(){"storage"in navigator&&"estimate"in navigator.storage&&navigator.storage.estimate().then(({usage:e,quota:r})=>(e&&r&&console.debug(`Using ${e/1024} out of ${r/1024} Mb.`),[e/1024,r/1024])).catch(e=>{console.error("Error estimating quota:",e)})}},size:{value(){let e=0;for(let r in localStorage)if(localStorage.hasOwnProperty(r)){let o=localStorage.getItem(r);o&&(e+=o.length)}return e}}});Object.freeze(store);Object.defineProperty(globalThis,"session",{value:new Proxy({},{}),enumerable:!1,configurable:!0});Object.defineProperties(session,{get:{value(e){if(e)try{let r=sessionStorage.getItem(e);return r&&JSON.parse(r)}catch(r){console.error(`Error parsing session item '${e}':`,r)}}},set:{value(e,r){if(e)try{r==null?sessionStorage.setItem(e,JSON.stringify(null)):typeof r=="object"||typeof r=="number"||typeof r=="boolean"||typeof r=="string"?sessionStorage.setItem(e,JSON.stringify(r)):typeof r=="function"&&console.error("It's not secure to session functions.")}catch(o){console.error(`Error setting session item '${e}':`,o)}}},remove:{value(e){if(e&&sessionStorage.getItem(e))return sessionStorage.removeItem(e),!0}},delete:{value(e){return session.remove(e),!0}},removeAll:{value(){return sessionStorage.clear(),!0}},clearAll:{value(){return session.removeAll(),!0}},quota:{value(){"storage"in navigator&&"estimate"in navigator.storage&&navigator.storage.estimate().then(({usage:e,quota:r})=>{e&&r&&console.debug(`Using ${e/1024} out of ${r/1024} Mb.`)}).catch(e=>{console.error("Error estimating quota:",e)})}},size:{value(){let e=0;for(let r in sessionStorage)if(sessionStorage.hasOwnProperty(r)){let o=sessionStorage.getItem(r);o&&(e+=o.length)}return e}}});Object.freeze(session);Object.defineProperty(window,"cache",{value:new Proxy({},{}),enumerable:!1,configurable:!0});Object.defineProperty(window,"idb",{value:{db:{},table:{},data:{}},writable:!0,configurable:!0,enumerable:!1}),Object.defineProperty(window,"idbases",{value:[],writable:!0,configurable:!0,enumerable:!1}),Promise.resolve().then(()=>v()),Promise.resolve().then(()=>y()),Promise.resolve().then(()=>h()),Promise.resolve().then(()=>j()),Promise.resolve().then(()=>S()),Promise.resolve().then(()=>O()),Promise.resolve().then(()=>x()),Promise.resolve().then(()=>w()),Promise.resolve().then(()=>P()),Promise.resolve().then(()=>T()),Promise.resolve().then(()=>D()),Promise.resolve().then(()=>E()),Promise.resolve().then(()=>$()),Object.preventExtensions(idb),Object.seal(idb),Object.freeze(idb);