@pindownai/client-js 1.3.3 → 1.3.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +11 -0
- package/dist/PindownClient-Blc0tgqw.d.cts +668 -0
- package/dist/PindownClient-Blc0tgqw.d.ts +668 -0
- package/dist/ai/index.cjs +9 -0
- package/dist/ai/index.cjs.map +1 -0
- package/dist/ai/index.d.cts +93 -0
- package/dist/ai/index.d.ts +93 -0
- package/dist/ai/index.js +9 -0
- package/dist/ai/index.js.map +1 -0
- package/dist/index.cjs +4 -4
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +23 -666
- package/dist/index.d.ts +23 -666
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/package.json +27 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/types/pins.ts","../../src/client/pins/pin-helper-core.ts","../../src/pin-config-hints.ts","../../src/ai/llm-schema-transform.ts","../../src/ai/pin-config-limits.ts","../../src/ai/pin-config-schemas.ts","../../src/ai/pin-config-zod-map.ts","../../src/ai/pin-config-canonical.ts","../../src/ai/providers.ts","../../src/ai/materialize.ts","../../src/ai/pipe.ts"],"names":["PRODUCT_PIN_TYPES","PIN_CONFIG_FIELDS","pinTypeToMethodSuffix","pinType","part","TABLE_HINT","PIN_CONFIG_HINTS","getPinConfigHint","formatPinConfigHint","hint","f","unwrapSchema","schema","current","z","llmEntryValue","toLlmPinConfigSchema","base","shape","key","value","entriesArrayToRecord","data","record","item","entry","looksLikeEntryArray","normalizeRecordValue","obj","out","k","v","normalizeLlmPinConfigOutput","apiSchema","output","fieldSchema","PIN_TYPE_ITEM_LIMITS","looseObject","markdownPinConfigSchema","statCardsPinConfigSchema","imagePinConfigSchema","videoPinConfigSchema","audioPinTrackSchema","audioPinConfigSchema","tablePinConfigSchema","cells","chartsPinConfigSchema","embedPinConfigSchema","pdfViewerPinConfigSchema","excelViewerPinConfigSchema","timelinePinConfigSchema","jsonViewerPinConfigSchema","jsonListPinConfigSchema","linksPinConfigSchema","stepsPinConfigSchema","tracePinConfigSchema","planContentBlockSchema","planTaskSchema","planPinConfigSchema","notesPinConfigSchema","csvViewerPinConfigSchema","galleryPinConfigSchema","mermaidPinConfigSchema","codePinConfigSchema","userStoryPinConfigSchema","chatPinConfigSchema","introPinConfigSchema","textMediaPinConfigSchema","businessCardPinConfigSchema","qrCodePinConfigSchema","socialHandlesPinConfigSchema","fileUploadPinConfigSchema","kanbanBoardPinConfigSchema","checklistItemSchema","checklistSectionSchema","checklistPinConfigSchema","ctx","cardsImageSchema","cardsItemSchema","keyValueItemSchema","faqItemSchema","ctaButtonSchema","comparisonPinConfigSchema","calendarPinConfigSchema","roadmapPinConfigSchema","config","sum","objective","realtimeCanvasPinConfigSchema","mastraPinConfigSchema","PIN_CONFIG_ZOD_SCHEMAS","getPinConfigZodSchema","getLlmPinConfigZodSchema","PIN_CONFIG_CANONICAL_NORMALIZERS","canonicalizeTablePinConfig","canonicalizePinConfigForApi","normalizer","table","columnIds","col","id","rows","row","index","PROVIDER_PACKAGES","DEFAULT_ENV_KEYS","loadProviderFactory","provider","pkg","mod","opts","resolveGoogleApiKey","candidates","validAiza","a","b","resolveLanguageModel","apiKey","googleHint","PinConfigMaterializeError","message","zodError","serializePipeInput","input","buildSystemPrompt","override","fields","runGenerateObject","generateObject","materializePinConfig","llm","options","llmSchema","model","inputText","object","normalized","canonical","parsed","mergeConfigIntoCreateInput","materialized","merged","fromInput","fromLlm","mergeConfigIntoUpdateInput","PinConfigPipe","client","c","pin_config","pinId","attachNamedPipeMethods","proto","suffix","createMethod","updateMethod","toConfig","pipePinConfig"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Pin types for the v1 Pins API.\n * Aligned with backend-api/src/lib/pin-types.ts + pin-config-schemas.ts.\n * Import per-type *PinConfig interfaces for typed CRUD payloads.\n */\n\nexport const PRODUCT_PIN_TYPES = [\n 'markdown',\n 'image',\n 'gallery',\n 'table',\n 'charts',\n 'mermaid',\n 'code',\n 'embed',\n 'pdf-viewer',\n 'excel-viewer',\n 'stat-cards',\n 'timeline',\n 'json-viewer',\n 'json-list',\n 'links',\n 'qr-code',\n 'social-handles',\n 'steps',\n 'trace',\n 'plan',\n 'notes',\n 'csv-viewer',\n 'user-story',\n 'chat',\n 'intro',\n 'mastra',\n 'text-media',\n 'business-card',\n 'video',\n 'audio',\n 'file-upload',\n 'kanban-board',\n 'checklist',\n 'comparison',\n 'calendar',\n 'roadmap',\n 'realtime-canvas',\n] as const\n\nexport const ALL_PIN_TYPES = [...PRODUCT_PIN_TYPES] as const\n\nexport type ProductPinTypeId = (typeof PRODUCT_PIN_TYPES)[number]\nexport type PinTypeId = (typeof ALL_PIN_TYPES)[number]\n\nexport type PinLayout = '1x1' | '1x2' | '2x1' | '2x2' | '3x1' | '3x2' | '3x3' | '4x4'\n\nexport type PinDataType = 'markdown' | 'json' | 'text' | 'pin-card'\n\n/** @deprecated Use PinTypeId */\nexport type PinCardType = PinTypeId\n\nexport interface StatCardItem {\n title: string\n value: string | number\n change?: string\n trend?: 'up' | 'down' | 'neutral' | string\n icon?: string\n [key: string]: unknown\n}\n\nexport interface TableColumn {\n id: string\n name: string\n type?: string\n [key: string]: unknown\n}\n\nexport interface TableRow {\n id: string\n cells: Record<string, unknown>\n [key: string]: unknown\n}\n\nexport interface KanbanColumn {\n id: string\n title: string\n cards?: Array<Record<string, unknown>>\n [key: string]: unknown\n}\n\nexport interface ChecklistItem {\n id: string\n name: string\n checked?: boolean\n [key: string]: unknown\n}\n\nexport interface GalleryImage {\n url: string\n alt?: string\n [key: string]: unknown\n}\n\nexport interface LinkItem {\n title: string\n url: string\n [key: string]: unknown\n}\n\nexport interface StepItem {\n title: string\n description?: string\n [key: string]: unknown\n}\n\nexport interface MarkdownPinConfig {\n content?: string\n collaboration?: { enabled?: boolean }\n [key: string]: unknown\n}\n\nexport interface ImagePinConfig {\n url?: string\n altText?: string\n fit?: 'cover' | 'contain' | string\n [key: string]: unknown\n}\n\nexport interface GalleryPinConfig {\n images?: GalleryImage[]\n [key: string]: unknown\n}\n\nexport interface TablePinConfig {\n columns: TableColumn[]\n rows?: TableRow[]\n [key: string]: unknown\n}\n\nexport interface ChartsPinConfig {\n chartType?: string\n data?: Array<Record<string, unknown>>\n xAxis?: string\n yAxis?: string\n [key: string]: unknown\n}\n\nexport interface MermaidPinConfig {\n diagram?: string\n code?: string\n title?: string\n [key: string]: unknown\n}\n\nexport interface CodePinConfig {\n code: string\n language?: string\n filename?: string\n title?: string\n [key: string]: unknown\n}\n\nexport interface EmbedPinConfig {\n url?: string\n type?: string\n [key: string]: unknown\n}\n\nexport interface PdfViewerPinConfig {\n pdf: { url: string; fileName?: string; title?: string; [key: string]: unknown }\n [key: string]: unknown\n}\n\nexport interface ExcelViewerPinConfig {\n excel: { url: string; fileName?: string; title?: string; [key: string]: unknown }\n [key: string]: unknown\n}\n\nexport interface StatCardsPinConfig {\n cards: StatCardItem[]\n [key: string]: unknown\n}\n\nexport interface TimelinePinConfig {\n mode?: string\n items?: Array<Record<string, unknown>>\n [key: string]: unknown\n}\n\nexport interface JsonViewerPinConfig {\n json?: unknown\n jsonString?: string\n title?: string\n [key: string]: unknown\n}\n\nexport interface JsonListPinConfig {\n json?: unknown[]\n jsonString?: string\n [key: string]: unknown\n}\n\nexport interface LinksPinConfig {\n links?: LinkItem[]\n [key: string]: unknown\n}\n\nexport interface QrCodePinConfig {\n url?: string\n label?: string\n [key: string]: unknown\n}\n\nexport interface SocialHandleItem {\n id?: string\n platform: string\n url: string\n label?: string\n [key: string]: unknown\n}\n\nexport interface SocialHandlesPinConfig {\n title?: string\n showLabels?: boolean\n iconSize?: number\n handles?: SocialHandleItem[]\n [key: string]: unknown\n}\n\nexport interface StepsPinConfig {\n steps: StepItem[]\n [key: string]: unknown\n}\n\nexport type TraceSpanStatus = 'completed' | 'running' | 'pending' | 'failed'\nexport type TraceSpanType = 'system' | 'agent' | 'tool'\n\nexport interface TraceSpanItem {\n id?: string\n type?: TraceSpanType\n name: string\n status: TraceSpanStatus\n timestamp?: string\n duration?: string\n details?: string\n}\n\nexport interface TracePinConfig {\n title?: string\n live?: boolean\n spans: TraceSpanItem[]\n [key: string]: unknown\n}\n\nexport type PlanContentBlock =\n | { type: 'details'; title?: string; items: string[] }\n | { type: 'command'; command: string; label?: string }\n | { type: 'code'; code: string; language?: string; filename?: string }\n | { type: 'text'; content: string }\n | { type: 'link'; url: string; label?: string }\n | { type: 'mermaid'; diagram: string; title?: string }\n | { type: 'summary'; content: string; title?: string }\n\nexport interface PlanTaskItem {\n id?: string\n number?: string\n title: string\n label?: string\n description?: string\n blocks?: PlanContentBlock[]\n [key: string]: unknown\n}\n\nexport interface PlanPhaseItem {\n id?: string\n title: string\n status?: 'pending' | 'in-progress' | 'completed'\n tasks: PlanTaskItem[]\n [key: string]: unknown\n}\n\nexport interface PlanPinConfig {\n title?: string\n status?: 'draft' | 'in-progress' | 'completed'\n breadcrumbs?: Array<{ label: string }>\n phases: PlanPhaseItem[]\n [key: string]: unknown\n}\n\nexport interface NoteItem {\n id?: string\n title: string\n content?: string\n order?: number\n createdAt?: number\n updatedAt?: number\n}\n\nexport interface NotesPinConfig {\n notes?: NoteItem[]\n [key: string]: unknown\n}\n\nexport interface CsvViewerPinConfig {\n csvText?: string\n csvData?: Array<Record<string, unknown>>\n fileName?: string\n [key: string]: unknown\n}\n\nexport interface UserStoryPinConfig {\n title?: string\n userStory: string\n acceptanceCriteria?: string\n [key: string]: unknown\n}\n\nexport interface ChatPinConfig {\n title?: string\n placeholder?: string\n /** Pin this discussion thread is about (commentary / feedback). */\n linked_pin_id?: string\n /** Cached title for display without fetching the linked pin. */\n linked_pin_title?: string\n [key: string]: unknown\n}\n\nexport interface IntroPinConfig {\n heading: string\n subheading?: string\n [key: string]: unknown\n}\n\nexport interface MastraPinConfig {\n mode?: 'workflow' | 'agent' | string\n agentId?: string\n workflowId?: string\n [key: string]: unknown\n}\n\nexport interface BusinessCardField {\n id: string\n key: string\n value: string\n}\n\nexport interface BusinessCardPinConfig {\n sectionTitle?: string\n fields?: BusinessCardField[]\n imageConfig?: { url?: string; alt?: string; fileId?: string; [key: string]: unknown }\n imagePosition?: 'left' | 'right' | string\n [key: string]: unknown\n}\n\nexport interface VideoPinConfig {\n url?: string\n fileId?: string\n fileName?: string\n mimeType?: 'video/mp4' | string\n caption?: string\n size?: number\n [key: string]: unknown\n}\n\nexport interface AudioPinTrack {\n url: string\n fileId?: string\n fileName?: string\n mimeType?: 'audio/mpeg' | 'audio/wav' | 'audio/x-wav' | string\n size?: number\n [key: string]: unknown\n}\n\nexport interface AudioPinConfig {\n url?: string\n fileId?: string\n fileName?: string\n mimeType?: 'audio/mpeg' | 'audio/wav' | 'audio/x-wav' | string\n caption?: string\n size?: number\n tracks?: AudioPinTrack[]\n [key: string]: unknown\n}\n\nexport interface TextMediaPinConfig {\n title?: string\n text?: string\n subtext?: string\n textPosition?: 'left' | 'right' | string\n mediaType?: 'embed' | 'image' | string\n embedConfig?: {\n type?: string\n url?: string\n aspectRatio?: string\n autoplay?: boolean\n [key: string]: unknown\n }\n imageConfig?: {\n url?: string\n alt?: string\n fileId?: string\n [key: string]: unknown\n }\n [key: string]: unknown\n}\n\nexport interface FileUploadPinConfig {\n files?: Array<Record<string, unknown>>\n displayMode?: string\n [key: string]: unknown\n}\n\nexport interface KanbanBoardPinConfig {\n columns: KanbanColumn[]\n [key: string]: unknown\n}\n\nexport interface ChecklistPinConfig {\n title?: string\n items: ChecklistItem[]\n [key: string]: unknown\n}\n\nexport interface ComparisonSideConfig {\n label: string\n body: string\n}\n\nexport interface ComparisonMatchPair {\n left: number\n right: number\n}\n\nexport interface ComparisonPinConfig {\n title?: string\n left: ComparisonSideConfig\n right: ComparisonSideConfig\n highlightedLines?: { left?: number[]; right?: number[] }\n matches?: ComparisonMatchPair[]\n showVsBadge?: boolean\n [key: string]: unknown\n}\n\nexport interface CalendarPinConfig {\n weekStartsOn?: number\n events?: Array<Record<string, unknown>>\n [key: string]: unknown\n}\n\nexport interface RoadmapPinConfig {\n title?: string\n months?: Array<Record<string, unknown>>\n [key: string]: unknown\n}\n\nexport interface RealtimeCanvasPinConfig {\n title?: string\n description?: string\n roomId?: string\n [key: string]: unknown\n}\n\nexport interface PinConfigByType {\n markdown: MarkdownPinConfig\n image: ImagePinConfig\n gallery: GalleryPinConfig\n table: TablePinConfig\n charts: ChartsPinConfig\n mermaid: MermaidPinConfig\n code: CodePinConfig\n embed: EmbedPinConfig\n 'pdf-viewer': PdfViewerPinConfig\n 'excel-viewer': ExcelViewerPinConfig\n 'stat-cards': StatCardsPinConfig\n timeline: TimelinePinConfig\n 'json-viewer': JsonViewerPinConfig\n 'json-list': JsonListPinConfig\n links: LinksPinConfig\n 'qr-code': QrCodePinConfig\n 'social-handles': SocialHandlesPinConfig\n steps: StepsPinConfig\n trace: TracePinConfig\n plan: PlanPinConfig\n notes: NotesPinConfig\n 'csv-viewer': CsvViewerPinConfig\n 'user-story': UserStoryPinConfig\n chat: ChatPinConfig\n intro: IntroPinConfig\n mastra: MastraPinConfig\n 'text-media': TextMediaPinConfig\n 'business-card': BusinessCardPinConfig\n video: VideoPinConfig\n audio: AudioPinConfig\n 'file-upload': FileUploadPinConfig\n 'kanban-board': KanbanBoardPinConfig\n checklist: ChecklistPinConfig\n comparison: ComparisonPinConfig\n calendar: CalendarPinConfig\n roadmap: RoadmapPinConfig\n 'realtime-canvas': RealtimeCanvasPinConfig\n}\n\nexport interface PinMetadataBase {\n title: string\n tags?: string[]\n description?: string\n allow_edit?: boolean\n require_sign_in?: boolean\n allow_comments?: boolean\n}\n\nexport type PinMetadata<T extends PinTypeId = PinTypeId> = PinMetadataBase & {\n pin_type?: T\n pin_config?: PinConfigByType[T]\n pin_layout?: PinLayout\n}\n\nexport interface CreateTypedPinRequest<T extends PinTypeId> {\n pin_type: T\n pin_config: PinConfigByType[T]\n pin_layout?: PinLayout\n is_public?: boolean\n allow_edit?: boolean\n require_sign_in?: boolean\n allow_comments?: boolean\n metadata: PinMetadataBase\n pending_invites?: Record<string, 'editor' | 'viewer'>\n /** @deprecated Inferred from pin_type */\n data_type?: PinDataType\n}\n\nexport interface CreateNestedPinRequest<T extends PinTypeId> {\n pin_layout?: PinLayout\n is_public?: boolean\n allow_edit?: boolean\n require_sign_in?: boolean\n allow_comments?: boolean\n metadata: PinMetadata<T> & PinMetadataBase\n pending_invites?: Record<string, 'editor' | 'viewer'>\n data_type?: PinDataType\n}\n\nexport type CreatePinRequest<T extends PinTypeId = PinTypeId> =\n | CreateTypedPinRequest<T>\n | CreateNestedPinRequest<T>\n\nexport interface UpdatePinRequest<T extends PinTypeId = PinTypeId> {\n pin_type?: T\n pin_config?: PinConfigByType[T]\n pin_layout?: PinLayout\n is_public?: boolean\n metadata?: Partial<PinMetadata<T>>\n}\n\nexport interface Pin<T extends PinTypeId = PinTypeId> {\n id: string\n owner_id: string\n user_id?: string\n title?: string\n description?: string\n data_type: PinDataType\n is_public: boolean\n allow_edit: boolean\n require_sign_in: boolean\n allow_comments: boolean\n metadata?: PinMetadata<T>\n created_at: string | number\n updated_at: string | number\n}\n\nexport interface SharePinRequest {\n is_public?: boolean\n allow_edit?: boolean\n require_sign_in?: boolean\n allow_comments?: boolean\n}\n\nexport interface ListPinsOptions {\n limit?: number\n offset?: number\n}\n\nexport interface CreatePinOptions {\n pin_layout?: PinLayout\n is_public?: boolean\n allow_edit?: boolean\n require_sign_in?: boolean\n allow_comments?: boolean\n pending_invites?: Record<string, 'editor' | 'viewer'>\n}\n\n/** Flat create input: metadata + pin_config fields (all pin types). */\nexport type CreatePinHelperInput<T extends PinTypeId> = PinMetadataBase &\n CreatePinOptions &\n PinConfigByType[T]\n\n/** Flat update input: optional metadata + partial pin_config fields. */\nexport type UpdatePinHelperInput<T extends PinTypeId> = {\n pin_layout?: PinLayout\n is_public?: boolean\n title?: string\n tags?: string[]\n description?: string\n metadata?: Partial<PinMetadataBase>\n} & Partial<PinConfigByType[T]>\n\nexport interface CreateMarkdownPinInput extends PinMetadataBase {\n content: string\n pin_layout?: PinLayout\n is_public?: boolean\n allow_edit?: boolean\n require_sign_in?: boolean\n allow_comments?: boolean\n pending_invites?: Record<string, 'editor' | 'viewer'>\n}\n\nexport interface CreateStatCardsPinInput extends PinMetadataBase {\n cards: StatCardItem[]\n pin_layout?: PinLayout\n is_public?: boolean\n}\n\nexport interface CreateTablePinInput extends PinMetadataBase {\n columns: TableColumn[]\n rows?: TableRow[]\n pin_layout?: PinLayout\n is_public?: boolean\n}\n\nexport interface UpdateTablePinInput extends UpdatePinHelperInput<'table'> {}\n\nexport interface CreateEmbedPinInput extends PinMetadataBase {\n url: string\n type?: string\n pin_layout?: PinLayout\n is_public?: boolean\n}\n","import {\n PRODUCT_PIN_TYPES,\n type CreatePinHelperInput,\n type CreateTypedPinRequest,\n type PinConfigByType,\n type PinMetadataBase,\n type PinTypeId,\n type UpdatePinHelperInput,\n type UpdatePinRequest,\n} from '../../types/pins'\n\n/** Known pin_config keys per type (top-level only). */\nexport const PIN_CONFIG_FIELDS: { readonly [K in PinTypeId]: readonly (keyof PinConfigByType[K] & string)[] } = {\n markdown: ['content', 'collaboration'],\n image: ['url', 'altText', 'fit'],\n gallery: ['images'],\n table: ['columns', 'rows'],\n charts: ['chartType', 'data', 'xAxis', 'yAxis'],\n mermaid: ['diagram', 'code', 'title'],\n code: ['code', 'language', 'filename', 'title'],\n embed: ['url', 'type'],\n 'pdf-viewer': ['pdf'],\n 'excel-viewer': ['excel'],\n 'stat-cards': ['cards'],\n timeline: ['mode', 'items'],\n 'json-viewer': ['json', 'jsonString', 'title'],\n 'json-list': ['json', 'jsonString'],\n links: ['links'],\n 'qr-code': ['url', 'label'],\n 'social-handles': ['title', 'showLabels', 'iconSize', 'handles'],\n steps: ['steps'],\n trace: ['title', 'live', 'spans'],\n plan: ['title', 'status', 'breadcrumbs', 'phases'],\n notes: ['notes'],\n 'csv-viewer': ['csvText', 'csvData', 'fileName'],\n 'user-story': ['title', 'userStory', 'acceptanceCriteria'],\n chat: ['title', 'placeholder', 'linked_pin_id', 'linked_pin_title'],\n intro: ['heading', 'subheading'],\n mastra: ['mode', 'agentId', 'workflowId'],\n 'text-media': ['title', 'text', 'subtext', 'textPosition', 'mediaType', 'embedConfig', 'imageConfig'],\n 'business-card': ['sectionTitle', 'fields', 'imageConfig', 'imagePosition'],\n video: ['url', 'fileId', 'fileName', 'mimeType', 'caption', 'size'],\n audio: ['url', 'fileId', 'fileName', 'mimeType', 'caption', 'size', 'tracks'],\n 'file-upload': ['files', 'displayMode'],\n 'kanban-board': ['columns'],\n checklist: ['title', 'items'],\n comparison: ['title', 'left', 'right', 'highlightedLines', 'matches', 'showVsBadge'],\n calendar: ['weekStartsOn', 'events'],\n roadmap: ['title', 'months'],\n 'realtime-canvas': ['title', 'description', 'roomId'],\n}\n\nexport function pinTypeToMethodSuffix(pinType: PinTypeId): string {\n return pinType\n .split('-')\n .map((part) => part.charAt(0).toUpperCase() + part.slice(1))\n .join('')\n}\n\nfunction pickPinConfig<T extends PinTypeId>(\n pinType: T,\n input: Record<string, unknown>,\n): PinConfigByType[T] {\n const fields = PIN_CONFIG_FIELDS[pinType]\n const pin_config = {} as PinConfigByType[T]\n for (const key of fields) {\n if (key in input && input[key] !== undefined) {\n ;(pin_config as Record<string, unknown>)[key] = input[key]\n }\n }\n return pin_config\n}\n\nexport function toCreatePinRequest<T extends PinTypeId>(\n pinType: T,\n input: CreatePinHelperInput<T>,\n): CreateTypedPinRequest<T> {\n const raw = input as Record<string, unknown>\n const pin_config = pickPinConfig(pinType, raw)\n\n const metadata: PinMetadataBase = {\n title: input.title,\n tags: input.tags,\n description: input.description,\n allow_edit: input.allow_edit,\n require_sign_in: input.require_sign_in,\n allow_comments: input.allow_comments,\n }\n\n return {\n pin_type: pinType,\n pin_config,\n pin_layout: input.pin_layout,\n is_public: input.is_public,\n allow_edit: input.allow_edit,\n require_sign_in: input.require_sign_in,\n allow_comments: input.allow_comments,\n pending_invites: input.pending_invites,\n metadata,\n }\n}\n\nexport function toUpdatePinRequest<T extends PinTypeId>(\n pinType: T,\n input: UpdatePinHelperInput<T>,\n): UpdatePinRequest<T> {\n const raw = input as Record<string, unknown>\n const pin_config = pickPinConfig(pinType, raw) as PinConfigByType[T]\n const hasPinConfig = Object.keys(pin_config as object).length > 0\n\n const metadata: Partial<PinMetadataBase> = {\n ...(input.metadata ?? {}),\n }\n if (input.title !== undefined) metadata.title = input.title\n if (input.tags !== undefined) metadata.tags = input.tags\n if (input.description !== undefined) metadata.description = input.description\n\n const hasMetadata = Object.keys(metadata).length > 0\n\n return {\n pin_type: pinType,\n ...(hasPinConfig ? { pin_config } : {}),\n pin_layout: input.pin_layout,\n is_public: input.is_public,\n ...(hasMetadata ? { metadata } : {}),\n }\n}\n\nexport function attachNamedPinHelpers(ctor: { prototype: Record<string, unknown> }) {\n for (const pinType of PRODUCT_PIN_TYPES as readonly PinTypeId[]) {\n const suffix = pinTypeToMethodSuffix(pinType)\n ctor.prototype[`create${suffix}`] = function (\n this: { createPin: (t: PinTypeId, i: unknown) => unknown },\n input: unknown,\n ) {\n return this.createPin(pinType, input)\n }\n ctor.prototype[`update${suffix}`] = function (\n this: { updatePin: (id: string, t: PinTypeId, i: unknown) => unknown },\n pinId: string,\n input: unknown,\n ) {\n return this.updatePin(pinId, pinType, input)\n }\n }\n}\n","/**\n * Runtime hints + minimal examples per pin type.\n * Use when building API payloads without opening the docs every time.\n */\n\nimport type { PinConfigByType, PinTypeId, UpdatePinRequest } from './types/pins'\n\nexport interface PinConfigFieldHint {\n path: string\n type: string\n required: boolean\n description: string\n}\n\nexport interface PinConfigHint<T extends PinTypeId = PinTypeId> {\n pin_type: T\n summary: string\n required_fields: string[]\n optional_fields: string[]\n fields: PinConfigFieldHint[]\n /** Minimal valid pin_config for create/update */\n example_config: PinConfigByType[T]\n /** Typical PUT /v1/pins/:id body (root-level pin_config) */\n example_update: UpdatePinRequest<T>\n}\n\nconst TABLE_HINT: PinConfigHint<'table'> = {\n pin_type: 'table',\n summary: 'Spreadsheet-style pin. columns is required; rows are optional but needed for visible data.',\n required_fields: ['columns'],\n optional_fields: ['rows'],\n fields: [\n {\n path: 'columns',\n type: 'TableColumn[]',\n required: true,\n description: 'At least one column. Each column needs id + name (type optional, e.g. text | number).',\n },\n {\n path: 'columns[].id',\n type: 'string',\n required: true,\n description: 'Stable column key used in row.cells.',\n },\n {\n path: 'columns[].name',\n type: 'string',\n required: true,\n description: 'Column header label.',\n },\n {\n path: 'rows',\n type: 'TableRow[]',\n required: false,\n description: 'Table data. Each row: { id, cells: { [columnId]: value } }.',\n },\n ],\n example_config: {\n columns: [\n { id: 'col1', name: 'Name', type: 'text' },\n { id: 'col2', name: 'Value', type: 'number' },\n ],\n rows: [{ id: 'row1', cells: { col1: 'Item', col2: 1 } }],\n },\n example_update: {\n pin_config: {\n columns: [\n { id: 'col1', name: 'Name', type: 'text' },\n { id: 'col2', name: 'Value', type: 'number' },\n ],\n rows: [{ id: 'row1', cells: { col1: 'Updated', col2: 42 } }],\n },\n },\n}\n\n/** Per-type hints (expand over time; table is fully documented). */\nexport const PIN_CONFIG_HINTS: Partial<Record<PinTypeId, PinConfigHint>> = {\n table: TABLE_HINT,\n markdown: {\n pin_type: 'markdown',\n summary: 'Rich text / markdown body.',\n required_fields: [],\n optional_fields: ['content', 'collaboration'],\n fields: [\n {\n path: 'content',\n type: 'string',\n required: false,\n description: 'Markdown source. Server seeds Yjs when set on create.',\n },\n ],\n example_config: { content: '# Hello\\n\\nBody text.' },\n example_update: { pin_config: { content: '# Updated\\n\\nNew body.' } },\n },\n 'stat-cards': {\n pin_type: 'stat-cards',\n summary: 'KPI cards grid.',\n required_fields: ['cards'],\n optional_fields: [],\n fields: [\n {\n path: 'cards',\n type: 'StatCardItem[]',\n required: true,\n description: 'Each card: title, value; optional change, trend (up|down|neutral).',\n },\n ],\n example_config: {\n cards: [{ title: 'Revenue', value: '1000', change: '+5%', trend: 'up' }],\n },\n example_update: {\n pin_config: {\n cards: [{ title: 'Revenue', value: '1234', change: '+8%', trend: 'up' }],\n },\n },\n },\n}\n\nexport function getPinConfigHint<T extends PinTypeId>(pinType: T): PinConfigHint<T> | undefined {\n return PIN_CONFIG_HINTS[pinType] as PinConfigHint<T> | undefined\n}\n\n/** Pretty-print field hints for CLI / logging. */\nexport function formatPinConfigHint(pinType: PinTypeId): string {\n const hint = getPinConfigHint(pinType)\n if (!hint) {\n return [\n `No built-in hint for pin type \"${pinType}\".`,\n 'Use CreatePinRequest<typeof pinType> / PinConfigByType[typeof pinType] in TypeScript,',\n 'or client.pins.create({ pin_type, pin_config, metadata }) with typed pin_config.',\n ].join('\\n')\n }\n\n const lines = [\n `Pin type: ${hint.pin_type}`,\n hint.summary,\n '',\n 'Required pin_config fields:',\n ...hint.required_fields.map((f) => ` - ${f}`),\n '',\n 'Optional pin_config fields:',\n ...(hint.optional_fields.length ? hint.optional_fields.map((f) => ` - ${f}`) : [' (none documented)']),\n '',\n 'Field reference:',\n ...hint.fields.map(\n (f) => ` ${f.path} (${f.type}${f.required ? ', required' : ''}): ${f.description}`,\n ),\n '',\n 'Example update payload:',\n JSON.stringify(hint.example_update, null, 2),\n ]\n return lines.join('\\n')\n}\n","import { z } from 'zod'\n\n/** Unwrap optional/nullable/default/effects wrappers. */\nfunction unwrapSchema(schema: z.ZodTypeAny): z.ZodTypeAny {\n let current = schema\n for (;;) {\n if (current instanceof z.ZodOptional || current instanceof z.ZodNullable) {\n current = current.unwrap()\n continue\n }\n if (current instanceof z.ZodDefault) {\n current = current.removeDefault()\n continue\n }\n if (current instanceof z.ZodEffects) {\n current = current.innerType()\n continue\n }\n break\n }\n return current\n}\n\nconst llmEntryValue = (): z.ZodTypeAny =>\n z.union([z.string(), z.number(), z.boolean(), z.null()])\n\n/**\n * Convert API zod schemas → LLM-friendly schemas.\n * `z.record()` becomes `[{ key, value }]` because structured-output APIs struggle with open records.\n */\nexport function toLlmPinConfigSchema(schema: z.ZodTypeAny): z.ZodTypeAny {\n const base = unwrapSchema(schema)\n\n if (base instanceof z.ZodRecord) {\n return z.array(\n z.object({\n key: z.string(),\n value: llmEntryValue(),\n }),\n )\n }\n\n if (base instanceof z.ZodArray) {\n return z.array(toLlmPinConfigSchema(base.element))\n }\n\n if (base instanceof z.ZodObject) {\n const shape: Record<string, z.ZodTypeAny> = {}\n for (const [key, value] of Object.entries(base.shape)) {\n shape[key] = toLlmPinConfigSchema(value as z.ZodTypeAny)\n }\n if (base._def.unknownKeys === 'passthrough') {\n return z.object(shape).passthrough()\n }\n return z.object(shape)\n }\n\n return schema\n}\n\nfunction entriesArrayToRecord(data: unknown): Record<string, unknown> {\n const record: Record<string, unknown> = {}\n if (!Array.isArray(data)) return record\n for (const item of data) {\n if (!item || typeof item !== 'object') continue\n const entry = item as { key?: string; columnId?: string; value?: unknown }\n const key = entry.key ?? entry.columnId\n if (key == null) continue\n const value = entry.value\n record[key] =\n Array.isArray(value) && looksLikeEntryArray(value)\n ? entriesArrayToRecord(value)\n : value\n }\n return record\n}\n\nfunction looksLikeEntryArray(value: unknown[]): boolean {\n return value.every(\n (item) =>\n item &&\n typeof item === 'object' &&\n ('key' in item || 'columnId' in item),\n )\n}\n\nfunction normalizeRecordValue(value: unknown): unknown {\n if (Array.isArray(value) && looksLikeEntryArray(value)) {\n return entriesArrayToRecord(value)\n }\n if (value && typeof value === 'object' && !Array.isArray(value)) {\n const obj = value as Record<string, unknown>\n const out: Record<string, unknown> = {}\n for (const [k, v] of Object.entries(obj)) {\n out[k] = normalizeRecordValue(v)\n }\n return out\n }\n return value\n}\n\n/**\n * Convert LLM output back to API pin_config shape using the same API zod schema as guide.\n */\nexport function normalizeLlmPinConfigOutput(data: unknown, apiSchema: z.ZodTypeAny): unknown {\n if (data == null) return data\n\n const base = unwrapSchema(apiSchema)\n\n if (base instanceof z.ZodRecord) {\n if (Array.isArray(data)) return entriesArrayToRecord(data)\n return normalizeRecordValue(data)\n }\n\n if (base instanceof z.ZodArray) {\n if (!Array.isArray(data)) return data\n return data.map((item) => normalizeLlmPinConfigOutput(item, base.element))\n }\n\n if (base instanceof z.ZodObject) {\n if (!data || typeof data !== 'object' || Array.isArray(data)) return data\n const input = data as Record<string, unknown>\n const output: Record<string, unknown> = { ...input }\n for (const [key, fieldSchema] of Object.entries(base.shape)) {\n if (key in output) {\n output[key] = normalizeLlmPinConfigOutput(output[key], fieldSchema as z.ZodTypeAny)\n }\n }\n return output\n }\n\n return data\n}\n","export const PIN_TYPE_ITEM_LIMITS = {\n TABLE_MAX_ROWS: 100,\n KEY_VALUE_MAX_ITEMS: 48,\n CARDS_MAX_ITEMS: 24,\n TRACE_MAX_SPANS: 50,\n OKR_MAX_KEY_RESULTS: 50,\n GALLERY_MAX_IMAGES: 32,\n} as const\n","import { z } from \"zod\";\nimport { PIN_TYPE_ITEM_LIMITS } from \"./pin-config-limits\";\n\n/** Lightweight zod validators for `metadata.pin_config` — aligned with product + agents-content shapes. */\n\nconst looseObject = z.object({}).passthrough();\n\nexport const markdownPinConfigSchema = z\n .object({\n content: z.string().optional(),\n collaboration: z.object({ enabled: z.boolean().optional() }).optional(),\n })\n .passthrough();\n\nexport const statCardsPinConfigSchema = z\n .object({\n cards: z\n .array(\n z\n .object({\n title: z.string(),\n value: z.union([z.string(), z.number()]),\n })\n .passthrough(),\n )\n .min(1, \"stat-cards pin_config.cards must contain at least one card\"),\n })\n .passthrough();\n\nexport const imagePinConfigSchema = z\n .object({\n url: z.string().optional(),\n altText: z.string().optional(),\n fit: z.string().optional(),\n })\n .passthrough();\n\nexport const videoPinConfigSchema = z\n .object({\n url: z.string().min(1).optional(),\n fileId: z.string().optional(),\n fileName: z.string().optional(),\n mimeType: z.literal('video/mp4').optional(),\n caption: z.string().optional(),\n size: z.number().positive().optional(),\n })\n .passthrough();\n\nconst audioPinTrackSchema = z\n .object({\n url: z.string().min(1),\n fileId: z.string().optional(),\n fileName: z.string().optional(),\n mimeType: z.enum(['audio/mpeg', 'audio/wav', 'audio/x-wav']).optional(),\n size: z.number().positive().optional(),\n })\n .passthrough();\n\nexport const audioPinConfigSchema = z\n .object({\n url: z.string().min(1).optional(),\n fileId: z.string().optional(),\n fileName: z.string().optional(),\n mimeType: z.enum(['audio/mpeg', 'audio/wav', 'audio/x-wav']).optional(),\n caption: z.string().optional(),\n size: z.number().positive().optional(),\n tracks: z.array(audioPinTrackSchema).max(10).optional(),\n })\n .passthrough()\n .refine(\n (value) =>\n Boolean(String(value.url ?? '').trim()) ||\n (Array.isArray(value.tracks) && value.tracks.length > 0),\n { message: 'Audio pin requires url or at least one track' },\n );\n\nexport const tablePinConfigSchema = z\n .object({\n columns: z\n .array(\n z\n .object({\n id: z.string(),\n name: z.string(),\n type: z.string().optional(),\n })\n .passthrough(),\n )\n .min(1),\n rows: z\n .array(\n z\n .object({\n id: z.string(),\n cells: z\n .record(z.string(), z.union([z.string(), z.number(), z.boolean(), z.null()]))\n .refine((cells) => Object.keys(cells).length > 0, {\n message: 'each table row must include at least one cell value',\n }),\n })\n .passthrough(),\n )\n .min(1)\n .max(PIN_TYPE_ITEM_LIMITS.TABLE_MAX_ROWS)\n .optional(),\n })\n .passthrough();\n\nexport const chartsPinConfigSchema = z\n .object({\n chartType: z.string().optional(),\n data: z.array(z.record(z.string(), z.unknown())).optional(),\n })\n .passthrough();\n\nexport const embedPinConfigSchema = z\n .object({\n url: z.string().optional(),\n type: z.string().optional(),\n })\n .passthrough();\n\nexport const pdfViewerPinConfigSchema = z\n .object({\n pdf: z.object({ url: z.string().min(1) }).passthrough(),\n })\n .passthrough();\n\nexport const excelViewerPinConfigSchema = z\n .object({\n excel: z.object({ url: z.string().min(1) }).passthrough(),\n })\n .passthrough();\n\nexport const timelinePinConfigSchema = z\n .object({\n items: z.array(z.record(z.string(), z.unknown())).optional(),\n mode: z.string().optional(),\n })\n .passthrough();\n\nexport const jsonViewerPinConfigSchema = z\n .object({\n json: z.unknown().optional(),\n jsonString: z.string().optional(),\n title: z.string().optional(),\n })\n .passthrough();\n\nexport const jsonListPinConfigSchema = z\n .object({\n json: z.array(z.unknown()).optional(),\n jsonString: z.string().optional(),\n })\n .passthrough();\n\nexport const linksPinConfigSchema = z\n .object({\n links: z.array(z.record(z.string(), z.unknown())).optional(),\n })\n .passthrough();\n\nexport const stepsPinConfigSchema = z\n .object({\n steps: z.array(z.object({ title: z.string() }).passthrough()).min(1),\n })\n .passthrough();\n\nexport const tracePinConfigSchema = z\n .object({\n spans: z\n .array(\n z\n .object({\n name: z.string(),\n status: z.enum(['completed', 'running', 'pending', 'failed']),\n })\n .passthrough(),\n )\n .min(1, 'trace pin_config.spans must contain at least one span')\n .max(PIN_TYPE_ITEM_LIMITS.TRACE_MAX_SPANS),\n })\n .passthrough();\n\nconst planContentBlockSchema = z\n .object({\n type: z.enum(['details', 'command', 'code', 'text', 'link', 'mermaid', 'summary']),\n })\n .passthrough();\n\nconst planTaskSchema = z\n .object({\n title: z.string(),\n blocks: z.array(planContentBlockSchema).optional(),\n })\n .passthrough();\n\nexport const planPinConfigSchema = z\n .object({\n phases: z\n .array(\n z\n .object({\n title: z.string(),\n tasks: z.array(planTaskSchema).min(1),\n })\n .passthrough(),\n )\n .min(1, 'plan pin_config.phases must contain at least one phase'),\n })\n .passthrough();\n\nexport const notesPinConfigSchema = z\n .object({\n notes: z\n .array(\n z\n .object({\n title: z.string(),\n })\n .passthrough(),\n )\n .optional(),\n })\n .passthrough();\n\nexport const csvViewerPinConfigSchema = z\n .object({\n csvData: z.array(z.record(z.string(), z.unknown())).optional(),\n csvText: z.string().optional(),\n fileName: z.string().optional(),\n })\n .passthrough();\n\nexport const galleryPinConfigSchema = z\n .object({\n images: z\n .array(z.record(z.string(), z.unknown()))\n .max(PIN_TYPE_ITEM_LIMITS.GALLERY_MAX_IMAGES)\n .optional(),\n })\n .passthrough();\n\nexport const mermaidPinConfigSchema = z\n .object({\n code: z.string().optional(),\n diagram: z.string().optional(),\n title: z.string().optional(),\n })\n .passthrough()\n .refine((v) => Boolean(v.code?.trim() || v.diagram?.trim()), {\n message: \"mermaid pin_config requires code or diagram\",\n });\n\nexport const codePinConfigSchema = z\n .object({\n code: z.string().min(1),\n language: z.string().optional(),\n filename: z.string().optional(),\n title: z.string().optional(),\n })\n .passthrough();\n\nexport const userStoryPinConfigSchema = z\n .object({\n userStory: z.string().min(1),\n })\n .passthrough();\n\nexport const chatPinConfigSchema = z\n .object({\n title: z.string().optional(),\n placeholder: z.string().optional(),\n linked_pin_id: z.string().optional(),\n linked_pin_title: z.string().optional(),\n })\n .passthrough();\n\nexport const introPinConfigSchema = z\n .object({\n heading: z.string().min(1),\n })\n .passthrough();\n\nexport const textMediaPinConfigSchema = z\n .object({\n title: z.string().optional(),\n text: z.string().optional(),\n })\n .passthrough();\n\nexport const businessCardPinConfigSchema = z\n .object({\n sectionTitle: z.string().optional(),\n fields: z\n .array(\n z\n .object({\n id: z.string(),\n key: z.string(),\n value: z.string(),\n })\n .passthrough(),\n )\n .min(1),\n imagePosition: z.enum([\"left\", \"right\"]).optional(),\n })\n .passthrough();\n\nexport const qrCodePinConfigSchema = z\n .object({\n url: z.string().optional(),\n label: z.string().optional(),\n })\n .passthrough();\n\nexport const socialHandlesPinConfigSchema = z\n .object({\n title: z.string().optional(),\n showLabels: z.boolean().optional(),\n iconSize: z.number().optional(),\n handles: z\n .array(\n z\n .object({\n platform: z.string(),\n url: z.string(),\n label: z.string().optional(),\n })\n .passthrough(),\n )\n .optional(),\n })\n .passthrough();\n\nexport const fileUploadPinConfigSchema = z\n .object({\n files: z.array(z.record(z.string(), z.unknown())).optional(),\n displayMode: z.string().optional(),\n })\n .passthrough();\n\nexport const kanbanBoardPinConfigSchema = z\n .object({\n columns: z.array(z.object({ id: z.string(), title: z.string() }).passthrough()).min(1),\n })\n .passthrough();\n\nexport const checklistItemSchema = z\n .object({\n id: z.string(),\n name: z.string(),\n description: z.string().optional(),\n checked: z.boolean().optional(),\n })\n .passthrough();\n\nexport const checklistSectionSchema = z\n .object({\n id: z.string(),\n title: z.string(),\n label: z.string().optional(),\n items: z.array(checklistItemSchema).min(1),\n })\n .passthrough();\n\nexport const checklistPinConfigSchema = z\n .object({\n mode: z.enum([\"flat\", \"sections\"]).optional(),\n title: z.string().optional(),\n footer: z.string().optional(),\n items: z.array(checklistItemSchema).optional(),\n sections: z.array(checklistSectionSchema).optional(),\n })\n .passthrough()\n .superRefine((data, ctx) => {\n const mode = data.mode === \"sections\" ? \"sections\" : \"flat\";\n if (mode === \"sections\") {\n if (!Array.isArray(data.sections) || data.sections.length === 0) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: \"checklist sections mode requires at least one section\",\n });\n }\n return;\n }\n if (!Array.isArray(data.items) || data.items.length === 0) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: \"checklist flat mode requires at least one item\",\n });\n }\n });\n\nexport const cardsImageSchema = z\n .object({\n url: z.string(),\n alt: z.string().optional(),\n link: z.string().optional(),\n fileId: z.string().optional(),\n })\n .passthrough();\n\nexport const cardsItemSchema = z\n .object({\n id: z.string(),\n image: cardsImageSchema,\n title: z.string(),\n subtext: z.string().optional(),\n })\n .passthrough();\n\nexport const cardsPinConfigSchema = z\n .object({\n title: z.string().optional(),\n layout: z.enum([\"horizontal\", \"vertical\", \"gallery\"]).optional(),\n columns: z.union([z.literal(2), z.literal(3), z.literal(4)]).optional(),\n items: z\n .array(cardsItemSchema)\n .min(1)\n .max(PIN_TYPE_ITEM_LIMITS.CARDS_MAX_ITEMS),\n })\n .passthrough();\n\nexport const keyValueItemSchema = z\n .object({\n id: z.string(),\n key: z.string(),\n value: z.union([z.string(), z.number()]),\n unit: z.string().optional(),\n hint: z.string().optional(),\n })\n .passthrough();\n\nexport const keyValuePinConfigSchema = z\n .object({\n title: z.string().optional(),\n subtitle: z.string().optional(),\n period: z.string().optional(),\n layout: z.enum([\"list\", \"grid\"]).optional(),\n columns: z.union([z.literal(2), z.literal(3), z.literal(4)]).optional(),\n items: z\n .array(keyValueItemSchema)\n .min(1)\n .max(PIN_TYPE_ITEM_LIMITS.KEY_VALUE_MAX_ITEMS),\n })\n .passthrough();\n\nexport const faqItemSchema = z\n .object({\n id: z.string(),\n question: z.string(),\n answer: z.string(),\n })\n .passthrough();\n\nexport const faqPinConfigSchema = z\n .object({\n title: z.string().optional(),\n items: z.array(faqItemSchema).min(1),\n })\n .passthrough();\n\nexport const ctaButtonSchema = z\n .object({\n id: z.string(),\n label: z.string(),\n url: z.string(),\n variant: z.enum([\"primary\", \"secondary\", \"outline\"]).optional(),\n })\n .passthrough();\n\nexport const ctaPinConfigSchema = z\n .object({\n headline: z.string().optional(),\n subline: z.string().optional(),\n buttons: z.array(ctaButtonSchema).min(1).max(2),\n })\n .passthrough();\n\nexport const comparisonPinConfigSchema = z\n .object({\n title: z.string().optional(),\n left: z.object({ label: z.string(), body: z.string() }).passthrough(),\n right: z.object({ label: z.string(), body: z.string() }).passthrough(),\n highlightedLines: z\n .object({\n left: z.array(z.number().int().nonnegative()).optional(),\n right: z.array(z.number().int().nonnegative()).optional(),\n })\n .optional(),\n matches: z\n .array(\n z.object({\n left: z.number().int().nonnegative(),\n right: z.number().int().nonnegative(),\n }),\n )\n .optional(),\n showVsBadge: z.boolean().optional(),\n })\n .passthrough();\n\nexport const calendarPinConfigSchema = z\n .object({\n events: z.array(z.record(z.string(), z.unknown())).optional(),\n weekStartsOn: z.number().optional(),\n })\n .passthrough();\n\nexport const roadmapPinConfigSchema = z\n .object({\n months: z.array(z.record(z.string(), z.unknown())).optional(),\n title: z.string().optional(),\n })\n .passthrough();\n\nexport const processFlowPinConfigSchema = z\n .object({\n title: z.string().optional(),\n defaultView: z.enum([\"onboarding\", \"bottlenecks\"]).optional(),\n showTeam: z.boolean().optional(),\n team: z\n .array(\n z\n .object({\n id: z.string(),\n name: z.string(),\n role: z.string(),\n avatarUrl: z.string().optional(),\n status: z.enum([\"live\", \"away\", \"offline\"]).optional(),\n })\n .passthrough(),\n )\n .optional(),\n swimlanes: z\n .array(z.object({ id: z.string(), title: z.string() }).passthrough())\n .min(1),\n nodes: z\n .array(\n z\n .object({\n id: z.string(),\n swimlane: z.string(),\n label: z.string(),\n })\n .passthrough(),\n )\n .min(1),\n edges: z.array(z.object({ source: z.string(), target: z.string() }).passthrough()).optional(),\n })\n .passthrough();\n\nexport const funnelPinConfigSchema = z\n .object({\n title: z.string().optional(),\n subtitle: z.string().optional(),\n valueFormat: z.enum([\"number\", \"percent\", \"currency\"]).optional(),\n currency: z.string().optional(),\n highlightBiggestDrop: z.boolean().optional(),\n stages: z\n .array(\n z\n .object({\n id: z.string(),\n label: z.string(),\n value: z.number(),\n })\n .passthrough(),\n )\n .min(1),\n })\n .passthrough();\n\nexport const decisionMatrixPinConfigSchema = z\n .object({\n title: z.string().optional(),\n subtitle: z.string().optional(),\n maxScore: z.number().optional(),\n options: z\n .array(z.object({ id: z.string(), label: z.string() }).passthrough())\n .min(2),\n criteria: z\n .array(\n z\n .object({\n id: z.string(),\n label: z.string(),\n scores: z.record(z.string(), z.number()),\n })\n .passthrough(),\n )\n .min(1),\n })\n .passthrough();\n\nexport const okrPinConfigSchema = z\n .object({\n title: z.string().optional(),\n subtitle: z.string().optional(),\n period: z.string().optional(),\n objectives: z\n .array(\n z\n .object({\n id: z.string(),\n title: z.string(),\n keyResults: z.array(z.record(z.string(), z.unknown())).min(1),\n })\n .passthrough(),\n )\n .min(1),\n })\n .passthrough()\n .refine(\n (config) => {\n const objectives = Array.isArray(config.objectives) ? config.objectives : [];\n const keyResultCount = objectives.reduce(\n (sum, objective) =>\n sum + (Array.isArray(objective.keyResults) ? objective.keyResults.length : 0),\n 0,\n );\n return keyResultCount <= PIN_TYPE_ITEM_LIMITS.OKR_MAX_KEY_RESULTS;\n },\n {\n message: `okr pin_config supports at most ${PIN_TYPE_ITEM_LIMITS.OKR_MAX_KEY_RESULTS} key results total`,\n },\n );\n\nexport const pollPinConfigSchema = z\n .object({\n question: z.string().min(1),\n options: z\n .array(z.object({ id: z.string(), label: z.string() }).passthrough())\n .min(2),\n status: z.enum([\"open\", \"closed\"]).optional(),\n showVoteCount: z.boolean().optional(),\n allowChangeVote: z.boolean().optional(),\n })\n .passthrough();\n\nexport const ratingPinConfigSchema = z\n .object({\n title: z.string().optional(),\n description: z.string().optional(),\n prompt: z.string().optional(),\n items: z\n .array(\n z\n .object({\n id: z.string(),\n label: z.string(),\n description: z.string().optional(),\n required: z.boolean().optional(),\n })\n .passthrough(),\n )\n .optional(),\n status: z.enum([\"open\", \"closed\"]).optional(),\n maxStars: z.number().min(3).max(5).optional(),\n allowHalfStars: z.boolean().optional(),\n allowChangeRating: z.boolean().optional(),\n showAverage: z.boolean().optional(),\n })\n .passthrough();\n\nexport const surveyPinConfigSchema = z\n .object({\n title: z.string().optional(),\n description: z.string().optional(),\n status: z.enum([\"open\", \"closed\"]).optional(),\n allowEditResponse: z.boolean().optional(),\n questions: z\n .array(\n z\n .object({\n id: z.string(),\n label: z.string(),\n type: z.enum([\n \"short-text\",\n \"long-text\",\n \"single-choice\",\n \"multiple-choice\",\n \"scale\",\n ]),\n required: z.boolean().optional(),\n options: z\n .array(z.object({ id: z.string(), label: z.string() }).passthrough())\n .optional(),\n scaleMin: z.number().optional(),\n scaleMax: z.number().optional(),\n })\n .passthrough(),\n )\n .min(1),\n })\n .passthrough();\n\nexport const realtimeCanvasPinConfigSchema = z\n .object({\n title: z.string().optional(),\n description: z.string().optional(),\n roomId: z.string().optional(),\n })\n .passthrough();\n\nexport const mastraPinConfigSchema = looseObject;\n","import { z } from 'zod'\nimport type { PinTypeId } from '../types/pins'\nimport { toLlmPinConfigSchema } from './llm-schema-transform'\nimport {\n audioPinConfigSchema,\n businessCardPinConfigSchema,\n calendarPinConfigSchema,\n chartsPinConfigSchema,\n chatPinConfigSchema,\n checklistPinConfigSchema,\n codePinConfigSchema,\n comparisonPinConfigSchema,\n csvViewerPinConfigSchema,\n embedPinConfigSchema,\n excelViewerPinConfigSchema,\n fileUploadPinConfigSchema,\n galleryPinConfigSchema,\n imagePinConfigSchema,\n introPinConfigSchema,\n jsonListPinConfigSchema,\n jsonViewerPinConfigSchema,\n kanbanBoardPinConfigSchema,\n linksPinConfigSchema,\n markdownPinConfigSchema,\n mastraPinConfigSchema,\n mermaidPinConfigSchema,\n notesPinConfigSchema,\n pdfViewerPinConfigSchema,\n planPinConfigSchema,\n qrCodePinConfigSchema,\n realtimeCanvasPinConfigSchema,\n roadmapPinConfigSchema,\n socialHandlesPinConfigSchema,\n statCardsPinConfigSchema,\n stepsPinConfigSchema,\n tablePinConfigSchema,\n textMediaPinConfigSchema,\n timelinePinConfigSchema,\n tracePinConfigSchema,\n userStoryPinConfigSchema,\n videoPinConfigSchema,\n} from './pin-config-schemas'\n\n/** Zod validators for product pin types — aligned with backend PIN_CONFIG_SCHEMAS. */\nexport const PIN_CONFIG_ZOD_SCHEMAS: Record<PinTypeId, z.ZodTypeAny> = {\n markdown: markdownPinConfigSchema,\n image: imagePinConfigSchema,\n gallery: galleryPinConfigSchema,\n table: tablePinConfigSchema,\n charts: chartsPinConfigSchema,\n mermaid: mermaidPinConfigSchema,\n code: codePinConfigSchema,\n embed: embedPinConfigSchema,\n 'pdf-viewer': pdfViewerPinConfigSchema,\n 'excel-viewer': excelViewerPinConfigSchema,\n 'stat-cards': statCardsPinConfigSchema,\n timeline: timelinePinConfigSchema,\n 'json-viewer': jsonViewerPinConfigSchema,\n 'json-list': jsonListPinConfigSchema,\n links: linksPinConfigSchema,\n 'qr-code': qrCodePinConfigSchema,\n 'social-handles': socialHandlesPinConfigSchema,\n steps: stepsPinConfigSchema,\n trace: tracePinConfigSchema,\n plan: planPinConfigSchema,\n notes: notesPinConfigSchema,\n 'csv-viewer': csvViewerPinConfigSchema,\n 'user-story': userStoryPinConfigSchema,\n chat: chatPinConfigSchema,\n intro: introPinConfigSchema,\n mastra: mastraPinConfigSchema,\n 'text-media': textMediaPinConfigSchema,\n 'business-card': businessCardPinConfigSchema,\n video: videoPinConfigSchema,\n audio: audioPinConfigSchema,\n 'file-upload': fileUploadPinConfigSchema,\n 'kanban-board': kanbanBoardPinConfigSchema,\n checklist: checklistPinConfigSchema,\n comparison: comparisonPinConfigSchema,\n calendar: calendarPinConfigSchema,\n roadmap: roadmapPinConfigSchema,\n 'realtime-canvas': realtimeCanvasPinConfigSchema,\n}\n\nexport function getPinConfigZodSchema(pinType: PinTypeId): z.ZodTypeAny {\n return PIN_CONFIG_ZOD_SCHEMAS[pinType]\n}\n\n/** LLM structured-output schema (records → entry arrays). Validated output is normalized back via API schema. */\nexport function getLlmPinConfigZodSchema(pinType: PinTypeId): z.ZodTypeAny {\n return toLlmPinConfigSchema(getPinConfigZodSchema(pinType))\n}\n","import type { PinTypeId } from '../types/pins'\n\ntype Canonicalizer = (config: unknown) => unknown\n\n/** UI/API canonical shapes after generic LLM normalize (one entry per pin type that needs it). */\nconst PIN_CONFIG_CANONICAL_NORMALIZERS: Partial<Record<PinTypeId, Canonicalizer>> = {\n table: canonicalizeTablePinConfig,\n}\n\nexport function canonicalizePinConfigForApi(pinType: PinTypeId, config: unknown): unknown {\n const normalizer = PIN_CONFIG_CANONICAL_NORMALIZERS[pinType]\n return normalizer ? normalizer(config) : config\n}\n\nfunction canonicalizeTablePinConfig(config: unknown): unknown {\n if (!config || typeof config !== 'object') return config\n const table = config as {\n columns?: Array<{ id?: string; name?: string }>\n rows?: unknown[]\n }\n if (!Array.isArray(table.rows)) return config\n\n const columnIds = new Set(\n (table.columns ?? [])\n .map((col) => col?.id)\n .filter((id): id is string => Boolean(id)),\n )\n\n const rows = table.rows.map((row, index) => {\n if (!row || typeof row !== 'object' || Array.isArray(row)) return row\n const record = row as Record<string, unknown>\n const id = String(record.id ?? `row-${index + 1}`)\n\n if (record.cells && typeof record.cells === 'object' && !Array.isArray(record.cells)) {\n return { ...record, id, cells: record.cells as Record<string, unknown> }\n }\n\n const cells: Record<string, unknown> = {}\n for (const [key, value] of Object.entries(record)) {\n if (key === 'id') continue\n if (columnIds.size === 0 || columnIds.has(key)) {\n cells[key] = value\n }\n }\n\n return { id, cells }\n })\n\n return { ...table, rows }\n}\n","import type { LanguageModel } from 'ai'\n\nexport type AiProvider = 'google' | 'anthropic' | 'openai'\n\nexport interface LlmConfig {\n provider: AiProvider\n /** Model id, e.g. gemini-2.0-flash, claude-sonnet-4-20250514, gpt-4o */\n model: string\n /** Falls back to GOOGLE_GENERATIVE_AI_API_KEY / ANTHROPIC_API_KEY / OPENAI_API_KEY */\n apiKey?: string\n}\n\nconst PROVIDER_PACKAGES: Record<AiProvider, string> = {\n google: '@ai-sdk/google',\n anthropic: '@ai-sdk/anthropic',\n openai: '@ai-sdk/openai',\n}\n\nconst DEFAULT_ENV_KEYS: Record<AiProvider, string> = {\n google: 'GOOGLE_GENERATIVE_AI_API_KEY',\n anthropic: 'ANTHROPIC_API_KEY',\n openai: 'OPENAI_API_KEY',\n}\n\nasync function loadProviderFactory(provider: AiProvider): Promise<(opts?: { apiKey?: string }) => (model: string) => LanguageModel> {\n const pkg = PROVIDER_PACKAGES[provider]\n try {\n const mod = await import(pkg)\n if (provider === 'google') {\n return (opts) => mod.createGoogleGenerativeAI(opts)\n }\n if (provider === 'anthropic') {\n return (opts) => mod.createAnthropic(opts)\n }\n return (opts) => mod.createOpenAI(opts)\n } catch {\n throw new Error(\n `Missing optional dependency \"${pkg}\". Install it to use provider \"${provider}\" (npm install ${pkg} ai zod).`,\n )\n }\n}\n\n/** Prefer a valid-length key when both env vars are set (truncated keys are common in .env). */\nexport function resolveGoogleApiKey(): string | undefined {\n const candidates = [process.env.GOOGLE_GENERATIVE_AI_API_KEY, process.env.GOOGLE_API_KEY]\n .map((k) => k?.trim())\n .filter((k): k is string => Boolean(k))\n if (!candidates.length) return undefined\n const validAiza = candidates.find((k) => k.startsWith('AIzaSy') && k.length === 39)\n if (validAiza) return validAiza\n return candidates.sort((a, b) => b.length - a.length)[0]\n}\n\nexport async function resolveLanguageModel(config: LlmConfig): Promise<LanguageModel> {\n const apiKey =\n config.apiKey ??\n (config.provider === 'google'\n ? resolveGoogleApiKey()\n : process.env[DEFAULT_ENV_KEYS[config.provider]])\n if (!apiKey) {\n const googleHint =\n 'GOOGLE_GENERATIVE_AI_API_KEY or GOOGLE_API_KEY'\n throw new Error(\n `No API key for provider \"${config.provider}\". Pass llm.apiKey or set ${\n config.provider === 'google' ? googleHint : DEFAULT_ENV_KEYS[config.provider]\n }.`,\n )\n }\n const factory = await loadProviderFactory(config.provider)\n return factory({ apiKey })(config.model)\n}\n","import { generateObject } from 'ai'\nimport type { z } from 'zod'\nimport { formatPinConfigHint } from '../pin-config-hints'\nimport { PIN_CONFIG_FIELDS } from '../client/pins/pin-helper-core'\nimport type { PinConfigByType, PinTypeId } from '../types/pins'\nimport { getLlmPinConfigZodSchema, getPinConfigZodSchema } from './pin-config-zod-map'\nimport { canonicalizePinConfigForApi } from './pin-config-canonical'\nimport { normalizeLlmPinConfigOutput } from './llm-schema-transform'\nimport { resolveLanguageModel, type LlmConfig } from './providers'\n\nexport type PipeInput = string | Record<string, unknown> | unknown[] | unknown\n\nexport interface MaterializeOptions {\n system?: string\n temperature?: number\n maxRetries?: number\n}\n\nexport class PinConfigMaterializeError extends Error {\n readonly pinType: PinTypeId\n readonly zodError?: z.ZodError\n\n constructor(pinType: PinTypeId, message: string, zodError?: z.ZodError) {\n super(message)\n this.name = 'PinConfigMaterializeError'\n this.pinType = pinType\n this.zodError = zodError\n }\n}\n\nfunction serializePipeInput(input: PipeInput): string {\n if (typeof input === 'string') return input\n try {\n return JSON.stringify(input, null, 2)\n } catch {\n return String(input)\n }\n}\n\nfunction buildSystemPrompt(pinType: PinTypeId, override?: string): string {\n if (override) return override\n const fields = PIN_CONFIG_FIELDS[pinType].join(', ')\n return [\n `You convert arbitrary user text or JSON into a valid Pindown pin_config for pin_type \"${pinType}\".`,\n `Only output top-level pin_config fields for this type: ${fields}.`,\n 'Map user data faithfully. Invent stable string ids where needed (columns, rows, cards, etc.).',\n 'Where a field is a key-value map, output it as [{ key, value }, ...] (one entry per key).',\n 'Do not include metadata (title, tags) — only pin_config shape.',\n ].join(' ')\n}\n\ntype GenerateObjectFn = (opts: {\n model: unknown\n schema: z.ZodTypeAny\n temperature?: number\n maxRetries?: number\n system?: string\n prompt: string\n}) => Promise<{ object: unknown }>\n\nconst runGenerateObject = generateObject as unknown as GenerateObjectFn\n\nexport async function materializePinConfig<T extends PinTypeId>(\n input: PipeInput,\n pinType: T,\n llm: LlmConfig,\n options?: MaterializeOptions,\n): Promise<PinConfigByType[T]> {\n const apiSchema = getPinConfigZodSchema(pinType)\n const llmSchema = getLlmPinConfigZodSchema(pinType)\n const model = await resolveLanguageModel(llm)\n const hint = formatPinConfigHint(pinType)\n const inputText = serializePipeInput(input)\n\n const { object } = await runGenerateObject({\n model,\n schema: llmSchema,\n temperature: options?.temperature ?? 0,\n maxRetries: options?.maxRetries ?? 2,\n system: buildSystemPrompt(pinType, options?.system),\n prompt: [`Pin type: ${pinType}`, '', hint, '', 'User input:', inputText].join('\\n'),\n })\n\n const normalized = normalizeLlmPinConfigOutput(object, apiSchema)\n const canonical = canonicalizePinConfigForApi(pinType, normalized)\n const parsed = apiSchema.safeParse(canonical)\n if (!parsed.success) {\n throw new PinConfigMaterializeError(\n pinType,\n `LLM output failed validation for pin_type \"${pinType}\": ${parsed.error.message}`,\n parsed.error,\n )\n }\n\n return parsed.data as PinConfigByType[T]\n}\n","import type { PindownClient } from '../client/PindownClient'\nimport { PIN_CONFIG_FIELDS, pinTypeToMethodSuffix } from '../client/pins/pin-helper-core'\nimport { PRODUCT_PIN_TYPES } from '../types/pins'\nimport type {\n CreatePinHelperInput,\n Pin,\n PinConfigByType,\n PinTypeId,\n UpdatePinHelperInput,\n} from '../types/pins'\nimport type { ConfigPipeHelperMethods } from './pipe-types'\nimport { materializePinConfig, type MaterializeOptions, type PipeInput } from './materialize'\nimport type { LlmConfig } from './providers'\n\nexport type { PipeInput, MaterializeOptions } from './materialize'\nexport type { LlmConfig } from './providers'\nexport type { ConfigPipeHelperMethods } from './pipe-types'\n\nfunction mergeConfigIntoCreateInput<T extends PinTypeId>(\n pinType: T,\n materialized: PinConfigByType[T],\n input: CreatePinHelperInput<T>,\n): CreatePinHelperInput<T> {\n const merged = { ...input } as Record<string, unknown>\n for (const key of PIN_CONFIG_FIELDS[pinType]) {\n const fromInput = (input as Record<string, unknown>)[key]\n const fromLlm = (materialized as Record<string, unknown>)[key]\n merged[key] = fromInput !== undefined ? fromInput : fromLlm\n }\n return merged as CreatePinHelperInput<T>\n}\n\nfunction mergeConfigIntoUpdateInput<T extends PinTypeId>(\n pinType: T,\n materialized: PinConfigByType[T],\n input?: UpdatePinHelperInput<T>,\n): UpdatePinHelperInput<T> {\n const base = { ...(input ?? {}) } as Record<string, unknown>\n for (const key of PIN_CONFIG_FIELDS[pinType]) {\n const fromInput = input ? (input as Record<string, unknown>)[key] : undefined\n const fromLlm = (materialized as Record<string, unknown>)[key]\n if (fromInput !== undefined) {\n base[key] = fromInput\n } else if (fromLlm !== undefined) {\n base[key] = fromLlm\n }\n }\n return base as UpdatePinHelperInput<T>\n}\n\nexport class PinConfigPipe<T extends PinTypeId> {\n private client?: PindownClient\n private materializedPromise?: Promise<PinConfigByType[T]>\n\n constructor(\n private readonly input: PipeInput,\n readonly pinType: T,\n private readonly llm: LlmConfig,\n private readonly options?: MaterializeOptions,\n ) {}\n\n /** Attach a Pindown client for create/update helpers. */\n using(client: PindownClient): this {\n this.client = client\n return this\n }\n\n /** Alias for {@link using}. */\n with(client: PindownClient): this {\n return this.using(client)\n }\n\n /** Run the LLM once and return validated pin_config (cached on this pipe). */\n async materialize(): Promise<PinConfigByType[T]> {\n if (!this.materializedPromise) {\n this.materializedPromise = materializePinConfig(this.input, this.pinType, this.llm, this.options)\n }\n return this.materializedPromise\n }\n\n async createPin(\n input: CreatePinHelperInput<T>,\n client?: PindownClient,\n ): Promise<Pin<T>> {\n const c = client ?? this.requireClient()\n const pin_config = await this.materialize()\n return c.pins.createPin(this.pinType, mergeConfigIntoCreateInput(this.pinType, pin_config, input))\n }\n\n async updatePin(\n pinId: string,\n input?: UpdatePinHelperInput<T>,\n client?: PindownClient,\n ): Promise<Pin<T>> {\n const c = client ?? this.requireClient()\n const pin_config = await this.materialize()\n return c.pins.updatePin(\n pinId,\n this.pinType,\n mergeConfigIntoUpdateInput(this.pinType, pin_config, input),\n )\n }\n\n private requireClient(): PindownClient {\n if (!this.client) {\n throw new Error(\n 'Pindown client required. Call .using(client) first or pass client as the last argument.',\n )\n }\n return this.client\n }\n}\n\nfunction attachNamedPipeMethods(proto: PinConfigPipe<PinTypeId>): void {\n for (const pinType of PRODUCT_PIN_TYPES as readonly PinTypeId[]) {\n const suffix = pinTypeToMethodSuffix(pinType)\n const createMethod = `create${suffix}`\n const updateMethod = `update${suffix}`\n\n ;(proto as unknown as Record<string, unknown>)[createMethod] = function (\n this: PinConfigPipe<PinTypeId>,\n input: CreatePinHelperInput<typeof pinType>,\n client?: PindownClient,\n ) {\n if (this.pinType !== pinType) {\n throw new Error(`${createMethod}() requires pin type \"${pinType}\", got \"${this.pinType}\"`)\n }\n return this.createPin(input, client)\n }\n\n ;(proto as unknown as Record<string, unknown>)[updateMethod] = function (\n this: PinConfigPipe<PinTypeId>,\n pinId: string,\n input?: UpdatePinHelperInput<typeof pinType>,\n client?: PindownClient,\n ) {\n if (this.pinType !== pinType) {\n throw new Error(`${updateMethod}() requires pin type \"${pinType}\", got \"${this.pinType}\"`)\n }\n return this.updatePin(pinId, input, client)\n }\n }\n}\n\nattachNamedPipeMethods(PinConfigPipe.prototype)\n\n/**\n * Pipe arbitrary text or JSON through an LLM into a typed pin_config, then create or update pins.\n *\n * @example\n * ```ts\n * const pin = await toConfig(myJson, 'table', { provider: 'google', model: 'gemini-2.0-flash' })\n * .using(client)\n * .createTable({ title: 'Inventory' })\n *\n * await toConfig('weekly KPIs...', 'stat-cards', llm)\n * .using(client)\n * .updateStatCards(pinId)\n * ```\n */\nexport function toConfig<T extends PinTypeId>(\n input: PipeInput,\n pinType: T,\n llm: LlmConfig,\n options?: MaterializeOptions,\n): PinConfigPipe<T> & ConfigPipeHelperMethods {\n return new PinConfigPipe(input, pinType, llm, options) as PinConfigPipe<T> & ConfigPipeHelperMethods\n}\n\n/** Alias for {@link toConfig}. */\nexport const pipePinConfig = toConfig\n"]}
|
package/dist/index.cjs
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
'use strict';var C=["markdown","image","gallery","table","charts","mermaid","code","embed","pdf-viewer","excel-viewer","stat-cards","timeline","json-viewer","json-list","links","qr-code","social-handles","steps","trace","plan","notes","csv-viewer","user-story","chat","intro","mastra","text-media","business-card","video","audio","file-upload","kanban-board","checklist","comparison","calendar","roadmap","realtime-canvas"];[...C];var S={markdown:["content","collaboration"],image:["url","altText","fit"],gallery:["images"],table:["columns","rows"],charts:["chartType","data","xAxis","yAxis"],mermaid:["diagram","code","title"],code:["code","language","filename","title"],embed:["url","type"],"pdf-viewer":["pdf"],"excel-viewer":["excel"],"stat-cards":["cards"],timeline:["mode","items"],"json-viewer":["json","jsonString","title"],"json-list":["json","jsonString"],links:["links"],"qr-code":["url","label"],"social-handles":["title","showLabels","iconSize","handles"],steps:["steps"],trace:["title","live","spans"],plan:["title","status","breadcrumbs","phases"],notes:["notes"],"csv-viewer":["csvText","csvData","fileName"],"user-story":["title","userStory","acceptanceCriteria"],chat:["title","placeholder","linked_pin_id","linked_pin_title"],intro:["heading","subheading"],mastra:["mode","agentId","workflowId"],"text-media":["title","text","subtext","textPosition","mediaType","embedConfig","imageConfig"],"business-card":["sectionTitle","fields","imageConfig","imagePosition"],video:["url","fileId","fileName","mimeType","caption","size"],audio:["url","fileId","fileName","mimeType","caption","size","tracks"],"file-upload":["files","displayMode"],"kanban-board":["columns"],checklist:["title","items"],comparison:["title","left","right","highlightedLines","matches","showVsBadge"],calendar:["weekStartsOn","events"],roadmap:["title","months"],"realtime-canvas":["title","description","roomId"]};function v(t){return t.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join("")}function T(t,e){let i=S[t],n={};for(let a of i)a in e&&e[a]!==void 0&&(n[a]=e[a]);return n}function k(t,e){let n=T(t,e),a={title:e.title,tags:e.tags,description:e.description,allow_edit:e.allow_edit,require_sign_in:e.require_sign_in,allow_comments:e.allow_comments};return {pin_type:t,pin_config:n,pin_layout:e.pin_layout,is_public:e.is_public,allow_edit:e.allow_edit,require_sign_in:e.require_sign_in,allow_comments:e.allow_comments,pending_invites:e.pending_invites,metadata:a}}function b(t,e){let n=T(t,e),a=Object.keys(n).length>0,o={...e.metadata??{}};e.title!==void 0&&(o.title=e.title),e.tags!==void 0&&(o.tags=e.tags),e.description!==void 0&&(o.description=e.description);let s=Object.keys(o).length>0;return {...a?{pin_config:n}:{},pin_layout:e.pin_layout,is_public:e.is_public,...s?{metadata:o}:{}}}function x(t){for(let e of C){let i=v(e);t.prototype[`create${i}`]=function(n){return this.createPin(e,n)},t.prototype[`update${i}`]=function(n,a){return this.updatePin(n,e,a)};}}var y=class{constructor(e){this.client=e;}async create(e){return this.client.request("POST","/pins",e)}async createPin(e,i){return this.create(k(e,i))}async get(e){return this.client.request("GET",`/pins/${e}`)}async list(e){let i=new URLSearchParams;e?.limit&&i.append("limit",e.limit.toString()),e?.offset&&i.append("offset",e.offset.toString());let n=i.toString(),a=n?`/pins?${n}`:"/pins";return this.client.request("GET",a)}async update(e,i){return this.client.request("PUT",`/pins/${e}`,i)}async updatePin(e,i,n){return this.update(e,b(i,n))}async delete(e){return this.client.request("DELETE",`/pins/${e}`)}async share(e,i){return this.client.request("POST",`/pins/${e}/share`,i)}async batchGet(e){return this.client.request("POST","/pins/batch/get",{pin_ids:e})}async batchCreate(e){return this.client.request("POST","/pins/batch",{pins:e})}async batchUpdate(e){return this.client.request("PATCH","/pins/batch",{updates:e})}async batchDelete(e){return this.client.request("DELETE","/pins/batch",{pin_ids:e})}async createMarkdown(e){let{content:i,title:n,tags:a,description:o,pin_layout:s,is_public:r,allow_edit:l,require_sign_in:I,allow_comments:R,pending_invites:q}=e;return this.create({pin_type:"markdown",pin_config:{content:i},pin_layout:s,is_public:r,allow_edit:l,require_sign_in:I,allow_comments:R,pending_invites:q,metadata:{title:n,tags:a,description:o}})}async createStatCards(e){let{cards:i,title:n,tags:a,description:o,pin_layout:s,is_public:r}=e;return this.create({pin_type:"stat-cards",pin_config:{cards:i},pin_layout:s,is_public:r,metadata:{title:n,tags:a,description:o}})}async createTable(e){let{columns:i,rows:n,title:a,tags:o,description:s,pin_layout:r,is_public:l}=e;return this.create({pin_type:"table",pin_config:{columns:i,rows:n},pin_layout:r,is_public:l,metadata:{title:a,tags:o,description:s}})}async updateTable(e,i){return this.updatePin(e,"table",i)}async createEmbed(e){let{url:i,type:n,title:a,tags:o,description:s,pin_layout:r,is_public:l}=e;return this.create({pin_type:"embed",pin_config:{url:i,type:n},pin_layout:r,is_public:l,metadata:{title:a,tags:o,description:s}})}async createMarkdownLegacy(e,i){return this.createMarkdown({title:e,content:"",...i})}};x(y);var p=class extends Error{constructor(e){super(e),this.name="PindownError";}},g=class extends p{constructor(e="Authentication failed"){super(e),this.name="AuthenticationError";}},c=class extends p{constructor(e="Access forbidden"){super(e),this.name="ForbiddenError";}},u=class extends p{constructor(e){super(`${e} not found`),this.name="NotFoundError";}},P=class extends p{constructor(e,i){super(e),this.name="ValidationError",this.details=i;}},f=class extends p{constructor(e="Rate limit exceeded (429 RATE_LIMITED)"){super(e),this.name="RateLimitError";}},d=class extends p{constructor(e,i=500){super(e),this.name="ServerError",this.statusCode=i;}},m=class extends p{constructor(e="Network request failed"){super(e),this.name="NetworkError";}};var w=class{constructor(e){if(!e.apiKey)throw new Error("API key is required");this.config={apiKey:e.apiKey,baseURL:e.baseURL||"https://api.pindown.ai/v1",maxRetries:e.maxRetries??3,timeout:e.timeout??3e4},this.pins=new y(this);}async request(e,i,n){let a=`${this.config.baseURL}${i}`,o={Authorization:`Bearer ${this.config.apiKey}`};n&&(e==="POST"||e==="PUT"||e==="PATCH"||e==="DELETE")&&(o["Content-Type"]="application/json");let s={method:e,headers:o,signal:AbortSignal.timeout(this.config.timeout)};n&&(e==="POST"||e==="PUT"||e==="PATCH"||e==="DELETE")&&(s.body=JSON.stringify(n));try{let r=await fetch(a,s);return r.ok||await this.handleErrorResponse(r),(await r.json()).data}catch(r){throw r instanceof g||r instanceof c||r instanceof u||r instanceof P||r instanceof f||r instanceof d?r:r instanceof Error&&(r.name==="AbortError"||r.name==="TimeoutError")?new m("Request timeout"):new m(r instanceof Error?r.message:"Network request failed")}}async handleErrorResponse(e){let i;try{i=await e.json();}catch{i={message:e.statusText};}let n=i.error?.message||i.message||"Unknown error";switch(e.status){case 401:throw new g(n);case 403:throw new c(n);case 404:throw new u(n);case 400:case 422:throw new P(n,i.error?.details);case 429:throw new f(n);case 500:case 502:case 503:throw new d(n,e.status);default:throw new d(n,e.status)}}};var E={pin_type:"table",summary:"Spreadsheet-style pin. columns is required; rows are optional but needed for visible data.",required_fields:["columns"],optional_fields:["rows"],fields:[{path:"columns",type:"TableColumn[]",required:true,description:"At least one column. Each column needs id + name (type optional, e.g. text | number)."},{path:"columns[].id",type:"string",required:true,description:"Stable column key used in row.cells."},{path:"columns[].name",type:"string",required:true,description:"Column header label."},{path:"rows",type:"TableRow[]",required:false,description:"Table data. Each row: { id, cells: { [columnId]: value } }."}],example_config:{columns:[{id:"col1",name:"Name",type:"text"},{id:"col2",name:"Value",type:"number"}],rows:[{id:"row1",cells:{col1:"Item",col2:1}}]},example_update:{pin_config:{columns:[{id:"col1",name:"Name",type:"text"},{id:"col2",name:"Value",type:"number"}],rows:[{id:"row1",cells:{col1:"Updated",col2:42}}]}}},_={table:E,markdown:{pin_type:"markdown",summary:"Rich text / markdown body.",required_fields:[],optional_fields:["content","collaboration"],fields:[{path:"content",type:"string",required:false,description:"Markdown source. Server seeds Yjs when set on create."}],example_config:{content:`# Hello
|
|
1
|
+
'use strict';var zod=require('zod');var I=["markdown","image","gallery","table","charts","mermaid","code","embed","pdf-viewer","excel-viewer","stat-cards","timeline","json-viewer","json-list","links","qr-code","social-handles","steps","trace","plan","notes","csv-viewer","user-story","chat","intro","mastra","text-media","business-card","video","audio","file-upload","kanban-board","checklist","comparison","calendar","roadmap","realtime-canvas"],A=[...I];var In={markdown:["content","collaboration"],image:["url","altText","fit"],gallery:["images"],table:["columns","rows"],charts:["chartType","data","xAxis","yAxis"],mermaid:["diagram","code","title"],code:["code","language","filename","title"],embed:["url","type"],"pdf-viewer":["pdf"],"excel-viewer":["excel"],"stat-cards":["cards"],timeline:["mode","items"],"json-viewer":["json","jsonString","title"],"json-list":["json","jsonString"],links:["links"],"qr-code":["url","label"],"social-handles":["title","showLabels","iconSize","handles"],steps:["steps"],trace:["title","live","spans"],plan:["title","status","breadcrumbs","phases"],notes:["notes"],"csv-viewer":["csvText","csvData","fileName"],"user-story":["title","userStory","acceptanceCriteria"],chat:["title","placeholder","linked_pin_id","linked_pin_title"],intro:["heading","subheading"],mastra:["mode","agentId","workflowId"],"text-media":["title","text","subtext","textPosition","mediaType","embedConfig","imageConfig"],"business-card":["sectionTitle","fields","imageConfig","imagePosition"],video:["url","fileId","fileName","mimeType","caption","size"],audio:["url","fileId","fileName","mimeType","caption","size","tracks"],"file-upload":["files","displayMode"],"kanban-board":["columns"],checklist:["title","items"],comparison:["title","left","right","highlightedLines","matches","showVsBadge"],calendar:["weekStartsOn","events"],roadmap:["title","months"],"realtime-canvas":["title","description","roomId"]};function Sn(i){return i.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join("")}function v(i,e){let t=In[i],o={};for(let r of t)r in e&&e[r]!==void 0&&(o[r]=e[r]);return o}function E(i,e){let o=v(i,e),r={title:e.title,tags:e.tags,description:e.description,allow_edit:e.allow_edit,require_sign_in:e.require_sign_in,allow_comments:e.allow_comments};return {pin_type:i,pin_config:o,pin_layout:e.pin_layout,is_public:e.is_public,allow_edit:e.allow_edit,require_sign_in:e.require_sign_in,allow_comments:e.allow_comments,pending_invites:e.pending_invites,metadata:r}}function M(i,e){let o=v(i,e),r=Object.keys(o).length>0,s={...e.metadata??{}};e.title!==void 0&&(s.title=e.title),e.tags!==void 0&&(s.tags=e.tags),e.description!==void 0&&(s.description=e.description);let p=Object.keys(s).length>0;return {pin_type:i,...r?{pin_config:o}:{},pin_layout:e.pin_layout,is_public:e.is_public,...p?{metadata:s}:{}}}function q(i){for(let e of I){let t=Sn(e);i.prototype[`create${t}`]=function(o){return this.createPin(e,o)},i.prototype[`update${t}`]=function(o,r){return this.updatePin(o,e,r)};}}var Rn={table:jn};function L(i,e){let t=Rn[i];return t?t(e):e}function jn(i){if(!i||typeof i!="object")return i;let e=i;if(!Array.isArray(e.rows))return i;let t=new Set((e.columns??[]).map(r=>r?.id).filter(r=>!!r)),o=e.rows.map((r,s)=>{if(!r||typeof r!="object"||Array.isArray(r))return r;let p=r,a=String(p.id??`row-${s+1}`);if(p.cells&&typeof p.cells=="object"&&!Array.isArray(p.cells))return {...p,id:a,cells:p.cells};let l={};for(let[d,C]of Object.entries(p))d!=="id"&&(t.size===0||t.has(d))&&(l[d]=C);return {id:a,cells:l}});return {...e,rows:o}}var u={TABLE_MAX_ROWS:100,KEY_VALUE_MAX_ITEMS:48,CARDS_MAX_ITEMS:24,TRACE_MAX_SPANS:50,OKR_MAX_KEY_RESULTS:50,GALLERY_MAX_IMAGES:32};var An=zod.z.object({}).passthrough(),N=zod.z.object({content:zod.z.string().optional(),collaboration:zod.z.object({enabled:zod.z.boolean().optional()}).optional()}).passthrough(),B=zod.z.object({cards:zod.z.array(zod.z.object({title:zod.z.string(),value:zod.z.union([zod.z.string(),zod.z.number()])}).passthrough()).min(1,"stat-cards pin_config.cards must contain at least one card")}).passthrough(),U=zod.z.object({url:zod.z.string().optional(),altText:zod.z.string().optional(),fit:zod.z.string().optional()}).passthrough(),O=zod.z.object({url:zod.z.string().min(1).optional(),fileId:zod.z.string().optional(),fileName:zod.z.string().optional(),mimeType:zod.z.literal("video/mp4").optional(),caption:zod.z.string().optional(),size:zod.z.number().positive().optional()}).passthrough(),vn=zod.z.object({url:zod.z.string().min(1),fileId:zod.z.string().optional(),fileName:zod.z.string().optional(),mimeType:zod.z.enum(["audio/mpeg","audio/wav","audio/x-wav"]).optional(),size:zod.z.number().positive().optional()}).passthrough(),V=zod.z.object({url:zod.z.string().min(1).optional(),fileId:zod.z.string().optional(),fileName:zod.z.string().optional(),mimeType:zod.z.enum(["audio/mpeg","audio/wav","audio/x-wav"]).optional(),caption:zod.z.string().optional(),size:zod.z.number().positive().optional(),tracks:zod.z.array(vn).max(10).optional()}).passthrough().refine(i=>!!String(i.url??"").trim()||Array.isArray(i.tracks)&&i.tracks.length>0,{message:"Audio pin requires url or at least one track"}),H=zod.z.object({columns:zod.z.array(zod.z.object({id:zod.z.string(),name:zod.z.string(),type:zod.z.string().optional()}).passthrough()).min(1),rows:zod.z.array(zod.z.object({id:zod.z.string(),cells:zod.z.record(zod.z.string(),zod.z.union([zod.z.string(),zod.z.number(),zod.z.boolean(),zod.z.null()])).refine(i=>Object.keys(i).length>0,{message:"each table row must include at least one cell value"})}).passthrough()).min(1).max(u.TABLE_MAX_ROWS).optional()}).passthrough(),z=zod.z.object({chartType:zod.z.string().optional(),data:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).optional()}).passthrough(),D=zod.z.object({url:zod.z.string().optional(),type:zod.z.string().optional()}).passthrough(),$=zod.z.object({pdf:zod.z.object({url:zod.z.string().min(1)}).passthrough()}).passthrough(),Z=zod.z.object({excel:zod.z.object({url:zod.z.string().min(1)}).passthrough()}).passthrough(),F=zod.z.object({items:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).optional(),mode:zod.z.string().optional()}).passthrough(),G=zod.z.object({json:zod.z.unknown().optional(),jsonString:zod.z.string().optional(),title:zod.z.string().optional()}).passthrough(),K=zod.z.object({json:zod.z.array(zod.z.unknown()).optional(),jsonString:zod.z.string().optional()}).passthrough(),Y=zod.z.object({links:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).optional()}).passthrough(),X=zod.z.object({steps:zod.z.array(zod.z.object({title:zod.z.string()}).passthrough()).min(1)}).passthrough(),J=zod.z.object({spans:zod.z.array(zod.z.object({name:zod.z.string(),status:zod.z.enum(["completed","running","pending","failed"])}).passthrough()).min(1,"trace pin_config.spans must contain at least one span").max(u.TRACE_MAX_SPANS)}).passthrough(),En=zod.z.object({type:zod.z.enum(["details","command","code","text","link","mermaid","summary"])}).passthrough(),Mn=zod.z.object({title:zod.z.string(),blocks:zod.z.array(En).optional()}).passthrough(),W=zod.z.object({phases:zod.z.array(zod.z.object({title:zod.z.string(),tasks:zod.z.array(Mn).min(1)}).passthrough()).min(1,"plan pin_config.phases must contain at least one phase")}).passthrough(),Q=zod.z.object({notes:zod.z.array(zod.z.object({title:zod.z.string()}).passthrough()).optional()}).passthrough(),nn=zod.z.object({csvData:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).optional(),csvText:zod.z.string().optional(),fileName:zod.z.string().optional()}).passthrough(),en=zod.z.object({images:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).max(u.GALLERY_MAX_IMAGES).optional()}).passthrough(),tn=zod.z.object({code:zod.z.string().optional(),diagram:zod.z.string().optional(),title:zod.z.string().optional()}).passthrough().refine(i=>!!(i.code?.trim()||i.diagram?.trim()),{message:"mermaid pin_config requires code or diagram"}),on=zod.z.object({code:zod.z.string().min(1),language:zod.z.string().optional(),filename:zod.z.string().optional(),title:zod.z.string().optional()}).passthrough(),rn=zod.z.object({userStory:zod.z.string().min(1)}).passthrough(),an=zod.z.object({title:zod.z.string().optional(),placeholder:zod.z.string().optional(),linked_pin_id:zod.z.string().optional(),linked_pin_title:zod.z.string().optional()}).passthrough(),sn=zod.z.object({heading:zod.z.string().min(1)}).passthrough(),pn=zod.z.object({title:zod.z.string().optional(),text:zod.z.string().optional()}).passthrough(),ln=zod.z.object({sectionTitle:zod.z.string().optional(),fields:zod.z.array(zod.z.object({id:zod.z.string(),key:zod.z.string(),value:zod.z.string()}).passthrough()).min(1),imagePosition:zod.z.enum(["left","right"]).optional()}).passthrough(),cn=zod.z.object({url:zod.z.string().optional(),label:zod.z.string().optional()}).passthrough(),gn=zod.z.object({title:zod.z.string().optional(),showLabels:zod.z.boolean().optional(),iconSize:zod.z.number().optional(),handles:zod.z.array(zod.z.object({platform:zod.z.string(),url:zod.z.string(),label:zod.z.string().optional()}).passthrough()).optional()}).passthrough(),dn=zod.z.object({files:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).optional(),displayMode:zod.z.string().optional()}).passthrough(),un=zod.z.object({columns:zod.z.array(zod.z.object({id:zod.z.string(),title:zod.z.string()}).passthrough()).min(1)}).passthrough(),mn=zod.z.object({id:zod.z.string(),name:zod.z.string(),description:zod.z.string().optional(),checked:zod.z.boolean().optional()}).passthrough(),qn=zod.z.object({id:zod.z.string(),title:zod.z.string(),label:zod.z.string().optional(),items:zod.z.array(mn).min(1)}).passthrough(),fn=zod.z.object({mode:zod.z.enum(["flat","sections"]).optional(),title:zod.z.string().optional(),footer:zod.z.string().optional(),items:zod.z.array(mn).optional(),sections:zod.z.array(qn).optional()}).passthrough().superRefine((i,e)=>{if((i.mode==="sections"?"sections":"flat")==="sections"){(!Array.isArray(i.sections)||i.sections.length===0)&&e.addIssue({code:zod.z.ZodIssueCode.custom,message:"checklist sections mode requires at least one section"});return}(!Array.isArray(i.items)||i.items.length===0)&&e.addIssue({code:zod.z.ZodIssueCode.custom,message:"checklist flat mode requires at least one item"});}),Ln=zod.z.object({url:zod.z.string(),alt:zod.z.string().optional(),link:zod.z.string().optional(),fileId:zod.z.string().optional()}).passthrough(),Nn=zod.z.object({id:zod.z.string(),image:Ln,title:zod.z.string(),subtext:zod.z.string().optional()}).passthrough();zod.z.object({title:zod.z.string().optional(),layout:zod.z.enum(["horizontal","vertical","gallery"]).optional(),columns:zod.z.union([zod.z.literal(2),zod.z.literal(3),zod.z.literal(4)]).optional(),items:zod.z.array(Nn).min(1).max(u.CARDS_MAX_ITEMS)}).passthrough();var Bn=zod.z.object({id:zod.z.string(),key:zod.z.string(),value:zod.z.union([zod.z.string(),zod.z.number()]),unit:zod.z.string().optional(),hint:zod.z.string().optional()}).passthrough();zod.z.object({title:zod.z.string().optional(),subtitle:zod.z.string().optional(),period:zod.z.string().optional(),layout:zod.z.enum(["list","grid"]).optional(),columns:zod.z.union([zod.z.literal(2),zod.z.literal(3),zod.z.literal(4)]).optional(),items:zod.z.array(Bn).min(1).max(u.KEY_VALUE_MAX_ITEMS)}).passthrough();var Un=zod.z.object({id:zod.z.string(),question:zod.z.string(),answer:zod.z.string()}).passthrough();zod.z.object({title:zod.z.string().optional(),items:zod.z.array(Un).min(1)}).passthrough();var On=zod.z.object({id:zod.z.string(),label:zod.z.string(),url:zod.z.string(),variant:zod.z.enum(["primary","secondary","outline"]).optional()}).passthrough();zod.z.object({headline:zod.z.string().optional(),subline:zod.z.string().optional(),buttons:zod.z.array(On).min(1).max(2)}).passthrough();var Pn=zod.z.object({title:zod.z.string().optional(),left:zod.z.object({label:zod.z.string(),body:zod.z.string()}).passthrough(),right:zod.z.object({label:zod.z.string(),body:zod.z.string()}).passthrough(),highlightedLines:zod.z.object({left:zod.z.array(zod.z.number().int().nonnegative()).optional(),right:zod.z.array(zod.z.number().int().nonnegative()).optional()}).optional(),matches:zod.z.array(zod.z.object({left:zod.z.number().int().nonnegative(),right:zod.z.number().int().nonnegative()})).optional(),showVsBadge:zod.z.boolean().optional()}).passthrough(),yn=zod.z.object({events:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).optional(),weekStartsOn:zod.z.number().optional()}).passthrough(),hn=zod.z.object({months:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).optional(),title:zod.z.string().optional()}).passthrough();zod.z.object({title:zod.z.string().optional(),defaultView:zod.z.enum(["onboarding","bottlenecks"]).optional(),showTeam:zod.z.boolean().optional(),team:zod.z.array(zod.z.object({id:zod.z.string(),name:zod.z.string(),role:zod.z.string(),avatarUrl:zod.z.string().optional(),status:zod.z.enum(["live","away","offline"]).optional()}).passthrough()).optional(),swimlanes:zod.z.array(zod.z.object({id:zod.z.string(),title:zod.z.string()}).passthrough()).min(1),nodes:zod.z.array(zod.z.object({id:zod.z.string(),swimlane:zod.z.string(),label:zod.z.string()}).passthrough()).min(1),edges:zod.z.array(zod.z.object({source:zod.z.string(),target:zod.z.string()}).passthrough()).optional()}).passthrough();zod.z.object({title:zod.z.string().optional(),subtitle:zod.z.string().optional(),valueFormat:zod.z.enum(["number","percent","currency"]).optional(),currency:zod.z.string().optional(),highlightBiggestDrop:zod.z.boolean().optional(),stages:zod.z.array(zod.z.object({id:zod.z.string(),label:zod.z.string(),value:zod.z.number()}).passthrough()).min(1)}).passthrough();zod.z.object({title:zod.z.string().optional(),subtitle:zod.z.string().optional(),maxScore:zod.z.number().optional(),options:zod.z.array(zod.z.object({id:zod.z.string(),label:zod.z.string()}).passthrough()).min(2),criteria:zod.z.array(zod.z.object({id:zod.z.string(),label:zod.z.string(),scores:zod.z.record(zod.z.string(),zod.z.number())}).passthrough()).min(1)}).passthrough();zod.z.object({title:zod.z.string().optional(),subtitle:zod.z.string().optional(),period:zod.z.string().optional(),objectives:zod.z.array(zod.z.object({id:zod.z.string(),title:zod.z.string(),keyResults:zod.z.array(zod.z.record(zod.z.string(),zod.z.unknown())).min(1)}).passthrough()).min(1)}).passthrough().refine(i=>(Array.isArray(i.objectives)?i.objectives:[]).reduce((o,r)=>o+(Array.isArray(r.keyResults)?r.keyResults.length:0),0)<=u.OKR_MAX_KEY_RESULTS,{message:`okr pin_config supports at most ${u.OKR_MAX_KEY_RESULTS} key results total`});zod.z.object({question:zod.z.string().min(1),options:zod.z.array(zod.z.object({id:zod.z.string(),label:zod.z.string()}).passthrough()).min(2),status:zod.z.enum(["open","closed"]).optional(),showVoteCount:zod.z.boolean().optional(),allowChangeVote:zod.z.boolean().optional()}).passthrough();zod.z.object({title:zod.z.string().optional(),description:zod.z.string().optional(),prompt:zod.z.string().optional(),items:zod.z.array(zod.z.object({id:zod.z.string(),label:zod.z.string(),description:zod.z.string().optional(),required:zod.z.boolean().optional()}).passthrough()).optional(),status:zod.z.enum(["open","closed"]).optional(),maxStars:zod.z.number().min(3).max(5).optional(),allowHalfStars:zod.z.boolean().optional(),allowChangeRating:zod.z.boolean().optional(),showAverage:zod.z.boolean().optional()}).passthrough();zod.z.object({title:zod.z.string().optional(),description:zod.z.string().optional(),status:zod.z.enum(["open","closed"]).optional(),allowEditResponse:zod.z.boolean().optional(),questions:zod.z.array(zod.z.object({id:zod.z.string(),label:zod.z.string(),type:zod.z.enum(["short-text","long-text","single-choice","multiple-choice","scale"]),required:zod.z.boolean().optional(),options:zod.z.array(zod.z.object({id:zod.z.string(),label:zod.z.string()}).passthrough()).optional(),scaleMin:zod.z.number().optional(),scaleMax:zod.z.number().optional()}).passthrough()).min(1)}).passthrough();var bn=zod.z.object({title:zod.z.string().optional(),description:zod.z.string().optional(),roomId:zod.z.string().optional()}).passthrough(),Cn=An;var Vn={markdown:N,image:U,gallery:en,table:H,charts:z,mermaid:tn,code:on,embed:D,"pdf-viewer":$,"excel-viewer":Z,"stat-cards":B,timeline:F,"json-viewer":G,"json-list":K,links:Y,"qr-code":cn,"social-handles":gn,steps:X,trace:J,plan:W,notes:Q,"csv-viewer":nn,"user-story":rn,chat:an,intro:sn,mastra:Cn,"text-media":pn,"business-card":ln,video:O,audio:V,"file-upload":dn,"kanban-board":un,checklist:fn,comparison:Pn,calendar:yn,roadmap:hn,"realtime-canvas":bn};function wn(i){return Vn[i]}var g=class extends Error{constructor(e){super(e),this.name="PindownError";}},P=class extends g{constructor(e="Authentication failed"){super(e),this.name="AuthenticationError";}},y=class extends g{constructor(e="Access forbidden"){super(e),this.name="ForbiddenError";}},h=class extends g{constructor(e){super(`${e} not found`),this.name="NotFoundError";}},c=class extends g{constructor(e,t){super(e),this.name="ValidationError",this.details=t;}},m=class extends g{constructor(e="Rate limit exceeded (429 RATE_LIMITED)"){super(e),this.name="RateLimitError";}},f=class extends g{constructor(e,t=500){super(e),this.name="ServerError",this.statusCode=t;}},b=class extends g{constructor(e="Network request failed"){super(e),this.name="NetworkError";}};function S(i){return A.includes(i)}function Hn(i,e){let t=e.issues[0],o=t?.path?.length?t.path.join("."):"pin_config";return `Invalid pin_config for pin_type "${i}" at ${o}: ${t?.message??"validation failed"}`}function Tn(i,e){if(!S(i))return {valid:false,pinType:i,message:`Unsupported pin_type "${i}"`};let t=e??{};if(typeof t!="object"||t===null||Array.isArray(t))return {valid:false,pinType:i,message:"pin_config must be a JSON object"};let o=L(i,t),s=wn(i).safeParse(o);return s.success?{valid:true,data:s.data}:{valid:false,pinType:i,message:Hn(i,s.error),details:s.error.flatten()}}function R(i,e){let t=Tn(i,e);if(!t.valid)throw new c(t.message,{code:"PIN_CONFIG_INVALID",pin_type:t.pinType,details:t.details});return t.data}function zn(i){let e="pin_type"in i?i.pin_type:void 0,t=i.metadata,o=e??t?.pin_type;if(!o)throw new c("pin_type is required when creating a pin",{code:"PIN_TYPE_REQUIRED"});if(!S(o))throw new c(`Unsupported pin_type "${o}"`,{code:"INVALID_PIN_TYPE"});return o}function Dn(i){return "pin_config"in i&&i.pin_config!==void 0?i.pin_config:i.metadata?.pin_config??{}}function T(i){let e=i.metadata?.title?.trim();if(!e)throw new c("metadata.title is required when creating a pin",{code:"METADATA_TITLE_REQUIRED"});let t=zn(i),o=R(t,Dn(i));return "pin_type"in i&&i.pin_type?{...i,pin_type:t,pin_config:o,metadata:{...i.metadata,title:e}}:{...i,metadata:{...i.metadata,title:e,pin_type:t,pin_config:o}}}function k(i,e){if(i.pin_config===void 0)return i;let t=e??i.pin_type;if(!t)throw new c("pin_type is required when updating pin_config",{code:"PIN_TYPE_REQUIRED"});if(!S(t))throw new c(`Unsupported pin_type "${t}"`,{code:"INVALID_PIN_TYPE"});let o=R(t,i.pin_config);return {...i,pin_type:t,pin_config:o}}var w=class{constructor(e){this.client=e;}async create(e){let t=T(e);return this.client.request("POST","/pins",t)}async createPin(e,t){return this.create(E(e,t))}async get(e){return this.client.request("GET",`/pins/${e}`)}async list(e){let t=new URLSearchParams;e?.limit&&t.append("limit",e.limit.toString()),e?.offset&&t.append("offset",e.offset.toString());let o=t.toString(),r=o?`/pins?${o}`:"/pins";return this.client.request("GET",r)}async update(e,t){let o=k(t);return this.client.request("PUT",`/pins/${e}`,o)}async updatePin(e,t,o){return this.update(e,M(t,o))}async delete(e){return this.client.request("DELETE",`/pins/${e}`)}async share(e,t){return this.client.request("POST",`/pins/${e}/share`,t)}async batchGet(e){return this.client.request("POST","/pins/batch/get",{pin_ids:e})}async batchCreate(e){let t=e.map(o=>T(o));return this.client.request("POST","/pins/batch",{pins:t})}async batchUpdate(e){let t=e.map(({id:o,...r})=>({id:o,...k(r)}));return this.client.request("PATCH","/pins/batch",{updates:t})}async batchDelete(e){return this.client.request("DELETE","/pins/batch",{pin_ids:e})}async createMarkdown(e){let{content:t,title:o,tags:r,description:s,pin_layout:p,is_public:a,allow_edit:l,require_sign_in:d,allow_comments:C,pending_invites:_}=e;return this.create({pin_type:"markdown",pin_config:{content:t},pin_layout:p,is_public:a,allow_edit:l,require_sign_in:d,allow_comments:C,pending_invites:_,metadata:{title:o,tags:r,description:s}})}async createStatCards(e){let{cards:t,title:o,tags:r,description:s,pin_layout:p,is_public:a}=e;return this.create({pin_type:"stat-cards",pin_config:{cards:t},pin_layout:p,is_public:a,metadata:{title:o,tags:r,description:s}})}async createTable(e){let{columns:t,rows:o,title:r,tags:s,description:p,pin_layout:a,is_public:l}=e;return this.create({pin_type:"table",pin_config:{columns:t,rows:o},pin_layout:a,is_public:l,metadata:{title:r,tags:s,description:p}})}async updateTable(e,t){return this.updatePin(e,"table",t)}async createEmbed(e){let{url:t,type:o,title:r,tags:s,description:p,pin_layout:a,is_public:l}=e;return this.create({pin_type:"embed",pin_config:{url:t,type:o},pin_layout:a,is_public:l,metadata:{title:r,tags:s,description:p}})}async createMarkdownLegacy(e,t){return this.createMarkdown({title:e,content:"",...t})}};q(w);var kn={windowMs:6e4,buckets:{read_standard:{maxPerWindow:120},read_batch:{maxPerWindow:60},write_core:{maxPerWindow:90},fallback_read:{maxPerWindow:120},fallback_write:{maxPerWindow:90}}};function $n(i){return i.split("?")[0]||i}function Zn(i,e){let t=i.toUpperCase(),o=$n(e);return t==="POST"&&o==="/pins/batch/get"?"read_batch":t==="GET"&&o==="/pins"||t==="GET"&&/^\/pins\/[^/]+$/.test(o)||t==="GET"&&/^\/pins\/[^/]+\/collaborators$/.test(o)||t==="GET"&&/^\/pins\/[^/]+\/permissions$/.test(o)?"read_standard":t==="POST"&&o==="/pins"||t==="PUT"&&/^\/pins\/[^/]+$/.test(o)||t==="DELETE"&&/^\/pins\/[^/]+$/.test(o)||t==="POST"&&/^\/pins\/[^/]+\/share$/.test(o)||t==="POST"&&o==="/pins/batch"||t==="PATCH"&&o==="/pins/batch"||t==="DELETE"&&o==="/pins/batch"||t==="POST"&&/^\/pins\/[^/]+\/collaborators$/.test(o)||t==="PUT"&&/^\/pins\/[^/]+\/collaborators\/[^/]+$/.test(o)||t==="DELETE"&&/^\/pins\/[^/]+\/collaborators\/[^/]+$/.test(o)?"write_core":t==="GET"||t==="HEAD"||t==="OPTIONS"?"fallback_read":"fallback_write"}var x=class{constructor(e){this.eventsByBucket=new Map;this.config={windowMs:e?.windowMs??kn.windowMs,buckets:{...kn.buckets,...e?.buckets??{}}};}consume(e,t,o=Date.now()){let r=Zn(e,t),s=this.config.buckets[r].maxPerWindow,p=o-this.config.windowMs,l=(this.eventsByBucket.get(r)??[]).filter(d=>d>p);if(l.length>=s){let d=l[0],C=Math.max(1e3,d+this.config.windowMs-o),_=Math.ceil(C/1e3);throw new m(`CLIENT_RATE_LIMITED: local ${r} limit exceeded (${s}/${Math.round(this.config.windowMs/1e3)}s). Retry in ~${_}s.`)}l.push(o),this.eventsByBucket.set(r,l);}};var j=class{constructor(e){if(!e.apiKey)throw new Error("API key is required");this.config={apiKey:e.apiKey,baseURL:e.baseURL||"https://api.pindown.ai/v1",maxRetries:e.maxRetries??3,timeout:e.timeout??3e4},this.rateLimiter=new x,this.pins=new w(this);}async request(e,t,o){this.rateLimiter.consume(e,t);let r=`${this.config.baseURL}${t}`,s={Authorization:`Bearer ${this.config.apiKey}`};o&&(e==="POST"||e==="PUT"||e==="PATCH"||e==="DELETE")&&(s["Content-Type"]="application/json");let p={method:e,headers:s,signal:AbortSignal.timeout(this.config.timeout)};o&&(e==="POST"||e==="PUT"||e==="PATCH"||e==="DELETE")&&(p.body=JSON.stringify(o));try{let a=await fetch(r,p);return a.ok||await this.handleErrorResponse(a),(await a.json()).data}catch(a){throw a instanceof P||a instanceof y||a instanceof h||a instanceof c||a instanceof m||a instanceof f?a:a instanceof Error&&(a.name==="AbortError"||a.name==="TimeoutError")?new b("Request timeout"):new b(a instanceof Error?a.message:"Network request failed")}}async handleErrorResponse(e){let t;try{t=await e.json();}catch{t={message:e.statusText};}let o=t.error?.message||t.message||"Unknown error";switch(e.status){case 401:throw new P(o);case 403:throw new y(o);case 404:throw new h(o);case 400:case 422:throw new c(o,t.error?.details);case 429:throw new m(o);case 500:case 502:case 503:throw new f(o,e.status);default:throw new f(o,e.status)}}};var Fn={pin_type:"table",summary:"Spreadsheet-style pin. columns is required; rows are optional but needed for visible data.",required_fields:["columns"],optional_fields:["rows"],fields:[{path:"columns",type:"TableColumn[]",required:true,description:"At least one column. Each column needs id + name (type optional, e.g. text | number)."},{path:"columns[].id",type:"string",required:true,description:"Stable column key used in row.cells."},{path:"columns[].name",type:"string",required:true,description:"Column header label."},{path:"rows",type:"TableRow[]",required:false,description:"Table data. Each row: { id, cells: { [columnId]: value } }."}],example_config:{columns:[{id:"col1",name:"Name",type:"text"},{id:"col2",name:"Value",type:"number"}],rows:[{id:"row1",cells:{col1:"Item",col2:1}}]},example_update:{pin_config:{columns:[{id:"col1",name:"Name",type:"text"},{id:"col2",name:"Value",type:"number"}],rows:[{id:"row1",cells:{col1:"Updated",col2:42}}]}}},xn={table:Fn,markdown:{pin_type:"markdown",summary:"Rich text / markdown body.",required_fields:[],optional_fields:["content","collaboration"],fields:[{path:"content",type:"string",required:false,description:"Markdown source. Server seeds Yjs when set on create."}],example_config:{content:`# Hello
|
|
2
2
|
|
|
3
3
|
Body text.`},example_update:{pin_config:{content:`# Updated
|
|
4
4
|
|
|
5
|
-
New body.`}}},"stat-cards":{pin_type:"stat-cards",summary:"KPI cards grid.",required_fields:["cards"],optional_fields:[],fields:[{path:"cards",type:"StatCardItem[]",required:true,description:"Each card: title, value; optional change, trend (up|down|neutral)."}],example_config:{cards:[{title:"Revenue",value:"1000",change:"+5%",trend:"up"}]},example_update:{pin_config:{cards:[{title:"Revenue",value:"1234",change:"+8%",trend:"up"}]}}}};function
|
|
6
|
-
`):[`No built-in hint for pin type "${
|
|
7
|
-
`)}exports.AuthenticationError=
|
|
5
|
+
New body.`}}},"stat-cards":{pin_type:"stat-cards",summary:"KPI cards grid.",required_fields:["cards"],optional_fields:[],fields:[{path:"cards",type:"StatCardItem[]",required:true,description:"Each card: title, value; optional change, trend (up|down|neutral)."}],example_config:{cards:[{title:"Revenue",value:"1000",change:"+5%",trend:"up"}]},example_update:{pin_config:{cards:[{title:"Revenue",value:"1234",change:"+8%",trend:"up"}]}}}};function _n(i){return xn[i]}function Gn(i){let e=_n(i);return e?[`Pin type: ${e.pin_type}`,e.summary,"","Required pin_config fields:",...e.required_fields.map(o=>` - ${o}`),"","Optional pin_config fields:",...e.optional_fields.length?e.optional_fields.map(o=>` - ${o}`):[" (none documented)"],"","Field reference:",...e.fields.map(o=>` ${o.path} (${o.type}${o.required?", required":""}): ${o.description}`),"","Example update payload:",JSON.stringify(e.example_update,null,2)].join(`
|
|
6
|
+
`):[`No built-in hint for pin type "${i}".`,"Use CreatePinRequest<typeof pinType> / PinConfigByType[typeof pinType] in TypeScript,","or client.pins.create({ pin_type, pin_config, metadata }) with typed pin_config."].join(`
|
|
7
|
+
`)}exports.AuthenticationError=P;exports.ForbiddenError=y;exports.NetworkError=b;exports.NotFoundError=h;exports.PIN_CONFIG_HINTS=xn;exports.PindownClient=j;exports.PindownError=g;exports.RateLimitError=m;exports.ServerError=f;exports.ValidationError=c;exports.assertValidPinConfig=R;exports.formatPinConfigHint=Gn;exports.getPinConfigHint=_n;exports.prepareCreatePinRequest=T;exports.prepareUpdatePinRequest=k;exports.validatePinConfig=Tn;//# sourceMappingURL=index.cjs.map
|
|
8
8
|
//# sourceMappingURL=index.cjs.map
|