d2495190a9
AI now returns a short descriptive title per document (e.g. "ACME Corp
Invoice April 2026"). Title is stored in a new documents.title column
(migration 0002), shown in the row header instead of the raw filename,
and editable inline via PATCH /documents/{id}/title. Filename is shown
as a subtitle when a title exists.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
49 lines
971 B
Python
49 lines
971 B
Python
from datetime import datetime
|
|
|
|
from pydantic import BaseModel
|
|
|
|
|
|
class CategoryOut(BaseModel):
|
|
id: str
|
|
name: str
|
|
model_config = {"from_attributes": True}
|
|
|
|
|
|
class DocumentOut(BaseModel):
|
|
id: str
|
|
user_id: str
|
|
filename: str
|
|
title: str | None
|
|
file_size: int
|
|
status: str
|
|
document_type: str | None
|
|
extracted_data: str | None # JSON string — frontend calls JSON.parse()
|
|
tags: str | None # JSON array string
|
|
error_message: str | None
|
|
created_at: datetime
|
|
processed_at: datetime | None
|
|
categories: list[CategoryOut] = []
|
|
|
|
model_config = {"from_attributes": True}
|
|
|
|
|
|
class DocumentStatusOut(BaseModel):
|
|
id: str
|
|
status: str
|
|
error_message: str | None
|
|
processed_at: datetime | None
|
|
|
|
model_config = {"from_attributes": True}
|
|
|
|
|
|
class DocumentTypeUpdate(BaseModel):
|
|
document_type: str
|
|
|
|
|
|
class TagsUpdate(BaseModel):
|
|
tags: list[str]
|
|
|
|
|
|
class TitleUpdate(BaseModel):
|
|
title: str
|