Skip to content
This repository has been archived by the owner on Jan 2, 2025. It is now read-only.

Commit

Permalink
Spinner for async work in launcher
Browse files Browse the repository at this point in the history
  • Loading branch information
ericvicenti committed Feb 27, 2024
1 parent e7f4a4f commit a6c77a6
Showing 1 changed file with 48 additions and 36 deletions.
84 changes: 48 additions & 36 deletions frontend/packages/app/components/launcher.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import {
Input,
ScrollView,
SizableText,
Spinner,
XStack,
YStack,
toast,
Expand Down Expand Up @@ -240,6 +241,52 @@ function LauncherContent({onClose}: {input: {}; onClose: () => void}) {
window.removeEventListener('keydown', keyPressHandler)
}
}, [])
let content = (
<ScrollView maxHeight={600}>
<YStack gap="$2" marginVertical="$2">
{isDisplayingRecents ? (
<SizableText marginTop="$2" marginHorizontal="$4" color="$color10">
Recent Resources
</SizableText>
) : null}
{activeItems?.map((item, itemIndex) => {
return (
<Button
key={item.key}
onPress={item.onSelect}
backgroundColor={
focusedIndex === itemIndex ? '$blue4' : undefined
}
hoverStyle={{
backgroundColor:
focusedIndex === itemIndex ? '$blue4' : undefined,
}}
onFocus={() => {
setFocusedIndex(itemIndex)
}}
onMouseEnter={() => {
setFocusedIndex(itemIndex)
}}
>
<XStack f={1} justifyContent="space-between">
<SizableText numberOfLines={1}>{item.title}</SizableText>

<SizableText color="$color10">{item.subtitle}</SizableText>
</XStack>
</Button>
)
})}
</YStack>
</ScrollView>
)

if (actionPromise) {
content = (
<YStack marginVertical="$4">
<Spinner />
</YStack>
)
}
return (
<YStack>
<Input
Expand Down Expand Up @@ -268,42 +315,7 @@ function LauncherContent({onClose}: {input: {}; onClose: () => void}) {
}
}}
/>
<ScrollView maxHeight={600}>
<YStack gap="$2" marginVertical="$2">
{isDisplayingRecents ? (
<SizableText marginTop="$2" marginHorizontal="$4" color="$color10">
Recent Resources
</SizableText>
) : null}
{activeItems?.map((item, itemIndex) => {
return (
<Button
key={item.key}
onPress={item.onSelect}
backgroundColor={
focusedIndex === itemIndex ? '$blue4' : undefined
}
hoverStyle={{
backgroundColor:
focusedIndex === itemIndex ? '$blue4' : undefined,
}}
onFocus={() => {
setFocusedIndex(itemIndex)
}}
onMouseEnter={() => {
setFocusedIndex(itemIndex)
}}
>
<XStack f={1} justifyContent="space-between">
<SizableText numberOfLines={1}>{item.title}</SizableText>

<SizableText color="$color10">{item.subtitle}</SizableText>
</XStack>
</Button>
)
})}
</YStack>
</ScrollView>
{content}
</YStack>
)
}
Expand Down

0 comments on commit a6c77a6

Please sign in to comment.