@davidsouther/jiffies 2.2.4 → 2.3.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/LICENSE +1 -1
- package/lib/cjs/assert.d.ts +2 -2
- package/lib/cjs/awaitable.d.ts +1 -1
- package/lib/cjs/components/button_bar.d.ts +2 -2
- package/lib/cjs/components/inline_edit.d.ts +2 -2
- package/lib/cjs/components/logger.d.ts +1 -1
- package/lib/cjs/components/select.d.ts +4 -7
- package/lib/cjs/components/test.d.ts +1 -1
- package/lib/cjs/components/virtual_scroll.d.ts +6 -4
- package/lib/cjs/context.d.ts +5 -9
- package/lib/cjs/debounce.d.ts +1 -1
- package/lib/cjs/diff.d.ts +2 -2
- package/lib/cjs/display.d.ts +1 -1
- package/lib/cjs/dom/css/border.d.ts +2 -2
- package/lib/cjs/dom/css/constants.d.ts +3 -3
- package/lib/cjs/dom/css/core.d.ts +1 -1
- package/lib/cjs/dom/css/fstyle.d.ts +2 -2
- package/lib/cjs/dom/css/sizing.d.ts +2 -2
- package/lib/cjs/dom/dom.d.ts +8 -8
- package/lib/cjs/dom/fc.d.ts +8 -12
- package/lib/cjs/dom/form/form.d.ts +5 -6
- package/lib/cjs/dom/html.d.ts +112 -113
- package/lib/cjs/dom/observable.d.ts +1 -1
- package/lib/cjs/dom/provide.d.ts +1 -1
- package/lib/cjs/dom/router/router.d.ts +2 -2
- package/lib/cjs/dom/svg.d.ts +64 -64
- package/lib/cjs/dom/types/css.d.ts +10 -32
- package/lib/cjs/dom/types/html.d.ts +4 -6
- package/lib/cjs/equal.d.ts +8 -5
- package/lib/cjs/flags.d.ts +1 -1
- package/lib/cjs/fs.d.ts +3 -3
- package/lib/cjs/fs_node.d.ts +1 -1
- package/lib/cjs/lock.d.ts +1 -1
- package/lib/cjs/log.d.ts +9 -9
- package/lib/cjs/observable/event.d.ts +2 -2
- package/lib/cjs/observable/observable.d.ts +37 -35
- package/lib/cjs/result.d.ts +21 -21
- package/lib/cjs/safe.d.ts +1 -1
- package/lib/cjs/scope/describe.d.ts +4 -4
- package/lib/cjs/scope/display/console.d.ts +1 -1
- package/lib/cjs/scope/display/dom.d.ts +2 -2
- package/lib/cjs/scope/display/junit.d.ts +1 -1
- package/lib/cjs/scope/execute.d.ts +2 -2
- package/lib/cjs/scope/index.d.ts +3 -3
- package/lib/cjs/scope/scope.d.ts +3 -3
- package/lib/cjs/scope/state.d.ts +1 -1
- package/lib/cjs/server/http/apps.d.ts +1 -1
- package/lib/cjs/server/http/css.d.ts +1 -1
- package/lib/cjs/server/http/index.d.ts +4 -9
- package/lib/cjs/server/http/response.d.ts +3 -3
- package/lib/cjs/server/http/sitemap.d.ts +1 -1
- package/lib/cjs/server/http/static.d.ts +1 -1
- package/lib/cjs/server/http/typescript.d.ts +1 -1
- package/lib/cjs/test_all.d.ts +9 -9
- package/lib/cjs/tsconfig.tsbuildinfo +1 -1
- package/lib/esm/assert.d.ts +2 -2
- package/lib/esm/awaitable.d.ts +1 -1
- package/lib/esm/components/button_bar.d.ts +2 -2
- package/lib/esm/components/inline_edit.d.ts +2 -2
- package/lib/esm/components/logger.d.ts +1 -1
- package/lib/esm/components/select.d.ts +3 -3
- package/lib/esm/components/test.d.ts +1 -1
- package/lib/esm/components/virtual_scroll.d.ts +6 -4
- package/lib/esm/context.d.ts +5 -9
- package/lib/esm/debounce.d.ts +1 -2
- package/lib/esm/diff.d.ts +2 -2
- package/lib/esm/display.d.ts +1 -1
- package/lib/esm/dom/css/border.d.ts +2 -2
- package/lib/esm/dom/css/constants.d.ts +3 -3
- package/lib/esm/dom/css/core.d.ts +1 -1
- package/lib/esm/dom/css/fstyle.d.ts +2 -2
- package/lib/esm/dom/css/sizing.d.ts +2 -2
- package/lib/esm/dom/dom.d.ts +8 -8
- package/lib/esm/dom/fc.d.ts +8 -12
- package/lib/esm/dom/form/form.d.ts +5 -6
- package/lib/esm/dom/html.d.ts +112 -113
- package/lib/esm/dom/observable.d.ts +1 -1
- package/lib/esm/dom/provide.d.ts +1 -1
- package/lib/esm/dom/router/router.d.ts +2 -2
- package/lib/esm/dom/svg.d.ts +64 -64
- package/lib/esm/dom/types/css.d.ts +10 -32
- package/lib/esm/dom/types/html.d.ts +4 -6
- package/lib/esm/equal.d.ts +8 -5
- package/lib/esm/flags.d.ts +1 -1
- package/lib/esm/fs.d.ts +3 -3
- package/lib/esm/fs_node.d.ts +1 -1
- package/lib/esm/lock.d.ts +1 -1
- package/lib/esm/log.d.ts +9 -9
- package/lib/esm/observable/event.d.ts +2 -2
- package/lib/esm/observable/observable.d.ts +37 -35
- package/lib/esm/result.d.ts +21 -21
- package/lib/esm/safe.d.ts +1 -1
- package/lib/esm/scope/describe.d.ts +4 -4
- package/lib/esm/scope/display/console.d.ts +1 -1
- package/lib/esm/scope/display/dom.d.ts +2 -2
- package/lib/esm/scope/display/junit.d.ts +1 -1
- package/lib/esm/scope/execute.d.ts +2 -2
- package/lib/esm/scope/index.d.ts +3 -3
- package/lib/esm/scope/scope.d.ts +3 -3
- package/lib/esm/scope/state.d.ts +1 -1
- package/lib/esm/server/http/apps.d.ts +1 -1
- package/lib/esm/server/http/css.d.ts +1 -1
- package/lib/esm/server/http/index.d.ts +4 -9
- package/lib/esm/server/http/response.d.ts +3 -3
- package/lib/esm/server/http/sitemap.d.ts +1 -1
- package/lib/esm/server/http/static.d.ts +1 -1
- package/lib/esm/server/http/typescript.d.ts +1 -1
- package/lib/esm/test_all.d.ts +9 -9
- package/lib/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +11 -9
- package/src/assert.ts +5 -5
- package/src/components/button_bar.ts +28 -30
- package/src/components/inline_edit.ts +8 -7
- package/src/components/logger.ts +6 -6
- package/src/components/select.ts +7 -7
- package/src/components/test.ts +5 -0
- package/src/components/virtual_scroll.test.ts +9 -6
- package/src/components/virtual_scroll.ts +29 -24
- package/src/context.test.ts +4 -4
- package/src/context.ts +16 -11
- package/src/debounce.ts +9 -3
- package/src/diff.test.ts +4 -4
- package/src/diff.ts +14 -16
- package/src/dom/css/border.ts +11 -11
- package/src/dom/css/core.ts +1 -1
- package/src/dom/css/fstyle.ts +4 -4
- package/src/dom/css/sizing.ts +1 -1
- package/src/dom/dom.ts +57 -47
- package/src/dom/fc.test.ts +8 -8
- package/src/dom/fc.ts +32 -35
- package/src/dom/form/form.app.ts +9 -9
- package/src/dom/form/form.ts +25 -16
- package/src/dom/form/index.html +3 -2
- package/src/dom/html.test.ts +12 -10
- package/src/dom/html.ts +2 -3
- package/src/dom/observable.test.ts +6 -6
- package/src/dom/observable.ts +2 -2
- package/src/dom/provide.ts +1 -1
- package/src/dom/router/link.ts +3 -3
- package/src/dom/router/router.ts +5 -5
- package/src/dom/svg.ts +7 -6
- package/src/dom/test.ts +3 -0
- package/src/dom/types/css.ts +43 -61
- package/src/dom/types/html.ts +2 -4
- package/src/dom/xml.ts +2 -2
- package/src/equal.test.ts +3 -3
- package/src/equal.ts +27 -14
- package/src/flags.test.ts +2 -2
- package/src/flags.ts +2 -2
- package/src/fs.test.ts +5 -5
- package/src/fs.ts +26 -20
- package/src/fs_node.ts +4 -4
- package/src/fs_win.test.ts +1 -1
- package/src/generator.test.ts +4 -3
- package/src/generator.ts +1 -1
- package/src/hooks/_notes +4 -1
- package/src/index.html +7 -7
- package/src/lock.test.ts +4 -4
- package/src/lock.ts +8 -7
- package/src/log.ts +28 -18
- package/src/observable/event.ts +7 -7
- package/src/observable/observable.test.ts +3 -3
- package/src/observable/observable.ts +71 -52
- package/src/result.test.ts +7 -10
- package/src/result.ts +51 -47
- package/src/safe.ts +1 -1
- package/src/scope/describe.ts +12 -11
- package/src/scope/display/console.ts +4 -4
- package/src/scope/display/dom.ts +9 -9
- package/src/scope/display/junit.ts +21 -24
- package/src/scope/execute.ts +17 -12
- package/src/scope/expect.ts +22 -22
- package/src/scope/fix.ts +10 -7
- package/src/scope/index.ts +3 -3
- package/src/scope/scope.ts +2 -2
- package/src/scope/state.ts +2 -2
- package/src/server/http/apps.ts +5 -5
- package/src/server/http/css.ts +10 -26
- package/src/server/http/index.ts +30 -24
- package/src/server/http/response.ts +12 -5
- package/src/server/http/sitemap.ts +8 -8
- package/src/server/http/static.ts +9 -6
- package/src/server/http/typescript.ts +25 -25
- package/src/server/main.ts +7 -4
- package/src/test.mjs +8 -8
- package/src/test_all.ts +16 -13
- package/src/transpile.mjs +6 -18
- package/build/pico.css +0 -2466
- package/build/pico.css.map +0 -1
- package/lib/cjs/assert.js +0 -46
- package/lib/cjs/awaitable.js +0 -2
- package/lib/cjs/case.js +0 -9
- package/lib/cjs/components/button_bar.js +0 -29
- package/lib/cjs/components/inline_edit.js +0 -51
- package/lib/cjs/components/logger.js +0 -27
- package/lib/cjs/components/select.js +0 -6
- package/lib/cjs/components/test.js +0 -7
- package/lib/cjs/components/virtual_scroll.js +0 -102
- package/lib/cjs/components/virtual_scroll.test.js +0 -22
- package/lib/cjs/context.js +0 -48
- package/lib/cjs/context.test.js +0 -48
- package/lib/cjs/debounce.js +0 -12
- package/lib/cjs/diff.js +0 -58
- package/lib/cjs/diff.test.js +0 -41
- package/lib/cjs/display.js +0 -16
- package/lib/cjs/dom/css/border.js +0 -33
- package/lib/cjs/dom/css/constants.js +0 -31
- package/lib/cjs/dom/css/core.js +0 -31
- package/lib/cjs/dom/css/fstyle.js +0 -36
- package/lib/cjs/dom/css/sizing.js +0 -14
- package/lib/cjs/dom/dom.js +0 -110
- package/lib/cjs/dom/fc.js +0 -39
- package/lib/cjs/dom/fc.test.js +0 -23
- package/lib/cjs/dom/form/form.app.js +0 -27
- package/lib/cjs/dom/form/form.js +0 -49
- package/lib/cjs/dom/form/form.test.js +0 -1
- package/lib/cjs/dom/html.js +0 -119
- package/lib/cjs/dom/html.test.js +0 -60
- package/lib/cjs/dom/observable.js +0 -10
- package/lib/cjs/dom/observable.test.js +0 -35
- package/lib/cjs/dom/provide.js +0 -12
- package/lib/cjs/dom/router/link.js +0 -7
- package/lib/cjs/dom/router/router.js +0 -55
- package/lib/cjs/dom/svg.js +0 -69
- package/lib/cjs/dom/test.js +0 -13
- package/lib/cjs/dom/types/css.js +0 -24
- package/lib/cjs/dom/types/dom.js +0 -1
- package/lib/cjs/dom/types/html.js +0 -2
- package/lib/cjs/dom/xml.js +0 -8
- package/lib/cjs/equal.js +0 -48
- package/lib/cjs/equal.test.js +0 -22
- package/lib/cjs/flags.js +0 -52
- package/lib/cjs/flags.test.js +0 -37
- package/lib/cjs/fs.js +0 -235
- package/lib/cjs/fs.test.js +0 -86
- package/lib/cjs/fs_node.js +0 -50
- package/lib/cjs/fs_win.test.js +0 -10
- package/lib/cjs/generator.js +0 -14
- package/lib/cjs/generator.test.js +0 -26
- package/lib/cjs/is_browser.js +0 -4
- package/lib/cjs/loader-register.d.mts +0 -1
- package/lib/cjs/loader-register.d.ts +0 -1
- package/lib/cjs/loader-register.js +0 -4
- package/lib/cjs/loader-register.mjs +0 -4
- package/lib/cjs/loader.d.mts +0 -23
- package/lib/cjs/loader.mjs +0 -41
- package/lib/cjs/lock.js +0 -27
- package/lib/cjs/lock.test.js +0 -18
- package/lib/cjs/log.js +0 -98
- package/lib/cjs/observable/event.js +0 -61
- package/lib/cjs/observable/observable.js +0 -363
- package/lib/cjs/observable/observable.test.js +0 -65
- package/lib/cjs/package.json +0 -1
- package/lib/cjs/range.js +0 -11
- package/lib/cjs/result.js +0 -80
- package/lib/cjs/result.test.js +0 -78
- package/lib/cjs/safe.js +0 -14
- package/lib/cjs/scope/describe.js +0 -73
- package/lib/cjs/scope/display/console.js +0 -25
- package/lib/cjs/scope/display/dom.js +0 -30
- package/lib/cjs/scope/display/junit.js +0 -21
- package/lib/cjs/scope/execute.js +0 -91
- package/lib/cjs/scope/expect.js +0 -110
- package/lib/cjs/scope/fix.js +0 -26
- package/lib/cjs/scope/index.js +0 -15
- package/lib/cjs/scope/scope.js +0 -2
- package/lib/cjs/scope/state.js +0 -12
- package/lib/cjs/server/http/apps.js +0 -27
- package/lib/cjs/server/http/css.js +0 -54
- package/lib/cjs/server/http/index.js +0 -77
- package/lib/cjs/server/http/response.js +0 -45
- package/lib/cjs/server/http/sitemap.js +0 -46
- package/lib/cjs/server/http/static.js +0 -25
- package/lib/cjs/server/http/typescript.js +0 -44
- package/lib/cjs/server/main.js +0 -14
- package/lib/cjs/test.mjs +0 -28
- package/lib/cjs/test_all.js +0 -30
- package/lib/cjs/transpile.mjs +0 -22
- package/lib/esm/assert.js +0 -38
- package/lib/esm/awaitable.js +0 -1
- package/lib/esm/case.js +0 -5
- package/lib/esm/components/button_bar.js +0 -27
- package/lib/esm/components/inline_edit.js +0 -48
- package/lib/esm/components/logger.js +0 -22
- package/lib/esm/components/select.js +0 -3
- package/lib/esm/components/test.js +0 -3
- package/lib/esm/components/virtual_scroll.js +0 -94
- package/lib/esm/components/virtual_scroll.test.js +0 -20
- package/lib/esm/context.js +0 -43
- package/lib/esm/context.test.js +0 -46
- package/lib/esm/debounce.js +0 -8
- package/lib/esm/diff.js +0 -54
- package/lib/esm/diff.test.js +0 -39
- package/lib/esm/display.js +0 -11
- package/lib/esm/dom/css/border.js +0 -27
- package/lib/esm/dom/css/constants.js +0 -28
- package/lib/esm/dom/css/core.js +0 -24
- package/lib/esm/dom/css/fstyle.js +0 -32
- package/lib/esm/dom/css/sizing.js +0 -10
- package/lib/esm/dom/dom.js +0 -104
- package/lib/esm/dom/fc.js +0 -35
- package/lib/esm/dom/fc.test.js +0 -21
- package/lib/esm/dom/form/form.app.js +0 -23
- package/lib/esm/dom/form/form.js +0 -34
- package/lib/esm/dom/form/form.test.js +0 -1
- package/lib/esm/dom/html.js +0 -114
- package/lib/esm/dom/html.test.js +0 -58
- package/lib/esm/dom/observable.js +0 -6
- package/lib/esm/dom/observable.test.js +0 -33
- package/lib/esm/dom/provide.js +0 -7
- package/lib/esm/dom/router/link.js +0 -3
- package/lib/esm/dom/router/router.js +0 -52
- package/lib/esm/dom/svg.js +0 -65
- package/lib/esm/dom/test.js +0 -9
- package/lib/esm/dom/types/css.js +0 -23
- package/lib/esm/dom/types/dom.js +0 -1
- package/lib/esm/dom/types/html.js +0 -1
- package/lib/esm/dom/xml.js +0 -4
- package/lib/esm/equal.js +0 -41
- package/lib/esm/equal.test.js +0 -20
- package/lib/esm/flags.js +0 -48
- package/lib/esm/flags.test.js +0 -35
- package/lib/esm/fs.js +0 -226
- package/lib/esm/fs.test.js +0 -84
- package/lib/esm/fs_node.js +0 -45
- package/lib/esm/fs_win.test.js +0 -8
- package/lib/esm/generator.js +0 -10
- package/lib/esm/generator.test.js +0 -24
- package/lib/esm/is_browser.js +0 -1
- package/lib/esm/loader-register.d.mts +0 -1
- package/lib/esm/loader-register.mjs +0 -2
- package/lib/esm/loader.d.mts +0 -23
- package/lib/esm/loader.mjs +0 -36
- package/lib/esm/lock.js +0 -23
- package/lib/esm/lock.test.js +0 -16
- package/lib/esm/log.js +0 -88
- package/lib/esm/observable/event.js +0 -46
- package/lib/esm/observable/observable.js +0 -343
- package/lib/esm/observable/observable.test.js +0 -63
- package/lib/esm/range.js +0 -7
- package/lib/esm/result.js +0 -65
- package/lib/esm/result.test.js +0 -76
- package/lib/esm/safe.js +0 -10
- package/lib/esm/scope/describe.js +0 -60
- package/lib/esm/scope/display/console.js +0 -21
- package/lib/esm/scope/display/dom.js +0 -26
- package/lib/esm/scope/display/junit.js +0 -17
- package/lib/esm/scope/execute.js +0 -85
- package/lib/esm/scope/expect.js +0 -104
- package/lib/esm/scope/fix.js +0 -22
- package/lib/esm/scope/index.js +0 -3
- package/lib/esm/scope/scope.js +0 -1
- package/lib/esm/scope/state.js +0 -8
- package/lib/esm/server/http/apps.js +0 -23
- package/lib/esm/server/http/css.js +0 -50
- package/lib/esm/server/http/index.js +0 -73
- package/lib/esm/server/http/response.js +0 -40
- package/lib/esm/server/http/sitemap.js +0 -42
- package/lib/esm/server/http/static.js +0 -21
- package/lib/esm/server/http/typescript.js +0 -40
- package/lib/esm/server/main.js +0 -12
- package/lib/esm/test.mjs +0 -26
- package/lib/esm/test_all.js +0 -28
- package/lib/esm/transpile.mjs +0 -18
- package/src/components/test.js +0 -3
- package/src/loader-register.mjs +0 -3
- package/src/loader.mjs +0 -46
package/lib/cjs/dom/css/core.js
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getSide = exports.getSize = exports.isSize = exports.isSide = void 0;
|
|
4
|
-
const constants_js_1 = require("./constants.js");
|
|
5
|
-
function isSide(v) {
|
|
6
|
-
return constants_js_1.Sides[v] !== undefined;
|
|
7
|
-
}
|
|
8
|
-
exports.isSide = isSide;
|
|
9
|
-
function isSize(v) {
|
|
10
|
-
return constants_js_1.Sizes[v] !== undefined;
|
|
11
|
-
}
|
|
12
|
-
exports.isSize = isSize;
|
|
13
|
-
function getSize(size) {
|
|
14
|
-
return constants_js_1.Sizes[size];
|
|
15
|
-
}
|
|
16
|
-
exports.getSize = getSize;
|
|
17
|
-
function getSide(side) {
|
|
18
|
-
switch (side) {
|
|
19
|
-
case "t":
|
|
20
|
-
return [...getSide("tl"), ...getSide("tr")];
|
|
21
|
-
case "r":
|
|
22
|
-
return [...getSide("tr"), ...getSide("br")];
|
|
23
|
-
case "b":
|
|
24
|
-
return [...getSide("br"), ...getSide("bl")];
|
|
25
|
-
case "l":
|
|
26
|
-
return [...getSide("tl"), ...getSide("bl")];
|
|
27
|
-
default:
|
|
28
|
-
return [constants_js_1.Sides[side]];
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
exports.getSide = getSide;
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.compileFStyle = void 0;
|
|
4
|
-
const case_js_1 = require("../../case.js");
|
|
5
|
-
function compileFStyle(fstyle, prefix = "") {
|
|
6
|
-
const properties = [];
|
|
7
|
-
const rules = [];
|
|
8
|
-
for (const [key, value] of Object.entries(fstyle)) {
|
|
9
|
-
if (typeof value == "string") {
|
|
10
|
-
properties.push({ key, value });
|
|
11
|
-
}
|
|
12
|
-
else {
|
|
13
|
-
rules.push({ key, value });
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
let rule = "";
|
|
17
|
-
if (properties.length > 0) {
|
|
18
|
-
rule += `${prefix} {\n`;
|
|
19
|
-
for (const { key, value } of properties) {
|
|
20
|
-
rule += ` ${(0, case_js_1.dashCase)(key)}: ${value};\n`;
|
|
21
|
-
}
|
|
22
|
-
rule += "}\n\n";
|
|
23
|
-
}
|
|
24
|
-
for (const { key, value } of rules) {
|
|
25
|
-
if (key.startsWith("@media")) {
|
|
26
|
-
rule += `${key} {\n`;
|
|
27
|
-
rule += compileFStyle(value, " ");
|
|
28
|
-
rule += `}\n\n`;
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
rule += compileFStyle(value, `${prefix} ${key}`);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
return rule;
|
|
35
|
-
}
|
|
36
|
-
exports.compileFStyle = compileFStyle;
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.width = void 0;
|
|
4
|
-
const constants_js_1 = require("./constants.js");
|
|
5
|
-
function width(amount, block) {
|
|
6
|
-
if (amount === undefined && constants_js_1.Widths[block] !== undefined) {
|
|
7
|
-
amount = block;
|
|
8
|
-
}
|
|
9
|
-
return {
|
|
10
|
-
...(block === "inline" ? { display: "inline-block" } : {}),
|
|
11
|
-
width: constants_js_1.Widths[amount] ?? "0",
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
exports.width = width;
|
package/lib/cjs/dom/dom.js
DELETED
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.update = exports.up = exports.normalizeArguments = exports.CLEAR = void 0;
|
|
4
|
-
const Events = Symbol("events");
|
|
5
|
-
exports.CLEAR = Symbol("Clear children");
|
|
6
|
-
function isAttrs(attrs) {
|
|
7
|
-
if (!attrs) {
|
|
8
|
-
return false;
|
|
9
|
-
}
|
|
10
|
-
if (typeof attrs === "object") {
|
|
11
|
-
return !attrs.nodeType;
|
|
12
|
-
}
|
|
13
|
-
return false;
|
|
14
|
-
}
|
|
15
|
-
function normalizeArguments(attrs, children = [], defaultAttrs = {}) {
|
|
16
|
-
let attributes;
|
|
17
|
-
if (isAttrs(attrs)) {
|
|
18
|
-
attributes = attrs;
|
|
19
|
-
}
|
|
20
|
-
else {
|
|
21
|
-
if (attrs !== undefined) {
|
|
22
|
-
children.unshift(attrs);
|
|
23
|
-
}
|
|
24
|
-
attributes = defaultAttrs;
|
|
25
|
-
}
|
|
26
|
-
return [attributes, children.flat()];
|
|
27
|
-
}
|
|
28
|
-
exports.normalizeArguments = normalizeArguments;
|
|
29
|
-
function up(element, attrs, ...children) {
|
|
30
|
-
return update(element, ...normalizeArguments(attrs, children));
|
|
31
|
-
}
|
|
32
|
-
exports.up = up;
|
|
33
|
-
function update(element, attrs, children) {
|
|
34
|
-
// Track events, to remove later
|
|
35
|
-
const $events = (element[Events] ??= new Map());
|
|
36
|
-
const { style = {}, events = {}, ...rest } = attrs;
|
|
37
|
-
Object.entries(events).forEach(([k, v]) => {
|
|
38
|
-
if (v === null) {
|
|
39
|
-
if ($events.has(k)) {
|
|
40
|
-
const listener = $events.get(k);
|
|
41
|
-
element.removeEventListener(k, listener);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
else if (v !== undefined) {
|
|
45
|
-
element.addEventListener(k, v);
|
|
46
|
-
$events.set(k, v);
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
const _style = element.style;
|
|
50
|
-
if (_style) {
|
|
51
|
-
if (typeof style === "string") {
|
|
52
|
-
_style.cssText = style;
|
|
53
|
-
}
|
|
54
|
-
else {
|
|
55
|
-
Object.entries(style).forEach(([k, v]) => {
|
|
56
|
-
// @ts-ignore Object.entries is unable to statically look into args
|
|
57
|
-
_style[k] = v;
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
Object.entries(rest).forEach(([k, v]) => {
|
|
62
|
-
if (k === "class") {
|
|
63
|
-
v = Array.isArray(v)
|
|
64
|
-
? v
|
|
65
|
-
: (typeof v === "string" ? v : `${v}`).split(/\s+/m);
|
|
66
|
-
v
|
|
67
|
-
.filter((s) => s !== "")
|
|
68
|
-
.forEach((c) => {
|
|
69
|
-
if (c.startsWith("!")) {
|
|
70
|
-
element.classList.remove(c.substring(1));
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
element.classList.add(c);
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
const useNamespace = element.namespaceURI &&
|
|
79
|
-
element.namespaceURI != "http://www.w3.org/1999/xhtml";
|
|
80
|
-
const remove = !v;
|
|
81
|
-
if (useNamespace) {
|
|
82
|
-
if (remove) {
|
|
83
|
-
element.removeAttributeNS(element.namespaceURI, k);
|
|
84
|
-
}
|
|
85
|
-
else if (v === true) {
|
|
86
|
-
element.setAttributeNS(element.namespaceURI, k, k);
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
element.setAttributeNS(element.namespaceURI, k, v);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
if (remove) {
|
|
94
|
-
element.removeAttribute(k);
|
|
95
|
-
}
|
|
96
|
-
else if (v === true) {
|
|
97
|
-
element.setAttribute(k, k);
|
|
98
|
-
}
|
|
99
|
-
else {
|
|
100
|
-
element.setAttribute(k, v);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
});
|
|
104
|
-
if (children?.length > 0) {
|
|
105
|
-
element.replaceChildren(...(children[0] === exports.CLEAR ? [] : children));
|
|
106
|
-
}
|
|
107
|
-
element.update ??= (attrs, ...children) => update(element, ...normalizeArguments(attrs, children));
|
|
108
|
-
return element;
|
|
109
|
-
}
|
|
110
|
-
exports.update = update;
|
package/lib/cjs/dom/fc.js
DELETED
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.FC = exports.State = void 0;
|
|
4
|
-
const dom_js_1 = require("./dom.js");
|
|
5
|
-
exports.State = Symbol();
|
|
6
|
-
function FC(name, component) {
|
|
7
|
-
class FCImpl extends HTMLElement {
|
|
8
|
-
constructor() {
|
|
9
|
-
super();
|
|
10
|
-
}
|
|
11
|
-
[exports.State] = {};
|
|
12
|
-
#attrs = {};
|
|
13
|
-
#children = [];
|
|
14
|
-
update(attrs, ...children) {
|
|
15
|
-
[attrs, children] = (0, dom_js_1.normalizeArguments)(attrs, children);
|
|
16
|
-
if (children[0] === dom_js_1.CLEAR) {
|
|
17
|
-
this.#children = [];
|
|
18
|
-
}
|
|
19
|
-
else if (children.length > 0) {
|
|
20
|
-
this.#children = children;
|
|
21
|
-
}
|
|
22
|
-
this.#attrs = { ...this.#attrs, ...attrs };
|
|
23
|
-
// Apply updates from the attrs to the dom node itself
|
|
24
|
-
(0, dom_js_1.update)(this, this.#attrs, []);
|
|
25
|
-
// Re-run the component function using new element, attrs, and children.
|
|
26
|
-
const replace = [component(this, this.#attrs, this.#children)];
|
|
27
|
-
this.replaceChildren(...replace.flat());
|
|
28
|
-
return this;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
customElements.define(name, FCImpl);
|
|
32
|
-
const ctor = (attrs, ...children) => {
|
|
33
|
-
const element = document.createElement(name);
|
|
34
|
-
element.update(attrs, ...children);
|
|
35
|
-
return element;
|
|
36
|
-
};
|
|
37
|
-
return ctor;
|
|
38
|
-
}
|
|
39
|
-
exports.FC = FC;
|
package/lib/cjs/dom/fc.test.js
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const index_js_1 = require("../scope/index.js");
|
|
4
|
-
const html_js_1 = require("./html.js");
|
|
5
|
-
const fc_js_1 = require("./fc.js");
|
|
6
|
-
(0, index_js_1.describe)("FC", () => {
|
|
7
|
-
(0, index_js_1.it)("creates FCs", () => {
|
|
8
|
-
const Input = (0, fc_js_1.FC)("fc-input", (el, attrs, children) => (0, html_js_1.label)(attrs.placeholder ?? attrs.name, (0, html_js_1.input)(attrs), ...children));
|
|
9
|
-
const f = (0, html_js_1.form)({ action: "#", method: "POST" }, (0, html_js_1.div)({ class: "grid" }, Input({
|
|
10
|
-
name: "firstName",
|
|
11
|
-
placeholder: "First Name",
|
|
12
|
-
required: true,
|
|
13
|
-
}), Input({
|
|
14
|
-
name: "lastName",
|
|
15
|
-
placeholder: "Last Name",
|
|
16
|
-
required: true,
|
|
17
|
-
})), Input({ name: "email", type: "email", placeholder: "E-Mail" }, (0, html_js_1.small)("We'll never share your information.")), (0, html_js_1.button)({ type: "submit" }, "Submit"));
|
|
18
|
-
// document.body.appendChild(f);
|
|
19
|
-
(0, index_js_1.expect)(f.children.length).toBe(3);
|
|
20
|
-
(0, index_js_1.expect)(f.querySelectorAll("input[required]").length).toBe(2);
|
|
21
|
-
(0, index_js_1.expect)(f.querySelectorAll('input[name="firstName"]').length).toBe(1);
|
|
22
|
-
});
|
|
23
|
-
});
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.App = void 0;
|
|
4
|
-
const html_js_1 = require("../html.js");
|
|
5
|
-
const form_js_1 = require("./form.js");
|
|
6
|
-
const App = () => (0, html_js_1.main)({ class: "container" }, (0, html_js_1.article)((0, form_js_1.Form)({
|
|
7
|
-
events: {
|
|
8
|
-
submit(event) {
|
|
9
|
-
console.log("Should see fields for firstname, lastname, email, etc");
|
|
10
|
-
console.log(event);
|
|
11
|
-
},
|
|
12
|
-
},
|
|
13
|
-
}, (0, html_js_1.div)({ class: "grid" }, (0, form_js_1.Input)({ id: "firstname", placeholder: "First name" }), (0, form_js_1.Input)({ id: "lastname", placeholder: "Last name" })), (0, form_js_1.Input)({
|
|
14
|
-
id: "email",
|
|
15
|
-
type: "email",
|
|
16
|
-
placeholder: "Email address",
|
|
17
|
-
required: true,
|
|
18
|
-
}, (0, html_js_1.small)("We will never share your email with anyone.")), (0, html_js_1.button)({ type: "submit" }, "Submit"), (0, html_js_1.div)({ class: "grid" }, (0, form_js_1.Input)({ id: "valid", placeholder: "Valid", "aria-invalid": "false" }), (0, form_js_1.Input)({
|
|
19
|
-
id: "invalid",
|
|
20
|
-
placeholder: "Invalid",
|
|
21
|
-
"aria-invalid": "true",
|
|
22
|
-
}), (0, form_js_1.Input)({ id: "disabled", placeholder: "Disabled", disabled: true }), (0, form_js_1.Input)({ id: "readonly", value: "Readonly", readOnly: true }))
|
|
23
|
-
// Dropdown({id: 'fruit', label: "Fruit", placeholder: "Select a fruit...", options: ['Banana', 'Watermelon', 'Apple', 'Orange', 'Mango']}),
|
|
24
|
-
// Radios({legend: 'Size', options: {small: 'Small', medium: 'Medium', large: 'Large', extralarge: "Extra Large"}, checked: 'small'}),
|
|
25
|
-
// Checkboxes({options: {terms: 'I agree to the Terms and Conditions', termsSharing: {label: 'I agree to share my information with partners', disabled: true, checked: true}}),
|
|
26
|
-
)));
|
|
27
|
-
exports.App = App;
|
package/lib/cjs/dom/form/form.js
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Switch = exports.Checkbox = exports.Radio = exports.Switches = exports.Checks = exports.Radios = exports.Dropdown = exports.Option = exports.Button = exports.Select = exports.Input = exports.Form = void 0;
|
|
4
|
-
const html_js_1 = require("../html.js");
|
|
5
|
-
const Form = (attrs, ...children) => {
|
|
6
|
-
if (attrs.events?.submit) {
|
|
7
|
-
const submit = attrs.events.submit;
|
|
8
|
-
attrs.events.submit = (event) => {
|
|
9
|
-
event.preventDefault();
|
|
10
|
-
submit(event);
|
|
11
|
-
};
|
|
12
|
-
}
|
|
13
|
-
return (0, html_js_1.form)(attrs, ...children);
|
|
14
|
-
};
|
|
15
|
-
exports.Form = Form;
|
|
16
|
-
const Input = (attrs, ...children) => (0, html_js_1.label)((0, html_js_1.input)(attrs), ...children);
|
|
17
|
-
exports.Input = Input;
|
|
18
|
-
const Select = (attrs) => (0, html_js_1.label)({ style: attrs.style ?? {} }, (0, html_js_1.select)({ events: attrs.events ?? {} }, ...prepareOptions(attrs.options, attrs.selected).map(exports.Option)));
|
|
19
|
-
exports.Select = Select;
|
|
20
|
-
const Button = () => { };
|
|
21
|
-
exports.Button = Button;
|
|
22
|
-
const prepareOptions = (attrs, selected) => Array.isArray(attrs)
|
|
23
|
-
? attrs.map((value) => ({
|
|
24
|
-
value,
|
|
25
|
-
label: value,
|
|
26
|
-
selected: selected == value,
|
|
27
|
-
}))
|
|
28
|
-
: Object.entries(attrs).map(([value, label]) => typeof label === "string"
|
|
29
|
-
? { value, label, selected: selected === value }
|
|
30
|
-
: { value, ...label });
|
|
31
|
-
const Option = (attrs) => (0, html_js_1.option)(attrs);
|
|
32
|
-
exports.Option = Option;
|
|
33
|
-
const Dropdown = (attrs, ...options) => (0, exports.Select)({
|
|
34
|
-
...attrs,
|
|
35
|
-
options: typeof options[0] == "string" ? options : options[0],
|
|
36
|
-
});
|
|
37
|
-
exports.Dropdown = Dropdown;
|
|
38
|
-
const Radios = () => { };
|
|
39
|
-
exports.Radios = Radios;
|
|
40
|
-
const Checks = () => { };
|
|
41
|
-
exports.Checks = Checks;
|
|
42
|
-
const Switches = () => { };
|
|
43
|
-
exports.Switches = Switches;
|
|
44
|
-
const Radio = (attrs) => (0, exports.Input)({ type: "radio" });
|
|
45
|
-
exports.Radio = Radio;
|
|
46
|
-
const Checkbox = (attrs) => (0, exports.Input)({ type: "checkbox" });
|
|
47
|
-
exports.Checkbox = Checkbox;
|
|
48
|
-
const Switch = () => (0, exports.Checkbox)({ role: "switch" });
|
|
49
|
-
exports.Switch = Switch;
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";
|
package/lib/cjs/dom/html.js
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.i = exports.html = exports.hr = exports.hgroup = exports.header = exports.head = exports.h6 = exports.h5 = exports.h4 = exports.h3 = exports.h2 = exports.h1 = exports.form = exports.footer = exports.figure = exports.figcaption = exports.fieldset = exports.embed = exports.em = exports.dt = exports.dl = exports.div = exports.dialog = exports.dfn = exports.details = exports.del = exports.dd = exports.datalist = exports.data = exports.colgroup = exports.col = exports.code = exports.cite = exports.caption = exports.canvas = exports.button = exports.br = exports.body = exports.blockquote = exports.bdo = exports.bdi = exports.base = exports.b = exports.audio = exports.aside = exports.article = exports.area = exports.address = exports.abbr = exports.a = void 0;
|
|
4
|
-
exports.textarea = exports.template = exports.td = exports.tbody = exports.table = exports.sup = exports.summary = exports.sub = exports.style = exports.strong = exports.span = exports.source = exports.small = exports.slot = exports.select = exports.section = exports.script = exports.samp = exports.s = exports.ruby = exports.rt = exports.rp = exports.q = exports.progress = exports.pre = exports.picture = exports.param = exports.p = exports.output = exports.option = exports.optgroup = exports.ol = exports.object = exports.noscript = exports.nav = exports.meter = exports.meta = exports.menu = exports.mark = exports.map = exports.main = exports.link = exports.li = exports.legend = exports.label = exports.kbd = exports.ins = exports.input = exports.img = exports.iframe = void 0;
|
|
5
|
-
exports.wbr = exports.video = exports.htmlvar = exports.ul = exports.u = exports.track = exports.tr = exports.title = exports.time = exports.thead = exports.th = exports.tfoot = void 0;
|
|
6
|
-
const dom_js_1 = require("./dom.js");
|
|
7
|
-
const makeHTMLElement = (name) => (attrs, ...children) => (0, dom_js_1.up)(document.createElement(name), attrs, ...children);
|
|
8
|
-
exports.a = makeHTMLElement("a");
|
|
9
|
-
exports.abbr = makeHTMLElement("abbr");
|
|
10
|
-
exports.address = makeHTMLElement("address");
|
|
11
|
-
exports.area = makeHTMLElement("area");
|
|
12
|
-
exports.article = makeHTMLElement("article");
|
|
13
|
-
exports.aside = makeHTMLElement("aside");
|
|
14
|
-
exports.audio = makeHTMLElement("audio");
|
|
15
|
-
exports.b = makeHTMLElement("b");
|
|
16
|
-
exports.base = makeHTMLElement("base");
|
|
17
|
-
exports.bdi = makeHTMLElement("bdi");
|
|
18
|
-
exports.bdo = makeHTMLElement("bdo");
|
|
19
|
-
exports.blockquote = makeHTMLElement("blockquote");
|
|
20
|
-
exports.body = makeHTMLElement("body");
|
|
21
|
-
exports.br = makeHTMLElement("br");
|
|
22
|
-
exports.button = makeHTMLElement("button");
|
|
23
|
-
exports.canvas = makeHTMLElement("canvas");
|
|
24
|
-
exports.caption = makeHTMLElement("caption");
|
|
25
|
-
exports.cite = makeHTMLElement("cite");
|
|
26
|
-
exports.code = makeHTMLElement("code");
|
|
27
|
-
exports.col = makeHTMLElement("col");
|
|
28
|
-
exports.colgroup = makeHTMLElement("colgroup");
|
|
29
|
-
exports.data = makeHTMLElement("data");
|
|
30
|
-
exports.datalist = makeHTMLElement("datalist");
|
|
31
|
-
exports.dd = makeHTMLElement("dd");
|
|
32
|
-
exports.del = makeHTMLElement("del");
|
|
33
|
-
exports.details = makeHTMLElement("details");
|
|
34
|
-
exports.dfn = makeHTMLElement("dfn");
|
|
35
|
-
exports.dialog = makeHTMLElement("dialog");
|
|
36
|
-
exports.div = makeHTMLElement("div");
|
|
37
|
-
exports.dl = makeHTMLElement("dl");
|
|
38
|
-
exports.dt = makeHTMLElement("dt");
|
|
39
|
-
exports.em = makeHTMLElement("em");
|
|
40
|
-
exports.embed = makeHTMLElement("embed");
|
|
41
|
-
exports.fieldset = makeHTMLElement("fieldset");
|
|
42
|
-
exports.figcaption = makeHTMLElement("figcaption");
|
|
43
|
-
exports.figure = makeHTMLElement("figure");
|
|
44
|
-
exports.footer = makeHTMLElement("footer");
|
|
45
|
-
exports.form = makeHTMLElement("form");
|
|
46
|
-
exports.h1 = makeHTMLElement("h1");
|
|
47
|
-
exports.h2 = makeHTMLElement("h2");
|
|
48
|
-
exports.h3 = makeHTMLElement("h3");
|
|
49
|
-
exports.h4 = makeHTMLElement("h4");
|
|
50
|
-
exports.h5 = makeHTMLElement("h5");
|
|
51
|
-
exports.h6 = makeHTMLElement("h6");
|
|
52
|
-
exports.head = makeHTMLElement("head");
|
|
53
|
-
exports.header = makeHTMLElement("header");
|
|
54
|
-
exports.hgroup = makeHTMLElement("hgroup");
|
|
55
|
-
exports.hr = makeHTMLElement("hr");
|
|
56
|
-
exports.html = makeHTMLElement("html");
|
|
57
|
-
exports.i = makeHTMLElement("i");
|
|
58
|
-
exports.iframe = makeHTMLElement("iframe");
|
|
59
|
-
exports.img = makeHTMLElement("img");
|
|
60
|
-
exports.input = makeHTMLElement("input");
|
|
61
|
-
exports.ins = makeHTMLElement("ins");
|
|
62
|
-
exports.kbd = makeHTMLElement("kbd");
|
|
63
|
-
exports.label = makeHTMLElement("label");
|
|
64
|
-
exports.legend = makeHTMLElement("legend");
|
|
65
|
-
exports.li = makeHTMLElement("li");
|
|
66
|
-
exports.link = makeHTMLElement("link");
|
|
67
|
-
exports.main = makeHTMLElement("main");
|
|
68
|
-
exports.map = makeHTMLElement("map");
|
|
69
|
-
exports.mark = makeHTMLElement("mark");
|
|
70
|
-
exports.menu = makeHTMLElement("menu");
|
|
71
|
-
exports.meta = makeHTMLElement("meta");
|
|
72
|
-
exports.meter = makeHTMLElement("meter");
|
|
73
|
-
exports.nav = makeHTMLElement("nav");
|
|
74
|
-
exports.noscript = makeHTMLElement("noscript");
|
|
75
|
-
exports.object = makeHTMLElement("object");
|
|
76
|
-
exports.ol = makeHTMLElement("ol");
|
|
77
|
-
exports.optgroup = makeHTMLElement("optgroup");
|
|
78
|
-
exports.option = makeHTMLElement("option");
|
|
79
|
-
exports.output = makeHTMLElement("output");
|
|
80
|
-
exports.p = makeHTMLElement("p");
|
|
81
|
-
exports.param = makeHTMLElement("param");
|
|
82
|
-
exports.picture = makeHTMLElement("picture");
|
|
83
|
-
exports.pre = makeHTMLElement("pre");
|
|
84
|
-
exports.progress = makeHTMLElement("progress");
|
|
85
|
-
exports.q = makeHTMLElement("q");
|
|
86
|
-
exports.rp = makeHTMLElement("rp");
|
|
87
|
-
exports.rt = makeHTMLElement("rt");
|
|
88
|
-
exports.ruby = makeHTMLElement("ruby");
|
|
89
|
-
exports.s = makeHTMLElement("s");
|
|
90
|
-
exports.samp = makeHTMLElement("samp");
|
|
91
|
-
exports.script = makeHTMLElement("script");
|
|
92
|
-
exports.section = makeHTMLElement("section");
|
|
93
|
-
exports.select = makeHTMLElement("select");
|
|
94
|
-
exports.slot = makeHTMLElement("slot");
|
|
95
|
-
exports.small = makeHTMLElement("small");
|
|
96
|
-
exports.source = makeHTMLElement("source");
|
|
97
|
-
exports.span = makeHTMLElement("span");
|
|
98
|
-
exports.strong = makeHTMLElement("strong");
|
|
99
|
-
exports.style = makeHTMLElement("style");
|
|
100
|
-
exports.sub = makeHTMLElement("sub");
|
|
101
|
-
exports.summary = makeHTMLElement("summary");
|
|
102
|
-
exports.sup = makeHTMLElement("sup");
|
|
103
|
-
exports.table = makeHTMLElement("table");
|
|
104
|
-
exports.tbody = makeHTMLElement("tbody");
|
|
105
|
-
exports.td = makeHTMLElement("td");
|
|
106
|
-
exports.template = makeHTMLElement("template");
|
|
107
|
-
exports.textarea = makeHTMLElement("textarea");
|
|
108
|
-
exports.tfoot = makeHTMLElement("tfoot");
|
|
109
|
-
exports.th = makeHTMLElement("th");
|
|
110
|
-
exports.thead = makeHTMLElement("thead");
|
|
111
|
-
exports.time = makeHTMLElement("time");
|
|
112
|
-
exports.title = makeHTMLElement("title");
|
|
113
|
-
exports.tr = makeHTMLElement("tr");
|
|
114
|
-
exports.track = makeHTMLElement("track");
|
|
115
|
-
exports.u = makeHTMLElement("u");
|
|
116
|
-
exports.ul = makeHTMLElement("ul");
|
|
117
|
-
exports.htmlvar = makeHTMLElement("var"); // var is reserved, export as variable
|
|
118
|
-
exports.video = makeHTMLElement("video");
|
|
119
|
-
exports.wbr = makeHTMLElement("wbr");
|
package/lib/cjs/dom/html.test.js
DELETED
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const describe_js_1 = require("../scope/describe.js");
|
|
4
|
-
const expect_js_1 = require("../scope/expect.js");
|
|
5
|
-
const html_js_1 = require("./html.js");
|
|
6
|
-
(0, describe_js_1.describe)("html", () => {
|
|
7
|
-
(0, describe_js_1.it)("creates HTML Elements", () => {
|
|
8
|
-
let tableBody;
|
|
9
|
-
const myTable = (0, html_js_1.table)((0, html_js_1.thead)((0, html_js_1.tr)((0, html_js_1.th)("Col A"), (0, html_js_1.th)("Col B"))), (tableBody = (0, html_js_1.tbody)()));
|
|
10
|
-
for (let x = 1; x <= 3; x++) {
|
|
11
|
-
tableBody.appendChild((0, html_js_1.tr)((0, html_js_1.td)(`${x}`), (0, html_js_1.td)(`${x * 2}`)));
|
|
12
|
-
}
|
|
13
|
-
(0, expect_js_1.expect)(myTable.textContent).toEqual("Col ACol B122436");
|
|
14
|
-
});
|
|
15
|
-
(0, describe_js_1.it)("attaches event handlers", () => {
|
|
16
|
-
let clicked = 0;
|
|
17
|
-
const btn = (0, html_js_1.button)({
|
|
18
|
-
events: {
|
|
19
|
-
click: () => {
|
|
20
|
-
clicked += 1;
|
|
21
|
-
},
|
|
22
|
-
},
|
|
23
|
-
});
|
|
24
|
-
btn.dispatchEvent(new Event("click"));
|
|
25
|
-
(0, expect_js_1.expect)(clicked).toBe(1);
|
|
26
|
-
});
|
|
27
|
-
(0, describe_js_1.it)("removes event handlers", () => {
|
|
28
|
-
let clicked = 0;
|
|
29
|
-
const btn = (0, html_js_1.button)({
|
|
30
|
-
events: {
|
|
31
|
-
click: () => {
|
|
32
|
-
clicked += 1;
|
|
33
|
-
},
|
|
34
|
-
},
|
|
35
|
-
});
|
|
36
|
-
btn.dispatchEvent(new Event("click"));
|
|
37
|
-
(0, expect_js_1.expect)(clicked).toBe(1);
|
|
38
|
-
btn.update({ events: { click: null } });
|
|
39
|
-
btn.dispatchEvent(new Event("click"));
|
|
40
|
-
(0, expect_js_1.expect)(clicked).toBe(1);
|
|
41
|
-
});
|
|
42
|
-
(0, describe_js_1.it)("sets style properties", () => {
|
|
43
|
-
const btn = (0, html_js_1.button)({
|
|
44
|
-
style: { flexDirection: "column" },
|
|
45
|
-
});
|
|
46
|
-
(0, expect_js_1.expect)(btn.style.flexDirection).toBe("column");
|
|
47
|
-
});
|
|
48
|
-
(0, describe_js_1.it)("sets style, attributes, and events together", () => {
|
|
49
|
-
let clicked = false;
|
|
50
|
-
const btn = (0, html_js_1.button)({
|
|
51
|
-
class: "test-class",
|
|
52
|
-
style: { flexDirection: "column" },
|
|
53
|
-
events: { click: () => (clicked = true) },
|
|
54
|
-
});
|
|
55
|
-
btn.dispatchEvent(new Event("click"));
|
|
56
|
-
(0, expect_js_1.expect)(btn.classList.contains("test-class")).toBe(true);
|
|
57
|
-
(0, expect_js_1.expect)(btn.style.flexDirection).toBe("column");
|
|
58
|
-
(0, expect_js_1.expect)(clicked).toBe(true);
|
|
59
|
-
});
|
|
60
|
-
});
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const observable_js_1 = require("./observable.js");
|
|
4
|
-
const observable_js_2 = require("../observable/observable.js");
|
|
5
|
-
const describe_js_1 = require("../scope/describe.js");
|
|
6
|
-
const expect_js_1 = require("../scope/expect.js");
|
|
7
|
-
const html_js_1 = require("./html.js");
|
|
8
|
-
(0, describe_js_1.describe)("DOM Observable", () => {
|
|
9
|
-
(0, describe_js_1.it)("updates a dom node with observable results", async () => {
|
|
10
|
-
const subject = new observable_js_2.Subject();
|
|
11
|
-
const observable = subject.pipe((0, observable_js_2.map)((s) => [s]));
|
|
12
|
-
const element = (0, observable_js_1.O)((0, html_js_1.div)(), observable);
|
|
13
|
-
(0, expect_js_1.expect)(element.innerText).toEqual("");
|
|
14
|
-
await subject.next("H");
|
|
15
|
-
(0, expect_js_1.expect)(element.innerText).toEqual("H");
|
|
16
|
-
await subject.next("He");
|
|
17
|
-
(0, expect_js_1.expect)(element.innerText).toEqual("He");
|
|
18
|
-
});
|
|
19
|
-
(0, describe_js_1.it)("updates a dom node's attributes", async () => {
|
|
20
|
-
const classes = new observable_js_2.Subject();
|
|
21
|
-
const observable = classes.map((c) => [{ class: c.join(" ") }]);
|
|
22
|
-
const element = (0, observable_js_1.O)((0, html_js_1.span)(), observable);
|
|
23
|
-
(0, expect_js_1.expect)(element.classList.contains("warning")).toBe(false);
|
|
24
|
-
(0, expect_js_1.expect)(element.classList.contains("error")).toBe(false);
|
|
25
|
-
await classes.next(["warning"]);
|
|
26
|
-
(0, expect_js_1.expect)(element.classList.contains("warning")).toBe(true);
|
|
27
|
-
(0, expect_js_1.expect)(element.classList.contains("error")).toBe(false);
|
|
28
|
-
await classes.next(["error"]);
|
|
29
|
-
(0, expect_js_1.expect)(element.classList.contains("warning")).toBe(true);
|
|
30
|
-
(0, expect_js_1.expect)(element.classList.contains("error")).toBe(true);
|
|
31
|
-
await classes.next(["!warning", "!error"]);
|
|
32
|
-
(0, expect_js_1.expect)(element.classList.contains("warning")).toBe(false);
|
|
33
|
-
(0, expect_js_1.expect)(element.classList.contains("error")).toBe(false);
|
|
34
|
-
});
|
|
35
|
-
});
|
package/lib/cjs/dom/provide.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.retrieve = exports.provide = void 0;
|
|
4
|
-
let registry = {};
|
|
5
|
-
function provide(items) {
|
|
6
|
-
registry = { ...registry, ...items };
|
|
7
|
-
}
|
|
8
|
-
exports.provide = provide;
|
|
9
|
-
function retrieve(key) {
|
|
10
|
-
return registry[key];
|
|
11
|
-
}
|
|
12
|
-
exports.retrieve = retrieve;
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.link = void 0;
|
|
4
|
-
const html_js_1 = require("../html.js");
|
|
5
|
-
const router_js_1 = require("./router.js");
|
|
6
|
-
const link = ({ href, link }) => (0, html_js_1.a)({ href: router_js_1.Router.href(href), events: { click: router_js_1.Router.navigate(href) } }, link);
|
|
7
|
-
exports.link = link;
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Router = void 0;
|
|
4
|
-
let baseURI = `${document.baseURI}`;
|
|
5
|
-
const normalizeHref = () => {
|
|
6
|
-
return location.href + "/" === baseURI ? baseURI : location.href;
|
|
7
|
-
};
|
|
8
|
-
let globalRouter;
|
|
9
|
-
exports.Router = {
|
|
10
|
-
local(links, index) {
|
|
11
|
-
return exports.Router.for(links, index, false);
|
|
12
|
-
},
|
|
13
|
-
for(links, index, setGlobalRouter = true) {
|
|
14
|
-
let target;
|
|
15
|
-
const partialRouter = (t) => {
|
|
16
|
-
target = t;
|
|
17
|
-
const href = normalizeHref();
|
|
18
|
-
const route = href === baseURI ? baseURI + index : href;
|
|
19
|
-
doNavigate(route);
|
|
20
|
-
window.addEventListener("popstate", () => {
|
|
21
|
-
doNavigate(location.href);
|
|
22
|
-
});
|
|
23
|
-
return target;
|
|
24
|
-
};
|
|
25
|
-
const doNavigate = (link) => {
|
|
26
|
-
link = link.replace(baseURI, "") || index;
|
|
27
|
-
if (link === partialRouter.current) {
|
|
28
|
-
return false;
|
|
29
|
-
}
|
|
30
|
-
partialRouter.current = link;
|
|
31
|
-
target.update((links.find(({ href }) => link.endsWith(href))?.target ??
|
|
32
|
-
(() => undefined))());
|
|
33
|
-
return true;
|
|
34
|
-
};
|
|
35
|
-
const navigate = (url) => {
|
|
36
|
-
return (event) => {
|
|
37
|
-
event.preventDefault();
|
|
38
|
-
if (doNavigate(url || index)) {
|
|
39
|
-
history.pushState(null, "", url);
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
};
|
|
43
|
-
partialRouter.navigate = navigate;
|
|
44
|
-
if (setGlobalRouter) {
|
|
45
|
-
globalRouter = partialRouter;
|
|
46
|
-
}
|
|
47
|
-
return partialRouter;
|
|
48
|
-
},
|
|
49
|
-
href(link) {
|
|
50
|
-
return `${baseURI}${link.replace(/^\//, "")}`;
|
|
51
|
-
},
|
|
52
|
-
navigate(href) {
|
|
53
|
-
return globalRouter?.navigate(href);
|
|
54
|
-
},
|
|
55
|
-
};
|