@e280/sly 0.2.0-8 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +400 -98
- package/package.json +14 -7
- package/s/base/element.ts +76 -0
- package/s/base/index.ts +6 -0
- package/s/{views → base}/use.ts +22 -14
- package/s/base/utils/attr-watcher.ts +22 -0
- package/s/base/utils/reactor.ts +32 -0
- package/s/base/utils/states.ts +49 -0
- package/s/base/utils/use-attrs.ts +36 -0
- package/s/demo/demo.bundle.ts +6 -7
- package/s/demo/views/counter.ts +21 -24
- package/s/demo/views/demo.ts +9 -6
- package/s/demo/views/{incredi.ts → fastcount.ts} +7 -6
- package/s/demo/views/loaders.ts +7 -7
- package/s/dom/attrs/attrs.ts +21 -0
- package/s/dom/attrs/parts/attr-fns.ts +68 -0
- package/s/dom/attrs/parts/attr-proxies.ts +35 -0
- package/s/dom/attrs/parts/attr-spec.ts +29 -0
- package/s/dom/attrs/parts/on-attrs.ts +8 -0
- package/s/dom/dom.ts +23 -60
- package/s/dom/index.ts +4 -0
- package/s/dom/parts/dom-scope.ts +46 -0
- package/s/dom/parts/el.ts +14 -0
- package/s/dom/parts/elmer.ts +38 -0
- package/s/dom/parts/eve.ts +24 -0
- package/s/dom/parts/mk.ts +9 -0
- package/s/dom/parts/queries.ts +26 -0
- package/s/dom/{register.ts → parts/register.ts} +2 -10
- package/s/dom/types.ts +50 -0
- package/s/index.html.ts +4 -3
- package/s/index.ts +7 -20
- package/s/loaders/index.barrel.ts +10 -0
- package/s/loaders/index.ts +4 -0
- package/s/loaders/make.ts +14 -0
- package/s/loaders/mock.ts +11 -0
- package/s/{ops/loaders → loaders}/parts/anims.ts +1 -1
- package/s/{ops/loaders → loaders}/parts/ascii-anim.ts +6 -5
- package/s/{ops/loaders → loaders}/parts/error-display.ts +2 -2
- package/s/loaders/types.ts +6 -0
- package/s/loot/index.barrel.ts +5 -0
- package/s/loot/index.ts +2 -3
- package/s/ops/index.ts +5 -0
- package/s/ops/op.ts +1 -0
- package/s/spa/index.barrel.ts +6 -0
- package/s/spa/index.ts +4 -0
- package/s/spa/plumbing/braces.ts +76 -0
- package/s/spa/plumbing/primitives.ts +85 -0
- package/s/spa/plumbing/router-core.ts +49 -0
- package/s/spa/plumbing/types.ts +45 -0
- package/s/spa/router.ts +49 -0
- package/s/spa/spa.test.ts +91 -0
- package/s/tests.test.ts +4 -1
- package/s/view/index.ts +7 -0
- package/s/view/types.ts +39 -0
- package/s/view/utils/contextualize.ts +45 -0
- package/s/view/utils/make-component.ts +34 -0
- package/s/view/utils/make-view.ts +48 -0
- package/s/view/utils/parts/capsule.ts +67 -0
- package/s/view/utils/parts/chain.ts +40 -0
- package/s/view/utils/parts/context.ts +11 -0
- package/s/view/utils/parts/directive.ts +29 -0
- package/s/view/utils/parts/sly-view.ts +15 -0
- package/s/view/view.ts +24 -0
- package/x/base/css-reset.js.map +1 -0
- package/x/base/element.d.ts +19 -0
- package/x/base/element.js +52 -0
- package/x/base/element.js.map +1 -0
- package/x/base/index.d.ts +4 -0
- package/x/base/index.js +5 -0
- package/x/base/index.js.map +1 -0
- package/x/{views → base}/use.d.ts +6 -2
- package/x/{views → base}/use.js +13 -8
- package/x/base/use.js.map +1 -0
- package/x/base/utils/apply-styles.js.map +1 -0
- package/x/base/utils/attr-watcher.d.ts +8 -0
- package/x/base/utils/attr-watcher.js +20 -0
- package/x/base/utils/attr-watcher.js.map +1 -0
- package/x/base/utils/mounts.js.map +1 -0
- package/x/base/utils/reactor.d.ts +5 -0
- package/x/base/utils/reactor.js +25 -0
- package/x/base/utils/reactor.js.map +1 -0
- package/x/base/utils/states.d.ts +13 -0
- package/x/base/utils/states.js +41 -0
- package/x/base/utils/states.js.map +1 -0
- package/x/base/utils/use-attrs.d.ts +11 -0
- package/x/base/utils/use-attrs.js +18 -0
- package/x/base/utils/use-attrs.js.map +1 -0
- package/x/demo/demo.bundle.js +6 -6
- package/x/demo/demo.bundle.js.map +1 -1
- package/x/demo/demo.bundle.min.js +17 -23
- package/x/demo/demo.bundle.min.js.map +4 -4
- package/x/demo/views/counter.d.ts +374 -1
- package/x/demo/views/counter.js +19 -22
- package/x/demo/views/counter.js.map +1 -1
- package/x/demo/views/demo.d.ts +4 -1
- package/x/demo/views/demo.js +9 -5
- package/x/demo/views/demo.js.map +1 -1
- package/x/demo/views/{incredi.d.ts → fastcount.d.ts} +3 -3
- package/x/demo/views/{incredi.js → fastcount.js} +6 -6
- package/x/demo/views/fastcount.js.map +1 -0
- package/x/demo/views/loaders.js +6 -6
- package/x/demo/views/loaders.js.map +1 -1
- package/x/dom/attrs/attrs.d.ts +23 -0
- package/x/dom/attrs/attrs.js +17 -0
- package/x/dom/attrs/attrs.js.map +1 -0
- package/x/dom/attrs/parts/attr-fns.d.ts +16 -0
- package/x/dom/attrs/parts/attr-fns.js +64 -0
- package/x/dom/attrs/parts/attr-fns.js.map +1 -0
- package/x/dom/attrs/parts/attr-proxies.d.ts +8 -0
- package/x/dom/attrs/parts/attr-proxies.js +21 -0
- package/x/dom/attrs/parts/attr-proxies.js.map +1 -0
- package/x/dom/attrs/parts/attr-spec.d.ts +3 -0
- package/x/dom/attrs/parts/attr-spec.js +21 -0
- package/x/dom/attrs/parts/attr-spec.js.map +1 -0
- package/x/dom/attrs/parts/on-attrs.d.ts +2 -0
- package/x/dom/attrs/parts/on-attrs.js +7 -0
- package/x/dom/attrs/parts/on-attrs.js.map +1 -0
- package/x/dom/dom.d.ts +16 -22
- package/x/dom/dom.js +21 -47
- package/x/dom/dom.js.map +1 -1
- package/x/dom/index.d.ts +2 -0
- package/x/dom/index.js +3 -0
- package/x/dom/index.js.map +1 -0
- package/x/dom/parts/dashify.js.map +1 -0
- package/x/dom/parts/dom-scope.d.ts +15 -0
- package/x/dom/parts/dom-scope.js +35 -0
- package/x/dom/parts/dom-scope.js.map +1 -0
- package/x/dom/parts/el.d.ts +2 -0
- package/x/dom/parts/el.js +7 -0
- package/x/dom/parts/el.js.map +1 -0
- package/x/dom/parts/elmer.d.ts +11 -0
- package/x/dom/parts/elmer.js +32 -0
- package/x/dom/parts/elmer.js.map +1 -0
- package/x/dom/parts/eve.d.ts +7 -0
- package/x/dom/parts/eve.js +16 -0
- package/x/dom/parts/eve.js.map +1 -0
- package/x/dom/parts/mk.d.ts +2 -0
- package/x/dom/parts/mk.js +7 -0
- package/x/dom/parts/mk.js.map +1 -0
- package/x/dom/parts/queries.d.ts +4 -0
- package/x/dom/parts/queries.js +13 -0
- package/x/dom/parts/queries.js.map +1 -0
- package/x/dom/{register.d.ts → parts/register.d.ts} +2 -10
- package/x/dom/parts/register.js.map +1 -0
- package/x/dom/types.d.ts +22 -0
- package/x/{views → dom}/types.js.map +1 -1
- package/x/index.d.ts +7 -17
- package/x/index.html +6 -5
- package/x/index.html.js +4 -3
- package/x/index.html.js.map +1 -1
- package/x/index.js +7 -17
- package/x/index.js.map +1 -1
- package/x/loaders/index.barrel.d.ts +7 -0
- package/x/loaders/index.barrel.js +7 -0
- package/x/loaders/index.barrel.js.map +1 -0
- package/x/loaders/index.d.ts +2 -0
- package/x/loaders/index.js +2 -0
- package/x/loaders/index.js.map +1 -0
- package/x/loaders/make.d.ts +3 -0
- package/x/loaders/make.js +6 -0
- package/x/loaders/make.js.map +1 -0
- package/x/loaders/mock.d.ts +2 -0
- package/x/loaders/mock.js +8 -0
- package/x/loaders/mock.js.map +1 -0
- package/x/{ops/loaders → loaders}/parts/anims.d.ts +1 -1
- package/x/loaders/parts/anims.js.map +1 -0
- package/x/{ops/loaders → loaders}/parts/ascii-anim.d.ts +2 -2
- package/x/{ops/loaders → loaders}/parts/ascii-anim.js +4 -4
- package/x/loaders/parts/ascii-anim.js.map +1 -0
- package/x/loaders/parts/error-display.d.ts +1 -0
- package/x/{ops/loaders → loaders}/parts/error-display.js +2 -2
- package/x/loaders/parts/error-display.js.map +1 -0
- package/x/loaders/types.d.ts +3 -0
- package/x/loaders/types.js +2 -0
- package/x/loaders/types.js.map +1 -0
- package/x/loot/index.barrel.d.ts +3 -0
- package/x/loot/index.barrel.js +4 -0
- package/x/loot/index.barrel.js.map +1 -0
- package/x/loot/index.d.ts +2 -3
- package/x/loot/index.js +1 -3
- package/x/loot/index.js.map +1 -1
- package/x/ops/index.d.ts +3 -0
- package/x/ops/index.js +4 -0
- package/x/ops/index.js.map +1 -0
- package/x/ops/op.js +1 -0
- package/x/ops/op.js.map +1 -1
- package/x/spa/index.barrel.d.ts +4 -0
- package/x/spa/index.barrel.js +3 -0
- package/x/spa/index.barrel.js.map +1 -0
- package/x/spa/index.d.ts +2 -0
- package/x/spa/index.js +2 -0
- package/x/spa/index.js.map +1 -0
- package/x/spa/plumbing/braces.d.ts +12 -0
- package/x/spa/plumbing/braces.js +55 -0
- package/x/spa/plumbing/braces.js.map +1 -0
- package/x/spa/plumbing/primitives.d.ts +22 -0
- package/x/spa/plumbing/primitives.js +65 -0
- package/x/spa/plumbing/primitives.js.map +1 -0
- package/x/spa/plumbing/router-core.d.ts +13 -0
- package/x/spa/plumbing/router-core.js +38 -0
- package/x/spa/plumbing/router-core.js.map +1 -0
- package/x/spa/plumbing/types.d.ts +35 -0
- package/x/spa/plumbing/types.js +2 -0
- package/x/spa/plumbing/types.js.map +1 -0
- package/x/spa/router.d.ts +13 -0
- package/x/spa/router.js +39 -0
- package/x/spa/router.js.map +1 -0
- package/x/spa/spa.test.d.ts +15 -0
- package/x/spa/spa.test.js +78 -0
- package/x/spa/spa.test.js.map +1 -0
- package/x/tests.test.js +4 -1
- package/x/tests.test.js.map +1 -1
- package/x/view/index.d.ts +5 -0
- package/x/view/index.js +6 -0
- package/x/view/index.js.map +1 -0
- package/x/view/types.d.ts +21 -0
- package/x/view/types.js +2 -0
- package/x/view/types.js.map +1 -0
- package/x/view/utils/contextualize.d.ts +13 -0
- package/x/view/utils/contextualize.js +18 -0
- package/x/view/utils/contextualize.js.map +1 -0
- package/x/view/utils/make-component.d.ts +5 -0
- package/x/view/utils/make-component.js +17 -0
- package/x/view/utils/make-component.js.map +1 -0
- package/x/view/utils/make-view.d.ts +2 -0
- package/x/view/utils/make-view.js +24 -0
- package/x/view/utils/make-view.js.map +1 -0
- package/x/view/utils/parts/capsule.d.ts +13 -0
- package/x/view/utils/parts/capsule.js +49 -0
- package/x/view/utils/parts/capsule.js.map +1 -0
- package/x/view/utils/parts/chain.d.ts +13 -0
- package/x/view/utils/parts/chain.js +26 -0
- package/x/view/utils/parts/chain.js.map +1 -0
- package/x/view/utils/parts/context.d.ts +9 -0
- package/x/view/utils/parts/context.js +10 -0
- package/x/view/utils/parts/context.js.map +1 -0
- package/x/view/utils/parts/directive.d.ts +5 -0
- package/x/view/utils/parts/directive.js +18 -0
- package/x/view/utils/parts/directive.js.map +1 -0
- package/x/view/utils/parts/sly-view.d.ts +5 -0
- package/x/view/utils/parts/sly-view.js +13 -0
- package/x/view/utils/parts/sly-view.js.map +1 -0
- package/x/view/view.d.ts +11 -0
- package/x/view/view.js +15 -0
- package/x/view/view.js.map +1 -0
- package/s/dom/attributes.ts +0 -89
- package/s/ops/loaders/make-loader.ts +0 -18
- package/s/views/base-element.ts +0 -84
- package/s/views/types.ts +0 -40
- package/s/views/utils/apply-attrs.ts +0 -33
- package/s/views/view.ts +0 -150
- package/x/demo/views/incredi.js.map +0 -1
- package/x/dom/attributes.d.ts +0 -10
- package/x/dom/attributes.js +0 -46
- package/x/dom/attributes.js.map +0 -1
- package/x/dom/dashify.js.map +0 -1
- package/x/dom/register.js.map +0 -1
- package/x/ops/loaders/make-loader.d.ts +0 -5
- package/x/ops/loaders/make-loader.js +0 -7
- package/x/ops/loaders/make-loader.js.map +0 -1
- package/x/ops/loaders/parts/anims.js.map +0 -1
- package/x/ops/loaders/parts/ascii-anim.js.map +0 -1
- package/x/ops/loaders/parts/error-display.d.ts +0 -1
- package/x/ops/loaders/parts/error-display.js.map +0 -1
- package/x/views/base-element.d.ts +0 -14
- package/x/views/base-element.js +0 -62
- package/x/views/base-element.js.map +0 -1
- package/x/views/css-reset.js.map +0 -1
- package/x/views/types.d.ts +0 -31
- package/x/views/use.js.map +0 -1
- package/x/views/utils/apply-attrs.d.ts +0 -2
- package/x/views/utils/apply-attrs.js +0 -21
- package/x/views/utils/apply-attrs.js.map +0 -1
- package/x/views/utils/apply-styles.js.map +0 -1
- package/x/views/utils/mounts.js.map +0 -1
- package/x/views/view.d.ts +0 -9
- package/x/views/view.js +0 -116
- package/x/views/view.js.map +0 -1
- /package/s/{views → base}/css-reset.ts +0 -0
- /package/s/{views → base}/utils/apply-styles.ts +0 -0
- /package/s/{views → base}/utils/mounts.ts +0 -0
- /package/s/dom/{dashify.ts → parts/dashify.ts} +0 -0
- /package/x/{views → base}/css-reset.d.ts +0 -0
- /package/x/{views → base}/css-reset.js +0 -0
- /package/x/{views → base}/utils/apply-styles.d.ts +0 -0
- /package/x/{views → base}/utils/apply-styles.js +0 -0
- /package/x/{views → base}/utils/mounts.d.ts +0 -0
- /package/x/{views → base}/utils/mounts.js +0 -0
- /package/x/dom/{dashify.d.ts → parts/dashify.d.ts} +0 -0
- /package/x/dom/{dashify.js → parts/dashify.js} +0 -0
- /package/x/dom/{register.js → parts/register.js} +0 -0
- /package/x/{views → dom}/types.js +0 -0
- /package/x/{ops/loaders → loaders}/parts/anims.js +0 -0
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import {Op} from "../op.js"
|
|
3
|
-
import {braille} from "./parts/anims.js"
|
|
4
|
-
import {Content} from "../../views/types.js"
|
|
5
|
-
import {ErrorDisplay} from "./parts/error-display.js"
|
|
6
|
-
|
|
7
|
-
export * as anims from "./parts/anims.js"
|
|
8
|
-
|
|
9
|
-
export type Loader = <V>(op: Op<V>, ready: (value: V) => Content) => Content
|
|
10
|
-
|
|
11
|
-
export function makeLoader(
|
|
12
|
-
loading: () => Content = braille,
|
|
13
|
-
error: (error: any) => Content = (error: any) => ErrorDisplay(error),
|
|
14
|
-
): Loader {
|
|
15
|
-
|
|
16
|
-
return (op, ready) => op.select({loading, ready, error})
|
|
17
|
-
}
|
|
18
|
-
|
package/s/views/base-element.ts
DELETED
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import {CSSResultGroup} from "lit"
|
|
3
|
-
import {tracker} from "@e280/strata"
|
|
4
|
-
import {debounce, MapG} from "@e280/stz"
|
|
5
|
-
|
|
6
|
-
import {dom} from "../dom/dom.js"
|
|
7
|
-
import {Content} from "./types.js"
|
|
8
|
-
import {onAttrChange} from "../dom/attributes.js"
|
|
9
|
-
import {applyStyles} from "./utils/apply-styles.js"
|
|
10
|
-
import {Use, _disconnect, _reconnect, _wrap} from "./use.js"
|
|
11
|
-
|
|
12
|
-
export abstract class BaseElement extends HTMLElement {
|
|
13
|
-
static styles: CSSResultGroup | undefined
|
|
14
|
-
readonly shadow: ShadowRoot
|
|
15
|
-
|
|
16
|
-
#use: Use
|
|
17
|
-
#mounts = 0
|
|
18
|
-
#tracking = new MapG<any, () => void>
|
|
19
|
-
|
|
20
|
-
constructor() {
|
|
21
|
-
super()
|
|
22
|
-
this.shadow = this.attachShadow({mode: "open"})
|
|
23
|
-
this.#use = new Use(
|
|
24
|
-
this,
|
|
25
|
-
this.shadow,
|
|
26
|
-
this.updateNow,
|
|
27
|
-
this.update,
|
|
28
|
-
)
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
abstract render(use: Use): Content
|
|
32
|
-
|
|
33
|
-
updateNow = () => {
|
|
34
|
-
this.#use[_wrap](() => {
|
|
35
|
-
const {result, seen} = tracker.observe(() => this.render(this.#use))
|
|
36
|
-
|
|
37
|
-
dom.render(this.shadow, result)
|
|
38
|
-
|
|
39
|
-
for (const item of seen)
|
|
40
|
-
this.#tracking.guarantee(
|
|
41
|
-
item,
|
|
42
|
-
() => tracker.subscribe(item, this.update),
|
|
43
|
-
)
|
|
44
|
-
})
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
update = debounce(0, this.updateNow)
|
|
48
|
-
|
|
49
|
-
connectedCallback() {
|
|
50
|
-
if (this.#mounts === 0) {
|
|
51
|
-
const styles = (this.constructor as any).styles
|
|
52
|
-
if (styles)
|
|
53
|
-
applyStyles(this.shadow, styles)
|
|
54
|
-
this.updateNow()
|
|
55
|
-
}
|
|
56
|
-
else {
|
|
57
|
-
this.#use[_reconnect]()
|
|
58
|
-
}
|
|
59
|
-
this.#attrListening.start()
|
|
60
|
-
this.#mounts++
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
disconnectedCallback() {
|
|
64
|
-
this.#attrListening.stop()
|
|
65
|
-
this.#use[_disconnect]()
|
|
66
|
-
for (const untrack of this.#tracking.values())
|
|
67
|
-
untrack()
|
|
68
|
-
this.#tracking.clear()
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
#attrListening = (() => {
|
|
72
|
-
let stopper: (() => void) | undefined
|
|
73
|
-
const start = () => {
|
|
74
|
-
if (stopper) stopper()
|
|
75
|
-
stopper = onAttrChange(this, () => this.update)
|
|
76
|
-
}
|
|
77
|
-
const stop = () => {
|
|
78
|
-
if (stopper) stopper()
|
|
79
|
-
stopper = undefined
|
|
80
|
-
}
|
|
81
|
-
return {start, stop}
|
|
82
|
-
})()
|
|
83
|
-
}
|
|
84
|
-
|
package/s/views/types.ts
DELETED
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import {Constructor} from "@e280/stz"
|
|
3
|
-
import {DirectiveResult} from "lit/directive.js"
|
|
4
|
-
import {CSSResultGroup, TemplateResult} from "lit"
|
|
5
|
-
|
|
6
|
-
import {Use} from "./use.js"
|
|
7
|
-
|
|
8
|
-
export type Content = TemplateResult | DirectiveResult | HTMLElement | string | null | undefined | void | Content[]
|
|
9
|
-
export type AttrValue = string | boolean | number | undefined | null | void
|
|
10
|
-
|
|
11
|
-
export type Component<Props extends any[] = []> = {
|
|
12
|
-
render(...props: Props): void
|
|
13
|
-
} & HTMLElement
|
|
14
|
-
|
|
15
|
-
export type ComponentFn = (use: Use) => Content
|
|
16
|
-
export type ViewFn<Props extends any[]> = (use: Use) => (...props: Props) => Content
|
|
17
|
-
export type BasicView<Props extends any[]> = (...props: Props) => DirectiveResult<any>
|
|
18
|
-
export type View<Props extends any[]> = BasicView<Props> & {
|
|
19
|
-
props: (...props: Props) => ViewChain
|
|
20
|
-
component: (...props: Props) => Constructor<Component>
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export type ViewSettings = ShadowRootInit & {
|
|
24
|
-
tag?: string
|
|
25
|
-
name?: string
|
|
26
|
-
styles?: CSSResultGroup
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export type ViewChain = {
|
|
30
|
-
children(...c: Content[]): ViewChain
|
|
31
|
-
attrs(a: Record<string, AttrValue>): ViewChain
|
|
32
|
-
attr(n: string, v: AttrValue): ViewChain
|
|
33
|
-
render(): DirectiveResult<any>
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
export type ViewContext = {
|
|
37
|
-
children: Content[]
|
|
38
|
-
attrs: Record<string, AttrValue>
|
|
39
|
-
}
|
|
40
|
-
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import {AttrValue} from "../types.js"
|
|
3
|
-
|
|
4
|
-
export function applyAttrs(
|
|
5
|
-
element: HTMLElement,
|
|
6
|
-
attrs: Record<string, AttrValue>,
|
|
7
|
-
) {
|
|
8
|
-
|
|
9
|
-
for (const [key, value] of Object.entries(attrs)) {
|
|
10
|
-
if (value === undefined)
|
|
11
|
-
element.removeAttribute(key)
|
|
12
|
-
|
|
13
|
-
else if (value === null)
|
|
14
|
-
element.removeAttribute(key)
|
|
15
|
-
|
|
16
|
-
else if (typeof value === "string")
|
|
17
|
-
element.setAttribute(key, value)
|
|
18
|
-
|
|
19
|
-
else if (typeof value === "number")
|
|
20
|
-
element.setAttribute(key, value.toString())
|
|
21
|
-
|
|
22
|
-
else if (typeof value === "boolean") {
|
|
23
|
-
if (value === true)
|
|
24
|
-
element.setAttribute(key, "")
|
|
25
|
-
else
|
|
26
|
-
element.removeAttribute(key)
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
else
|
|
30
|
-
console.warn(`invalid attribute type ${key} is ${typeof value}`)
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
package/s/views/view.ts
DELETED
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import {render} from "lit"
|
|
3
|
-
import {debounce, MapG} from "@e280/stz"
|
|
4
|
-
import {directive} from "lit/directive.js"
|
|
5
|
-
import {tracker} from "@e280/strata/tracker"
|
|
6
|
-
import {AsyncDirective} from "lit/async-directive.js"
|
|
7
|
-
|
|
8
|
-
import {register} from "../dom/register.js"
|
|
9
|
-
import {applyAttrs} from "./utils/apply-attrs.js"
|
|
10
|
-
import {applyStyles} from "./utils/apply-styles.js"
|
|
11
|
-
import {Use, _wrap, _disconnect, _reconnect} from "./use.js"
|
|
12
|
-
import {AttrValue, ComponentFn, Content, View, ViewFn, ViewSettings, ViewContext} from "./types.js"
|
|
13
|
-
|
|
14
|
-
export const view = setupView({mode: "open"})
|
|
15
|
-
export class SlyView extends HTMLElement {}
|
|
16
|
-
register({SlyView}, {soft: true, upgrade: true})
|
|
17
|
-
|
|
18
|
-
function setupView(settings: ViewSettings) {
|
|
19
|
-
function view<Props extends any[]>(fn: ViewFn<Props>): View<Props> {
|
|
20
|
-
type Situation = {
|
|
21
|
-
getElement: () => HTMLElement
|
|
22
|
-
isComponent: boolean
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
const make = (situation: Situation) => class ViewDirective extends AsyncDirective {
|
|
26
|
-
#element = situation.getElement()
|
|
27
|
-
#shadow = this.#element.attachShadow(settings)
|
|
28
|
-
#renderDebounced = debounce(0, () => this.#renderNow())
|
|
29
|
-
#tracking = new MapG<any, () => void>
|
|
30
|
-
#params!: {context: ViewContext, props: Props}
|
|
31
|
-
|
|
32
|
-
#use = new Use(
|
|
33
|
-
this.#element,
|
|
34
|
-
this.#shadow,
|
|
35
|
-
() => this.#renderNow(),
|
|
36
|
-
this.#renderDebounced,
|
|
37
|
-
)
|
|
38
|
-
|
|
39
|
-
#fn = (() => {
|
|
40
|
-
const fn2 = fn(this.#use)
|
|
41
|
-
this.#element.setAttribute("view", settings.name ?? "")
|
|
42
|
-
if (settings.styles) applyStyles(this.#shadow, settings.styles)
|
|
43
|
-
return fn2
|
|
44
|
-
})()
|
|
45
|
-
|
|
46
|
-
#renderNow() {
|
|
47
|
-
if (!this.#params) return
|
|
48
|
-
if (!this.isConnected) return
|
|
49
|
-
const {context, props} = this.#params
|
|
50
|
-
|
|
51
|
-
this.#use[_wrap](() => {
|
|
52
|
-
// apply html attributes
|
|
53
|
-
applyAttrs(this.#element, context.attrs)
|
|
54
|
-
|
|
55
|
-
// render the template, tracking strata items
|
|
56
|
-
const {result, seen} = tracker.observe(() => this.#fn(...props))
|
|
57
|
-
|
|
58
|
-
// inject the template
|
|
59
|
-
render(result, this.#shadow)
|
|
60
|
-
|
|
61
|
-
// reacting to changes
|
|
62
|
-
for (const item of seen)
|
|
63
|
-
this.#tracking.guarantee(
|
|
64
|
-
item,
|
|
65
|
-
() => tracker.subscribe(item, async() => this.#renderDebounced()),
|
|
66
|
-
)
|
|
67
|
-
|
|
68
|
-
// inject content into light dom
|
|
69
|
-
if (!situation.isComponent)
|
|
70
|
-
render(context.children, this.#element)
|
|
71
|
-
})
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
render(context: ViewContext, props: Props) {
|
|
75
|
-
this.#params = {context, props}
|
|
76
|
-
this.#renderNow()
|
|
77
|
-
return situation.isComponent ? null : this.#element
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
disconnected() {
|
|
81
|
-
this.#use[_disconnect]()
|
|
82
|
-
for (const untrack of this.#tracking.values())
|
|
83
|
-
untrack()
|
|
84
|
-
this.#tracking.clear()
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
reconnected() {
|
|
88
|
-
this.#use[_reconnect]()
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
const d = directive(make({
|
|
93
|
-
getElement: () => document.createElement(settings.tag ?? "sly-view"),
|
|
94
|
-
isComponent: false,
|
|
95
|
-
}))
|
|
96
|
-
|
|
97
|
-
const freshViewContext = (): ViewContext => ({attrs: {}, children: []})
|
|
98
|
-
|
|
99
|
-
function rendy(...props: Props) {
|
|
100
|
-
return d(freshViewContext(), props)
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
rendy.props = (...props: Props) => {
|
|
104
|
-
let ctx = freshViewContext()
|
|
105
|
-
const chain = {
|
|
106
|
-
children(...children: Content[]) {
|
|
107
|
-
ctx = {...ctx, children: [...ctx.children, ...children]}
|
|
108
|
-
return chain
|
|
109
|
-
},
|
|
110
|
-
attrs(attrs: Record<string, AttrValue>) {
|
|
111
|
-
ctx = {...ctx, attrs: {...ctx.attrs, ...attrs}}
|
|
112
|
-
return chain
|
|
113
|
-
},
|
|
114
|
-
attr(name: string, value: AttrValue) {
|
|
115
|
-
ctx = {...ctx, attrs: {...ctx.attrs, [name]: value}}
|
|
116
|
-
return chain
|
|
117
|
-
},
|
|
118
|
-
render() {
|
|
119
|
-
return d(ctx, props)
|
|
120
|
-
},
|
|
121
|
-
}
|
|
122
|
-
return chain
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
rendy.component = (...props: Props) => class ViewComponent extends HTMLElement {
|
|
126
|
-
#context = freshViewContext()
|
|
127
|
-
#directive = directive(
|
|
128
|
-
make({
|
|
129
|
-
getElement: () => this,
|
|
130
|
-
isComponent: true,
|
|
131
|
-
})
|
|
132
|
-
)
|
|
133
|
-
connectedCallback() {
|
|
134
|
-
this.render(...props)
|
|
135
|
-
}
|
|
136
|
-
render(...props: Props) {
|
|
137
|
-
if (this.isConnected)
|
|
138
|
-
render(this.#directive(this.#context, props), this)
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
return rendy
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
view.declare = view
|
|
146
|
-
view.settings = (settings2: Partial<ViewSettings>) => setupView({...settings, ...settings2})
|
|
147
|
-
view.component = (fn: ComponentFn) => view(use => () => fn(use)).component()
|
|
148
|
-
return view
|
|
149
|
-
}
|
|
150
|
-
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"incredi.js","sourceRoot":"","sources":["../../../s/demo/views/incredi.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,KAAK,CAAA;AAC7B,OAAO,EAAC,GAAG,EAAE,MAAM,EAAC,MAAM,WAAW,CAAA;AAErC,OAAO,EAAC,GAAG,EAAC,MAAM,kBAAkB,CAAA;AAEpC,OAAO,EAAC,WAAW,EAAC,MAAM,6BAA6B,CAAA;AAEvD,MAAM,OAAO,cAAe,SAAQ,WAAW;IAC9C,MAAM,CAAC,MAAM,GAAG,GAAG,CAAA,oBAAoB,CAAA;IACvC,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,EAAC,KAAK,EAAE,MAAM,EAAC,CAAC,CAAA;IACxC,SAAS,GAAG,EAAC,QAAQ,EAAE,MAAM,EAAC,CAAA;IAE9B,MAAM,CAAC,GAAQ;QACd,MAAM,EAAC,KAAK,GAAG,CAAC,EAAC,GAAG,IAAI,CAAC,KAAK,CAAA;QAC9B,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QAE5B,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,KAAK,IAAG,EAAE;YAChC,MAAM,GAAG,CAAC,EAAE,CAAC,CAAA;YACb,MAAM,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAA;QAC3B,CAAC,CAAC,CAAC,CAAA;QAEH,OAAO,IAAI,CAAA;WACF,MAAM,EAAE,GAAG,KAAK;GACxB,CAAA;IACF,CAAC"}
|
package/x/dom/attributes.d.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export type AttrKind = (typeof String | typeof Number | typeof Boolean);
|
|
2
|
-
export type AttrType<H extends AttrKind> = (H extends typeof String ? string | undefined : H extends typeof Number ? number | undefined : H extends typeof Boolean ? boolean : never);
|
|
3
|
-
export type AttrSpec = {
|
|
4
|
-
[key: string]: AttrKind;
|
|
5
|
-
};
|
|
6
|
-
export type AttrTypes<A extends AttrSpec> = {
|
|
7
|
-
[P in keyof A]: AttrType<A[P]>;
|
|
8
|
-
};
|
|
9
|
-
export declare function onAttrChange(element: HTMLElement, fn: () => void): () => void;
|
|
10
|
-
export declare const attributes: <A extends AttrSpec>(element: HTMLElement, spec: A) => AttrTypes<A>;
|
package/x/dom/attributes.js
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
export function onAttrChange(element, fn) {
|
|
2
|
-
const observer = new MutationObserver(fn);
|
|
3
|
-
observer.observe(element, { attributes: true });
|
|
4
|
-
return () => observer.disconnect();
|
|
5
|
-
}
|
|
6
|
-
export const attributes = (element, spec) => new Proxy(spec, {
|
|
7
|
-
get: (_target, name) => {
|
|
8
|
-
const type = spec[name];
|
|
9
|
-
const raw = element.getAttribute(name);
|
|
10
|
-
switch (type) {
|
|
11
|
-
case String:
|
|
12
|
-
return raw ?? undefined;
|
|
13
|
-
case Number:
|
|
14
|
-
return raw !== null
|
|
15
|
-
? Number(raw)
|
|
16
|
-
: undefined;
|
|
17
|
-
case Boolean:
|
|
18
|
-
return raw !== null;
|
|
19
|
-
default:
|
|
20
|
-
throw new Error(`invalid attribute type for "${name}"`);
|
|
21
|
-
}
|
|
22
|
-
},
|
|
23
|
-
set: (_target, name, value) => {
|
|
24
|
-
const type = spec[name];
|
|
25
|
-
switch (type) {
|
|
26
|
-
case String: {
|
|
27
|
-
element.setAttribute(name, value);
|
|
28
|
-
return true;
|
|
29
|
-
}
|
|
30
|
-
case Number: {
|
|
31
|
-
element.setAttribute(name, value.toString());
|
|
32
|
-
return true;
|
|
33
|
-
}
|
|
34
|
-
case Boolean: {
|
|
35
|
-
if (value)
|
|
36
|
-
element.setAttribute(name, "");
|
|
37
|
-
else
|
|
38
|
-
element.removeAttribute(name);
|
|
39
|
-
return true;
|
|
40
|
-
}
|
|
41
|
-
default:
|
|
42
|
-
throw new Error(`invalid attribute type for "${name}"`);
|
|
43
|
-
}
|
|
44
|
-
},
|
|
45
|
-
});
|
|
46
|
-
//# sourceMappingURL=attributes.js.map
|
package/x/dom/attributes.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"attributes.js","sourceRoot":"","sources":["../../s/dom/attributes.ts"],"names":[],"mappings":"AA4BA,MAAM,UAAU,YAAY,CAAC,OAAoB,EAAE,EAAc;IAChE,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAA;IACzC,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,EAAC,UAAU,EAAE,IAAI,EAAC,CAAC,CAAA;IAC7C,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAA;AACnC,CAAC;AAED,MAAM,CAAC,MAAM,UAAU,GAAG,CACxB,OAAoB,EACpB,IAAO,EACN,EAAE,CAAC,IAAI,KAAK,CAAC,IAAI,EAAE;IAErB,GAAG,EAAE,CAAC,OAAO,EAAE,IAAY,EAAE,EAAE;QAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAA;QACvB,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;QAEtC,QAAQ,IAAI,EAAE,CAAC;YACd,KAAK,MAAM;gBACV,OAAO,GAAG,IAAI,SAAS,CAAA;YAExB,KAAK,MAAM;gBACV,OAAO,GAAG,KAAK,IAAI;oBAClB,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;oBACb,CAAC,CAAC,SAAS,CAAA;YAEb,KAAK,OAAO;gBACX,OAAO,GAAG,KAAK,IAAI,CAAA;YAEpB;gBACC,MAAM,IAAI,KAAK,CAAC,+BAA+B,IAAI,GAAG,CAAC,CAAA;QACzD,CAAC;IACF,CAAC;IAED,GAAG,EAAE,CAAC,OAAO,EAAE,IAAY,EAAE,KAAU,EAAE,EAAE;QAC1C,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAA;QAEvB,QAAQ,IAAI,EAAE,CAAC;YACd,KAAK,MAAM,CAAC,CAAC,CAAC;gBACb,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;gBACjC,OAAO,IAAI,CAAA;YACZ,CAAC;YAED,KAAK,MAAM,CAAC,CAAC,CAAC;gBACb,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAA;gBAC5C,OAAO,IAAI,CAAA;YACZ,CAAC;YAED,KAAK,OAAO,CAAC,CAAC,CAAC;gBACd,IAAI,KAAK;oBACR,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;;oBAE9B,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,CAAA;gBAC9B,OAAO,IAAI,CAAA;YACZ,CAAC;YAED;gBACC,MAAM,IAAI,KAAK,CAAC,+BAA+B,IAAI,GAAG,CAAC,CAAA;QACzD,CAAC;IACF,CAAC;CAED,CAAwB,CAAA"}
|
package/x/dom/dashify.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dashify.js","sourceRoot":"","sources":["../../s/dom/dashify.ts"],"names":[],"mappings":"AACA;;;;;GAKG;AACH,MAAM,UAAU,OAAO,CAAC,KAAa;IACpC,OAAO,KAAK,CAAC,OAAO,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;AAClE,CAAC"}
|
package/x/dom/register.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"register.js","sourceRoot":"","sources":["../../s/dom/register.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,OAAO,EAAC,MAAM,cAAc,CAAA;AAWpC;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,QAAQ,CACtB,QAAW,EACX,UAAwC,EAAE;IAG3C,MAAM,EACL,IAAI,GAAG,KAAK,EACZ,OAAO,GAAG,IAAI,GACd,GAAG,OAAO,CAAA;IAEX,KAAK,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QACxD,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;QACzB,MAAM,OAAO,GAAG,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAEvC,IAAI,IAAI,IAAI,OAAO;YAClB,SAAQ;QAET,cAAc,CAAC,MAAM,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;QAEnC,IAAI,OAAO;YACV,QAAQ,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAChD,IAAI,OAAO,CAAC,WAAW,KAAK,WAAW;oBACtC,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;YACjC,CAAC,CAAC,CAAA;IACJ,CAAC;AACF,CAAC"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import { Op } from "../op.js";
|
|
2
|
-
import { Content } from "../../views/types.js";
|
|
3
|
-
export * as anims from "./parts/anims.js";
|
|
4
|
-
export type Loader = <V>(op: Op<V>, ready: (value: V) => Content) => Content;
|
|
5
|
-
export declare function makeLoader(loading?: () => Content, error?: (error: any) => Content): Loader;
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { braille } from "./parts/anims.js";
|
|
2
|
-
import { ErrorDisplay } from "./parts/error-display.js";
|
|
3
|
-
export * as anims from "./parts/anims.js";
|
|
4
|
-
export function makeLoader(loading = braille, error = (error) => ErrorDisplay(error)) {
|
|
5
|
-
return (op, ready) => op.select({ loading, ready, error });
|
|
6
|
-
}
|
|
7
|
-
//# sourceMappingURL=make-loader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"make-loader.js","sourceRoot":"","sources":["../../../s/ops/loaders/make-loader.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,OAAO,EAAC,MAAM,kBAAkB,CAAA;AAExC,OAAO,EAAC,YAAY,EAAC,MAAM,0BAA0B,CAAA;AAErD,OAAO,KAAK,KAAK,MAAM,kBAAkB,CAAA;AAIzC,MAAM,UAAU,UAAU,CACxB,UAAyB,OAAO,EAChC,QAAiC,CAAC,KAAU,EAAE,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC;IAGrE,OAAO,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,EAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAC,CAAC,CAAA;AACzD,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"anims.js","sourceRoot":"","sources":["../../../../s/ops/loaders/parts/anims.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ascii-anim.js","sourceRoot":"","sources":["../../../../s/ops/loaders/parts/ascii-anim.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAA;AACvB,OAAO,EAAC,GAAG,EAAE,MAAM,EAAC,MAAM,WAAW,CAAA;AAErC,OAAO,EAAC,IAAI,EAAC,MAAM,wBAAwB,CAAA;AAE3C,OAAO,EAAC,QAAQ,EAAC,MAAM,6BAA6B,CAAA;AAEpD,MAAM,UAAU,aAAa,CAAC,EAAU,EAAE,MAAgB;IACzD,OAAO,GAAG,EAAE,CAAC,SAAS,CAAC,EAAC,EAAE,EAAE,MAAM,EAAC,CAAC,CAAA;AACrC,CAAC;AAED,MAAM,CAAC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EAAC,EAAE,EAAE,MAAM,EAG/C,EAAE,EAAE;IAEL,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IACnB,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;IAC3B,MAAM,KAAK,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;IAE3B,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,KAAK,IAAG,EAAE;QAChC,MAAM,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC,CAAA;QACpB,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;QAC5B,KAAK,CAAC,GAAG,CAAC,IAAI,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IAC5C,CAAC,CAAC,CAAC,CAAA;IAEH,OAAO,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAA;AAC9B,CAAC,CAAC,CAAA;AAEF,MAAM,KAAK,GAAG,GAAG,CAAA;;;;;;CAMhB,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const ErrorDisplay: import("../../../index.js").View<[error: any]>;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"error-display.js","sourceRoot":"","sources":["../../../../s/ops/loaders/parts/error-display.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,KAAK,CAAA;AAC7B,OAAO,EAAC,IAAI,EAAC,MAAM,wBAAwB,CAAA;AAC3C,OAAO,EAAC,QAAQ,EAAC,MAAM,6BAA6B,CAAA;AAEpD,MAAM,CAAC,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,KAAU,EAAE,EAAE;IACtD,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IACjB,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;IAE3B,IAAI,OAAO,KAAK,KAAK,QAAQ;QAC5B,OAAO,KAAK,CAAA;SAER,IAAI,KAAK,YAAY,KAAK;QAC9B,OAAO,IAAI,CAAA,WAAW,KAAK,CAAC,IAAI,oBAAoB,KAAK,CAAC,OAAO,SAAS,CAAA;;QAG1E,OAAO,OAAO,CAAA;AAChB,CAAC,CAAC,CAAA;AAEF,MAAM,KAAK,GAAG,GAAG,CAAA;;;;;CAKhB,CAAA"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { CSSResultGroup } from "lit";
|
|
2
|
-
import { Content } from "./types.js";
|
|
3
|
-
import { Use } from "./use.js";
|
|
4
|
-
export declare abstract class BaseElement extends HTMLElement {
|
|
5
|
-
#private;
|
|
6
|
-
static styles: CSSResultGroup | undefined;
|
|
7
|
-
readonly shadow: ShadowRoot;
|
|
8
|
-
constructor();
|
|
9
|
-
abstract render(use: Use): Content;
|
|
10
|
-
updateNow: () => void;
|
|
11
|
-
update: import("@e280/stz").DebounceReturn<() => void>;
|
|
12
|
-
connectedCallback(): void;
|
|
13
|
-
disconnectedCallback(): void;
|
|
14
|
-
}
|
package/x/views/base-element.js
DELETED
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { tracker } from "@e280/strata";
|
|
2
|
-
import { debounce, MapG } from "@e280/stz";
|
|
3
|
-
import { dom } from "../dom/dom.js";
|
|
4
|
-
import { onAttrChange } from "../dom/attributes.js";
|
|
5
|
-
import { applyStyles } from "./utils/apply-styles.js";
|
|
6
|
-
import { Use, _disconnect, _reconnect, _wrap } from "./use.js";
|
|
7
|
-
export class BaseElement extends HTMLElement {
|
|
8
|
-
static styles;
|
|
9
|
-
shadow;
|
|
10
|
-
#use;
|
|
11
|
-
#mounts = 0;
|
|
12
|
-
#tracking = new MapG;
|
|
13
|
-
constructor() {
|
|
14
|
-
super();
|
|
15
|
-
this.shadow = this.attachShadow({ mode: "open" });
|
|
16
|
-
this.#use = new Use(this, this.shadow, this.updateNow, this.update);
|
|
17
|
-
}
|
|
18
|
-
updateNow = () => {
|
|
19
|
-
this.#use[_wrap](() => {
|
|
20
|
-
const { result, seen } = tracker.observe(() => this.render(this.#use));
|
|
21
|
-
dom.render(this.shadow, result);
|
|
22
|
-
for (const item of seen)
|
|
23
|
-
this.#tracking.guarantee(item, () => tracker.subscribe(item, this.update));
|
|
24
|
-
});
|
|
25
|
-
};
|
|
26
|
-
update = debounce(0, this.updateNow);
|
|
27
|
-
connectedCallback() {
|
|
28
|
-
if (this.#mounts === 0) {
|
|
29
|
-
const styles = this.constructor.styles;
|
|
30
|
-
if (styles)
|
|
31
|
-
applyStyles(this.shadow, styles);
|
|
32
|
-
this.updateNow();
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
this.#use[_reconnect]();
|
|
36
|
-
}
|
|
37
|
-
this.#attrListening.start();
|
|
38
|
-
this.#mounts++;
|
|
39
|
-
}
|
|
40
|
-
disconnectedCallback() {
|
|
41
|
-
this.#attrListening.stop();
|
|
42
|
-
this.#use[_disconnect]();
|
|
43
|
-
for (const untrack of this.#tracking.values())
|
|
44
|
-
untrack();
|
|
45
|
-
this.#tracking.clear();
|
|
46
|
-
}
|
|
47
|
-
#attrListening = (() => {
|
|
48
|
-
let stopper;
|
|
49
|
-
const start = () => {
|
|
50
|
-
if (stopper)
|
|
51
|
-
stopper();
|
|
52
|
-
stopper = onAttrChange(this, () => this.update);
|
|
53
|
-
};
|
|
54
|
-
const stop = () => {
|
|
55
|
-
if (stopper)
|
|
56
|
-
stopper();
|
|
57
|
-
stopper = undefined;
|
|
58
|
-
};
|
|
59
|
-
return { start, stop };
|
|
60
|
-
})();
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=base-element.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"base-element.js","sourceRoot":"","sources":["../../s/views/base-element.ts"],"names":[],"mappings":"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"}
|
package/x/views/css-reset.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"css-reset.js","sourceRoot":"","sources":["../../s/views/css-reset.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAiB,MAAM,KAAK,CAAA;AAEvC,MAAM,CAAC,MAAM,QAAQ,GAAmB,GAAG,CAAA;;;;;;;;;;;;;;;;CAgB1C,CAAA"}
|
package/x/views/types.d.ts
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { Constructor } from "@e280/stz";
|
|
2
|
-
import { DirectiveResult } from "lit/directive.js";
|
|
3
|
-
import { CSSResultGroup, TemplateResult } from "lit";
|
|
4
|
-
import { Use } from "./use.js";
|
|
5
|
-
export type Content = TemplateResult | DirectiveResult | HTMLElement | string | null | undefined | void | Content[];
|
|
6
|
-
export type AttrValue = string | boolean | number | undefined | null | void;
|
|
7
|
-
export type Component<Props extends any[] = []> = {
|
|
8
|
-
render(...props: Props): void;
|
|
9
|
-
} & HTMLElement;
|
|
10
|
-
export type ComponentFn = (use: Use) => Content;
|
|
11
|
-
export type ViewFn<Props extends any[]> = (use: Use) => (...props: Props) => Content;
|
|
12
|
-
export type BasicView<Props extends any[]> = (...props: Props) => DirectiveResult<any>;
|
|
13
|
-
export type View<Props extends any[]> = BasicView<Props> & {
|
|
14
|
-
props: (...props: Props) => ViewChain;
|
|
15
|
-
component: (...props: Props) => Constructor<Component>;
|
|
16
|
-
};
|
|
17
|
-
export type ViewSettings = ShadowRootInit & {
|
|
18
|
-
tag?: string;
|
|
19
|
-
name?: string;
|
|
20
|
-
styles?: CSSResultGroup;
|
|
21
|
-
};
|
|
22
|
-
export type ViewChain = {
|
|
23
|
-
children(...c: Content[]): ViewChain;
|
|
24
|
-
attrs(a: Record<string, AttrValue>): ViewChain;
|
|
25
|
-
attr(n: string, v: AttrValue): ViewChain;
|
|
26
|
-
render(): DirectiveResult<any>;
|
|
27
|
-
};
|
|
28
|
-
export type ViewContext = {
|
|
29
|
-
children: Content[];
|
|
30
|
-
attrs: Record<string, AttrValue>;
|
|
31
|
-
};
|
package/x/views/use.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"use.js","sourceRoot":"","sources":["../../s/views/use.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
export function applyAttrs(element, attrs) {
|
|
2
|
-
for (const [key, value] of Object.entries(attrs)) {
|
|
3
|
-
if (value === undefined)
|
|
4
|
-
element.removeAttribute(key);
|
|
5
|
-
else if (value === null)
|
|
6
|
-
element.removeAttribute(key);
|
|
7
|
-
else if (typeof value === "string")
|
|
8
|
-
element.setAttribute(key, value);
|
|
9
|
-
else if (typeof value === "number")
|
|
10
|
-
element.setAttribute(key, value.toString());
|
|
11
|
-
else if (typeof value === "boolean") {
|
|
12
|
-
if (value === true)
|
|
13
|
-
element.setAttribute(key, "");
|
|
14
|
-
else
|
|
15
|
-
element.removeAttribute(key);
|
|
16
|
-
}
|
|
17
|
-
else
|
|
18
|
-
console.warn(`invalid attribute type ${key} is ${typeof value}`);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
//# sourceMappingURL=apply-attrs.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"apply-attrs.js","sourceRoot":"","sources":["../../../s/views/utils/apply-attrs.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,UAAU,CACxB,OAAoB,EACpB,KAAgC;IAGjC,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAClD,IAAI,KAAK,KAAK,SAAS;YACtB,OAAO,CAAC,eAAe,CAAC,GAAG,CAAC,CAAA;aAExB,IAAI,KAAK,KAAK,IAAI;YACtB,OAAO,CAAC,eAAe,CAAC,GAAG,CAAC,CAAA;aAExB,IAAI,OAAO,KAAK,KAAK,QAAQ;YACjC,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;aAE5B,IAAI,OAAO,KAAK,KAAK,QAAQ;YACjC,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAA;aAEvC,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE,CAAC;YACrC,IAAI,KAAK,KAAK,IAAI;gBACjB,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;;gBAE7B,OAAO,CAAC,eAAe,CAAC,GAAG,CAAC,CAAA;QAC9B,CAAC;;YAGA,OAAO,CAAC,IAAI,CAAC,0BAA0B,GAAG,OAAO,OAAO,KAAK,EAAE,CAAC,CAAA;IAClE,CAAC;AACF,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"apply-styles.js","sourceRoot":"","sources":["../../../s/views/utils/apply-styles.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,WAAW,EAAqC,kBAAkB,EAAC,MAAM,KAAK,CAAA;AAEtF,MAAM,UAAU,WAAW,CAAC,MAAkB,EAAE,MAAuB;IACtE,WAAW,CAAC,MAAM,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC,CAAA;AAC3C,CAAC;AAED,SAAS,aAAa,CAAC,MAAuB;IAC7C,MAAM,aAAa,GAAG,EAAE,CAAA;IAExB,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;QAC3B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAE,MAAyB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,CAAC,CAAA;QACxE,KAAK,MAAM,CAAC,IAAI,GAAG;YAClB,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAsB,CAAC,CAAC,CAAA;IACnE,CAAC;SACI,IAAI,MAAM,KAAK,SAAS;QAC5B,aAAa,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAA;IAE/C,OAAO,aAAa,CAAA;AACrB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mounts.js","sourceRoot":"","sources":["../../../s/views/utils/mounts.ts"],"names":[],"mappings":"AACA,MAAM,OAAO,MAAM;IAClB,SAAS,GAAyB,EAAE,CAAA;IACpC,WAAW,GAAmB,EAAE,CAAA;IAEhC,KAAK,CAAC,KAAuB;QAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;IAC/B,CAAC;IAED,UAAU;QACT,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,WAAW;YACrC,OAAO,EAAE,CAAA;QACV,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;IACtB,CAAC;IAED,UAAU;QACT,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,SAAS;YACjC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;IAChC,CAAC;CACD"}
|
package/x/views/view.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { ComponentFn, View, ViewFn, ViewSettings } from "./types.js";
|
|
2
|
-
export declare const view: {
|
|
3
|
-
<Props extends any[]>(fn: ViewFn<Props>): View<Props>;
|
|
4
|
-
declare: /*elided*/ any;
|
|
5
|
-
settings(settings2: Partial<ViewSettings>): /*elided*/ any;
|
|
6
|
-
component(fn: ComponentFn): import("@e280/stz").Constructor<import("./types.js").Component<[]>>;
|
|
7
|
-
};
|
|
8
|
-
export declare class SlyView extends HTMLElement {
|
|
9
|
-
}
|