@rebasepro/plugin-insights 0.2.1 → 0.2.4

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 (54) hide show
  1. package/dist/common/src/collections/default-collections.d.ts +12 -0
  2. package/dist/common/src/collections/index.d.ts +1 -0
  3. package/dist/common/src/data/query_builder.d.ts +51 -0
  4. package/dist/common/src/index.d.ts +1 -0
  5. package/dist/common/src/util/permissions.d.ts +1 -0
  6. package/dist/core/src/components/LoginView/LoginView.d.ts +17 -1
  7. package/dist/core/src/components/common/types.d.ts +10 -7
  8. package/dist/core/src/components/common/useDebouncedData.d.ts +1 -1
  9. package/dist/core/src/core/RebaseProps.d.ts +13 -2
  10. package/dist/core/src/core/RebaseRouter.d.ts +1 -1
  11. package/dist/core/src/hooks/index.d.ts +0 -1
  12. package/dist/core/src/util/entity_cache.d.ts +0 -5
  13. package/dist/core/src/util/index.d.ts +0 -2
  14. package/dist/core/src/util/useStorageUploadController.d.ts +2 -2
  15. package/dist/formex/src/utils.d.ts +2 -2
  16. package/dist/index.es.js +1 -0
  17. package/dist/index.es.js.map +1 -1
  18. package/dist/index.umd.js +1 -0
  19. package/dist/index.umd.js.map +1 -1
  20. package/dist/types/src/controllers/auth.d.ts +2 -24
  21. package/dist/types/src/controllers/client.d.ts +0 -3
  22. package/dist/types/src/controllers/collection_registry.d.ts +1 -1
  23. package/dist/types/src/controllers/data.d.ts +21 -0
  24. package/dist/types/src/controllers/data_driver.d.ts +18 -0
  25. package/dist/types/src/controllers/registry.d.ts +5 -4
  26. package/dist/types/src/rebase_context.d.ts +1 -1
  27. package/dist/types/src/types/auth_adapter.d.ts +2 -4
  28. package/dist/types/src/types/collections.d.ts +0 -4
  29. package/dist/types/src/types/component_ref.d.ts +1 -1
  30. package/dist/types/src/types/cron.d.ts +1 -1
  31. package/dist/types/src/types/entity_views.d.ts +1 -0
  32. package/dist/types/src/types/export_import.d.ts +1 -1
  33. package/dist/types/src/types/formex.d.ts +2 -2
  34. package/dist/types/src/types/properties.d.ts +2 -2
  35. package/dist/types/src/types/translations.d.ts +28 -12
  36. package/dist/types/src/types/user_management_delegate.d.ts +6 -4
  37. package/dist/types/src/users/roles.d.ts +0 -8
  38. package/dist/ui/src/components/Button.d.ts +2 -2
  39. package/dist/ui/src/components/ErrorBoundary.d.ts +25 -3
  40. package/dist/ui/src/components/VirtualTable/VirtualTable.d.ts +1 -1
  41. package/dist/ui/src/components/VirtualTable/VirtualTableCell.d.ts +6 -6
  42. package/dist/ui/src/components/VirtualTable/VirtualTableHeader.d.ts +8 -8
  43. package/dist/ui/src/components/VirtualTable/VirtualTableHeaderRow.d.ts +1 -1
  44. package/dist/ui/src/components/VirtualTable/VirtualTableProps.d.ts +11 -11
  45. package/dist/ui/src/components/VirtualTable/VirtualTableRow.d.ts +1 -1
  46. package/dist/ui/src/components/VirtualTable/types.d.ts +9 -9
  47. package/dist/ui/src/hooks/useDebounceCallback.d.ts +1 -1
  48. package/dist/ui/src/util/debounce.d.ts +1 -1
  49. package/package.json +9 -3
  50. package/src/engine/InsightsCache.test.ts +56 -0
  51. package/src/engine/useInsightsData.ts +1 -0
  52. package/dist/core/src/hooks/useValidateAuthenticator.d.ts +0 -21
  53. package/dist/core/src/util/icon_synonyms.d.ts +0 -1
  54. package/dist/core/src/util/useTraceUpdate.d.ts +0 -2
