jails-js 5.0.0-beta.1 → 5.0.0-beta.12
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/.babelrc +3 -13
- package/.github/FUNDING.yml +2 -0
- package/README.md +7 -37
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/package.json +40 -37
- package/src/component.ts +148 -0
- package/src/element.ts +39 -0
- package/src/index.ts +28 -0
- package/src/template-system.ts +90 -0
- package/src/utils/{events.js → events.ts} +1 -1
- package/src/utils/index.ts +60 -0
- package/src/utils/{pubsub.js → pubsub.ts} +8 -8
- package/tsconfig.json +13 -0
- package/webpack.config.js +35 -0
- package/.eslintignore +0 -2
- package/.eslintrc +0 -20
- package/.eslintrc.js +0 -28
- package/dist/jails.js +0 -1
- package/src/component.js +0 -128
- package/src/index.js +0 -187
- package/src/soda-config.js +0 -82
- package/src/utils/index.js +0 -27
- package/webpack.config.babel.js +0 -16
package/src/component.ts
ADDED
@@ -0,0 +1,148 @@
|
|
1
|
+
import morphdom from 'morphdom'
|
2
|
+
|
3
|
+
import { rAF, dup, buildtemplates } from './utils'
|
4
|
+
import { on, off, trigger } from './utils/events'
|
5
|
+
import { publish, subscribe, unsubscribe } from './utils/pubsub'
|
6
|
+
|
7
|
+
type MainArgs = () => Array<Function>
|
8
|
+
|
9
|
+
export default function Component( elm:HTMLElement, { module, dependencies, templates, components }) {
|
10
|
+
|
11
|
+
const options = getOptions( module )
|
12
|
+
buildtemplates( elm, components, templates )
|
13
|
+
|
14
|
+
const tplid:string|null = elm.getAttribute('tplid')
|
15
|
+
const template = tplid ? templates[tplid] : null
|
16
|
+
const state = { data: module.model ? dup(module.model) : {} }
|
17
|
+
|
18
|
+
const base = {
|
19
|
+
template,
|
20
|
+
elm,
|
21
|
+
dependencies,
|
22
|
+
publish,
|
23
|
+
subscribe,
|
24
|
+
unsubscribe,
|
25
|
+
|
26
|
+
main(fn: MainArgs) {
|
27
|
+
options.main = fn
|
28
|
+
},
|
29
|
+
|
30
|
+
unmount(fn) {
|
31
|
+
options.unmount = fn
|
32
|
+
},
|
33
|
+
|
34
|
+
onupdate(fn) {
|
35
|
+
options.onupdate = fn
|
36
|
+
},
|
37
|
+
|
38
|
+
on(eventName: string, selectorOrCallback: object | Function, callback: Function) {
|
39
|
+
on(elm, eventName, selectorOrCallback, callback)
|
40
|
+
},
|
41
|
+
|
42
|
+
off(eventName: string, callback: Function) {
|
43
|
+
off(elm, eventName, callback)
|
44
|
+
},
|
45
|
+
|
46
|
+
trigger(eventName: string, target: string, args: any) {
|
47
|
+
if (target.constructor === String) {
|
48
|
+
Array
|
49
|
+
.from(elm.querySelectorAll(target))
|
50
|
+
.forEach( children => trigger(children, eventName, { args: args }) )
|
51
|
+
}
|
52
|
+
else trigger(elm, eventName, { args: target })
|
53
|
+
},
|
54
|
+
|
55
|
+
emit: (...args: any) => {
|
56
|
+
trigger(elm, args.shift(), { args: args })
|
57
|
+
},
|
58
|
+
|
59
|
+
state: {
|
60
|
+
set( data: any ) {
|
61
|
+
if (data.constructor === Function) {
|
62
|
+
const newstate = dup(state.data)
|
63
|
+
data(newstate)
|
64
|
+
base.render(newstate)
|
65
|
+
} else {
|
66
|
+
base.render(data)
|
67
|
+
}
|
68
|
+
return new Promise((resolve) => rAF(_ => rAF(resolve)))
|
69
|
+
},
|
70
|
+
get(): object {
|
71
|
+
return dup(state.data)
|
72
|
+
}
|
73
|
+
},
|
74
|
+
|
75
|
+
render(data: object = state.data) {
|
76
|
+
|
77
|
+
if (!document.body.contains(elm))
|
78
|
+
return
|
79
|
+
|
80
|
+
state.data = Object.assign(state.data, data)
|
81
|
+
|
82
|
+
const newdata = dup(state.data)
|
83
|
+
const newhtml = base.template(options.view(newdata))
|
84
|
+
|
85
|
+
morphdom(elm, newhtml, morphdomOptions(elm, options))
|
86
|
+
|
87
|
+
rAF(_ => {
|
88
|
+
Array
|
89
|
+
.from(elm.querySelectorAll('[tplid]'))
|
90
|
+
.forEach((child: any) => {
|
91
|
+
child.options.onupdate(newdata)
|
92
|
+
child.base.render(newdata)
|
93
|
+
})
|
94
|
+
})
|
95
|
+
}
|
96
|
+
}
|
97
|
+
|
98
|
+
return { base, options }
|
99
|
+
}
|
100
|
+
|
101
|
+
const getOptions = (module: any) : any => ({
|
102
|
+
main: (a:any) => a,
|
103
|
+
unmount: (a:any) => a,
|
104
|
+
onupdate: (a:any) => a,
|
105
|
+
view: module.view ? module.view : (a:any) => a
|
106
|
+
})
|
107
|
+
|
108
|
+
const morphdomOptions = (_parent: HTMLElement, options: any) => ({
|
109
|
+
|
110
|
+
onNodeAdded: onUpdates(_parent, options),
|
111
|
+
onElUpdated: onUpdates(_parent, options),
|
112
|
+
onBeforeElChildrenUpdated: checkStatic,
|
113
|
+
onBeforeElUpdated: checkStatic,
|
114
|
+
|
115
|
+
getNodeKey(node: HTMLElement) {
|
116
|
+
if (node.nodeType === 1 && node.getAttribute('tplid'))
|
117
|
+
return node.dataset.key || node.getAttribute('tplid')
|
118
|
+
return false
|
119
|
+
}
|
120
|
+
})
|
121
|
+
|
122
|
+
const checkStatic = (node: HTMLElement) => {
|
123
|
+
if ('static' in node.dataset) {
|
124
|
+
return false
|
125
|
+
}
|
126
|
+
}
|
127
|
+
|
128
|
+
const onUpdates = (_parent: HTMLElement, options: any) => (node: HTMLElement) => {
|
129
|
+
|
130
|
+
if (node.nodeType === 1) {
|
131
|
+
|
132
|
+
if (node.getAttribute && node.getAttribute('scope')) {
|
133
|
+
|
134
|
+
const scope = JSON.parse((node.getAttribute('scope') ||'').replace(/\'/g, '\"'))
|
135
|
+
|
136
|
+
Array.from(node.querySelectorAll('[tplid]'))
|
137
|
+
.map((el: any) => {
|
138
|
+
const data = Object.assign({}, _parent.base.state.get(), scope)
|
139
|
+
options.onupdate(data)
|
140
|
+
el.base.render(data)
|
141
|
+
})
|
142
|
+
|
143
|
+
node.removeAttribute('scope')
|
144
|
+
}
|
145
|
+
}
|
146
|
+
|
147
|
+
return node
|
148
|
+
}
|
package/src/element.ts
ADDED
@@ -0,0 +1,39 @@
|
|
1
|
+
import Component from './component'
|
2
|
+
|
3
|
+
export default function Element(module, dependencies, templates, components) {
|
4
|
+
|
5
|
+
return class extends HTMLElement {
|
6
|
+
|
7
|
+
base: any
|
8
|
+
options: any
|
9
|
+
__events: any
|
10
|
+
|
11
|
+
constructor() {
|
12
|
+
|
13
|
+
super()
|
14
|
+
|
15
|
+
const { base, options } = Component(this, { module, dependencies, templates, components })
|
16
|
+
|
17
|
+
this.base = base
|
18
|
+
this.options = options
|
19
|
+
|
20
|
+
module.default(base)
|
21
|
+
}
|
22
|
+
|
23
|
+
connectedCallback() {
|
24
|
+
this.base.render()
|
25
|
+
this.options.main().forEach(f => f(this.base))
|
26
|
+
}
|
27
|
+
|
28
|
+
disconnectedCallback() {
|
29
|
+
this.options.unmount(this.base)
|
30
|
+
delete this.options
|
31
|
+
delete this.base
|
32
|
+
delete this.__events
|
33
|
+
}
|
34
|
+
|
35
|
+
attributeChangedCallback() {
|
36
|
+
//TODO
|
37
|
+
}
|
38
|
+
}
|
39
|
+
}
|
package/src/index.ts
ADDED
@@ -0,0 +1,28 @@
|
|
1
|
+
import { buildtemplates } from './utils'
|
2
|
+
import Element from './element'
|
3
|
+
|
4
|
+
export const templates = {} as any
|
5
|
+
export const components = {} as any
|
6
|
+
|
7
|
+
export default {
|
8
|
+
|
9
|
+
register( name: string, module: any, dependencies: object = {} ) {
|
10
|
+
components[name] = { name, module, dependencies }
|
11
|
+
},
|
12
|
+
|
13
|
+
start() {
|
14
|
+
const body = document.body
|
15
|
+
buildtemplates( body, components, templates )
|
16
|
+
registerComponents()
|
17
|
+
}
|
18
|
+
}
|
19
|
+
|
20
|
+
const registerComponents = () => {
|
21
|
+
Object
|
22
|
+
.values( components )
|
23
|
+
.forEach( (component) => {
|
24
|
+
const { name, module, dependencies } = component as any
|
25
|
+
const Base = Element(module, dependencies, templates, components)
|
26
|
+
customElements.define(name, Base)
|
27
|
+
})
|
28
|
+
}
|
@@ -0,0 +1,90 @@
|
|
1
|
+
import { compile, defaultConfig, filters } from 'squirrelly'
|
2
|
+
import { SqrlConfig } from 'squirrelly/dist/types/config'
|
3
|
+
import { decodeHtmlEntities } from './utils'
|
4
|
+
|
5
|
+
const defaultOptions: SqrlConfig = {
|
6
|
+
...defaultConfig,
|
7
|
+
tags: ['{', '}'],
|
8
|
+
useWith: true
|
9
|
+
}
|
10
|
+
|
11
|
+
export default function templateSystem( element: HTMLElement ) {
|
12
|
+
|
13
|
+
const tree = document.createElement('template')
|
14
|
+
|
15
|
+
tree.innerHTML = element.outerHTML.replace(/<\/?template[^>]*>/g, '')
|
16
|
+
|
17
|
+
directives(tree.content)
|
18
|
+
|
19
|
+
const html = decodeHtmlEntities(
|
20
|
+
tree.innerHTML
|
21
|
+
.replace(/html-(selected|checked|readonly|disabled|autoplay)=\"(.*)\"/g, `{@if ($2) }$1{/if}`)
|
22
|
+
.replace(/html-/g, '')
|
23
|
+
)
|
24
|
+
|
25
|
+
const template = compile(html, defaultOptions)
|
26
|
+
|
27
|
+
return ( data: object ) => {
|
28
|
+
return template(data, defaultOptions)
|
29
|
+
}
|
30
|
+
}
|
31
|
+
|
32
|
+
/**@Directives */
|
33
|
+
|
34
|
+
const directives = (vdom: DocumentFragment) => {
|
35
|
+
|
36
|
+
const nodes = Array
|
37
|
+
.from(vdom.querySelectorAll('[html-for],[html-if],[html-foreach]'))
|
38
|
+
.reverse() as Array<HTMLElement>
|
39
|
+
|
40
|
+
if (nodes.length) {
|
41
|
+
|
42
|
+
nodes.forEach((node: HTMLElement ) => {
|
43
|
+
if (node.getAttribute('html-foreach')) {
|
44
|
+
const instruction = node.getAttribute('html-foreach') || ''
|
45
|
+
const split = instruction.match(/(.*)\sin\s(.*)/) || ''
|
46
|
+
const varname = split[1]
|
47
|
+
const object = split[2]
|
48
|
+
node.removeAttribute('html-foreach')
|
49
|
+
node.setAttribute('scope', `{${varname} | JSON($key, '${varname}')}`)
|
50
|
+
const open = document.createTextNode(`{@foreach(${object}) => $key, ${varname}}`)
|
51
|
+
const close = document.createTextNode('{/foreach}')
|
52
|
+
wrap(open, node, close)
|
53
|
+
} else if (node.getAttribute('html-for')) {
|
54
|
+
const instruction = node.getAttribute('html-for') || ''
|
55
|
+
const split = instruction.match(/(.*)\sin\s(.*)/) || ''
|
56
|
+
const varname = split[1]
|
57
|
+
const object = split[2]
|
58
|
+
node.removeAttribute('html-for')
|
59
|
+
node.setAttribute('scope', `{${varname} | JSON($index, '${varname}')}`)
|
60
|
+
const open = document.createTextNode(`{@each(${object}) => ${varname}, $index}`)
|
61
|
+
const close = document.createTextNode('{/each}')
|
62
|
+
wrap(open, node, close)
|
63
|
+
} else if (node.getAttribute('html-if')) {
|
64
|
+
const instruction = node.getAttribute('html-if')
|
65
|
+
node.removeAttribute('html-if')
|
66
|
+
const open = document.createTextNode(`{@if (${instruction}) }`)
|
67
|
+
const close = document.createTextNode('{/if}')
|
68
|
+
wrap(open, node, close)
|
69
|
+
}
|
70
|
+
})
|
71
|
+
}
|
72
|
+
|
73
|
+
return vdom
|
74
|
+
}
|
75
|
+
|
76
|
+
filters.define('JSON', (scope, index, varname) => {
|
77
|
+
|
78
|
+
const key = index.constructor == String ? '$key' : '$index'
|
79
|
+
const newobject = { $index: index } as any
|
80
|
+
|
81
|
+
newobject[varname] = scope
|
82
|
+
newobject[key] = index
|
83
|
+
|
84
|
+
return JSON.stringify(newobject)
|
85
|
+
})
|
86
|
+
|
87
|
+
const wrap = (open: Text, node :HTMLElement, close: Text) => {
|
88
|
+
node.parentNode?.insertBefore(open, node)
|
89
|
+
node.parentNode?.insertBefore(close, node.nextSibling)
|
90
|
+
}
|
@@ -0,0 +1,60 @@
|
|
1
|
+
import templateSystem from '../template-system'
|
2
|
+
|
3
|
+
const textarea = document.createElement('textarea')
|
4
|
+
|
5
|
+
export const rAF = (fn) => {
|
6
|
+
if (requestAnimationFrame)
|
7
|
+
return requestAnimationFrame(fn)
|
8
|
+
else
|
9
|
+
return setTimeout(fn, 1000 / 60)
|
10
|
+
}
|
11
|
+
|
12
|
+
export const uuid = () => {
|
13
|
+
return 'xxxxxxxx'.replace(/[xy]/g, (c) => {
|
14
|
+
const r = Math.random() * 8 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8)
|
15
|
+
return v.toString(8)
|
16
|
+
})
|
17
|
+
}
|
18
|
+
|
19
|
+
export const stripTemplateTag = ( element:HTMLElement | DocumentFragment | HTMLTemplateElement ) => {
|
20
|
+
const templates = Array.from(element.querySelectorAll('template'))
|
21
|
+
// https://gist.github.com/harmenjanssen/07e425248779c65bc5d11b02fb913274
|
22
|
+
templates.forEach((template: HTMLTemplateElement) => {
|
23
|
+
template.parentNode?.replaceChild(template.content, template)
|
24
|
+
stripTemplateTag(template.content)
|
25
|
+
})
|
26
|
+
}
|
27
|
+
|
28
|
+
export const dup = (o) => {
|
29
|
+
return JSON.parse(JSON.stringify(o))
|
30
|
+
}
|
31
|
+
|
32
|
+
export const createTemplateId = (element: HTMLElement, templates: any ) => {
|
33
|
+
|
34
|
+
const tplid = element.getAttribute('tplid')
|
35
|
+
|
36
|
+
if (!tplid) {
|
37
|
+
const id = uuid()
|
38
|
+
element.setAttribute('tplid', id)
|
39
|
+
templates[id] = templateSystem(element)
|
40
|
+
}
|
41
|
+
}
|
42
|
+
|
43
|
+
export const buildtemplates = ( target: any, components: any, templates: any ) => {
|
44
|
+
|
45
|
+
return Array
|
46
|
+
.from(target.querySelectorAll('*'))
|
47
|
+
.filter((node: any) => node.tagName.toLowerCase() in components)
|
48
|
+
.reverse()
|
49
|
+
.map((node: any) => {
|
50
|
+
Array.from(node.querySelectorAll('template'))
|
51
|
+
.map(template => buildtemplates(template.content, components, templates))
|
52
|
+
createTemplateId(node, templates)
|
53
|
+
return node
|
54
|
+
})
|
55
|
+
}
|
56
|
+
|
57
|
+
export const decodeHtmlEntities = ( str:string ) => {
|
58
|
+
textarea.innerHTML = str
|
59
|
+
return textarea.value
|
60
|
+
}
|
@@ -1,23 +1,23 @@
|
|
1
|
-
const topics = {}
|
2
|
-
const _async = {}
|
1
|
+
const topics: any = {}
|
2
|
+
const _async: any = {}
|
3
3
|
|
4
|
-
export const publish = (name, params) => {
|
4
|
+
export const publish = (name: string, params: any) => {
|
5
5
|
_async[name] = Object.assign({}, _async[name], params)
|
6
|
-
if(
|
6
|
+
if (topics[name])
|
7
7
|
topics[name].forEach(topic => topic(params))
|
8
8
|
}
|
9
9
|
|
10
|
-
export const subscribe = (name, method) => {
|
10
|
+
export const subscribe = (name: string, method: Function) => {
|
11
11
|
topics[name] = topics[name] || []
|
12
12
|
topics[name].push(method)
|
13
|
-
if (
|
13
|
+
if (name in _async) {
|
14
14
|
method(_async[name])
|
15
15
|
}
|
16
16
|
}
|
17
17
|
|
18
|
-
export const unsubscribe = (topic) => {
|
18
|
+
export const unsubscribe = ( topic: any ) => {
|
19
19
|
topics[topic.name] = (topics[topic.name] || [])
|
20
|
-
.filter(t => t != topic.method)
|
20
|
+
.filter((t: any) => t != topic.method)
|
21
21
|
if (!topics[topic.name].length) {
|
22
22
|
delete topics[topic.name]
|
23
23
|
delete _async[topic.name]
|
package/tsconfig.json
ADDED
@@ -0,0 +1,35 @@
|
|
1
|
+
const path = require('path')
|
2
|
+
|
3
|
+
module.exports = {
|
4
|
+
|
5
|
+
devtool: 'source-map',
|
6
|
+
|
7
|
+
resolve: {
|
8
|
+
extensions: ['.ts', '.js', '.json']
|
9
|
+
},
|
10
|
+
|
11
|
+
entry: {
|
12
|
+
index: './src/index.ts'
|
13
|
+
},
|
14
|
+
|
15
|
+
module: {
|
16
|
+
rules: [
|
17
|
+
{
|
18
|
+
test: /\.ts$/,
|
19
|
+
exclude: [/node_modules/],
|
20
|
+
loader: 'ts-loader',
|
21
|
+
options: {
|
22
|
+
transpileOnly: true
|
23
|
+
}
|
24
|
+
}
|
25
|
+
]
|
26
|
+
},
|
27
|
+
|
28
|
+
output: {
|
29
|
+
path: path.resolve(__dirname, './dist'),
|
30
|
+
filename: '[name].js',
|
31
|
+
libraryTarget: 'umd',
|
32
|
+
library: 'jails',
|
33
|
+
umdNamedDefine: true
|
34
|
+
}
|
35
|
+
}
|
package/.eslintignore
DELETED
package/.eslintrc
DELETED
@@ -1,20 +0,0 @@
|
|
1
|
-
{
|
2
|
-
"rules": {
|
3
|
-
"indent": [2,"tab", {"SwitchCase":1}],
|
4
|
-
"quotes": [2,"single"],
|
5
|
-
"semi": [2,"never"],
|
6
|
-
"no-unused-vars": ["warn", { "vars": "all", "args": "none" }],
|
7
|
-
"no-console": 0
|
8
|
-
},
|
9
|
-
"env": {
|
10
|
-
"es6": true,
|
11
|
-
"browser": true,
|
12
|
-
"node" : true,
|
13
|
-
"jquery": true,
|
14
|
-
},
|
15
|
-
"extends": "eslint:recommended",
|
16
|
-
"parserOptions": {
|
17
|
-
"sourceType": "module"
|
18
|
-
},
|
19
|
-
"globals":{}
|
20
|
-
}
|
package/.eslintrc.js
DELETED
@@ -1,28 +0,0 @@
|
|
1
|
-
module.exports = {
|
2
|
-
"parser":"babel-eslint",
|
3
|
-
"rules": {
|
4
|
-
"indent": [2,"tab", {"SwitchCase":1}],
|
5
|
-
"quotes": [2,"single"],
|
6
|
-
"semi": [2,"never"],
|
7
|
-
"no-unused-vars": ["warn", { "vars": "all", "args": "none" }],
|
8
|
-
"no-console": 0
|
9
|
-
},
|
10
|
-
"env": {
|
11
|
-
"es6": true,
|
12
|
-
"browser": true,
|
13
|
-
"node" : true,
|
14
|
-
"jquery": true,
|
15
|
-
},
|
16
|
-
"extends": "eslint:recommended",
|
17
|
-
"parserOptions": {
|
18
|
-
"sourceType": "module",
|
19
|
-
"ecmaVersion": 2017,
|
20
|
-
"ecmaFeatures": {
|
21
|
-
"experimentalObjectRestSpread": true
|
22
|
-
}
|
23
|
-
},
|
24
|
-
"globals":{
|
25
|
-
"APPCONFIG":true,
|
26
|
-
"webcomponents":true
|
27
|
-
}
|
28
|
-
}
|
package/dist/jails.js
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("jails",[],t):"object"==typeof exports?exports.jails=t():e.jails=t()}(self,(function(){return(()=>{var e={17:function(e){var t;t=function(){return function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{configurable:!1,enumerable:!0,get:r})},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=3)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},i=function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}(),o=n(1),a=n(2);function s(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}var l="undefined"!=typeof document?document:{},u=function(){function e(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"soda-";s(this,e),this._prefix=t}return i(e,[{key:"setDocument",value:function(e){l=e}},{key:"run",value:function(e,t){var n=this,r=l.createElement("div");l.documentMode<9&&(r.style.display="none",l.body.appendChild(r)),r.innerHTML=e,(0,a.nodes2Arr)(r.childNodes).map((function(e){n.compileNode(e,t)}));var i=r.innerHTML;return l.documentMode<9&&l.body.removeChild(r),i}},{key:"prefix",value:function(e){this._prefix=e}},{key:"_getPrefixReg",value:function(){return new RegExp("^"+this._prefix)}},{key:"_getPrefixedDirectiveMap",value:function(){var t=this,n={};return e.sodaDirectives.map((function(e){var r=t._prefix+e.name;n[r]=e})),n}},{key:"_removeSodaMark",value:function(e,t){e.removeAttribute(t)}},{key:"compileNode",value:function(t,n){var i=this,s=this._getPrefixReg(),u=e.sodaDirectives,c=this._getPrefixedDirectiveMap();!function e(t,n){t.nodeType===(t.TEXT_NODE||3)&&(t.nodeValue=t.nodeValue.replace(o.VALUE_OUT_REG,(function(e,t){var o=i.parseSodaExpression(t,n);return"object"===(void 0===o?"undefined":r(o))&&(o=JSON.stringify(o,null,2)),o}))),t.attributes&&t.attributes.length&&(u.map((function(e){var r=e.name,o=e.opt,s=i._prefix+r;if((0,a.exist)(t.getAttribute(s))){var u=t.getAttribute(s);o.link.bind(i)({expression:u,scope:n,el:t,parseSodaExpression:i.parseSodaExpression.bind(i),getValue:i.getValue.bind(i),compileNode:i.compileNode.bind(i),document:l}),i._removeSodaMark(t,s)}})),(0,a.nodes2Arr)(t.attributes).filter((function(e){return!c[e.name]})).map((function(e){if(s.test(e.name)){var r=e.name.replace(s,"");if(r&&(0,a.exist)(e.value)){var o=i.parseComplexExpression(e.value,n);!1!==o&&(0,a.exist)(o)&&t.setAttribute(r,o),i._removeSodaMark(t,e.name)}}else(0,a.exist)(e.value)&&(e.value=i.parseComplexExpression(e.value,n))}))),(0,a.nodes2Arr)(t.childNodes).map((function(t){e(t,n)}))}(t,n)}},{key:"getEvalFunc",value:function(t){return new Function("getValue","sodaFilterMap","return function sodaExp(scope){ return "+t+"}")(this.getValue,e.sodaFilterMap)}},{key:"getValue",value:function(e,t){return o.CONST_REGG.lastIndex=0,t.replace(o.CONST_REGG,(function(t){return void 0===e[t]?t:e[t]})),"true"===t||"false"!==t&&function t(n,r){var i=r.indexOf(".");if(i>-1){var a=r.substr(0,i);return r=r.substr(i+1),void 0!==e[a]&&o.CONST_REG.test(a)&&(a=e[a]),void 0!==n[a]&&null!==n[a]?t(n[a],r):""}return r=r.trim(),void 0!==e[r]&&o.CONST_REG.test(r)&&(r=e[r]),void 0!==n[r]?n[r]:""}(e,t)}},{key:"parseComplexExpression",value:function(e,t){var n=this,r=o.ONLY_VALUE_OUT_REG.exec(e);if(r){var i=r[1];return this.parseSodaExpression(i,t)}return e.replace(o.VALUE_OUT_REG,(function(e,r){return n.parseSodaExpression(r,t)}))}},{key:"parseSodaExpression",value:function(e,t){var n=this;e=(e=e.replace(o.STRING_REG,(function(e,n,r){var i=(0,a.getRandom)();return t[i]=n||r,i}))).replace(o.OR_REG,o.OR_REPLACE).split("|");for(var r=0;r<e.length;r++)e[r]=(e[r].replace(new RegExp(o.OR_REPLACE,"g"),"||")||"").trim();for(var i=e[0]||"",s=e.slice(1);o.ATTR_REG_NG.test(i);)o.ATTR_REG.lastIndex=0,i=i.replace(o.ATTR_REG,(function(e,r){var i=(0,a.getAttrVarKey)(),o=n.parseSodaExpression(r,t);return t[i]=o,"."+i}));return i=i.replace(o.OBJECT_REG,(function(e){return"getValue(scope,'"+e.trim()+"')"})),i=this.parseFilter(s,i),this.getEvalFunc(i)(t)}},{key:"parseFilter",value:function(t,n){var r=e.sodaFilterMap;return function e(){if(i=t.shift()){for(var i,a=(i=i.split(":")).slice(1)||[],s=(i[0]||"").trim(),l=0;l<a.length;l++)o.OBJECT_REG_NG.test(a[l])&&(a[l]="getValue(scope,'"+a[l]+"')");r[s]&&(a.unshift(n),a=a.join(","),n="sodaFilterMap['"+s+"']("+a+")"),e()}}(),n}}],[{key:"filter",value:function(e,t){this.sodaFilterMap[e]=t}},{key:"getFilter",value:function(e){return this.sodaFilterMap[e]}},{key:"directive",value:function(e,t){var n=t.priority,r=void 0===n?0:n,i=void 0;for(i=0;i<this.sodaDirectives.length;i++){var o=this.sodaDirectives[i].opt.priority,a=void 0===o?0:o;if(r<a);else if(r>=a)break}this.sodaDirectives.splice(i,0,{name:e,opt:t})}},{key:"discribe",value:function(e,t){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{compile:!0};this.template[e]={funcOrStr:t,option:n}}},{key:"getTmpl",value:function(e,t){var n=this.template[e],r=n.funcOrStr,i=n.option,o=void 0===i?{}:i;return{template:"function"==typeof r?r.apply(null,t):r,option:o}}}]),e}();u.sodaDirectives=[],u.sodaFilterMap={},u.template={},t.default=u},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.IDENTOR_REG=/[a-zA-Z_\$]+[\w\$]*/g,t.STRING_REG=/"([^"]*)"|'([^']*)'/g,t.NUMBER_REG=/\d+|\d*\.\d+/g,t.OBJECT_REG=/[a-zA-Z_\$]+[\w\$]*(?:\s*\.\s*(?:[a-zA-Z_\$]+[\w\$]*|\d+))*/g,t.OBJECT_REG_NG=/[a-zA-Z_\$]+[\w\$]*(?:\s*\.\s*(?:[a-zA-Z_\$]+[\w\$]*|\d+))*/,t.ATTR_REG=/\[([^\[\]]*)\]/g,t.ATTR_REG_NG=/\[([^\[\]]*)\]/,t.ATTR_REG_DOT=/\.([a-zA-Z_\$]+[\w\$]*)/g,t.NOT_ATTR_REG=/[^\.|]([a-zA-Z_\$]+[\w\$]*)/g,t.OR_REG=/\|\|/g,t.OR_REPLACE="OR_OPERATOR",t.CONST_PRIFIX="_$C$_",t.CONST_REG=/^_\$C\$_/,t.CONST_REGG=/_\$C\$_[^\.]+/g,t.VALUE_OUT_REG=/\{\{([^\}]*)\}\}/g,t.ONLY_VALUE_OUT_REG=/^\{\{([^\}]*)\}\}$/},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.assign=t.nodes2Arr=t.exist=t.getRandom=t.getAttrVarKey=void 0;var r=n(1),i=(t.getAttrVarKey=function(){return r.CONST_PRIFIX+~~(1e6*Math.random())},t.getRandom=function(){return"$$"+~~(1e6*Math.random())},t.exist=function(e){return null!=e&&""!==e&&void 0!==e},t.nodes2Arr=function(e){for(var t=[],n=0;n<e.length;n++)t.push(e[n]);return t},Object.getOwnPropertySymbols),o=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable,s=function(e){if(null==e)throw new TypeError("Object.assign cannot be called with null or undefined");return Object(e)};t.assign=Object.assign||function(e,t){for(var n,r,l=s(e),u=1;u<arguments.length;u++){for(var c in n=Object(arguments[u]))o.call(n,c)&&(l[c]=n[c]);if(i){r=i(n);for(var d=0;d<r.length;d++)a.call(n,r[d])&&(l[r[d]]=n[r[d]])}}return l}},function(e,t,n){"use strict";var r,i=(r=n(0))&&r.__esModule?r:{default:r},o=n(2);n(4),n(5),n(6),n(7),n(8),n(9),n(10);var a=new i.default,s={prefix:function(e){a.prefix(e)},filter:function(e,t){i.default.filter(e,t)},directive:function(e,t){i.default.directive(e,t)},setDocument:function(e){a.setDocument(e)},discribe:function(e,t,n){i.default.discribe(e,t,n)},Soda:i.default},l=(0,o.assign)((function(e,t){return a.run(e,t)}),s);e.exports=l},function(e,t,n){"use strict";var r;((r=n(0))&&r.__esModule?r:{default:r}).default.directive("repeat",{priority:10,link:function(e){var t,n,r,i=this,o=e.scope,a=e.el,s=e.expression,l=e.getValue,u=(e.parseSodaExpression,e.compileNode),c=s.replace(/\s+by\s+([^\s]+)$/,(function(e,t){return t&&(r=(t||"").trim()),""})),d=/([^\s]+)\s+in\s+([^\s]+)|\(([^,]+)\s*,\s*([^)]+)\)\s+in\s+([^\s]+)/.exec(c);if(d){if(d[1]&&d[2]){if(t=(d[1]||"").trim(),n=(d[2]||"").trim(),!t||!n)return}else d[3]&&d[4]&&d[5]&&(r=(d[3]||"").trim(),t=(d[4]||"").trim(),n=(d[5]||"").trim());r=r||"$index";var f=l(o,n)||[],p=function(e){var n=a.cloneNode(!0),s=Object.create(o);s[r]=e,s[t]=f[e],n.removeAttribute(i._prefix+"repeat"),a.parentNode.insertBefore(n,a),u(n,s)};if("length"in f)for(var v=0;v<f.length;v++)p(v);else for(var v in f)f.hasOwnProperty(v)&&p(v);a.parentNode.removeChild(a),a.childNodes&&a.childNodes.length&&(a.innerHTML="")}}})},function(e,t,n){"use strict";var r;((r=n(0))&&r.__esModule?r:{default:r}).default.directive("if",{priority:9,link:function(e){var t=e.expression,n=e.parseSodaExpression,r=e.scope,i=e.el;n(t,r)||(i.parentNode&&i.parentNode.removeChild(i),i.innerHTML="")}})},function(e,t,n){"use strict";var r,i=(r=n(0))&&r.__esModule?r:{default:r};i.default.directive("class",{link:function(e){var t=e.scope,n=e.el,r=e.expression,i=(0,e.parseSodaExpression)(r,t);i&&function(e,t){e.className?e.className.match(function(e){return new RegExp("(^|\\s+)"+e+"(\\s+|$)","g")}(t))||(e.className+=" "+t):e.className=t}(n,i)}})},function(e,t,n){"use strict";var r;((r=n(0))&&r.__esModule?r:{default:r}).default.directive("html",{link:function(e){var t=e.expression,n=e.scope,r=e.el,i=(0,e.parseSodaExpression)(t,n);i&&(r.innerHTML=i)}})},function(e,t,n){"use strict";var r;((r=n(0))&&r.__esModule?r:{default:r}).default.directive("replace",{link:function(e){var t=e.scope,n=e.el,r=e.expression,i=e.parseSodaExpression,o=e.document,a=i(r,t);if(a){var s=o.createElement("div");if(s.innerHTML=a,n.parentNode)for(;s.childNodes[0];)n.parentNode.insertBefore(s.childNodes[0],n)}n.parentNode&&n.parentNode.removeChild(n)}})},function(e,t,n){"use strict";var r;((r=n(0))&&r.__esModule?r:{default:r}).default.directive("style",{link:function(e){var t=e.scope,n=e.el,r=e.expression,i=(0,e.parseSodaExpression)(r,t),o=function(e,t){return/opacity|z-index/.test(e)?parseFloat(t):isNaN(t)?t:t+"px"};if(i){var a=[];for(var s in i)if(i.hasOwnProperty(s)){var l=o(s,i[s]);a.push([s,l].join(":"))}var u=n.style;for(s=0;s<u.length;s++){var c=u[s];i[c]||a.push([c,u[c]].join(":"))}var d=a.join(";");n.setAttribute("style",d)}}})},function(e,t,n){"use strict";var r,i=(r=n(0))&&r.__esModule?r:{default:r};i.default.directive("include",{priority:8,link:function(e){var t=e.scope,n=e.el,r=e.parseSodaExpression,o=e.expression.replace(/\{\{([^\}]*)\}\}/g,(function(e,n){return r(n,t)})),a=(o=o.split(":"))[0],s=o.slice(1),l=i.default.getTmpl(a,s),u=l.template,c=l.option;u&&((void 0===c?{}:c).compile?n.outerHTML=this.run(u,t):n.outerHTML=u)}})}])},e.exports=t()}},t={};function n(r){var i=t[r];if(void 0!==i)return i.exports;var o=t[r]={exports:{}};return e[r].call(o.exports,o,o.exports,n),o.exports}n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t},n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),n.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var r={};return(()=>{"use strict";n.r(r),n.d(r,{default:()=>M});var e,t={};n.r(t),n.d(t,{publish:()=>_,subscribe:()=>g,unsubscribe:()=>y});var i="undefined"==typeof document?void 0:document,o=!!i&&"content"in i.createElement("template"),a=!!i&&i.createRange&&"createContextualFragment"in i.createRange();function s(e,t){var n,r,i=e.nodeName,o=t.nodeName;return i===o||(n=i.charCodeAt(0),r=o.charCodeAt(0),n<=90&&r>=97?i===o.toUpperCase():r<=90&&n>=97&&o===i.toUpperCase())}function l(e,t,n){e[n]!==t[n]&&(e[n]=t[n],e[n]?e.setAttribute(n,""):e.removeAttribute(n))}var u={OPTION:function(e,t){var n=e.parentNode;if(n){var r=n.nodeName.toUpperCase();"OPTGROUP"===r&&(r=(n=n.parentNode)&&n.nodeName.toUpperCase()),"SELECT"!==r||n.hasAttribute("multiple")||(e.hasAttribute("selected")&&!t.selected&&(e.setAttribute("selected","selected"),e.removeAttribute("selected")),n.selectedIndex=-1)}l(e,t,"selected")},INPUT:function(e,t){l(e,t,"checked"),l(e,t,"disabled"),e.value!==t.value&&(e.value=t.value),t.hasAttribute("value")||e.removeAttribute("value")},TEXTAREA:function(e,t){var n=t.value;e.value!==n&&(e.value=n);var r=e.firstChild;if(r){var i=r.nodeValue;if(i==n||!n&&i==e.placeholder)return;r.nodeValue=n}},SELECT:function(e,t){if(!t.hasAttribute("multiple")){for(var n,r,i=-1,o=0,a=e.firstChild;a;)if("OPTGROUP"===(r=a.nodeName&&a.nodeName.toUpperCase()))a=(n=a).firstChild;else{if("OPTION"===r){if(a.hasAttribute("selected")){i=o;break}o++}!(a=a.nextSibling)&&n&&(a=n.nextSibling,n=null)}e.selectedIndex=i}}};function c(){}function d(e){if(e)return e.getAttribute&&e.getAttribute("id")||e.id}const f=function(t,n,r){if(r||(r={}),"string"==typeof n)if("#document"===t.nodeName||"HTML"===t.nodeName||"BODY"===t.nodeName){var l=n;(n=i.createElement("html")).innerHTML=l}else f=(f=n).trim(),n=o?function(e){var t=i.createElement("template");return t.innerHTML=e,t.content.childNodes[0]}(f):a?function(t){return e||(e=i.createRange()).selectNode(i.body),e.createContextualFragment(t).childNodes[0]}(f):function(e){var t=i.createElement("body");return t.innerHTML=e,t.childNodes[0]}(f);var f,p=r.getNodeKey||d,v=r.onBeforeNodeAdded||c,m=r.onNodeAdded||c,h=r.onBeforeElUpdated||c,b=r.onElUpdated||c,_=r.onBeforeNodeDiscarded||c,g=r.onNodeDiscarded||c,y=r.onBeforeElChildrenUpdated||c,E=!0===r.childrenOnly,x=Object.create(null),N=[];function A(e){N.push(e)}function T(e,t){if(1===e.nodeType)for(var n=e.firstChild;n;){var r=void 0;t&&(r=p(n))?A(r):(g(n),n.firstChild&&T(n,t)),n=n.nextSibling}}function O(e,t,n){!1!==_(e)&&(t&&t.removeChild(e),g(e),T(e,n))}function S(e){m(e);for(var t=e.firstChild;t;){var n=t.nextSibling,r=p(t);if(r){var i=x[r];i&&s(t,i)?(t.parentNode.replaceChild(i,t),R(i,t)):S(t)}else S(t);t=n}}function R(e,t,n){var r=p(t);if(r&&delete x[r],!n){if(!1===h(e,t))return;if(function(e,t){var n,r,i,o,a=t.attributes;if(11!==t.nodeType&&11!==e.nodeType){for(var s=a.length-1;s>=0;s--)r=(n=a[s]).name,i=n.namespaceURI,o=n.value,i?(r=n.localName||r,e.getAttributeNS(i,r)!==o&&("xmlns"===n.prefix&&(r=n.name),e.setAttributeNS(i,r,o))):e.getAttribute(r)!==o&&e.setAttribute(r,o);for(var l=e.attributes,u=l.length-1;u>=0;u--)r=(n=l[u]).name,(i=n.namespaceURI)?(r=n.localName||r,t.hasAttributeNS(i,r)||e.removeAttributeNS(i,r)):t.hasAttribute(r)||e.removeAttribute(r)}}(e,t),b(e),!1===y(e,t))return}"TEXTAREA"!==e.nodeName?function(e,t){var n,r,o,a,l,c=t.firstChild,d=e.firstChild;e:for(;c;){for(a=c.nextSibling,n=p(c);d;){if(o=d.nextSibling,c.isSameNode&&c.isSameNode(d)){c=a,d=o;continue e}r=p(d);var f=d.nodeType,m=void 0;if(f===c.nodeType&&(1===f?(n?n!==r&&((l=x[n])?o===l?m=!1:(e.insertBefore(l,d),r?A(r):O(d,e,!0),d=l):m=!1):r&&(m=!1),(m=!1!==m&&s(d,c))&&R(d,c)):3!==f&&8!=f||(m=!0,d.nodeValue!==c.nodeValue&&(d.nodeValue=c.nodeValue))),m){c=a,d=o;continue e}r?A(r):O(d,e,!0),d=o}if(n&&(l=x[n])&&s(l,c))e.appendChild(l),R(l,c);else{var h=v(c);!1!==h&&(h&&(c=h),c.actualize&&(c=c.actualize(e.ownerDocument||i)),e.appendChild(c),S(c))}c=a,d=o}!function(e,t,n){for(;t;){var r=t.nextSibling;(n=p(t))?A(n):O(t,e,!0),t=r}}(e,d,r);var b=u[e.nodeName];b&&b(e,t)}(e,t):u.TEXTAREA(e,t)}!function e(t){if(1===t.nodeType||11===t.nodeType)for(var n=t.firstChild;n;){var r=p(n);r&&(x[r]=n),e(n),n=n.nextSibling}}(t);var C,M,w=t,G=w.nodeType,j=n.nodeType;if(!E)if(1===G)1===j?s(t,n)||(g(t),w=function(e,t){for(var n=e.firstChild;n;){var r=n.nextSibling;t.appendChild(n),n=r}return t}(t,(C=n.nodeName,(M=n.namespaceURI)&&"http://www.w3.org/1999/xhtml"!==M?i.createElementNS(M,C):i.createElement(C)))):w=n;else if(3===G||8===G){if(j===G)return w.nodeValue!==n.nodeValue&&(w.nodeValue=n.nodeValue),w;w=n}if(w===n)g(t);else{if(n.isSameNode&&n.isSameNode(w))return;if(R(w,n,E),N)for(var P=0,k=N.length;P<k;P++){var L=x[N[P]];L&&O(L,L.parentNode,!1)}}return!E&&w!==t&&t.parentNode&&(w.actualize&&(w=w.actualize(t.ownerDocument||i)),t.parentNode.replaceChild(w,t)),w};var p=n(17),v=n.n(p);const m=e=>{(requestAnimationFrame||setTimeout)(e,1e3/60)},h={},b={},_=(e,t)=>{b[e]=Object.assign({},b[e],t),h[e]&&h[e].forEach((e=>e(t)))},g=(e,t)=>{h[e]=h[e]||[],h[e].push(t),e in b&&t(b[e])},y=e=>{h[e.name]=(h[e.name]||[]).filter((t=>t!=e.method)),h[e.name].length||(delete h[e.name],delete b[e.name])},E="CustomEvent"in window&&"function"==typeof window.CustomEvent?(e,t)=>new CustomEvent(e,t):(e,t)=>{const n=document.createEvent("CustomEvent");return n.initCustomEvent(e,!0,!0,t),n},x=(e,t)=>function(n){const r=this,i=n.detail||{};e.__events[t].forEach((e=>{e.handler.apply(r,[n].concat(i.args))}))},N=(e,t)=>{e.__events[t]&&e.__events[t].listener&&(e.removeEventListener(t,e.__events[t].listener,"focus"==t||"blur"==t||"mouseenter"==t||"mouseleave"==t),delete e.__events[t])},A=(e,t,n)=>function(r){const i=this,o=r.detail||{};let a=r.target;for(;a&&(a.matches(t)&&(r.delegateTarget=a,n.apply(i,[r].concat(o.args))),a!==e);)a=a.parentNode},T=(e,t,n)=>{e.dispatchEvent(E(t,{bubbles:!0,detail:n}))};var O;(O=v()).prefix("v-"),O.directive("repeat",{priority:10,link({scope:e,el:t,expression:n,getValue:r,compileNode:i}){let o,a,s;const l=n.replace(/\s+by\s+([^\s]+)$/,((e,t)=>(t&&(s=(t||"").trim()),""))),u=/([^\s]+)\s+in\s+([^\s]+)|\(([^,]+)\s*,\s*([^)]+)\)\s+in\s+([^\s]+)/.exec(l);if(!u)return;if(u[1]&&u[2]){if(o=(u[1]||"").trim(),a=(u[2]||"").trim(),!o||!a)return}else u[3]&&u[4]&&u[5]&&(s=(u[3]||"").trim(),o=(u[4]||"").trim(),a=(u[5]||"").trim());s=s||"$index";const c=r(e,a)||[],d=n=>{const r=t.cloneNode(!0),a=Object.create(e);a[s]=n,a[o]=c[n],r.removeAttribute(`${this._prefix}repeat`),t.parentNode.insertBefore(r,t),Array.from(r.querySelectorAll("[data-component]")).forEach((e=>e.setAttribute("initialState",JSON.stringify(a)))),i(r,a)};if("length"in c)for(var f=0;f<c.length;f++)d(f);else for(var f in c)c.hasOwnProperty(f)&&d(f);t.parentNode.removeChild(t),t.childNodes&&t.childNodes.length&&(t.innerHTML="")}});let S={},R=[];const C={},M={start(){w.start(),w.observe()},register(e,t,n={}){C[e]={name:e,module:t,dependencies:n}}},w={start(){var e;e=document.body,Array.from(e.querySelectorAll("template")).forEach((e=>{e.parentNode.replaceChild(e.content,e)})),w.scan(document.body,G)},scan(e,t){if(1===e.nodeType){const n=Array.from(e.querySelectorAll("[data-component]"));(e.dataset.component?[e].concat(n):n).reverse().forEach(t)}},observe(){new MutationObserver((e=>e.forEach((e=>{"childList"===e.type&&(e.addedNodes.length?Array.from(e.addedNodes).forEach((e=>w.scan(e,G))):e.removedNodes.length&&Array.from(e.removedNodes).forEach((e=>w.scan(e,w.remove))))})))).observe(document.body,{childList:!0,subtree:!0})},remove(e){const t=R.find((t=>t.element==e));t&&t.dispose()}},G=e=>{let n,r;e.getAttribute("tplid")?(n=e.getAttribute("tplid"),r=R.find((e=>e.tplid==n)).template):(n="xxxxxxxx".replace(/[xy]/g,(e=>{const t=8*Math.random()|0;return("x"==e?t:3&t|8).toString(8)})),e.setAttribute("tplid",n),r=j(e.outerHTML));const i={tplid:n,element:e,template:r,instances:{},destroyers:[],promises:[],view:e=>e,parentUpdate:e=>null,dispose(){i.promises.length?Promise.all(i.promises).then((e=>{this.destroyers.forEach((e=>e(i)))})):this.destroyers.forEach((e=>e(i)))},model:Object.assign({},JSON.parse(e.getAttribute("initialState"))),update(t,n=!1){this.model=Object.assign({global:S},this.model,t),S=P(t),n&&this.parentUpdate(this.model);const r=JSON.parse(JSON.stringify(this.model));f(e,v()(this.template,this.view(r)),{onNodeDiscarded:e=>(w.scan(e,w.remove),!0),onBeforeElUpdated:(e,t)=>!(e.isEqualNode(t)||1==e.nodeType&&"static"in e.dataset)}),m((t=>{Array.from(e.querySelectorAll("[data-component]")).forEach((e=>{const t=JSON.parse(e.getAttribute("initialState"))||{},n=R.find((t=>t.element==e)),{global:r,parent:i,...o}=this.model;if(n){const e=Object.assign(t,{parent:o,global:S});n.update(e,!0)}}))}))}};R.push(i),e.dataset.component.split(/\s/).forEach((n=>{const r=C[n];if(!r)return void console.warn(`Jails - Module ${n} not registered`);const{module:o,dependencies:a}=r;i.model=Object.assign({},o.model,i.model);const s=function({name:e,element:t,dependencies:n,Pubsub:r,ElementInterface:i,AST:o}){const a=[];let s,l=[],u=new Promise((e=>s=e));const c={name:e,dependencies:n,elm:t,publish:r.publish,unsubscribe:r.unsubscribe,__initialize(){s(c)},main(e){u.then((t=>e().forEach((e=>e(c))))).catch((e=>console.error(e)))},expose(t){i.instances[e].methods=t},state:{set(e){if(e.constructor===Function){const t=i.model;e(t),i.update(t),l.forEach((e=>e(t)))}else i.update(e),l.forEach((t=>t(e)));return new Promise((e=>m(e)))},get:()=>i.model,subscribe(e){l.push(e)},unsubscribe(e){l=l.filter((t=>t!==e))}},destroy(e){i.destroyers.push(e)},on(e,n,r){((e,t,n,r)=>{if(e.__events=e.__events||{},e.__events[t]=e.__events[t]||[],!e.__events[t].length){const n=x(e,t);e.addEventListener(t,n,"focus"==t||"blur"==t||"mouseenter"==t||"mouseleave"==t),e.__events[t].listener=n}n.call?e.__events[t].push({handler:n,callback:n}):e.__events[t].push({handler:A(e,n,r),callback:r})})(t,e,n,r)},off(e,n){((e,t,n)=>{if(n&&e.__events[t]&&e.__events[t].length){var r=e.__events[t];e.__events[t]=e.__events[t].filter((function(e){return e.callback!=n})),e.__events[t].listener=r.listener,e.__events[t].length||N(e,t)}else N(e,t)})(t,e,n)},trigger(e,n,r){n.constructor===String?T(t.querySelector(n),e,{args:r}):T(t,e,{args:n})},emit(e,n){const r=Array.prototype.slice.call(arguments);T(t,r.shift(),{args:r})},update(e){i.parentUpdate=e},get:(e,n)=>function(){m((r=>{const i=Array.prototype.slice.call(arguments),a=i.shift(),s=`[data-component*=${e}]`;if(n=n?s+n:s,Array.from(t.querySelectorAll(n)).forEach((t=>{const n=o.find((e=>e.element==t));if(n){const t=n.instances[e];t&&a in t.methods&&t.methods[a].apply(null,i)}})),t.matches(n)){const n=o.find((e=>e.element==t)).instances[e];n&&a in n.methods&&n.methods[a].apply(null,i)}}))},subscribe(e,t){a.push({name:e,method:t}),r.subscribe(e,t)}};return c}({name:n,element:e,dependencies:a,Pubsub:t,ElementInterface:i,AST:R}),l=o.default(s);l&&l.then&&i.promises.push(l),s.__initialize(),i.view=o.view||i.view,i.instances[n]={methods:{}}})),i.update()},j=e=>{const t=(e=>e.replace(/<template.*?>|<\/template>/g,""))(e),n=document.createElement("div");return n.innerHTML=t,Array.from(n.querySelectorAll("[data-component]")).forEach((e=>{const t=R.find((t=>t.tplid===e.getAttribute("tplid")));t&&(e.outerHTML=t.template)})),n.innerHTML},P=e=>(Object.assign(S,e),delete S.parent,delete S.global,S)})(),r})()}));
|