van as ambient
This commit is contained in:
		
							parent
							
								
									33bc665cb8
								
							
						
					
					
						commit
						9c9717bdec
					
				
							
								
								
									
										7
									
								
								app.js
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								app.js
									
									
									
									
									
								
							| @ -1 +1,6 @@ | |||||||
| /** @type {Van.State<number>} */ | const state = van.state(7); | ||||||
|  | van.add(document.body, van.tags.div({onclick() | ||||||
|  |     { | ||||||
|  |         state.val++; | ||||||
|  |     } | ||||||
|  | }, state)); | ||||||
| @ -10,7 +10,6 @@ | |||||||
|     ] |     ] | ||||||
|   }, |   }, | ||||||
|   "imports": { |   "imports": { | ||||||
|     "test": "https://esm.sh/react", |  | ||||||
|     "entry": "./app.js" |     "entry": "./app.js" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										34
									
								
								index.html
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								index.html
									
									
									
									
									
								
							| @ -3,13 +3,16 @@ | |||||||
|         <meta charset="UTF-8"> |         <meta charset="UTF-8"> | ||||||
|         <meta name="viewport" content="width=device-width, initial-scale=1.0"> |         <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||||
|         <title>Document</title> |         <title>Document</title> | ||||||
|         <script type="module"> |  | ||||||
|             import "./global.js"; |  | ||||||
|             console.log(window.test); |  | ||||||
|         </script> |  | ||||||
|         <!-- |  | ||||||
|         <script> |         <script> | ||||||
|             fetch('./deno.json').then(resp=>resp.json()).then(json=> |             // van: | ||||||
|  |             {let e,t,r,o,n,l,s,i,f,h,w,a,d,u,_,c,S,g,y,b,m,v,j,x,O;s=Object.getPrototypeOf,f={},h=s(i={isConnected:1}),w=s(s),a=(e,t,r,o)=>(e??(setTimeout(r,o),new Set)).add(t),d=(e,t,o)=>{let n=r;r=t;try{return e(o)}catch(e){return console.error(e),o}finally{r=n}},u=e=>e.filter(e=>e.t?.isConnected),_=e=>n=a(n,e,()=>{for(let e of n)e.o=u(e.o),e.l=u(e.l);n=l},1e3),c={get val(){return r?.i?.add(this),this.rawVal},get oldVal(){return r?.i?.add(this),this.h},set val(o){r?.u?.add(this),o!==this.rawVal&&(this.rawVal=o,this.o.length+this.l.length?(t?.add(this),e=a(e,this,x)):this.h=o)}},S=e=>({__proto__:c,rawVal:e,h:e,o:[],l:[]}),g=(e,t)=>{let r={i:new Set,u:new Set},n={f:e},l=o;o=[];let s=d(e,r,t);s=(s??document).nodeType?s:new Text(s);for(let e of r.i)r.u.has(e)||(_(e),e.o.push(n));for(let e of o)e.t=s;return o=l,n.t=s},y=(e,t=S(),r)=>{let n={i:new Set,u:new Set},l={f:e,s:t};l.t=r??o?.push(l)??i,t.val=d(e,n,t.rawVal);for(let e of n.i)n.u.has(e)||(_(e),e.l.push(l));return t},b=(e,...t)=>{for(let r of t.flat(1/0)){let t=s(r??0),o=t===c?g(()=>r.val):t===w?g(r):r;o!=l&&e.append(o)}return e},m=(e,t,...r)=>{let[{is:o,...n},...i]=s(r[0]??0)===h?r:[{},...r],a=e?document.createElementNS(e,t,{is:o}):document.createElement(t,{is:o});for(let[e,r]of Object.entries(n)){let o=t=>t?Object.getOwnPropertyDescriptor(t,e)??o(s(t)):l,n=t+","+e,i=f[n]??=o(s(a))?.set??0,h=e.startsWith("on")?(t,r)=>{let o=e.slice(2);a.removeEventListener(o,r),a.addEventListener(o,t)}:i?i.bind(a):a.setAttribute.bind(a,e),d=s(r??0);e.startsWith("on")||d===w&&(r=y(r),d=c),d===c?g(()=>(h(r.val,r.h),a)):h(r)}return b(a,i)},v=e=>({get:(t,r)=>m.bind(l,e,r)}),j=(e,t)=>t?t!==e&&e.replaceWith(t):e.remove(),x=()=>{let r=0,o=[...e].filter(e=>e.rawVal!==e.h);do{t=new Set;for(let e of new Set(o.flatMap(e=>e.l=u(e.l))))y(e.f,e.s,e.t),e.t=l}while(++r<100&&(o=[...t]).length);let n=[...e].filter(e=>e.rawVal!==e.h);e=l;for(let e of new Set(n.flatMap(e=>e.o=u(e.o))))j(e.t,g(e.f,e.t)),e.t=l;for(let e of n)e.h=e.rawVal},O={tags:new Proxy(e=>new Proxy(m,v(e)),v()),hydrate:(e,t)=>j(e,g(t,e)),add:b,state:S,derive:y},window.van=O;} | ||||||
|  |              | ||||||
|  |             // vanX: | ||||||
|  |             {let e,t,r,{fromEntries:o,entries:l,keys:n,hasOwn:f,getPrototypeOf:a}=Object,{get:i,set:y,deleteProperty:c,ownKeys:s}=Reflect,{state:m,derive:d,add:u}=van,b=1e3,w=Symbol(),A=Symbol(),S=Symbol(),_=Symbol(),g=Symbol(),p=Symbol(),P=e=>(e[A]=1,e),v=e=>e instanceof Object&&!(e instanceof Function)&&!e[p],h=e=>{if(e?.[A]){let t=m();return d(()=>{let r=e();v(t.rawVal)&&v(r)?B(t.rawVal,r):t.val=x(r)}),t}return m(x(e))},F=e=>{let t=Array.isArray(e)?[]:{__proto__:a(e)};for(let[r,o]of l(e))t[r]=h(o);return t[S]=[],t[_]=m(1),t},O={get:(e,t,r)=>t===w?e:f(e,t)?Array.isArray(e)&&"length"===t?(e[_].val,e.length):e[t].val:i(e,t,r),set:(e,o,l,n)=>f(e,o)?Array.isArray(e)&&"length"===o?(l!==e.length&&++e[_].val,e.length=l,1):(e[o].val=x(l),1):o in e?y(e,o,l,n):y(e,o,h(l))&&(++e[_].val,C(e).forEach(E.bind(t,n,o,e[o],r)),1),deleteProperty:(e,t)=>(c(e,t)&&R(e,t),++e[_].val),ownKeys:e=>(e[_].val,s(e))},x=e=>!v(e)||e[w]?e:new Proxy(F(e),O),D=e=>(e[p]=1,e),j=e=>e[w],K=a(m()),N=e=>new Proxy(e,{get:(e,t,r)=>a(e[t]??0)===K?{val:k(e[t].rawVal)}:i(e,t,r)}),k=e=>e?.[w]?new Proxy(N(e[w]),O):e,C=e=>e[S]=e[S].filter(e=>e.t.isConnected),E=(e,t,r,o,{t:l,f:f})=>{let a=Array.isArray(e),i=a?Number(t):t;u(l,()=>l[g][t]=f(r,()=>delete e[t],i)),a&&!o&&i!==e.length-1&&l.insertBefore(l.lastChild,l[g][n(e).find(e=>Number(e)>i)])},R=(e,t)=>{for(let r of C(e)){let e=r.t[g];e[t]?.remove(),delete e[t]}},T=r=>(e??(setTimeout(()=>(e.forEach(C),e=t),b),e=new Set)).add(r),q=(e,t,r)=>{let o={t:e instanceof Function?e():e,f:r},n=t[w];o.t[g]={},n[S].push(o),T(n);for(let[e,r]of l(n))E(t,e,r,1,o);return o.t},z=(e,t)=>{for(let[r,o]of l(t)){let t=e[r];v(t)&&v(o)?z(t,o):e[r]=o}for(let r in e)f(t,r)||delete e[r];let r=n(t),o=Array.isArray(e);if(o||n(e).some((e,t)=>e!==r[t])){let l=e[w];if(o)e.length=t.length;else{++l[_].val;let e={...l};for(let e of r)delete l[e];for(let t of r)l[t]=e[t]}for(let{t:e}of C(l)){let{firstChild:t,[g]:o}=e;for(let l of r)t===o[l]?t=t.nextSibling:e.insertBefore(o[l],t)}}return e},B=(e,n)=>{r=1;try{return z(e,n instanceof Function?Array.isArray(e)?n(e.filter(e=>1)):o(n(l(e))):n)}finally{r=t}},G=e=>Array.isArray(e)?e.filter(e=>1).map(G):v(e)?o(l(e).map(([e,t])=>[e,G(t)])):e;window.vanX={calc:P,reactive:x,noreactive:D,stateFields:j,raw:k,list:q,replace:B,compact:G}} | ||||||
|  | 
 | ||||||
|  |              | ||||||
|  |             const root = "/"; | ||||||
|  |             fetch(root + 'deno.json').then(resp=>resp.json()).then(json=> | ||||||
|             { |             { | ||||||
|                 const s=(type, content)=>{ |                 const s=(type, content)=>{ | ||||||
|                     let script = document.createElement('script'); |                     let script = document.createElement('script'); | ||||||
| @ -17,20 +20,19 @@ | |||||||
|                     script.textContent = content; |                     script.textContent = content; | ||||||
|                     document.head.appendChild(script); |                     document.head.appendChild(script); | ||||||
|                 }; |                 }; | ||||||
|  |                  | ||||||
|  |                 for(let key in json.imports) | ||||||
|  |                 { | ||||||
|  |                     const value = json.imports[key]; | ||||||
|  |                     if(value.startsWith("./")) | ||||||
|  |                     { | ||||||
|  |                         json.imports[key] = root + value.substring(2); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|                 s("importmap", JSON.stringify({imports:json.imports})) |                 s("importmap", JSON.stringify({imports:json.imports})) | ||||||
|                 s("module", `import "entry";`); |                 s("module", `import "entry";`); | ||||||
|             }); |             }); | ||||||
|         </script> |         </script> | ||||||
| 
 |  | ||||||
|         <script> |  | ||||||
| // van: |  | ||||||
| {let e,t,r,o,n,l,s,i,f,h,w,a,d,u,_,c,S,g,y,b,m,v,j,x,O;s=Object.getPrototypeOf,f={},h=s(i={isConnected:1}),w=s(s),a=(e,t,r,o)=>(e??(setTimeout(r,o),new Set)).add(t),d=(e,t,o)=>{let n=r;r=t;try{return e(o)}catch(e){return console.error(e),o}finally{r=n}},u=e=>e.filter(e=>e.t?.isConnected),_=e=>n=a(n,e,()=>{for(let e of n)e.o=u(e.o),e.l=u(e.l);n=l},1e3),c={get val(){return r?.i?.add(this),this.rawVal},get oldVal(){return r?.i?.add(this),this.h},set val(o){r?.u?.add(this),o!==this.rawVal&&(this.rawVal=o,this.o.length+this.l.length?(t?.add(this),e=a(e,this,x)):this.h=o)}},S=e=>({__proto__:c,rawVal:e,h:e,o:[],l:[]}),g=(e,t)=>{let r={i:new Set,u:new Set},n={f:e},l=o;o=[];let s=d(e,r,t);s=(s??document).nodeType?s:new Text(s);for(let e of r.i)r.u.has(e)||(_(e),e.o.push(n));for(let e of o)e.t=s;return o=l,n.t=s},y=(e,t=S(),r)=>{let n={i:new Set,u:new Set},l={f:e,s:t};l.t=r??o?.push(l)??i,t.val=d(e,n,t.rawVal);for(let e of n.i)n.u.has(e)||(_(e),e.l.push(l));return t},b=(e,...t)=>{for(let r of t.flat(1/0)){let t=s(r??0),o=t===c?g(()=>r.val):t===w?g(r):r;o!=l&&e.append(o)}return e},m=(e,t,...r)=>{let[{is:o,...n},...i]=s(r[0]??0)===h?r:[{},...r],a=e?document.createElementNS(e,t,{is:o}):document.createElement(t,{is:o});for(let[e,r]of Object.entries(n)){let o=t=>t?Object.getOwnPropertyDescriptor(t,e)??o(s(t)):l,n=t+","+e,i=f[n]??=o(s(a))?.set??0,h=e.startsWith("on")?(t,r)=>{let o=e.slice(2);a.removeEventListener(o,r),a.addEventListener(o,t)}:i?i.bind(a):a.setAttribute.bind(a,e),d=s(r??0);e.startsWith("on")||d===w&&(r=y(r),d=c),d===c?g(()=>(h(r.val,r.h),a)):h(r)}return b(a,i)},v=e=>({get:(t,r)=>m.bind(l,e,r)}),j=(e,t)=>t?t!==e&&e.replaceWith(t):e.remove(),x=()=>{let r=0,o=[...e].filter(e=>e.rawVal!==e.h);do{t=new Set;for(let e of new Set(o.flatMap(e=>e.l=u(e.l))))y(e.f,e.s,e.t),e.t=l}while(++r<100&&(o=[...t]).length);let n=[...e].filter(e=>e.rawVal!==e.h);e=l;for(let e of new Set(n.flatMap(e=>e.o=u(e.o))))j(e.t,g(e.f,e.t)),e.t=l;for(let e of n)e.h=e.rawVal},O={tags:new Proxy(e=>new Proxy(m,v(e)),v()),hydrate:(e,t)=>j(e,g(t,e)),add:b,state:S,derive:y},window.van=O;} |  | ||||||
| // vanX: |  | ||||||
| {let e,t,r,{fromEntries:o,entries:l,keys:n,hasOwn:f,getPrototypeOf:a}=Object,{get:i,set:y,deleteProperty:c,ownKeys:s}=Reflect,{state:m,derive:d,add:u}=van,b=1e3,w=Symbol(),A=Symbol(),S=Symbol(),_=Symbol(),g=Symbol(),p=Symbol(),P=e=>(e[A]=1,e),v=e=>e instanceof Object&&!(e instanceof Function)&&!e[p],h=e=>{if(e?.[A]){let t=m();return d(()=>{let r=e();v(t.rawVal)&&v(r)?B(t.rawVal,r):t.val=x(r)}),t}return m(x(e))},F=e=>{let t=Array.isArray(e)?[]:{__proto__:a(e)};for(let[r,o]of l(e))t[r]=h(o);return t[S]=[],t[_]=m(1),t},O={get:(e,t,r)=>t===w?e:f(e,t)?Array.isArray(e)&&"length"===t?(e[_].val,e.length):e[t].val:i(e,t,r),set:(e,o,l,n)=>f(e,o)?Array.isArray(e)&&"length"===o?(l!==e.length&&++e[_].val,e.length=l,1):(e[o].val=x(l),1):o in e?y(e,o,l,n):y(e,o,h(l))&&(++e[_].val,C(e).forEach(E.bind(t,n,o,e[o],r)),1),deleteProperty:(e,t)=>(c(e,t)&&R(e,t),++e[_].val),ownKeys:e=>(e[_].val,s(e))},x=e=>!v(e)||e[w]?e:new Proxy(F(e),O),D=e=>(e[p]=1,e),j=e=>e[w],K=a(m()),N=e=>new Proxy(e,{get:(e,t,r)=>a(e[t]??0)===K?{val:k(e[t].rawVal)}:i(e,t,r)}),k=e=>e?.[w]?new Proxy(N(e[w]),O):e,C=e=>e[S]=e[S].filter(e=>e.t.isConnected),E=(e,t,r,o,{t:l,f:f})=>{let a=Array.isArray(e),i=a?Number(t):t;u(l,()=>l[g][t]=f(r,()=>delete e[t],i)),a&&!o&&i!==e.length-1&&l.insertBefore(l.lastChild,l[g][n(e).find(e=>Number(e)>i)])},R=(e,t)=>{for(let r of C(e)){let e=r.t[g];e[t]?.remove(),delete e[t]}},T=r=>(e??(setTimeout(()=>(e.forEach(C),e=t),b),e=new Set)).add(r),q=(e,t,r)=>{let o={t:e instanceof Function?e():e,f:r},n=t[w];o.t[g]={},n[S].push(o),T(n);for(let[e,r]of l(n))E(t,e,r,1,o);return o.t},z=(e,t)=>{for(let[r,o]of l(t)){let t=e[r];v(t)&&v(o)?z(t,o):e[r]=o}for(let r in e)f(t,r)||delete e[r];let r=n(t),o=Array.isArray(e);if(o||n(e).some((e,t)=>e!==r[t])){let l=e[w];if(o)e.length=t.length;else{++l[_].val;let e={...l};for(let e of r)delete l[e];for(let t of r)l[t]=e[t]}for(let{t:e}of C(l)){let{firstChild:t,[g]:o}=e;for(let l of r)t===o[l]?t=t.nextSibling:e.insertBefore(o[l],t)}}return e},B=(e,n)=>{r=1;try{return z(e,n instanceof Function?Array.isArray(e)?n(e.filter(e=>1)):o(n(l(e))):n)}finally{r=t}},G=e=>Array.isArray(e)?e.filter(e=>1).map(G):v(e)?o(l(e).map(([e,t])=>[e,G(t)])):e;window.vanX={calc:P,reactive:x,noreactive:D,stateFields:j,raw:k,list:q,replace:B,compact:G}} |  | ||||||
|         </script> |  | ||||||
|         <script type="module" src="app.js"></script> |  | ||||||
|         --> |  | ||||||
| 
 |  | ||||||
|     </head> |     </head> | ||||||
|     <body> |     <body> | ||||||
|          |          | ||||||
|  | |||||||
							
								
								
									
										97
									
								
								van.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										97
									
								
								van.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -1,69 +1,74 @@ | |||||||
| export {} |  | ||||||
| declare global | declare global | ||||||
| { | { | ||||||
|   namespace VanX |   namespace VanX | ||||||
|   { |   { | ||||||
|       type StateOf<T> = { readonly [K in keyof T]: Van.State<T[K]> } |     type StateOf<T> = { readonly [K in keyof T]: Van.State<T[K]> } | ||||||
|       type ValueType<T> = T extends (infer V)[] ? V : T[keyof T] |     type ValueType<T> = T extends (infer V)[] ? V : T[keyof T] | ||||||
|       type KeyType<T> = T extends unknown[] ? number : string |     type KeyType<T> = T extends unknown[] ? number : string | ||||||
|       type ReplacementFunc<T> = |     type ReplacementFunc<T> = | ||||||
|           T extends (infer V)[] ? (items: V[]) => readonly V[] : |         T extends (infer V)[] ? (items: V[]) => readonly V[] : | ||||||
|           (items: [string, T[keyof T]][]) => readonly [string, T[keyof T]][] |         (items: [string, T[keyof T]][]) => readonly [string, T[keyof T]][] | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   namespace Van { |   namespace Van { | ||||||
| 
 | 
 | ||||||
|       interface State<T> { |     interface State<T> { | ||||||
|         val: T |       val: T | ||||||
|         readonly oldVal: T |       readonly oldVal: T | ||||||
|         readonly rawVal: T |       readonly rawVal: T | ||||||
|       } |     } | ||||||
|      |      | ||||||
|       // Defining readonly view of State<T> for covariance.
 |     // Defining readonly view of State<T> for covariance.
 | ||||||
|       // Basically we want StateView<string> to implement StateView<string | number>
 |     // Basically we want StateView<string> to implement StateView<string | number>
 | ||||||
|       type StateView<T> = Readonly<State<T>> |     type StateView<T> = Readonly<State<T>> | ||||||
|      |      | ||||||
|       type Val<T> = State<T> | T |     type Val<T> = State<T> | T | ||||||
|      |      | ||||||
|       type Primitive = string | number | boolean | bigint |     type Primitive = string | number | boolean | bigint | ||||||
|      |      | ||||||
|       // deno-lint-ignore no-explicit-any
 |     // deno-lint-ignore no-explicit-any
 | ||||||
|       type PropValue = Primitive | ((e: any) => void) | null |     type PropValue = Primitive | ((e: any) => void) | null | ||||||
|      |      | ||||||
|       type PropValueOrDerived = PropValue | StateView<PropValue> | (() => PropValue) |     type PropValueOrDerived = PropValue | StateView<PropValue> | (() => PropValue) | ||||||
|      |      | ||||||
|       type Props = Record<string, PropValueOrDerived> & { class?: PropValueOrDerived; is?: string } |     type Props = Record<string, PropValueOrDerived> & { class?: PropValueOrDerived; is?: string } | ||||||
|      |      | ||||||
|       type PropsWithKnownKeys<ElementType> = Partial<{[K in keyof ElementType]: PropValueOrDerived}> |     type PropsWithKnownKeys<ElementType> = Partial<{[K in keyof ElementType]: PropValueOrDerived}> | ||||||
|      |      | ||||||
|       type ValidChildDomValue = Primitive | Node | null | undefined |     type ValidChildDomValue = Primitive | Node | null | undefined | ||||||
|      |      | ||||||
|       type BindingFunc = ((dom?: Node) => ValidChildDomValue) | ((dom?: Element) => Element) |     type BindingFunc = ((dom?: Node) => ValidChildDomValue) | ((dom?: Element) => Element) | ||||||
|      |      | ||||||
|       type ChildDom = ValidChildDomValue | StateView<Primitive | null | undefined> | BindingFunc | readonly ChildDom[] |     type ChildDom = ValidChildDomValue | StateView<Primitive | null | undefined> | BindingFunc | readonly ChildDom[] | ||||||
|      |      | ||||||
|       type TagFunc<Result> = (first?: Props & PropsWithKnownKeys<Result> | ChildDom, ...rest: readonly ChildDom[]) => Result |     type TagFunc<Result> = (first?: Props & PropsWithKnownKeys<Result> | ChildDom, ...rest: readonly ChildDom[]) => Result | ||||||
|      |      | ||||||
|       type Tags = Readonly<Record<string, TagFunc<Element>>> & { |     type Tags = Readonly<Record<string, TagFunc<Element>>> & { | ||||||
|         [K in keyof HTMLElementTagNameMap]: TagFunc<HTMLElementTagNameMap[K]> |       [K in keyof HTMLElementTagNameMap]: TagFunc<HTMLElementTagNameMap[K]> | ||||||
|       } |     } | ||||||
|   } |   } | ||||||
|    |    | ||||||
|   const van:{ |   const van:MembersVan; | ||||||
|     readonly state: <T>(initVal: T)=> Van.State<T> |   const vanX:MembersVanX; | ||||||
|     readonly derive: <T>(f: () => T) => Van.State<T> |  | ||||||
|     readonly add: (dom: Element, ...children: readonly Van.ChildDom[]) => Element |  | ||||||
|     readonly tags: Van.Tags & ((namespaceURI: string) => Readonly<Record<string, Van.TagFunc<Element>>>) |  | ||||||
|     readonly hydrate: <T extends Node>(dom: T, f: (dom: T) => T | null | undefined) => T |  | ||||||
|   }; |  | ||||||
|   const vanX: { |  | ||||||
|     readonly calc: <R>(f: () => R) => R |  | ||||||
|     readonly reactive: <T extends object>(obj: T) => T |  | ||||||
|     readonly noreactive: <T extends object>(obj: T) => T |  | ||||||
|     readonly stateFields: <T extends object>(obj: T) => VanX.StateOf<T> |  | ||||||
|     readonly raw: <T extends object>(obj: T) => T |  | ||||||
|     readonly list: <T extends object, ElementType extends Element>(container: (() => ElementType) | ElementType, items: T,itemFunc: (v: Van.State<VanX.ValueType<T>>, deleter: () => void, k: VanX.KeyType<T>) => Node) => ElementType |  | ||||||
|     readonly replace: <T extends object>(obj: T, replacement: VanX.ReplacementFunc<T> | T) => T |  | ||||||
|     readonly compact: <T extends object>(obj: T) => T |  | ||||||
|   }; |  | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | type MembersVan = { | ||||||
|  |   readonly state: <T>(initVal: T)=> Van.State<T> | ||||||
|  |   readonly derive: <T>(f: () => T) => Van.State<T> | ||||||
|  |   readonly add: (dom: Element, ...children: readonly Van.ChildDom[]) => Element | ||||||
|  |   readonly tags: Van.Tags & ((namespaceURI: string) => Readonly<Record<string, Van.TagFunc<Element>>>) | ||||||
|  |   readonly hydrate: <T extends Node>(dom: T, f: (dom: T) => T | null | undefined) => T | ||||||
|  | } | ||||||
|  | type MembersVanX = { | ||||||
|  |   readonly calc: <R>(f: () => R) => R | ||||||
|  |   readonly reactive: <T extends object>(obj: T) => T | ||||||
|  |   readonly noreactive: <T extends object>(obj: T) => T | ||||||
|  |   readonly stateFields: <T extends object>(obj: T) => VanX.StateOf<T> | ||||||
|  |   readonly raw: <T extends object>(obj: T) => T | ||||||
|  |   readonly list: <T extends object, ElementType extends Element>(container: (() => ElementType) | ElementType, items: T,itemFunc: (v: Van.State<VanX.ValueType<T>>, deleter: () => void, k: VanX.KeyType<T>) => Node) => ElementType | ||||||
|  |   readonly replace: <T extends object>(obj: T, replacement: VanX.ReplacementFunc<T> | T) => T | ||||||
|  |   readonly compact: <T extends object>(obj: T) => T | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export const Van: MembersVan; | ||||||
|  | export const VanX: MembersVanX; | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user