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:
@@ -9,7 +9,7 @@ import { getStorageBackend } from '@/lib/storage';
|
||||
import { detectFields } from '@/lib/services/document-field-detector';
|
||||
|
||||
/**
|
||||
* Phase 4 — Auto-detect signature/date/initials/name/email anchors in the
|
||||
* Phase 4 - Auto-detect signature/date/initials/name/email anchors in the
|
||||
* template's current source PDF and return suggested field placements.
|
||||
*
|
||||
* The detector (`src/lib/services/document-field-detector.ts`) scans each
|
||||
@@ -18,7 +18,7 @@ import { detectFields } from '@/lib/services/document-field-detector';
|
||||
* coords (0..100 of page dimensions), which the editor converts to its
|
||||
* own 0..1 marker coords before adding to the field map.
|
||||
*
|
||||
* Permission: `admin.manage_settings` — same gate as the editor itself.
|
||||
* Permission: `admin.manage_settings` - same gate as the editor itself.
|
||||
*/
|
||||
export const POST = withAuth(
|
||||
withPermission('admin', 'manage_settings', async (_req, ctx, params) => {
|
||||
@@ -29,7 +29,7 @@ export const POST = withAuth(
|
||||
if (!template) throw new NotFoundError('Template');
|
||||
if (!template.sourceFileId) {
|
||||
throw new ValidationError(
|
||||
'Template has no source PDF — upload one first via the Replace PDF button',
|
||||
'Template has no source PDF - upload one first via the Replace PDF button',
|
||||
);
|
||||
}
|
||||
|
||||
@@ -40,7 +40,7 @@ export const POST = withAuth(
|
||||
throw new NotFoundError('Source PDF file row missing');
|
||||
}
|
||||
|
||||
// Read the PDF blob from storage. Buffer the whole stream — the
|
||||
// Read the PDF blob from storage. Buffer the whole stream - the
|
||||
// detector needs a contiguous Buffer for pdfjs-dist, and template
|
||||
// source PDFs are capped at 10MB by the source-pdf upload route.
|
||||
const backend = await getStorageBackend();
|
||||
|
||||
@@ -18,13 +18,13 @@ const previewBodySchema = z.object({
|
||||
});
|
||||
|
||||
/**
|
||||
* Phase 7.2 — live preview endpoint for the PDF editor.
|
||||
* Phase 7.2 - live preview endpoint for the PDF editor.
|
||||
*
|
||||
* Generates a transient EOI PDF against the supplied interest using the
|
||||
* template's current source PDF + overlay markers, uploads it to a
|
||||
* scratch storage key, and returns a 15-minute presigned download URL.
|
||||
*
|
||||
* The blob is intentionally not linked to a `files` row — preview PDFs
|
||||
* The blob is intentionally not linked to a `files` row - preview PDFs
|
||||
* are throwaway. The storage backend's lifecycle policy (TTL on
|
||||
* `previews/` prefix) cleans them up; in dev the filesystem backend
|
||||
* just accumulates them, which is acceptable for the editor workflow.
|
||||
@@ -39,7 +39,7 @@ export const POST = withAuth(
|
||||
});
|
||||
if (!template) throw new NotFoundError('Template');
|
||||
if (template.templateType !== 'eoi') {
|
||||
// Live preview is currently EOI-only — that's where the
|
||||
// Live preview is currently EOI-only - that's where the
|
||||
// editor's overlay-positions flow into rendering. Other
|
||||
// template types are deferred (no in-app fill yet).
|
||||
throw new ValidationError(
|
||||
|
||||
@@ -15,7 +15,7 @@ const MAX_PDF_BYTES = 10 * 1024 * 1024;
|
||||
const PDF_MAGIC = Buffer.from([0x25, 0x50, 0x44, 0x46, 0x2d]); // "%PDF-"
|
||||
|
||||
/**
|
||||
* Phase 7.2 — replace the template's source PDF while preserving the
|
||||
* Phase 7.2 - replace the template's source PDF while preserving the
|
||||
* field map. The existing `overlay_positions` is kept exactly as-is;
|
||||
* the client warns when the new page count truncates the previous set
|
||||
* (markers on now-orphaned pages are invisible at render time).
|
||||
|
||||
Reference in New Issue
Block a user