@rebasepro/plugin-insights 0.0.1-canary.09e5ec5

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 (301) hide show
  1. package/LICENSE +6 -0
  2. package/dist/common/src/collections/CollectionRegistry.d.ts +56 -0
  3. package/dist/common/src/collections/index.d.ts +1 -0
  4. package/dist/common/src/data/buildRebaseData.d.ts +14 -0
  5. package/dist/common/src/index.d.ts +3 -0
  6. package/dist/common/src/util/builders.d.ts +57 -0
  7. package/dist/common/src/util/callbacks.d.ts +6 -0
  8. package/dist/common/src/util/collections.d.ts +11 -0
  9. package/dist/common/src/util/common.d.ts +2 -0
  10. package/dist/common/src/util/conditions.d.ts +26 -0
  11. package/dist/common/src/util/entities.d.ts +58 -0
  12. package/dist/common/src/util/enums.d.ts +3 -0
  13. package/dist/common/src/util/index.d.ts +16 -0
  14. package/dist/common/src/util/navigation_from_path.d.ts +34 -0
  15. package/dist/common/src/util/navigation_utils.d.ts +20 -0
  16. package/dist/common/src/util/parent_references_from_path.d.ts +6 -0
  17. package/dist/common/src/util/paths.d.ts +14 -0
  18. package/dist/common/src/util/permissions.d.ts +5 -0
  19. package/dist/common/src/util/references.d.ts +2 -0
  20. package/dist/common/src/util/relations.d.ts +22 -0
  21. package/dist/common/src/util/resolutions.d.ts +72 -0
  22. package/dist/common/src/util/storage.d.ts +24 -0
  23. package/dist/core/src/components/AIIcon.d.ts +16 -0
  24. package/dist/core/src/components/ConfirmationDialog.d.ts +9 -0
  25. package/dist/core/src/components/Debug/UIReferenceView.d.ts +1 -0
  26. package/dist/core/src/components/Debug/UIStyleGuide.d.ts +1 -0
  27. package/dist/core/src/components/ErrorTooltip.d.ts +2 -0
  28. package/dist/core/src/components/ErrorView.d.ts +21 -0
  29. package/dist/core/src/components/LanguageToggle.d.ts +1 -0
  30. package/dist/core/src/components/LoginView/LoginView.d.ts +68 -0
  31. package/dist/core/src/components/LoginView/index.d.ts +2 -0
  32. package/dist/core/src/components/NotFoundPage.d.ts +1 -0
  33. package/dist/core/src/components/RebaseAuth.d.ts +10 -0
  34. package/dist/core/src/components/RebaseLogo.d.ts +7 -0
  35. package/dist/core/src/components/UnsavedChangesDialog.d.ts +9 -0
  36. package/dist/core/src/components/UserDisplay.d.ts +7 -0
  37. package/dist/core/src/components/UserSelectPopover.d.ts +62 -0
  38. package/dist/core/src/components/UserSettingsView.d.ts +1 -0
  39. package/dist/core/src/components/common/index.d.ts +6 -0
  40. package/dist/core/src/components/common/table_height.d.ts +5 -0
  41. package/dist/core/src/components/common/types.d.ts +63 -0
  42. package/dist/core/src/components/common/useColumnsIds.d.ts +9 -0
  43. package/dist/core/src/components/common/useDataTableController.d.ts +45 -0
  44. package/dist/core/src/components/common/useDebouncedData.d.ts +9 -0
  45. package/dist/core/src/components/common/useScrollRestoration.d.ts +14 -0
  46. package/dist/core/src/components/index.d.ts +16 -0
  47. package/dist/core/src/contexts/AdminModeController.d.ts +4 -0
  48. package/dist/core/src/contexts/AnalyticsContext.d.ts +3 -0
  49. package/dist/core/src/contexts/AuthControllerContext.d.ts +3 -0
  50. package/dist/core/src/contexts/CustomizationControllerContext.d.ts +3 -0
  51. package/dist/core/src/contexts/DataDriverContext.d.ts +3 -0
  52. package/dist/core/src/contexts/DatabaseAdminContext.d.ts +3 -0
  53. package/dist/core/src/contexts/DialogsProvider.d.ts +4 -0
  54. package/dist/core/src/contexts/EffectiveRoleController.d.ts +4 -0
  55. package/dist/core/src/contexts/InternalUserManagementContext.d.ts +3 -0
  56. package/dist/core/src/contexts/ModeController.d.ts +4 -0
  57. package/dist/core/src/contexts/RebaseClientInstanceContext.d.ts +6 -0
  58. package/dist/core/src/contexts/RebaseDataContext.d.ts +3 -0
  59. package/dist/core/src/contexts/SnackbarProvider.d.ts +2 -0
  60. package/dist/core/src/contexts/StorageSourceContext.d.ts +3 -0
  61. package/dist/core/src/contexts/UserConfigurationPersistenceContext.d.ts +3 -0
  62. package/dist/core/src/contexts/index.d.ts +13 -0
  63. package/dist/core/src/core/PluginLifecycleManager.d.ts +17 -0
  64. package/dist/core/src/core/PluginProviderStack.d.ts +21 -0
  65. package/dist/core/src/core/Rebase.d.ts +14 -0
  66. package/dist/core/src/core/RebaseProps.d.ts +136 -0
  67. package/dist/core/src/core/RebaseRouter.d.ts +4 -0
  68. package/dist/core/src/core/RebaseRoutes.d.ts +17 -0
  69. package/dist/core/src/core/index.d.ts +4 -0
  70. package/dist/core/src/hooks/ApiConfigContext.d.ts +24 -0
  71. package/dist/core/src/hooks/data/delete.d.ts +31 -0
  72. package/dist/core/src/hooks/data/save.d.ts +34 -0
  73. package/dist/core/src/hooks/data/useCollectionFetch.d.ts +51 -0
  74. package/dist/core/src/hooks/data/useData.d.ts +13 -0
  75. package/dist/core/src/hooks/data/useDataOrder.d.ts +12 -0
  76. package/dist/core/src/hooks/data/useEntityFetch.d.ts +38 -0
  77. package/dist/core/src/hooks/data/useRelationSelector.d.ts +52 -0
  78. package/dist/core/src/hooks/data/useUserSelector.d.ts +31 -0
  79. package/dist/core/src/hooks/index.d.ts +37 -0
  80. package/dist/core/src/hooks/useAdminModeController.d.ts +19 -0
  81. package/dist/core/src/hooks/useAnalyticsController.d.ts +5 -0
  82. package/dist/core/src/hooks/useAuthController.d.ts +11 -0
  83. package/dist/core/src/hooks/useAuthSubscription.d.ts +2 -0
  84. package/dist/core/src/hooks/useBackendStorageSource.d.ts +30 -0
  85. package/dist/core/src/hooks/useBridgeRegistration.d.ts +18 -0
  86. package/dist/core/src/hooks/useBrowserTitleAndIcon.d.ts +6 -0
  87. package/dist/core/src/hooks/useBuildAdminModeController.d.ts +6 -0
  88. package/dist/core/src/hooks/useBuildEffectiveRoleController.d.ts +8 -0
  89. package/dist/core/src/hooks/useBuildLocalConfigurationPersistence.d.ts +2 -0
  90. package/dist/core/src/hooks/useBuildModeController.d.ts +6 -0
  91. package/dist/core/src/hooks/useClipboard.d.ts +57 -0
  92. package/dist/core/src/hooks/useCollapsedGroups.d.ts +12 -0
  93. package/dist/core/src/hooks/useCustomizationController.d.ts +11 -0
  94. package/dist/core/src/hooks/useDialogsController.d.ts +11 -0
  95. package/dist/core/src/hooks/useEffectiveRoleController.d.ts +7 -0
  96. package/dist/core/src/hooks/useInternalUserManagementController.d.ts +12 -0
  97. package/dist/core/src/hooks/useLargeLayout.d.ts +1 -0
  98. package/dist/core/src/hooks/useModeController.d.ts +19 -0
  99. package/dist/core/src/hooks/usePermissions.d.ts +12 -0
  100. package/dist/core/src/hooks/useRebaseClient.d.ts +5 -0
  101. package/dist/core/src/hooks/useRebaseContext.d.ts +11 -0
  102. package/dist/core/src/hooks/useRebaseRegistry.d.ts +34 -0
  103. package/dist/core/src/hooks/useSlot.d.ts +18 -0
  104. package/dist/core/src/hooks/useSnackbarController.d.ts +20 -0
  105. package/dist/core/src/hooks/useStorageSource.d.ts +7 -0
  106. package/dist/core/src/hooks/useStudioBridge.d.ts +91 -0
  107. package/dist/core/src/hooks/useTranslation.d.ts +17 -0
  108. package/dist/core/src/hooks/useUnsavedChangesDialog.d.ts +12 -0
  109. package/dist/core/src/hooks/useUserConfigurationPersistence.d.ts +8 -0
  110. package/dist/core/src/hooks/useValidateAuthenticator.d.ts +21 -0
  111. package/dist/core/src/i18n/RebaseI18nProvider.d.ts +33 -0
  112. package/dist/core/src/index.d.ts +15 -0
  113. package/dist/core/src/internal/common.d.ts +3 -0
  114. package/dist/core/src/internal/useRestoreScroll.d.ts +6 -0
  115. package/dist/core/src/locales/de.d.ts +2 -0
  116. package/dist/core/src/locales/en.d.ts +10 -0
  117. package/dist/core/src/locales/es.d.ts +10 -0
  118. package/dist/core/src/locales/fr.d.ts +2 -0
  119. package/dist/core/src/locales/hi.d.ts +2 -0
  120. package/dist/core/src/locales/it.d.ts +2 -0
  121. package/dist/core/src/locales/pt.d.ts +7 -0
  122. package/dist/core/src/util/constants.d.ts +1 -0
  123. package/dist/core/src/util/createFormexStub.d.ts +2 -0
  124. package/dist/core/src/util/entity_cache.d.ts +27 -0
  125. package/dist/core/src/util/enums.d.ts +5 -0
  126. package/dist/core/src/util/icon_list.d.ts +5 -0
  127. package/dist/core/src/util/icon_synonyms.d.ts +1 -0
  128. package/dist/core/src/util/icons.d.ts +20 -0
  129. package/dist/core/src/util/index.d.ts +10 -0
  130. package/dist/core/src/util/previews.d.ts +4 -0
  131. package/dist/core/src/util/useStorageUploadController.d.ts +38 -0
  132. package/dist/core/src/util/useTraceUpdate.d.ts +2 -0
  133. package/dist/formex/src/Field.d.ts +52 -0
  134. package/dist/formex/src/Formex.d.ts +7 -0
  135. package/dist/formex/src/index.d.ts +5 -0
  136. package/dist/formex/src/types.d.ts +40 -0
  137. package/dist/formex/src/useCreateFormex.d.ts +14 -0
  138. package/dist/formex/src/utils.d.ts +16 -0
  139. package/dist/index.es.js +945 -0
  140. package/dist/index.es.js.map +1 -0
  141. package/dist/index.umd.js +944 -0
  142. package/dist/index.umd.js.map +1 -0
  143. package/dist/plugin-insights/src/components/CollectionInsightsInline.d.ts +16 -0
  144. package/dist/plugin-insights/src/components/HomeCardInsightSlot.d.ts +16 -0
  145. package/dist/plugin-insights/src/components/HomeInsightsSlot.d.ts +13 -0
  146. package/dist/plugin-insights/src/components/InsightWidget.d.ts +19 -0
  147. package/dist/plugin-insights/src/components/InsightWidgetSkeleton.d.ts +20 -0
  148. package/dist/plugin-insights/src/components/InsightsScorecardView.d.ts +19 -0
  149. package/dist/plugin-insights/src/engine/InsightsCache.d.ts +18 -0
  150. package/dist/plugin-insights/src/engine/InsightsProvider.d.ts +22 -0
  151. package/dist/plugin-insights/src/engine/useInsightsData.d.ts +17 -0
  152. package/dist/plugin-insights/src/index.d.ts +8 -0
  153. package/dist/plugin-insights/src/types/engine.d.ts +79 -0
  154. package/dist/plugin-insights/src/types/index.d.ts +2 -0
  155. package/dist/plugin-insights/src/types/widgets.d.ts +59 -0
  156. package/dist/plugin-insights/src/useInsightsPlugin.d.ts +37 -0
  157. package/dist/types/src/controllers/analytics_controller.d.ts +7 -0
  158. package/dist/types/src/controllers/auth.d.ts +119 -0
  159. package/dist/types/src/controllers/client.d.ts +170 -0
  160. package/dist/types/src/controllers/collection_registry.d.ts +45 -0
  161. package/dist/types/src/controllers/customization_controller.d.ts +60 -0
  162. package/dist/types/src/controllers/data.d.ts +168 -0
  163. package/dist/types/src/controllers/data_driver.d.ts +160 -0
  164. package/dist/types/src/controllers/database_admin.d.ts +11 -0
  165. package/dist/types/src/controllers/dialogs_controller.d.ts +36 -0
  166. package/dist/types/src/controllers/effective_role.d.ts +4 -0
  167. package/dist/types/src/controllers/email.d.ts +34 -0
  168. package/dist/types/src/controllers/index.d.ts +18 -0
  169. package/dist/types/src/controllers/local_config_persistence.d.ts +20 -0
  170. package/dist/types/src/controllers/navigation.d.ts +213 -0
  171. package/dist/types/src/controllers/registry.d.ts +54 -0
  172. package/dist/types/src/controllers/side_dialogs_controller.d.ts +67 -0
  173. package/dist/types/src/controllers/side_entity_controller.d.ts +90 -0
  174. package/dist/types/src/controllers/snackbar.d.ts +24 -0
  175. package/dist/types/src/controllers/storage.d.ts +171 -0
  176. package/dist/types/src/index.d.ts +4 -0
  177. package/dist/types/src/rebase_context.d.ts +105 -0
  178. package/dist/types/src/types/backend.d.ts +536 -0
  179. package/dist/types/src/types/builders.d.ts +15 -0
  180. package/dist/types/src/types/chips.d.ts +5 -0
  181. package/dist/types/src/types/collections.d.ts +856 -0
  182. package/dist/types/src/types/cron.d.ts +102 -0
  183. package/dist/types/src/types/data_source.d.ts +64 -0
  184. package/dist/types/src/types/entities.d.ts +145 -0
  185. package/dist/types/src/types/entity_actions.d.ts +98 -0
  186. package/dist/types/src/types/entity_callbacks.d.ts +173 -0
  187. package/dist/types/src/types/entity_link_builder.d.ts +7 -0
  188. package/dist/types/src/types/entity_overrides.d.ts +10 -0
  189. package/dist/types/src/types/entity_views.d.ts +61 -0
  190. package/dist/types/src/types/export_import.d.ts +21 -0
  191. package/dist/types/src/types/index.d.ts +23 -0
  192. package/dist/types/src/types/locales.d.ts +4 -0
  193. package/dist/types/src/types/modify_collections.d.ts +5 -0
  194. package/dist/types/src/types/plugins.d.ts +279 -0
  195. package/dist/types/src/types/properties.d.ts +1176 -0
  196. package/dist/types/src/types/property_config.d.ts +70 -0
  197. package/dist/types/src/types/relations.d.ts +336 -0
  198. package/dist/types/src/types/slots.d.ts +252 -0
  199. package/dist/types/src/types/translations.d.ts +870 -0
  200. package/dist/types/src/types/user_management_delegate.d.ts +121 -0
  201. package/dist/types/src/types/websockets.d.ts +78 -0
  202. package/dist/types/src/users/index.d.ts +2 -0
  203. package/dist/types/src/users/roles.d.ts +22 -0
  204. package/dist/types/src/users/user.d.ts +46 -0
  205. package/dist/ui/src/components/Alert.d.ts +12 -0
  206. package/dist/ui/src/components/Autocomplete.d.ts +21 -0
  207. package/dist/ui/src/components/Avatar.d.ts +11 -0
  208. package/dist/ui/src/components/Badge.d.ts +8 -0
  209. package/dist/ui/src/components/BooleanSwitch.d.ts +14 -0
  210. package/dist/ui/src/components/BooleanSwitchWithLabel.d.ts +17 -0
  211. package/dist/ui/src/components/Button.d.ts +14 -0
  212. package/dist/ui/src/components/Card.d.ts +9 -0
  213. package/dist/ui/src/components/CenteredView.d.ts +9 -0
  214. package/dist/ui/src/components/Checkbox.d.ts +13 -0
  215. package/dist/ui/src/components/Chip.d.ts +26 -0
  216. package/dist/ui/src/components/CircularProgress.d.ts +5 -0
  217. package/dist/ui/src/components/CircularProgressCenter.d.ts +11 -0
  218. package/dist/ui/src/components/Collapse.d.ts +9 -0
  219. package/dist/ui/src/components/ColorPicker.d.ts +30 -0
  220. package/dist/ui/src/components/Container.d.ts +8 -0
  221. package/dist/ui/src/components/DateTimeField.d.ts +24 -0
  222. package/dist/ui/src/components/DebouncedTextField.d.ts +2 -0
  223. package/dist/ui/src/components/Dialog.d.ts +39 -0
  224. package/dist/ui/src/components/DialogActions.d.ts +7 -0
  225. package/dist/ui/src/components/DialogContent.d.ts +7 -0
  226. package/dist/ui/src/components/DialogTitle.d.ts +10 -0
  227. package/dist/ui/src/components/ErrorBoundary.d.ts +11 -0
  228. package/dist/ui/src/components/ExpandablePanel.d.ts +12 -0
  229. package/dist/ui/src/components/FileUpload.d.ts +23 -0
  230. package/dist/ui/src/components/IconButton.d.ts +12 -0
  231. package/dist/ui/src/components/InfoLabel.d.ts +5 -0
  232. package/dist/ui/src/components/InputLabel.d.ts +11 -0
  233. package/dist/ui/src/components/Label.d.ts +7 -0
  234. package/dist/ui/src/components/LoadingButton.d.ts +7 -0
  235. package/dist/ui/src/components/Markdown.d.ts +10 -0
  236. package/dist/ui/src/components/Menu.d.ts +23 -0
  237. package/dist/ui/src/components/Menubar.d.ts +80 -0
  238. package/dist/ui/src/components/MultiSelect.d.ts +48 -0
  239. package/dist/ui/src/components/Paper.d.ts +6 -0
  240. package/dist/ui/src/components/Popover.d.ts +24 -0
  241. package/dist/ui/src/components/RadioGroup.d.ts +28 -0
  242. package/dist/ui/src/components/ResizablePanels.d.ts +18 -0
  243. package/dist/ui/src/components/SearchBar.d.ts +22 -0
  244. package/dist/ui/src/components/Select.d.ts +43 -0
  245. package/dist/ui/src/components/Separator.d.ts +5 -0
  246. package/dist/ui/src/components/Sheet.d.ts +22 -0
  247. package/dist/ui/src/components/Skeleton.d.ts +6 -0
  248. package/dist/ui/src/components/Slider.d.ts +21 -0
  249. package/dist/ui/src/components/Table.d.ts +34 -0
  250. package/dist/ui/src/components/Tabs.d.ts +19 -0
  251. package/dist/ui/src/components/TextField.d.ts +58 -0
  252. package/dist/ui/src/components/TextareaAutosize.d.ts +43 -0
  253. package/dist/ui/src/components/ToggleButtonGroup.d.ts +30 -0
  254. package/dist/ui/src/components/Tooltip.d.ts +19 -0
  255. package/dist/ui/src/components/Typography.d.ts +36 -0
  256. package/dist/ui/src/components/VirtualTable/VirtualTable.d.ts +11 -0
  257. package/dist/ui/src/components/VirtualTable/VirtualTableCell.d.ts +21 -0
  258. package/dist/ui/src/components/VirtualTable/VirtualTableHeader.d.ts +29 -0
  259. package/dist/ui/src/components/VirtualTable/VirtualTableHeaderRow.d.ts +2 -0
  260. package/dist/ui/src/components/VirtualTable/VirtualTableProps.d.ts +243 -0
  261. package/dist/ui/src/components/VirtualTable/VirtualTableRow.d.ts +3 -0
  262. package/dist/ui/src/components/VirtualTable/index.d.ts +3 -0
  263. package/dist/ui/src/components/VirtualTable/types.d.ts +38 -0
  264. package/dist/ui/src/components/common/SelectInputLabel.d.ts +5 -0
  265. package/dist/ui/src/components/index.d.ts +53 -0
  266. package/dist/ui/src/hooks/PortalContainerContext.d.ts +31 -0
  267. package/dist/ui/src/hooks/index.d.ts +6 -0
  268. package/dist/ui/src/hooks/useDebounceCallback.d.ts +1 -0
  269. package/dist/ui/src/hooks/useDebounceValue.d.ts +1 -0
  270. package/dist/ui/src/hooks/useDebouncedCallback.d.ts +1 -0
  271. package/dist/ui/src/hooks/useInjectStyles.d.ts +7 -0
  272. package/dist/ui/src/hooks/useOutsideAlerter.d.ts +5 -0
  273. package/dist/ui/src/icons/GitHubIcon.d.ts +2 -0
  274. package/dist/ui/src/icons/HandleIcon.d.ts +1 -0
  275. package/dist/ui/src/icons/Icon.d.ts +20 -0
  276. package/dist/ui/src/icons/cool_icon_keys.d.ts +1 -0
  277. package/dist/ui/src/icons/icon_keys.d.ts +1 -0
  278. package/dist/ui/src/icons/index.d.ts +6 -0
  279. package/dist/ui/src/index.d.ts +5 -0
  280. package/dist/ui/src/styles.d.ts +12 -0
  281. package/dist/ui/src/util/chip_colors.d.ts +4 -0
  282. package/dist/ui/src/util/cls.d.ts +2 -0
  283. package/dist/ui/src/util/debounce.d.ts +10 -0
  284. package/dist/ui/src/util/hash.d.ts +1 -0
  285. package/dist/ui/src/util/index.d.ts +4 -0
  286. package/dist/ui/src/util/key_to_icon_component.d.ts +1 -0
  287. package/package.json +80 -0
  288. package/src/components/CollectionInsightsInline.tsx +30 -0
  289. package/src/components/HomeCardInsightSlot.tsx +36 -0
  290. package/src/components/HomeInsightsSlot.tsx +30 -0
  291. package/src/components/InsightWidget.tsx +65 -0
  292. package/src/components/InsightWidgetSkeleton.tsx +122 -0
  293. package/src/components/InsightsScorecardView.tsx +160 -0
  294. package/src/engine/InsightsCache.ts +52 -0
  295. package/src/engine/InsightsProvider.tsx +38 -0
  296. package/src/engine/useInsightsData.ts +100 -0
  297. package/src/index.ts +22 -0
  298. package/src/types/engine.ts +85 -0
  299. package/src/types/index.ts +5 -0
  300. package/src/types/widgets.ts +66 -0
  301. package/src/useInsightsPlugin.tsx +117 -0
