Files
supabase/apps/studio/components/interfaces/Storage/BucketFilePickerDialog/BucketFilePickerExplorer.tsx
Ivan Vasilov 35905e70d5 feat: Add a logo picker for OAuth app creation sheet (#44995)
<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
## Summary by CodeRabbit

* **New Features**
* Logo field now accepts/editable logo URL, plus a new storage-based
Logo Picker to select or remove images from project storage.
* Full storage picker: browse buckets, columns/list views, search,
drag‑and‑drop uploads, file previews (image/audio/video), and
single-file selection with responsive mobile/desktop layouts.

* **Refactor**
* Logo submission streamlined to send the provided URL directly (legacy
file-read/upload flow removed).
<!-- end of auto-generated comment: release notes by coderabbit.ai -->
2026-05-06 16:44:18 +02:00

46 lines
1.7 KiB
TypeScript

import { useParams } from 'common'
import { cn } from 'ui'
import { STORAGE_VIEWS } from '../Storage.constants'
import { useStoragePreference } from '../StorageExplorer/useStoragePreference'
import { BucketFilePickerColumn } from './BucketFilePickerColumn'
import { BucketFilePickerHeader } from './BucketFilePickerHeader'
import { BucketFilePickerHeaderSelection } from './BucketFilePickerHeaderSelection'
import { PreviewPane } from './BucketFilePickerPreviewPane'
import { useBucketFilePickerStateSnapshot } from './BucketFilePickerState'
export function BucketFilePickerExplorer({ onSelect }: { onSelect: (value: string) => void }) {
const { ref: projectRef } = useParams()
const { view } = useStoragePreference(projectRef!)
const { selectedItems, columns } = useBucketFilePickerStateSnapshot()
return (
<div className="flex-1 min-h-0">
<div className="bg-studio border rounded-md border-overlay flex h-full w-full flex-col">
{selectedItems.length === 0 ? (
<BucketFilePickerHeader />
) : (
<BucketFilePickerHeaderSelection />
)}
<div className="flex flex-1 min-h-0">
<div
className={cn(
'file-explorer flex grow overflow-x-auto justify-between h-full w-full relative',
view === STORAGE_VIEWS.LIST && 'flex-col'
)}
>
{view === STORAGE_VIEWS.COLUMNS ? (
<div className="flex">
<BucketFilePickerColumn index={0} />
</div>
) : (
<BucketFilePickerColumn fullWidth index={columns.length} />
)}
</div>
<PreviewPane onSelect={onSelect} />
</div>
</div>
</div>
)
}