All checks were successful
Deploy to Production / Build and Deploy (push) Successful in 44s
- Add image description service + API route for AI-powered image analysis - Image title generation returns 3 selectable suggestions via TitleSuggestions component - Add "Describe images" action in AI assistant (individual + collective) - Fix pin refresh propagation in card and tabs view - Fix note creation refresh in tabs mode, pass all notes to tabs view - Add RTL support (dir="auto") on note content elements - Pass UI language dynamically to AI endpoints instead of hardcoded 'fr' - Add 18 missing i18n keys in both en.json and fr.json - Sparkles button on images for AI title generation (bottom-right, pulse animation) Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
73 lines
1.8 KiB
TypeScript
73 lines
1.8 KiB
TypeScript
'use client'
|
|
|
|
import dynamic from 'next/dynamic'
|
|
import { Note } from '@/lib/types'
|
|
import { NotesTabsView } from '@/components/notes-tabs-view'
|
|
|
|
const MasonryGridLazy = dynamic(
|
|
() => import('@/components/masonry-grid').then((m) => m.MasonryGrid),
|
|
{
|
|
ssr: false,
|
|
loading: () => (
|
|
<div
|
|
className="min-h-[200px] rounded-xl border border-dashed border-muted-foreground/20 bg-muted/30 animate-pulse"
|
|
aria-hidden
|
|
/>
|
|
),
|
|
}
|
|
)
|
|
|
|
export type NotesViewMode = 'masonry' | 'tabs'
|
|
|
|
interface NotesMainSectionProps {
|
|
notes: Note[]
|
|
viewMode: NotesViewMode
|
|
onEdit?: (note: Note, readOnly?: boolean) => void
|
|
onSizeChange?: (noteId: string, size: 'small' | 'medium' | 'large') => void
|
|
currentNotebookId?: string | null
|
|
noteHistoryMode?: 'manual' | 'auto'
|
|
onOpenHistory?: (note: Note) => void
|
|
onEnableHistory?: (noteId: string) => Promise<void>
|
|
onNoteCreated?: (note: Note) => void
|
|
}
|
|
|
|
export function NotesMainSection({
|
|
notes,
|
|
viewMode,
|
|
onEdit,
|
|
onSizeChange,
|
|
currentNotebookId,
|
|
noteHistoryMode = 'manual',
|
|
onOpenHistory,
|
|
onEnableHistory,
|
|
onNoteCreated,
|
|
}: NotesMainSectionProps) {
|
|
if (viewMode === 'tabs') {
|
|
return (
|
|
<div className="flex min-h-0 flex-1 flex-col" data-testid="notes-grid-tabs-wrap">
|
|
<NotesTabsView
|
|
notes={notes}
|
|
onEdit={onEdit}
|
|
currentNotebookId={currentNotebookId}
|
|
noteHistoryMode={noteHistoryMode}
|
|
onOpenHistory={onOpenHistory}
|
|
onEnableHistory={onEnableHistory}
|
|
onNoteCreated={onNoteCreated}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<div data-testid="notes-grid">
|
|
<MasonryGridLazy
|
|
notes={notes}
|
|
onEdit={onEdit}
|
|
onSizeChange={onSizeChange}
|
|
noteHistoryMode={noteHistoryMode}
|
|
onOpenHistory={onOpenHistory}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|