@rebasepro/plugin-insights 0.2.3 → 0.2.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.
Files changed (63) hide show
  1. package/dist/common/src/collections/default-collections.d.ts +9 -0
  2. package/dist/common/src/collections/index.d.ts +1 -0
  3. package/dist/common/src/util/permissions.d.ts +1 -0
  4. package/dist/core/src/components/LoginView/LoginView.d.ts +25 -1
  5. package/dist/core/src/components/common/types.d.ts +10 -7
  6. package/dist/core/src/components/common/useDebouncedData.d.ts +1 -1
  7. package/dist/core/src/core/RebaseProps.d.ts +13 -2
  8. package/dist/core/src/core/RebaseRouter.d.ts +1 -1
  9. package/dist/core/src/hooks/data/useCollectionFetch.d.ts +12 -1
  10. package/dist/core/src/hooks/index.d.ts +0 -1
  11. package/dist/core/src/util/entity_cache.d.ts +0 -5
  12. package/dist/core/src/util/index.d.ts +0 -2
  13. package/dist/core/src/util/useStorageUploadController.d.ts +2 -2
  14. package/dist/formex/src/utils.d.ts +2 -2
  15. package/dist/index.es.js +216 -164
  16. package/dist/index.es.js.map +1 -1
  17. package/dist/index.umd.js +216 -164
  18. package/dist/index.umd.js.map +1 -1
  19. package/dist/plugin-insights/src/components/InsightWidget.d.ts +2 -2
  20. package/dist/plugin-insights/src/components/InsightWidgetSkeleton.d.ts +3 -1
  21. package/dist/plugin-insights/src/components/InsightsScorecardView.d.ts +3 -1
  22. package/dist/types/src/controllers/auth.d.ts +4 -26
  23. package/dist/types/src/controllers/client.d.ts +25 -43
  24. package/dist/types/src/controllers/collection_registry.d.ts +1 -1
  25. package/dist/types/src/controllers/data.d.ts +4 -0
  26. package/dist/types/src/controllers/data_driver.d.ts +23 -0
  27. package/dist/types/src/controllers/registry.d.ts +5 -4
  28. package/dist/types/src/rebase_context.d.ts +1 -1
  29. package/dist/types/src/types/auth_adapter.d.ts +5 -60
  30. package/dist/types/src/types/backend.d.ts +2 -2
  31. package/dist/types/src/types/backend_hooks.d.ts +2 -17
  32. package/dist/types/src/types/collections.d.ts +0 -4
  33. package/dist/types/src/types/component_ref.d.ts +1 -1
  34. package/dist/types/src/types/cron.d.ts +1 -1
  35. package/dist/types/src/types/entity_views.d.ts +1 -0
  36. package/dist/types/src/types/export_import.d.ts +1 -1
  37. package/dist/types/src/types/formex.d.ts +2 -2
  38. package/dist/types/src/types/properties.d.ts +9 -7
  39. package/dist/types/src/types/translations.d.ts +28 -12
  40. package/dist/types/src/types/user_management_delegate.d.ts +22 -57
  41. package/dist/types/src/users/index.d.ts +0 -1
  42. package/dist/types/src/users/user.d.ts +0 -1
  43. package/dist/ui/src/components/Button.d.ts +2 -2
  44. package/dist/ui/src/components/ErrorBoundary.d.ts +25 -3
  45. package/dist/ui/src/components/VirtualTable/VirtualTable.d.ts +1 -1
  46. package/dist/ui/src/components/VirtualTable/VirtualTableCell.d.ts +6 -6
  47. package/dist/ui/src/components/VirtualTable/VirtualTableHeader.d.ts +8 -8
  48. package/dist/ui/src/components/VirtualTable/VirtualTableHeaderRow.d.ts +1 -1
  49. package/dist/ui/src/components/VirtualTable/VirtualTableProps.d.ts +11 -11
  50. package/dist/ui/src/components/VirtualTable/VirtualTableRow.d.ts +1 -1
  51. package/dist/ui/src/components/VirtualTable/types.d.ts +9 -9
  52. package/dist/ui/src/hooks/useDebounceCallback.d.ts +1 -1
  53. package/dist/ui/src/util/debounce.d.ts +1 -1
  54. package/package.json +4 -3
  55. package/src/components/InsightWidget.tsx +33 -4
  56. package/src/components/InsightWidgetSkeleton.tsx +7 -1
  57. package/src/components/InsightsScorecardView.tsx +4 -1
  58. package/src/engine/InsightsCache.test.ts +56 -0
  59. package/src/engine/useInsightsData.ts +1 -0
  60. package/dist/core/src/hooks/useValidateAuthenticator.d.ts +0 -21
  61. package/dist/core/src/util/icon_synonyms.d.ts +0 -1
  62. package/dist/core/src/util/useTraceUpdate.d.ts +0 -2
  63. package/dist/types/src/users/roles.d.ts +0 -22
