Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Popup settings dialog when no env vars set #1033

Merged
merged 1 commit into from
Oct 14, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 22 additions & 6 deletions typescript/playground-common/src/shared/SettingsDialog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -112,12 +112,19 @@ const requiredButUnsetAtom = atom((get) => {
)
})

const requiredAndSetCountAtom = atom((get) => {
const envvars = get(envvarsAtom)
return get(runtimeRequiredEnvVarsAtom).filter((k) =>
envvars.some(({ key, value }) => k === key && value && value.length > 0),
).length
})

type EnvVar = { key: string; value: string; type: 'baml' | 'tracing' | 'user' | 'config'; index: number | null }
const EnvvarInput: React.FC<{ envvar: EnvVar }> = ({ envvar }) => {
const [showEnvvarValues] = useAtom(showEnvvarValuesAtom)
const setEnvKeyValue = useSetAtom(envKeyValuesAtom)
return (
<div className='flex flex-row items-center gap-2 my-2'>
<div className='flex flex-row gap-2 items-center my-2'>
<Input
type='text'
value={envvar.key}
Expand Down Expand Up @@ -173,20 +180,28 @@ const EnvvarInput: React.FC<{ envvar: EnvVar }> = ({ envvar }) => {
export const ShowSettingsButton: React.FC<{ iconClassName: string }> = ({ iconClassName }) => {
const setShowSettings = useSetAtom(showSettingsAtom)
const requiredButUnset = useAtomValue(requiredButUnsetAtom)
const requiredAndSetCount = useAtomValue(requiredAndSetCountAtom)
const requiredButUnsetCount = requiredButUnset.length
if ((window as any).next?.version) {
// dont run in nextjs
return null
}

useEffect(() => {
if (requiredAndSetCount === 0) {
// no env vars have been set at all pop up the dialog
setShowSettings(true)
}
}, [requiredAndSetCount])

const button = (
<Button
className='relative px-2 py-1 bg-transparent h-fit text-vscode-editor-foreground hover:text-vscode-button-foreground hover:bg-vscode-button-hoverBackground'
onClick={() => setShowSettings(true)}
>
<SettingsIcon className='w-4' /> Env Vars
{requiredButUnsetCount > 0 && (
<div className='absolute inline-flex items-center justify-center w-6 h-6 text-xs font-bold text-white bg-yellow-500 border-2 border-white rounded-full -top-2 -end-3 dark:border-gray-900'>
<div className='inline-flex absolute -top-2 justify-center items-center w-6 h-6 text-xs font-bold text-white bg-yellow-500 rounded-full border-2 border-white -end-3 dark:border-gray-900'>
{requiredButUnsetCount}
</div>
)}
Expand Down Expand Up @@ -223,12 +238,12 @@ export const SettingsDialog: React.FC = () => {
return (
<Dialog open={showSettings} onOpenChange={setShowSettings}>
<DialogContent className=' min-h-[550px] max-h-[550px] overflow-y-auto bg-vscode-editorWidget-background flex flex-col border-vscode-textSeparator-foreground overflow-x-clip'>
<DialogHeader className='flex flex-row items-end gap-x-4'>
<DialogHeader className='flex flex-row gap-x-4 items-end'>
<DialogTitle className='font-semibold'>Environment variables</DialogTitle>
<Button
variant='ghost'
size='icon'
className='flex flex-row items-center p-1 py-0 text-xs w-fit h-fit gap-x-2 hover:bg-vscode-descriptionForeground'
className='flex flex-row gap-x-2 items-center p-1 py-0 text-xs w-fit h-fit hover:bg-vscode-descriptionForeground'
onClick={() => setShowEnvvarValues((prev) => !prev)}
>
{showEnvvarValues ? <ShowIcon className='h-4' /> : <HideIcon className='h-4' />}
Expand Down Expand Up @@ -263,7 +278,8 @@ export const SettingsDialog: React.FC = () => {
<div className='flex flex-col gap-1'>
<span className='text-sm text-vscode-foreground'>From .baml files</span>
<p className='text-xs italic text-vscode-descriptionForeground'>
Environment variables are loaded lazily, only set any you want to use.
Environment variables are loaded lazily, only set any you want to use. They are stored locally in your
machine.
</p>
{envvars
.filter((t) => t.type === 'baml')
Expand All @@ -281,7 +297,7 @@ export const SettingsDialog: React.FC = () => {
<Button
variant='ghost'
size='icon'
className='flex flex-row items-center p-1 text-xs w-fit h-fit gap-x-2 hover:bg-vscode-descriptionForeground'
className='flex flex-row gap-x-2 items-center p-1 text-xs w-fit h-fit hover:bg-vscode-descriptionForeground'
onClick={() => setEnvKeyValue({ itemIndex: null, key: 'NEW_ENV_VAR' })}
>
<PlusIcon size={14} /> <div>Add item</div>
Expand Down
Loading