2025-02-12 16:09:59 -05:00
|
|
|
export {}
|
|
|
|
declare global
|
|
|
|
{
|
|
|
|
namespace Van {
|
|
|
|
|
|
|
|
interface State<T> {
|
|
|
|
val: T
|
|
|
|
readonly oldVal: T
|
|
|
|
readonly rawVal: T
|
|
|
|
}
|
|
|
|
|
|
|
|
// Defining readonly view of State<T> for covariance.
|
|
|
|
// Basically we want StateView<string> to implement StateView<string | number>
|
|
|
|
type StateView<T> = Readonly<State<T>>
|
|
|
|
|
|
|
|
type Val<T> = State<T> | T
|
|
|
|
|
|
|
|
type Primitive = string | number | boolean | bigint
|
|
|
|
|
|
|
|
// deno-lint-ignore no-explicit-any
|
|
|
|
type PropValue = Primitive | ((e: any) => void) | null
|
|
|
|
|
|
|
|
type PropValueOrDerived = PropValue | StateView<PropValue> | (() => PropValue)
|
|
|
|
|
|
|
|
type Props = Record<string, PropValueOrDerived> & { class?: PropValueOrDerived; is?: string }
|
|
|
|
|
|
|
|
type PropsWithKnownKeys<ElementType> = Partial<{[K in keyof ElementType]: PropValueOrDerived}>
|
|
|
|
|
|
|
|
type ValidChildDomValue = Primitive | Node | null | undefined
|
|
|
|
|
|
|
|
type BindingFunc = ((dom?: Node) => ValidChildDomValue) | ((dom?: Element) => Element)
|
|
|
|
|
|
|
|
type ChildDom = ValidChildDomValue | StateView<Primitive | null | undefined> | BindingFunc | readonly ChildDom[]
|
|
|
|
|
|
|
|
type TagFunc<Result> = (first?: Props & PropsWithKnownKeys<Result> | ChildDom, ...rest: readonly ChildDom[]) => Result
|
|
|
|
|
|
|
|
type Tags = Readonly<Record<string, TagFunc<Element>>> & {
|
|
|
|
[K in keyof HTMLElementTagNameMap]: TagFunc<HTMLElementTagNameMap[K]>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
const van:{
|
|
|
|
readonly state: <T>(initVal: T, HMRKey?:string)=> 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
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
namespace VanX
|
|
|
|
{
|
|
|
|
type StateOf<T> = { readonly [K in keyof T]: Van.State<T[K]> }
|
|
|
|
type ValueType<T> = T extends (infer V)[] ? V : T[keyof T]
|
|
|
|
type KeyType<T> = T extends unknown[] ? number : string
|
|
|
|
type ReplacementFunc<T> =
|
|
|
|
T extends (infer V)[] ? (items: V[]) => readonly V[] :
|
|
|
|
(items: [string, T[keyof T]][]) => readonly [string, T[keyof T]][]
|
|
|
|
}
|
|
|
|
const vanX:{
|
|
|
|
readonly calc: <R>(f: () => R) => R
|
|
|
|
readonly reactive: <T extends object>(obj: T, HMRKey?:string) => 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
|
2025-02-19 17:01:11 -05:00
|
|
|
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
|
2025-02-12 16:09:59 -05:00
|
|
|
readonly replace: <T extends object>(obj: T, replacement: VanX.ReplacementFunc<T> | T) => T
|
|
|
|
readonly compact: <T extends object>(obj: T) => T
|
2025-02-22 16:38:11 -05:00
|
|
|
// my addition
|
|
|
|
readonly Store: <T extends object>(obj:T, key:string)=>T
|
2025-02-12 16:09:59 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
namespace Gale {
|
|
|
|
type KeyQuery = "@";
|
|
|
|
type KeyPseudo = ":";
|
|
|
|
type KeyChild = ".";
|
|
|
|
type KeyGroup = "^";
|
|
|
|
type UserStyles = Partial<CSSStyleDeclaration> & {[key: `${KeyQuery|KeyPseudo|KeyChild|KeyGroup}${string}`]: UserStyles }
|
|
|
|
type UserSheet = Record<string, UserStyles>
|
|
|
|
type CollectKeys<Obj> = {[Key in keyof Obj]: Obj[Key] extends object ? Key | CollectKeys<Obj[Key]> : Key }[keyof Obj]
|
|
|
|
type FilterKeys<Keys> = Keys extends `${KeyChild|KeyGroup}${infer Rest}` ? Keys : never
|
|
|
|
type CrossMultiply<A, B> = A extends string ? B extends string ? `${A}${B}` : never : never
|
|
|
|
type CrossMultiplyRecord<Rec> = keyof Rec | { [K in keyof Rec]: K extends string ? CrossMultiply<K, FilterKeys<CollectKeys<Rec[K]>>> : never }[keyof Rec]
|
|
|
|
type Tier = (selector:string, obj:UserStyles)=>string;
|
2025-02-13 14:27:41 -05:00
|
|
|
type CreateSheet = <T extends UserSheet>(sheet:UserSheet&T)=> ((...args:CrossMultiplyRecord<T>[])=>string)&{CSS:string, DOM:Elemental<CrossMultiplyRecord<T>>}
|
2025-02-12 17:09:58 -05:00
|
|
|
|
2025-02-13 14:27:41 -05:00
|
|
|
|
2025-02-12 17:09:58 -05:00
|
|
|
type Elemental<T extends string> = {[K in keyof HTMLElementTagNameMap]: Circular<T, K>}
|
|
|
|
type Circular<Keys extends string, ElementName extends keyof HTMLElementTagNameMap> = {
|
|
|
|
[K in Keys]: Circular<Keys, ElementName>&Van.TagFunc<HTMLElementTagNameMap[ElementName]>;
|
|
|
|
};
|
2025-02-13 14:27:41 -05:00
|
|
|
|
2025-02-12 16:09:59 -05:00
|
|
|
}
|
2025-02-22 16:38:11 -05:00
|
|
|
const Gale:Gale.CreateSheet
|
2025-02-12 16:09:59 -05:00
|
|
|
}
|