chore(autonomous-session): consolidate uncommitted work from prior session
Bundles the prior autonomous-session output that was sitting unstaged: - Em-dash sweep across src/ + tests/ (en-dash/em-dash to hyphen, ~2280 instances) - country-flag-icons rollout (CountryFlag component, replaces emoji glyphs that never rendered on Windows; lazy-loads the 3x2 SVG index as a single chunk after the per-subpath dynamic-import approach silently failed in webpack) - Admin IA Phase 1+2: 7-domain regroup, 41 to 38 pages, /admin/berths index, redirects (ocr to ai, reports to dashboard, invitations to users), docs/admin-ia-proposal.md - Per-template email tester (registry + endpoint + UI on Email admin page) - Cancel-document mode picker (delete-from-Documenso vs keep-for-audit) - Dashboard PDF report: 25 widgets, SVG charts, date-range picker, 11 resolvers - Customize-widgets per-region sortables at xl+ (charts/rails/feed); single flat sortable below xl when the layout stacks; per-viewport saved orders - Audit doc updates capturing each shipped item - Lint fixes: react-compiler immutability in DonutChart (reduce instead of let-reassign), set-state-in-effect disables in CountryFlag and UploadForSigning preview-bytes effect, unused 'confirm' destructures in interest contract + reservation tabs, unescaped apostrophe in test-template card copy
This commit is contained in:
@@ -39,7 +39,7 @@ export const files = pgTable(
|
||||
* client folder. NULL for client/yacht/company-level uploads.
|
||||
*
|
||||
* Added by migration 0078; not yet wired into ensureEntityFolder
|
||||
* (interest subfolder nesting) — see master UAT line 728+ for the
|
||||
* (interest subfolder nesting) - see master UAT line 728+ for the
|
||||
* remaining work plan.
|
||||
*/
|
||||
interestId: text('interest_id').references(() => interests.id, { onDelete: 'set null' }),
|
||||
@@ -64,7 +64,7 @@ export const files = pgTable(
|
||||
index('idx_files_folder').on(table.folderId),
|
||||
index('idx_files_port_folder').on(table.portId, table.folderId),
|
||||
// Composite indexes for the aggregated-projection queries
|
||||
// (`listFilesAggregatedByEntity`) — every join carries a defense-in-
|
||||
// (`listFilesAggregatedByEntity`) - every join carries a defense-in-
|
||||
// depth `port_id` filter so the leading column matters at scale.
|
||||
index('idx_files_port_client').on(table.portId, table.clientId),
|
||||
index('idx_files_port_company').on(table.portId, table.companyId),
|
||||
@@ -84,8 +84,8 @@ export const documents = pgTable(
|
||||
.notNull()
|
||||
.references(() => ports.id),
|
||||
interestId: text('interest_id').references(() => interests.id, { onDelete: 'set null' }),
|
||||
// H-01: nullable; tolerate the owning client being hard-deleted (rare —
|
||||
// archive is the normal path — but if it happens the document row
|
||||
// H-01: nullable; tolerate the owning client being hard-deleted (rare -
|
||||
// archive is the normal path - but if it happens the document row
|
||||
// should outlive it so the audit trail stays intact).
|
||||
clientId: text('client_id').references(() => clients.id, { onDelete: 'set null' }),
|
||||
yachtId: text('yacht_id').references(() => yachts.id, { onDelete: 'set null' }),
|
||||
@@ -112,22 +112,22 @@ export const documents = pgTable(
|
||||
signedFileId: text('signed_file_id').references(() => files.id, { onDelete: 'set null' }),
|
||||
isManualUpload: boolean('is_manual_upload').notNull().default(false),
|
||||
/** Email addresses CC'd on the completion notification (the
|
||||
* passive Documenso CC concept — see plan Q4). Per-document set
|
||||
* passive Documenso CC concept - see plan Q4). Per-document set
|
||||
* by the rep; doesn't gate signing. */
|
||||
completionCcEmails: text('completion_cc_emails').array().default([]),
|
||||
/** Optional auto-reminder cadence — when set, a daily worker
|
||||
/** Optional auto-reminder cadence - when set, a daily worker
|
||||
* fires `sendSigningReminder()` for unsigned signers every
|
||||
* N days until they complete. Null = manual reminders only. */
|
||||
autoReminderIntervalDays: integer('auto_reminder_interval_days'),
|
||||
notes: text('notes'),
|
||||
/** Phase 6 polish — rep-authored note inserted above the CTA in
|
||||
/** Phase 6 polish - rep-authored note inserted above the CTA in
|
||||
* every signing-invitation email for THIS document. Falls back to
|
||||
* the empty string when null. Plain-text (XSS-escaped by the
|
||||
* email renderer); not Markdown. */
|
||||
invitationMessage: text('invitation_message'),
|
||||
remindersDisabled: boolean('reminders_disabled').notNull().default(false),
|
||||
reminderCadenceOverride: integer('reminder_cadence_override'),
|
||||
// Phase 3 — per-document field overrides. When NULL, the canonical
|
||||
// Phase 3 - per-document field overrides. When NULL, the canonical
|
||||
// client/yacht record value flows through; when set, this document
|
||||
// uses the override without touching the underlying record. Mirrors
|
||||
// the AcroForm field set per docs/eoi-documenso-field-mapping.md.
|
||||
@@ -166,7 +166,7 @@ export const documents = pgTable(
|
||||
index('idx_docs_documenso_numeric_id').on(table.documensoNumericId),
|
||||
index('idx_docs_folder').on(table.folderId),
|
||||
// Composite indexes for the aggregated-projection queries
|
||||
// (`listInflightWorkflowsAggregatedByEntity`) — every join carries a
|
||||
// (`listInflightWorkflowsAggregatedByEntity`) - every join carries a
|
||||
// defense-in-depth `port_id` filter so the leading column matters at scale.
|
||||
index('idx_docs_port_client').on(table.portId, table.clientId),
|
||||
index('idx_docs_port_company').on(table.portId, table.companyId),
|
||||
@@ -191,12 +191,12 @@ export const documentSigners = pgTable(
|
||||
signedAt: timestamp('signed_at', { withTimezone: true }),
|
||||
signingUrl: text('signing_url'),
|
||||
embeddedUrl: text('embedded_url'),
|
||||
/** Phase 1+2 lifecycle tracking — set by the send-invitation endpoint
|
||||
/** Phase 1+2 lifecycle tracking - set by the send-invitation endpoint
|
||||
* and the Documenso webhook handler respectively. */
|
||||
invitedAt: timestamp('invited_at', { withTimezone: true }),
|
||||
openedAt: timestamp('opened_at', { withTimezone: true }),
|
||||
lastReminderSentAt: timestamp('last_reminder_sent_at', { withTimezone: true }),
|
||||
/** Documenso recipient token — used for token-based lookup when the
|
||||
/** Documenso recipient token - used for token-based lookup when the
|
||||
* webhook fires (more robust than email match when one address
|
||||
* serves multiple roles). */
|
||||
signingToken: text('signing_token'),
|
||||
@@ -350,7 +350,7 @@ export const formSubmissions = pgTable(
|
||||
|
||||
/**
|
||||
* Per-port folder tree for organising documents. Self-referencing
|
||||
* via parent_id; null parent = root. Unlimited depth — the UI is the
|
||||
* via parent_id; null parent = root. Unlimited depth - the UI is the
|
||||
* gate (collapsed sidebar tree + breadcrumb header). Cycle prevention
|
||||
* happens in the service layer (parent_id chain walk on insert/move).
|
||||
*
|
||||
@@ -367,7 +367,7 @@ export const documentFolders = pgTable(
|
||||
.notNull()
|
||||
.references(() => ports.id),
|
||||
// Null = root. ON DELETE NO ACTION on the FK (added by migration
|
||||
// 0050) — the service bubbles children up to the deleted folder's
|
||||
// 0050) - the service bubbles children up to the deleted folder's
|
||||
// parent in a transaction instead of cascading.
|
||||
parentId: text('parent_id'),
|
||||
name: text('name').notNull(),
|
||||
|
||||
Reference in New Issue
Block a user