mirror of
https://github.com/pacnpal/thrilltrack-explorer.git
synced 2025-12-23 08:51:13 -05:00
Fix: Make photo management modal responsive on mobile
This commit is contained in:
@@ -36,7 +36,7 @@ const DialogContent = React.forwardRef<
|
|||||||
<DialogPrimitive.Content
|
<DialogPrimitive.Content
|
||||||
ref={ref}
|
ref={ref}
|
||||||
className={cn(
|
className={cn(
|
||||||
"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",
|
"fixed left-[50%] top-[50%] z-50 grid w-full max-w-[100vw] max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg",
|
||||||
className,
|
className,
|
||||||
)}
|
)}
|
||||||
{...props}
|
{...props}
|
||||||
|
|||||||
@@ -220,7 +220,7 @@ export function PhotoManagementDialog({
|
|||||||
if (editingPhoto) {
|
if (editingPhoto) {
|
||||||
return (
|
return (
|
||||||
<Dialog open={open} onOpenChange={onOpenChange}>
|
<Dialog open={open} onOpenChange={onOpenChange}>
|
||||||
<DialogContent className="max-w-2xl">
|
<DialogContent className="max-w-[95vw] sm:max-w-2xl">
|
||||||
<DialogHeader>
|
<DialogHeader>
|
||||||
<DialogTitle>Edit Photo</DialogTitle>
|
<DialogTitle>Edit Photo</DialogTitle>
|
||||||
<DialogDescription>Update photo details</DialogDescription>
|
<DialogDescription>Update photo details</DialogDescription>
|
||||||
@@ -274,7 +274,7 @@ export function PhotoManagementDialog({
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<Dialog open={open} onOpenChange={onOpenChange}>
|
<Dialog open={open} onOpenChange={onOpenChange}>
|
||||||
<DialogContent className="max-w-4xl max-h-[80vh] overflow-y-auto">
|
<DialogContent className="max-w-[95vw] sm:max-w-2xl lg:max-w-4xl max-h-[80vh] overflow-y-auto p-3 sm:p-6">
|
||||||
<DialogHeader>
|
<DialogHeader>
|
||||||
<DialogTitle>Manage Photos</DialogTitle>
|
<DialogTitle>Manage Photos</DialogTitle>
|
||||||
<DialogDescription>
|
<DialogDescription>
|
||||||
@@ -294,9 +294,9 @@ export function PhotoManagementDialog({
|
|||||||
<div className="space-y-4">
|
<div className="space-y-4">
|
||||||
{photos.map((photo, index) => (
|
{photos.map((photo, index) => (
|
||||||
<Card key={photo.id}>
|
<Card key={photo.id}>
|
||||||
<CardContent className="p-4">
|
<CardContent className="p-2 sm:p-4">
|
||||||
<div className="flex gap-4">
|
<div className="flex gap-2 sm:gap-4">
|
||||||
<div className="w-32 h-32 flex-shrink-0 overflow-hidden rounded-lg">
|
<div className="w-20 h-20 sm:w-32 sm:h-32 flex-shrink-0 overflow-hidden rounded-lg">
|
||||||
<img
|
<img
|
||||||
src={photo.cloudflare_image_url}
|
src={photo.cloudflare_image_url}
|
||||||
alt={photo.title || 'Photo'}
|
alt={photo.title || 'Photo'}
|
||||||
@@ -307,23 +307,23 @@ export function PhotoManagementDialog({
|
|||||||
<div className="flex-1 space-y-2">
|
<div className="flex-1 space-y-2">
|
||||||
<div className="flex items-start justify-between">
|
<div className="flex items-start justify-between">
|
||||||
<div>
|
<div>
|
||||||
<h4 className="font-semibold">
|
<h4 className="font-semibold text-sm sm:text-base">
|
||||||
{photo.title || 'Untitled'}
|
{photo.title || 'Untitled'}
|
||||||
</h4>
|
</h4>
|
||||||
{photo.caption && (
|
{photo.caption && (
|
||||||
<p className="text-sm text-muted-foreground">
|
<p className="text-xs sm:text-sm text-muted-foreground">
|
||||||
{photo.caption}
|
{photo.caption}
|
||||||
</p>
|
</p>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
{photo.is_featured && (
|
{photo.is_featured && (
|
||||||
<span className="text-xs bg-primary text-primary-foreground px-2 py-1 rounded">
|
<span className="text-[10px] sm:text-xs bg-primary text-primary-foreground px-2 py-1 rounded">
|
||||||
Featured
|
Featured
|
||||||
</span>
|
</span>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="flex items-center gap-2">
|
<div className="flex items-center flex-wrap gap-1 sm:gap-2">
|
||||||
<Button
|
<Button
|
||||||
size="sm"
|
size="sm"
|
||||||
variant="outline"
|
variant="outline"
|
||||||
|
|||||||
Reference in New Issue
Block a user