From 2dfadd344b6d6a26e878f04cd2de03132ada166a Mon Sep 17 00:00:00 2001 From: Dhravya <63950637+Dhravya@users.noreply.github.com> Date: Fri, 9 Jan 2026 02:40:04 +0000 Subject: Document promptTemplate feature for AI SDK (#660) Added comprehensive documentation for the new `promptTemplate` option in the AI SDK, which allows developers to customize how memories are formatted and injected into system prompts. This includes examples for XML-based prompting (Claude), custom branding, and the `MemoryPromptData` interface. ## Files Changed - `apps/docs/ai-sdk/user-profiles.mdx` - Added "Custom Prompt Templates" section with examples and interface documentation - `apps/docs/ai-sdk/overview.mdx` - Updated User Profiles section to mention customization capabilities Generated from [feat: allow prompt template for @supermemory/tools package](https://github.com/supermemoryai/supermemory/pull/655) @MaheshtheDev --- apps/docs/ai-sdk/overview.mdx | 2 +- apps/docs/ai-sdk/user-profiles.mdx | 93 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 94 insertions(+), 1 deletion(-) (limited to 'apps') diff --git a/apps/docs/ai-sdk/overview.mdx b/apps/docs/ai-sdk/overview.mdx index 667ae5c7..07d70e29 100644 --- a/apps/docs/ai-sdk/overview.mdx +++ b/apps/docs/ai-sdk/overview.mdx @@ -18,7 +18,7 @@ npm install @supermemory/tools ## User Profiles with Middleware -Automatically inject user profiles into every LLM call for instant personalization. +Automatically inject user profiles into every LLM call for instant personalization. Customize how memories are formatted with the `promptTemplate` option for XML-based prompting, custom branding, or model-specific formatting. ```typescript import { generateText } from "ai" diff --git a/apps/docs/ai-sdk/user-profiles.mdx b/apps/docs/ai-sdk/user-profiles.mdx index 68ba819a..fcfe4d7a 100644 --- a/apps/docs/ai-sdk/user-profiles.mdx +++ b/apps/docs/ai-sdk/user-profiles.mdx @@ -117,6 +117,99 @@ const result = await generateText({ // Uses both profile (user's expertise) AND search (previous debugging sessions) ``` +## Custom Prompt Templates + +Customize how memories are formatted and injected into the system prompt using the `promptTemplate` option. This is useful for: +- Using XML-based prompting (e.g., for Claude models) +- Custom branding (removing "supermemories" references) +- Controlling how your agent describes where information comes from + +```typescript +import { generateText } from "ai" +import { withSupermemory, type MemoryPromptData } from "@supermemory/tools/ai-sdk" +import { openai } from "@ai-sdk/openai" + +const customPrompt = (data: MemoryPromptData) => ` + +Here is some information about your past conversations with the user: +${data.userMemories} +${data.generalSearchMemories} + +`.trim() + +const model = withSupermemory(openai("gpt-4"), "user-123", { + mode: "full", + promptTemplate: customPrompt +}) + +const result = await generateText({ + model, + messages: [{ role: "user", content: "What do you know about me?" }] +}) +``` + +### MemoryPromptData Interface + +The `MemoryPromptData` object passed to your template function provides: + +- `userMemories`: Pre-formatted markdown combining static profile facts (name, preferences, goals) and dynamic context (current projects, recent interests) +- `generalSearchMemories`: Pre-formatted search results based on semantic similarity to the current query (empty string if mode is "profile") + +### XML-Based Prompting for Claude + +Claude models perform better with XML-structured prompts: + +```typescript +const claudePrompt = (data: MemoryPromptData) => ` + + + ${data.userMemories} + + + ${data.generalSearchMemories} + + + +Use the above context to provide personalized responses. +`.trim() + +const model = withSupermemory(anthropic("claude-3-sonnet"), "user-123", { + mode: "full", + promptTemplate: claudePrompt +}) +``` + +### Custom Branding + +Remove "supermemories" references and use your own branding: + +```typescript +const brandedPrompt = (data: MemoryPromptData) => ` +You are an AI assistant with access to the user's personal knowledge base. + +User Profile: +${data.userMemories} + +Relevant Context: +${data.generalSearchMemories} + +Use this information to provide personalized and contextually relevant responses. +`.trim() + +const model = withSupermemory(openai("gpt-4"), "user-123", { + promptTemplate: brandedPrompt +}) +``` + +### Default Template + +If no `promptTemplate` is provided, the default format is used: + +```typescript +const defaultPrompt = (data: MemoryPromptData) => + `User Supermemories: \n${data.userMemories}\n${data.generalSearchMemories}`.trim() +``` + ## Verbose Logging Enable detailed logging to see exactly what's happening: -- cgit v1.2.3