termcast 1.3.21 → 1.3.25
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/ai.d.ts +104 -0
- package/dist/ai.d.ts.map +1 -0
- package/dist/ai.js +135 -0
- package/dist/ai.js.map +1 -0
- package/dist/apis/browser-extension.d.ts +18 -0
- package/dist/apis/browser-extension.d.ts.map +1 -0
- package/dist/apis/browser-extension.js +14 -0
- package/dist/apis/browser-extension.js.map +1 -0
- package/dist/apis/localstorage.d.ts.map +1 -1
- package/dist/apis/localstorage.js +4 -7
- package/dist/apis/localstorage.js.map +1 -1
- package/dist/apis/oauth.d.ts.map +1 -1
- package/dist/apis/oauth.js +5 -1
- package/dist/apis/oauth.js.map +1 -1
- package/dist/apis/preferences.d.ts.map +1 -1
- package/dist/apis/preferences.js +38 -19
- package/dist/apis/preferences.js.map +1 -1
- package/dist/apis/toast.d.ts +5 -0
- package/dist/apis/toast.d.ts.map +1 -1
- package/dist/apis/toast.js +7 -43
- package/dist/apis/toast.js.map +1 -1
- package/dist/build.d.ts.map +1 -1
- package/dist/build.js +3 -1
- package/dist/build.js.map +1 -1
- package/dist/cache.d.ts +32 -0
- package/dist/cache.d.ts.map +1 -0
- package/dist/cache.js +205 -0
- package/dist/cache.js.map +1 -0
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +87 -41
- package/dist/cli.js.map +1 -1
- package/dist/clipboard.d.ts +36 -0
- package/dist/clipboard.d.ts.map +1 -0
- package/dist/clipboard.js +154 -0
- package/dist/clipboard.js.map +1 -0
- package/dist/compile.d.ts +2 -1
- package/dist/compile.d.ts.map +1 -1
- package/dist/compile.js +31 -12
- package/dist/compile.js.map +1 -1
- package/dist/components/actions.d.ts.map +1 -1
- package/dist/components/actions.js +56 -30
- package/dist/components/actions.js.map +1 -1
- package/dist/components/detail.d.ts.map +1 -1
- package/dist/components/detail.js +4 -0
- package/dist/components/detail.js.map +1 -1
- package/dist/components/dropdown.d.ts.map +1 -1
- package/dist/components/dropdown.js +38 -15
- package/dist/components/dropdown.js.map +1 -1
- package/dist/components/extension-preferences.d.ts.map +1 -1
- package/dist/components/extension-preferences.js +40 -13
- 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 +5 -3
- 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 +5 -3
- package/dist/components/form/date-picker.js.map +1 -1
- package/dist/components/form/description.d.ts.map +1 -1
- package/dist/components/form/description.js +2 -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 +84 -80
- package/dist/components/form/dropdown.js.map +1 -1
- package/dist/components/form/file-autocomplete.d.ts +3 -6
- package/dist/components/form/file-autocomplete.d.ts.map +1 -1
- package/dist/components/form/file-autocomplete.js +61 -66
- package/dist/components/form/file-autocomplete.js.map +1 -1
- package/dist/components/form/file-picker.d.ts.map +1 -1
- package/dist/components/form/file-picker.js +33 -30
- package/dist/components/form/file-picker.js.map +1 -1
- package/dist/components/form/form-end.d.ts.map +1 -1
- package/dist/components/form/form-end.js +21 -1
- package/dist/components/form/form-end.js.map +1 -1
- package/dist/components/form/form-type-only.d.ts +174 -0
- package/dist/components/form/form-type-only.d.ts.map +1 -0
- package/dist/components/form/form-type-only.js +2 -0
- package/dist/components/form/form-type-only.js.map +1 -0
- package/dist/components/form/index.d.ts +3 -1
- package/dist/components/form/index.d.ts.map +1 -1
- package/dist/components/form/index.js +104 -30
- 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 +5 -3
- 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 +5 -3
- 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 +6 -4
- package/dist/components/form/text-field.js.map +1 -1
- package/dist/components/form/types.d.ts +5 -0
- package/dist/components/form/types.d.ts.map +1 -1
- package/dist/components/form/use-form-handling.d.ts +4 -0
- package/dist/components/form/use-form-handling.d.ts.map +1 -0
- package/dist/components/form/use-form-handling.js +37 -0
- package/dist/components/form/use-form-handling.js.map +1 -0
- package/dist/components/form/with-left-border.d.ts +2 -1
- package/dist/components/form/with-left-border.d.ts.map +1 -1
- package/dist/components/form/with-left-border.js +27 -3
- package/dist/components/form/with-left-border.js.map +1 -1
- package/dist/components/icon.d.ts +1 -0
- package/dist/components/icon.d.ts.map +1 -1
- package/dist/components/icon.js +24 -8
- package/dist/components/icon.js.map +1 -1
- package/dist/components/list.d.ts +2 -2
- package/dist/components/list.d.ts.map +1 -1
- package/dist/components/list.js +155 -70
- package/dist/components/list.js.map +1 -1
- package/dist/components/loading-bar.d.ts.map +1 -1
- package/dist/components/loading-bar.js +2 -2
- package/dist/components/loading-bar.js.map +1 -1
- package/dist/components/loading-text.d.ts +8 -0
- package/dist/components/loading-text.d.ts.map +1 -0
- package/dist/components/loading-text.js +58 -0
- package/dist/components/loading-text.js.map +1 -0
- package/dist/descendants.js +1 -1
- package/dist/descendants.js.map +1 -1
- package/dist/dev-ui.d.ts +7 -0
- package/dist/dev-ui.d.ts.map +1 -0
- package/dist/dev-ui.js +118 -0
- package/dist/dev-ui.js.map +1 -0
- package/dist/environment.d.ts +63 -0
- package/dist/environment.d.ts.map +1 -0
- package/dist/environment.js +189 -0
- package/dist/environment.js.map +1 -0
- package/dist/examples/datepicker.d.ts +2 -0
- package/dist/examples/datepicker.d.ts.map +1 -0
- package/dist/examples/datepicker.js +344 -0
- package/dist/examples/datepicker.js.map +1 -0
- package/dist/examples/file-autocomplete.vitest.d.ts +2 -0
- package/dist/examples/file-autocomplete.vitest.d.ts.map +1 -0
- package/dist/examples/file-autocomplete.vitest.js +223 -0
- package/dist/examples/file-autocomplete.vitest.js.map +1 -0
- package/dist/examples/form-basic-arrow-keys.vitest.d.ts +2 -0
- package/dist/examples/form-basic-arrow-keys.vitest.d.ts.map +1 -0
- package/dist/examples/form-basic-arrow-keys.vitest.js +46 -0
- package/dist/examples/form-basic-arrow-keys.vitest.js.map +1 -0
- package/dist/examples/form-basic.vitest.d.ts +2 -0
- package/dist/examples/form-basic.vitest.d.ts.map +1 -0
- package/dist/examples/form-basic.vitest.js +630 -0
- package/dist/examples/form-basic.vitest.js.map +1 -0
- package/dist/examples/form-dropdown-with-sections.d.ts +2 -0
- package/dist/examples/form-dropdown-with-sections.d.ts.map +1 -0
- package/dist/examples/form-dropdown-with-sections.js +13 -0
- package/dist/examples/form-dropdown-with-sections.js.map +1 -0
- package/dist/examples/form-dropdown-with-sections.vitest.d.ts +2 -0
- package/dist/examples/form-dropdown-with-sections.vitest.d.ts.map +1 -0
- package/dist/examples/form-dropdown-with-sections.vitest.js +75 -0
- package/dist/examples/form-dropdown-with-sections.vitest.js.map +1 -0
- package/dist/examples/form-dropdown.vitest.d.ts +2 -0
- package/dist/examples/form-dropdown.vitest.d.ts.map +1 -0
- package/dist/examples/form-dropdown.vitest.js +854 -0
- package/dist/examples/form-dropdown.vitest.js.map +1 -0
- package/dist/examples/form-multiselect-dropdown.d.ts +2 -0
- package/dist/examples/form-multiselect-dropdown.d.ts.map +1 -0
- package/dist/examples/form-multiselect-dropdown.js +13 -0
- package/dist/examples/form-multiselect-dropdown.js.map +1 -0
- package/dist/examples/form-scroll.d.ts.map +1 -1
- package/dist/examples/form-scroll.js +7 -1
- package/dist/examples/form-scroll.js.map +1 -1
- package/dist/examples/form-scroll.vitest.d.ts +2 -0
- package/dist/examples/form-scroll.vitest.d.ts.map +1 -0
- package/dist/examples/form-scroll.vitest.js +211 -0
- package/dist/examples/form-scroll.vitest.js.map +1 -0
- package/dist/examples/form-tagpicker.vitest.d.ts +2 -0
- package/dist/examples/form-tagpicker.vitest.d.ts.map +1 -0
- package/dist/examples/form-tagpicker.vitest.js +736 -0
- package/dist/examples/form-tagpicker.vitest.js.map +1 -0
- package/dist/examples/internal/descendants-filtering.js +1 -1
- package/dist/examples/internal/descendants-filtering.js.map +1 -1
- package/dist/examples/internal/descendants.js +1 -1
- package/dist/examples/internal/descendants.js.map +1 -1
- package/dist/examples/internal/nested-boxes.d.ts +2 -0
- package/dist/examples/internal/nested-boxes.d.ts.map +1 -0
- package/dist/examples/internal/nested-boxes.js +7 -0
- package/dist/examples/internal/nested-boxes.js.map +1 -0
- package/dist/examples/internal/rhf-custom-ref.js +2 -2
- package/dist/examples/internal/rhf-custom-ref.js.map +1 -1
- package/dist/examples/internal/scrollbox-demo.js +3 -22
- package/dist/examples/internal/scrollbox-demo.js.map +1 -1
- package/dist/examples/internal/scrollbox-descendants.d.ts +2 -0
- package/dist/examples/internal/scrollbox-descendants.d.ts.map +1 -0
- package/dist/examples/internal/scrollbox-descendants.js +83 -0
- package/dist/examples/internal/scrollbox-descendants.js.map +1 -0
- package/dist/examples/internal/scrollbox-with-descendants.js +4 -8
- package/dist/examples/internal/scrollbox-with-descendants.js.map +1 -1
- package/dist/examples/internal/simple-scrollbox.vitest.d.ts +2 -0
- package/dist/examples/internal/simple-scrollbox.vitest.d.ts.map +1 -0
- package/dist/examples/internal/simple-scrollbox.vitest.js +96 -0
- package/dist/examples/internal/simple-scrollbox.vitest.js.map +1 -0
- package/dist/examples/internal/unicode-square-repro.d.ts +2 -0
- package/dist/examples/internal/unicode-square-repro.d.ts.map +1 -0
- package/dist/examples/internal/unicode-square-repro.js +7 -0
- package/dist/examples/internal/unicode-square-repro.js.map +1 -0
- package/dist/examples/list-detail-metadata.d.ts +2 -0
- package/dist/examples/list-detail-metadata.d.ts.map +1 -0
- package/dist/examples/list-detail-metadata.js +8 -0
- package/dist/examples/list-detail-metadata.js.map +1 -0
- package/dist/examples/list-dropdown-default.vitest.d.ts +2 -0
- package/dist/examples/list-dropdown-default.vitest.d.ts.map +1 -0
- package/dist/examples/list-dropdown-default.vitest.js +234 -0
- package/dist/examples/list-dropdown-default.vitest.js.map +1 -0
- package/dist/examples/list-fetch-data.vitest.d.ts +2 -0
- package/dist/examples/list-fetch-data.vitest.d.ts.map +1 -0
- package/dist/examples/list-fetch-data.vitest.js +111 -0
- package/dist/examples/list-fetch-data.vitest.js.map +1 -0
- package/dist/examples/list-filter-navigation.d.ts +2 -0
- package/dist/examples/list-filter-navigation.d.ts.map +1 -0
- package/dist/examples/list-filter-navigation.js +8 -0
- package/dist/examples/list-filter-navigation.js.map +1 -0
- package/dist/examples/list-scrollbox.vitest.d.ts +2 -0
- package/dist/examples/list-scrollbox.vitest.d.ts.map +1 -0
- package/dist/examples/list-scrollbox.vitest.js +93 -0
- package/dist/examples/list-scrollbox.vitest.js.map +1 -0
- package/dist/examples/list-with-detail-long.d.ts +2 -0
- package/dist/examples/list-with-detail-long.d.ts.map +1 -0
- package/dist/examples/list-with-detail-long.js +53 -0
- package/dist/examples/list-with-detail-long.js.map +1 -0
- package/dist/examples/list-with-detail.vitest.d.ts +2 -0
- package/dist/examples/list-with-detail.vitest.d.ts.map +1 -0
- package/dist/examples/list-with-detail.vitest.js +434 -0
- package/dist/examples/list-with-detail.vitest.js.map +1 -0
- package/dist/examples/list-with-dropdown.vitest.d.ts +2 -0
- package/dist/examples/list-with-dropdown.vitest.d.ts.map +1 -0
- package/dist/examples/list-with-dropdown.vitest.js +337 -0
- package/dist/examples/list-with-dropdown.vitest.js.map +1 -0
- package/dist/examples/list-with-sections.js +5 -1
- package/dist/examples/list-with-sections.js.map +1 -1
- package/dist/examples/list-with-sections.vitest.d.ts +2 -0
- package/dist/examples/list-with-sections.vitest.d.ts.map +1 -0
- package/dist/examples/list-with-sections.vitest.js +601 -0
- package/dist/examples/list-with-sections.vitest.js.map +1 -0
- package/dist/examples/scrollbox-vertical-centering.d.ts +6 -0
- package/dist/examples/scrollbox-vertical-centering.d.ts.map +1 -0
- package/dist/examples/scrollbox-vertical-centering.js +17 -0
- package/dist/examples/scrollbox-vertical-centering.js.map +1 -0
- package/dist/examples/simple-file-picker.vitest.d.ts +2 -0
- package/dist/examples/simple-file-picker.vitest.d.ts.map +1 -0
- package/dist/examples/simple-file-picker.vitest.js +678 -0
- package/dist/examples/simple-file-picker.vitest.js.map +1 -0
- package/dist/examples/simple-grid.vitest.d.ts +2 -0
- package/dist/examples/simple-grid.vitest.d.ts.map +1 -0
- package/dist/examples/simple-grid.vitest.js +521 -0
- package/dist/examples/simple-grid.vitest.js.map +1 -0
- package/dist/examples/simple-navigation.js +10 -4
- package/dist/examples/simple-navigation.js.map +1 -1
- package/dist/examples/simple-navigation.vitest.d.ts +2 -0
- package/dist/examples/simple-navigation.vitest.d.ts.map +1 -0
- package/dist/examples/simple-navigation.vitest.js +718 -0
- package/dist/examples/simple-navigation.vitest.js.map +1 -0
- package/dist/examples/store.vitest.d.ts +2 -0
- package/dist/examples/store.vitest.d.ts.map +1 -0
- package/dist/examples/store.vitest.js +69 -0
- package/dist/examples/store.vitest.js.map +1 -0
- package/dist/examples/toast-variations.d.ts +2 -0
- package/dist/examples/toast-variations.d.ts.map +1 -0
- package/dist/examples/toast-variations.js +122 -0
- package/dist/examples/toast-variations.js.map +1 -0
- package/dist/extensions/dev.d.ts +4 -2
- package/dist/extensions/dev.d.ts.map +1 -1
- package/dist/extensions/dev.js +61 -10
- package/dist/extensions/dev.js.map +1 -1
- package/dist/extensions/dev.vitest.d.ts +2 -0
- package/dist/extensions/dev.vitest.d.ts.map +1 -0
- package/dist/extensions/dev.vitest.js +197 -0
- package/dist/extensions/dev.vitest.js.map +1 -0
- package/dist/extensions/home.d.ts.map +1 -1
- package/dist/extensions/home.js +3 -0
- package/dist/extensions/home.js.map +1 -1
- package/dist/home-command.d.ts +8 -0
- package/dist/home-command.d.ts.map +1 -0
- package/dist/home-command.js +181 -0
- package/dist/home-command.js.map +1 -0
- package/dist/hover-repro.d.ts +2 -0
- package/dist/hover-repro.d.ts.map +1 -0
- package/dist/hover-repro.js +20 -0
- package/dist/hover-repro.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/internal/dialog.d.ts +1 -0
- package/dist/internal/dialog.d.ts.map +1 -1
- package/dist/internal/dialog.js +27 -18
- package/dist/internal/dialog.js.map +1 -1
- package/dist/internal/navigation.d.ts +9 -1
- package/dist/internal/navigation.d.ts.map +1 -1
- package/dist/internal/navigation.js +5 -5
- package/dist/internal/navigation.js.map +1 -1
- package/dist/internal/offscreen.d.ts +6 -0
- package/dist/internal/offscreen.d.ts.map +1 -0
- package/dist/internal/offscreen.js +10 -0
- package/dist/internal/offscreen.js.map +1 -0
- package/dist/internal/providers.d.ts.map +1 -1
- package/dist/internal/providers.js +2 -2
- package/dist/internal/providers.js.map +1 -1
- package/dist/internal/scrollbox.d.ts +1 -10
- package/dist/internal/scrollbox.d.ts.map +1 -1
- package/dist/internal/scrollbox.js +2 -1
- package/dist/internal/scrollbox.js.map +1 -1
- package/dist/localstorage.d.ts +13 -0
- package/dist/localstorage.d.ts.map +1 -0
- package/dist/localstorage.js +190 -0
- package/dist/localstorage.js.map +1 -0
- package/dist/oauth.d.ts +142 -0
- package/dist/oauth.d.ts.map +1 -0
- package/dist/oauth.js +551 -0
- package/dist/oauth.js.map +1 -0
- package/dist/preferences.d.ts +23 -0
- package/dist/preferences.d.ts.map +1 -0
- package/dist/preferences.js +105 -0
- package/dist/preferences.js.map +1 -0
- package/dist/release.d.ts +1 -1
- package/dist/release.d.ts.map +1 -1
- package/dist/release.js +29 -33
- package/dist/release.js.map +1 -1
- package/dist/state.d.ts +2 -0
- package/dist/state.d.ts.map +1 -1
- package/dist/state.js +3 -0
- package/dist/state.js.map +1 -1
- package/dist/store.d.ts +21 -0
- package/dist/store.d.ts.map +1 -0
- package/dist/store.js +84 -0
- package/dist/store.js.map +1 -0
- package/dist/swift-loader.d.ts +3 -0
- package/dist/swift-loader.d.ts.map +1 -0
- package/dist/swift-loader.js +193 -0
- package/dist/swift-loader.js.map +1 -0
- package/dist/swift-runtime.d.ts +2 -0
- package/dist/swift-runtime.d.ts.map +1 -0
- package/dist/swift-runtime.js +27 -0
- package/dist/swift-runtime.js.map +1 -0
- package/dist/toast.d.ts +44 -0
- package/dist/toast.d.ts.map +1 -0
- package/dist/toast.js +221 -0
- package/dist/toast.js.map +1 -0
- package/dist/utils/file-system.d.ts +9 -0
- package/dist/utils/file-system.d.ts.map +1 -1
- package/dist/utils/file-system.js +49 -0
- package/dist/utils/file-system.js.map +1 -1
- package/dist/utils/run-command.d.ts +26 -1
- package/dist/utils/run-command.d.ts.map +1 -1
- package/dist/utils/run-command.js +53 -4
- package/dist/utils/run-command.js.map +1 -1
- package/dist/window.d.ts +12 -0
- package/dist/window.d.ts.map +1 -0
- package/dist/window.js +48 -0
- package/dist/window.js.map +1 -0
- package/package.json +12 -12
- package/src/apis/browser-extension.tsx +29 -0
- package/src/apis/localstorage.test.ts +14 -6
- package/src/apis/localstorage.tsx +8 -5
- package/src/apis/oauth.tsx +5 -1
- package/src/apis/preferences.tsx +48 -22
- package/src/apis/toast.tsx +37 -62
- package/src/build.test.tsx +52 -0
- package/src/build.tsx +3 -1
- package/src/cli.tsx +99 -48
- package/src/compile.tsx +32 -11
- package/src/components/actions.tsx +94 -32
- package/src/components/detail.tsx +4 -0
- package/src/components/dropdown.tsx +47 -14
- package/src/components/extension-preferences.tsx +44 -16
- package/src/components/form/checkbox.tsx +12 -6
- package/src/components/form/date-picker.tsx +12 -6
- package/src/components/form/description.tsx +7 -2
- package/src/components/form/dropdown.tsx +131 -119
- package/src/components/form/file-autocomplete.tsx +90 -108
- package/src/components/form/file-picker.tsx +54 -43
- package/src/components/form/form-end.tsx +23 -2
- package/src/components/form/index.tsx +168 -41
- package/src/components/form/password-field.tsx +12 -6
- package/src/components/form/text-area.tsx +13 -6
- package/src/components/form/text-field.tsx +13 -6
- package/src/components/form/types.tsx +6 -0
- package/src/components/form/with-left-border.tsx +41 -8
- package/src/components/icon.tsx +27 -8
- package/src/components/list.tsx +243 -101
- package/src/components/loading-bar.tsx +3 -2
- package/src/components/loading-text.tsx +79 -0
- package/src/descendants.tsx +1 -0
- package/src/examples/file-autocomplete.vitest.tsx +130 -125
- package/src/examples/form-basic.vitest.tsx +376 -176
- package/src/examples/form-dropdown.vitest.tsx +126 -126
- package/src/examples/form-scroll.tsx +2 -0
- package/src/examples/form-scroll.vitest.tsx +58 -58
- package/src/examples/form-tagpicker.vitest.tsx +99 -99
- package/src/examples/internal/descendants-filtering.tsx +1 -0
- package/src/examples/internal/descendants.tsx +1 -0
- package/src/examples/internal/rhf-custom-ref.tsx +2 -0
- package/src/examples/internal/scrollbox-demo.tsx +3 -27
- package/src/examples/internal/scrollbox-with-descendants.tsx +4 -7
- package/src/examples/internal/simple-scrollbox.vitest.tsx +7 -5
- package/src/examples/list-detail-metadata.tsx +49 -0
- package/src/examples/list-detail-metadata.vitest.tsx +88 -0
- package/src/examples/list-dropdown-default.vitest.tsx +51 -51
- package/src/examples/list-fetch-data.vitest.tsx +4 -4
- package/src/examples/list-scrollbox.vitest.tsx +73 -14
- package/src/examples/list-with-detail-long.tsx +70 -0
- package/src/examples/list-with-detail.vitest.tsx +191 -85
- package/src/examples/list-with-dropdown.vitest.tsx +53 -53
- package/src/examples/list-with-sections.tsx +1 -0
- package/src/examples/list-with-sections.vitest.tsx +221 -97
- package/src/examples/list-with-toast.vitest.tsx +16 -16
- package/src/examples/simple-file-picker.vitest.tsx +63 -469
- package/src/examples/simple-grid.vitest.tsx +238 -233
- package/src/examples/simple-navigation.tsx +15 -7
- package/src/examples/simple-navigation.vitest.tsx +130 -219
- package/src/examples/store.vitest.tsx +1 -1
- package/src/examples/swift-extension.vitest.tsx +148 -0
- package/src/examples/synonyms.vitest.tsx +159 -0
- package/src/examples/toast-variations.tsx +150 -0
- package/src/examples/toast-variations.vitest.tsx +370 -0
- package/src/extensions/dev.tsx +74 -7
- package/src/extensions/dev.vitest.tsx +102 -34
- package/src/extensions/home.tsx +6 -0
- package/src/index.tsx +3 -0
- package/src/internal/dialog.tsx +43 -30
- package/src/internal/navigation.tsx +3 -1
- package/src/internal/offscreen.tsx +15 -0
- package/src/internal/providers.tsx +4 -2
- package/src/internal/scrollbox.tsx +4 -8
- package/src/keyboard.test.tsx +69 -0
- package/src/release.tsx +32 -38
- package/src/state.tsx +7 -0
- package/src/swift-loader.tsx +239 -0
- package/src/swift-runtime.tsx +36 -0
- package/src/utils/file-system.ts +61 -0
- package/src/utils/run-command.tsx +82 -6
package/dist/components/icon.js
CHANGED
|
@@ -5,11 +5,11 @@ const ICON_SHAPES = [
|
|
|
5
5
|
'◆', // filled diamond
|
|
6
6
|
'▲', // filled triangle up
|
|
7
7
|
'▼', // filled triangle down
|
|
8
|
-
'★', // filled star
|
|
9
|
-
'♦', // diamond suit
|
|
10
|
-
'♥', // heart suit
|
|
11
|
-
'♠', // spade suit
|
|
12
|
-
'♣', // club suit
|
|
8
|
+
// '★', // filled star
|
|
9
|
+
// '♦', // diamond suit
|
|
10
|
+
// '♥', // heart suit
|
|
11
|
+
// '♠', // spade suit
|
|
12
|
+
// '♣', // club suit
|
|
13
13
|
];
|
|
14
14
|
function hashString(str) {
|
|
15
15
|
let hash = 0;
|
|
@@ -497,14 +497,30 @@ function createIconEnum() {
|
|
|
497
497
|
}
|
|
498
498
|
return icons;
|
|
499
499
|
}
|
|
500
|
-
|
|
500
|
+
function createIconWithUnicode() {
|
|
501
|
+
const icons = {};
|
|
502
|
+
for (const iconId of iconIds) {
|
|
503
|
+
const name = iconId.replace(/-16$/, '');
|
|
504
|
+
const pascalName = pascalCase(name);
|
|
505
|
+
icons[pascalName] = getIconShape(iconId);
|
|
506
|
+
}
|
|
507
|
+
return icons;
|
|
508
|
+
}
|
|
509
|
+
export const IconSource = createIconEnum();
|
|
510
|
+
export const Icon = createIconWithUnicode();
|
|
501
511
|
export function getIconEmoji(icon) {
|
|
512
|
+
// If it's an icon ID (like 'pencil-16'), convert to unicode
|
|
502
513
|
if (iconIds.includes(icon)) {
|
|
503
514
|
return getIconShape(icon);
|
|
504
515
|
}
|
|
505
|
-
return
|
|
516
|
+
// Otherwise assume it's already unicode and return as-is
|
|
517
|
+
return icon;
|
|
506
518
|
}
|
|
507
519
|
export function IconComponent({ source }) {
|
|
508
|
-
return
|
|
520
|
+
// If it's an icon ID, convert to unicode; otherwise return as-is
|
|
521
|
+
if (iconIds.includes(source)) {
|
|
522
|
+
return getIconShape(source);
|
|
523
|
+
}
|
|
524
|
+
return source;
|
|
509
525
|
}
|
|
510
526
|
//# sourceMappingURL=icon.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"icon.js","sourceRoot":"","sources":["../../src/components/icon.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAExC,MAAM,WAAW,GAAG;IAClB,GAAG,EAAE,gBAAgB;IACrB,GAAG,EAAE,gBAAgB;IACrB,GAAG,EAAE,iBAAiB;IACtB,GAAG,EAAE,qBAAqB;IAC1B,GAAG,EAAE,uBAAuB;IAC5B,
|
|
1
|
+
{"version":3,"file":"icon.js","sourceRoot":"","sources":["../../src/components/icon.tsx"],"names":[],"mappings":"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"}
|
|
@@ -67,12 +67,12 @@ export interface ItemProps extends ActionsInterface, CommonProps {
|
|
|
67
67
|
tooltip: string;
|
|
68
68
|
};
|
|
69
69
|
accessories?: ItemAccessory[];
|
|
70
|
-
detail?:
|
|
70
|
+
detail?: ReactNode;
|
|
71
71
|
}
|
|
72
72
|
export interface DetailProps extends CommonProps {
|
|
73
73
|
isLoading?: boolean;
|
|
74
74
|
markdown?: string;
|
|
75
|
-
metadata?:
|
|
75
|
+
metadata?: ReactNode;
|
|
76
76
|
}
|
|
77
77
|
export interface MetadataProps extends CommonProps {
|
|
78
78
|
children?: ReactNode;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../src/components/list.tsx"],"names":[],"mappings":"AAOA,OAAc,EACV,YAAY,EACZ,SAAS,EAQZ,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../src/components/list.tsx"],"names":[],"mappings":"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"}
|
package/dist/components/list.js
CHANGED
|
@@ -4,9 +4,11 @@ import { useKeyboard } from '@opentui/react';
|
|
|
4
4
|
import React, { createContext, useContext, useEffect, useLayoutEffect, useMemo, useRef, useState } from 'react';
|
|
5
5
|
import { LoadingBar } from 'termcast/src/components/loading-bar';
|
|
6
6
|
import { createDescendants } from 'termcast/src/descendants';
|
|
7
|
+
import { useStore } from 'termcast/src/state';
|
|
7
8
|
import { useDialog } from 'termcast/src/internal/dialog';
|
|
8
9
|
import { useIsInFocus } from 'termcast/src/internal/focus-context';
|
|
9
10
|
import { useNavigationPending } from 'termcast/src/internal/navigation';
|
|
11
|
+
import { Offscreen } from 'termcast/src/internal/offscreen';
|
|
10
12
|
import { ScrollBox } from 'termcast/src/internal/scrollbox';
|
|
11
13
|
import { Color, resolveColor } from 'termcast/src/colors';
|
|
12
14
|
import { getIconEmoji } from 'termcast/src/components/icon';
|
|
@@ -43,14 +45,17 @@ function formatRelativeDate(date) {
|
|
|
43
45
|
return `${diffYear}y`;
|
|
44
46
|
}
|
|
45
47
|
function ListFooter() {
|
|
46
|
-
|
|
48
|
+
const firstActionTitle = useStore((s) => s.firstActionTitle);
|
|
49
|
+
const hasToast = useStore((s) => s.toast !== null);
|
|
50
|
+
const content = hasToast ? null : (_jsxs(_Fragment, { children: [firstActionTitle && (_jsxs(_Fragment, { children: [_jsx("text", { fg: Theme.text, attributes: TextAttributes.BOLD, children: "\u21B5" }), _jsxs("text", { fg: Theme.textMuted, children: [" ", firstActionTitle.toLowerCase()] })] })), _jsxs("text", { fg: Theme.text, attributes: TextAttributes.BOLD, children: [' ', "\u2191\u2193"] }), _jsx("text", { fg: Theme.textMuted, children: " navigate" }), _jsxs("text", { fg: Theme.text, attributes: TextAttributes.BOLD, children: [' ', "^k"] }), _jsx("text", { fg: Theme.textMuted, children: " actions" })] }));
|
|
51
|
+
return (_jsx("box", { border: false, height: 1, style: {
|
|
47
52
|
paddingLeft: 1,
|
|
48
53
|
flexShrink: 0,
|
|
49
54
|
paddingRight: 1,
|
|
50
55
|
paddingTop: 1,
|
|
51
56
|
marginTop: 1,
|
|
52
57
|
flexDirection: 'row',
|
|
53
|
-
}, children:
|
|
58
|
+
}, children: content }));
|
|
54
59
|
}
|
|
55
60
|
const ListContext = createContext(undefined);
|
|
56
61
|
// Helper function to determine if an item should be visible based on search
|
|
@@ -80,7 +85,13 @@ function ListDropdownDialog(props) {
|
|
|
80
85
|
// Wrapper function that updates search text
|
|
81
86
|
const setSearchText = (value) => {
|
|
82
87
|
setSearchTextRaw(value);
|
|
83
|
-
|
|
88
|
+
// TODO: use flushSync when available to force descendants to update visibility
|
|
89
|
+
const items = Object.values(descendantsContext.map.current)
|
|
90
|
+
.filter((item) => item.index !== -1 && item.props?.visible !== false)
|
|
91
|
+
.sort((a, b) => a.index - b.index);
|
|
92
|
+
if (items.length > 0 && items[0]) {
|
|
93
|
+
setSelectedIndex(items[0].index);
|
|
94
|
+
}
|
|
84
95
|
};
|
|
85
96
|
const move = (direction) => {
|
|
86
97
|
// Get all visible items
|
|
@@ -133,7 +144,7 @@ function ListDropdownDialog(props) {
|
|
|
133
144
|
return (_jsx(DropdownDescendantsProvider, { value: descendantsContext, children: _jsxs("box", { children: [_jsxs("box", { style: { paddingLeft: 2, paddingRight: 2 }, children: [_jsxs("box", { style: { paddingLeft: 1, paddingRight: 1 }, children: [_jsxs("box", { style: {
|
|
134
145
|
flexDirection: 'row',
|
|
135
146
|
justifyContent: 'space-between',
|
|
136
|
-
}, children: [_jsx("text", { attributes: TextAttributes.BOLD, children: props.tooltip }), _jsx("text", { fg: Theme.textMuted, children: "esc" })] }), _jsx("box", { style: { paddingTop: 1, paddingBottom: 1 }, children: _jsx("textarea", { ref: inputRef, height: 1, keyBindings: [
|
|
147
|
+
}, children: [_jsx("text", { attributes: TextAttributes.BOLD, children: props.tooltip }), _jsx("text", { fg: Theme.textMuted, children: "esc" })] }), _jsx("box", { style: { paddingTop: 1, paddingBottom: 1 }, children: _jsx("textarea", { ref: inputRef, height: 1, wrapMode: 'none', keyBindings: [
|
|
137
148
|
{ name: 'return', action: 'submit' },
|
|
138
149
|
{ name: 'linefeed', action: 'submit' },
|
|
139
150
|
], onContentChange: () => {
|
|
@@ -149,13 +160,18 @@ function ListDropdownDialog(props) {
|
|
|
149
160
|
onChange: (value) => {
|
|
150
161
|
props.onChange?.(value);
|
|
151
162
|
},
|
|
152
|
-
}, children: props.children }) }), props.isLoading && (_jsx("box", { style: { paddingLeft: 1 }, children: _jsx("text", { fg: Theme.textMuted, children: "Loading..." }) }))] }),
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
163
|
+
}, children: props.children }) }), props.isLoading && (_jsx("box", { style: { paddingLeft: 1 }, children: _jsx("text", { fg: Theme.textMuted, children: "Loading..." }) }))] }), _jsx(DropdownFooter, {})] }) }));
|
|
164
|
+
}
|
|
165
|
+
function DropdownFooter() {
|
|
166
|
+
const hasToast = useStore((s) => s.toast !== null);
|
|
167
|
+
const content = hasToast ? null : (_jsxs(_Fragment, { children: [_jsx("text", { fg: Theme.text, attributes: TextAttributes.BOLD, children: "\u21B5" }), _jsx("text", { fg: Theme.textMuted, children: " select" }), _jsxs("text", { fg: Theme.text, attributes: TextAttributes.BOLD, children: [' ', "\u2191\u2193"] }), _jsx("text", { fg: Theme.textMuted, children: " navigate" })] }));
|
|
168
|
+
return (_jsx("box", { border: false, height: 1, style: {
|
|
169
|
+
paddingRight: 2,
|
|
170
|
+
paddingLeft: 3,
|
|
171
|
+
paddingBottom: 1,
|
|
172
|
+
paddingTop: 1,
|
|
173
|
+
flexDirection: 'row',
|
|
174
|
+
}, children: content }));
|
|
159
175
|
}
|
|
160
176
|
// Render a single list item row
|
|
161
177
|
function ListItemRow(props) {
|
|
@@ -214,11 +230,12 @@ function ListItemRow(props) {
|
|
|
214
230
|
}, onMouseDown: props.onMouseDown, children: [_jsxs("box", { style: { flexDirection: 'row', flexGrow: 1, flexShrink: 1, overflow: 'hidden', gap: 1 }, children: [_jsxs("box", { style: { flexDirection: 'row', flexShrink: 0 }, children: [_jsx("text", { fg: active ? Theme.background : Theme.text, attributes: active ? TextAttributes.BOLD : undefined, selectable: false, wrapMode: "none", children: active ? '›' : ' ' }), icon && _jsxs("text", { fg: active ? Theme.background : iconColor || Theme.text, selectable: false, wrapMode: "none", children: [getIconEmoji(icon), " "] }), _jsx("text", { fg: active ? Theme.background : Theme.text, attributes: active ? TextAttributes.BOLD : undefined, selectable: false, wrapMode: "none", children: title })] }), subtitle && (_jsx("text", { fg: active ? Theme.background : Theme.textMuted, selectable: false, wrapMode: "none", children: subtitle }))] }), accessoryElements.length > 0 && (_jsx("box", { style: { flexDirection: 'row', flexShrink: 0 }, children: accessoryElements.map((elem, i) => (_jsxs("box", { style: { flexDirection: 'row' }, children: [i > 0 && _jsx("text", { children: " " }), elem] }, i))) }))] }));
|
|
215
231
|
}
|
|
216
232
|
export const List = (props) => {
|
|
217
|
-
const { children, onSelectionChange, filtering
|
|
233
|
+
const { children, onSelectionChange, filtering, searchText: controlledSearchText, onSearchTextChange, searchBarPlaceholder = 'Search...', isLoading, navigationTitle, isShowingDetail, selectedItemId, searchBarAccessory, ...otherProps } = props;
|
|
218
234
|
const [internalSearchText, setInternalSearchTextRaw] = useState('');
|
|
219
235
|
const [selectedIndex, setSelectedIndex] = useState(0);
|
|
220
236
|
const [isDropdownOpen, setIsDropdownOpen] = useState(false);
|
|
221
237
|
const [currentDetail, setCurrentDetail] = useState(null);
|
|
238
|
+
const [currentItemActions, setCurrentItemActions] = useState(null);
|
|
222
239
|
const inputRef = useRef(null);
|
|
223
240
|
const scrollBoxRef = useRef(null);
|
|
224
241
|
const descendantsContext = useListDescendants();
|
|
@@ -231,24 +248,36 @@ export const List = (props) => {
|
|
|
231
248
|
if (controlledSearchText === undefined)
|
|
232
249
|
return;
|
|
233
250
|
const textarea = inputRef.current;
|
|
234
|
-
if (textarea
|
|
235
|
-
|
|
236
|
-
|
|
251
|
+
if (!textarea)
|
|
252
|
+
return;
|
|
253
|
+
// Skip if textarea already has the correct value
|
|
254
|
+
if (textarea.plainText === controlledSearchText)
|
|
255
|
+
return;
|
|
256
|
+
// Save cursor position, set text, then restore cursor (clamped to valid range)
|
|
257
|
+
const cursorOffset = textarea.cursorOffset;
|
|
258
|
+
textarea.setText(controlledSearchText);
|
|
259
|
+
textarea.cursorOffset = Math.min(cursorOffset, controlledSearchText.length);
|
|
237
260
|
}, [controlledSearchText]);
|
|
238
|
-
//
|
|
239
|
-
//
|
|
240
|
-
//
|
|
241
|
-
//
|
|
242
|
-
//
|
|
243
|
-
//
|
|
244
|
-
//
|
|
261
|
+
// Filtering logic (matches Raycast behavior):
|
|
262
|
+
//
|
|
263
|
+
// | filtering prop | onSearchTextChange | Result |
|
|
264
|
+
// |----------------|-------------------|-----------------|
|
|
265
|
+
// | undefined | undefined | true (default) |
|
|
266
|
+
// | undefined | provided | false |
|
|
267
|
+
// | true | undefined | true |
|
|
268
|
+
// | true | provided | true |
|
|
269
|
+
// | false | undefined | false |
|
|
270
|
+
// | false | provided | false |
|
|
271
|
+
//
|
|
272
|
+
// Summary: filtering defaults to true, but is implicitly disabled when
|
|
273
|
+
// onSearchTextChange is provided (user manages filtering). Set filtering={true}
|
|
274
|
+
// explicitly to use built-in filtering alongside onSearchTextChange.
|
|
245
275
|
const isFilteringEnabled = (() => {
|
|
246
276
|
if (filtering === false)
|
|
247
277
|
return false;
|
|
248
278
|
if (filtering === true)
|
|
249
279
|
return true;
|
|
250
|
-
|
|
251
|
-
return !onSearchTextChange; // defaults to true unless onSearchTextChange is provided
|
|
280
|
+
return !onSearchTextChange;
|
|
252
281
|
})();
|
|
253
282
|
const openDropdown = () => {
|
|
254
283
|
setIsDropdownOpen(true);
|
|
@@ -256,8 +285,14 @@ export const List = (props) => {
|
|
|
256
285
|
// Wrapper function that updates search text
|
|
257
286
|
const setInternalSearchText = (value) => {
|
|
258
287
|
setInternalSearchTextRaw(value);
|
|
259
|
-
//
|
|
260
|
-
|
|
288
|
+
// TODO: use flushSync when available to force descendants to update visibility
|
|
289
|
+
// before querying. For now, we compute visibility inline with the new search value.
|
|
290
|
+
const items = Object.values(descendantsContext.map.current)
|
|
291
|
+
.filter((item) => item.index !== -1 && item.props?.visible !== false)
|
|
292
|
+
.sort((a, b) => a.index - b.index);
|
|
293
|
+
if (items.length > 0 && items[0]) {
|
|
294
|
+
setSelectedIndex(items[0].index);
|
|
295
|
+
}
|
|
261
296
|
};
|
|
262
297
|
const listContextValue = useMemo(() => ({
|
|
263
298
|
isDropdownOpen,
|
|
@@ -281,25 +316,32 @@ export const List = (props) => {
|
|
|
281
316
|
// Only update selection if selectedItemId is explicitly provided
|
|
282
317
|
if (selectedItemId !== undefined) {
|
|
283
318
|
const items = Object.values(descendantsContext.map.current)
|
|
284
|
-
.filter((item) => item.index !== -1)
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
setSelectedIndex(index);
|
|
319
|
+
.filter((item) => item.index !== -1);
|
|
320
|
+
const foundItem = items.find((item) => item.props?.id === selectedItemId);
|
|
321
|
+
if (foundItem) {
|
|
322
|
+
setSelectedIndex(foundItem.index);
|
|
289
323
|
}
|
|
290
324
|
}
|
|
291
325
|
}, [selectedItemId]);
|
|
292
|
-
// Call onSelectionChange when selection changes
|
|
326
|
+
// Call onSelectionChange when selection changes and track current item's actions
|
|
293
327
|
useEffect(() => {
|
|
294
|
-
if (!onSelectionChange)
|
|
295
|
-
return;
|
|
296
328
|
const items = Object.values(descendantsContext.map.current)
|
|
297
329
|
.filter((item) => item.index !== -1)
|
|
298
330
|
.sort((a, b) => a.index - b.index);
|
|
299
331
|
const currentItem = items.find((item) => item.index === selectedIndex);
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
332
|
+
// Track current item's actions for footer display
|
|
333
|
+
const actions = currentItem?.props?.actions ?? props.actions ?? null;
|
|
334
|
+
setCurrentItemActions(actions);
|
|
335
|
+
// Clear first action title when there are no actions
|
|
336
|
+
if (!actions) {
|
|
337
|
+
useStore.setState({ firstActionTitle: '' });
|
|
338
|
+
}
|
|
339
|
+
// Call onSelectionChange callback if provided
|
|
340
|
+
if (onSelectionChange) {
|
|
341
|
+
const selectedId = currentItem?.props?.id ?? null;
|
|
342
|
+
onSelectionChange(selectedId);
|
|
343
|
+
}
|
|
344
|
+
}, [selectedIndex, props.actions]);
|
|
303
345
|
const scrollToItem = (item) => {
|
|
304
346
|
const scrollBox = scrollBoxRef.current;
|
|
305
347
|
const elementRef = item.props?.elementRef;
|
|
@@ -307,33 +349,29 @@ export const List = (props) => {
|
|
|
307
349
|
return;
|
|
308
350
|
const contentY = scrollBox.content?.y || 0;
|
|
309
351
|
const viewportHeight = scrollBox.viewport?.height || 10;
|
|
310
|
-
|
|
352
|
+
// Calculate item position relative to content
|
|
311
353
|
const itemTop = elementRef.y - contentY;
|
|
312
|
-
|
|
313
|
-
const
|
|
314
|
-
|
|
315
|
-
if (itemTop < visibleTop) {
|
|
316
|
-
scrollBox.scrollTo(itemTop);
|
|
317
|
-
}
|
|
318
|
-
else if (itemBottom > visibleBottom) {
|
|
319
|
-
scrollBox.scrollTo(itemBottom - viewportHeight);
|
|
320
|
-
}
|
|
354
|
+
// Scroll so the top of the item is centered in the viewport
|
|
355
|
+
const targetScrollTop = itemTop - viewportHeight / 2;
|
|
356
|
+
scrollBox.scrollTo(Math.max(0, targetScrollTop));
|
|
321
357
|
};
|
|
322
358
|
const move = (direction) => {
|
|
359
|
+
// Get all visible items
|
|
323
360
|
const items = Object.values(descendantsContext.map.current)
|
|
324
361
|
.filter((item) => item.index !== -1 && item.props?.visible !== false)
|
|
325
362
|
.sort((a, b) => a.index - b.index);
|
|
326
363
|
if (items.length === 0)
|
|
327
364
|
return;
|
|
365
|
+
// Find currently selected item's position in visible items
|
|
328
366
|
let currentVisibleIndex = items.findIndex((item) => item.index === selectedIndex);
|
|
329
367
|
if (currentVisibleIndex === -1) {
|
|
330
368
|
// If current selection is not visible, select first visible item
|
|
331
369
|
if (items[0]) {
|
|
332
370
|
setSelectedIndex(items[0].index);
|
|
333
|
-
scrollToItem(items[0]);
|
|
334
371
|
}
|
|
335
372
|
return;
|
|
336
373
|
}
|
|
374
|
+
// Calculate next visible index
|
|
337
375
|
let nextVisibleIndex = currentVisibleIndex + direction;
|
|
338
376
|
if (nextVisibleIndex < 0)
|
|
339
377
|
nextVisibleIndex = items.length - 1;
|
|
@@ -341,8 +379,8 @@ export const List = (props) => {
|
|
|
341
379
|
nextVisibleIndex = 0;
|
|
342
380
|
const nextItem = items[nextVisibleIndex];
|
|
343
381
|
if (nextItem) {
|
|
344
|
-
setSelectedIndex(nextItem.index);
|
|
345
382
|
scrollToItem(nextItem);
|
|
383
|
+
setSelectedIndex(nextItem.index);
|
|
346
384
|
}
|
|
347
385
|
};
|
|
348
386
|
const inFocus = useIsInFocus();
|
|
@@ -355,12 +393,13 @@ export const List = (props) => {
|
|
|
355
393
|
openDropdown();
|
|
356
394
|
return;
|
|
357
395
|
}
|
|
358
|
-
//
|
|
396
|
+
// Get current item by selectedIndex (which is a descendant index)
|
|
397
|
+
const items = Object.values(descendantsContext.map.current)
|
|
398
|
+
.filter((item) => item.index !== -1)
|
|
399
|
+
.sort((a, b) => a.index - b.index);
|
|
400
|
+
const currentItem = items.find((item) => item.index === selectedIndex);
|
|
401
|
+
// Handle Ctrl+K to show actions (always show sheet)
|
|
359
402
|
if (evt.name === 'k' && evt.ctrl) {
|
|
360
|
-
const items = Object.values(descendantsContext.map.current)
|
|
361
|
-
.filter((item) => item.index !== -1)
|
|
362
|
-
.sort((a, b) => a.index - b.index);
|
|
363
|
-
const currentItem = items.find((item) => item.index === selectedIndex);
|
|
364
403
|
// Show current item's actions if available
|
|
365
404
|
if (currentItem?.props?.actions) {
|
|
366
405
|
dialog.push(currentItem.props.actions, 'bottom-right');
|
|
@@ -375,14 +414,12 @@ export const List = (props) => {
|
|
|
375
414
|
move(-1);
|
|
376
415
|
if (evt.name === 'down')
|
|
377
416
|
move(1);
|
|
417
|
+
// Handle Enter to execute first action directly
|
|
378
418
|
if (evt.name === 'return') {
|
|
379
|
-
const items = Object.values(descendantsContext.map.current)
|
|
380
|
-
.filter((item) => item.index !== -1)
|
|
381
|
-
.sort((a, b) => a.index - b.index);
|
|
382
|
-
const currentItem = items.find((item) => item.index === selectedIndex);
|
|
383
419
|
if (!currentItem?.props)
|
|
384
420
|
return;
|
|
385
421
|
if (currentItem.props.actions) {
|
|
422
|
+
useStore.setState({ shouldAutoExecuteFirstAction: true });
|
|
386
423
|
dialog.push(currentItem.props.actions, 'bottom-right');
|
|
387
424
|
}
|
|
388
425
|
}
|
|
@@ -400,7 +437,10 @@ export const List = (props) => {
|
|
|
400
437
|
};
|
|
401
438
|
return (_jsx(ListContext.Provider, { value: listContextValue, children: _jsx(ListDescendantsProvider, { value: descendantsContext, children: _jsxs("box", { style: { flexDirection: 'column', flexGrow: 1 }, children: [navigationTitle && (_jsx("box", { border: false, style: {
|
|
402
439
|
paddingBottom: 0,
|
|
403
|
-
|
|
440
|
+
flexShrink: 0,
|
|
441
|
+
paddingLeft: 1,
|
|
442
|
+
paddingRight: 1,
|
|
443
|
+
overflow: 'hidden',
|
|
404
444
|
}, children: _jsx(LoadingBar, { title: navigationTitle, isLoading: isLoading || navigationPending }) })), _jsx("box", { style: { flexShrink: 0 }, children: _jsxs("box", { border: false, style: {
|
|
405
445
|
paddingLeft: 1,
|
|
406
446
|
paddingRight: 1,
|
|
@@ -413,7 +453,7 @@ export const List = (props) => {
|
|
|
413
453
|
flexGrow: 1,
|
|
414
454
|
flexDirection: 'column',
|
|
415
455
|
flexShrink: 1,
|
|
416
|
-
}, children: _jsx("textarea", { ref: inputRef, height: 1, keyBindings: [
|
|
456
|
+
}, children: _jsx("textarea", { ref: inputRef, height: 1, wrapMode: 'none', keyBindings: [
|
|
417
457
|
{ name: 'return', action: 'submit' },
|
|
418
458
|
{ name: 'linefeed', action: 'submit' },
|
|
419
459
|
], placeholder: searchBarPlaceholder, focused: inFocus && !isDropdownOpen, initialValue: searchText, onContentChange: () => {
|
|
@@ -426,7 +466,7 @@ export const List = (props) => {
|
|
|
426
466
|
scrollbarOptions: {
|
|
427
467
|
showArrows: true,
|
|
428
468
|
},
|
|
429
|
-
}, children: _jsx(ListItemsRenderer, { children: children }) }), _jsx(ListFooter, {})] }), isShowingDetail && currentDetail && (_jsx("box", { style: {
|
|
469
|
+
}, children: _jsx(ListItemsRenderer, { children: children }) }), _jsx(ListFooter, {}), currentItemActions && (_jsx(Offscreen, { children: currentItemActions }))] }), isShowingDetail && currentDetail && (_jsx("box", { style: {
|
|
430
470
|
marginTop: 1,
|
|
431
471
|
width: '50%',
|
|
432
472
|
paddingLeft: 1,
|
|
@@ -475,7 +515,7 @@ const ListItem = (props) => {
|
|
|
475
515
|
detail: props.detail,
|
|
476
516
|
elementRef: elementRef.current,
|
|
477
517
|
});
|
|
478
|
-
//
|
|
518
|
+
// Check if this item is selected
|
|
479
519
|
const selectedIndex = listContext?.selectedIndex ?? 0;
|
|
480
520
|
const isActive = index === selectedIndex;
|
|
481
521
|
// Update detail when this item becomes active or detail prop changes
|
|
@@ -530,7 +570,7 @@ const ListItem = (props) => {
|
|
|
530
570
|
};
|
|
531
571
|
const ListItemDetail = (props) => {
|
|
532
572
|
const { isLoading, markdown, metadata } = props;
|
|
533
|
-
return (_jsxs("box", { style: { flexDirection: 'column', flexGrow: 1 }, children: [isLoading && (_jsx("box", { style: { paddingBottom: 1 }, children: _jsx("text", { fg: Theme.textMuted, children: "Loading..." }) })), _jsx(ScrollBox, { focused:
|
|
573
|
+
return (_jsxs("box", { style: { flexDirection: 'column', flexGrow: 1 }, children: [isLoading && (_jsx("box", { style: { paddingBottom: 1 }, children: _jsx("text", { fg: Theme.textMuted, children: "Loading..." }) })), _jsx(ScrollBox, { focused: false, flexGrow: 1, flexShrink: 1, style: {
|
|
534
574
|
rootOptions: {
|
|
535
575
|
backgroundColor: undefined,
|
|
536
576
|
},
|
|
@@ -543,13 +583,13 @@ const ListItemDetailMetadata = (props) => {
|
|
|
543
583
|
return (_jsx("box", { style: { flexDirection: 'column' }, children: props.children }));
|
|
544
584
|
};
|
|
545
585
|
const ListItemDetailMetadataLabel = (props) => {
|
|
546
|
-
return (_jsxs("box", { style: { flexDirection: '
|
|
586
|
+
return (_jsxs("box", { style: { flexDirection: 'column', paddingBottom: 0.5 }, children: [_jsxs("text", { fg: Theme.textMuted, children: [props.title, ":"] }), props.text && _jsx("text", { fg: Theme.text, children: props.text })] }));
|
|
547
587
|
};
|
|
548
588
|
const ListItemDetailMetadataSeparator = () => {
|
|
549
589
|
return (_jsx("box", { style: { paddingBottom: 0.5 }, children: _jsx("text", { fg: Theme.border, children: "\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500" }) }));
|
|
550
590
|
};
|
|
551
591
|
const ListItemDetailMetadataLink = (props) => {
|
|
552
|
-
return (_jsxs("box", { style: { flexDirection: '
|
|
592
|
+
return (_jsxs("box", { style: { flexDirection: 'column', paddingBottom: 0.5 }, children: [_jsxs("text", { fg: Theme.textMuted, children: [props.title, ":"] }), _jsx("text", { fg: Theme.link, children: props.text })] }));
|
|
553
593
|
};
|
|
554
594
|
const ListItemDetailMetadataTagList = (props) => {
|
|
555
595
|
return (_jsxs("box", { style: { flexDirection: 'column', paddingBottom: 0.5 }, children: [_jsxs("text", { fg: Theme.textMuted, children: [props.title, ":"] }), _jsx("box", { style: { flexDirection: 'row', paddingLeft: 1 }, children: props.children })] }));
|
|
@@ -748,16 +788,61 @@ const ListSection = (props) => {
|
|
|
748
788
|
sectionTitle: props.title,
|
|
749
789
|
searchText,
|
|
750
790
|
}), [parentContext, props.title, searchText]);
|
|
751
|
-
|
|
752
|
-
const
|
|
753
|
-
|
|
791
|
+
const isSearching = searchText.trim().length > 0;
|
|
792
|
+
const children = (_jsx(ListSectionContext.Provider, { value: sectionContextValue, children: props.children }));
|
|
793
|
+
if (isSearching) {
|
|
794
|
+
return children;
|
|
795
|
+
}
|
|
796
|
+
return (_jsxs("box", { style: { marginBottom: 1 }, children: [props.title && (_jsx("box", { border: false, style: {
|
|
754
797
|
paddingLeft: 1,
|
|
755
|
-
}, children: _jsx("text", { fg: Theme.accent, attributes: TextAttributes.BOLD, children: props.title }) })),
|
|
798
|
+
}, children: _jsx("text", { fg: Theme.accent, attributes: TextAttributes.BOLD, children: props.title }) })), children] }));
|
|
756
799
|
};
|
|
757
800
|
List.Section = ListSection;
|
|
758
801
|
List.Dropdown = ListDropdown;
|
|
759
802
|
List.EmptyView = (props) => {
|
|
760
|
-
|
|
803
|
+
const dialog = useDialog();
|
|
804
|
+
const inFocus = useIsInFocus();
|
|
805
|
+
// Handle keyboard for actions
|
|
806
|
+
useKeyboard((evt) => {
|
|
807
|
+
if (!inFocus)
|
|
808
|
+
return;
|
|
809
|
+
// Handle Ctrl+K to show actions
|
|
810
|
+
if (evt.name === 'k' && evt.ctrl && props.actions) {
|
|
811
|
+
dialog.push(props.actions, 'bottom-right');
|
|
812
|
+
return;
|
|
813
|
+
}
|
|
814
|
+
// Handle Enter to execute first action
|
|
815
|
+
if (evt.name === 'return' && props.actions) {
|
|
816
|
+
useStore.setState({ shouldAutoExecuteFirstAction: true });
|
|
817
|
+
dialog.push(props.actions, 'bottom-right');
|
|
818
|
+
}
|
|
819
|
+
});
|
|
820
|
+
// Get icon string from ImageLike
|
|
821
|
+
const getIconString = (icon) => {
|
|
822
|
+
if (typeof icon === 'string') {
|
|
823
|
+
return getIconEmoji(icon);
|
|
824
|
+
}
|
|
825
|
+
if (icon && typeof icon === 'object' && 'source' in icon) {
|
|
826
|
+
// For { source: string } or { source: { light, dark } } objects
|
|
827
|
+
const source = icon.source;
|
|
828
|
+
if (typeof source === 'string') {
|
|
829
|
+
return getIconEmoji(source);
|
|
830
|
+
}
|
|
831
|
+
}
|
|
832
|
+
return null;
|
|
833
|
+
};
|
|
834
|
+
const iconEmoji = props.icon ? getIconString(props.icon) : null;
|
|
835
|
+
return (_jsxs("box", { style: {
|
|
836
|
+
flexDirection: 'column',
|
|
837
|
+
alignItems: 'center',
|
|
838
|
+
justifyContent: 'center',
|
|
839
|
+
flexGrow: 1,
|
|
840
|
+
paddingTop: 2,
|
|
841
|
+
paddingBottom: 2,
|
|
842
|
+
paddingLeft: 2,
|
|
843
|
+
paddingRight: 2,
|
|
844
|
+
gap: 1,
|
|
845
|
+
}, children: [iconEmoji && (_jsx("text", { fg: Theme.textMuted, style: { marginBottom: 1 }, children: iconEmoji })), props.title && (_jsx("text", { fg: Theme.text, attributes: TextAttributes.BOLD, children: props.title?.replace(/\bRaycast\b/g, 'Termcast').replace(/\braycast\b/g, 'termcast') || '' })), props.description && (_jsx("text", { fg: Theme.textMuted, wrapMode: 'word', children: props.description?.replace(/\bRaycast\b/g, 'Termcast').replace(/\braycast\b/g, 'termcast') || '' }))] }));
|
|
761
846
|
};
|
|
762
847
|
export default List;
|
|
763
848
|
// Grid uses List internally with a different visual representation
|