@@ -0,0 +1,945 @@
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { c } from "react-compiler-runtime";
3
+ import React, { createContext, useContext, useState, useEffect, useRef } from "react";
4
+ import { useAuthController, getIcon } from "@rebasepro/core";
5
+ import { cls, defaultBorderMixin } from "@rebasepro/ui";
6
+ class InsightsCache {
7
+ constructor(ttl = 6e4) {
8
+ this.ttl = ttl;
9
+ }
10
+ cache = /* @__PURE__ */ new Map();
11
+ inflight = /* @__PURE__ */ new Map();
12
+ get(key) {
13
+ const entry = this.cache.get(key);
14
+ if (!entry) return null;
15
+ if (Date.now() - entry.timestamp > this.ttl) {
16
+ this.cache.delete(key);
17
+ return null;
18
+ }
19
+ return entry.data;
20
+ }
21
+ set(key, data) {
22
+ this.cache.set(key, {
23
+ data,
24
+ timestamp: Date.now()
25
+ });
26
+ this.inflight.delete(key);
27
+ }
28
+ getInflight(key) {
29
+ return this.inflight.get(key) ?? null;
30
+ }
31
+ setInflight(key, promise) {
32
+ this.inflight.set(key, promise);
33
+ }
34
+ invalidate(key) {
35
+ if (key) {
36
+ this.cache.delete(key);
37
+ this.inflight.delete(key);
38
+ } else {
39
+ this.cache.clear();
40
+ this.inflight.clear();
41
+ }
42
+ }
43
+ }
44
+ const InsightsContext = createContext(null);
45
+ function InsightsProvider(t0) {
46
+ const $ = c(7);
47
+ const {
48
+ cacheTTL,
49
+ children
50
+ } = t0;
51
+ let t1;
52
+ let t2;
53
+ if ($[0] !== cacheTTL) {
54
+ t2 = new InsightsCache(cacheTTL);
55
+ $[0] = cacheTTL;
56
+ $[1] = t2;
57
+ } else {
58
+ t2 = $[1];
59
+ }
60
+ t1 = t2;
61
+ const cache = t1;
62
+ let t3;
63
+ let t4;
64
+ if ($[2] !== cache) {
65
+ t4 = {
66
+ cache
67
+ };
68
+ $[2] = cache;
69
+ $[3] = t4;
70
+ } else {
71
+ t4 = $[3];
72
+ }
73
+ t3 = t4;
74
+ const value = t3;
75
+ let t5;
76
+ if ($[4] !== children || $[5] !== value) {
77
+ t5 = /* @__PURE__ */ jsx(InsightsContext.Provider, { value, children });
78
+ $[4] = children;
79
+ $[5] = value;
80
+ $[6] = t5;
81
+ } else {
82
+ t5 = $[6];
83
+ }
84
+ return t5;
85
+ }
86
+ function useInsightsEngine() {
87
+ return useContext(InsightsContext);
88
+ }
89
+ function useInsightsData(definition, collectionSlug) {
90
+ const $ = c(16);
91
+ const engine = useInsightsEngine();
92
+ const cache = engine?.cache ?? null;
93
+ const {
94
+ initialLoading,
95
+ authLoading,
96
+ user,
97
+ loginSkipped
98
+ } = useAuthController();
99
+ const authReady = !initialLoading && !authLoading && (Boolean(user) || loginSkipped);
100
+ const [data, setData] = useState(null);
101
+ const [loading, setLoading] = useState(true);
102
+ const [error, setError] = useState(null);
103
+ const cacheKey = `${definition.id}:${collectionSlug ?? "global"}`;
104
+ let t0;
105
+ if ($[0] !== authReady || $[1] !== cache || $[2] !== cacheKey || $[3] !== definition) {
106
+ t0 = () => {
107
+ if (!authReady || !cache) {
108
+ return;
109
+ }
110
+ let cancelled;
111
+ cancelled = false;
112
+ const cached = cache.get(cacheKey);
113
+ if (cached) {
114
+ setData(cached);
115
+ setLoading(false);
116
+ return;
117
+ }
118
+ const inflight = cache.getInflight(cacheKey);
119
+ if (inflight) {
120
+ setLoading(true);
121
+ inflight.then((result) => {
122
+ if (!cancelled) {
123
+ setData(result);
124
+ }
125
+ }).catch((err) => {
126
+ if (!cancelled) {
127
+ setError(err instanceof Error ? err : new Error(String(err)));
128
+ }
129
+ }).finally(() => {
130
+ if (!cancelled) {
131
+ setLoading(false);
132
+ }
133
+ });
134
+ return;
135
+ }
136
+ setLoading(true);
137
+ setError(null);
138
+ const promise = definition.data();
139
+ cache.setInflight(cacheKey, promise);
140
+ promise.then((result_0) => {
141
+ cache.set(cacheKey, result_0);
142
+ if (!cancelled) {
143
+ setData(result_0);
144
+ }
145
+ }).catch((err_0) => {
146
+ if (!cancelled) {
147
+ setError(err_0 instanceof Error ? err_0 : new Error(String(err_0)));
148
+ }
149
+ }).finally(() => {
150
+ if (!cancelled) {
151
+ setLoading(false);
152
+ }
153
+ });
154
+ return () => {
155
+ cancelled = true;
156
+ };
157
+ };
158
+ $[0] = authReady;
159
+ $[1] = cache;
160
+ $[2] = cacheKey;
161
+ $[3] = definition;
162
+ $[4] = t0;
163
+ } else {
164
+ t0 = $[4];
165
+ }
166
+ let t1;
167
+ if ($[5] !== authReady || $[6] !== cache || $[7] !== cacheKey || $[8] !== collectionSlug || $[9] !== definition.data || $[10] !== definition.id) {
168
+ t1 = [definition.id, definition.data, collectionSlug, cacheKey, cache, authReady];
169
+ $[5] = authReady;
170
+ $[6] = cache;
171
+ $[7] = cacheKey;
172
+ $[8] = collectionSlug;
173
+ $[9] = definition.data;
174
+ $[10] = definition.id;
175
+ $[11] = t1;
176
+ } else {
177
+ t1 = $[11];
178
+ }
179
+ useEffect(t0, t1);
180
+ let t2;
181
+ if ($[12] !== data || $[13] !== error || $[14] !== loading) {
182
+ t2 = {
183
+ data,
184
+ loading,
185
+ error
186
+ };
187
+ $[12] = data;
188
+ $[13] = error;
189
+ $[14] = loading;
190
+ $[15] = t2;
191
+ } else {
192
+ t2 = $[15];
193
+ }
194
+ return t2;
195
+ }
196
+ function formatNumber(value, format) {
197
+ if (value === null || value === void 0) return "N/A";
198
+ const options = {
199
+ style: format?.style ?? "decimal",
200
+ notation: format?.notation ?? "standard",
201
+ maximumFractionDigits: format?.decimals ?? 1,
202
+ minimumFractionDigits: format?.decimals ?? 1
203
+ };
204
+ if (format?.style === "currency") {
205
+ options.currency = format.currency ?? "USD";
206
+ }
207
+ let formatted = new Intl.NumberFormat("en-US", options).format(value);
208
+ if (format?.showSign && value > 0) {
209
+ formatted = "+" + formatted;
210
+ }
211
+ return formatted;
212
+ }
213
+ function InsightsScorecardView(t0) {
214
+ const $ = c(58);
215
+ const {
216
+ config,
217
+ data,
218
+ title,
219
+ compact: t1,
220
+ embedded: t2
221
+ } = t0;
222
+ const compact = t1 === void 0 ? false : t1;
223
+ const embedded = t2 === void 0 ? false : t2;
224
+ const containerRef = useRef(null);
225
+ const [containerWidth, setContainerWidth] = useState(null);
226
+ let t3;
227
+ let t4;
228
+ if ($[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
229
+ t3 = () => {
230
+ if (!containerRef.current) {
231
+ return;
232
+ }
233
+ setContainerWidth(containerRef.current.offsetWidth);
234
+ const observer = new ResizeObserver((entries) => {
235
+ for (const entry of entries) {
236
+ setContainerWidth(entry.contentRect.width);
237
+ }
238
+ });
239
+ observer.observe(containerRef.current);
240
+ return () => observer.disconnect();
241
+ };
242
+ t4 = [];
243
+ $[0] = t3;
244
+ $[1] = t4;
245
+ } else {
246
+ t3 = $[0];
247
+ t4 = $[1];
248
+ }
249
+ React.useLayoutEffect(t3, t4);
250
+ const mainValue = data[config.value.field];
251
+ let t5;
252
+ if ($[2] !== config.value.format || $[3] !== mainValue) {
253
+ t5 = typeof mainValue === "number" ? formatNumber(mainValue, config.value.format) : String(mainValue ?? "N/A");
254
+ $[2] = config.value.format;
255
+ $[3] = mainValue;
256
+ $[4] = t5;
257
+ } else {
258
+ t5 = $[4];
259
+ }
260
+ const formattedValue = t5;
261
+ let comparisonElement = null;
262
+ if (config.comparison) {
263
+ const comparisonValue = data[config.comparison.field];
264
+ if (typeof comparisonValue === "number") {
265
+ let t62;
266
+ if ($[5] !== comparisonValue || $[6] !== config.comparison.format) {
267
+ t62 = formatNumber(comparisonValue, config.comparison.format);
268
+ $[5] = comparisonValue;
269
+ $[6] = config.comparison.format;
270
+ $[7] = t62;
271
+ } else {
272
+ t62 = $[7];
273
+ }
274
+ const formattedComparison = t62;
275
+ const isPositive = comparisonValue > 0;
276
+ const isNegative = comparisonValue < 0;
277
+ let colorClass = "text-surface-500 dark:text-surface-400";
278
+ if (config.comparison.intent === "increase_is_good") {
279
+ if (isPositive) {
280
+ colorClass = "text-emerald-500";
281
+ }
282
+ if (isNegative) {
283
+ colorClass = "text-red-500";
284
+ }
285
+ } else {
286
+ if (config.comparison.intent === "decrease_is_good") {
287
+ if (isPositive) {
288
+ colorClass = "text-red-500";
289
+ }
290
+ if (isNegative) {
291
+ colorClass = "text-emerald-500";
292
+ }
293
+ }
294
+ }
295
+ const t72 = `font-medium ${compact ? "text-[10px]" : "text-xs"} ${colorClass}`;
296
+ let t82;
297
+ if ($[8] !== formattedComparison || $[9] !== t72) {
298
+ t82 = /* @__PURE__ */ jsx("span", { className: t72, children: formattedComparison });
299
+ $[8] = formattedComparison;
300
+ $[9] = t72;
301
+ $[10] = t82;
302
+ } else {
303
+ t82 = $[10];
304
+ }
305
+ comparisonElement = t82;
306
+ }
307
+ }
308
+ const isSmall = compact || containerWidth !== null && containerWidth < 200;
309
+ let t6;
310
+ if ($[11] !== config.icon || $[12] !== isSmall) {
311
+ t6 = config.icon ? getIcon(config.icon, "text-surface-400 dark:text-surface-500", void 0, isSmall ? 14 : 18) : null;
312
+ $[11] = config.icon;
313
+ $[12] = isSmall;
314
+ $[13] = t6;
315
+ } else {
316
+ t6 = $[13];
317
+ }
318
+ const iconElement = t6;
319
+ if (compact) {
320
+ let t72;
321
+ if ($[14] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
322
+ t72 = cls("flex flex-col gap-0.5 px-2.5 py-2 rounded-md bg-transparent border min-w-0", defaultBorderMixin);
323
+ $[14] = t72;
324
+ } else {
325
+ t72 = $[14];
326
+ }
327
+ let t82;
328
+ if ($[15] !== title) {
329
+ t82 = /* @__PURE__ */ jsx("span", { className: "text-[10px] uppercase tracking-wider text-surface-400 dark:text-surface-500 truncate", children: title });
330
+ $[15] = title;
331
+ $[16] = t82;
332
+ } else {
333
+ t82 = $[16];
334
+ }
335
+ let t92;
336
+ if ($[17] !== formattedValue) {
337
+ t92 = /* @__PURE__ */ jsx("span", { className: "text-sm font-semibold tabular-nums text-surface-800 dark:text-surface-100", children: formattedValue });
338
+ $[17] = formattedValue;
339
+ $[18] = t92;
340
+ } else {
341
+ t92 = $[18];
342
+ }
343
+ let t102;
344
+ if ($[19] !== comparisonElement || $[20] !== t92) {
345
+ t102 = /* @__PURE__ */ jsxs("div", { className: "flex items-baseline gap-1.5", children: [
346
+ t92,
347
+ comparisonElement
348
+ ] });
349
+ $[19] = comparisonElement;
350
+ $[20] = t92;
351
+ $[21] = t102;
352
+ } else {
353
+ t102 = $[21];
354
+ }
355
+ let t112;
356
+ if ($[22] !== t102 || $[23] !== t82) {
357
+ t112 = /* @__PURE__ */ jsxs("div", { className: t72, children: [
358
+ t82,
359
+ t102
360
+ ] });
361
+ $[22] = t102;
362
+ $[23] = t82;
363
+ $[24] = t112;
364
+ } else {
365
+ t112 = $[24];
366
+ }
367
+ return t112;
368
+ }
369
+ let t7;
370
+ if ($[25] !== embedded || $[26] !== isSmall) {
371
+ t7 = embedded ? `flex flex-col min-w-0 h-full ${isSmall ? "px-3.5 py-3" : "px-5 py-4"}` : cls("rounded-lg flex flex-col min-w-0 bg-transparent border", defaultBorderMixin, isSmall ? "px-3.5 py-3" : "px-5 py-4");
372
+ $[25] = embedded;
373
+ $[26] = isSmall;
374
+ $[27] = t7;
375
+ } else {
376
+ t7 = $[27];
377
+ }
378
+ const baseClass = t7;
379
+ let t8;
380
+ if ($[28] !== embedded || $[29] !== isSmall) {
381
+ t8 = embedded ? void 0 : {
382
+ minHeight: isSmall ? 68 : 92
383
+ };
384
+ $[28] = embedded;
385
+ $[29] = isSmall;
386
+ $[30] = t8;
387
+ } else {
388
+ t8 = $[30];
389
+ }
390
+ const t9 = `flex items-center justify-between ${isSmall ? "mb-1" : "mb-2"}`;
391
+ const t10 = `font-medium leading-snug truncate text-surface-500 dark:text-surface-400 ${isSmall ? "text-[11px]" : "text-xs"}`;
392
+ let t11;
393
+ if ($[31] !== t10 || $[32] !== title) {
394
+ t11 = /* @__PURE__ */ jsx("span", { className: t10, children: title });
395
+ $[31] = t10;
396
+ $[32] = title;
397
+ $[33] = t11;
398
+ } else {
399
+ t11 = $[33];
400
+ }
401
+ let t12;
402
+ if ($[34] !== config.dateRange || $[35] !== isSmall) {
403
+ t12 = config.dateRange && !isSmall && /* @__PURE__ */ jsx("span", { className: "text-[10px] text-surface-400 dark:text-surface-500 truncate mt-0.5", children: config.dateRange });
404
+ $[34] = config.dateRange;
405
+ $[35] = isSmall;
406
+ $[36] = t12;
407
+ } else {
408
+ t12 = $[36];
409
+ }
410
+ let t13;
411
+ if ($[37] !== t11 || $[38] !== t12) {
412
+ t13 = /* @__PURE__ */ jsxs("div", { className: "flex flex-col min-w-0", children: [
413
+ t11,
414
+ t12
415
+ ] });
416
+ $[37] = t11;
417
+ $[38] = t12;
418
+ $[39] = t13;
419
+ } else {
420
+ t13 = $[39];
421
+ }
422
+ let t14;
423
+ if ($[40] !== iconElement) {
424
+ t14 = iconElement && /* @__PURE__ */ jsx("span", { className: "ml-2 shrink-0", children: iconElement });
425
+ $[40] = iconElement;
426
+ $[41] = t14;
427
+ } else {
428
+ t14 = $[41];
429
+ }
430
+ let t15;
431
+ if ($[42] !== t13 || $[43] !== t14 || $[44] !== t9) {
432
+ t15 = /* @__PURE__ */ jsxs("div", { className: t9, children: [
433
+ t13,
434
+ t14
435
+ ] });
436
+ $[42] = t13;
437
+ $[43] = t14;
438
+ $[44] = t9;
439
+ $[45] = t15;
440
+ } else {
441
+ t15 = $[45];
442
+ }
443
+ const t16 = `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"}`;
444
+ let t17;
445
+ if ($[46] !== formattedValue || $[47] !== t16) {
446
+ t17 = /* @__PURE__ */ jsx("div", { className: t16, children: formattedValue });
447
+ $[46] = formattedValue;
448
+ $[47] = t16;
449
+ $[48] = t17;
450
+ } else {
451
+ t17 = $[48];
452
+ }
453
+ let t18;
454
+ if ($[49] !== comparisonElement || $[50] !== isSmall) {
455
+ t18 = comparisonElement && /* @__PURE__ */ jsx("div", { className: isSmall ? "mt-0.5" : "mt-1", children: comparisonElement });
456
+ $[49] = comparisonElement;
457
+ $[50] = isSmall;
458
+ $[51] = t18;
459
+ } else {
460
+ t18 = $[51];
461
+ }
462
+ let t19;
463
+ if ($[52] !== baseClass || $[53] !== t15 || $[54] !== t17 || $[55] !== t18 || $[56] !== t8) {
464
+ t19 = /* @__PURE__ */ jsxs("div", { ref: containerRef, className: baseClass, style: t8, children: [
465
+ t15,
466
+ t17,
467
+ t18
468
+ ] });
469
+ $[52] = baseClass;
470
+ $[53] = t15;
471
+ $[54] = t17;
472
+ $[55] = t18;
473
+ $[56] = t8;
474
+ $[57] = t19;
475
+ } else {
476
+ t19 = $[57];
477
+ }
478
+ return t19;
479
+ }
480
+ InsightsScorecardView.displayName = "InsightsScorecardView";
481
+ function InsightWidgetSkeleton(t0) {
482
+ const $ = c(35);
483
+ const {
484
+ config,
485
+ compact: t1,
486
+ embedded: t2
487
+ } = t0;
488
+ const compact = t1 === void 0 ? false : t1;
489
+ const embedded = t2 === void 0 ? false : t2;
490
+ const hasComparison = Boolean(config.comparison);
491
+ const hasIcon = Boolean(config.icon);
492
+ const hasDateRange = Boolean(config.dateRange);
493
+ if (compact) {
494
+ const t32 = embedded ? "h-full px-2.5 py-2" : "flex flex-col gap-0.5 rounded-md bg-transparent border min-w-0 px-2.5 py-2";
495
+ const t42 = !embedded && defaultBorderMixin;
496
+ let t52;
497
+ if ($[0] !== t32 || $[1] !== t42) {
498
+ t52 = cls("animate-pulse", t32, t42);
499
+ $[0] = t32;
500
+ $[1] = t42;
501
+ $[2] = t52;
502
+ } else {
503
+ t52 = $[2];
504
+ }
505
+ let t62;
506
+ if ($[3] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
507
+ t62 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded-sm", style: {
508
+ height: 14,
509
+ width: 48
510
+ } });
511
+ $[3] = t62;
512
+ } else {
513
+ t62 = $[3];
514
+ }
515
+ let t72;
516
+ if ($[4] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
517
+ t72 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded-sm", style: {
518
+ height: 20,
519
+ width: 40
520
+ } });
521
+ $[4] = t72;
522
+ } else {
523
+ t72 = $[4];
524
+ }
525
+ let t82;
526
+ if ($[5] !== hasComparison) {
527
+ t82 = hasComparison && /* @__PURE__ */ jsx("div", { className: "bg-surface-200/60 dark:bg-surface-700/60 rounded-sm", style: {
528
+ height: 14,
529
+ width: 28
530
+ } });
531
+ $[5] = hasComparison;
532
+ $[6] = t82;
533
+ } else {
534
+ t82 = $[6];
535
+ }
536
+ let t92;
537
+ if ($[7] !== t82) {
538
+ t92 = /* @__PURE__ */ jsxs("div", { className: "flex items-baseline gap-1.5", children: [
539
+ t72,
540
+ t82
541
+ ] });
542
+ $[7] = t82;
543
+ $[8] = t92;
544
+ } else {
545
+ t92 = $[8];
546
+ }
547
+ let t102;
548
+ if ($[9] !== t52 || $[10] !== t92) {
549
+ t102 = /* @__PURE__ */ jsxs("div", { className: t52, children: [
550
+ t62,
551
+ t92
552
+ ] });
553
+ $[9] = t52;
554
+ $[10] = t92;
555
+ $[11] = t102;
556
+ } else {
557
+ t102 = $[11];
558
+ }
559
+ return t102;
560
+ }
561
+ const t3 = embedded ? "h-full px-5 py-4" : "rounded-lg bg-transparent border px-5 py-4";
562
+ const t4 = !embedded && defaultBorderMixin;
563
+ let t5;
564
+ if ($[12] !== t3 || $[13] !== t4) {
565
+ t5 = cls("animate-pulse", t3, t4);
566
+ $[12] = t3;
567
+ $[13] = t4;
568
+ $[14] = t5;
569
+ } else {
570
+ t5 = $[14];
571
+ }
572
+ let t6;
573
+ if ($[15] !== embedded) {
574
+ t6 = embedded ? void 0 : {
575
+ minHeight: 92
576
+ };
577
+ $[15] = embedded;
578
+ $[16] = t6;
579
+ } else {
580
+ t6 = $[16];
581
+ }
582
+ let t7;
583
+ if ($[17] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
584
+ t7 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded", style: {
585
+ height: 16,
586
+ width: "60%"
587
+ } });
588
+ $[17] = t7;
589
+ } else {
590
+ t7 = $[17];
591
+ }
592
+ let t8;
593
+ if ($[18] !== hasDateRange) {
594
+ t8 = hasDateRange && /* @__PURE__ */ jsx("div", { className: "bg-surface-200/60 dark:bg-surface-700/60 rounded mt-0.5", style: {
595
+ height: 14,
596
+ width: "40%"
597
+ } });
598
+ $[18] = hasDateRange;
599
+ $[19] = t8;
600
+ } else {
601
+ t8 = $[19];
602
+ }
603
+ let t9;
604
+ if ($[20] !== t8) {
605
+ t9 = /* @__PURE__ */ jsxs("div", { className: "flex flex-col min-w-0", children: [
606
+ t7,
607
+ t8
608
+ ] });
609
+ $[20] = t8;
610
+ $[21] = t9;
611
+ } else {
612
+ t9 = $[21];
613
+ }
614
+ let t10;
615
+ if ($[22] !== hasIcon) {
616
+ t10 = hasIcon && /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded ml-2 shrink-0", style: {
617
+ height: 18,
618
+ width: 18
619
+ } });
620
+ $[22] = hasIcon;
621
+ $[23] = t10;
622
+ } else {
623
+ t10 = $[23];
624
+ }
625
+ let t11;
626
+ if ($[24] !== t10 || $[25] !== t9) {
627
+ t11 = /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between mb-2", children: [
628
+ t9,
629
+ t10
630
+ ] });
631
+ $[24] = t10;
632
+ $[25] = t9;
633
+ $[26] = t11;
634
+ } else {
635
+ t11 = $[26];
636
+ }
637
+ let t12;
638
+ if ($[27] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
639
+ t12 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded", style: {
640
+ height: 32,
641
+ width: "40%"
642
+ } });
643
+ $[27] = t12;
644
+ } else {
645
+ t12 = $[27];
646
+ }
647
+ let t13;
648
+ if ($[28] !== hasComparison) {
649
+ t13 = hasComparison && /* @__PURE__ */ jsx("div", { className: "bg-surface-200/60 dark:bg-surface-700/60 rounded mt-1", style: {
650
+ height: 16,
651
+ width: "25%"
652
+ } });
653
+ $[28] = hasComparison;
654
+ $[29] = t13;
655
+ } else {
656
+ t13 = $[29];
657
+ }
658
+ let t14;
659
+ if ($[30] !== t11 || $[31] !== t13 || $[32] !== t5 || $[33] !== t6) {
660
+ t14 = /* @__PURE__ */ jsxs("div", { className: t5, style: t6, children: [
661
+ t11,
662
+ t12,
663
+ t13
664
+ ] });
665
+ $[30] = t11;
666
+ $[31] = t13;
667
+ $[32] = t5;
668
+ $[33] = t6;
669
+ $[34] = t14;
670
+ } else {
671
+ t14 = $[34];
672
+ }
673
+ return t14;
674
+ }
675
+ InsightWidgetSkeleton.displayName = "InsightWidgetSkeleton";
676
+ function InsightWidget(t0) {
677
+ const $ = c(21);
678
+ const {
679
+ definition,
680
+ collectionSlug,
681
+ compact: t1,
682
+ embedded: t2
683
+ } = t0;
684
+ const compact = t1 === void 0 ? false : t1;
685
+ const embedded = t2 === void 0 ? false : t2;
686
+ const {
687
+ data,
688
+ loading,
689
+ error
690
+ } = useInsightsData(definition, collectionSlug);
691
+ if (loading) {
692
+ let t32;
693
+ if ($[0] !== compact || $[1] !== definition.scorecard || $[2] !== embedded) {
694
+ t32 = /* @__PURE__ */ jsx(InsightWidgetSkeleton, { config: definition.scorecard, compact, embedded });
695
+ $[0] = compact;
696
+ $[1] = definition.scorecard;
697
+ $[2] = embedded;
698
+ $[3] = t32;
699
+ } else {
700
+ t32 = $[3];
701
+ }
702
+ return t32;
703
+ }
704
+ if (error) {
705
+ const t32 = `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"}`}`;
706
+ let t42;
707
+ if ($[4] !== definition.title) {
708
+ t42 = /* @__PURE__ */ jsx("div", { className: "font-semibold mb-1", children: definition.title });
709
+ $[4] = definition.title;
710
+ $[5] = t42;
711
+ } else {
712
+ t42 = $[5];
713
+ }
714
+ let t5;
715
+ if ($[6] !== error.message) {
716
+ t5 = /* @__PURE__ */ jsx("div", { children: error.message });
717
+ $[6] = error.message;
718
+ $[7] = t5;
719
+ } else {
720
+ t5 = $[7];
721
+ }
722
+ let t6;
723
+ if ($[8] !== t32 || $[9] !== t42 || $[10] !== t5) {
724
+ t6 = /* @__PURE__ */ jsxs("div", { className: t32, children: [
725
+ t42,
726
+ t5
727
+ ] });
728
+ $[8] = t32;
729
+ $[9] = t42;
730
+ $[10] = t5;
731
+ $[11] = t6;
732
+ } else {
733
+ t6 = $[11];
734
+ }
735
+ return t6;
736
+ }
737
+ if (!data || data.rows.length === 0) {
738
+ const t32 = `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"}`}`;
739
+ let t42;
740
+ if ($[12] !== definition.title || $[13] !== t32) {
741
+ t42 = /* @__PURE__ */ jsxs("div", { className: t32, children: [
742
+ definition.title,
743
+ " — No data"
744
+ ] });
745
+ $[12] = definition.title;
746
+ $[13] = t32;
747
+ $[14] = t42;
748
+ } else {
749
+ t42 = $[14];
750
+ }
751
+ return t42;
752
+ }
753
+ const t3 = data.rows[0];
754
+ let t4;
755
+ if ($[15] !== compact || $[16] !== definition.scorecard || $[17] !== definition.title || $[18] !== embedded || $[19] !== t3) {
756
+ t4 = /* @__PURE__ */ jsx(InsightsScorecardView, { config: definition.scorecard, data: t3, title: definition.title, compact, embedded });
757
+ $[15] = compact;
758
+ $[16] = definition.scorecard;
759
+ $[17] = definition.title;
760
+ $[18] = embedded;
761
+ $[19] = t3;
762
+ $[20] = t4;
763
+ } else {
764
+ t4 = $[20];
765
+ }
766
+ return t4;
767
+ }
768
+ InsightWidget.displayName = "InsightWidget";
769
+ function HomeCardInsightSlot(t0) {
770
+ const $ = c(8);
771
+ const {
772
+ slug,
773
+ insights
774
+ } = t0;
775
+ if (!insights || insights.length === 0) {
776
+ return null;
777
+ }
778
+ let t1;
779
+ if ($[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
780
+ t1 = {
781
+ minHeight: 46
782
+ };
783
+ $[0] = t1;
784
+ } else {
785
+ t1 = $[0];
786
+ }
787
+ let t2;
788
+ if ($[1] !== insights || $[2] !== slug) {
789
+ let t32;
790
+ if ($[4] !== slug) {
791
+ t32 = (def) => /* @__PURE__ */ jsx(InsightWidget, { definition: def, collectionSlug: slug, compact: true }, def.id);
792
+ $[4] = slug;
793
+ $[5] = t32;
794
+ } else {
795
+ t32 = $[5];
796
+ }
797
+ t2 = insights.map(t32);
798
+ $[1] = insights;
799
+ $[2] = slug;
800
+ $[3] = t2;
801
+ } else {
802
+ t2 = $[3];
803
+ }
804
+ let t3;
805
+ if ($[6] !== t2) {
806
+ t3 = /* @__PURE__ */ jsx("div", { className: "flex flex-wrap items-center gap-1.5 mt-2", style: t1, children: t2 });
807
+ $[6] = t2;
808
+ $[7] = t3;
809
+ } else {
810
+ t3 = $[7];
811
+ }
812
+ return t3;
813
+ }
814
+ HomeCardInsightSlot.displayName = "HomeCardInsightSlot";
815
+ function HomeInsightsSlot(t0) {
816
+ const $ = c(5);
817
+ const {
818
+ insights
819
+ } = t0;
820
+ if (!insights || insights.length === 0) {
821
+ return null;
822
+ }
823
+ let t1;
824
+ if ($[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
825
+ t1 = {
826
+ minHeight: 92
827
+ };
828
+ $[0] = t1;
829
+ } else {
830
+ t1 = $[0];
831
+ }
832
+ let t2;
833
+ if ($[1] !== insights) {
834
+ t2 = insights.map(_temp$1);
835
+ $[1] = insights;
836
+ $[2] = t2;
837
+ } else {
838
+ t2 = $[2];
839
+ }
840
+ let t3;
841
+ if ($[3] !== t2) {
842
+ t3 = /* @__PURE__ */ jsx("div", { className: "grid grid-cols-2 sm:grid-cols-3 lg:grid-cols-4 gap-3 pb-6", style: t1, children: t2 });
843
+ $[3] = t2;
844
+ $[4] = t3;
845
+ } else {
846
+ t3 = $[4];
847
+ }
848
+ return t3;
849
+ }
850
+ function _temp$1(def) {
851
+ return /* @__PURE__ */ jsx(InsightWidget, { definition: def }, def.id);
852
+ }
853
+ HomeInsightsSlot.displayName = "HomeInsightsSlot";
854
+ function CollectionInsightsInline(t0) {
855
+ const $ = c(4);
856
+ const {
857
+ insights
858
+ } = t0;
859
+ if (!insights || insights.length === 0) {
860
+ return null;
861
+ }
862
+ let t1;
863
+ if ($[0] !== insights) {
864
+ t1 = insights.map(_temp);
865
+ $[0] = insights;
866
+ $[1] = t1;
867
+ } else {
868
+ t1 = $[1];
869
+ }
870
+ let t2;
871
+ if ($[2] !== t1) {
872
+ t2 = /* @__PURE__ */ jsx("div", { className: "grid grid-cols-2 sm:grid-cols-3 lg:grid-cols-4 gap-3 pb-4", children: t1 });
873
+ $[2] = t1;
874
+ $[3] = t2;
875
+ } else {
876
+ t2 = $[3];
877
+ }
878
+ return t2;
879
+ }
880
+ function _temp(def) {
881
+ return /* @__PURE__ */ jsx(InsightWidget, { definition: def }, def.id);
882
+ }
883
+ CollectionInsightsInline.displayName = "CollectionInsightsInline";
884
+ function useInsightsPlugin(config) {
885
+ const {
886
+ insights,
887
+ cacheTTL
888
+ } = config;
889
+ const slots = [];
890
+ if (insights.home && insights.home.length > 0) {
891
+ const homeInsights = insights.home;
892
+ slots.push({
893
+ slot: "home.children.start",
894
+ Component: (props) => /* @__PURE__ */ jsx(HomeInsightsSlot, { ...props, insights: homeInsights }),
895
+ order: 10
896
+ });
897
+ }
898
+ if (insights.collections) {
899
+ for (const [slug, defs] of Object.entries(insights.collections)) {
900
+ if (defs.length === 0) continue;
901
+ const collectionInsights = defs;
902
+ slots.push({
903
+ slot: "collection.insights",
904
+ Component: (props) => {
905
+ const path = props.path;
906
+ const collectionSlug = path?.split("/").filter(Boolean).pop() ?? "";
907
+ if (collectionSlug !== slug) return null;
908
+ return /* @__PURE__ */ jsx(CollectionInsightsInline, { ...props, insights: collectionInsights });
909
+ },
910
+ order: 10
911
+ });
912
+ slots.push({
913
+ slot: "home.card.insight",
914
+ Component: (props) => {
915
+ const cardSlug = props.slug;
916
+ if (cardSlug !== slug) return null;
917
+ return /* @__PURE__ */ jsx(HomeCardInsightSlot, { ...props, insights: collectionInsights });
918
+ },
919
+ order: 10
920
+ });
921
+ }
922
+ }
923
+ return {
924
+ key: "plugin-insights",
925
+ slots,
926
+ providers: [{
927
+ scope: "root",
928
+ Component: InsightsProvider,
929
+ props: {
930
+ cacheTTL
931
+ }
932
+ }]
933
+ };
934
+ }
935
+ export {
936
+ InsightWidget,
937
+ InsightWidgetSkeleton,
938
+ InsightsCache,
939
+ InsightsProvider,
940
+ InsightsScorecardView,
941
+ useInsightsData,
942
+ useInsightsEngine,
943
+ useInsightsPlugin
944
+ };
945
+ //# sourceMappingURL=index.es.js.map