termcast 1.3.9
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/action-utils.d.ts +25 -0
- package/dist/action-utils.d.ts.map +1 -0
- package/dist/action-utils.js +209 -0
- package/dist/action-utils.js.map +1 -0
- 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/ai.d.ts +104 -0
- package/dist/apis/ai.d.ts.map +1 -0
- package/dist/apis/ai.js +135 -0
- package/dist/apis/ai.js.map +1 -0
- package/dist/apis/cache.d.ts +84 -0
- package/dist/apis/cache.d.ts.map +1 -0
- package/dist/apis/cache.js +307 -0
- package/dist/apis/cache.js.map +1 -0
- package/dist/apis/cache.test.d.ts +2 -0
- package/dist/apis/cache.test.d.ts.map +1 -0
- package/dist/apis/cache.test.js +246 -0
- package/dist/apis/cache.test.js.map +1 -0
- package/dist/apis/clipboard.d.ts +36 -0
- package/dist/apis/clipboard.d.ts.map +1 -0
- package/dist/apis/clipboard.js +154 -0
- package/dist/apis/clipboard.js.map +1 -0
- package/dist/apis/environment.d.ts +63 -0
- package/dist/apis/environment.d.ts.map +1 -0
- package/dist/apis/environment.js +189 -0
- package/dist/apis/environment.js.map +1 -0
- package/dist/apis/hud.d.ts +7 -0
- package/dist/apis/hud.d.ts.map +1 -0
- package/dist/apis/hud.js +45 -0
- package/dist/apis/hud.js.map +1 -0
- package/dist/apis/localstorage.d.ts +13 -0
- package/dist/apis/localstorage.d.ts.map +1 -0
- package/dist/apis/localstorage.js +190 -0
- package/dist/apis/localstorage.js.map +1 -0
- package/dist/apis/localstorage.test.d.ts +2 -0
- package/dist/apis/localstorage.test.d.ts.map +1 -0
- package/dist/apis/localstorage.test.js +131 -0
- package/dist/apis/localstorage.test.js.map +1 -0
- package/dist/apis/oauth.d.ts +142 -0
- package/dist/apis/oauth.d.ts.map +1 -0
- package/dist/apis/oauth.js +551 -0
- package/dist/apis/oauth.js.map +1 -0
- package/dist/apis/preferences.d.ts +23 -0
- package/dist/apis/preferences.d.ts.map +1 -0
- package/dist/apis/preferences.js +105 -0
- package/dist/apis/preferences.js.map +1 -0
- package/dist/apis/toast.d.ts +81 -0
- package/dist/apis/toast.d.ts.map +1 -0
- package/dist/apis/toast.js +275 -0
- package/dist/apis/toast.js.map +1 -0
- package/dist/apis/toast.test.d.ts +2 -0
- package/dist/apis/toast.test.d.ts.map +1 -0
- package/dist/apis/toast.test.js +67 -0
- package/dist/apis/toast.test.js.map +1 -0
- package/dist/apis/window.d.ts +12 -0
- package/dist/apis/window.d.ts.map +1 -0
- package/dist/apis/window.js +47 -0
- package/dist/apis/window.js.map +1 -0
- package/dist/build.d.ts +15 -0
- package/dist/build.d.ts.map +1 -0
- package/dist/build.js +213 -0
- package/dist/build.js.map +1 -0
- package/dist/build.test.d.ts +2 -0
- package/dist/build.test.d.ts.map +1 -0
- package/dist/build.test.js +73 -0
- package/dist/build.test.js.map +1 -0
- 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/cache.test.d.ts +2 -0
- package/dist/cache.test.d.ts.map +1 -0
- package/dist/cache.test.js +246 -0
- package/dist/cache.test.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +278 -0
- package/dist/cli.js.map +1 -0
- 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/colors.d.ts +15 -0
- package/dist/colors.d.ts.map +1 -0
- package/dist/colors.js +13 -0
- package/dist/colors.js.map +1 -0
- package/dist/components/actions.d.ts +120 -0
- package/dist/components/actions.d.ts.map +1 -0
- package/dist/components/actions.js +371 -0
- package/dist/components/actions.js.map +1 -0
- package/dist/components/alert.d.ts +25 -0
- package/dist/components/alert.d.ts.map +1 -0
- package/dist/components/alert.js +99 -0
- package/dist/components/alert.js.map +1 -0
- package/dist/components/detail.d.ts +65 -0
- package/dist/components/detail.d.ts.map +1 -0
- package/dist/components/detail.js +147 -0
- package/dist/components/detail.js.map +1 -0
- package/dist/components/dropdown.d.ts +40 -0
- package/dist/components/dropdown.d.ts.map +1 -0
- package/dist/components/dropdown.js +202 -0
- package/dist/components/dropdown.js.map +1 -0
- package/dist/components/extension-preferences.d.ts +8 -0
- package/dist/components/extension-preferences.d.ts.map +1 -0
- package/dist/components/extension-preferences.js +139 -0
- package/dist/components/extension-preferences.js.map +1 -0
- package/dist/components/form/assign-components.d.ts +2 -0
- package/dist/components/form/assign-components.d.ts.map +1 -0
- package/dist/components/form/assign-components.js +22 -0
- package/dist/components/form/assign-components.js.map +1 -0
- package/dist/components/form/checkbox.d.ts +7 -0
- package/dist/components/form/checkbox.d.ts.map +1 -0
- package/dist/components/form/checkbox.js +46 -0
- package/dist/components/form/checkbox.js.map +1 -0
- package/dist/components/form/date-picker.d.ts +18 -0
- package/dist/components/form/date-picker.d.ts.map +1 -0
- package/dist/components/form/date-picker.js +69 -0
- package/dist/components/form/date-picker.js.map +1 -0
- package/dist/components/form/description.d.ts +7 -0
- package/dist/components/form/description.d.ts.map +1 -0
- package/dist/components/form/description.js +8 -0
- package/dist/components/form/description.js.map +1 -0
- package/dist/components/form/dropdown.d.ts +25 -0
- package/dist/components/form/dropdown.d.ts.map +1 -0
- package/dist/components/form/dropdown.js +286 -0
- package/dist/components/form/dropdown.js.map +1 -0
- package/dist/components/form/file-autocomplete.d.ts +12 -0
- package/dist/components/form/file-autocomplete.d.ts.map +1 -0
- package/dist/components/form/file-autocomplete.js +84 -0
- package/dist/components/form/file-autocomplete.js.map +1 -0
- package/dist/components/form/file-picker.d.ts +31 -0
- package/dist/components/form/file-picker.d.ts.map +1 -0
- package/dist/components/form/file-picker.js +113 -0
- package/dist/components/form/file-picker.js.map +1 -0
- package/dist/components/form/form-end.d.ts +2 -0
- package/dist/components/form/form-end.d.ts.map +1 -0
- package/dist/components/form/form-end.js +6 -0
- package/dist/components/form/form-end.js.map +1 -0
- 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 +46 -0
- package/dist/components/form/index.d.ts.map +1 -0
- package/dist/components/form/index.js +106 -0
- package/dist/components/form/index.js.map +1 -0
- package/dist/components/form/password-field.d.ts +7 -0
- package/dist/components/form/password-field.d.ts.map +1 -0
- package/dist/components/form/password-field.js +34 -0
- package/dist/components/form/password-field.js.map +1 -0
- package/dist/components/form/separator.d.ts +2 -0
- package/dist/components/form/separator.d.ts.map +1 -0
- package/dist/components/form/separator.js +8 -0
- package/dist/components/form/separator.js.map +1 -0
- package/dist/components/form/tagpicker.d.ts +134 -0
- package/dist/components/form/tagpicker.d.ts.map +1 -0
- package/dist/components/form/tagpicker.js +79 -0
- package/dist/components/form/tagpicker.js.map +1 -0
- package/dist/components/form/text-area.d.ts +8 -0
- package/dist/components/form/text-area.d.ts.map +1 -0
- package/dist/components/form/text-area.js +26 -0
- package/dist/components/form/text-area.js.map +1 -0
- package/dist/components/form/text-field.d.ts +7 -0
- package/dist/components/form/text-field.d.ts.map +1 -0
- package/dist/components/form/text-field.js +28 -0
- package/dist/components/form/text-field.js.map +1 -0
- package/dist/components/form/types.d.ts +43 -0
- package/dist/components/form/types.d.ts.map +1 -0
- package/dist/components/form/types.js +2 -0
- package/dist/components/form/types.js.map +1 -0
- 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/use-form-navigation.d.ts +8 -0
- package/dist/components/form/use-form-navigation.d.ts.map +1 -0
- package/dist/components/form/use-form-navigation.js +58 -0
- package/dist/components/form/use-form-navigation.js.map +1 -0
- package/dist/components/form/with-left-border.d.ts +17 -0
- package/dist/components/form/with-left-border.d.ts.map +1 -0
- package/dist/components/form/with-left-border.js +10 -0
- package/dist/components/form/with-left-border.js.map +1 -0
- package/dist/components/icon.d.ts +9 -0
- package/dist/components/icon.d.ts.map +1 -0
- package/dist/components/icon.js +485 -0
- package/dist/components/icon.js.map +1 -0
- package/dist/components/image.d.ts +19 -0
- package/dist/components/image.d.ts.map +1 -0
- package/dist/components/image.js +32 -0
- package/dist/components/image.js.map +1 -0
- package/dist/components/list.d.ts +234 -0
- package/dist/components/list.d.ts.map +1 -0
- package/dist/components/list.js +667 -0
- package/dist/components/list.js.map +1 -0
- package/dist/components/loading-bar.d.ts +8 -0
- package/dist/components/loading-bar.d.ts.map +1 -0
- package/dist/components/loading-bar.js +107 -0
- package/dist/components/loading-bar.js.map +1 -0
- package/dist/components/menubar-extra.d.ts +68 -0
- package/dist/components/menubar-extra.d.ts.map +1 -0
- package/dist/components/menubar-extra.js +39 -0
- package/dist/components/menubar-extra.js.map +1 -0
- package/dist/descendants.d.ts +25 -0
- package/dist/descendants.d.ts.map +1 -0
- package/dist/descendants.js +81 -0
- package/dist/descendants.js.map +1 -0
- 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/e2e-node.d.ts +63 -0
- package/dist/e2e-node.d.ts.map +1 -0
- package/dist/e2e-node.js +255 -0
- package/dist/e2e-node.js.map +1 -0
- package/dist/e2e.d.ts +39 -0
- package/dist/e2e.d.ts.map +1 -0
- package/dist/e2e.js +127 -0
- package/dist/e2e.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/action-show-in-finder.d.ts +2 -0
- package/dist/examples/action-show-in-finder.d.ts.map +1 -0
- package/dist/examples/action-show-in-finder.js +13 -0
- package/dist/examples/action-show-in-finder.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/environment-test.d.ts +2 -0
- package/dist/examples/environment-test.d.ts.map +1 -0
- package/dist/examples/environment-test.js +28 -0
- package/dist/examples/environment-test.js.map +1 -0
- package/dist/examples/error-boundary.d.ts +6 -0
- package/dist/examples/error-boundary.d.ts.map +1 -0
- package/dist/examples/error-boundary.js +67 -0
- package/dist/examples/error-boundary.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.d.ts +2 -0
- package/dist/examples/form-basic.d.ts.map +1 -0
- package/dist/examples/form-basic.js +21 -0
- package/dist/examples/form-basic.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 +995 -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.d.ts +2 -0
- package/dist/examples/form-dropdown.d.ts.map +1 -0
- package/dist/examples/form-dropdown.js +13 -0
- package/dist/examples/form-dropdown.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 +722 -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-tagpicker.d.ts +2 -0
- package/dist/examples/form-tagpicker.d.ts.map +1 -0
- package/dist/examples/form-tagpicker.js +13 -0
- package/dist/examples/form-tagpicker.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 +491 -0
- package/dist/examples/form-tagpicker.vitest.js.map +1 -0
- package/dist/examples/internal/descendants-filtering.d.ts +2 -0
- package/dist/examples/internal/descendants-filtering.d.ts.map +1 -0
- package/dist/examples/internal/descendants-filtering.js +144 -0
- package/dist/examples/internal/descendants-filtering.js.map +1 -0
- package/dist/examples/internal/descendants.d.ts +2 -0
- package/dist/examples/internal/descendants.d.ts.map +1 -0
- package/dist/examples/internal/descendants.js +134 -0
- package/dist/examples/internal/descendants.js.map +1 -0
- 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/scrollbox-demo.d.ts +2 -0
- package/dist/examples/internal/scrollbox-demo.d.ts.map +1 -0
- package/dist/examples/internal/scrollbox-demo.js +104 -0
- package/dist/examples/internal/scrollbox-demo.js.map +1 -0
- package/dist/examples/internal/simple-dialog.d.ts +2 -0
- package/dist/examples/internal/simple-dialog.d.ts.map +1 -0
- package/dist/examples/internal/simple-dialog.js +43 -0
- package/dist/examples/internal/simple-dialog.js.map +1 -0
- package/dist/examples/internal/text-stacking.d.ts +2 -0
- package/dist/examples/internal/text-stacking.d.ts.map +1 -0
- package/dist/examples/internal/text-stacking.js +53 -0
- package/dist/examples/internal/text-stacking.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-dropdown-default.d.ts +2 -0
- package/dist/examples/list-dropdown-default.d.ts.map +1 -0
- package/dist/examples/list-dropdown-default.js +14 -0
- package/dist/examples/list-dropdown-default.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 +164 -0
- package/dist/examples/list-dropdown-default.vitest.js.map +1 -0
- package/dist/examples/list-fetch-data.d.ts +2 -0
- package/dist/examples/list-fetch-data.d.ts.map +1 -0
- package/dist/examples/list-fetch-data.js +87 -0
- package/dist/examples/list-fetch-data.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 +103 -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-with-detail.d.ts +2 -0
- package/dist/examples/list-with-detail.d.ts.map +1 -0
- package/dist/examples/list-with-detail.js +94 -0
- package/dist/examples/list-with-detail.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 +438 -0
- package/dist/examples/list-with-detail.vitest.js.map +1 -0
- package/dist/examples/list-with-dropdown.d.ts +2 -0
- package/dist/examples/list-with-dropdown.d.ts.map +1 -0
- package/dist/examples/list-with-dropdown.js +43 -0
- package/dist/examples/list-with-dropdown.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 +297 -0
- package/dist/examples/list-with-dropdown.vitest.js.map +1 -0
- package/dist/examples/list-with-sections.d.ts +2 -0
- package/dist/examples/list-with-sections.d.ts.map +1 -0
- package/dist/examples/list-with-sections.js +67 -0
- package/dist/examples/list-with-sections.js.map +1 -0
- 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 +441 -0
- package/dist/examples/list-with-sections.vitest.js.map +1 -0
- package/dist/examples/miscellaneous.d.ts +2 -0
- package/dist/examples/miscellaneous.d.ts.map +1 -0
- package/dist/examples/miscellaneous.js +313 -0
- package/dist/examples/miscellaneous.js.map +1 -0
- package/dist/examples/nested-navigation.d.ts +2 -0
- package/dist/examples/nested-navigation.d.ts.map +1 -0
- package/dist/examples/nested-navigation.js +35 -0
- package/dist/examples/nested-navigation.js.map +1 -0
- package/dist/examples/preferences-test.d.ts +2 -0
- package/dist/examples/preferences-test.d.ts.map +1 -0
- package/dist/examples/preferences-test.js +43 -0
- package/dist/examples/preferences-test.js.map +1 -0
- package/dist/examples/simple-dropdown.d.ts +2 -0
- package/dist/examples/simple-dropdown.d.ts.map +1 -0
- package/dist/examples/simple-dropdown.js +15 -0
- package/dist/examples/simple-dropdown.js.map +1 -0
- package/dist/examples/simple-file-picker.d.ts +2 -0
- package/dist/examples/simple-file-picker.d.ts.map +1 -0
- package/dist/examples/simple-file-picker.js +21 -0
- package/dist/examples/simple-file-picker.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 +277 -0
- package/dist/examples/simple-file-picker.vitest.js.map +1 -0
- package/dist/examples/simple-grid.d.ts +2 -0
- package/dist/examples/simple-grid.d.ts.map +1 -0
- package/dist/examples/simple-grid.js +51 -0
- package/dist/examples/simple-grid.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 +498 -0
- package/dist/examples/simple-grid.vitest.js.map +1 -0
- package/dist/examples/simple-hud.d.ts +2 -0
- package/dist/examples/simple-hud.d.ts.map +1 -0
- package/dist/examples/simple-hud.js +18 -0
- package/dist/examples/simple-hud.js.map +1 -0
- package/dist/examples/simple-list-search.d.ts +2 -0
- package/dist/examples/simple-list-search.d.ts.map +1 -0
- package/dist/examples/simple-list-search.js +26 -0
- package/dist/examples/simple-list-search.js.map +1 -0
- package/dist/examples/simple-list.d.ts +2 -0
- package/dist/examples/simple-list.d.ts.map +1 -0
- package/dist/examples/simple-list.js +50 -0
- package/dist/examples/simple-list.js.map +1 -0
- package/dist/examples/simple-navigation.d.ts +2 -0
- package/dist/examples/simple-navigation.d.ts.map +1 -0
- package/dist/examples/simple-navigation.js +36 -0
- package/dist/examples/simple-navigation.js.map +1 -0
- 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 +522 -0
- package/dist/examples/simple-navigation.vitest.js.map +1 -0
- package/dist/examples/store.d.ts +2 -0
- package/dist/examples/store.d.ts.map +1 -0
- package/dist/examples/store.js +5 -0
- package/dist/examples/store.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 +52 -0
- package/dist/examples/store.vitest.js.map +1 -0
- package/dist/examples/tanstack-demo.d.ts +2 -0
- package/dist/examples/tanstack-demo.d.ts.map +1 -0
- package/dist/examples/tanstack-demo.js +51 -0
- package/dist/examples/tanstack-demo.js.map +1 -0
- package/dist/examples/use-promise-demo.d.ts +2 -0
- package/dist/examples/use-promise-demo.d.ts.map +1 -0
- package/dist/examples/use-promise-demo.js +45 -0
- package/dist/examples/use-promise-demo.js.map +1 -0
- package/dist/extensions/dev.d.ts +7 -0
- package/dist/extensions/dev.d.ts.map +1 -0
- package/dist/extensions/dev.js +124 -0
- package/dist/extensions/dev.js.map +1 -0
- package/dist/extensions/home.d.ts +8 -0
- package/dist/extensions/home.d.ts.map +1 -0
- package/dist/extensions/home.js +184 -0
- package/dist/extensions/home.js.map +1 -0
- package/dist/extensions/store.d.ts +6 -0
- package/dist/extensions/store.d.ts.map +1 -0
- package/dist/extensions/store.js +203 -0
- package/dist/extensions/store.js.map +1 -0
- package/dist/globals.d.ts +9 -0
- package/dist/globals.d.ts.map +1 -0
- package/dist/globals.js +21 -0
- package/dist/globals.js.map +1 -0
- 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/hooks/hooks.test.d.ts +2 -0
- package/dist/hooks/hooks.test.d.ts.map +1 -0
- package/dist/hooks/hooks.test.js +37 -0
- package/dist/hooks/hooks.test.js.map +1 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +6 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/use-action-panel.d.ts +16 -0
- package/dist/hooks/use-action-panel.d.ts.map +1 -0
- package/dist/hooks/use-action-panel.js +19 -0
- package/dist/hooks/use-action-panel.js.map +1 -0
- package/dist/hooks/use-id.d.ts +9 -0
- package/dist/hooks/use-id.d.ts.map +1 -0
- package/dist/hooks/use-id.js +17 -0
- package/dist/hooks/use-id.js.map +1 -0
- package/dist/hooks/use-unstable-ai.d.ts +9 -0
- package/dist/hooks/use-unstable-ai.d.ts.map +1 -0
- package/dist/hooks/use-unstable-ai.js +13 -0
- package/dist/hooks/use-unstable-ai.js.map +1 -0
- package/dist/hooks.d.ts +10 -0
- package/dist/hooks.d.ts.map +1 -0
- package/dist/hooks.js +20 -0
- package/dist/hooks.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 +58 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +71 -0
- package/dist/index.js.map +1 -0
- package/dist/internal/date-picker-widget.d.ts +9 -0
- package/dist/internal/date-picker-widget.d.ts.map +1 -0
- package/dist/internal/date-picker-widget.js +380 -0
- package/dist/internal/date-picker-widget.js.map +1 -0
- package/dist/internal/dialog.d.ts +21 -0
- package/dist/internal/dialog.d.ts.map +1 -0
- package/dist/internal/dialog.js +122 -0
- package/dist/internal/dialog.js.map +1 -0
- package/dist/internal/error-handler.d.ts +2 -0
- package/dist/internal/error-handler.d.ts.map +1 -0
- package/dist/internal/error-handler.js +29 -0
- package/dist/internal/error-handler.js.map +1 -0
- package/dist/internal/focus-context.d.ts +10 -0
- package/dist/internal/focus-context.d.ts.map +1 -0
- package/dist/internal/focus-context.js +12 -0
- package/dist/internal/focus-context.js.map +1 -0
- package/dist/internal/navigation.d.ts +18 -0
- package/dist/internal/navigation.d.ts.map +1 -0
- package/dist/internal/navigation.js +83 -0
- package/dist/internal/navigation.js.map +1 -0
- package/dist/internal/providers.d.ts +8 -0
- package/dist/internal/providers.d.ts.map +1 -0
- package/dist/internal/providers.js +262 -0
- package/dist/internal/providers.js.map +1 -0
- 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/localstorage.test.d.ts +2 -0
- package/dist/localstorage.test.d.ts.map +1 -0
- package/dist/localstorage.test.js +131 -0
- package/dist/localstorage.test.js.map +1 -0
- package/dist/logger.d.ts +7 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +70 -0
- package/dist/logger.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/package-json.d.ts +84 -0
- package/dist/package-json.d.ts.map +1 -0
- package/dist/package-json.js +77 -0
- package/dist/package-json.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/preload.d.ts +2 -0
- package/dist/preload.d.ts.map +1 -0
- package/dist/preload.js +28 -0
- package/dist/preload.js.map +1 -0
- package/dist/state.d.ts +26 -0
- package/dist/state.d.ts.map +1 -0
- package/dist/state.js +18 -0
- package/dist/state.js.map +1 -0
- package/dist/store-api/download.d.ts +8 -0
- package/dist/store-api/download.d.ts.map +1 -0
- package/dist/store-api/download.js +37 -0
- package/dist/store-api/download.js.map +1 -0
- package/dist/store-api/download.test.d.ts +2 -0
- package/dist/store-api/download.test.d.ts.map +1 -0
- package/dist/store-api/download.test.js +36 -0
- package/dist/store-api/download.test.js.map +1 -0
- package/dist/store-api/extension.d.ts +87 -0
- package/dist/store-api/extension.d.ts.map +1 -0
- package/dist/store-api/extension.js +23 -0
- package/dist/store-api/extension.js.map +1 -0
- package/dist/store-api/extension.test.d.ts +2 -0
- package/dist/store-api/extension.test.d.ts.map +1 -0
- package/dist/store-api/extension.test.js +22 -0
- package/dist/store-api/extension.test.js.map +1 -0
- package/dist/store-api/search.d.ts +101 -0
- package/dist/store-api/search.d.ts.map +1 -0
- package/dist/store-api/search.js +29 -0
- package/dist/store-api/search.js.map +1 -0
- package/dist/store-api/search.test.d.ts +2 -0
- package/dist/store-api/search.test.d.ts.map +1 -0
- package/dist/store-api/search.test.js +45 -0
- package/dist/store-api/search.test.js.map +1 -0
- 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/theme.d.ts +20 -0
- package/dist/theme.d.ts.map +1 -0
- package/dist/theme.js +26 -0
- package/dist/theme.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 +11 -0
- package/dist/utils/file-system.d.ts.map +1 -0
- package/dist/utils/file-system.js +66 -0
- package/dist/utils/file-system.js.map +1 -0
- package/dist/utils.d.ts +234 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +473 -0
- package/dist/utils.js.map +1 -0
- package/dist/utils.test.d.ts +2 -0
- package/dist/utils.test.d.ts.map +1 -0
- package/dist/utils.test.js +152 -0
- package/dist/utils.test.js.map +1 -0
- 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 +56 -0
- package/src/action-utils.tsx +207 -0
- package/src/apis/ai.tsx +177 -0
- package/src/apis/cache.test.ts +311 -0
- package/src/apis/cache.tsx +394 -0
- package/src/apis/clipboard.tsx +200 -0
- package/src/apis/environment.tsx +239 -0
- package/src/apis/hud.tsx +86 -0
- package/src/apis/localstorage.test.ts +164 -0
- package/src/apis/localstorage.tsx +215 -0
- package/src/apis/oauth.tsx +744 -0
- package/src/apis/preferences.tsx +140 -0
- package/src/apis/toast.tsx +388 -0
- package/src/apis/window.tsx +61 -0
- package/src/build.test.tsx +78 -0
- package/src/build.tsx +273 -0
- package/src/cli.tsx +328 -0
- package/src/colors.tsx +15 -0
- package/src/components/actions.tsx +718 -0
- package/src/components/alert.tsx +205 -0
- package/src/components/detail.tsx +359 -0
- package/src/components/dropdown.tsx +438 -0
- package/src/components/extension-preferences.tsx +269 -0
- package/src/components/form/assign-components.tsx +22 -0
- package/src/components/form/checkbox.tsx +96 -0
- package/src/components/form/date-picker.tsx +125 -0
- package/src/components/form/description.tsx +30 -0
- package/src/components/form/dropdown.tsx +512 -0
- package/src/components/form/file-autocomplete.tsx +141 -0
- package/src/components/form/file-picker.tsx +233 -0
- package/src/components/form/form-end.tsx +6 -0
- package/src/components/form/index.tsx +242 -0
- package/src/components/form/password-field.tsx +87 -0
- package/src/components/form/separator.tsx +15 -0
- package/src/components/form/tagpicker.tsx +245 -0
- package/src/components/form/text-area.tsx +82 -0
- package/src/components/form/text-field.tsx +82 -0
- package/src/components/form/types.tsx +49 -0
- package/src/components/form/use-form-navigation.tsx +65 -0
- package/src/components/form/with-left-border.tsx +53 -0
- package/src/components/icon.tsx +496 -0
- package/src/components/image.tsx +54 -0
- package/src/components/list.tsx +1564 -0
- package/src/components/loading-bar.tsx +141 -0
- package/src/components/menubar-extra.tsx +181 -0
- package/src/descendants.tsx +134 -0
- package/src/e2e-node.tsx +303 -0
- package/src/e2e.tsx +147 -0
- package/src/examples/action-show-in-finder.tsx +80 -0
- package/src/examples/environment-test.tsx +50 -0
- package/src/examples/error-boundary.tsx +217 -0
- package/src/examples/form-basic.tsx +122 -0
- package/src/examples/form-basic.vitest.tsx +1035 -0
- package/src/examples/form-dropdown.tsx +102 -0
- package/src/examples/form-dropdown.vitest.tsx +758 -0
- package/src/examples/form-tagpicker.tsx +66 -0
- package/src/examples/form-tagpicker.vitest.tsx +523 -0
- package/src/examples/internal/descendants-filtering.tsx +223 -0
- package/src/examples/internal/descendants.tsx +208 -0
- package/src/examples/internal/scrollbox-demo.tsx +149 -0
- package/src/examples/internal/simple-dialog.tsx +124 -0
- package/src/examples/internal/text-stacking.tsx +90 -0
- package/src/examples/list-dropdown-default.tsx +69 -0
- package/src/examples/list-dropdown-default.vitest.tsx +187 -0
- package/src/examples/list-fetch-data.tsx +123 -0
- package/src/examples/list-fetch-data.vitest.tsx +110 -0
- package/src/examples/list-with-detail.tsx +161 -0
- package/src/examples/list-with-detail.vitest.tsx +468 -0
- package/src/examples/list-with-dropdown.tsx +97 -0
- package/src/examples/list-with-dropdown.vitest.tsx +324 -0
- package/src/examples/list-with-sections.tsx +196 -0
- package/src/examples/list-with-sections.vitest.tsx +479 -0
- package/src/examples/miscellaneous.tsx +780 -0
- package/src/examples/nested-navigation.tsx +118 -0
- package/src/examples/preferences-test.tsx +82 -0
- package/src/examples/simple-dropdown.tsx +95 -0
- package/src/examples/simple-file-picker.tsx +75 -0
- package/src/examples/simple-file-picker.vitest.tsx +306 -0
- package/src/examples/simple-grid.tsx +149 -0
- package/src/examples/simple-grid.vitest.tsx +535 -0
- package/src/examples/simple-hud.tsx +60 -0
- package/src/examples/simple-list-search.tsx +93 -0
- package/src/examples/simple-list.tsx +149 -0
- package/src/examples/simple-navigation.tsx +89 -0
- package/src/examples/simple-navigation.vitest.tsx +571 -0
- package/src/examples/store.tsx +4 -0
- package/src/examples/store.vitest.tsx +59 -0
- package/src/examples/tanstack-demo.tsx +104 -0
- package/src/examples/use-promise-demo.tsx +96 -0
- package/src/extensions/dev.tsx +215 -0
- package/src/extensions/home.tsx +332 -0
- package/src/extensions/store.tsx +375 -0
- package/src/globals.ts +34 -0
- package/src/hooks/index.tsx +8 -0
- package/src/hooks/use-action-panel.tsx +28 -0
- package/src/hooks/use-id.tsx +19 -0
- package/src/hooks/use-unstable-ai.tsx +15 -0
- package/src/hooks.tsx +22 -0
- package/src/index.tsx +240 -0
- package/src/internal/date-picker-widget.tsx +500 -0
- package/src/internal/dialog.tsx +202 -0
- package/src/internal/error-handler.tsx +32 -0
- package/src/internal/focus-context.tsx +23 -0
- package/src/internal/navigation.tsx +149 -0
- package/src/internal/providers.tsx +430 -0
- package/src/logger.tsx +84 -0
- package/src/package-json.tsx +197 -0
- package/src/preload.tsx +32 -0
- package/src/state.tsx +49 -0
- package/src/store-api/download.test.tsx +38 -0
- package/src/store-api/download.tsx +52 -0
- package/src/store-api/extension.test.tsx +24 -0
- package/src/store-api/extension.tsx +123 -0
- package/src/store-api/search.test.tsx +50 -0
- package/src/store-api/search.tsx +146 -0
- package/src/theme.tsx +31 -0
- package/src/utils/file-system.ts +87 -0
- package/src/utils.test.tsx +204 -0
- package/src/utils.tsx +657 -0
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import React, { useState, useEffect, useRef, useLayoutEffect } from 'react'
|
|
2
|
+
import { BoxRenderable } from '@opentui/core'
|
|
3
|
+
import {} from '@opentui/react'
|
|
4
|
+
import { Theme } from 'termcast/src/theme'
|
|
5
|
+
import { logger } from 'termcast/src/logger'
|
|
6
|
+
|
|
7
|
+
interface LoadingBarProps {
|
|
8
|
+
title: string
|
|
9
|
+
isLoading?: boolean
|
|
10
|
+
barLength?: number
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export function LoadingBar(props: LoadingBarProps): any {
|
|
14
|
+
let { title, isLoading = false, barLength: propBarLength } = props
|
|
15
|
+
const [position, setPosition] = useState(0)
|
|
16
|
+
const [calculatedBarLength, setCalculatedBarLength] = useState(
|
|
17
|
+
propBarLength || 0,
|
|
18
|
+
)
|
|
19
|
+
const intervalRef = useRef<NodeJS.Timeout | null>(null)
|
|
20
|
+
const containerRef = useRef<BoxRenderable>(null)
|
|
21
|
+
|
|
22
|
+
// Calculate bar length based on container width
|
|
23
|
+
useLayoutEffect(() => {
|
|
24
|
+
if (containerRef.current) {
|
|
25
|
+
// TODO i am using the full terminal width for now. it would be better to use the box width for real instead
|
|
26
|
+
const containerWidth = containerRef.current.ctx.width - 4
|
|
27
|
+
|
|
28
|
+
// logger.log('LoadingBar container width:', containerWidth)
|
|
29
|
+
if (!containerWidth) return
|
|
30
|
+
// Account for padding (1 on each side) and the title length + space
|
|
31
|
+
const availableWidth = containerWidth - 2 - title.length - 1
|
|
32
|
+
|
|
33
|
+
const calculatedLength = Math.max(availableWidth, 10) // Minimum bar length of 10
|
|
34
|
+
|
|
35
|
+
setCalculatedBarLength(calculatedLength)
|
|
36
|
+
}
|
|
37
|
+
}, [title, propBarLength])
|
|
38
|
+
|
|
39
|
+
// Create the full text including title and bar
|
|
40
|
+
const barLength = propBarLength || calculatedBarLength
|
|
41
|
+
const bar = '─'.repeat(barLength)
|
|
42
|
+
const fullText = `${title} ${bar}`
|
|
43
|
+
const characters = fullText.split('')
|
|
44
|
+
|
|
45
|
+
// Define gradient colors using xterm-256 colors for consistency
|
|
46
|
+
const waveColors = [
|
|
47
|
+
'#585858', // xterm 240
|
|
48
|
+
'#585858', // xterm 240
|
|
49
|
+
'#6c6c6c', // xterm 242
|
|
50
|
+
'#6c6c6c', // xterm 242
|
|
51
|
+
'#808080', // xterm 244
|
|
52
|
+
'#808080', // xterm 244
|
|
53
|
+
'#949494', // xterm 246
|
|
54
|
+
'#949494', // xterm 246
|
|
55
|
+
'#a8a8a8', // xterm 248
|
|
56
|
+
'#a8a8a8', // xterm 248
|
|
57
|
+
'#bcbcbc', // xterm 250
|
|
58
|
+
'#bcbcbc', // xterm 250
|
|
59
|
+
'#d0d0d0', // xterm 252
|
|
60
|
+
'#d0d0d0', // xterm 252
|
|
61
|
+
'#bcbcbc', // xterm 250
|
|
62
|
+
'#bcbcbc', // xterm 250
|
|
63
|
+
'#a8a8a8', // xterm 248
|
|
64
|
+
'#a8a8a8', // xterm 248
|
|
65
|
+
'#949494', // xterm 246
|
|
66
|
+
'#949494', // xterm 246
|
|
67
|
+
'#808080', // xterm 244
|
|
68
|
+
'#808080', // xterm 244
|
|
69
|
+
'#6c6c6c', // xterm 242
|
|
70
|
+
'#6c6c6c', // xterm 242
|
|
71
|
+
'#585858', // xterm 240
|
|
72
|
+
'#585858', // xterm 240
|
|
73
|
+
]
|
|
74
|
+
|
|
75
|
+
const waveWidth = waveColors.length
|
|
76
|
+
|
|
77
|
+
useEffect(() => {
|
|
78
|
+
if (isLoading) {
|
|
79
|
+
intervalRef.current = setInterval(() => {
|
|
80
|
+
setPosition((prev) => (prev + 1) % (characters.length + waveWidth))
|
|
81
|
+
}, 10)
|
|
82
|
+
} else {
|
|
83
|
+
if (intervalRef.current) {
|
|
84
|
+
clearInterval(intervalRef.current)
|
|
85
|
+
intervalRef.current = null
|
|
86
|
+
}
|
|
87
|
+
setPosition(0)
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
return () => {
|
|
91
|
+
if (intervalRef.current) {
|
|
92
|
+
clearInterval(intervalRef.current)
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}, [isLoading, characters.length, waveWidth])
|
|
96
|
+
|
|
97
|
+
// Calculate color for each character
|
|
98
|
+
const getCharacterColor = (index: number): string => {
|
|
99
|
+
if (!isLoading) {
|
|
100
|
+
// When not loading, use default theme colors
|
|
101
|
+
return index < title.length ? Theme.text : '#626262'
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// Title text stays static when loading, only animate the bar
|
|
105
|
+
if (index < title.length) {
|
|
106
|
+
return Theme.textMuted // Keep title text muted during loading
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
// Only animate the bar part
|
|
110
|
+
const barIndex = index - title.length - 1 // Adjust for space after title
|
|
111
|
+
const distance = position - barIndex
|
|
112
|
+
|
|
113
|
+
// If character is within the wave (behind the current position)
|
|
114
|
+
if (distance >= 0 && distance < waveWidth) {
|
|
115
|
+
return waveColors[distance]
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// Default muted color for characters outside the wave (xterm 241)
|
|
119
|
+
return '#626262'
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
return (
|
|
123
|
+
<box
|
|
124
|
+
ref={(el) => {
|
|
125
|
+
containerRef.current = el
|
|
126
|
+
}}
|
|
127
|
+
style={{
|
|
128
|
+
flexDirection: 'row',
|
|
129
|
+
flexGrow: 1,
|
|
130
|
+
paddingLeft: 1,
|
|
131
|
+
paddingRight: 1,
|
|
132
|
+
}}
|
|
133
|
+
>
|
|
134
|
+
{characters.map((char, index) => (
|
|
135
|
+
<text key={index} fg={getCharacterColor(index)}>
|
|
136
|
+
{char}
|
|
137
|
+
</text>
|
|
138
|
+
))}
|
|
139
|
+
</box>
|
|
140
|
+
)
|
|
141
|
+
}
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MenuBarExtra Component - Creates menu bar extensions for macOS
|
|
3
|
+
*
|
|
4
|
+
* Raycast Docs: https://developers.raycast.com/api-reference/menu-bar-commands
|
|
5
|
+
*
|
|
6
|
+
* MenuBarExtra allows you to create persistent menu bar items in macOS that can
|
|
7
|
+
* display information and provide quick actions without opening the main Raycast window.
|
|
8
|
+
*
|
|
9
|
+
* Key features:
|
|
10
|
+
* - Display text/icons in the menu bar
|
|
11
|
+
* - Show dropdown menus with items, sections, and submenus
|
|
12
|
+
* - Handle user interactions via onAction callbacks
|
|
13
|
+
* - Support for keyboard shortcuts
|
|
14
|
+
* - Loading states and tooltips
|
|
15
|
+
*
|
|
16
|
+
* Components:
|
|
17
|
+
* - MenuBarExtra: Root component for menu bar extensions
|
|
18
|
+
* - MenuBarExtra.Item: Individual menu items with optional actions
|
|
19
|
+
* - MenuBarExtra.Section: Group related items with optional title
|
|
20
|
+
* - MenuBarExtra.Submenu: Nested menu for organizing items hierarchically
|
|
21
|
+
* - MenuBarExtra.Separator: Visual separator between items
|
|
22
|
+
*/
|
|
23
|
+
|
|
24
|
+
import React, { ReactNode } from 'react'
|
|
25
|
+
import { Image, ImageLike } from 'termcast/src/components/image'
|
|
26
|
+
import { logger } from 'termcast/src/logger'
|
|
27
|
+
|
|
28
|
+
export interface MenuBarExtraProps {
|
|
29
|
+
isLoading?: boolean
|
|
30
|
+
title?: string
|
|
31
|
+
tooltip?: string
|
|
32
|
+
icon?: ImageLike
|
|
33
|
+
children?: ReactNode
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
export interface MenuBarExtraItemProps {
|
|
37
|
+
title: string
|
|
38
|
+
subtitle?: string
|
|
39
|
+
icon?: ImageLike
|
|
40
|
+
tooltip?: string
|
|
41
|
+
shortcut?: { modifiers: string[]; key: string }
|
|
42
|
+
onAction?: (event?: MenuBarExtraActionEvent) => void
|
|
43
|
+
disabled?: boolean
|
|
44
|
+
children?: ReactNode
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
export interface MenuBarExtraSeparatorProps {}
|
|
48
|
+
|
|
49
|
+
export interface MenuBarExtraSubmenuProps {
|
|
50
|
+
title: string
|
|
51
|
+
icon?: ImageLike
|
|
52
|
+
children?: ReactNode
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export interface MenuBarExtraSectionProps {
|
|
56
|
+
title?: string
|
|
57
|
+
children?: ReactNode
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
export interface MenuBarExtraActionEvent {
|
|
61
|
+
type: 'left-click' | 'right-click'
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
interface MenuBarExtraType {
|
|
65
|
+
(props: MenuBarExtraProps): any
|
|
66
|
+
Item: (props: MenuBarExtraItemProps) => any
|
|
67
|
+
Separator: (props: MenuBarExtraSeparatorProps) => any
|
|
68
|
+
Submenu: (props: MenuBarExtraSubmenuProps) => any
|
|
69
|
+
Section: (props: MenuBarExtraSectionProps) => any
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const MenuBarExtra: MenuBarExtraType = ({
|
|
73
|
+
isLoading,
|
|
74
|
+
title,
|
|
75
|
+
tooltip,
|
|
76
|
+
icon,
|
|
77
|
+
children,
|
|
78
|
+
}) => {
|
|
79
|
+
logger.log('MenuBarExtra rendered', { isLoading, title, tooltip })
|
|
80
|
+
|
|
81
|
+
// TODO: Implement actual menu bar integration
|
|
82
|
+
// This component should:
|
|
83
|
+
// 1. Create a real macOS menu bar item
|
|
84
|
+
// 2. Handle menu dropdown display/hide
|
|
85
|
+
// 3. Position the menu correctly below the menu bar icon
|
|
86
|
+
// Currently just renders content in the terminal
|
|
87
|
+
|
|
88
|
+
return (
|
|
89
|
+
<box>
|
|
90
|
+
{title && (
|
|
91
|
+
<box>
|
|
92
|
+
{icon &&
|
|
93
|
+
(typeof icon === 'string' ? (
|
|
94
|
+
<text>{icon}</text>
|
|
95
|
+
) : (
|
|
96
|
+
<Image source={icon} />
|
|
97
|
+
))}
|
|
98
|
+
<text>{title}</text>
|
|
99
|
+
</box>
|
|
100
|
+
)}
|
|
101
|
+
{tooltip && <text>{tooltip}</text>}
|
|
102
|
+
{children}
|
|
103
|
+
</box>
|
|
104
|
+
)
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
MenuBarExtra.Item = ({
|
|
108
|
+
title,
|
|
109
|
+
subtitle,
|
|
110
|
+
icon,
|
|
111
|
+
tooltip,
|
|
112
|
+
shortcut,
|
|
113
|
+
onAction,
|
|
114
|
+
disabled,
|
|
115
|
+
children,
|
|
116
|
+
}) => {
|
|
117
|
+
// TODO: Implement real click/keyboard handling for menu items
|
|
118
|
+
// OpenTUI doesn't support onClick on box elements yet
|
|
119
|
+
// This should handle:
|
|
120
|
+
// 1. Mouse clicks on the menu item
|
|
121
|
+
// 2. Keyboard navigation and selection (Enter key)
|
|
122
|
+
// 3. Keyboard shortcuts defined in shortcut prop
|
|
123
|
+
if (onAction) {
|
|
124
|
+
logger.log('MenuBarExtra.Item would handle action', { title })
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
return (
|
|
128
|
+
<box>
|
|
129
|
+
<box>
|
|
130
|
+
{icon &&
|
|
131
|
+
(typeof icon === 'string' ? (
|
|
132
|
+
<text>{icon}</text>
|
|
133
|
+
) : (
|
|
134
|
+
<Image source={icon} />
|
|
135
|
+
))}
|
|
136
|
+
<text>{disabled ? `[${title}]` : title}</text>
|
|
137
|
+
{subtitle && <text> {subtitle}</text>}
|
|
138
|
+
</box>
|
|
139
|
+
{shortcut && (
|
|
140
|
+
<text>
|
|
141
|
+
{shortcut.modifiers.join('')}
|
|
142
|
+
{shortcut.key}
|
|
143
|
+
</text>
|
|
144
|
+
)}
|
|
145
|
+
{children}
|
|
146
|
+
</box>
|
|
147
|
+
)
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
MenuBarExtra.Separator = () => {
|
|
151
|
+
return <text>─────────────────</text>
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
MenuBarExtra.Submenu = ({ title, icon, children }) => {
|
|
155
|
+
return (
|
|
156
|
+
<box>
|
|
157
|
+
<box>
|
|
158
|
+
{icon &&
|
|
159
|
+
(typeof icon === 'string' ? (
|
|
160
|
+
<text>{icon}</text>
|
|
161
|
+
) : (
|
|
162
|
+
<Image source={icon} />
|
|
163
|
+
))}
|
|
164
|
+
<text>{title} ▶</text>
|
|
165
|
+
</box>
|
|
166
|
+
{children && <box>{children}</box>}
|
|
167
|
+
</box>
|
|
168
|
+
)
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
MenuBarExtra.Section = ({ title, children }) => {
|
|
172
|
+
return (
|
|
173
|
+
<box>
|
|
174
|
+
{title && <text>{title}</text>}
|
|
175
|
+
{children}
|
|
176
|
+
<MenuBarExtra.Separator />
|
|
177
|
+
</box>
|
|
178
|
+
)
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
export { MenuBarExtra }
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
// inspired by https://github.com/pacocoursey/use-descendants
|
|
2
|
+
//
|
|
3
|
+
import * as React from 'react'
|
|
4
|
+
|
|
5
|
+
type DescendantMap<T> = { [id: string]: { index: number; props?: T } }
|
|
6
|
+
|
|
7
|
+
export interface DescendantContextType<T> {
|
|
8
|
+
getIndexForId: (id: string, props?: T) => number
|
|
9
|
+
// IMPORTANT! map is not reactive, it cannot be used in render, only in useEffect or useLayoutEffect or other event handlers like useKeyboard
|
|
10
|
+
map: React.RefObject<DescendantMap<T>>
|
|
11
|
+
reset: () => void
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const randomId = () => Math.random().toString(36).slice(2, 11)
|
|
15
|
+
|
|
16
|
+
export function createDescendants<T = any>() {
|
|
17
|
+
const DescendantContext = React.createContext<
|
|
18
|
+
DescendantContextType<T> | undefined
|
|
19
|
+
>(undefined)
|
|
20
|
+
|
|
21
|
+
function DescendantsProvider(props: {
|
|
22
|
+
value: DescendantContextType<T>
|
|
23
|
+
children: React.ReactNode
|
|
24
|
+
}) {
|
|
25
|
+
// On every re-render of children, reset the count
|
|
26
|
+
props.value.reset()
|
|
27
|
+
|
|
28
|
+
return (
|
|
29
|
+
<DescendantContext.Provider value={props.value}>
|
|
30
|
+
{props.children}
|
|
31
|
+
</DescendantContext.Provider>
|
|
32
|
+
)
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const useDescendants = (): DescendantContextType<T> => {
|
|
36
|
+
const indexCounter = React.useRef<number>(0)
|
|
37
|
+
const map = React.useRef<DescendantMap<T>>({})
|
|
38
|
+
|
|
39
|
+
const reset = () => {
|
|
40
|
+
indexCounter.current = 0
|
|
41
|
+
map.current = {}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
const getIndexForId = (id: string, props?: T) => {
|
|
45
|
+
if (!map.current[id])
|
|
46
|
+
map.current[id] = {
|
|
47
|
+
index: indexCounter.current++,
|
|
48
|
+
}
|
|
49
|
+
map.current[id].props = props
|
|
50
|
+
return map.current[id].index
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// React.useEffect(() => {
|
|
54
|
+
// return () => {
|
|
55
|
+
// reset()
|
|
56
|
+
// }
|
|
57
|
+
// }, [])
|
|
58
|
+
|
|
59
|
+
// Do NOT memoize context value, so that we bypass React.memo on any children
|
|
60
|
+
// We NEED them to re-render, in case stable children were re-ordered
|
|
61
|
+
// (this creates a new object every render, so children reading the context MUST re-render)
|
|
62
|
+
return { getIndexForId, map, reset }
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* Return index of the current item within its parent's list
|
|
67
|
+
*/
|
|
68
|
+
function useDescendant(props?: T) {
|
|
69
|
+
const context = React.useContext(DescendantContext)
|
|
70
|
+
const [descendantId] = React.useState<string>(() => randomId())
|
|
71
|
+
const [index, setIndex] = React.useState<number>(-1)
|
|
72
|
+
|
|
73
|
+
React.useLayoutEffect(() => {
|
|
74
|
+
// Do this inside of useLayoutEffect, it's only
|
|
75
|
+
// called for the "real render" in React strict mode
|
|
76
|
+
setIndex(context?.getIndexForId(descendantId, props) ?? -1)
|
|
77
|
+
})
|
|
78
|
+
|
|
79
|
+
return { descendantId, index }
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
return { DescendantsProvider, useDescendants, useDescendant }
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// EXAMPLE
|
|
86
|
+
const { DescendantsProvider, useDescendants, useDescendant } =
|
|
87
|
+
createDescendants<{
|
|
88
|
+
title?: string
|
|
89
|
+
}>()
|
|
90
|
+
|
|
91
|
+
const FilteredIndexesContext = React.createContext<number[]>([])
|
|
92
|
+
|
|
93
|
+
const MenuExample = () => {
|
|
94
|
+
const context = useDescendants()
|
|
95
|
+
const [search, setSearchRaw] = React.useState('')
|
|
96
|
+
const [filteredIndexes, setFilteredIndexes] = React.useState<number[]>([])
|
|
97
|
+
|
|
98
|
+
// Filtering logic is now in this wrapper
|
|
99
|
+
const setSearch = (value: string) => {
|
|
100
|
+
setSearchRaw(value)
|
|
101
|
+
const items = Object.entries(context.map.current)
|
|
102
|
+
const filtered = items
|
|
103
|
+
.filter(([, item]) =>
|
|
104
|
+
item.props?.title?.toLowerCase().includes(value.toLowerCase()),
|
|
105
|
+
)
|
|
106
|
+
.map(([, item]) => item.index)
|
|
107
|
+
setFilteredIndexes(filtered)
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
return (
|
|
111
|
+
<DescendantsProvider value={context}>
|
|
112
|
+
<FilteredIndexesContext.Provider value={filteredIndexes}>
|
|
113
|
+
<box>
|
|
114
|
+
<input value={search} onInput={setSearch} placeholder='Search...' />
|
|
115
|
+
<Item title='First Item' />
|
|
116
|
+
<Item title='Second Item' />
|
|
117
|
+
<Item title='Third Item' />
|
|
118
|
+
</box>
|
|
119
|
+
</FilteredIndexesContext.Provider>
|
|
120
|
+
</DescendantsProvider>
|
|
121
|
+
)
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
const Item = ({ title }: { title: string }) => {
|
|
125
|
+
const { index } = useDescendant({ title })
|
|
126
|
+
const filteredIndexes = React.useContext(FilteredIndexesContext)
|
|
127
|
+
|
|
128
|
+
// If index is not in filteredIndexes, don't render
|
|
129
|
+
if (!filteredIndexes.includes(index)) {
|
|
130
|
+
return null
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
return <text>{title}</text>
|
|
134
|
+
}
|