hermes-agent/ui-tui/src/components/maskedPrompt.tsx
2026-04-03 20:14:57 -05:00

35 lines
712 B
TypeScript

import { Box, Text } from 'ink'
import TextInput from 'ink-text-input'
import { useState } from 'react'
import type { Theme } from '../theme.js'
export function MaskedPrompt({
icon,
label,
onSubmit,
sub,
t
}: {
icon: string
label: string
onSubmit: (v: string) => void
sub?: string
t: Theme
}) {
const [value, setValue] = useState('')
return (
<Box flexDirection="column">
<Text bold color={t.color.warn}>
{icon} {label}
</Text>
{sub && <Text color={t.color.dim}> {sub}</Text>}
<Box>
<Text color={t.color.label}>{'> '}</Text>
<TextInput mask="*" onChange={setValue} onSubmit={onSubmit} value={value} />
</Box>
</Box>
)
}