@@ -1 +1 @@
1
- {"version":3,"file":"index.umd.js","sources":["../src/engine/InsightsCache.ts","../src/engine/InsightsProvider.tsx","../src/engine/useInsightsData.ts","../src/components/InsightsScorecardView.tsx","../src/components/InsightWidgetSkeleton.tsx","../src/components/InsightWidget.tsx","../src/components/HomeCardInsightSlot.tsx","../src/components/HomeInsightsSlot.tsx","../src/components/CollectionInsightsInline.tsx","../src/useInsightsPlugin.tsx"],"sourcesContent":["import type { InsightDataResult } from \"../types\";\n\ninterface CacheEntry {\n data: InsightDataResult;\n timestamp: number;\n}\n\n/**\n * In-memory cache for insight query results.\n * Supports TTL-based expiry and inflight request deduplication\n * to prevent redundant network requests when multiple widgets\n * share the same query.\n */\nexport class InsightsCache {\n private cache = new Map<string, CacheEntry>();\n private inflight = new Map<string, Promise<InsightDataResult>>();\n\n constructor(private ttl: number = 60_000) {}\n\n get(key: string): InsightDataResult | null {\n const entry = this.cache.get(key);\n if (!entry) return null;\n if (Date.now() - entry.timestamp > this.ttl) {\n this.cache.delete(key);\n return null;\n }\n return entry.data;\n }\n\n set(key: string, data: InsightDataResult): void {\n this.cache.set(key, { data, timestamp: Date.now() });\n this.inflight.delete(key);\n }\n\n getInflight(key: string): Promise<InsightDataResult> | null {\n return this.inflight.get(key) ?? null;\n }\n\n setInflight(key: string, promise: Promise<InsightDataResult>): void {\n this.inflight.set(key, promise);\n }\n\n invalidate(key?: string): void {\n if (key) {\n this.cache.delete(key);\n this.inflight.delete(key);\n } else {\n this.cache.clear();\n this.inflight.clear();\n }\n }\n}\n","import React, { createContext, useContext, useMemo, type PropsWithChildren } from \"react\";\nimport { InsightsCache } from \"./InsightsCache\";\n\ninterface InsightsContextValue {\n cache: InsightsCache;\n}\n\nconst InsightsContext = createContext<InsightsContextValue | null>(null);\n\n/**\n * Root-level provider for the insights data engine.\n * Injected automatically by the plugin via `providers: [{ scope: \"root\" }]`.\n *\n * Manages a single `InsightsCache` instance shared by all insight widgets\n * for TTL-based caching and inflight request deduplication.\n */\nexport function InsightsProvider({\n cacheTTL,\n children\n}: PropsWithChildren<{ cacheTTL?: number }>) {\n const cache = useMemo(() => new InsightsCache(cacheTTL), [cacheTTL]);\n const value = useMemo(() => ({ cache }), [cache]);\n\n return (\n <InsightsContext.Provider value={value}>\n {children}\n </InsightsContext.Provider>\n );\n}\n\n/**\n * Access the insights cache (for advanced usage).\n * Returns null when called outside of an `InsightsProvider`\n * (e.g. during auth-loading phase before plugin providers mount).\n */\nexport function useInsightsEngine(): InsightsContextValue | null {\n return useContext(InsightsContext);\n}\n","import { useEffect, useState } from \"react\";\nimport type { InsightDefinition, InsightDataResult, InsightContext } from \"../types\";\nimport { useInsightsEngine } from \"./InsightsProvider\";\nimport { useAuthController } from \"@rebasepro/core\";\n\n/**\n * Hook that fetches and caches data for a single insight definition.\n *\n * Calls the definition's own `data()` callback and manages:\n * - TTL-based caching via InsightsCache\n * - Inflight request deduplication (multiple mounts of the same widget)\n * - Loading and error state management\n *\n * @param definition - The insight to fetch data for\n * @param collectionSlug - Optional collection context for cache key scoping\n */\nexport function useInsightsData(\n definition: InsightDefinition,\n context: InsightContext\n): {\n data: InsightDataResult | null;\n loading: boolean;\n error: Error | null;\n} {\n const engine = useInsightsEngine();\n const cache = engine?.cache ?? null;\n const { initialLoading, authLoading, user, loginSkipped } = useAuthController();\n const authReady = !initialLoading && !authLoading && (Boolean(user) || loginSkipped);\n const [data, setData] = useState<InsightDataResult | null>(null);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n\n const cacheKey = `${definition.id}:${context.path ?? context.collectionSlug ?? \"global\"}`;\n\n useEffect(() => {\n // Keep showing skeleton until both auth and engine are ready\n if (!authReady || !cache) {\n return;\n }\n\n let cancelled = false;\n\n // 1. Check cache\n const cached = cache.get(cacheKey);\n if (cached) {\n setData(cached);\n setLoading(false);\n return;\n }\n\n // 2. Check inflight — deduplicate concurrent requests for the same widget\n const inflight = cache.getInflight(cacheKey);\n if (inflight) {\n setLoading(true);\n inflight\n .then((result) => {\n if (!cancelled) {\n setData(result);\n }\n })\n .catch((err) => {\n if (!cancelled) setError(err instanceof Error ? err : new Error(String(err)));\n })\n .finally(() => {\n if (!cancelled) setLoading(false);\n });\n return;\n }\n\n // 3. Fresh fetch — invoke the definition's own data callback\n setLoading(true);\n setError(null);\n\n const promise = definition.data(context);\n\n cache.setInflight(cacheKey, promise);\n\n promise\n .then((result) => {\n cache.set(cacheKey, result);\n if (!cancelled) {\n setData(result);\n }\n })\n .catch((err) => {\n if (!cancelled) {\n setError(err instanceof Error ? err : new Error(String(err)));\n }\n })\n .finally(() => {\n if (!cancelled) setLoading(false);\n });\n\n return () => {\n cancelled = true;\n };\n }, [definition.id, definition.data, context.path, context.collectionSlug, cacheKey, cache, authReady]);\n\n return { data, loading, error };\n}\n","import React, { useRef, useState } from \"react\";\nimport { getIcon } from \"@rebasepro/core\";\nimport { cls, defaultBorderMixin } from \"@rebasepro/ui\";\nimport type { DataRow, ScorecardConfig, ScorecardFormat } from \"../types\";\n\nfunction formatNumber(value: number, format?: ScorecardFormat): string {\n if (value === null || value === undefined) return \"N/A\";\n\n const options: Intl.NumberFormatOptions = {\n style: format?.style ?? \"decimal\",\n notation: format?.notation ?? \"standard\",\n maximumFractionDigits: format?.decimals ?? 1,\n minimumFractionDigits: format?.decimals ?? 1,\n };\n\n if (format?.style === \"currency\") {\n options.currency = format.currency ?? \"USD\";\n }\n\n let formatted = new Intl.NumberFormat(\"en-US\", options).format(value);\n\n if (format?.showSign && value > 0) {\n formatted = \"+\" + formatted;\n }\n\n return formatted;\n}\n\n/**\n * Scorecard widget for the Rebase design system.\n *\n * Renders a single KPI metric with optional comparison value and icon.\n * Uses Tailwind `dark:` classes — no JS dark mode detection.\n * Icons are resolved via `getIcon` from `@rebasepro/core`.\n */\nexport function InsightsScorecardView({\n config,\n data,\n title,\n compact = false,\n embedded = false,\n}: {\n config: ScorecardConfig;\n data: DataRow;\n title: string;\n compact?: boolean;\n /** When true, skip own border/bg since the parent card provides them. */\n embedded?: boolean;\n}) {\n const containerRef = useRef<HTMLDivElement>(null);\n const [containerWidth, setContainerWidth] = useState<number | null>(null);\n\n React.useLayoutEffect(() => {\n if (!containerRef.current) return;\n // Read initial width synchronously before paint\n setContainerWidth(containerRef.current.offsetWidth);\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n setContainerWidth(entry.contentRect.width);\n }\n });\n observer.observe(containerRef.current);\n return () => observer.disconnect();\n }, []);\n\n const mainValue = data[config.value.field];\n const formattedValue = typeof mainValue === \"number\"\n ? formatNumber(mainValue, config.value.format)\n : String(mainValue ?? \"N/A\");\n\n // Comparison rendering\n let comparisonElement: React.ReactNode = null;\n if (config.comparison) {\n const comparisonValue = data[config.comparison.field];\n if (typeof comparisonValue === \"number\") {\n const formattedComparison = formatNumber(comparisonValue, config.comparison.format);\n const isPositive = comparisonValue > 0;\n const isNegative = comparisonValue < 0;\n\n let colorClass = \"text-surface-500 dark:text-surface-400\";\n if (config.comparison.intent === \"increase_is_good\") {\n if (isPositive) colorClass = \"text-emerald-500\";\n if (isNegative) colorClass = \"text-red-500\";\n } else if (config.comparison.intent === \"decrease_is_good\") {\n if (isPositive) colorClass = \"text-red-500\";\n if (isNegative) colorClass = \"text-emerald-500\";\n }\n\n comparisonElement = (\n <span className={`font-medium ${compact ? \"text-[10px]\" : \"text-xs\"} ${colorClass}`}>\n {formattedComparison}\n </span>\n );\n }\n }\n\n const isSmall = compact || (containerWidth !== null && containerWidth < 200);\n\n // Resolve icon via getIcon (Lucide-based resolution)\n const iconElement = config.icon\n ? getIcon(config.icon, \"text-surface-400 dark:text-surface-500\", undefined, isSmall ? 14 : 18)\n : null;\n\n // ── Compact card-inline layout ──────────────────────────────────────\n if (compact) {\n return (\n <div className={cls(\"flex flex-col gap-0.5 px-2.5 py-2 rounded-md bg-transparent border min-w-0\", defaultBorderMixin)}>\n <span className=\"text-[10px] uppercase tracking-wider text-surface-400 dark:text-surface-500 truncate\">\n {title}\n </span>\n <div className=\"flex items-baseline gap-1.5\">\n <span className=\"text-sm font-semibold tabular-nums text-surface-800 dark:text-surface-100\">\n {formattedValue}\n </span>\n {comparisonElement}\n </div>\n </div>\n );\n }\n\n // ── Standard scorecard layout ───────────────────────────────────────\n const baseClass = embedded\n ? `flex flex-col min-w-0 h-full ${isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\"}`\n : cls(\"rounded-lg flex flex-col min-w-0 bg-transparent border\", defaultBorderMixin, isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\");\n\n return (\n <div ref={containerRef} className={baseClass} style={embedded ? undefined : { minHeight: isSmall ? 68 : 92 }}>\n {/* Title row */}\n <div className={`flex items-center justify-between ${isSmall ? \"mb-1\" : \"mb-2\"}`}>\n <div className=\"flex flex-col min-w-0\">\n <span className={`font-medium leading-snug truncate text-surface-500 dark:text-surface-400 ${isSmall ? \"text-[11px]\" : \"text-xs\"}`}>\n {title}\n </span>\n {config.dateRange && !isSmall && (\n <span className=\"text-[10px] text-surface-400 dark:text-surface-500 truncate mt-0.5\">\n {config.dateRange}\n </span>\n )}\n </div>\n {iconElement && (\n <span className=\"ml-2 shrink-0\">{iconElement}</span>\n )}\n </div>\n\n {/* Main value */}\n <div className={`font-semibold leading-tight tracking-tight break-all text-surface-800 dark:text-surface-100 ${isSmall ? \"text-lg\" : (containerWidth !== null && containerWidth < 300) ? \"text-xl\" : \"text-2xl\"}`}>\n {formattedValue}\n </div>\n\n {/* Comparison */}\n {comparisonElement && (\n <div className={isSmall ? \"mt-0.5\" : \"mt-1\"}>\n {comparisonElement}\n </div>\n )}\n </div>\n );\n}\n\nInsightsScorecardView.displayName = \"InsightsScorecardView\";\n","import React, { useRef, useState } from \"react\";\nimport { cls, defaultBorderMixin } from \"@rebasepro/ui\";\nimport type { ScorecardConfig } from \"../types\";\n\n/**\n * Skeleton loader for scorecard insight widgets — displays animated\n * shimmer placeholders that exactly match the final rendered layout\n * of InsightsScorecardView for a given config, preventing layout shift.\n *\n * The skeleton receives the scorecard config so it can conditionally\n * render placeholder lines for comparison, dateRange, and icon —\n * only when the loaded view will also render them.\n *\n * The standard skeleton mirrors InsightsScorecardView's responsive\n * container-width breakpoints (ResizeObserver → isSmall / isMedium)\n * and uses placeholder heights that exactly match the **computed**\n * Tailwind line-heights (accounting for `leading-*` overrides).\n * This guarantees a pixel-perfect skeleton → loaded transition.\n */\nexport function InsightWidgetSkeleton({\n config,\n compact = false,\n embedded = false,\n}: {\n /** Scorecard config — used to match optional elements (comparison, dateRange, icon). */\n config: ScorecardConfig;\n compact?: boolean;\n /** When true, skip own border since the parent card provides it. */\n embedded?: boolean;\n}) {\n const hasComparison = Boolean(config.comparison);\n const hasIcon = Boolean(config.icon);\n const hasDateRange = Boolean(config.dateRange);\n\n // ── Compact scorecard skeleton ──────────────────────────────────────\n // Matches InsightsScorecardView compact layout:\n // container: flex flex-col gap-0.5 px-2.5 py-2 rounded-md border\n // title: text-[10px] uppercase → line-height ~14px\n // value row: text-sm font-semibold → line-height 20px\n // + optional comparison text-[10px] inside value row\n if (compact) {\n return (\n <div\n className={cls(\n \"animate-pulse\",\n embedded\n ? \"h-full px-2.5 py-2\"\n : \"flex flex-col gap-0.5 rounded-md bg-transparent border min-w-0 px-2.5 py-2\",\n !embedded && defaultBorderMixin\n )}\n >\n {/* Title line */}\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded-sm\"\n style={{ height: 14, width: 48 }}\n />\n {/* Value + optional comparison row */}\n <div className=\"flex items-baseline gap-1.5\">\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded-sm\"\n style={{ height: 20, width: 40 }}\n />\n {hasComparison && (\n <div className=\"bg-surface-200/60 dark:bg-surface-700/60 rounded-sm\"\n style={{ height: 14, width: 28 }}\n />\n )}\n </div>\n </div>\n );\n }\n\n // ── Standard scorecard skeleton ─────────────────────────────────────\n return <StandardSkeleton\n hasComparison={hasComparison}\n hasIcon={hasIcon}\n hasDateRange={hasDateRange}\n embedded={embedded}\n />;\n}\n\n// ── Tailwind line-height reference ──────────────────────────────────────\n// All heights below are the **computed** CSS line-heights, accounting\n// for `leading-*` overrides that InsightsScorecardView applies.\n//\n// Title:\n// text-xs (12px) + leading-snug (1.375) → 12 × 1.375 = 16.5px\n// text-[11px] + leading-snug (1.375) → 11 × 1.375 = 15.125px\n//\n// DateRange:\n// text-[10px] with no explicit LH → normal ≈ 14px (browser)\n//\n// Value:\n// text-2xl (24px) + leading-tight (1.25) → 24 × 1.25 = 30px\n// text-xl (20px) + leading-tight (1.25) → 20 × 1.25 = 25px\n// text-lg (18px) + leading-tight (1.25) → 18 × 1.25 = 22.5px\n//\n// Comparison:\n// text-xs (12px) → built-in LH 1rem = 16px\n\n/**\n * Inner component for the standard scorecard skeleton.\n *\n * Mirrors InsightsScorecardView's layout by:\n * 1. Using the same ResizeObserver + containerWidth pattern for\n * responsive breakpoints (isSmall < 200px, isMedium < 300px).\n * 2. Using placeholder heights derived from the exact computed\n * Tailwind line-heights that InsightsScorecardView renders.\n * 3. Matching all container classes, margins, paddings, and flex\n * layout properties identically.\n */\nfunction StandardSkeleton({\n hasComparison,\n hasIcon,\n hasDateRange,\n embedded,\n}: {\n hasComparison: boolean;\n hasIcon: boolean;\n hasDateRange: boolean;\n embedded: boolean;\n}) {\n const containerRef = useRef<HTMLDivElement>(null);\n const [containerWidth, setContainerWidth] = useState<number | null>(null);\n\n React.useLayoutEffect(() => {\n if (!containerRef.current) return;\n setContainerWidth(containerRef.current.offsetWidth);\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n setContainerWidth(entry.contentRect.width);\n }\n });\n observer.observe(containerRef.current);\n return () => observer.disconnect();\n }, []);\n\n // Mirror InsightsScorecardView's responsive breakpoints exactly\n const isSmall = containerWidth !== null && containerWidth < 200;\n\n // Computed line-heights for each breakpoint\n // Title: text-xs + leading-snug = 16.5px, text-[11px] + leading-snug = 15.125px\n const titleHeight = isSmall ? 15 : 16.5;\n // Value: leading-tight (×1.25) applied on top of font-size\n const valueHeight = isSmall\n ? 22.5 // text-lg: 18 × 1.25\n : (containerWidth !== null && containerWidth < 300)\n ? 25 // text-xl: 20 × 1.25\n : 30; // text-2xl: 24 × 1.25\n // Comparison: text-xs = 12px / 16px line-height (no leading override)\n const comparisonHeight = 16;\n // Icon: 14px when small, 18px otherwise\n const iconSize = isSmall ? 14 : 18;\n\n const baseClass = embedded\n ? `flex flex-col min-w-0 h-full ${isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\"}`\n : cls(\"rounded-lg flex flex-col min-w-0 bg-transparent border\", defaultBorderMixin, isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\");\n\n return (\n <div\n ref={containerRef}\n className={cls(\"animate-pulse\", baseClass)}\n style={embedded ? undefined : { minHeight: isSmall ? 68 : 92 }}\n >\n {/* Title row — identical flex structure to InsightsScorecardView */}\n <div className={`flex items-center justify-between ${isSmall ? \"mb-1\" : \"mb-2\"}`}>\n <div className=\"flex flex-col min-w-0\">\n {/* Title placeholder */}\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded\"\n style={{ height: titleHeight, width: \"60%\" }}\n />\n {/* DateRange — hidden when isSmall, same as real view (line 134) */}\n {hasDateRange && !isSmall && (\n <div className=\"bg-surface-200/60 dark:bg-surface-700/60 rounded mt-0.5\"\n style={{ height: 14, width: \"40%\" }}\n />\n )}\n </div>\n {/* Icon placeholder — same wrapper as real view */}\n {hasIcon && (\n <span className=\"ml-2 shrink-0\">\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded\"\n style={{ height: iconSize, width: iconSize }}\n />\n </span>\n )}\n </div>\n\n {/* Main value placeholder */}\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded\"\n style={{ height: valueHeight, width: \"40%\" }}\n />\n\n {/* Comparison placeholder */}\n {hasComparison && (\n <div className={isSmall ? \"mt-0.5\" : \"mt-1\"}>\n <div className=\"bg-surface-200/60 dark:bg-surface-700/60 rounded\"\n style={{ height: comparisonHeight, width: \"25%\" }}\n />\n </div>\n )}\n </div>\n );\n}\n\nInsightWidgetSkeleton.displayName = \"InsightWidgetSkeleton\";\n","import React from \"react\";\nimport type { InsightDefinition, DataRow } from \"../types\";\nimport { useInsightsData } from \"../engine/useInsightsData\";\nimport { InsightsScorecardView } from \"./InsightsScorecardView\";\nimport { InsightWidgetSkeleton } from \"./InsightWidgetSkeleton\";\n\n/**\n * Single insight widget orchestrator.\n *\n * Fetches data via the engine, renders the scorecard visualization,\n * and manages loading/error states.\n *\n * All theme-awareness is handled via Tailwind `dark:` classes.\n */\nexport function InsightWidget({\n definition,\n collectionSlug,\n path,\n parentCollectionSlugs, parentEntityIds,\n compact = false,\n embedded = false,\n}: {\n definition: InsightDefinition;\n collectionSlug?: string;\n path?: string;\n parentCollectionSlugs?: string[], parentEntityIds?: string[];\n compact?: boolean;\n /** When true, inner views skip their own borders since the parent card provides them. */\n embedded?: boolean;\n}) {\n const { data, loading, error } = useInsightsData(definition, { path, collectionSlug, parentCollectionSlugs });\n\n if (loading) {\n return <InsightWidgetSkeleton config={definition.scorecard} compact={compact} embedded={embedded} />;\n }\n\n if (error) {\n return (\n <div\n className={`text-red-500/70 dark:text-red-400/70 text-[0.8125rem] ${embedded ? \"px-5 py-4 h-full\" : `rounded-lg bg-red-500/5 dark:bg-red-400/5 border border-red-500/10 dark:border-red-400/10 ${compact ? \"px-3.5 py-3\" : \"px-5 py-4\"}`}`}\n >\n <div className=\"font-semibold mb-1\">{definition.title}</div>\n <div>{error.message}</div>\n </div>\n );\n }\n\n if (!data || data.rows.length === 0) {\n return (\n <div\n className={`text-surface-400 dark:text-surface-500 text-[0.8125rem] ${embedded ? \"px-5 py-4 h-full\" : `rounded-lg bg-surface-100 dark:bg-surface-800 border border-surface-200 dark:border-surface-700 ${compact ? \"px-3.5 py-3\" : \"px-5 py-4\"}`}`}\n >\n {definition.title} — No data\n </div>\n );\n }\n\n return (\n <InsightsScorecardView\n config={definition.scorecard}\n data={data.rows[0] as DataRow}\n title={definition.title}\n compact={compact}\n embedded={embedded}\n />\n );\n}\n\nInsightWidget.displayName = \"InsightWidget\";\n","import React from \"react\";\nimport type { InsightDefinition } from \"../types\";\nimport { InsightWidget } from \"./InsightWidget\";\n\n/**\n * Renders compact insight widgets inline within a home page collection card.\n * Injected via the `home.card.insight` slot.\n *\n * Uses a horizontal flex layout so multiple cards sit side by side.\n */\nexport function HomeCardInsightSlot({\n slug,\n insights,\n}: {\n slug: string;\n collection: unknown;\n context: unknown;\n insights: InsightDefinition[];\n}) {\n if (!insights || insights.length === 0) return null;\n\n // Each compact card row is ~42px; estimate 2 cards per row for wrapping\n const estimatedRows = Math.ceil(insights.length / 2);\n const minHeight = estimatedRows * 42 + (estimatedRows - 1) * 6; // 6px = gap-1.5\n\n return (\n <div className=\"flex flex-wrap items-center gap-1.5 mt-2\" style={{ minHeight }}>\n {insights.map((def) => (\n <InsightWidget\n key={def.id}\n definition={def}\n collectionSlug={slug}\n compact={true}\n />\n ))}\n </div>\n );\n}\n\nHomeCardInsightSlot.displayName = \"HomeCardInsightSlot\";\n","import React from \"react\";\nimport type { InsightDefinition } from \"../types\";\nimport { InsightWidget } from \"./InsightWidget\";\n\n/**\n * Scorecard insights panel rendered at the top of the home page.\n * Injected via the `home.children.start` slot.\n *\n * Renders scorecards in a responsive grid (up to 4 columns).\n */\nexport function HomeInsightsSlot({\n insights,\n}: {\n insights: InsightDefinition[];\n}) {\n if (!insights || insights.length === 0) return null;\n\n return (\n <div\n className=\"grid grid-cols-2 sm:grid-cols-3 lg:grid-cols-4 gap-3 pb-6\"\n style={{ minHeight: 92 }}\n >\n {insights.map((def) => (\n <InsightWidget key={def.id} definition={def} />\n ))}\n </div>\n );\n}\n\nHomeInsightsSlot.displayName = \"HomeInsightsSlot\";\n","import React from \"react\";\nimport type { InsightDefinition } from \"../types\";\nimport { InsightWidget } from \"./InsightWidget\";\n\n/**\n * Renders scorecard insight widgets inline within a collection's list view,\n * positioned below the title and above the main data list.\n *\n * Injected via the `collection.insights` slot.\n */\nexport function CollectionInsightsInline({\n insights,\n path,\n parentCollectionSlugs,\n parentEntityIds\n}: {\n path: string;\n collection: unknown;\n parentCollectionSlugs: string[], parentEntityIds: string[];\n insights: InsightDefinition[];\n}) {\n if (!insights || insights.length === 0) return null;\n\n return (\n <div className=\"grid grid-cols-2 sm:grid-cols-3 lg:grid-cols-4 gap-3 pb-4\">\n {insights.map((def) => (\n <InsightWidget \n key={def.id} \n definition={def} \n path={path}\n parentCollectionSlugs={parentCollectionSlugs} parentEntityIds={parentEntityIds}\n />\n ))}\n </div>\n );\n}\n\nCollectionInsightsInline.displayName = \"CollectionInsightsInline\";\n","import React from \"react\";\nimport type { RebasePlugin, SlotContribution } from \"@rebasepro/types\";\nimport type { InsightsPluginConfig } from \"./types\";\nimport { InsightsProvider } from \"./engine/InsightsProvider\";\nimport { HomeCardInsightSlot } from \"./components/HomeCardInsightSlot\";\nimport { HomeInsightsSlot } from \"./components/HomeInsightsSlot\";\nimport { CollectionInsightsInline } from \"./components/CollectionInsightsInline\";\n\n/**\n * Creates the Insights plugin for Rebase.\n *\n * This plugin injects scorecard widgets into key UI locations:\n * - **Home page header**: KPI overview via `home.children.start` slot\n * - **Collection list view**: Scorecards inline (below title, above list) via `collection.insights` slot\n * - **Home page cards**: Compact scorecard metrics auto-extracted from collection insights via `home.card.insight` slot\n *\n * Collection-level insights (`collections.<slug>`) are the single source of truth:\n * scorecards render in the collection list view and are automatically extracted\n * to show as compact widgets on the corresponding home page card.\n *\n * Each insight owns its own `data()` callback — use the Rebase client SDK,\n * call a custom function, or hit any external API. Full flexibility, zero new endpoints.\n *\n * @example\n * ```typescript\n * import { useInsightsPlugin } from \"@rebasepro/plugin-insights\";\n *\n * const insightsPlugin = useInsightsPlugin({\n * cacheTTL: 120_000,\n * insights: {\n * home: [\n * { id: \"revenue\", title: \"Revenue\", data: async () => ..., scorecard: { ... } },\n * ],\n * collections: {\n * orders: [\n * { id: \"total\", title: \"Total Orders\", data: async () => ..., scorecard: { ... } },\n * ],\n * },\n * },\n * });\n * ```\n */\nexport function useInsightsPlugin(config: InsightsPluginConfig): RebasePlugin {\n const { insights, cacheTTL } = config;\n const slots: SlotContribution[] = [];\n\n // ── Home page insights ────────────────────────────────────────────\n if (insights.home && insights.home.length > 0) {\n const homeInsights = insights.home;\n slots.push({\n slot: \"home.children.start\" as const,\n Component: (props: Record<string, unknown>) => (\n <HomeInsightsSlot\n {...props}\n insights={homeInsights}\n />\n ),\n order: 10,\n });\n }\n\n // ── Per-collection insights ───────────────────────────────────────\n // A single `collections.<slug>` definition serves two slots:\n // 1. collection.insights → inline scorecards in the list view\n // 2. home.card.insight → compact scorecards on the home card\n if (insights.collections) {\n for (const [slug, defs] of Object.entries(insights.collections)) {\n if (defs.length === 0) continue;\n const collectionInsights = defs;\n\n // 1. Inline in collection list view\n slots.push({\n slot: \"collection.insights\" as const,\n Component: (props: Record<string, unknown>) => {\n const path = props.path as string;\n const collectionSlug = path?.split(\"/\").filter(Boolean).pop() ?? \"\";\n if (collectionSlug !== slug) return null;\n return (\n <CollectionInsightsInline\n {...props as { path: string; collection: unknown; parentCollectionSlugs: string[], parentEntityIds: string[] }}\n insights={collectionInsights}\n />\n );\n },\n order: 10,\n });\n\n // 2. Auto-extract scorecards for home page card\n slots.push({\n slot: \"home.card.insight\" as const,\n Component: (props: Record<string, unknown>) => {\n const cardSlug = props.slug as string;\n if (cardSlug !== slug) return null;\n return (\n <HomeCardInsightSlot\n {...props as { slug: string; collection: unknown; context: unknown }}\n insights={collectionInsights}\n />\n );\n },\n order: 10,\n });\n }\n }\n\n return {\n key: \"plugin-insights\",\n slots,\n providers: [\n {\n scope: \"root\" as const,\n Component: InsightsProvider as React.ComponentType<React.PropsWithChildren<Record<string, unknown>>>,\n props: { cacheTTL },\n },\n ],\n };\n}\n"],"names":["InsightsCache","constructor","ttl","cache","Map","inflight","get","key","entry","Date","now","timestamp","delete","data","set","getInflight","setInflight","promise","invalidate","clear","InsightsContext","createContext","InsightsProvider","t0","$","_c","cacheTTL","children","t1","t2","t3","t4","value","t5","jsx","useInsightsEngine","useContext","useInsightsData","definition","context","engine","initialLoading","authLoading","user","loginSkipped","useAuthController","authReady","Boolean","setData","useState","loading","setLoading","error","setError","cacheKey","id","path","collectionSlug","cancelled","cached","then","result","catch","err","Error","String","finally","result_0","err_0","useEffect","formatNumber","format","undefined","options","style","notation","maximumFractionDigits","decimals","minimumFractionDigits","currency","formatted","Intl","NumberFormat","showSign","InsightsScorecardView","config","title","compact","embedded","containerRef","useRef","containerWidth","setContainerWidth","Symbol","for","current","offsetWidth","observer","ResizeObserver","entries","contentRect","width","observe","disconnect","React","useLayoutEffect","mainValue","field","formattedValue","comparisonElement","comparison","comparisonValue","t6","formattedComparison","isPositive","isNegative","colorClass","intent","t7","t8","isSmall","icon","getIcon","iconElement","cls","defaultBorderMixin","t9","t10","jsxs","t11","baseClass","minHeight","t12","dateRange","t13","t14","t15","t16","t17","t18","t19","displayName","InsightWidgetSkeleton","hasComparison","hasIcon","hasDateRange","height","StandardSkeleton","titleHeight","valueHeight","iconSize","InsightWidget","parentCollectionSlugs","scorecard","message","rows","length","HomeCardInsightSlot","slug","insights","estimatedRows","Math","ceil","def","map","HomeInsightsSlot","_temp","CollectionInsightsInline","parentEntityIds","useInsightsPlugin","slots","home","homeInsights","push","slot","Component","props","order","collections","defs","Object","collectionInsights","split","filter","pop","cardSlug","providers","scope"],"mappings":"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"}
1
+ {"version":3,"file":"index.umd.js","sources":["../src/engine/InsightsCache.ts","../src/engine/InsightsProvider.tsx","../src/engine/useInsightsData.ts","../src/components/InsightsScorecardView.tsx","../src/components/InsightWidgetSkeleton.tsx","../src/components/InsightWidget.tsx","../src/components/HomeCardInsightSlot.tsx","../src/components/HomeInsightsSlot.tsx","../src/components/CollectionInsightsInline.tsx","../src/useInsightsPlugin.tsx"],"sourcesContent":["import type { InsightDataResult } from \"../types\";\n\ninterface CacheEntry {\n data: InsightDataResult;\n timestamp: number;\n}\n\n/**\n * In-memory cache for insight query results.\n * Supports TTL-based expiry and inflight request deduplication\n * to prevent redundant network requests when multiple widgets\n * share the same query.\n */\nexport class InsightsCache {\n private cache = new Map<string, CacheEntry>();\n private inflight = new Map<string, Promise<InsightDataResult>>();\n\n constructor(private ttl: number = 60_000) {}\n\n get(key: string): InsightDataResult | null {\n const entry = this.cache.get(key);\n if (!entry) return null;\n if (Date.now() - entry.timestamp > this.ttl) {\n this.cache.delete(key);\n return null;\n }\n return entry.data;\n }\n\n set(key: string, data: InsightDataResult): void {\n this.cache.set(key, { data, timestamp: Date.now() });\n this.inflight.delete(key);\n }\n\n getInflight(key: string): Promise<InsightDataResult> | null {\n return this.inflight.get(key) ?? null;\n }\n\n setInflight(key: string, promise: Promise<InsightDataResult>): void {\n this.inflight.set(key, promise);\n }\n\n invalidate(key?: string): void {\n if (key) {\n this.cache.delete(key);\n this.inflight.delete(key);\n } else {\n this.cache.clear();\n this.inflight.clear();\n }\n }\n}\n","import React, { createContext, useContext, useMemo, type PropsWithChildren } from \"react\";\nimport { InsightsCache } from \"./InsightsCache\";\n\ninterface InsightsContextValue {\n cache: InsightsCache;\n}\n\nconst InsightsContext = createContext<InsightsContextValue | null>(null);\n\n/**\n * Root-level provider for the insights data engine.\n * Injected automatically by the plugin via `providers: [{ scope: \"root\" }]`.\n *\n * Manages a single `InsightsCache` instance shared by all insight widgets\n * for TTL-based caching and inflight request deduplication.\n */\nexport function InsightsProvider({\n cacheTTL,\n children\n}: PropsWithChildren<{ cacheTTL?: number }>) {\n const cache = useMemo(() => new InsightsCache(cacheTTL), [cacheTTL]);\n const value = useMemo(() => ({ cache }), [cache]);\n\n return (\n <InsightsContext.Provider value={value}>\n {children}\n </InsightsContext.Provider>\n );\n}\n\n/**\n * Access the insights cache (for advanced usage).\n * Returns null when called outside of an `InsightsProvider`\n * (e.g. during auth-loading phase before plugin providers mount).\n */\nexport function useInsightsEngine(): InsightsContextValue | null {\n return useContext(InsightsContext);\n}\n","import { useEffect, useState } from \"react\";\nimport type { InsightDefinition, InsightDataResult, InsightContext } from \"../types\";\nimport { useInsightsEngine } from \"./InsightsProvider\";\nimport { useAuthController } from \"@rebasepro/core\";\n\n/**\n * Hook that fetches and caches data for a single insight definition.\n *\n * Calls the definition's own `data()` callback and manages:\n * - TTL-based caching via InsightsCache\n * - Inflight request deduplication (multiple mounts of the same widget)\n * - Loading and error state management\n *\n * @param definition - The insight to fetch data for\n * @param collectionSlug - Optional collection context for cache key scoping\n */\nexport function useInsightsData(\n definition: InsightDefinition,\n context: InsightContext\n): {\n data: InsightDataResult | null;\n loading: boolean;\n error: Error | null;\n} {\n const engine = useInsightsEngine();\n const cache = engine?.cache ?? null;\n const { initialLoading, authLoading, user, loginSkipped } = useAuthController();\n const authReady = !initialLoading && !authLoading && (Boolean(user) || loginSkipped);\n const [data, setData] = useState<InsightDataResult | null>(null);\n const [loading, setLoading] = useState(true);\n const [error, setError] = useState<Error | null>(null);\n\n const cacheKey = `${definition.id}:${context.path ?? context.collectionSlug ?? \"global\"}`;\n\n useEffect(() => {\n // Keep showing skeleton until both auth and engine are ready\n if (!authReady || !cache) {\n return;\n }\n\n let cancelled = false;\n\n // 1. Check cache\n const cached = cache.get(cacheKey);\n if (cached) {\n setData(cached);\n setLoading(false);\n return;\n }\n\n // 2. Check inflight — deduplicate concurrent requests for the same widget\n const inflight = cache.getInflight(cacheKey);\n if (inflight) {\n setLoading(true);\n inflight\n .then((result) => {\n if (!cancelled) {\n setData(result);\n }\n })\n .catch((err) => {\n if (!cancelled) setError(err instanceof Error ? err : new Error(String(err)));\n })\n .finally(() => {\n if (!cancelled) setLoading(false);\n });\n return;\n }\n\n // 3. Fresh fetch — invoke the definition's own data callback\n setLoading(true);\n setError(null);\n\n const promise = definition.data(context);\n\n cache.setInflight(cacheKey, promise);\n\n promise\n .then((result) => {\n cache.set(cacheKey, result);\n if (!cancelled) {\n setData(result);\n }\n })\n .catch((err) => {\n cache.invalidate(cacheKey);\n if (!cancelled) {\n setError(err instanceof Error ? err : new Error(String(err)));\n }\n })\n .finally(() => {\n if (!cancelled) setLoading(false);\n });\n\n return () => {\n cancelled = true;\n };\n }, [definition.id, definition.data, context.path, context.collectionSlug, cacheKey, cache, authReady]);\n\n return { data, loading, error };\n}\n","import React, { useRef, useState } from \"react\";\nimport { getIcon } from \"@rebasepro/core\";\nimport { cls, defaultBorderMixin } from \"@rebasepro/ui\";\nimport type { DataRow, ScorecardConfig, ScorecardFormat } from \"../types\";\n\nfunction formatNumber(value: number, format?: ScorecardFormat): string {\n if (value === null || value === undefined) return \"N/A\";\n\n const options: Intl.NumberFormatOptions = {\n style: format?.style ?? \"decimal\",\n notation: format?.notation ?? \"standard\",\n maximumFractionDigits: format?.decimals ?? 1,\n minimumFractionDigits: format?.decimals ?? 1,\n };\n\n if (format?.style === \"currency\") {\n options.currency = format.currency ?? \"USD\";\n }\n\n let formatted = new Intl.NumberFormat(\"en-US\", options).format(value);\n\n if (format?.showSign && value > 0) {\n formatted = \"+\" + formatted;\n }\n\n return formatted;\n}\n\n/**\n * Scorecard widget for the Rebase design system.\n *\n * Renders a single KPI metric with optional comparison value and icon.\n * Uses Tailwind `dark:` classes — no JS dark mode detection.\n * Icons are resolved via `getIcon` from `@rebasepro/core`.\n */\nexport function InsightsScorecardView({\n config,\n data,\n title,\n compact = false,\n embedded = false,\n fixedHeight,\n}: {\n config: ScorecardConfig;\n data: DataRow;\n title: string;\n compact?: boolean;\n /** When true, skip own border/bg since the parent card provides them. */\n embedded?: boolean;\n /** Explicit height to prevent layout shift between skeleton → loaded. */\n fixedHeight?: number;\n}) {\n const containerRef = useRef<HTMLDivElement>(null);\n const [containerWidth, setContainerWidth] = useState<number | null>(null);\n\n React.useLayoutEffect(() => {\n if (!containerRef.current) return;\n // Read initial width synchronously before paint\n setContainerWidth(containerRef.current.offsetWidth);\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n setContainerWidth(entry.contentRect.width);\n }\n });\n observer.observe(containerRef.current);\n return () => observer.disconnect();\n }, []);\n\n const mainValue = data[config.value.field];\n const formattedValue = typeof mainValue === \"number\"\n ? formatNumber(mainValue, config.value.format)\n : String(mainValue ?? \"N/A\");\n\n // Comparison rendering\n let comparisonElement: React.ReactNode = null;\n if (config.comparison) {\n const comparisonValue = data[config.comparison.field];\n if (typeof comparisonValue === \"number\") {\n const formattedComparison = formatNumber(comparisonValue, config.comparison.format);\n const isPositive = comparisonValue > 0;\n const isNegative = comparisonValue < 0;\n\n let colorClass = \"text-surface-500 dark:text-surface-400\";\n if (config.comparison.intent === \"increase_is_good\") {\n if (isPositive) colorClass = \"text-emerald-500\";\n if (isNegative) colorClass = \"text-red-500\";\n } else if (config.comparison.intent === \"decrease_is_good\") {\n if (isPositive) colorClass = \"text-red-500\";\n if (isNegative) colorClass = \"text-emerald-500\";\n }\n\n comparisonElement = (\n <span className={`font-medium ${compact ? \"text-[10px]\" : \"text-xs\"} ${colorClass}`}>\n {formattedComparison}\n </span>\n );\n }\n }\n\n const isSmall = compact || (containerWidth !== null && containerWidth < 200);\n\n // Resolve icon via getIcon (Lucide-based resolution)\n const iconElement = config.icon\n ? getIcon(config.icon, \"text-surface-400 dark:text-surface-500\", undefined, isSmall ? 14 : 18)\n : null;\n\n // ── Compact card-inline layout ──────────────────────────────────────\n if (compact) {\n return (\n <div className={cls(\"flex flex-col gap-0.5 px-2.5 py-2 rounded-md bg-transparent border min-w-0\", defaultBorderMixin)}>\n <span className=\"text-[10px] uppercase tracking-wider text-surface-400 dark:text-surface-500 truncate\">\n {title}\n </span>\n <div className=\"flex items-baseline gap-1.5\">\n <span className=\"text-sm font-semibold tabular-nums text-surface-800 dark:text-surface-100\">\n {formattedValue}\n </span>\n {comparisonElement}\n </div>\n </div>\n );\n }\n\n // ── Standard scorecard layout ───────────────────────────────────────\n const baseClass = embedded\n ? `flex flex-col min-w-0 h-full ${isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\"}`\n : cls(\"rounded-lg flex flex-col min-w-0 bg-transparent border\", defaultBorderMixin, isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\");\n\n return (\n <div ref={containerRef} className={baseClass} style={embedded ? undefined : fixedHeight ? { height: fixedHeight } : { minHeight: isSmall ? 68 : 92 }}>\n {/* Title row */}\n <div className={`flex items-center justify-between ${isSmall ? \"mb-1\" : \"mb-2\"}`}>\n <div className=\"flex flex-col min-w-0\">\n <span className={`font-medium leading-snug truncate text-surface-500 dark:text-surface-400 ${isSmall ? \"text-[11px]\" : \"text-xs\"}`}>\n {title}\n </span>\n {config.dateRange && !isSmall && (\n <span className=\"text-[10px] text-surface-400 dark:text-surface-500 truncate mt-0.5\">\n {config.dateRange}\n </span>\n )}\n </div>\n {iconElement && (\n <span className=\"ml-2 shrink-0\">{iconElement}</span>\n )}\n </div>\n\n {/* Main value */}\n <div className={`font-semibold leading-tight tracking-tight break-all text-surface-800 dark:text-surface-100 ${isSmall ? \"text-lg\" : (containerWidth !== null && containerWidth < 300) ? \"text-xl\" : \"text-2xl\"}`}>\n {formattedValue}\n </div>\n\n {/* Comparison */}\n {comparisonElement && (\n <div className={isSmall ? \"mt-0.5\" : \"mt-1\"}>\n {comparisonElement}\n </div>\n )}\n </div>\n );\n}\n\nInsightsScorecardView.displayName = \"InsightsScorecardView\";\n","import React, { useRef, useState } from \"react\";\nimport { cls, defaultBorderMixin } from \"@rebasepro/ui\";\nimport type { ScorecardConfig } from \"../types\";\n\n/**\n * Skeleton loader for scorecard insight widgets — displays animated\n * shimmer placeholders that exactly match the final rendered layout\n * of InsightsScorecardView for a given config, preventing layout shift.\n *\n * The skeleton receives the scorecard config so it can conditionally\n * render placeholder lines for comparison, dateRange, and icon —\n * only when the loaded view will also render them.\n *\n * The standard skeleton mirrors InsightsScorecardView's responsive\n * container-width breakpoints (ResizeObserver → isSmall / isMedium)\n * and uses placeholder heights that exactly match the **computed**\n * Tailwind line-heights (accounting for `leading-*` overrides).\n * This guarantees a pixel-perfect skeleton → loaded transition.\n */\nexport function InsightWidgetSkeleton({\n config,\n compact = false,\n embedded = false,\n fixedHeight,\n}: {\n /** Scorecard config — used to match optional elements (comparison, dateRange, icon). */\n config: ScorecardConfig;\n compact?: boolean;\n /** When true, skip own border since the parent card provides it. */\n embedded?: boolean;\n /** Explicit height to prevent layout shift between skeleton → loaded. */\n fixedHeight?: number;\n}) {\n const hasComparison = Boolean(config.comparison);\n const hasIcon = Boolean(config.icon);\n const hasDateRange = Boolean(config.dateRange);\n\n // ── Compact scorecard skeleton ──────────────────────────────────────\n // Matches InsightsScorecardView compact layout:\n // container: flex flex-col gap-0.5 px-2.5 py-2 rounded-md border\n // title: text-[10px] uppercase → line-height ~14px\n // value row: text-sm font-semibold → line-height 20px\n // + optional comparison text-[10px] inside value row\n if (compact) {\n return (\n <div\n className={cls(\n \"animate-pulse\",\n embedded\n ? \"h-full px-2.5 py-2\"\n : \"flex flex-col gap-0.5 rounded-md bg-transparent border min-w-0 px-2.5 py-2\",\n !embedded && defaultBorderMixin\n )}\n >\n {/* Title line */}\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded-sm\"\n style={{ height: 14, width: 48 }}\n />\n {/* Value + optional comparison row */}\n <div className=\"flex items-baseline gap-1.5\">\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded-sm\"\n style={{ height: 20, width: 40 }}\n />\n {hasComparison && (\n <div className=\"bg-surface-200/60 dark:bg-surface-700/60 rounded-sm\"\n style={{ height: 14, width: 28 }}\n />\n )}\n </div>\n </div>\n );\n }\n\n // ── Standard scorecard skeleton ─────────────────────────────────────\n return <StandardSkeleton\n hasComparison={hasComparison}\n hasIcon={hasIcon}\n hasDateRange={hasDateRange}\n embedded={embedded}\n fixedHeight={fixedHeight}\n />;\n}\n\n// ── Tailwind line-height reference ──────────────────────────────────────\n// All heights below are the **computed** CSS line-heights, accounting\n// for `leading-*` overrides that InsightsScorecardView applies.\n//\n// Title:\n// text-xs (12px) + leading-snug (1.375) → 12 × 1.375 = 16.5px\n// text-[11px] + leading-snug (1.375) → 11 × 1.375 = 15.125px\n//\n// DateRange:\n// text-[10px] with no explicit LH → normal ≈ 14px (browser)\n//\n// Value:\n// text-2xl (24px) + leading-tight (1.25) → 24 × 1.25 = 30px\n// text-xl (20px) + leading-tight (1.25) → 20 × 1.25 = 25px\n// text-lg (18px) + leading-tight (1.25) → 18 × 1.25 = 22.5px\n//\n// Comparison:\n// text-xs (12px) → built-in LH 1rem = 16px\n\n/**\n * Inner component for the standard scorecard skeleton.\n *\n * Mirrors InsightsScorecardView's layout by:\n * 1. Using the same ResizeObserver + containerWidth pattern for\n * responsive breakpoints (isSmall < 200px, isMedium < 300px).\n * 2. Using placeholder heights derived from the exact computed\n * Tailwind line-heights that InsightsScorecardView renders.\n * 3. Matching all container classes, margins, paddings, and flex\n * layout properties identically.\n */\nfunction StandardSkeleton({\n hasComparison,\n hasIcon,\n hasDateRange,\n embedded,\n fixedHeight,\n}: {\n hasComparison: boolean;\n hasIcon: boolean;\n hasDateRange: boolean;\n embedded: boolean;\n fixedHeight?: number;\n}) {\n const containerRef = useRef<HTMLDivElement>(null);\n const [containerWidth, setContainerWidth] = useState<number | null>(null);\n\n React.useLayoutEffect(() => {\n if (!containerRef.current) return;\n setContainerWidth(containerRef.current.offsetWidth);\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n setContainerWidth(entry.contentRect.width);\n }\n });\n observer.observe(containerRef.current);\n return () => observer.disconnect();\n }, []);\n\n // Mirror InsightsScorecardView's responsive breakpoints exactly\n const isSmall = containerWidth !== null && containerWidth < 200;\n\n // Computed line-heights for each breakpoint\n // Title: text-xs + leading-snug = 16.5px, text-[11px] + leading-snug = 15.125px\n const titleHeight = isSmall ? 15 : 16.5;\n // Value: leading-tight (×1.25) applied on top of font-size\n const valueHeight = isSmall\n ? 22.5 // text-lg: 18 × 1.25\n : (containerWidth !== null && containerWidth < 300)\n ? 25 // text-xl: 20 × 1.25\n : 30; // text-2xl: 24 × 1.25\n // Comparison: text-xs = 12px / 16px line-height (no leading override)\n const comparisonHeight = 16;\n // Icon: 14px when small, 18px otherwise\n const iconSize = isSmall ? 14 : 18;\n\n const baseClass = embedded\n ? `flex flex-col min-w-0 h-full ${isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\"}`\n : cls(\"rounded-lg flex flex-col min-w-0 bg-transparent border\", defaultBorderMixin, isSmall ? \"px-3.5 py-3\" : \"px-5 py-4\");\n\n return (\n <div\n ref={containerRef}\n className={cls(\"animate-pulse\", baseClass)}\n style={embedded ? undefined : fixedHeight ? { height: fixedHeight } : { minHeight: isSmall ? 68 : 92 }}\n >\n {/* Title row — identical flex structure to InsightsScorecardView */}\n <div className={`flex items-center justify-between ${isSmall ? \"mb-1\" : \"mb-2\"}`}>\n <div className=\"flex flex-col min-w-0\">\n {/* Title placeholder */}\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded\"\n style={{ height: titleHeight, width: \"60%\" }}\n />\n {/* DateRange — hidden when isSmall, same as real view (line 134) */}\n {hasDateRange && !isSmall && (\n <div className=\"bg-surface-200/60 dark:bg-surface-700/60 rounded mt-0.5\"\n style={{ height: 14, width: \"40%\" }}\n />\n )}\n </div>\n {/* Icon placeholder — same wrapper as real view */}\n {hasIcon && (\n <span className=\"ml-2 shrink-0\">\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded\"\n style={{ height: iconSize, width: iconSize }}\n />\n </span>\n )}\n </div>\n\n {/* Main value placeholder */}\n <div className=\"bg-surface-200 dark:bg-surface-700 rounded\"\n style={{ height: valueHeight, width: \"40%\" }}\n />\n\n {/* Comparison placeholder */}\n {hasComparison && (\n <div className={isSmall ? \"mt-0.5\" : \"mt-1\"}>\n <div className=\"bg-surface-200/60 dark:bg-surface-700/60 rounded\"\n style={{ height: comparisonHeight, width: \"25%\" }}\n />\n </div>\n )}\n </div>\n );\n}\n\nInsightWidgetSkeleton.displayName = \"InsightWidgetSkeleton\";\n","import React from \"react\";\nimport type { InsightDefinition, DataRow, ScorecardConfig } from \"../types\";\nimport { useInsightsData } from \"../engine/useInsightsData\";\nimport { InsightsScorecardView } from \"./InsightsScorecardView\";\nimport { InsightWidgetSkeleton } from \"./InsightWidgetSkeleton\";\n\n/**\n * Compute a deterministic fixed height for a standard scorecard based\n * on which optional elements the config declares. This eliminates\n * layout shift between skeleton and loaded states.\n *\n * Breakdown (non-compact, non-small):\n * py-4 padding: 16 + 16 = 32\n * title row: 16.5 (text-xs leading-snug)\n * mb-2 margin: 8\n * value: 30 (text-2xl leading-tight)\n * ---\n * base: 86.5\n * + dateRange: +16 (14px text + 2px mt-0.5)\n * + comparison: +20 (16px text + 4px mt-1)\n */\nfunction computeFixedHeight(config: ScorecardConfig): number {\n let h = 86.5; // base: padding + title + mb-2 + value\n if (config.dateRange) h += 16;\n if (config.comparison) h += 20;\n return Math.ceil(h);\n}\n\n/**\n * Single insight widget orchestrator.\n *\n * Wraps skeleton and loaded states in a fixed-height container\n * (computed from the scorecard config) to prevent layout shift.\n *\n * All theme-awareness is handled via Tailwind `dark:` classes.\n */\nexport function InsightWidget({\n definition,\n collectionSlug,\n path,\n parentCollectionSlugs, parentEntityIds,\n compact = false,\n embedded = false,\n}: {\n definition: InsightDefinition;\n collectionSlug?: string;\n path?: string;\n parentCollectionSlugs?: string[], parentEntityIds?: string[];\n compact?: boolean;\n /** When true, inner views skip their own borders since the parent card provides them. */\n embedded?: boolean;\n}) {\n const { data, loading, error } = useInsightsData(definition, { path, collectionSlug, parentCollectionSlugs });\n\n // For non-compact, non-embedded standard scorecards, use a fixed height\n // derived from the config to prevent layout shift between skeleton → loaded.\n const fixedHeight = (!compact && !embedded) ? computeFixedHeight(definition.scorecard) : undefined;\n\n if (loading) {\n return <InsightWidgetSkeleton config={definition.scorecard} compact={compact} embedded={embedded} fixedHeight={fixedHeight} />;\n }\n\n if (error) {\n return (\n <div\n className={`text-red-500/70 dark:text-red-400/70 text-[0.8125rem] ${embedded ? \"px-5 py-4 h-full\" : `rounded-lg bg-red-500/5 dark:bg-red-400/5 border border-red-500/10 dark:border-red-400/10 ${compact ? \"px-3.5 py-3\" : \"px-5 py-4\"}`}`}\n style={fixedHeight ? { height: fixedHeight } : undefined}\n >\n <div className=\"font-semibold mb-1\">{definition.title}</div>\n <div>{error.message}</div>\n </div>\n );\n }\n\n if (!data || data.rows.length === 0) {\n return (\n <div\n className={`text-surface-400 dark:text-surface-500 text-[0.8125rem] ${embedded ? \"px-5 py-4 h-full\" : `rounded-lg bg-surface-100 dark:bg-surface-800 border border-surface-200 dark:border-surface-700 ${compact ? \"px-3.5 py-3\" : \"px-5 py-4\"}`}`}\n style={fixedHeight ? { height: fixedHeight } : undefined}\n >\n {definition.title} — No data\n </div>\n );\n }\n\n return (\n <InsightsScorecardView\n config={definition.scorecard}\n data={data.rows[0] as DataRow}\n title={definition.title}\n compact={compact}\n embedded={embedded}\n fixedHeight={fixedHeight}\n />\n );\n}\n\nInsightWidget.displayName = \"InsightWidget\";\n","import React from \"react\";\nimport type { InsightDefinition } from \"../types\";\nimport { InsightWidget } from \"./InsightWidget\";\n\n/**\n * Renders compact insight widgets inline within a home page collection card.\n * Injected via the `home.card.insight` slot.\n *\n * Uses a horizontal flex layout so multiple cards sit side by side.\n */\nexport function HomeCardInsightSlot({\n slug,\n insights,\n}: {\n slug: string;\n collection: unknown;\n context: unknown;\n insights: InsightDefinition[];\n}) {\n if (!insights || insights.length === 0) return null;\n\n // Each compact card row is ~42px; estimate 2 cards per row for wrapping\n const estimatedRows = Math.ceil(insights.length / 2);\n const minHeight = estimatedRows * 42 + (estimatedRows - 1) * 6; // 6px = gap-1.5\n\n return (\n <div className=\"flex flex-wrap items-center gap-1.5 mt-2\" style={{ minHeight }}>\n {insights.map((def) => (\n <InsightWidget\n key={def.id}\n definition={def}\n collectionSlug={slug}\n compact={true}\n />\n ))}\n </div>\n );\n}\n\nHomeCardInsightSlot.displayName = \"HomeCardInsightSlot\";\n","import React from \"react\";\nimport type { InsightDefinition } from \"../types\";\nimport { InsightWidget } from \"./InsightWidget\";\n\n/**\n * Scorecard insights panel rendered at the top of the home page.\n * Injected via the `home.children.start` slot.\n *\n * Renders scorecards in a responsive grid (up to 4 columns).\n */\nexport function HomeInsightsSlot({\n insights,\n}: {\n insights: InsightDefinition[];\n}) {\n if (!insights || insights.length === 0) return null;\n\n return (\n <div\n className=\"grid grid-cols-2 sm:grid-cols-3 lg:grid-cols-4 gap-3 pb-6\"\n style={{ minHeight: 92 }}\n >\n {insights.map((def) => (\n <InsightWidget key={def.id} definition={def} />\n ))}\n </div>\n );\n}\n\nHomeInsightsSlot.displayName = \"HomeInsightsSlot\";\n","import React from \"react\";\nimport type { InsightDefinition } from \"../types\";\nimport { InsightWidget } from \"./InsightWidget\";\n\n/**\n * Renders scorecard insight widgets inline within a collection's list view,\n * positioned below the title and above the main data list.\n *\n * Injected via the `collection.insights` slot.\n */\nexport function CollectionInsightsInline({\n insights,\n path,\n parentCollectionSlugs,\n parentEntityIds\n}: {\n path: string;\n collection: unknown;\n parentCollectionSlugs: string[], parentEntityIds: string[];\n insights: InsightDefinition[];\n}) {\n if (!insights || insights.length === 0) return null;\n\n return (\n <div className=\"grid grid-cols-2 sm:grid-cols-3 lg:grid-cols-4 gap-3 pb-4\">\n {insights.map((def) => (\n <InsightWidget \n key={def.id} \n definition={def} \n path={path}\n parentCollectionSlugs={parentCollectionSlugs} parentEntityIds={parentEntityIds}\n />\n ))}\n </div>\n );\n}\n\nCollectionInsightsInline.displayName = \"CollectionInsightsInline\";\n","import React from \"react\";\nimport type { RebasePlugin, SlotContribution } from \"@rebasepro/types\";\nimport type { InsightsPluginConfig } from \"./types\";\nimport { InsightsProvider } from \"./engine/InsightsProvider\";\nimport { HomeCardInsightSlot } from \"./components/HomeCardInsightSlot\";\nimport { HomeInsightsSlot } from \"./components/HomeInsightsSlot\";\nimport { CollectionInsightsInline } from \"./components/CollectionInsightsInline\";\n\n/**\n * Creates the Insights plugin for Rebase.\n *\n * This plugin injects scorecard widgets into key UI locations:\n * - **Home page header**: KPI overview via `home.children.start` slot\n * - **Collection list view**: Scorecards inline (below title, above list) via `collection.insights` slot\n * - **Home page cards**: Compact scorecard metrics auto-extracted from collection insights via `home.card.insight` slot\n *\n * Collection-level insights (`collections.<slug>`) are the single source of truth:\n * scorecards render in the collection list view and are automatically extracted\n * to show as compact widgets on the corresponding home page card.\n *\n * Each insight owns its own `data()` callback — use the Rebase client SDK,\n * call a custom function, or hit any external API. Full flexibility, zero new endpoints.\n *\n * @example\n * ```typescript\n * import { useInsightsPlugin } from \"@rebasepro/plugin-insights\";\n *\n * const insightsPlugin = useInsightsPlugin({\n * cacheTTL: 120_000,\n * insights: {\n * home: [\n * { id: \"revenue\", title: \"Revenue\", data: async () => ..., scorecard: { ... } },\n * ],\n * collections: {\n * orders: [\n * { id: \"total\", title: \"Total Orders\", data: async () => ..., scorecard: { ... } },\n * ],\n * },\n * },\n * });\n * ```\n */\nexport function useInsightsPlugin(config: InsightsPluginConfig): RebasePlugin {\n const { insights, cacheTTL } = config;\n const slots: SlotContribution[] = [];\n\n // ── Home page insights ────────────────────────────────────────────\n if (insights.home && insights.home.length > 0) {\n const homeInsights = insights.home;\n slots.push({\n slot: \"home.children.start\" as const,\n Component: (props: Record<string, unknown>) => (\n <HomeInsightsSlot\n {...props}\n insights={homeInsights}\n />\n ),\n order: 10,\n });\n }\n\n // ── Per-collection insights ───────────────────────────────────────\n // A single `collections.<slug>` definition serves two slots:\n // 1. collection.insights → inline scorecards in the list view\n // 2. home.card.insight → compact scorecards on the home card\n if (insights.collections) {\n for (const [slug, defs] of Object.entries(insights.collections)) {\n if (defs.length === 0) continue;\n const collectionInsights = defs;\n\n // 1. Inline in collection list view\n slots.push({\n slot: \"collection.insights\" as const,\n Component: (props: Record<string, unknown>) => {\n const path = props.path as string;\n const collectionSlug = path?.split(\"/\").filter(Boolean).pop() ?? \"\";\n if (collectionSlug !== slug) return null;\n return (\n <CollectionInsightsInline\n {...props as { path: string; collection: unknown; parentCollectionSlugs: string[], parentEntityIds: string[] }}\n insights={collectionInsights}\n />\n );\n },\n order: 10,\n });\n\n // 2. Auto-extract scorecards for home page card\n slots.push({\n slot: \"home.card.insight\" as const,\n Component: (props: Record<string, unknown>) => {\n const cardSlug = props.slug as string;\n if (cardSlug !== slug) return null;\n return (\n <HomeCardInsightSlot\n {...props as { slug: string; collection: unknown; context: unknown }}\n insights={collectionInsights}\n />\n );\n },\n order: 10,\n });\n }\n }\n\n return {\n key: \"plugin-insights\",\n slots,\n providers: [\n {\n scope: \"root\" as const,\n Component: InsightsProvider as React.ComponentType<React.PropsWithChildren<Record<string, unknown>>>,\n props: { cacheTTL },\n },\n ],\n };\n}\n"],"names":["InsightsCache","constructor","ttl","cache","Map","inflight","get","key","entry","Date","now","timestamp","delete","data","set","getInflight","setInflight","promise","invalidate","clear","InsightsContext","createContext","InsightsProvider","t0","$","_c","cacheTTL","children","t1","t2","t3","t4","value","t5","jsx","useInsightsEngine","useContext","useInsightsData","definition","context","engine","initialLoading","authLoading","user","loginSkipped","useAuthController","authReady","Boolean","setData","useState","loading","setLoading","error","setError","cacheKey","id","path","collectionSlug","cancelled","cached","then","result","catch","err","Error","String","finally","result_0","err_0","useEffect","formatNumber","format","undefined","options","style","notation","maximumFractionDigits","decimals","minimumFractionDigits","currency","formatted","Intl","NumberFormat","showSign","InsightsScorecardView","config","title","compact","embedded","fixedHeight","containerRef","useRef","containerWidth","setContainerWidth","Symbol","for","current","offsetWidth","observer","ResizeObserver","entries","contentRect","width","observe","disconnect","React","useLayoutEffect","mainValue","field","formattedValue","comparisonElement","comparison","comparisonValue","t6","formattedComparison","isPositive","isNegative","colorClass","intent","t7","t8","isSmall","icon","getIcon","iconElement","cls","defaultBorderMixin","t9","t10","jsxs","t11","baseClass","height","minHeight","t12","dateRange","t13","t14","t15","t16","t17","t18","t19","displayName","InsightWidgetSkeleton","hasComparison","hasIcon","hasDateRange","StandardSkeleton","titleHeight","valueHeight","iconSize","computeFixedHeight","h","Math","ceil","InsightWidget","parentCollectionSlugs","scorecard","message","rows","length","HomeCardInsightSlot","slug","insights","estimatedRows","def","map","HomeInsightsSlot","_temp","CollectionInsightsInline","parentEntityIds","useInsightsPlugin","slots","home","homeInsights","push","slot","Component","props","order","collections","defs","Object","collectionInsights","split","filter","pop","cardSlug","providers","scope"],"mappings":"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"}
@@ -2,8 +2,8 @@ import type { InsightDefinition } from "../types";
2
2
  /**
3
3
  * Single insight widget orchestrator.
4
4
  *
5
- * Fetches data via the engine, renders the scorecard visualization,
6
- * and manages loading/error states.
5
+ * Wraps skeleton and loaded states in a fixed-height container
6
+ * (computed from the scorecard config) to prevent layout shift.
7
7
  *
8
8
  * All theme-awareness is handled via Tailwind `dark:` classes.
9
9
  */
