- bill_notes table (migration 0014): user_id, bill_id, content, pinned,
created_at, updated_at; unique constraint (user_id, bill_id)
- BillNote SQLAlchemy model with back-refs on User and Bill
- GET/PUT/DELETE /api/notes/{bill_id} — auth-required, one note per (user, bill)
- NotesPanel component: collapsible, auto-resize textarea, pin toggle,
save + delete; shows last-saved date and pin indicator in collapsed header
- Pinned notes render above BriefPanel; unpinned render below DraftLetterPanel
- Guests see nothing (token guard in component + query disabled)
Co-Authored-By: Jack Levy
32 lines
856 B
Python
32 lines
856 B
Python
from app.models.bill import Bill, BillAction, BillDocument
|
|
from app.models.brief import BillBrief
|
|
from app.models.follow import Follow
|
|
from app.models.member import Member
|
|
from app.models.member_interest import MemberTrendScore, MemberNewsArticle
|
|
from app.models.news import NewsArticle
|
|
from app.models.note import BillNote
|
|
from app.models.notification import NotificationEvent
|
|
from app.models.setting import AppSetting
|
|
from app.models.trend import TrendScore
|
|
from app.models.committee import Committee, CommitteeBill
|
|
from app.models.user import User
|
|
|
|
__all__ = [
|
|
"Bill",
|
|
"BillAction",
|
|
"BillDocument",
|
|
"BillBrief",
|
|
"BillNote",
|
|
"Follow",
|
|
"Member",
|
|
"MemberTrendScore",
|
|
"MemberNewsArticle",
|
|
"NewsArticle",
|
|
"NotificationEvent",
|
|
"AppSetting",
|
|
"TrendScore",
|
|
"Committee",
|
|
"CommitteeBill",
|
|
"User",
|
|
]
|