mirror of
https://gitea.toothfairyai.com/ToothFairyAI/tf_code.git
synced 2026-04-09 18:29:39 +00:00
73 lines
2.7 KiB
TypeScript
73 lines
2.7 KiB
TypeScript
import { Portal } from "solid-js/web"
|
|
import { useI18n } from "../context/i18n"
|
|
import { Icon } from "./icon"
|
|
|
|
export function FileSearchBar(props: {
|
|
pos: () => { top: number; right: number }
|
|
query: () => string
|
|
index: () => number
|
|
count: () => number
|
|
setInput: (el: HTMLInputElement) => void
|
|
onInput: (value: string) => void
|
|
onKeyDown: (event: KeyboardEvent) => void
|
|
onClose: () => void
|
|
onPrev: () => void
|
|
onNext: () => void
|
|
}) {
|
|
const i18n = useI18n()
|
|
|
|
return (
|
|
<Portal>
|
|
<div
|
|
class="fixed z-50 flex h-8 items-center gap-2 rounded-md border border-border-base bg-background-base px-3 shadow-md"
|
|
style={{
|
|
top: `${props.pos().top}px`,
|
|
right: `${props.pos().right}px`,
|
|
}}
|
|
onPointerDown={(e) => e.stopPropagation()}
|
|
>
|
|
<Icon name="magnifying-glass" size="small" class="text-text-weak shrink-0" />
|
|
<input
|
|
ref={props.setInput}
|
|
placeholder={i18n.t("ui.fileSearch.placeholder")}
|
|
value={props.query()}
|
|
class="w-40 bg-transparent outline-none text-14-regular text-text-strong placeholder:text-text-weak"
|
|
onInput={(e) => props.onInput(e.currentTarget.value)}
|
|
onKeyDown={(e) => props.onKeyDown(e as KeyboardEvent)}
|
|
/>
|
|
<div class="shrink-0 text-12-regular text-text-weak tabular-nums text-right" style={{ width: "10ch" }}>
|
|
{props.count() ? `${props.index() + 1}/${props.count()}` : "0/0"}
|
|
</div>
|
|
<div class="flex items-center">
|
|
<button
|
|
type="button"
|
|
class="size-6 grid place-items-center rounded text-text-weak hover:bg-surface-base-hover hover:text-text-strong disabled:opacity-40 disabled:pointer-events-none"
|
|
disabled={props.count() === 0}
|
|
aria-label={i18n.t("ui.fileSearch.previousMatch")}
|
|
onClick={props.onPrev}
|
|
>
|
|
<Icon name="chevron-down" size="small" class="rotate-180" />
|
|
</button>
|
|
<button
|
|
type="button"
|
|
class="size-6 grid place-items-center rounded text-text-weak hover:bg-surface-base-hover hover:text-text-strong disabled:opacity-40 disabled:pointer-events-none"
|
|
disabled={props.count() === 0}
|
|
aria-label={i18n.t("ui.fileSearch.nextMatch")}
|
|
onClick={props.onNext}
|
|
>
|
|
<Icon name="chevron-down" size="small" />
|
|
</button>
|
|
</div>
|
|
<button
|
|
type="button"
|
|
class="size-6 grid place-items-center rounded text-text-weak hover:bg-surface-base-hover hover:text-text-strong"
|
|
aria-label={i18n.t("ui.fileSearch.close")}
|
|
onClick={props.onClose}
|
|
>
|
|
<Icon name="close-small" size="small" />
|
|
</button>
|
|
</div>
|
|
</Portal>
|
|
)
|
|
}
|