@@ -14,12 +14,14 @@ import type { ScorecardConfig } from "../types";
14
14
  * Tailwind line-heights (accounting for `leading-*` overrides).
15
15
  * This guarantees a pixel-perfect skeleton → loaded transition.
16
16
  */
17
- export declare function InsightWidgetSkeleton({ config, compact, embedded, }: {
17
+ export declare function InsightWidgetSkeleton({ config, compact, embedded, fixedHeight, }: {
18
18
  /** Scorecard config — used to match optional elements (comparison, dateRange, icon). */
19
19
  config: ScorecardConfig;
20
20
  compact?: boolean;
21
21
  /** When true, skip own border since the parent card provides it. */
22
22
  embedded?: boolean;
23
+ /** Explicit height to prevent layout shift between skeleton → loaded. */
24
+ fixedHeight?: number;
23
25
  }): import("react/jsx-runtime").JSX.Element;
24
26
  export declare namespace InsightWidgetSkeleton {
25
27
  var displayName: string;
@@ -6,13 +6,15 @@ import type { DataRow, ScorecardConfig } from "../types";
6
6
  * Uses Tailwind `dark:` classes — no JS dark mode detection.
7
7
  * Icons are resolved via `getIcon` from `@rebasepro/core`.
8
8
  */
9
- export declare function InsightsScorecardView({ config, data, title, compact, embedded, }: {
9
+ export declare function InsightsScorecardView({ config, data, title, compact, embedded, fixedHeight, }: {
10
10
  config: ScorecardConfig;
11
11
  data: DataRow;
12
12
  title: string;
13
13
  compact?: boolean;
14
14
  /** When true, skip own border/bg since the parent card provides them. */
15
15
  embedded?: boolean;
16
+ /** Explicit height to prevent layout shift between skeleton → loaded. */
17
+ fixedHeight?: number;
16
18
  }): import("react/jsx-runtime").JSX.Element;
17
19
  export declare namespace InsightsScorecardView {
18
20
  var displayName: string;
@@ -1,6 +1,4 @@
1
- import { StorageSource } from "./storage";
2
- import { Role, User } from "../users";
3
- import { RebaseData } from "./data";
1
+ import type { User } from "../users";
4
2
  /**
5
3
  * Capabilities advertised by an auth provider.
6
4
  * UI components use this to show/hide features dynamically
@@ -64,7 +62,7 @@ export type AuthController<USER extends User = User, ExtraData = unknown> = {
64
62
  extra: ExtraData;
65
63
  setExtra: (extra: ExtraData) => void;
66
64
  setUser?(user: USER | null): void;
67
- setUserRoles?(roles: Role[]): void;
65
+ setUserRoles?(roles: string[]): void;
68
66
  /**
69
67
  * Capabilities advertised by the auth provider.
70
68
  * UI components use this to feature-detect what the backend supports.
@@ -89,6 +87,8 @@ export interface AuthControllerExtended<USER extends User = User, ExtraData = un
89
87
  code: string;
90
88
  redirectUri: string;
91
89
  }) => Promise<void>;
90
+ /** Generic OAuth login — works with any provider. Posts payload to /auth/{providerId}. */
91
+ oauthLogin?: (providerId: string, payload: Record<string, unknown>) => Promise<void>;
92
92
  /** Register a new user */
93
93
  register?(email: string, password: string, displayName?: string): Promise<void>;
94
94
  /** Skip login (for anonymous access if enabled) */
@@ -102,25 +102,3 @@ export interface AuthControllerExtended<USER extends User = User, ExtraData = un
102
102
  /** Update user profile */
103
103
  updateProfile?(displayName?: string, photoURL?: string): Promise<USER>;
104
104
  }
105
- /**
106
- * Implement this function to allow access to specific users.
107
- * @group Hooks and utilities
108
- */
109
- export type Authenticator<USER extends User = User> = (props: {
110
- /**
111
- * Logged-in user or null
112
- */
113
- user: USER | null;
114
- /**
115
- * AuthController
116
- */
117
- authController: AuthController<USER>;
118
- /**
119
- * Unified data access API
120
- */
121
- data: RebaseData;
122
- /**
123
- * Used storage implementation
124
- */
125
- storageSource: StorageSource;
126
- }) => boolean | Promise<boolean>;
@@ -1,6 +1,6 @@
1
- import { User } from "../users";
2
- import { RebaseData } from "./data";
3
- import { EmailService } from "./email";
1
+ import type { User } from "../users";
2
+ import type { RebaseData } from "./data";
3
+ import type { EmailService } from "./email";
4
4
  /**
5
5
  * Event type for authentication state changes
6
6
  */
@@ -14,7 +14,7 @@ export interface RebaseSession {
14
14
  expiresAt: number;
15
15
  user: User;
16
16
  }
17
- import { StorageSource } from "./storage";
17
+ import type { StorageSource } from "./storage";
18
18
  /**
19
19
  * Unified Authentication Client Interface
20
20
  * Pure functional SDK interface, decoupled from UI and React hooks
@@ -56,20 +56,9 @@ export interface AdminUser {
56
56
  createdAt: string;
57
57
  updatedAt: string;
58
58
  }
59
- /**
60
- * Role record as returned by the Admin API.
61
- * @group Admin
62
- */
63
- export interface AdminRole {
64
- id: string;
65
- name: string;
66
- isAdmin: boolean;
67
- defaultPermissions: Record<string, unknown> | null;
68
- config: Record<string, unknown> | null;
69
- }
70
59
  /**
71
60
  * Client-side Admin API interface.
72
- * Provides user and role management operations.
61
+ * Provides user management operations.
73
62
  * @group Admin
74
63
  */
75
64
  export interface AdminAPI {
@@ -112,32 +101,6 @@ export interface AdminAPI {
112
101
  deleteUser(userId: string): Promise<{
113
102
  success: boolean;
114
103
  }>;
115
- listRoles(): Promise<{
116
- roles: AdminRole[];
117
- }>;
118
- getRole(roleId: string): Promise<{
119
- role: AdminRole;
120
- }>;
121
- createRole(data: {
122
- id: string;
123
- name: string;
124
- isAdmin?: boolean;
125
- defaultPermissions?: Record<string, unknown>;
126
- config?: Record<string, unknown>;
127
- }): Promise<{
128
- role: AdminRole;
129
- }>;
130
- updateRole(roleId: string, data: {
131
- name?: string;
132
- isAdmin?: boolean;
133
- defaultPermissions?: Record<string, unknown>;
134
- config?: Record<string, unknown>;
135
- }): Promise<{
136
- role: AdminRole;
137
- }>;
138
- deleteRole(roleId: string): Promise<{
139
- success: boolean;
140
- }>;
141
104
  bootstrap(): Promise<{
142
105
  success: boolean;
143
106
  message: string;
@@ -168,7 +131,7 @@ export interface RebaseClient<DB = unknown> {
168
131
  * > The client-side SDK does not include an email service.
169
132
  */
170
133
  email?: EmailService;
171
- /** Admin API for user and role management */
134
+ /** Admin API for user management */
172
135
  admin?: AdminAPI;
173
136
  /**
174
137
  * The base HTTP URL of the backend server.
@@ -183,4 +146,23 @@ export interface RebaseClient<DB = unknown> {
183
146
  * detection (e.g. `typeof ws.executeSql === "function"`).
184
147
  */
185
148
  ws?: unknown;
149
+ /**
150
+ * Execute raw SQL against the database.
151
+ *
152
+ * Only available server-side when the backend uses a SQL database
153
+ * (PostgreSQL, MySQL, etc.). `undefined` for document databases
154
+ * (MongoDB, Firestore) and on the client-side SDK.
155
+ *
156
+ * @example
157
+ * ```typescript
158
+ * // In a cron job or custom function:
159
+ * if (ctx.client.sql) {
160
+ * const rows = await ctx.client.sql("SELECT count(*) FROM orders");
161
+ * }
162
+ * ```
163
+ */
164
+ sql?(query: string, options?: {
165
+ database?: string;
166
+ role?: string;
167
+ }): Promise<Record<string, unknown>[]>;
186
168
  }
@@ -4,7 +4,7 @@ import type { EntityReference } from "../types/entities";
4
4
  * Controller that provides access to the registered entity collections.
5
5
  * @group Models
6
6
  */
7
- export type CollectionRegistryController<DB = Record<string, unknown>, EC extends EntityCollection = EntityCollection<any>> = {
7
+ export type CollectionRegistryController<DB = Record<string, unknown>, EC extends EntityCollection = EntityCollection> = {
8
8
  /**
9
9
  * List of the mapped collections in the CMS.
10
10
  * Each entry relates to a collection in the root database.
@@ -125,6 +125,10 @@ export interface CollectionAccessor<M extends Record<string, unknown> = Record<s
125
125
  * Delete a record by ID.
126
126
  */
127
127
  delete(id: string | number): Promise<void>;
128
+ /**
129
+ * Delete all records in this collection.
130
+ */
131
+ deleteAll?(): Promise<void>;
128
132
  /**
129
133
  * Subscribe to a collection for real-time updates.
130
134
  * Optional method, may not be supported by all implementations (like stateless HTTP clients).
@@ -17,6 +17,21 @@ export type ListenEntityProps<M extends Record<string, unknown> = Record<string,
17
17
  onUpdate: (entity: Entity<M> | null) => void;
18
18
  onError?: (error: Error) => void;
19
19
  };
20
+ /**
21
+ * Configuration for vector similarity search queries.
22
+ * Vector search applies an ORDER BY distance expression and optionally
23
+ * filters results by a distance threshold.
24
+ */
25
+ export interface VectorSearchParams {
26
+ /** Property name containing the vector column */
27
+ property: string;
28
+ /** Query vector to compare against */
29
+ vector: number[];
30
+ /** Distance function (default: "cosine") */
31
+ distance?: "cosine" | "l2" | "inner_product";
32
+ /** Only return results within this distance threshold */
33
+ threshold?: number;
34
+ }
20
35
  /**
21
36
  * @internal
22
37
  */
@@ -30,6 +45,8 @@ export interface FetchCollectionProps<M extends Record<string, unknown> = Record
30
45
  orderBy?: string;
31
46
  searchString?: string;
32
47
  order?: "desc" | "asc";
48
+ /** Vector similarity search configuration */
49
+ vectorSearch?: VectorSearchParams;
33
50
  }
34
51
  /**
35
52
  * @internal
@@ -112,6 +129,11 @@ export interface DataDriver {
112
129
  * @return was the whole deletion flow successful
113
130
  */
114
131
  deleteEntity<M extends Record<string, unknown> = Record<string, unknown>>(props: DeleteEntityProps<M>): Promise<void>;
132
+ /**
133
+ * Delete all entities from a collection.
134
+ * @param path Collection path
135
+ */
136
+ deleteAll?(path: string): Promise<void>;
115
137
  /**
116
138
  * Check if the given property is unique in the given collection
117
139
  * @param path Collection path
@@ -187,6 +209,7 @@ export interface RestFetchService {
187
209
  startAfter?: Record<string, unknown>;
188
210
  searchString?: string;
189
211
  databaseId?: string;
212
+ vectorSearch?: VectorSearchParams;
190
213
  }, include?: string[]): Promise<Record<string, unknown>[]>;
191
214
  /**
192
215
  * Fetch a single flattened entity with optional relation includes.
@@ -4,6 +4,7 @@ import type { EntityCollectionsBuilder } from "../types/builders";
4
4
  import type { EntityCustomView } from "../types/entity_views";
5
5
  import type { EntityAction } from "../types/entity_actions";
6
6
  import type { AppView, NavigationGroupMapping } from "./navigation";
7
+ import type { RebasePlugin } from "../types/plugins";
7
8
  /**
8
9
  * Options to enable the built-in collection editor.
9
10
  * When provided to `<RebaseCMS>`, the editor is auto-wired as a native feature.
@@ -19,12 +20,12 @@ export interface CollectionEditorOptions {
19
20
  /** Suggested base paths shown when creating new collections. */
20
21
  pathSuggestions?: string[];
21
22
  }
22
- export interface RebaseCMSConfig<EC extends EntityCollection = any> {
23
+ export interface RebaseCMSConfig<EC extends EntityCollection = EntityCollection> {
23
24
  collections?: EC[] | EntityCollectionsBuilder<EC>;
24
25
  homePage?: ReactNode;
25
- entityViews?: EntityCustomView<any>[];
26
+ entityViews?: EntityCustomView[];
26
27
  entityActions?: EntityAction[];
27
- plugins?: any[];
28
+ plugins?: RebasePlugin[];
28
29
  /**
29
30
  * Centralized configuration for how collections and views are grouped
30
31
  * in the navigation sidebar and home page.
@@ -42,7 +43,7 @@ export interface RebaseCMSConfig<EC extends EntityCollection = any> {
42
43
  collectionEditor?: boolean | CollectionEditorOptions;
43
44
  }
44
45
  export interface RebaseStudioConfig {
45
- tools?: ("sql" | "js" | "rls" | "schema" | "storage" | "cron" | "schema-visualizer" | "branches" | "api")[];
46
+ tools?: ("sql" | "js" | "rls" | "schema" | "storage" | "cron" | "schema-visualizer" | "branches" | "api" | "logs")[];
46
47
  homePage?: ReactNode;
47
48
  devViews?: AppView[];
48
49
  }
@@ -28,7 +28,7 @@ export type RebaseCallContext<USER extends User = User> = {
28
28
  * const { client } = props.context;
29
29
  * const result = await client.functions.invoke('extract-job', { url });
30
30
  */
31
- client: RebaseClient<any>;
31
+ client: RebaseClient;
32
32
  /**
33
33
  * Unified data access — `context.data.products.create(...)`.
34
34
  * Access any collection as a dynamic property.