termcast 1.3.10 → 1.3.18
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/dist/apis/toast.d.ts +1 -5
- package/dist/apis/toast.d.ts.map +1 -1
- package/dist/apis/toast.js +23 -17
- package/dist/apis/toast.js.map +1 -1
- package/dist/build.d.ts +2 -0
- package/dist/build.d.ts.map +1 -1
- package/dist/build.js +4 -3
- package/dist/build.js.map +1 -1
- package/dist/cli.js +42 -0
- package/dist/cli.js.map +1 -1
- package/dist/colors.d.ts +8 -1
- package/dist/colors.d.ts.map +1 -1
- package/dist/colors.js +12 -0
- package/dist/colors.js.map +1 -1
- package/dist/compile.d.ts +30 -0
- package/dist/compile.d.ts.map +1 -0
- package/dist/compile.js +156 -0
- package/dist/compile.js.map +1 -0
- package/dist/components/actions.d.ts +1 -0
- package/dist/components/actions.d.ts.map +1 -1
- package/dist/components/actions.js +5 -2
- package/dist/components/actions.js.map +1 -1
- package/dist/components/command-arguments.d.ts +9 -0
- package/dist/components/command-arguments.d.ts.map +1 -0
- package/dist/components/command-arguments.js +21 -0
- package/dist/components/command-arguments.js.map +1 -0
- package/dist/components/detail.d.ts +1 -1
- package/dist/components/detail.d.ts.map +1 -1
- package/dist/components/detail.js +17 -39
- package/dist/components/detail.js.map +1 -1
- package/dist/components/dropdown.d.ts +1 -0
- package/dist/components/dropdown.d.ts.map +1 -1
- package/dist/components/dropdown.js +77 -21
- package/dist/components/dropdown.js.map +1 -1
- package/dist/components/extension-preferences.d.ts.map +1 -1
- package/dist/components/extension-preferences.js +19 -29
- package/dist/components/extension-preferences.js.map +1 -1
- package/dist/components/form/checkbox.d.ts.map +1 -1
- package/dist/components/form/checkbox.js +9 -2
- package/dist/components/form/checkbox.js.map +1 -1
- package/dist/components/form/date-picker.d.ts.map +1 -1
- package/dist/components/form/date-picker.js +15 -28
- package/dist/components/form/date-picker.js.map +1 -1
- package/dist/components/form/description.d.ts +2 -0
- package/dist/components/form/description.d.ts.map +1 -1
- package/dist/components/form/description.js +20 -2
- package/dist/components/form/description.js.map +1 -1
- package/dist/components/form/dropdown.d.ts.map +1 -1
- package/dist/components/form/dropdown.js +13 -28
- package/dist/components/form/dropdown.js.map +1 -1
- package/dist/components/form/file-autocomplete.d.ts +7 -4
- package/dist/components/form/file-autocomplete.d.ts.map +1 -1
- package/dist/components/form/file-autocomplete.js +54 -46
- package/dist/components/form/file-autocomplete.js.map +1 -1
- package/dist/components/form/file-picker.d.ts +5 -0
- package/dist/components/form/file-picker.d.ts.map +1 -1
- package/dist/components/form/file-picker.js +46 -49
- package/dist/components/form/file-picker.js.map +1 -1
- package/dist/components/form/form-ref.d.ts +43 -0
- package/dist/components/form/form-ref.d.ts.map +1 -0
- package/dist/components/form/form-ref.js +53 -0
- package/dist/components/form/form-ref.js.map +1 -0
- package/dist/components/form/index.d.ts +16 -0
- package/dist/components/form/index.d.ts.map +1 -1
- package/dist/components/form/index.js +86 -23
- package/dist/components/form/index.js.map +1 -1
- package/dist/components/form/password-field.d.ts.map +1 -1
- package/dist/components/form/password-field.js +32 -16
- package/dist/components/form/password-field.js.map +1 -1
- package/dist/components/form/text-area.d.ts.map +1 -1
- package/dist/components/form/text-area.js +32 -15
- package/dist/components/form/text-area.js.map +1 -1
- package/dist/components/form/text-field.d.ts.map +1 -1
- package/dist/components/form/text-field.js +37 -17
- package/dist/components/form/text-field.js.map +1 -1
- package/dist/components/form/use-form-navigation.d.ts +4 -0
- package/dist/components/form/use-form-navigation.d.ts.map +1 -1
- package/dist/components/form/use-form-navigation.js +35 -18
- package/dist/components/form/use-form-navigation.js.map +1 -1
- package/dist/components/form/with-left-border.d.ts.map +1 -1
- package/dist/components/form/with-left-border.js +2 -2
- package/dist/components/form/with-left-border.js.map +1 -1
- package/dist/components/icon.d.ts +3 -1
- package/dist/components/icon.d.ts.map +1 -1
- package/dist/components/icon.js +494 -469
- package/dist/components/icon.js.map +1 -1
- package/dist/components/list.d.ts +11 -7
- package/dist/components/list.d.ts.map +1 -1
- package/dist/components/list.js +170 -38
- package/dist/components/list.js.map +1 -1
- package/dist/components/loading-bar.js +1 -1
- package/dist/components/loading-bar.js.map +1 -1
- package/dist/descendants.d.ts.map +1 -1
- package/dist/descendants.js +8 -5
- package/dist/descendants.js.map +1 -1
- package/dist/examples/action-show-in-finder.js +1 -1
- package/dist/examples/action-show-in-finder.js.map +1 -1
- package/dist/examples/environment-test.js +1 -1
- package/dist/examples/environment-test.js.map +1 -1
- package/dist/examples/error-boundary.js +1 -1
- package/dist/examples/error-boundary.js.map +1 -1
- package/dist/examples/form-basic.d.ts.map +1 -1
- package/dist/examples/form-basic.js +2 -2
- package/dist/examples/form-basic.js.map +1 -1
- package/dist/examples/form-dropdown.js +1 -1
- package/dist/examples/form-dropdown.js.map +1 -1
- package/dist/examples/form-scroll.d.ts +2 -0
- package/dist/examples/form-scroll.d.ts.map +1 -0
- package/dist/examples/form-scroll.js +8 -0
- package/dist/examples/form-scroll.js.map +1 -0
- package/dist/examples/form-tagpicker.js +1 -1
- package/dist/examples/form-tagpicker.js.map +1 -1
- package/dist/examples/internal/descendants-filtering.js +8 -3
- package/dist/examples/internal/descendants-filtering.js.map +1 -1
- package/dist/examples/internal/descendants.js +10 -3
- package/dist/examples/internal/descendants.js.map +1 -1
- package/dist/examples/internal/rhf-custom-ref.d.ts +2 -0
- package/dist/examples/internal/rhf-custom-ref.d.ts.map +1 -0
- package/dist/examples/internal/rhf-custom-ref.js +67 -0
- package/dist/examples/internal/rhf-custom-ref.js.map +1 -0
- package/dist/examples/internal/scrollbox-demo.js +3 -7
- package/dist/examples/internal/scrollbox-demo.js.map +1 -1
- package/dist/examples/internal/scrollbox-with-descendants.d.ts +2 -0
- package/dist/examples/internal/scrollbox-with-descendants.d.ts.map +1 -0
- package/dist/examples/internal/scrollbox-with-descendants.js +63 -0
- package/dist/examples/internal/scrollbox-with-descendants.js.map +1 -0
- package/dist/examples/internal/simple-dialog.js +1 -1
- package/dist/examples/internal/simple-dialog.js.map +1 -1
- package/dist/examples/internal/simple-scrollbox.js +2 -3
- package/dist/examples/internal/simple-scrollbox.js.map +1 -1
- package/dist/examples/internal/text-stacking.js +4 -2
- package/dist/examples/internal/text-stacking.js.map +1 -1
- package/dist/examples/list-dropdown-default.js +1 -1
- package/dist/examples/list-dropdown-default.js.map +1 -1
- package/dist/examples/list-fetch-data.js +1 -1
- package/dist/examples/list-fetch-data.js.map +1 -1
- package/dist/examples/list-scrollbox.d.ts +2 -0
- package/dist/examples/list-scrollbox.d.ts.map +1 -0
- package/dist/examples/list-scrollbox.js +29 -0
- package/dist/examples/list-scrollbox.js.map +1 -0
- package/dist/examples/list-with-detail.js +1 -1
- package/dist/examples/list-with-detail.js.map +1 -1
- package/dist/examples/list-with-dropdown.js +1 -1
- package/dist/examples/list-with-dropdown.js.map +1 -1
- package/dist/examples/list-with-sections.js +3 -3
- package/dist/examples/list-with-sections.js.map +1 -1
- package/dist/examples/miscellaneous.js +1 -1
- package/dist/examples/miscellaneous.js.map +1 -1
- package/dist/examples/nested-navigation.js +4 -2
- package/dist/examples/nested-navigation.js.map +1 -1
- package/dist/examples/preferences-test.js +1 -1
- package/dist/examples/preferences-test.js.map +1 -1
- package/dist/examples/simple-dropdown.js +1 -1
- package/dist/examples/simple-dropdown.js.map +1 -1
- package/dist/examples/simple-file-picker.js +1 -1
- package/dist/examples/simple-file-picker.js.map +1 -1
- package/dist/examples/simple-grid.js +1 -1
- package/dist/examples/simple-grid.js.map +1 -1
- package/dist/examples/simple-hud.js +1 -1
- package/dist/examples/simple-hud.js.map +1 -1
- package/dist/examples/simple-list-search.js +1 -1
- package/dist/examples/simple-list-search.js.map +1 -1
- package/dist/examples/simple-list.js +1 -1
- package/dist/examples/simple-list.js.map +1 -1
- package/dist/examples/simple-navigation.js +4 -2
- package/dist/examples/simple-navigation.js.map +1 -1
- package/dist/examples/store.js +1 -1
- package/dist/examples/store.js.map +1 -1
- package/dist/examples/submodule-diff.d.ts +2 -0
- package/dist/examples/submodule-diff.d.ts.map +1 -0
- package/dist/examples/submodule-diff.js +99 -0
- package/dist/examples/submodule-diff.js.map +1 -0
- package/dist/examples/tanstack-demo.js +1 -1
- package/dist/examples/tanstack-demo.js.map +1 -1
- package/dist/examples/use-promise-demo.js +1 -1
- package/dist/examples/use-promise-demo.js.map +1 -1
- package/dist/extensions/dev.d.ts +8 -0
- package/dist/extensions/dev.d.ts.map +1 -1
- package/dist/extensions/dev.js +53 -28
- package/dist/extensions/dev.js.map +1 -1
- package/dist/extensions/home.d.ts.map +1 -1
- package/dist/extensions/home.js +16 -91
- package/dist/extensions/home.js.map +1 -1
- package/dist/globals.js +1 -1
- package/dist/globals.js.map +1 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/dist/internal/date-picker-widget.d.ts.map +1 -1
- package/dist/internal/date-picker-widget.js +56 -48
- package/dist/internal/date-picker-widget.js.map +1 -1
- package/dist/internal/dialog.d.ts.map +1 -1
- package/dist/internal/dialog.js +7 -7
- package/dist/internal/dialog.js.map +1 -1
- package/dist/internal/scrollbox.d.ts +2 -1
- package/dist/internal/scrollbox.d.ts.map +1 -1
- package/dist/internal/scrollbox.js +13 -7
- package/dist/internal/scrollbox.js.map +1 -1
- package/dist/release.d.ts +11 -0
- package/dist/release.d.ts.map +1 -0
- package/dist/release.js +113 -0
- package/dist/release.js.map +1 -0
- package/dist/state.d.ts +1 -0
- package/dist/state.d.ts.map +1 -1
- package/dist/state.js +1 -0
- package/dist/state.js.map +1 -1
- package/dist/theme.d.ts +11 -8
- package/dist/theme.d.ts.map +1 -1
- package/dist/theme.js +31 -8
- package/dist/theme.js.map +1 -1
- package/dist/utils/run-command.d.ts +22 -0
- package/dist/utils/run-command.d.ts.map +1 -0
- package/dist/utils/run-command.js +127 -0
- package/dist/utils/run-command.js.map +1 -0
- package/dist/utils.d.ts +1 -1
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +5 -3
- package/dist/utils.js.map +1 -1
- package/package.json +10 -7
- package/src/apis/toast.tsx +38 -17
- package/src/build.tsx +5 -3
- package/src/cli.tsx +46 -0
- package/src/colors.tsx +22 -1
- package/src/compile.tsx +219 -0
- package/src/components/actions.tsx +7 -1
- package/src/components/command-arguments.tsx +81 -0
- package/src/components/detail.tsx +26 -58
- package/src/components/dropdown.tsx +108 -23
- package/src/components/extension-preferences.tsx +55 -35
- package/src/components/form/checkbox.tsx +13 -5
- package/src/components/form/date-picker.tsx +24 -29
- package/src/components/form/description.tsx +35 -7
- package/src/components/form/dropdown.tsx +16 -30
- package/src/components/form/file-autocomplete.tsx +87 -77
- package/src/components/form/file-picker.tsx +69 -57
- package/src/components/form/form-ref.tsx +68 -0
- package/src/components/form/index.tsx +152 -41
- package/src/components/form/password-field.tsx +35 -22
- package/src/components/form/text-area.tsx +78 -58
- package/src/components/form/text-field.tsx +82 -61
- package/src/components/form/use-form-navigation.tsx +43 -23
- package/src/components/form/with-left-border.tsx +2 -1
- package/src/components/icon.tsx +497 -469
- package/src/components/list.tsx +279 -112
- package/src/components/loading-bar.tsx +1 -1
- package/src/descendants.tsx +15 -5
- package/src/examples/action-show-in-finder.tsx +1 -1
- package/src/examples/environment-test.tsx +1 -1
- package/src/examples/error-boundary.tsx +1 -1
- package/src/examples/file-autocomplete.vitest.tsx +245 -0
- package/src/examples/form-basic.tsx +12 -12
- package/src/examples/form-basic.vitest.tsx +297 -671
- package/src/examples/form-dropdown.tsx +1 -1
- package/src/examples/form-dropdown.vitest.tsx +353 -221
- package/src/examples/form-scroll.tsx +56 -0
- package/src/examples/form-scroll.vitest.tsx +228 -0
- package/src/examples/form-tagpicker.tsx +1 -1
- package/src/examples/form-tagpicker.vitest.tsx +438 -193
- package/src/examples/internal/descendants-filtering.tsx +13 -5
- package/src/examples/internal/descendants.tsx +17 -5
- package/src/examples/internal/rhf-custom-ref.tsx +152 -0
- package/src/examples/internal/scrollbox-demo.tsx +15 -7
- package/src/examples/internal/scrollbox-with-descendants.tsx +94 -0
- package/src/examples/internal/simple-dialog.tsx +1 -1
- package/src/examples/internal/simple-scrollbox.tsx +8 -5
- package/src/examples/internal/simple-scrollbox.vitest.tsx +47 -37
- package/src/examples/internal/text-stacking.tsx +4 -2
- package/src/examples/list-dropdown-default.tsx +1 -1
- package/src/examples/list-dropdown-default.vitest.tsx +136 -71
- package/src/examples/list-fetch-data.tsx +1 -1
- package/src/examples/list-fetch-data.vitest.tsx +42 -33
- package/src/examples/list-scrollbox.tsx +46 -0
- package/src/examples/list-scrollbox.vitest.tsx +103 -0
- package/src/examples/list-with-detail.tsx +1 -1
- package/src/examples/list-with-detail.vitest.tsx +290 -294
- package/src/examples/list-with-dropdown.tsx +1 -1
- package/src/examples/list-with-dropdown.vitest.tsx +190 -150
- package/src/examples/list-with-sections.tsx +12 -1
- package/src/examples/list-with-sections.vitest.tsx +390 -218
- package/src/examples/miscellaneous.tsx +1 -1
- package/src/examples/nested-navigation.tsx +4 -2
- package/src/examples/preferences-test.tsx +1 -1
- package/src/examples/simple-dropdown.tsx +1 -1
- package/src/examples/simple-file-picker.tsx +1 -1
- package/src/examples/simple-file-picker.vitest.tsx +538 -132
- package/src/examples/simple-grid.tsx +1 -1
- package/src/examples/simple-grid.vitest.tsx +258 -234
- package/src/examples/simple-hud.tsx +1 -1
- package/src/examples/simple-list-search.tsx +1 -1
- package/src/examples/simple-list.tsx +1 -1
- package/src/examples/simple-navigation.tsx +4 -2
- package/src/examples/simple-navigation.vitest.tsx +434 -238
- package/src/examples/store.tsx +1 -1
- package/src/examples/store.vitest.tsx +31 -10
- package/src/examples/submodule-diff.tsx +153 -0
- package/src/examples/tanstack-demo.tsx +1 -1
- package/src/examples/use-promise-demo.tsx +1 -1
- package/src/extensions/dev.tsx +74 -36
- package/src/extensions/dev.vitest.tsx +220 -0
- package/src/extensions/home.tsx +17 -118
- package/src/globals.ts +1 -1
- package/src/index.tsx +7 -1
- package/src/internal/date-picker-widget.tsx +56 -46
- package/src/internal/dialog.tsx +6 -6
- package/src/internal/scrollbox.tsx +15 -5
- package/src/release.tsx +159 -0
- package/src/state.tsx +2 -0
- package/src/store-api/search.test.tsx +4 -13
- package/src/theme.tsx +33 -8
- package/src/utils/run-command.tsx +204 -0
- package/src/utils.tsx +5 -3
- package/dist/ai.d.ts +0 -104
- package/dist/ai.d.ts.map +0 -1
- package/dist/ai.js +0 -135
- package/dist/ai.js.map +0 -1
- package/dist/apis/cache.test.d.ts +0 -2
- package/dist/apis/cache.test.d.ts.map +0 -1
- package/dist/apis/cache.test.js +0 -246
- package/dist/apis/cache.test.js.map +0 -1
- package/dist/apis/localstorage.test.d.ts +0 -2
- package/dist/apis/localstorage.test.d.ts.map +0 -1
- package/dist/apis/localstorage.test.js +0 -131
- package/dist/apis/localstorage.test.js.map +0 -1
- package/dist/apis/toast.test.d.ts +0 -2
- package/dist/apis/toast.test.d.ts.map +0 -1
- package/dist/apis/toast.test.js +0 -67
- package/dist/apis/toast.test.js.map +0 -1
- package/dist/build.test.d.ts +0 -2
- package/dist/build.test.d.ts.map +0 -1
- package/dist/build.test.js +0 -73
- package/dist/build.test.js.map +0 -1
- package/dist/cache.d.ts +0 -32
- package/dist/cache.d.ts.map +0 -1
- package/dist/cache.js +0 -205
- package/dist/cache.js.map +0 -1
- package/dist/cache.test.d.ts +0 -2
- package/dist/cache.test.d.ts.map +0 -1
- package/dist/cache.test.js +0 -246
- package/dist/cache.test.js.map +0 -1
- package/dist/clipboard.d.ts +0 -36
- package/dist/clipboard.d.ts.map +0 -1
- package/dist/clipboard.js +0 -154
- package/dist/clipboard.js.map +0 -1
- package/dist/components/form/form-type-only.d.ts +0 -174
- package/dist/components/form/form-type-only.d.ts.map +0 -1
- package/dist/components/form/form-type-only.js +0 -2
- package/dist/components/form/form-type-only.js.map +0 -1
- package/dist/components/form/use-form-handling.d.ts +0 -4
- package/dist/components/form/use-form-handling.d.ts.map +0 -1
- package/dist/components/form/use-form-handling.js +0 -37
- package/dist/components/form/use-form-handling.js.map +0 -1
- package/dist/dev-ui.d.ts +0 -7
- package/dist/dev-ui.d.ts.map +0 -1
- package/dist/dev-ui.js +0 -118
- package/dist/dev-ui.js.map +0 -1
- package/dist/environment.d.ts +0 -63
- package/dist/environment.d.ts.map +0 -1
- package/dist/environment.js +0 -189
- package/dist/environment.js.map +0 -1
- package/dist/examples/datepicker.d.ts +0 -2
- package/dist/examples/datepicker.d.ts.map +0 -1
- package/dist/examples/datepicker.js +0 -344
- package/dist/examples/datepicker.js.map +0 -1
- package/dist/examples/form-basic-arrow-keys.vitest.d.ts +0 -2
- package/dist/examples/form-basic-arrow-keys.vitest.d.ts.map +0 -1
- package/dist/examples/form-basic-arrow-keys.vitest.js +0 -46
- package/dist/examples/form-basic-arrow-keys.vitest.js.map +0 -1
- package/dist/examples/form-basic.vitest.d.ts +0 -2
- package/dist/examples/form-basic.vitest.d.ts.map +0 -1
- package/dist/examples/form-basic.vitest.js +0 -995
- package/dist/examples/form-basic.vitest.js.map +0 -1
- package/dist/examples/form-dropdown-with-sections.d.ts +0 -2
- package/dist/examples/form-dropdown-with-sections.d.ts.map +0 -1
- package/dist/examples/form-dropdown-with-sections.js +0 -13
- package/dist/examples/form-dropdown-with-sections.js.map +0 -1
- package/dist/examples/form-dropdown-with-sections.vitest.d.ts +0 -2
- package/dist/examples/form-dropdown-with-sections.vitest.d.ts.map +0 -1
- package/dist/examples/form-dropdown-with-sections.vitest.js +0 -75
- package/dist/examples/form-dropdown-with-sections.vitest.js.map +0 -1
- package/dist/examples/form-dropdown.vitest.d.ts +0 -2
- package/dist/examples/form-dropdown.vitest.d.ts.map +0 -1
- package/dist/examples/form-dropdown.vitest.js +0 -722
- package/dist/examples/form-dropdown.vitest.js.map +0 -1
- package/dist/examples/form-multiselect-dropdown.d.ts +0 -2
- package/dist/examples/form-multiselect-dropdown.d.ts.map +0 -1
- package/dist/examples/form-multiselect-dropdown.js +0 -13
- package/dist/examples/form-multiselect-dropdown.js.map +0 -1
- package/dist/examples/form-tagpicker.vitest.d.ts +0 -2
- package/dist/examples/form-tagpicker.vitest.d.ts.map +0 -1
- package/dist/examples/form-tagpicker.vitest.js +0 -491
- package/dist/examples/form-tagpicker.vitest.js.map +0 -1
- package/dist/examples/internal/nested-boxes.d.ts +0 -2
- package/dist/examples/internal/nested-boxes.d.ts.map +0 -1
- package/dist/examples/internal/nested-boxes.js +0 -7
- package/dist/examples/internal/nested-boxes.js.map +0 -1
- package/dist/examples/internal/simple-scrollbox.vitest.d.ts +0 -2
- package/dist/examples/internal/simple-scrollbox.vitest.d.ts.map +0 -1
- package/dist/examples/internal/simple-scrollbox.vitest.js +0 -88
- package/dist/examples/internal/simple-scrollbox.vitest.js.map +0 -1
- package/dist/examples/internal/unicode-square-repro.d.ts +0 -2
- package/dist/examples/internal/unicode-square-repro.d.ts.map +0 -1
- package/dist/examples/internal/unicode-square-repro.js +0 -7
- package/dist/examples/internal/unicode-square-repro.js.map +0 -1
- package/dist/examples/list-dropdown-default.vitest.d.ts +0 -2
- package/dist/examples/list-dropdown-default.vitest.d.ts.map +0 -1
- package/dist/examples/list-dropdown-default.vitest.js +0 -164
- package/dist/examples/list-dropdown-default.vitest.js.map +0 -1
- package/dist/examples/list-fetch-data.vitest.d.ts +0 -2
- package/dist/examples/list-fetch-data.vitest.d.ts.map +0 -1
- package/dist/examples/list-fetch-data.vitest.js +0 -103
- package/dist/examples/list-fetch-data.vitest.js.map +0 -1
- package/dist/examples/list-filter-navigation.d.ts +0 -2
- package/dist/examples/list-filter-navigation.d.ts.map +0 -1
- package/dist/examples/list-filter-navigation.js +0 -8
- package/dist/examples/list-filter-navigation.js.map +0 -1
- package/dist/examples/list-with-detail.vitest.d.ts +0 -2
- package/dist/examples/list-with-detail.vitest.d.ts.map +0 -1
- package/dist/examples/list-with-detail.vitest.js +0 -438
- package/dist/examples/list-with-detail.vitest.js.map +0 -1
- package/dist/examples/list-with-dropdown.vitest.d.ts +0 -2
- package/dist/examples/list-with-dropdown.vitest.d.ts.map +0 -1
- package/dist/examples/list-with-dropdown.vitest.js +0 -297
- package/dist/examples/list-with-dropdown.vitest.js.map +0 -1
- package/dist/examples/list-with-sections.vitest.d.ts +0 -2
- package/dist/examples/list-with-sections.vitest.d.ts.map +0 -1
- package/dist/examples/list-with-sections.vitest.js +0 -441
- package/dist/examples/list-with-sections.vitest.js.map +0 -1
- package/dist/examples/simple-file-picker.vitest.d.ts +0 -2
- package/dist/examples/simple-file-picker.vitest.d.ts.map +0 -1
- package/dist/examples/simple-file-picker.vitest.js +0 -277
- package/dist/examples/simple-file-picker.vitest.js.map +0 -1
- package/dist/examples/simple-grid.vitest.d.ts +0 -2
- package/dist/examples/simple-grid.vitest.d.ts.map +0 -1
- package/dist/examples/simple-grid.vitest.js +0 -498
- package/dist/examples/simple-grid.vitest.js.map +0 -1
- package/dist/examples/simple-navigation.vitest.d.ts +0 -2
- package/dist/examples/simple-navigation.vitest.d.ts.map +0 -1
- package/dist/examples/simple-navigation.vitest.js +0 -522
- package/dist/examples/simple-navigation.vitest.js.map +0 -1
- package/dist/examples/store.vitest.d.ts +0 -2
- package/dist/examples/store.vitest.d.ts.map +0 -1
- package/dist/examples/store.vitest.js +0 -48
- package/dist/examples/store.vitest.js.map +0 -1
- package/dist/home-command.d.ts +0 -8
- package/dist/home-command.d.ts.map +0 -1
- package/dist/home-command.js +0 -181
- package/dist/home-command.js.map +0 -1
- package/dist/hooks/hooks.test.d.ts +0 -2
- package/dist/hooks/hooks.test.d.ts.map +0 -1
- package/dist/hooks/hooks.test.js +0 -37
- package/dist/hooks/hooks.test.js.map +0 -1
- package/dist/hover-repro.d.ts +0 -2
- package/dist/hover-repro.d.ts.map +0 -1
- package/dist/hover-repro.js +0 -20
- package/dist/hover-repro.js.map +0 -1
- package/dist/localstorage.d.ts +0 -13
- package/dist/localstorage.d.ts.map +0 -1
- package/dist/localstorage.js +0 -190
- package/dist/localstorage.js.map +0 -1
- package/dist/localstorage.test.d.ts +0 -2
- package/dist/localstorage.test.d.ts.map +0 -1
- package/dist/localstorage.test.js +0 -131
- package/dist/localstorage.test.js.map +0 -1
- package/dist/oauth.d.ts +0 -142
- package/dist/oauth.d.ts.map +0 -1
- package/dist/oauth.js +0 -551
- package/dist/oauth.js.map +0 -1
- package/dist/preferences.d.ts +0 -23
- package/dist/preferences.d.ts.map +0 -1
- package/dist/preferences.js +0 -105
- package/dist/preferences.js.map +0 -1
- package/dist/store-api/download.test.d.ts +0 -2
- package/dist/store-api/download.test.d.ts.map +0 -1
- package/dist/store-api/download.test.js +0 -36
- package/dist/store-api/download.test.js.map +0 -1
- package/dist/store-api/extension.test.d.ts +0 -2
- package/dist/store-api/extension.test.d.ts.map +0 -1
- package/dist/store-api/extension.test.js +0 -22
- package/dist/store-api/extension.test.js.map +0 -1
- package/dist/store-api/search.test.d.ts +0 -2
- package/dist/store-api/search.test.d.ts.map +0 -1
- package/dist/store-api/search.test.js +0 -45
- package/dist/store-api/search.test.js.map +0 -1
- package/dist/store.d.ts +0 -21
- package/dist/store.d.ts.map +0 -1
- package/dist/store.js +0 -84
- package/dist/store.js.map +0 -1
- package/dist/toast.d.ts +0 -44
- package/dist/toast.d.ts.map +0 -1
- package/dist/toast.js +0 -221
- package/dist/toast.js.map +0 -1
- package/dist/utils.test.d.ts +0 -2
- package/dist/utils.test.d.ts.map +0 -1
- package/dist/utils.test.js +0 -152
- package/dist/utils.test.js.map +0 -1
- package/dist/window.d.ts +0 -12
- package/dist/window.d.ts.map +0 -1
- package/dist/window.js +0 -48
- package/dist/window.js.map +0 -1
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import React from 'react'
|
|
2
|
-
import {
|
|
3
|
-
import { useFormContext
|
|
4
|
-
import { useFocusContext } from './index'
|
|
1
|
+
import React, { useRef, useCallback } from 'react'
|
|
2
|
+
import { BoxRenderable, TextareaRenderable } from '@opentui/core'
|
|
3
|
+
import { useFormContext } from 'react-hook-form'
|
|
4
|
+
import { useFocusContext, useFormFieldDescendant } from './index'
|
|
5
5
|
import { FormItemProps, FormItemRef } from './types'
|
|
6
|
-
import { logger } from 'termcast/src/logger'
|
|
7
6
|
import { Theme } from 'termcast/src/theme'
|
|
8
7
|
import { WithLeftBorder } from './with-left-border'
|
|
9
8
|
import { useFormNavigation } from './use-form-navigation'
|
|
9
|
+
import { createTextareaFormRef } from './form-ref'
|
|
10
10
|
|
|
11
11
|
export interface TextAreaProps extends FormItemProps<string> {
|
|
12
12
|
placeholder?: string
|
|
@@ -16,67 +16,87 @@ export interface TextAreaProps extends FormItemProps<string> {
|
|
|
16
16
|
export type TextAreaRef = FormItemRef
|
|
17
17
|
|
|
18
18
|
export const TextArea = (props: TextAreaProps): any => {
|
|
19
|
-
const {
|
|
19
|
+
const { register, formState } = useFormContext()
|
|
20
20
|
const { focusedField, setFocusedField } = useFocusContext()
|
|
21
21
|
const isFocused = focusedField === props.id
|
|
22
22
|
|
|
23
|
+
const elementRef = useRef<BoxRenderable>(null)
|
|
24
|
+
const textareaRef = useRef<TextareaRenderable>(null)
|
|
25
|
+
|
|
26
|
+
// Register as form field descendant for scroll support
|
|
27
|
+
useFormFieldDescendant({
|
|
28
|
+
id: props.id,
|
|
29
|
+
elementRef: elementRef.current,
|
|
30
|
+
})
|
|
31
|
+
|
|
23
32
|
// TODO in textarea arrows should probably go to lines instead of other forms
|
|
24
33
|
useFormNavigation(props.id)
|
|
25
34
|
|
|
35
|
+
// Get register props
|
|
36
|
+
const registration = register(props.id)
|
|
37
|
+
|
|
38
|
+
// Create form ref adapter with onContentChange handler
|
|
39
|
+
const { formRef, onContentChange } = createTextareaFormRef(
|
|
40
|
+
props.id,
|
|
41
|
+
textareaRef,
|
|
42
|
+
registration,
|
|
43
|
+
)
|
|
44
|
+
|
|
45
|
+
// Memoize ref callback - register() returns new object every render,
|
|
46
|
+
// so we must not pass registration.ref directly to avoid re-renders
|
|
47
|
+
const handleRef = useCallback((el: TextareaRenderable | null) => {
|
|
48
|
+
textareaRef.current = el
|
|
49
|
+
registration.ref(formRef)
|
|
50
|
+
}, [])
|
|
51
|
+
|
|
52
|
+
const handleContentChange = useCallback(() => {
|
|
53
|
+
onContentChange()
|
|
54
|
+
props.onChange?.(formRef.value)
|
|
55
|
+
}, [props.onChange])
|
|
56
|
+
|
|
57
|
+
const fieldError = formState.errors[props.id]
|
|
58
|
+
|
|
26
59
|
return (
|
|
27
|
-
<
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
setFocusedField(props.id)
|
|
39
|
-
}}
|
|
40
|
-
>
|
|
41
|
-
{props.title}
|
|
42
|
-
</text>
|
|
43
|
-
</WithLeftBorder>
|
|
60
|
+
<box ref={elementRef} flexDirection="column">
|
|
61
|
+
<WithLeftBorder withDiamond isFocused={isFocused}>
|
|
62
|
+
<text
|
|
63
|
+
fg={isFocused ? Theme.primary : Theme.text}
|
|
64
|
+
onMouseDown={() => {
|
|
65
|
+
setFocusedField(props.id)
|
|
66
|
+
}}
|
|
67
|
+
>
|
|
68
|
+
{props.title}
|
|
69
|
+
</text>
|
|
70
|
+
</WithLeftBorder>
|
|
44
71
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
}}
|
|
61
|
-
/>
|
|
62
|
-
</box>
|
|
63
|
-
</WithLeftBorder>
|
|
72
|
+
<WithLeftBorder isFocused={isFocused}>
|
|
73
|
+
<box flexGrow={1}>
|
|
74
|
+
<textarea
|
|
75
|
+
ref={handleRef}
|
|
76
|
+
initialValue={props.defaultValue || props.value || ''}
|
|
77
|
+
onContentChange={handleContentChange}
|
|
78
|
+
minHeight={4}
|
|
79
|
+
placeholder={props.placeholder}
|
|
80
|
+
focused={isFocused}
|
|
81
|
+
onMouseDown={() => {
|
|
82
|
+
setFocusedField(props.id)
|
|
83
|
+
}}
|
|
84
|
+
/>
|
|
85
|
+
</box>
|
|
86
|
+
</WithLeftBorder>
|
|
64
87
|
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
) as React.ReactElement
|
|
79
|
-
}}
|
|
80
|
-
/>
|
|
88
|
+
{(fieldError || props.error) && (
|
|
89
|
+
<WithLeftBorder isFocused={isFocused}>
|
|
90
|
+
<text fg={Theme.error}>
|
|
91
|
+
{(fieldError?.message as string) || props.error}
|
|
92
|
+
</text>
|
|
93
|
+
</WithLeftBorder>
|
|
94
|
+
)}
|
|
95
|
+
{props.info && (
|
|
96
|
+
<WithLeftBorder isFocused={isFocused}>
|
|
97
|
+
<text fg={Theme.textMuted}>{props.info}</text>
|
|
98
|
+
</WithLeftBorder>
|
|
99
|
+
)}
|
|
100
|
+
</box>
|
|
81
101
|
)
|
|
82
102
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import React from 'react'
|
|
2
|
-
import {
|
|
3
|
-
import { useFormContext
|
|
4
|
-
import { useFocusContext } from './index'
|
|
1
|
+
import React, { useRef, useCallback } from 'react'
|
|
2
|
+
import { BoxRenderable, TextareaRenderable } from '@opentui/core'
|
|
3
|
+
import { useFormContext } from 'react-hook-form'
|
|
4
|
+
import { useFocusContext, useFormFieldDescendant } from './index'
|
|
5
5
|
import { FormItemProps, FormItemRef } from './types'
|
|
6
|
-
import { logger } from 'termcast/src/logger'
|
|
7
6
|
import { Theme } from 'termcast/src/theme'
|
|
8
7
|
import { WithLeftBorder } from './with-left-border'
|
|
9
8
|
import { useFormNavigation } from './use-form-navigation'
|
|
9
|
+
import { createTextareaFormRef } from './form-ref'
|
|
10
10
|
|
|
11
11
|
export interface TextFieldProps extends FormItemProps<string> {
|
|
12
12
|
placeholder?: string
|
|
@@ -15,68 +15,89 @@ export interface TextFieldProps extends FormItemProps<string> {
|
|
|
15
15
|
export type TextFieldRef = FormItemRef
|
|
16
16
|
|
|
17
17
|
export const TextField = (props: TextFieldProps): any => {
|
|
18
|
-
const {
|
|
19
|
-
control,
|
|
20
|
-
formState: { errors },
|
|
21
|
-
} = useFormContext()
|
|
18
|
+
const { register, formState } = useFormContext()
|
|
22
19
|
const { focusedField, setFocusedField } = useFocusContext()
|
|
23
20
|
const isFocused = focusedField === props.id
|
|
24
21
|
|
|
22
|
+
const elementRef = useRef<BoxRenderable>(null)
|
|
23
|
+
const textareaRef = useRef<TextareaRenderable>(null)
|
|
24
|
+
|
|
25
|
+
// Register as form field descendant for scroll support
|
|
26
|
+
useFormFieldDescendant({
|
|
27
|
+
id: props.id,
|
|
28
|
+
elementRef: elementRef.current,
|
|
29
|
+
})
|
|
30
|
+
|
|
25
31
|
// Use form navigation hook
|
|
26
32
|
useFormNavigation(props.id)
|
|
27
33
|
|
|
34
|
+
// Get register props
|
|
35
|
+
const registration = register(props.id, {
|
|
36
|
+
required: props.error ? props.error : false,
|
|
37
|
+
})
|
|
38
|
+
|
|
39
|
+
// Create form ref adapter with onContentChange handler
|
|
40
|
+
const { formRef, onContentChange } = createTextareaFormRef(
|
|
41
|
+
props.id,
|
|
42
|
+
textareaRef,
|
|
43
|
+
registration,
|
|
44
|
+
)
|
|
45
|
+
|
|
46
|
+
// Memoize ref callback - register() returns new object every render,
|
|
47
|
+
// so we must not pass registration.ref directly to avoid re-renders
|
|
48
|
+
const handleRef = useCallback((el: TextareaRenderable | null) => {
|
|
49
|
+
textareaRef.current = el
|
|
50
|
+
registration.ref(formRef)
|
|
51
|
+
}, [])
|
|
52
|
+
|
|
53
|
+
const handleContentChange = useCallback(() => {
|
|
54
|
+
onContentChange()
|
|
55
|
+
props.onChange?.(formRef.value)
|
|
56
|
+
}, [props.onChange])
|
|
57
|
+
|
|
58
|
+
const fieldError = formState.errors[props.id]
|
|
59
|
+
|
|
28
60
|
return (
|
|
29
|
-
<
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
</WithLeftBorder>
|
|
71
|
-
)}
|
|
72
|
-
{props.info && (
|
|
73
|
-
<WithLeftBorder isFocused={isFocused}>
|
|
74
|
-
<text fg={Theme.textMuted}>{props.info}</text>
|
|
75
|
-
</WithLeftBorder>
|
|
76
|
-
)}
|
|
77
|
-
</box>
|
|
78
|
-
) as React.ReactElement
|
|
79
|
-
}}
|
|
80
|
-
/>
|
|
61
|
+
<box ref={elementRef} flexDirection="column">
|
|
62
|
+
<WithLeftBorder withDiamond isFocused={isFocused}>
|
|
63
|
+
<text
|
|
64
|
+
fg={isFocused ? Theme.primary : Theme.text}
|
|
65
|
+
onMouseDown={() => {
|
|
66
|
+
setFocusedField(props.id)
|
|
67
|
+
}}
|
|
68
|
+
>
|
|
69
|
+
{props.title}
|
|
70
|
+
</text>
|
|
71
|
+
</WithLeftBorder>
|
|
72
|
+
<WithLeftBorder isFocused={isFocused}>
|
|
73
|
+
<textarea
|
|
74
|
+
ref={handleRef}
|
|
75
|
+
height={1}
|
|
76
|
+
keyBindings={[
|
|
77
|
+
{ name: 'return', action: 'submit' },
|
|
78
|
+
{ name: 'linefeed', action: 'submit' },
|
|
79
|
+
]}
|
|
80
|
+
initialValue={props.defaultValue || props.value || ''}
|
|
81
|
+
onContentChange={handleContentChange}
|
|
82
|
+
placeholder={props.placeholder}
|
|
83
|
+
focused={isFocused}
|
|
84
|
+
onMouseDown={() => {
|
|
85
|
+
setFocusedField(props.id)
|
|
86
|
+
}}
|
|
87
|
+
/>
|
|
88
|
+
</WithLeftBorder>
|
|
89
|
+
{(fieldError || props.error) && (
|
|
90
|
+
<WithLeftBorder isFocused={isFocused}>
|
|
91
|
+
<text fg={Theme.error}>
|
|
92
|
+
{(fieldError?.message as string) || props.error}
|
|
93
|
+
</text>
|
|
94
|
+
</WithLeftBorder>
|
|
95
|
+
)}
|
|
96
|
+
{props.info && (
|
|
97
|
+
<WithLeftBorder isFocused={isFocused}>
|
|
98
|
+
<text fg={Theme.textMuted}>{props.info}</text>
|
|
99
|
+
</WithLeftBorder>
|
|
100
|
+
)}
|
|
101
|
+
</box>
|
|
81
102
|
)
|
|
82
103
|
}
|
|
@@ -1,8 +1,47 @@
|
|
|
1
1
|
import { useKeyboard } from '@opentui/react'
|
|
2
|
-
import {
|
|
3
|
-
import { useFocusContext } from './index'
|
|
2
|
+
import { useFocusContext, useFormScrollContext } from './index'
|
|
4
3
|
import { useIsInFocus } from '../../internal/focus-context'
|
|
5
4
|
|
|
5
|
+
// Helper hook to get navigation functions without keyboard handling
|
|
6
|
+
export function useFormNavigationHelpers(id: string) {
|
|
7
|
+
const scrollContext = useFormScrollContext()
|
|
8
|
+
const { setFocusedField } = useFocusContext()
|
|
9
|
+
|
|
10
|
+
// Get sorted field IDs from descendants
|
|
11
|
+
const getFieldIds = () => {
|
|
12
|
+
if (!scrollContext) return []
|
|
13
|
+
const descendants = Object.values(scrollContext.descendantsContext.map.current)
|
|
14
|
+
.filter((item) => item.index !== -1 && item.props?.id)
|
|
15
|
+
.sort((a, b) => a.index - b.index)
|
|
16
|
+
return descendants.map((item) => item.props!.id)
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const navigateToPrevious = () => {
|
|
20
|
+
const fieldIds = getFieldIds()
|
|
21
|
+
const currentIndex = fieldIds.indexOf(id)
|
|
22
|
+
if (currentIndex > 0) {
|
|
23
|
+
setFocusedField(fieldIds[currentIndex - 1])
|
|
24
|
+
} else {
|
|
25
|
+
setFocusedField(fieldIds[fieldIds.length - 1])
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const navigateToNext = () => {
|
|
30
|
+
const fieldIds = getFieldIds()
|
|
31
|
+
const currentIndex = fieldIds.indexOf(id)
|
|
32
|
+
if (currentIndex < fieldIds.length - 1) {
|
|
33
|
+
setFocusedField(fieldIds[currentIndex + 1])
|
|
34
|
+
} else {
|
|
35
|
+
setFocusedField(fieldIds[0])
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
return {
|
|
40
|
+
navigateToPrevious,
|
|
41
|
+
navigateToNext,
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
6
45
|
export function useFormNavigation(
|
|
7
46
|
id: string,
|
|
8
47
|
options?: {
|
|
@@ -10,8 +49,7 @@ export function useFormNavigation(
|
|
|
10
49
|
handleTabs?: boolean
|
|
11
50
|
},
|
|
12
51
|
) {
|
|
13
|
-
const {
|
|
14
|
-
const { focusedField, setFocusedField } = useFocusContext()
|
|
52
|
+
const { focusedField } = useFocusContext()
|
|
15
53
|
const isInFocus = useIsInFocus()
|
|
16
54
|
const isFocused = focusedField === id
|
|
17
55
|
|
|
@@ -19,25 +57,7 @@ export function useFormNavigation(
|
|
|
19
57
|
|
|
20
58
|
handleArrows = false
|
|
21
59
|
|
|
22
|
-
const navigateToPrevious = ()
|
|
23
|
-
const fieldNames = Object.keys(getValues())
|
|
24
|
-
const currentIndex = fieldNames.indexOf(id)
|
|
25
|
-
if (currentIndex > 0) {
|
|
26
|
-
setFocusedField(fieldNames[currentIndex - 1])
|
|
27
|
-
} else {
|
|
28
|
-
setFocusedField(fieldNames[fieldNames.length - 1])
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const navigateToNext = () => {
|
|
33
|
-
const fieldNames = Object.keys(getValues())
|
|
34
|
-
const currentIndex = fieldNames.indexOf(id)
|
|
35
|
-
if (currentIndex < fieldNames.length - 1) {
|
|
36
|
-
setFocusedField(fieldNames[currentIndex + 1])
|
|
37
|
-
} else {
|
|
38
|
-
setFocusedField(fieldNames[0])
|
|
39
|
-
}
|
|
40
|
-
}
|
|
60
|
+
const { navigateToPrevious, navigateToNext } = useFormNavigationHelpers(id)
|
|
41
61
|
|
|
42
62
|
useKeyboard((evt) => {
|
|
43
63
|
// Only handle keyboard events when this field is focused and form is in focus
|
|
@@ -30,7 +30,7 @@ export const WithLeftBorder = ({
|
|
|
30
30
|
key={String(isFocused)}
|
|
31
31
|
fg={isFocused ? Theme.accent : Theme.text}
|
|
32
32
|
>
|
|
33
|
-
{isFocused ? chars.focused : chars.unfocused}
|
|
33
|
+
<b>{isFocused ? chars.focused : chars.unfocused}</b>
|
|
34
34
|
</text>
|
|
35
35
|
<box flexGrow={1} paddingLeft={paddingLeft}>
|
|
36
36
|
{children}
|
|
@@ -42,6 +42,7 @@ export const WithLeftBorder = ({
|
|
|
42
42
|
<box
|
|
43
43
|
paddingLeft={paddingLeft}
|
|
44
44
|
border={['left']}
|
|
45
|
+
borderStyle={isFocused ? 'heavy' : 'single'}
|
|
45
46
|
borderColor={isFocused ? Theme.accent : undefined}
|
|
46
47
|
flexDirection='row'
|
|
47
48
|
>
|