feat: add X-App-Source header to Nova + remove notify checkbox#926
Conversation
…ckbox - Add X-App-Source: nova header to $fetch, authClient, AutumnProvider, and raw fetch calls - Remove notify-when-deleted checkbox from account deletion dialog (emails now always sent)
Add onRequest hook to Nova $fetch client so X-App-Source: nova is always injected even when individual calls pass their own headers object (which shallow-replaces the createFetch defaults).
Deploying with
|
| Status | Name | Latest Commit | Updated (UTC) |
|---|---|---|---|
| ✅ Deployment successful! View logs |
supermemory-mcp | 3926da4 | May 11 2026, 03:39 PM |
|
Claude finished @MaheshtheDev's task in 1m 38s —— View job Review Complete
Overview: Adds Issues found: None — this looks good to ship. The implementation is well thought out:
Score: 10/10 |
Deploying with
|
| Status | Name | Latest Commit | Preview URL | Updated (UTC) |
|---|---|---|---|---|
| ✅ Deployment successful! View logs |
supermemory-app | 3926da4 | Commit Preview URL Branch Preview URL |
May 11 2026, 03:40 PM |
There was a problem hiding this comment.
Overview: Adds X-App-Source: nova header across all Nova API entry points and removes the opt-in notification checkbox from account deletion flow.
Issues found: None — this looks good to ship.
The implementation is well thought out:
- The
onRequesthook in$fetchcorrectly ensures the header survives per-request header overrides - Header additions are consistent across
$fetch,authClient,AutumnProvider, and manual fetch calls - The checkbox removal is clean with all related state and UI properly removed
- The
notifyOnCompleteparameter remains inuseDeleteUserAccountfor backwards compatibility but is no longer passed from the UI, which aligns with the backend change to always send emails
Score: 10/10
|
Can we verify this works with our installed autumn-js@1.2.12? |
Co-authored-by: ved015 <vedant.04.mahajan@gmail.com>
…920) ## Summary Addresses user feedback about the graph view: content in node popovers was hard-truncated at 100 characters with no way to read the full text or navigate to the document. ### Changes **Scrollable popover content (no more truncation)** - Removed the `truncate(content, 100)` call -- full content is now rendered in the popover - Made the content area scrollable with `maxHeight: 100px` and `overflowY: auto` - Increased version timeline entry truncation from 60 to 120 characters - Increased version timeline container height from 120px to 160px **"View document" in shortcuts panel** - Added an eye icon + "View document" entry to the shortcuts panel (alongside existing arrow navigation) - Clicking opens the Document Modal for the corresponding document - Works for both document nodes (opens that document) and memory nodes (opens the parent document) - Popover is automatically dismissed before the modal opens (prevents z-index overlap) - Wired `onOpenDocument` callback through the full component chain: `page.tsx` -> `GraphLayoutView` -> `MemoryGraph` wrapper -> `MemoryGraphBase` -> `NodeHoverPopover` **Shortcuts panel visual cleanup** - Icon badges (`KeyBadge`) retain dark background and border for a keyboard-key badge look - All icons (including the new EyeIcon) are uniformly wrapped in `KeyBadge` for consistent styling - Removed background, border, and border-radius from the shortcuts panel container itself - Widened shortcuts panel from 100px to 160px so navigation labels are fully visible **Type safety improvement** - Changed `MemoryGraphProps.colors` from `GraphThemeColors` to `Partial<GraphThemeColors>` to match actual usage (callers pass partial overrides that get merged with defaults) - Replaced `as Partial<typeof import(...)>` cast with proper `satisfies Partial<GraphThemeColors>` using a direct type import ### Files changed - `packages/memory-graph/src/components/node-hover-popover.tsx` -- scrollable content, EyeIcon + "View document" in shortcuts, KeyBadge styling, NavButton icon type broadened to `React.ReactNode`, all icons wrapped in KeyBadge - `packages/memory-graph/src/components/memory-graph.tsx` -- popover dismissal wrapper (`handleOpenDocument`), prop forwarding - `packages/memory-graph/src/types.ts` -- `onOpenDocument` prop on `MemoryGraphProps`, `colors` changed to `Partial<GraphThemeColors>` - `apps/web/components/graph-layout-view.tsx` -- accepts and passes `onOpenDocument` - `apps/web/components/memory-graph/memory-graph-wrapper.tsx` -- `onOpenDocument` in wrapper props, clean type import - `apps/web/app/(app)/page.tsx` -- `handleOpenDocumentById` handler, wired to `GraphLayoutView` ## Testing ### Unit Tests (154/154 passed) - **Command:** `cd packages/memory-graph && bun run test` - **Result:** 9 test files, 154 tests passed (107 existing + 47 new) - **New test file:** `packages/memory-graph/src/__tests__/node-hover-popover.test.tsx` covering: - Layout constants (`SHORTCUTS_W=160`, `CARD_W=280`, `TOTAL_W` formula) - Content area scrollability (`maxHeight:100`, `overflowY:auto`, `flex:1 1 auto`, no truncation) - KeyBadge styles (has `backgroundColor: colors.controlBg`, has `border` with `colors.controlBorder`) - Shortcuts panel styles (no `backgroundColor`, no `border`, no `borderRadius`) - EyeIcon SVG component (`aria-hidden`, viewBox, path, circle, stroke) - "View document" button render guard (`onOpenDocument && documentId`) - `documentId` derivation (memory vs document node) - VersionTimeline truncation limit (120 chars) and container maxHeight (160) - `onOpenDocument` prop wiring - NavButton icon prop type (`React.ReactNode`), all icons wrapped in KeyBadge - `handleOpenDocument` wrapper in MemoryGraph (dismiss calls, ordering, useCallback deps) ### Build - **Command:** `bun run --filter=@supermemory/memory-graph build` - **Result:** Build succeeds, 0 errors ### Lint/Format - **Command:** `bunx biome ci --changed --since=origin/main --no-errors-on-unmatched` - **Result:** 6 files checked, no fixes applied, 0 errors ### Type Checking - `packages/memory-graph`: 0 errors - `apps/web`: 0 new errors introduced ### CI - "CI - Type Check, Format & Lint" workflow passes - "Claude Code Review" workflow fails due to repo config (`non-human actor: vorflux` not in `allowed_bots` list) -- not related to code changes --- **Session Details** - Session: [View Session](https://supermemory.us1.vorflux.com/agent-sessions/d0c067f1-38c1-40c5-ada9-b2ffb7331d1c) - Requested by: Mahesh Sanikommu (mahesh@supermemory.com) - Address comments on this PR. Add `(aside)` to your comment to have me ignore it.
…ations-nova-headers
|
Verified — |
|
Okay lgtm! |
Summary
Adds
X-App-Source: novaheader to all Nova API clients and removes the "notify when deleted" checkbox from the account deletion dialog. This is the companion PR to the main email notifications feature in the mono repo.Companion PR: supermemoryai/mono — Email notifications for lifecycle events
What Changed
X-App-Source Header
packages/lib/api.ts—$fetchsendsX-App-Source: novaviaonRequesthook (survives per-request header overrides)packages/lib/auth.ts—authClientsendsX-App-Source: novaheaderapps/web/app/layout.tsx—AutumnProviderreceivesheaders={{ "X-App-Source": "nova" }}propapps/web/hooks/use-account-settings.ts— all 3 rawfetchcalls includeX-App-Source: novaNotify Checkbox Removal
apps/web/components/settings/account.tsx— removednotifyWhenDeletedstate, checkbox UI, andnotifyOnCompleteparameter from the delete account callWhy
The backend uses this header to determine which email template variant to send (developer vs consumer). Account deletion emails are now always sent (no longer opt-in), so the checkbox is removed.
Testing
Type Checking
layout.tsx:57—AutumnProvidertypes fromautumn-js/reactdon't declareheadersprop yet, but it's supported at runtime. Added@ts-expect-errorwith tracking comment.apps/webandpackages/toolsare pre-existing across unrelated filesLinting
X-App-Source Header Coverage Audit
$fetch(withonRequestguard),authClient,AutumnProvider, and all 3 manualfetchcalls inuse-account-settings.tscarry"nova"Checkbox Removal Audit
notifyWhenDeletedand checkbox JSX fully removed fromaccount.tsxSession Details
(aside)to your comment to have me ignore it.