diff --git a/packages/app/src/components/prompt-input.tsx b/packages/app/src/components/prompt-input.tsx index b6c4d3c85..86e6c1870 100644 --- a/packages/app/src/components/prompt-input.tsx +++ b/packages/app/src/components/prompt-input.tsx @@ -39,7 +39,7 @@ import type { IconName } from "@opencode-ai/ui/icons/provider" import { Tooltip, TooltipKeybind } from "@opencode-ai/ui/tooltip" import { IconButton } from "@opencode-ai/ui/icon-button" import { Select } from "@opencode-ai/ui/select" -import { getDirectory, getFilename } from "@opencode-ai/util/path" +import { getDirectory, getFilename, getFilenameTruncated } from "@opencode-ai/util/path" import { useDialog } from "@opencode-ai/ui/context/dialog" import { ImagePreview } from "@opencode-ai/ui/image-preview" import { ModelSelectorPopover } from "@/components/dialog-select-model" @@ -1691,18 +1691,13 @@ export const PromptInput: Component = (props) => { tabs().open("review") }} > -
+
- - - {getDirectory(item.path)} - {getFilename(item.path)} - - + {getFilenameTruncated(item.path, 18)} {(sel) => ( diff --git a/packages/util/src/path.ts b/packages/util/src/path.ts index 1ac106f21..8f4f3304a 100644 --- a/packages/util/src/path.ts +++ b/packages/util/src/path.ts @@ -17,3 +17,16 @@ export function getFileExtension(path: string | undefined) { const parts = path.split(".") return parts[parts.length - 1] } + +export function getFilenameTruncated(path: string | undefined, maxLength: number = 20) { + const filename = getFilename(path) + if (filename.length <= maxLength) return filename + const lastDot = filename.lastIndexOf(".") + const name = lastDot <= 0 ? filename : filename.slice(0, lastDot) + const ext = lastDot <= 0 ? "" : filename.slice(lastDot) + const available = maxLength - ext.length - 1 // -1 for ellipsis + if (available <= 0) return filename.slice(0, maxLength - 1) + "…" + const start = Math.ceil(available / 2) + const end = Math.floor(available / 2) + return name.slice(0, start) + "…" + name.slice(-end) + ext +}