@@ -0,0 +1,12 @@
1
+ import { PostgresCollection } from "@rebasepro/types";
2
+ /**
3
+ * Default users collection definition.
4
+ *
5
+ * Shared between the admin UI (for navigation/display) and the backend
6
+ * (for schema generation). Both consumers prepend this to the developer's
7
+ * collections array and rely on generic slug-based deduplication
8
+ * (Map keyed by slug, last-write-wins) so that developer-defined
9
+ * collections with the same slug override this default — no hardcoded
10
+ * string checks required.
11
+ */
12
+ export declare const defaultUsersCollection: PostgresCollection;
@@ -1 +1,2 @@
1
1
  export * from "./CollectionRegistry";
2
+ export * from "./default-collections";
@@ -0,0 +1,51 @@
1
+ import { FindResponse, CollectionAccessor, QueryBuilderInterface, FilterOperator } from "@rebasepro/types";
2
+ export declare class QueryBuilder<M extends Record<string, unknown> = Record<string, unknown>> implements QueryBuilderInterface<M> {
3
+ private collection;
4
+ private params;
5
+ constructor(collection: CollectionAccessor<M>);
6
+ /**
7
+ * Add a filter condition to your query.
8
+ * @example
9
+ * client.collection('users').where('age', '>=', 18).find()
10
+ */
11
+ where(column: keyof M & string, operator: FilterOperator, value: unknown): this;
12
+ /**
13
+ * Order the results by a specific column.
14
+ * @example
15
+ * client.collection('users').orderBy('createdAt', 'desc').find()
16
+ */
17
+ orderBy(column: keyof M & string, ascending?: "asc" | "desc"): this;
18
+ /**
19
+ * Limit the number of results returned.
20
+ */
21
+ limit(count: number): this;
22
+ /**
23
+ * Skip the first N results.
24
+ */
25
+ offset(count: number): this;
26
+ /**
27
+ * Set a free-text search string if supported by the backend.
28
+ */
29
+ search(searchString: string): this;
30
+ /**
31
+ * Include related entities in the response.
32
+ * Relations will be populated with full entity data instead of just IDs.
33
+ *
34
+ * @param relations - Relation names to include, or "*" for all.
35
+ * @example
36
+ * // Include specific relations
37
+ * client.data.posts.include("tags", "author").find()
38
+ *
39
+ * // Include all relations
40
+ * client.data.posts.include("*").find()
41
+ */
42
+ include(...relations: string[]): this;
43
+ /**
44
+ * Execute the find query and return the results.
45
+ */
46
+ find(): Promise<FindResponse<M>>;
47
+ /**
48
+ * Listen to realtime updates matching this query.
49
+ */
50
+ listen(onUpdate: (data: FindResponse<M>) => void, onError?: (error: Error) => void): () => void;
51
+ }
@@ -1,3 +1,4 @@
1
1
  export * from "./util";
2
2
  export * from "./collections";
3
3
  export * from "./data/buildRebaseData";
4
+ export * from "./data/query_builder";
@@ -1,4 +1,5 @@
1
1
  import { AuthController, Entity, EntityCollection, User } from "@rebasepro/types";
2
+ export declare function checkOperation<M extends Record<string, unknown>, USER extends User>(collection: EntityCollection<M>, authController: AuthController<USER>, entity: Entity<M> | null, targetOperation: "select" | "insert" | "update" | "delete"): boolean;
2
3
  export declare function canReadCollection<M extends Record<string, unknown>, USER extends User>(collection: EntityCollection<M>, authController: AuthController<USER>): boolean;
3
4
  export declare function canEditEntity<M extends Record<string, unknown>, USER extends User>(collection: EntityCollection<M>, authController: AuthController<USER>, path: string, entity: Entity<M> | null): boolean;
