@davidsouther/jiffies 1.0.0-beta.1 → 2.0.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/{build → lib/cjs}/assert.d.ts +0 -0
- package/lib/cjs/assert.js +40 -0
- package/{build → lib/cjs}/case.d.ts +0 -0
- package/lib/cjs/case.js +9 -0
- package/{build → lib/cjs}/components/button_bar.d.ts +1 -1
- package/lib/cjs/components/button_bar.js +29 -0
- package/{build → lib/cjs}/components/inline_edit.d.ts +1 -1
- package/lib/cjs/components/inline_edit.js +51 -0
- package/{build → lib/cjs}/components/logger.d.ts +2 -3
- package/lib/cjs/components/logger.js +27 -0
- package/lib/cjs/components/select.d.ts +10 -0
- package/lib/cjs/components/select.js +6 -0
- package/lib/cjs/components/test.d.ts +1 -0
- package/lib/cjs/components/test.js +7 -0
- package/{build → lib/cjs}/components/virtual_scroll.d.ts +3 -4
- package/lib/cjs/components/virtual_scroll.js +102 -0
- package/{build → lib/cjs}/components/virtual_scroll.test.d.ts +0 -0
- package/lib/cjs/components/virtual_scroll.test.js +22 -0
- package/{build → lib/cjs}/context.d.ts +0 -0
- package/lib/cjs/context.js +48 -0
- package/{build → lib/cjs}/context.test.d.ts +0 -0
- package/lib/cjs/context.test.js +48 -0
- package/{build → lib/cjs}/debounce.d.ts +0 -0
- package/lib/cjs/debounce.js +11 -0
- package/lib/cjs/diff.d.ts +15 -0
- package/lib/cjs/diff.js +58 -0
- package/{build/components/index.d.ts → lib/cjs/diff.test.d.ts} +0 -0
- package/lib/cjs/diff.test.js +41 -0
- package/{build → lib/cjs}/display.d.ts +0 -0
- package/lib/cjs/display.js +16 -0
- package/{build → lib/cjs}/dom/css/border.d.ts +0 -0
- package/lib/cjs/dom/css/border.js +33 -0
- package/{build → lib/cjs}/dom/css/constants.d.ts +0 -0
- package/lib/cjs/dom/css/constants.js +31 -0
- package/{build → lib/cjs}/dom/css/core.d.ts +0 -0
- package/lib/cjs/dom/css/core.js +31 -0
- package/{build → lib/cjs}/dom/css/fstyle.d.ts +0 -0
- package/lib/cjs/dom/css/fstyle.js +36 -0
- package/{build → lib/cjs}/dom/css/sizing.d.ts +0 -0
- package/lib/cjs/dom/css/sizing.js +14 -0
- package/lib/cjs/dom/dom.d.ts +27 -0
- package/lib/cjs/dom/dom.js +110 -0
- package/{build → lib/cjs}/dom/fc.d.ts +5 -5
- package/lib/cjs/dom/fc.js +39 -0
- package/{build → lib/cjs}/dom/fc.test.d.ts +0 -0
- package/lib/cjs/dom/fc.test.js +23 -0
- package/lib/cjs/dom/form/form.app.d.ts +1 -0
- package/lib/cjs/dom/form/form.app.js +27 -0
- package/lib/cjs/dom/form/form.d.ts +26 -0
- package/lib/cjs/dom/form/form.js +49 -0
- package/{build → lib/cjs}/dom/form/form.test.d.ts +0 -0
- package/{build → lib/cjs}/dom/form/form.test.js +0 -0
- package/lib/cjs/dom/html.d.ts +113 -0
- package/lib/cjs/dom/html.js +119 -0
- package/{build → lib/cjs}/dom/html.test.d.ts +0 -0
- package/lib/cjs/dom/html.test.js +60 -0
- package/lib/cjs/dom/observable.d.ts +2 -0
- package/lib/cjs/dom/observable.js +10 -0
- package/{build/components/index.js → lib/cjs/dom/observable.test.d.ts} +0 -0
- package/lib/cjs/dom/observable.test.js +35 -0
- package/lib/cjs/dom/provide.d.ts +3 -0
- package/lib/cjs/dom/provide.js +12 -0
- package/lib/cjs/dom/router/link.d.ts +6 -0
- package/lib/cjs/dom/router/link.js +7 -0
- package/{build → lib/cjs}/dom/router/router.d.ts +3 -3
- package/lib/cjs/dom/router/router.js +52 -0
- package/lib/cjs/dom/svg.d.ts +64 -0
- package/lib/cjs/dom/svg.js +69 -0
- package/lib/cjs/dom/test.d.ts +1 -0
- package/lib/cjs/dom/test.js +13 -0
- package/{build → lib/cjs}/dom/types/css.d.ts +0 -0
- package/lib/cjs/dom/types/css.js +24 -0
- package/{build → lib/cjs}/dom/types/dom.d.ts +0 -0
- package/{build → lib/cjs}/dom/types/dom.js +0 -0
- package/{build → lib/cjs}/dom/types/html.d.ts +1 -1
- package/lib/cjs/dom/types/html.js +2 -0
- package/{build → lib/cjs}/dom/xml.d.ts +0 -0
- package/lib/cjs/dom/xml.js +8 -0
- package/lib/cjs/equal.d.ts +5 -0
- package/lib/cjs/equal.js +43 -0
- package/{build → lib/cjs}/equal.test.d.ts +0 -0
- package/lib/cjs/equal.test.js +22 -0
- package/{build → lib/cjs}/flags.d.ts +0 -0
- package/lib/cjs/flags.js +52 -0
- package/{build → lib/cjs}/flags.test.d.ts +0 -0
- package/lib/cjs/flags.test.js +37 -0
- package/lib/cjs/fs.d.ts +48 -0
- package/lib/cjs/fs.js +151 -0
- package/{build/components/test.d.ts → lib/cjs/fs.test.d.ts} +0 -0
- package/lib/cjs/fs.test.js +45 -0
- package/{build → lib/cjs}/generator.d.ts +0 -0
- package/lib/cjs/generator.js +14 -0
- package/{build → lib/cjs}/generator.test.d.ts +0 -0
- package/lib/cjs/generator.test.js +26 -0
- package/{build → lib/cjs}/is_browser.d.ts +0 -0
- package/lib/cjs/is_browser.js +4 -0
- package/{build → lib/cjs}/loader.d.mts +0 -0
- package/lib/cjs/loader.mjs +40 -0
- package/{build → lib/cjs}/lock.d.ts +0 -0
- package/lib/cjs/lock.js +27 -0
- package/{build → lib/cjs}/lock.test.d.ts +0 -0
- package/lib/cjs/lock.test.js +18 -0
- package/{build → lib/cjs}/log.d.ts +0 -0
- package/lib/cjs/log.js +54 -0
- package/lib/cjs/observable/event.d.ts +35 -0
- package/lib/cjs/observable/event.js +61 -0
- package/lib/cjs/observable/observable.d.ts +132 -0
- package/lib/cjs/observable/observable.js +363 -0
- package/{build/dom/test.d.ts → lib/cjs/observable/observable.test.d.ts} +0 -0
- package/lib/cjs/observable/observable.test.js +65 -0
- package/{build → lib/cjs}/range.d.ts +0 -0
- package/lib/cjs/range.js +11 -0
- package/{build → lib/cjs}/result.d.ts +11 -11
- package/lib/cjs/result.js +80 -0
- package/{build → lib/cjs}/result.test.d.ts +0 -0
- package/lib/cjs/result.test.js +73 -0
- package/{build → lib/cjs}/safe.d.ts +0 -0
- package/lib/cjs/safe.js +14 -0
- package/{build → lib/cjs}/scope/describe.d.ts +4 -0
- package/lib/cjs/scope/describe.js +73 -0
- package/{build → lib/cjs}/scope/display/console.d.ts +0 -0
- package/lib/cjs/scope/display/console.js +25 -0
- package/{build → lib/cjs}/scope/display/dom.d.ts +2 -2
- package/lib/cjs/scope/display/dom.js +30 -0
- package/{build → lib/cjs}/scope/display/junit.d.ts +0 -0
- package/lib/cjs/scope/display/junit.js +21 -0
- package/{build → lib/cjs}/scope/execute.d.ts +1 -1
- package/lib/cjs/scope/execute.js +91 -0
- package/{build → lib/cjs}/scope/expect.d.ts +1 -1
- package/lib/cjs/scope/expect.js +114 -0
- package/{build → lib/cjs}/scope/fix.d.ts +0 -0
- package/lib/cjs/scope/fix.js +26 -0
- package/{build → lib/cjs}/scope/index.d.ts +0 -0
- package/lib/cjs/scope/index.js +15 -0
- package/{build → lib/cjs}/scope/scope.d.ts +0 -0
- package/lib/cjs/scope/scope.js +2 -0
- package/lib/cjs/scope/state.d.ts +1 -0
- package/lib/cjs/scope/state.js +11 -0
- package/{build → lib/cjs}/server/http/apps.d.ts +0 -0
- package/lib/cjs/server/http/apps.js +27 -0
- package/lib/cjs/server/http/css.d.ts +5 -0
- package/lib/cjs/server/http/css.js +54 -0
- package/{build → lib/cjs}/server/http/index.d.ts +0 -0
- package/lib/cjs/server/http/index.js +77 -0
- package/{build → lib/cjs}/server/http/response.d.ts +0 -0
- package/lib/cjs/server/http/response.js +45 -0
- package/{build → lib/cjs}/server/http/sitemap.d.ts +0 -0
- package/lib/cjs/server/http/sitemap.js +46 -0
- package/{build → lib/cjs}/server/http/static.d.ts +0 -0
- package/lib/cjs/server/http/static.js +25 -0
- package/{build → lib/cjs}/server/http/typescript.d.ts +0 -0
- package/lib/cjs/server/http/typescript.js +44 -0
- package/{build → lib/cjs}/server/main.d.ts +0 -0
- package/lib/cjs/server/main.js +14 -0
- package/{build → lib/cjs}/test.d.mts +0 -0
- package/lib/cjs/test.mjs +28 -0
- package/lib/cjs/test_all.d.ts +9 -0
- package/lib/cjs/test_all.js +30 -0
- package/{build → lib/cjs}/transpile.d.mts +0 -0
- package/lib/cjs/transpile.mjs +22 -0
- package/lib/cjs/tsconfig.tsbuildinfo +1 -0
- package/lib/esm/assert.d.ts +23 -0
- package/{build → lib/esm}/assert.js +1 -1
- package/lib/esm/case.d.ts +1 -0
- package/{build → lib/esm}/case.js +0 -0
- package/lib/esm/components/button_bar.d.ts +8 -0
- package/lib/esm/components/button_bar.js +27 -0
- package/lib/esm/components/inline_edit.d.ts +12 -0
- package/{build → lib/esm}/components/inline_edit.js +3 -3
- package/lib/esm/components/logger.d.ts +6 -0
- package/{build → lib/esm}/components/logger.js +3 -3
- package/lib/esm/components/select.d.ts +10 -0
- package/{build → lib/esm}/components/select.js +2 -2
- package/lib/esm/components/test.d.ts +1 -0
- package/lib/esm/components/test.js +3 -0
- package/lib/esm/components/virtual_scroll.d.ts +40 -0
- package/{build → lib/esm}/components/virtual_scroll.js +3 -3
- package/{build/dom/types/html.js → lib/esm/components/virtual_scroll.test.d.ts} +0 -0
- package/{build → lib/esm}/components/virtual_scroll.test.js +3 -4
- package/lib/esm/context.d.ts +15 -0
- package/{build → lib/esm}/context.js +3 -3
- package/{build/scope/scope.js → lib/esm/context.test.d.ts} +0 -0
- package/{build → lib/esm}/context.test.js +0 -0
- package/lib/esm/debounce.d.ts +1 -0
- package/{build → lib/esm}/debounce.js +0 -0
- package/lib/esm/diff.d.ts +15 -0
- package/lib/esm/diff.js +54 -0
- package/{build/test_all.d.ts → lib/esm/diff.test.d.ts} +0 -0
- package/lib/esm/diff.test.js +39 -0
- package/lib/esm/display.d.ts +5 -0
- package/lib/esm/display.js +11 -0
- package/lib/esm/dom/css/border.d.ts +11 -0
- package/{build → lib/esm}/dom/css/border.js +0 -0
- package/lib/esm/dom/css/constants.d.ts +31 -0
- package/{build → lib/esm}/dom/css/constants.js +0 -0
- package/lib/esm/dom/css/core.d.ts +5 -0
- package/{build → lib/esm}/dom/css/core.js +0 -0
- package/lib/esm/dom/css/fstyle.d.ts +5 -0
- package/{build → lib/esm}/dom/css/fstyle.js +0 -0
- package/lib/esm/dom/css/sizing.d.ts +5 -0
- package/{build → lib/esm}/dom/css/sizing.js +0 -0
- package/lib/esm/dom/dom.d.ts +27 -0
- package/{build → lib/esm}/dom/dom.js +44 -34
- package/lib/esm/dom/fc.d.ts +14 -0
- package/{build → lib/esm}/dom/fc.js +1 -1
- package/lib/esm/dom/fc.test.d.ts +1 -0
- package/{build → lib/esm}/dom/fc.test.js +0 -0
- package/lib/esm/dom/form/form.app.d.ts +1 -0
- package/{build → lib/esm}/dom/form/form.app.js +0 -0
- package/lib/esm/dom/form/form.d.ts +26 -0
- package/{build → lib/esm}/dom/form/form.js +14 -5
- package/lib/esm/dom/form/form.test.d.ts +0 -0
- package/lib/esm/dom/form/form.test.js +1 -0
- package/lib/esm/dom/html.d.ts +113 -0
- package/{build → lib/esm}/dom/html.js +0 -0
- package/lib/esm/dom/html.test.d.ts +1 -0
- package/{build → lib/esm}/dom/html.test.js +4 -4
- package/lib/esm/dom/observable.d.ts +2 -0
- package/lib/esm/dom/observable.js +6 -0
- package/lib/esm/dom/observable.test.d.ts +1 -0
- package/lib/esm/dom/observable.test.js +33 -0
- package/lib/esm/dom/provide.d.ts +3 -0
- package/lib/esm/dom/provide.js +7 -0
- package/lib/esm/dom/router/link.d.ts +6 -0
- package/{build → lib/esm}/dom/router/link.js +0 -0
- package/lib/esm/dom/router/router.d.ts +12 -0
- package/{build → lib/esm}/dom/router/router.js +0 -0
- package/lib/esm/dom/svg.d.ts +64 -0
- package/{build → lib/esm}/dom/svg.js +0 -0
- package/lib/esm/dom/test.d.ts +1 -0
- package/lib/esm/dom/test.js +9 -0
- package/lib/esm/dom/types/css.d.ts +6612 -0
- package/{build → lib/esm}/dom/types/css.js +0 -0
- package/lib/esm/dom/types/dom.d.ts +0 -0
- package/lib/esm/dom/types/dom.js +1 -0
- package/lib/esm/dom/types/html.d.ts +616 -0
- package/lib/esm/dom/types/html.js +1 -0
- package/lib/esm/dom/xml.d.ts +1 -0
- package/{build → lib/esm}/dom/xml.js +1 -2
- package/lib/esm/equal.d.ts +5 -0
- package/lib/esm/equal.js +37 -0
- package/lib/esm/equal.test.d.ts +1 -0
- package/{build → lib/esm}/equal.test.js +0 -0
- package/lib/esm/flags.d.ts +7 -0
- package/{build → lib/esm}/flags.js +1 -1
- package/lib/esm/flags.test.d.ts +1 -0
- package/{build → lib/esm}/flags.test.js +0 -0
- package/lib/esm/fs.d.ts +48 -0
- package/lib/esm/fs.js +144 -0
- package/lib/esm/fs.test.d.ts +1 -0
- package/lib/esm/fs.test.js +43 -0
- package/lib/esm/generator.d.ts +1 -0
- package/{build → lib/esm}/generator.js +0 -0
- package/lib/esm/generator.test.d.ts +1 -0
- package/{build → lib/esm}/generator.test.js +0 -0
- package/lib/esm/is_browser.d.ts +1 -0
- package/{build → lib/esm}/is_browser.js +0 -0
- package/lib/esm/loader.d.mts +22 -0
- package/{build → lib/esm}/loader.mjs +0 -0
- package/lib/esm/lock.d.ts +1 -0
- package/{build → lib/esm}/lock.js +0 -0
- package/lib/esm/lock.test.d.ts +1 -0
- package/{build → lib/esm}/lock.test.js +0 -0
- package/lib/esm/log.d.ts +26 -0
- package/{build → lib/esm}/log.js +16 -4
- package/lib/esm/observable/event.d.ts +35 -0
- package/lib/esm/observable/event.js +46 -0
- package/lib/esm/observable/observable.d.ts +132 -0
- package/lib/esm/observable/observable.js +343 -0
- package/lib/esm/observable/observable.test.d.ts +1 -0
- package/lib/esm/observable/observable.test.js +63 -0
- package/lib/esm/range.d.ts +1 -0
- package/{build → lib/esm}/range.js +0 -0
- package/lib/esm/result.d.ts +31 -0
- package/{build → lib/esm}/result.js +3 -3
- package/lib/esm/result.test.d.ts +1 -0
- package/{build → lib/esm}/result.test.js +0 -0
- package/lib/esm/safe.d.ts +1 -0
- package/{build → lib/esm}/safe.js +0 -0
- package/lib/esm/scope/describe.d.ts +18 -0
- package/{build → lib/esm}/scope/describe.js +14 -6
- package/lib/esm/scope/display/console.d.ts +2 -0
- package/{build → lib/esm}/scope/display/console.js +0 -0
- package/lib/esm/scope/display/dom.d.ts +3 -0
- package/{build → lib/esm}/scope/display/dom.js +0 -0
- package/lib/esm/scope/display/junit.d.ts +2 -0
- package/{build → lib/esm}/scope/display/junit.js +0 -0
- package/lib/esm/scope/execute.d.ts +12 -0
- package/{build → lib/esm}/scope/execute.js +3 -3
- package/lib/esm/scope/expect.d.ts +23 -0
- package/{build → lib/esm}/scope/expect.js +4 -3
- package/lib/esm/scope/fix.d.ts +4 -0
- package/{build → lib/esm}/scope/fix.js +0 -0
- package/{build/scope/index.js → lib/esm/scope/index.d.ts} +0 -0
- package/lib/esm/scope/index.js +3 -0
- package/lib/esm/scope/scope.d.ts +17 -0
- package/lib/esm/scope/scope.js +1 -0
- package/lib/esm/scope/state.d.ts +1 -0
- package/lib/esm/scope/state.js +7 -0
- package/lib/esm/server/http/apps.d.ts +5 -0
- package/{build → lib/esm}/server/http/apps.js +0 -0
- package/lib/esm/server/http/css.d.ts +5 -0
- package/lib/esm/server/http/css.js +50 -0
- package/lib/esm/server/http/index.d.ts +21 -0
- package/{build → lib/esm}/server/http/index.js +4 -2
- package/lib/esm/server/http/response.d.ts +4 -0
- package/{build → lib/esm}/server/http/response.js +6 -3
- package/lib/esm/server/http/sitemap.d.ts +2 -0
- package/{build → lib/esm}/server/http/sitemap.js +0 -0
- package/lib/esm/server/http/static.d.ts +2 -0
- package/{build → lib/esm}/server/http/static.js +0 -0
- package/lib/esm/server/http/typescript.d.ts +5 -0
- package/{build → lib/esm}/server/http/typescript.js +0 -0
- package/lib/esm/server/main.d.ts +2 -0
- package/{build → lib/esm}/server/main.js +5 -2
- package/lib/esm/test.d.mts +2 -0
- package/lib/esm/test.mjs +26 -0
- package/lib/esm/test_all.d.ts +9 -0
- package/lib/esm/test_all.js +28 -0
- package/lib/esm/transpile.d.mts +3 -0
- package/{build → lib/esm}/transpile.mjs +0 -0
- package/lib/esm/tsconfig.tsbuildinfo +1 -0
- package/package.json +18 -16
- package/src/assert.ts +1 -1
- package/src/components/button_bar.ts +33 -27
- package/src/components/inline_edit.ts +3 -3
- package/src/components/logger.ts +5 -6
- package/src/components/select.ts +3 -3
- package/src/components/test.js +3 -2
- package/src/components/virtual_scroll.test.ts +4 -4
- package/src/components/virtual_scroll.ts +8 -8
- package/src/context.ts +3 -3
- package/src/diff.test.ts +48 -0
- package/src/diff.ts +84 -0
- package/src/display.ts +8 -2
- package/src/dom/css/border.ts +3 -3
- package/src/dom/css/core.ts +1 -1
- package/src/dom/css/fstyle.ts +2 -2
- package/src/dom/css/sizing.ts +1 -1
- package/src/dom/dom.ts +73 -60
- package/src/dom/fc.test.ts +3 -3
- package/src/dom/fc.ts +11 -10
- package/src/dom/form/form.app.ts +2 -2
- package/src/dom/form/form.ts +33 -10
- package/src/dom/html.test.ts +8 -8
- package/src/dom/html.ts +7 -10
- package/src/dom/observable.test.ts +43 -0
- package/src/dom/observable.ts +11 -0
- package/src/dom/provide.ts +11 -0
- package/src/dom/router/link.ts +2 -2
- package/src/dom/router/router.ts +5 -5
- package/src/dom/svg.ts +1 -1
- package/src/dom/test.ts +8 -2
- package/src/dom/types/html.ts +1 -1
- package/src/dom/xml.ts +1 -2
- package/src/equal.ts +22 -11
- package/src/flags.ts +1 -1
- package/src/fs.test.ts +53 -0
- package/src/fs.ts +180 -0
- package/src/index.html +16 -13
- package/src/log.ts +8 -4
- package/src/observable/_notes +21 -8
- package/src/observable/event.ts +93 -0
- package/src/observable/observable.test.ts +73 -0
- package/src/observable/observable.ts +463 -0
- package/src/pico/_variables.scss +66 -0
- package/src/pico/components/_accordion.scss +112 -0
- package/src/pico/components/_button-group.scss +51 -0
- package/src/pico/components/_card.scss +47 -0
- package/src/pico/components/_dropdown.scss +203 -0
- package/src/pico/components/_modal.scss +181 -0
- package/src/pico/components/_nav.scss +79 -0
- package/src/pico/components/_progress.scss +70 -0
- package/src/pico/components/_property.scss +34 -0
- package/src/pico/content/_button.scss +152 -0
- package/src/pico/content/_code.scss +63 -0
- package/src/pico/content/_embedded.scss +0 -0
- package/src/pico/content/_form-alt.scss +276 -0
- package/src/pico/content/_form.scss +259 -0
- package/src/pico/content/_misc.scss +0 -0
- package/src/pico/content/_table.scss +28 -0
- package/src/pico/content/_toggle.scss +132 -0
- package/src/pico/content/_typography.scss +232 -0
- package/src/pico/layout/_container.scss +40 -0
- package/src/pico/layout/_document.scss +0 -0
- package/src/pico/layout/_flex.scss +46 -0
- package/src/pico/layout/_grid.scss +24 -0
- package/src/pico/layout/_scroller.scss +16 -0
- package/src/pico/layout/_section.scss +8 -0
- package/src/pico/layout/_sectioning.scss +55 -0
- package/src/pico/pico.scss +60 -0
- package/src/pico/reset/_accessibility.scss +34 -0
- package/src/pico/reset/_button.scss +17 -0
- package/src/pico/reset/_code.scss +15 -0
- package/src/pico/reset/_document.scss +48 -0
- package/src/pico/reset/_embedded.scss +39 -0
- package/src/pico/reset/_form.scss +97 -0
- package/src/pico/reset/_misc.scss +23 -0
- package/src/pico/reset/_nav.scss +5 -0
- package/src/pico/reset/_progress.scss +4 -0
- package/src/pico/reset/_table.scss +8 -0
- package/src/pico/reset/_typography.scss +25 -0
- package/src/pico/themes/default/_colors.scss +65 -0
- package/src/pico/themes/default/_dark.scss +148 -0
- package/src/pico/themes/default/_light.scss +149 -0
- package/src/pico/themes/default/_styles.scss +272 -0
- package/src/pico/themes/default.scss +34 -0
- package/src/pico/utilities/_accessibility.scss +3 -0
- package/src/pico/utilities/_loading.scss +52 -0
- package/src/pico/utilities/_reduce-motion.scss +27 -0
- package/src/pico/utilities/_tooltip.scss +101 -0
- package/src/result.ts +17 -21
- package/src/scope/describe.ts +16 -6
- package/src/scope/display/console.ts +4 -4
- package/src/scope/display/dom.ts +7 -7
- package/src/scope/display/junit.ts +3 -3
- package/src/scope/execute.ts +5 -8
- package/src/scope/expect.ts +12 -11
- package/src/scope/state.ts +10 -0
- package/src/server/http/css.ts +65 -0
- package/src/server/http/index.ts +4 -2
- package/src/server/http/response.ts +7 -4
- package/src/server/http/sitemap.ts +1 -1
- package/src/server/main.ts +9 -2
- package/src/test.mjs +22 -18
- package/src/test_all.ts +20 -9
- package/src/zip/spec.txt +3260 -0
- package/build/components/button_bar.js +0 -16
- package/build/components/select.d.ts +0 -13
- package/build/components/test.js +0 -2
- package/build/display.js +0 -3
- package/build/dom/dom.d.ts +0 -27
- package/build/dom/form/form.app.d.ts +0 -1
- package/build/dom/form/form.d.ts +0 -25
- package/build/dom/html.d.ts +0 -117
- package/build/dom/router/link.d.ts +0 -6
- package/build/dom/svg.d.ts +0 -64
- package/build/dom/test.js +0 -2
- package/build/equal.d.ts +0 -4
- package/build/equal.js +0 -22
- package/build/index.d.ts +0 -13
- package/build/index.js +0 -13
- package/build/parcel_resolver.d.ts +0 -3
- package/build/parcel_resolver.js +0 -19
- package/build/test.mjs +0 -23
- package/build/test_all.js +0 -19
- package/src/observable/observable._js +0 -175
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { debounce } from "../debounce.js";
|
|
2
2
|
import { FC, State } from "../dom/fc.js";
|
|
3
|
-
import { div
|
|
3
|
+
import { div } from "../dom/html.js";
|
|
4
4
|
|
|
5
5
|
export interface VirtualScrollSettings {
|
|
6
6
|
minIndex: number;
|
|
@@ -22,7 +22,7 @@ export function arrayAdapter<T>(data: T[]): VirtualScrollDataAdapter<T> {
|
|
|
22
22
|
export interface VirtualScrollProps<T, U extends HTMLElement> {
|
|
23
23
|
settings: Partial<VirtualScrollSettings>;
|
|
24
24
|
get: VirtualScrollDataAdapter<T>;
|
|
25
|
-
row: (t: T) =>
|
|
25
|
+
row: (t: T) => U;
|
|
26
26
|
}
|
|
27
27
|
|
|
28
28
|
export function fillVirtualScrollSettings(
|
|
@@ -30,7 +30,7 @@ export function fillVirtualScrollSettings(
|
|
|
30
30
|
): VirtualScrollSettings {
|
|
31
31
|
const {
|
|
32
32
|
minIndex = 0,
|
|
33
|
-
maxIndex =
|
|
33
|
+
maxIndex = Number.MAX_SAFE_INTEGER,
|
|
34
34
|
startIndex = 0,
|
|
35
35
|
itemHeight = 20,
|
|
36
36
|
count = maxIndex - minIndex + 1,
|
|
@@ -121,7 +121,7 @@ interface VirtualScrollState<T, U extends HTMLElement = HTMLElement> {
|
|
|
121
121
|
bottomPaddingHeight: number; // px
|
|
122
122
|
toleranceHeight: number; // px
|
|
123
123
|
data: T[];
|
|
124
|
-
rows:
|
|
124
|
+
rows: U[];
|
|
125
125
|
}
|
|
126
126
|
|
|
127
127
|
// export interface VirtualScroll<T, U extends HTMLElement> {
|
|
@@ -130,8 +130,8 @@ interface VirtualScrollState<T, U extends HTMLElement = HTMLElement> {
|
|
|
130
130
|
// }
|
|
131
131
|
|
|
132
132
|
export const VirtualScroll = FC<
|
|
133
|
-
VirtualScrollProps<
|
|
134
|
-
VirtualScrollState<
|
|
133
|
+
VirtualScrollProps<any, HTMLElement>,
|
|
134
|
+
VirtualScrollState<any, HTMLElement>
|
|
135
135
|
>("virtual-scroll", (element, props) => {
|
|
136
136
|
const settings = fillVirtualScrollSettings(props.settings);
|
|
137
137
|
const state = (element[State] = {
|
|
@@ -163,14 +163,14 @@ export const VirtualScroll = FC<
|
|
|
163
163
|
state.topPaddingHeight = newState.topPaddingHeight;
|
|
164
164
|
state.bottomPaddingHeight = newState.bottomPaddingHeight;
|
|
165
165
|
state.data = newState.data;
|
|
166
|
-
|
|
166
|
+
state.rows = state.data.map(props.row);
|
|
167
167
|
|
|
168
168
|
viewportElement.update(
|
|
169
169
|
div({
|
|
170
170
|
class: "VirtualScroll__topPadding",
|
|
171
171
|
style: { height: `${state.topPaddingHeight}px` },
|
|
172
172
|
}),
|
|
173
|
-
...(
|
|
173
|
+
...(state.rows ?? []).map((row, i) =>
|
|
174
174
|
div(
|
|
175
175
|
{
|
|
176
176
|
class: `VirtualScroll__item_${i}`,
|
package/src/context.ts
CHANGED
|
@@ -21,8 +21,8 @@ export function using<T, E extends Error, C extends Context>(
|
|
|
21
21
|
operation?: Operation<T, E, C>,
|
|
22
22
|
normalizeError: (e: Error | unknown | any) => Err<E> = (e) => Err(e)
|
|
23
23
|
): Result<T, E> {
|
|
24
|
-
if (typeof context
|
|
25
|
-
if (context.length
|
|
24
|
+
if (typeof context === "function") {
|
|
25
|
+
if (context.length === 1) {
|
|
26
26
|
operation = context as Operation<T, E, C>;
|
|
27
27
|
context = {} as C;
|
|
28
28
|
} else {
|
|
@@ -47,7 +47,7 @@ export async function asyncUsing<T, E extends Error, C extends Context>(
|
|
|
47
47
|
operation: AsyncOperation<T, E, C>,
|
|
48
48
|
normalizeError: (e: Error | unknown | any) => Err<E> = (e: E) => Err(e)
|
|
49
49
|
): Promise<Result<T, E>> {
|
|
50
|
-
context = typeof context
|
|
50
|
+
context = typeof context === "function" ? await context() : context;
|
|
51
51
|
let result: Result<T, E>;
|
|
52
52
|
try {
|
|
53
53
|
context[Enter]();
|
package/src/diff.test.ts
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { diff } from "./diff.js";
|
|
2
|
+
import { describe, it } from "./scope/describe.js";
|
|
3
|
+
import { expect } from "./scope/expect.js";
|
|
4
|
+
|
|
5
|
+
describe("diff", () => {
|
|
6
|
+
it("diffs primitives", () => {
|
|
7
|
+
const diffed = diff(1, 2);
|
|
8
|
+
expect(diffed).toEqual([{ key: "", left: 1, right: 2 }]);
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
it("diffs objects", () => {
|
|
12
|
+
const diffed = diff({ a: 1, b: 2 }, { a: 2, b: 2 });
|
|
13
|
+
expect(diffed).toEqual([{ key: "a", left: 1, right: 2 }]);
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
it("diffs nested objects", () => {
|
|
17
|
+
const diffed = diff({ a: { c: 1 }, b: 2 }, { a: { c: 2 }, b: 2 });
|
|
18
|
+
expect(diffed).toEqual([
|
|
19
|
+
{ key: "a", children: [{ key: "c", left: 1, right: 2 }] },
|
|
20
|
+
]);
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
it("diffs missing sides", () => {
|
|
24
|
+
const diffed = diff<{ a?: number; b?: number }>({ a: 1 }, { b: 2 });
|
|
25
|
+
expect(diffed).toEqual([
|
|
26
|
+
{ key: "a", left: 1, right: undefined },
|
|
27
|
+
{ key: "b", left: undefined, right: 2 },
|
|
28
|
+
]);
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
it("diffs arrays", () => {
|
|
32
|
+
const diffed = diff<number[]>([1, 2, 3], [1, 4, 3]);
|
|
33
|
+
expect(diffed).toEqual([{ key: 1, left: 2, right: 4 }]);
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
it("diffs objects in an array", () => {
|
|
37
|
+
const diffed = diff(
|
|
38
|
+
[{ a: { b: 1 } }, { a: { b: 2 } }, { a: { b: 3 } }],
|
|
39
|
+
[{ a: { b: 1 } }, { a: { b: 4 } }, { a: { b: 3 } }]
|
|
40
|
+
);
|
|
41
|
+
expect(diffed).toEqual([
|
|
42
|
+
{
|
|
43
|
+
key: 1,
|
|
44
|
+
children: [{ key: "a", children: [{ key: "b", left: 2, right: 4 }] }],
|
|
45
|
+
},
|
|
46
|
+
]);
|
|
47
|
+
});
|
|
48
|
+
});
|
package/src/diff.ts
ADDED
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { range } from "./range.js";
|
|
2
|
+
import { isSome, None, Option, Some } from "./result.js";
|
|
3
|
+
|
|
4
|
+
export const DiffA = Symbol("A");
|
|
5
|
+
export const DiffB = Symbol("B");
|
|
6
|
+
|
|
7
|
+
export type DiffIndex = string | number;
|
|
8
|
+
export type DiffPrimitive = string | number | boolean | null | undefined;
|
|
9
|
+
|
|
10
|
+
interface DiffEntry {
|
|
11
|
+
key: DiffIndex;
|
|
12
|
+
left: DiffPrimitive;
|
|
13
|
+
right: DiffPrimitive;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
interface DiffList {
|
|
17
|
+
key: DiffIndex;
|
|
18
|
+
children: (DiffEntry | DiffList)[];
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function doDiff<T>(va: T, vb: T, k: DiffIndex): Option<DiffList | DiffEntry> {
|
|
22
|
+
if (Array.isArray(va)) {
|
|
23
|
+
// @ts-ignore
|
|
24
|
+
return diffArray(va, vb, k);
|
|
25
|
+
}
|
|
26
|
+
if (typeof va === "object") {
|
|
27
|
+
const d = diffObject(va, vb, k);
|
|
28
|
+
if (d.children.length === 0) {
|
|
29
|
+
return None();
|
|
30
|
+
} else {
|
|
31
|
+
return Some(d);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
if (Object.is(va, vb)) {
|
|
35
|
+
return None();
|
|
36
|
+
} else {
|
|
37
|
+
// @ts-ignore
|
|
38
|
+
return { key: k, left: va, right: vb };
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function diffArray<T>(
|
|
43
|
+
a: Partial<T>[],
|
|
44
|
+
b: Partial<T>[],
|
|
45
|
+
key: DiffIndex
|
|
46
|
+
): Option<DiffList> {
|
|
47
|
+
const indexes = Math.max(a.length, b.length);
|
|
48
|
+
const children = range(0, indexes)
|
|
49
|
+
.map((i) => doDiff(a[i], b[i], i))
|
|
50
|
+
.filter(isSome);
|
|
51
|
+
return children.length > 0 ? { key, children } : None();
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
function diffObject<T>(
|
|
55
|
+
a: Partial<T>,
|
|
56
|
+
b: Partial<T>,
|
|
57
|
+
key: DiffIndex = ""
|
|
58
|
+
): DiffList {
|
|
59
|
+
const keys = new Set([...Object.keys(a), ...Object.keys(b)]);
|
|
60
|
+
const children = [...keys]
|
|
61
|
+
// @ts-ignore
|
|
62
|
+
.map((k) => doDiff(a[k], b[k], k))
|
|
63
|
+
.filter(isSome);
|
|
64
|
+
return {
|
|
65
|
+
key,
|
|
66
|
+
children,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
export function diff<T>(
|
|
71
|
+
a: Partial<T>,
|
|
72
|
+
b: Partial<T>
|
|
73
|
+
): (DiffEntry | DiffList)[] {
|
|
74
|
+
if (typeof a != "object" && !Object.is(a, b)) {
|
|
75
|
+
// @ts-ignore
|
|
76
|
+
return [{ key: "", left: a, right: b }];
|
|
77
|
+
}
|
|
78
|
+
return (
|
|
79
|
+
Array.isArray(a)
|
|
80
|
+
? // @ts-ignore
|
|
81
|
+
diffArray(a, b, "") ?? { children: [] }
|
|
82
|
+
: diffObject(a, b, "")
|
|
83
|
+
).children;
|
|
84
|
+
}
|
package/src/display.ts
CHANGED
|
@@ -8,5 +8,11 @@ export const isDisplay = (/** @type unknown */ a: unknown): a is Display =>
|
|
|
8
8
|
typeof (a as Display).toString === "function" ||
|
|
9
9
|
typeof (a as Display) === "string";
|
|
10
10
|
|
|
11
|
-
export const display = (a: unknown | Display): string =>
|
|
12
|
-
isDisplay(a)
|
|
11
|
+
export const display = (a: unknown | Display): string => {
|
|
12
|
+
if (isDisplay(a)) {
|
|
13
|
+
const str = a.toString();
|
|
14
|
+
if (str === "[object Object]") return JSON.stringify(a);
|
|
15
|
+
return str;
|
|
16
|
+
}
|
|
17
|
+
return JSON.stringify(a);
|
|
18
|
+
};
|
package/src/dom/css/border.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Properties } from "../types/css.js"
|
|
2
|
-
import { Side, Size } from "./constants.js"
|
|
3
|
-
import { isSide, getSize, getSide } from "./core.js"
|
|
1
|
+
import { Properties } from "../types/css.js"
|
|
2
|
+
import { Side, Size } from "./constants.js"
|
|
3
|
+
import { isSide, getSize, getSide } from "./core.js"
|
|
4
4
|
|
|
5
5
|
export function rounded(size: Size = "", side: Side = "") {
|
|
6
6
|
if (isSide(size)) {
|
package/src/dom/css/core.ts
CHANGED
package/src/dom/css/fstyle.ts
CHANGED
package/src/dom/css/sizing.ts
CHANGED
package/src/dom/dom.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { Properties } from "./types/css.js"
|
|
2
2
|
|
|
3
3
|
const Events = Symbol("events");
|
|
4
4
|
export const CLEAR = Symbol("Clear children");
|
|
@@ -10,40 +10,44 @@ export type DOMElement = Element &
|
|
|
10
10
|
DocumentAndElementEventHandlers &
|
|
11
11
|
ElementCSSInlineStyle;
|
|
12
12
|
|
|
13
|
-
export type Updater<E extends DOMElement> = Omit<E, "style"> & {
|
|
14
|
-
[Events]?: Map<string, EventHandler>;
|
|
15
|
-
update?: (attrs?: DenormAttrs<E>, ...children: DenormChildren[]) => Node;
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export type Updatable<E extends Element> = Omit<E, "style"> & {
|
|
19
|
-
[Events]: Map<string, EventHandler>;
|
|
20
|
-
update: (attrs?: DenormAttrs<E>, ...children: DenormChildren[]) => Node;
|
|
21
|
-
};
|
|
22
|
-
|
|
23
13
|
export type DomAttrs = {
|
|
24
|
-
class: string;
|
|
25
|
-
style: Partial<
|
|
14
|
+
class: string | string[];
|
|
15
|
+
style: Partial<Properties> | string;
|
|
16
|
+
role: "button" | "list" | "listbox";
|
|
26
17
|
events: Partial<{
|
|
27
|
-
[K in keyof HTMLElementEventMap]: EventHandler;
|
|
18
|
+
[K in keyof HTMLElementEventMap]: EventHandler | null;
|
|
28
19
|
}>;
|
|
29
20
|
};
|
|
30
21
|
|
|
31
|
-
export type Attrs<E extends Element, S = {}> = Partial<
|
|
22
|
+
export type Attrs<E extends Omit<Element, "update">, S = {}> = Partial<
|
|
23
|
+
Omit<E, "style"> & S & DomAttrs
|
|
24
|
+
>;
|
|
32
25
|
|
|
33
|
-
export type DenormAttrs<E extends Element, S = {}> =
|
|
26
|
+
export type DenormAttrs<E extends Omit<Element, "update">, S = {}> =
|
|
34
27
|
| Attrs<E, S>
|
|
35
28
|
| DenormChildren;
|
|
36
29
|
|
|
30
|
+
declare global {
|
|
31
|
+
interface Element {
|
|
32
|
+
[Events]: Map<string, EventHandler>;
|
|
33
|
+
update(attrs?: DenormAttrs<Element>, ...children: DenormChildren[]): this;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export type DOMUpdates<E extends Element = Element> =
|
|
38
|
+
| [DenormAttrs<E>, ...DenormChildren[]]
|
|
39
|
+
| DenormChildren[];
|
|
40
|
+
|
|
37
41
|
function isAttrs<E extends Element>(
|
|
38
42
|
attrs: DenormAttrs<E> | undefined
|
|
39
43
|
): attrs is Attrs<E> {
|
|
40
44
|
if (!attrs) {
|
|
41
45
|
return false;
|
|
42
46
|
}
|
|
43
|
-
if (typeof attrs === "
|
|
44
|
-
return
|
|
47
|
+
if (typeof attrs === "object") {
|
|
48
|
+
return !(attrs as Node).nodeType;
|
|
45
49
|
}
|
|
46
|
-
return
|
|
50
|
+
return false;
|
|
47
51
|
}
|
|
48
52
|
|
|
49
53
|
export function normalizeArguments<E extends Element>(
|
|
@@ -63,29 +67,31 @@ export function normalizeArguments<E extends Element>(
|
|
|
63
67
|
return [attributes, children.flat()];
|
|
64
68
|
}
|
|
65
69
|
|
|
66
|
-
export function up<E extends
|
|
67
|
-
element: E,
|
|
70
|
+
export function up<E extends Element>(
|
|
71
|
+
element: Omit<E, "update">,
|
|
68
72
|
attrs?: DenormAttrs<E>,
|
|
69
73
|
...children: DenormChildren[]
|
|
70
|
-
):
|
|
71
|
-
return update(element, ...normalizeArguments(attrs, children));
|
|
74
|
+
): E {
|
|
75
|
+
return update(element, ...normalizeArguments(attrs, children)) as E;
|
|
72
76
|
}
|
|
73
77
|
|
|
74
|
-
export function update
|
|
75
|
-
element:
|
|
76
|
-
attrs: Attrs<
|
|
78
|
+
export function update(
|
|
79
|
+
element: Omit<Element, "update">,
|
|
80
|
+
attrs: Attrs<Element>,
|
|
77
81
|
children: DenormChildren[]
|
|
78
|
-
):
|
|
82
|
+
): Element {
|
|
79
83
|
// Track events, to remove later
|
|
80
84
|
const $events = (element[Events] ??= new Map<string, EventHandler>());
|
|
81
85
|
const { style = {}, events = {}, ...rest } = attrs;
|
|
82
86
|
|
|
83
87
|
Object.entries(events as NonNullable<typeof attrs.events>).forEach(
|
|
84
88
|
([k, v]) => {
|
|
85
|
-
if (v === null
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
+
if (v === null) {
|
|
90
|
+
if ($events.has(k)) {
|
|
91
|
+
const listener = $events.get(k)!;
|
|
92
|
+
element.removeEventListener(k, listener);
|
|
93
|
+
}
|
|
94
|
+
} else if (v !== undefined) {
|
|
89
95
|
element.addEventListener(k as keyof ElementEventMap, v);
|
|
90
96
|
$events.set(k, v);
|
|
91
97
|
}
|
|
@@ -107,47 +113,54 @@ export function update<E extends DOMElement>(
|
|
|
107
113
|
}
|
|
108
114
|
|
|
109
115
|
Object.entries(rest).forEach(([k, v]) => {
|
|
110
|
-
if (k === "class"
|
|
111
|
-
v.
|
|
116
|
+
if (k === "class") {
|
|
117
|
+
v = Array.isArray(v)
|
|
118
|
+
? v
|
|
119
|
+
: (typeof v === "string" ? v : `${v}`).split(/\s+/m);
|
|
120
|
+
(v as string[])
|
|
112
121
|
.filter((s) => s !== "")
|
|
113
|
-
.forEach((c) =>
|
|
122
|
+
.forEach((c) => {
|
|
123
|
+
if (c.startsWith("!")) {
|
|
124
|
+
element.classList.remove(c.substring(1));
|
|
125
|
+
} else {
|
|
126
|
+
element.classList.add(c);
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
return;
|
|
114
130
|
}
|
|
115
131
|
|
|
116
|
-
|
|
117
|
-
|
|
132
|
+
const useNamespace =
|
|
133
|
+
element.namespaceURI &&
|
|
118
134
|
element.namespaceURI != "http://www.w3.org/1999/xhtml";
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
default:
|
|
129
|
-
if (v === "") {
|
|
130
|
-
element.removeAttributeNS(element.namespaceURI, k);
|
|
131
|
-
} else {
|
|
132
|
-
element.setAttributeNS(element.namespaceURI, k, v);
|
|
133
|
-
}
|
|
135
|
+
const remove = !v;
|
|
136
|
+
|
|
137
|
+
if (useNamespace) {
|
|
138
|
+
if (remove) {
|
|
139
|
+
element.removeAttributeNS(element.namespaceURI, k);
|
|
140
|
+
} else if (v === true) {
|
|
141
|
+
element.setAttributeNS(element.namespaceURI, k, k);
|
|
142
|
+
} else {
|
|
143
|
+
element.setAttributeNS(element.namespaceURI, k, v);
|
|
134
144
|
}
|
|
135
145
|
} else {
|
|
136
|
-
|
|
137
|
-
|
|
146
|
+
if (remove) {
|
|
147
|
+
element.removeAttribute(k);
|
|
148
|
+
} else if (v === true) {
|
|
149
|
+
element.setAttribute(k, k);
|
|
150
|
+
} else {
|
|
151
|
+
element.setAttribute(k, v);
|
|
152
|
+
}
|
|
138
153
|
}
|
|
139
154
|
});
|
|
140
155
|
|
|
141
156
|
if (children?.length > 0) {
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
element.replaceChildren(...(children as (string | Node)[]));
|
|
146
|
-
}
|
|
157
|
+
element.replaceChildren(
|
|
158
|
+
...(children[0] === CLEAR ? [] : (children as (string | Node)[]))
|
|
159
|
+
);
|
|
147
160
|
}
|
|
148
161
|
|
|
149
|
-
element.update ??= (attrs, ...children) =>
|
|
162
|
+
(element as Element).update ??= (attrs, ...children) =>
|
|
150
163
|
update(element, ...normalizeArguments(attrs, children));
|
|
151
164
|
|
|
152
|
-
return element as
|
|
165
|
+
return element as Element;
|
|
153
166
|
}
|
package/src/dom/fc.test.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { describe, it, expect } from "../scope/index.js"
|
|
2
|
-
import { FC } from "./fc.js"
|
|
3
|
-
import { button, div, form, input, label, small } from "./html.js"
|
|
1
|
+
import { describe, it, expect } from "../scope/index.js"
|
|
2
|
+
import { FC } from "./fc.js"
|
|
3
|
+
import { button, div, form, input, label, small } from "./html.js"
|
|
4
4
|
|
|
5
5
|
describe("FC", () => {
|
|
6
6
|
it("creates FCs", () => {
|
package/src/dom/fc.ts
CHANGED
|
@@ -3,25 +3,24 @@ import {
|
|
|
3
3
|
DenormChildren,
|
|
4
4
|
DomAttrs,
|
|
5
5
|
normalizeArguments,
|
|
6
|
-
Updatable,
|
|
7
6
|
update,
|
|
8
|
-
} from "./dom.js"
|
|
7
|
+
} from "./dom.js"
|
|
9
8
|
|
|
10
9
|
export type Attrs<S> = S & Partial<DomAttrs>;
|
|
11
10
|
|
|
12
11
|
export const State = Symbol();
|
|
13
12
|
export interface FCComponent<P extends object, S extends object>
|
|
14
|
-
extends
|
|
15
|
-
[State]
|
|
13
|
+
extends Element {
|
|
14
|
+
[State]?: Partial<S>;
|
|
16
15
|
update(
|
|
17
|
-
attrs?: Partial<Attrs<P
|
|
16
|
+
attrs?: Partial<Attrs<P> & DomAttrs> | DenormChildren,
|
|
18
17
|
...children: DenormChildren[]
|
|
19
|
-
):
|
|
18
|
+
): this;
|
|
20
19
|
}
|
|
21
20
|
export interface RenderFn<P extends object, S extends object> {
|
|
22
21
|
(el: FCComponent<P, S>, attrs: Attrs<P>, children: DenormChildren[]):
|
|
23
|
-
|
|
|
24
|
-
|
|
|
22
|
+
| Element
|
|
23
|
+
| Element[];
|
|
25
24
|
}
|
|
26
25
|
|
|
27
26
|
export interface FCComponentCtor<P extends object, S extends object> {
|
|
@@ -35,7 +34,7 @@ export function FC<P extends object, S extends object = {}>(
|
|
|
35
34
|
name: string,
|
|
36
35
|
component: RenderFn<P, S>
|
|
37
36
|
): FCComponentCtor<P, S> {
|
|
38
|
-
class FCImpl extends HTMLElement {
|
|
37
|
+
class FCImpl extends HTMLElement implements FCComponent<P, S> {
|
|
39
38
|
constructor() {
|
|
40
39
|
super();
|
|
41
40
|
}
|
|
@@ -55,12 +54,14 @@ export function FC<P extends object, S extends object = {}>(
|
|
|
55
54
|
this.#children = children;
|
|
56
55
|
}
|
|
57
56
|
this.#attrs = { ...this.#attrs, ...(attrs as Attrs<P>) };
|
|
57
|
+
|
|
58
58
|
// Apply updates from the attrs to the dom node itself
|
|
59
|
-
// @ts-ignore
|
|
60
59
|
update(this, this.#attrs, []);
|
|
60
|
+
|
|
61
61
|
// Re-run the component function using new element, attrs, and children.
|
|
62
62
|
const replace = [component(this, this.#attrs, this.#children)];
|
|
63
63
|
this.replaceChildren(...replace.flat());
|
|
64
|
+
return this;
|
|
64
65
|
}
|
|
65
66
|
}
|
|
66
67
|
|
package/src/dom/form/form.app.ts
CHANGED
package/src/dom/form/form.ts
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
|
-
import { Attrs, DenormChildren } from "../dom.js"
|
|
2
|
-
import { form, input, label, option, select } from "../html.js"
|
|
1
|
+
import { Attrs, DenormChildren } from "../dom.js"
|
|
2
|
+
import { form, input, label, option, select } from "../html.js"
|
|
3
3
|
import {
|
|
4
4
|
FormAttributes,
|
|
5
5
|
InputAttributes,
|
|
6
|
+
LabelAttributes,
|
|
6
7
|
OptionAttributes,
|
|
7
8
|
SelectAttributes,
|
|
8
|
-
} from "../types/html
|
|
9
|
+
} from "../types/html"
|
|
9
10
|
|
|
10
11
|
export const Form = (attrs: FormAttributes, ...children: DenormChildren[]) => {
|
|
11
12
|
if (attrs.events?.submit) {
|
|
@@ -19,8 +20,18 @@ export const Form = (attrs: FormAttributes, ...children: DenormChildren[]) => {
|
|
|
19
20
|
};
|
|
20
21
|
export const Input = (attrs: InputAttributes, ...children: DenormChildren[]) =>
|
|
21
22
|
label(input(attrs as Attrs<HTMLInputElement>), ...children);
|
|
22
|
-
|
|
23
|
-
|
|
23
|
+
|
|
24
|
+
export const Select = (
|
|
25
|
+
attrs: { options: string[] | {}; selected?: string } & SelectAttributes &
|
|
26
|
+
LabelAttributes
|
|
27
|
+
) =>
|
|
28
|
+
label(
|
|
29
|
+
{ style: attrs.style ?? {} },
|
|
30
|
+
select(
|
|
31
|
+
{ events: attrs.events ?? {} },
|
|
32
|
+
...prepareOptions(attrs.options, attrs.selected).map(Option)
|
|
33
|
+
)
|
|
34
|
+
);
|
|
24
35
|
export const Button = () => {};
|
|
25
36
|
|
|
26
37
|
const prepareOptions = (
|
|
@@ -29,19 +40,31 @@ const prepareOptions = (
|
|
|
29
40
|
| Record<
|
|
30
41
|
string,
|
|
31
42
|
string | { label: string; disabled?: boolean; selected?: boolean }
|
|
32
|
-
|
|
43
|
+
>,
|
|
44
|
+
selected?: string
|
|
33
45
|
): Parameters<typeof Option>[0][] =>
|
|
34
46
|
Array.isArray(attrs)
|
|
35
|
-
? attrs.map((value) => ({
|
|
47
|
+
? attrs.map((value) => ({
|
|
48
|
+
value,
|
|
49
|
+
label: value,
|
|
50
|
+
selected: selected == value,
|
|
51
|
+
}))
|
|
36
52
|
: Object.entries(attrs).map(([value, label]) =>
|
|
37
|
-
typeof label === "string"
|
|
53
|
+
typeof label === "string"
|
|
54
|
+
? { value, label, selected: selected === value }
|
|
55
|
+
: { value, ...label }
|
|
38
56
|
);
|
|
39
57
|
export const Option = (attrs: OptionAttributes) =>
|
|
40
58
|
option(attrs as Attrs<HTMLOptionElement>);
|
|
41
59
|
|
|
42
60
|
export const Dropdown = (
|
|
43
|
-
attrs: SelectAttributes | {
|
|
44
|
-
|
|
61
|
+
attrs: SelectAttributes | { selected?: string },
|
|
62
|
+
...options: Parameters<typeof prepareOptions>[0][]
|
|
63
|
+
) =>
|
|
64
|
+
Select({
|
|
65
|
+
...attrs,
|
|
66
|
+
options: typeof options[0] == "string" ? options : options[0],
|
|
67
|
+
});
|
|
45
68
|
export const Radios = () => {};
|
|
46
69
|
export const Checks = () => {};
|
|
47
70
|
export const Switches = () => {};
|
package/src/dom/html.test.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { describe, it } from "../scope/describe.js"
|
|
2
|
-
import { expect } from "../scope/expect.js"
|
|
3
|
-
import { table, tbody, td, th, thead, tr, button } from "./html.js"
|
|
1
|
+
import { describe, it } from "../scope/describe.js"
|
|
2
|
+
import { expect } from "../scope/expect.js"
|
|
3
|
+
import { table, tbody, td, th, thead, tr, button } from "./html.js"
|
|
4
4
|
|
|
5
5
|
describe("html", () => {
|
|
6
6
|
it("creates HTML Elements", () => {
|
|
@@ -16,16 +16,16 @@ describe("html", () => {
|
|
|
16
16
|
});
|
|
17
17
|
|
|
18
18
|
it("attaches event handlers", () => {
|
|
19
|
-
let clicked =
|
|
19
|
+
let clicked = 0;
|
|
20
20
|
const btn = button({
|
|
21
21
|
events: {
|
|
22
22
|
click: () => {
|
|
23
|
-
clicked
|
|
23
|
+
clicked += 1;
|
|
24
24
|
},
|
|
25
25
|
},
|
|
26
26
|
});
|
|
27
27
|
btn.dispatchEvent(new Event("click"));
|
|
28
|
-
expect(clicked).toBe(
|
|
28
|
+
expect(clicked).toBe(1);
|
|
29
29
|
});
|
|
30
30
|
|
|
31
31
|
it("removes event handlers", () => {
|
|
@@ -41,7 +41,7 @@ describe("html", () => {
|
|
|
41
41
|
|
|
42
42
|
expect(clicked).toBe(1);
|
|
43
43
|
|
|
44
|
-
btn.update({ events: { click:
|
|
44
|
+
btn.update({ events: { click: null } });
|
|
45
45
|
btn.dispatchEvent(new Event("click"));
|
|
46
46
|
expect(clicked).toBe(1);
|
|
47
47
|
});
|
|
@@ -49,7 +49,7 @@ describe("html", () => {
|
|
|
49
49
|
it("sets style properties", () => {
|
|
50
50
|
const btn = button({
|
|
51
51
|
style: { flexDirection: "column" },
|
|
52
|
-
})
|
|
52
|
+
});
|
|
53
53
|
|
|
54
54
|
expect(btn.style.flexDirection).toBe("column");
|
|
55
55
|
});
|