4
5
  export declare function canCreateEntity<M extends Record<string, unknown>, USER extends User>(collection: EntityCollection<M>, authController: AuthController<USER>, path: string, entity: Entity<M> | null): boolean;
@@ -66,6 +66,22 @@ export interface LoginViewProps {
66
66
  * Required when Google login is enabled via ID token flow.
67
67
  */
68
68
  googleClientId?: string;
69
+ /**
70
+ * GitHub client ID for GitHub OAuth.
71
+ */
72
+ githubClientId?: string;
73
+ /**
74
+ * LinkedIn client ID for LinkedIn OAuth.
75
+ */
76
+ linkedinClientId?: string;
77
+ /**
78
+ * Optional custom title shown above options
79
+ */
80
+ title?: string;
81
+ /**
82
+ * Optional custom subtitle shown above options
83
+ */
84
+ subtitle?: string;
69
85
  /**
70
86
  * When true, shows bootstrap/setup UI (first-user creation).
71
87
  * If not set, derived from `authController` if it exposes `needsSetup`.
@@ -82,4 +98,4 @@ export interface LoginViewProps {
82
98
  * Feature-detects capabilities to show/hide login methods.
83
99
  * @group Core
84
100
  */
85
- export declare function LoginView({ logo, authController, noUserComponent, disableSignupScreen, disabled, notAllowedError, googleClientId, needsSetup, registrationEnabled }: LoginViewProps): import("react/jsx-runtime").JSX.Element;
101
+ export declare function LoginView({ logo, authController, noUserComponent, disableSignupScreen, disabled, notAllowedError, googleClientId, githubClientId, linkedinClientId, title, subtitle, needsSetup, registrationEnabled, additionalComponent }: LoginViewProps): import("react/jsx-runtime").JSX.Element;
@@ -1,14 +1,17 @@
1
1
  import type { Property } from "@rebasepro/types";
2
2
  import { CollectionSize, SelectedCellProps } from "@rebasepro/types";
3
- export type EntityCollectionTableController<M extends Record<string, any>> = {
3
+ export type EntityCollectionTableController<M extends Record<string, unknown>> = {
4
4
  /**
5
5
  * This cell is displayed as selected
6
6
  */
7
- selectedCell?: SelectedCellProps<any>;
7
+ selectedCell?: SelectedCellProps;
8
8
  /**
9
9
  * Store used to sync selection state across cells efficiently.
10
10
  */
11
- selectionStore?: any;
11
+ selectionStore?: {
12
+ getSnapshot: () => SelectedCellProps | undefined;
13
+ subscribe: (cb: () => void) => () => void;
14
+ };
12
15
  /**
13
16
  * Select a table cell
14
17
  * @param cell
@@ -23,7 +26,7 @@ export type EntityCollectionTableController<M extends Record<string, any>> = {
23
26
  * Callback used when the value of a cell has changed.
24
27
  * @param params
25
28
  */
26
- onValueChange?: (params: OnCellValueChangeParams<any, M>) => void;
29
+ onValueChange?: (params: OnCellValueChangeParams<unknown, M>) => void;
27
30
  /**
28
31
  * Size of the elements in the collection
29
32
  */
@@ -33,7 +36,7 @@ export type EntityCollectionTableController<M extends Record<string, any>> = {
33
36
  * Props passed in a callback when the content of a cell in a table has been edited
34
37
  * @group Collection components
35
38
  */
36
- export interface OnCellValueChangeParams<T = any, D = any> {
39
+ export interface OnCellValueChangeParams<T = unknown, D = unknown> {
37
40
  value: T;
38
41
  propertyKey: string;
39
42
  data?: D;
@@ -45,7 +48,7 @@ export interface OnCellValueChangeParams<T = any, D = any> {
45
48
  */
46
49
  export type UniqueFieldValidator = (props: {
47
50
  name: string;
48
- value: any;
51
+ value: unknown;
49
52
  property: Property;
50
53
  entityId?: string | number;
51
54
  }) => Promise<boolean>;
@@ -53,7 +56,7 @@ export type UniqueFieldValidator = (props: {
53
56
  * Callback when a cell has changed in a table
54
57
  * @group Collection components
55
58
  */
56
- export type OnCellValueChange<T, M extends Record<string, any>> = (params: OnCellValueChangeParams<T, M>) => Promise<void> | void;
59
+ export type OnCellValueChange<T, M extends Record<string, unknown>> = (params: OnCellValueChangeParams<T, M>) => Promise<void> | void;
57
60
  /**
58
61
  * @group Collection components
59
62
  */
@@ -6,4 +6,4 @@
6
6
  * @param deps
7
7
  * @param timeoutMs
8
8
  */
9
- export declare function useDebouncedData<T>(data: T[], deps: any, timeoutMs?: number): T[];
9
+ export declare function useDebouncedData<T>(data: T[], deps: unknown, timeoutMs?: number): T[];
@@ -1,5 +1,9 @@
1
1
  import React from "react";
2
- import { Locale, User, AuthController, AnalyticsEvent, DataDriver, StorageSource, UserConfigurationPersistence, DatabaseAdmin, RebaseData, RebaseClient, RebaseContext, UserManagementDelegate, EntityLinkBuilder, RebasePlugin, SlotContribution, PropertyConfig, EntityCustomView, EntityAction } from "@rebasepro/types";
2
+ import { Locale, User, AuthController, AnalyticsEvent, DataDriver, StorageSource, UserConfigurationPersistence, DatabaseAdmin, RebaseData, RebaseClient, RebaseContext, UserManagementDelegate, EntityLinkBuilder, RebasePlugin, SlotContribution, PropertyConfig, EntityCustomView, EntityAction, RebaseTranslations } from "@rebasepro/types";
3
+ /** DeepPartial helper — allows partial overrides at any nesting level */
4
+ type DeepPartial<T> = T extends object ? {
5
+ [K in keyof T]?: DeepPartial<T[K]>;
6
+ } : T;
3
7
  /**
4
8
  * Controller to simulate different roles when dev mode is active.
5
9
  * @group Models
@@ -116,7 +120,7 @@ export type RebaseProps<USER extends User> = {
116
120
  /**
117
121
  * Entity Views
118
122
  */
119
- entityViews?: EntityCustomView<any>[];
123
+ entityViews?: EntityCustomView[];
120
124
  /**
121
125
  * Entity Actions
122
126
  */
@@ -133,4 +137,11 @@ export type RebaseProps<USER extends User> = {
133
137
  * Controller to simulate different roles when dev mode is active.
134
138
  */
135
139
  effectiveRoleController?: EffectiveRoleController;
140
+ /**
141
+ * Override or extend any Rebase UI string, keyed by locale.
142
+ */
143
+ translations?: {
144
+ [locale: string]: DeepPartial<RebaseTranslations>;
145
+ };
136
146
  };
147
+ export {};
@@ -1,4 +1,4 @@
1
1
  export declare function RebaseRouter({ children, basePath }: {
2
- children: any;
2
+ children: React.ReactNode;
3
3
  basePath?: string;
4
4
  }): import("react/jsx-runtime").JSX.Element;
@@ -26,7 +26,6 @@ export * from "./useSlot";
26
26
  export * from "./useCustomizationController";
27
27
  export * from "./useBuildLocalConfigurationPersistence";
28
28
  export * from "./useBuildModeController";
29
- export * from "./useValidateAuthenticator";
30
29
  export * from "./useRebaseRegistry";
31
30
  export * from "./useBackendStorageSource";
32
31
  export * from "./usePermissions";
@@ -7,7 +7,6 @@ export declare function saveEntityToCache(path: string, data: object): void;
7
7
  export declare function removeEntityFromMemoryCache(path: string): void;
8
8
  export declare function saveEntityToMemoryCache(path: string, data: object): void;
9
9
  export declare function getEntityFromMemoryCache(path: string): object | undefined;
10
- export declare function hasEntityInCache(path: string): boolean;
11
10
  /**
12
11
  * Retrieves an entity from the in-memory cache or `sessionStorage`.
13
12
  * If the entity is not in the cache but exists in `sessionStorage`, it loads it into the cache.
@@ -20,8 +19,4 @@ export declare function getEntityFromCache(path: string): object | undefined;
20
19
  * @param path - The unique path/key for the entity to remove.
21
20
  */
22
21
  export declare function removeEntityFromCache(path: string): void;
23
- /**
24
- * Clears the entire in-memory cache and removes all related entities from `sessionStorage`.
25
- */
26
- export declare function clearEntityCache(): void;
27
22
  export declare function flattenKeys(obj: Record<string, unknown> | unknown[], prefix?: string, result?: string[]): string[];
@@ -1,10 +1,8 @@
1
1
  export * from "./icon_list";
2
- export * from "./icon_synonyms";
3
2
  export * from "./icons";
4
3
  export * from "./createFormexStub";
5
4
  export * from "./entity_cache";
6
5
  export * from "./useStorageUploadController";
7
- export * from "./useTraceUpdate";
8
6
  export * from "./previews";
9
7
  export * from "./enums";
10
8
  export * from "./constants";
@@ -12,7 +12,7 @@ export interface StorageFieldItem {
12
12
  storagePathOrDownloadUrl?: string;
13
13
  file?: File;
14
14
  fileName?: string;
15
- metadata?: any;
15
+ metadata?: Record<string, unknown>;
16
16
  size: StorageFieldSize;
17
17
  }
18
18
  export declare function useStorageUploadController<M extends Record<string, unknown>>({ entityId, entityValues, path, value, property, propertyKey, storageSource, disabled, onChange }: {
@@ -31,7 +31,7 @@ export declare function useStorageUploadController<M extends Record<string, unkn
31
31
  storage: StorageConfig;
32
32
  fileNameBuilder: (file: File) => Promise<string>;
33
33
  storagePathBuilder: (file: File) => string;
34
- onFileUploadComplete: (uploadedPath: string, entry: StorageFieldItem, metadata?: any, uploadedUrl?: string) => Promise<void>;
34
+ onFileUploadComplete: (uploadedPath: string, entry: StorageFieldItem, metadata?: Record<string, unknown>, uploadedUrl?: string) => Promise<void>;
35
35
  onFileUploadError: (entry: StorageFieldItem) => void;
36
36
  onFilesAdded: (acceptedFiles: File[]) => Promise<void>;
37
37
  multipleFilesSupported: boolean;
@@ -11,6 +11,6 @@ export declare const isNaN: (obj: unknown) => boolean;
11
11
  /**
12
12
  * Deeply get a value from an object via its path.
13
13
  */
14
- export declare function getIn(obj: any, key: string | string[], def?: unknown, p?: number): any;
15
- export declare function setIn(obj: any, path: string, value: unknown): any;
14
+ export declare function getIn(obj: unknown, key: string | string[], def?: unknown, p?: number): unknown;
15
+ export declare function setIn(obj: unknown, path: string, value: unknown): unknown;
16
16
  export declare function clone(value: unknown): unknown;
package/dist/index.es.js CHANGED
@@ -144,6 +144,7 @@ function useInsightsData(definition, context) {
144
144
  setData(result_0);
145
145
  }
146
146
  }).catch((err_0) => {
147
+ cache.invalidate(cacheKey);
147
148
  if (!cancelled) {
148
149
  setError(err_0 instanceof Error ? err_0 : new Error(String(err_0)));
149
150
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.es.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","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","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.es.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}: {\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","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","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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"}
package/dist/index.umd.js CHANGED
@@ -143,6 +143,7 @@
143
143
  setData(result_0);
144
144
  }
145
145
  }).catch((err_0) => {
146
+ cache.invalidate(cacheKey);
146
147
  if (!cancelled) {
147
148
  setError(err_0 instanceof Error ? err_0 : new Error(String(err_0)));
148
149
  }