@rebasepro/plugin-insights 0.0.1-canary.000dc36

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 (303) 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 +1045 -0
  140. package/dist/index.es.js.map +1 -0
  141. package/dist/index.umd.js +1044 -0
  142. package/dist/index.umd.js.map +1 -0
  143. package/dist/plugin-insights/src/components/CollectionInsightsInline.d.ts +17 -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 +22 -0
  147. package/dist/plugin-insights/src/components/InsightWidgetSkeleton.d.ts +26 -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 +88 -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 +46 -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 +195 -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/backend_hooks.d.ts +187 -0
  180. package/dist/types/src/types/builders.d.ts +15 -0
  181. package/dist/types/src/types/chips.d.ts +5 -0
  182. package/dist/types/src/types/collections.d.ts +857 -0
  183. package/dist/types/src/types/cron.d.ts +102 -0
  184. package/dist/types/src/types/data_source.d.ts +64 -0
  185. package/dist/types/src/types/entities.d.ts +145 -0
  186. package/dist/types/src/types/entity_actions.d.ts +98 -0
  187. package/dist/types/src/types/entity_callbacks.d.ts +173 -0
  188. package/dist/types/src/types/entity_link_builder.d.ts +7 -0
  189. package/dist/types/src/types/entity_overrides.d.ts +10 -0
  190. package/dist/types/src/types/entity_views.d.ts +59 -0
  191. package/dist/types/src/types/export_import.d.ts +21 -0
  192. package/dist/types/src/types/formex.d.ts +40 -0
  193. package/dist/types/src/types/index.d.ts +25 -0
  194. package/dist/types/src/types/locales.d.ts +4 -0
  195. package/dist/types/src/types/modify_collections.d.ts +5 -0
  196. package/dist/types/src/types/plugins.d.ts +282 -0
  197. package/dist/types/src/types/properties.d.ts +1148 -0
  198. package/dist/types/src/types/property_config.d.ts +70 -0
  199. package/dist/types/src/types/relations.d.ts +336 -0
  200. package/dist/types/src/types/slots.d.ts +262 -0
  201. package/dist/types/src/types/translations.d.ts +874 -0
  202. package/dist/types/src/types/user_management_delegate.d.ts +121 -0
  203. package/dist/types/src/types/websockets.d.ts +78 -0
  204. package/dist/types/src/users/index.d.ts +2 -0
  205. package/dist/types/src/users/roles.d.ts +22 -0
  206. package/dist/types/src/users/user.d.ts +46 -0
  207. package/dist/ui/src/components/Alert.d.ts +12 -0
  208. package/dist/ui/src/components/Autocomplete.d.ts +21 -0
  209. package/dist/ui/src/components/Avatar.d.ts +11 -0
  210. package/dist/ui/src/components/Badge.d.ts +8 -0
  211. package/dist/ui/src/components/BooleanSwitch.d.ts +14 -0
  212. package/dist/ui/src/components/BooleanSwitchWithLabel.d.ts +17 -0
  213. package/dist/ui/src/components/Button.d.ts +14 -0
  214. package/dist/ui/src/components/Card.d.ts +9 -0
  215. package/dist/ui/src/components/CenteredView.d.ts +9 -0
  216. package/dist/ui/src/components/Checkbox.d.ts +13 -0
  217. package/dist/ui/src/components/Chip.d.ts +26 -0
  218. package/dist/ui/src/components/CircularProgress.d.ts +5 -0
  219. package/dist/ui/src/components/CircularProgressCenter.d.ts +11 -0
  220. package/dist/ui/src/components/Collapse.d.ts +9 -0
  221. package/dist/ui/src/components/ColorPicker.d.ts +30 -0
  222. package/dist/ui/src/components/Container.d.ts +8 -0
  223. package/dist/ui/src/components/DateTimeField.d.ts +24 -0
  224. package/dist/ui/src/components/DebouncedTextField.d.ts +2 -0
  225. package/dist/ui/src/components/Dialog.d.ts +39 -0
  226. package/dist/ui/src/components/DialogActions.d.ts +7 -0
  227. package/dist/ui/src/components/DialogContent.d.ts +7 -0
  228. package/dist/ui/src/components/DialogTitle.d.ts +10 -0
  229. package/dist/ui/src/components/ErrorBoundary.d.ts +11 -0
  230. package/dist/ui/src/components/ExpandablePanel.d.ts +12 -0
  231. package/dist/ui/src/components/FileUpload.d.ts +23 -0
  232. package/dist/ui/src/components/IconButton.d.ts +12 -0
  233. package/dist/ui/src/components/InfoLabel.d.ts +5 -0
  234. package/dist/ui/src/components/InputLabel.d.ts +11 -0
  235. package/dist/ui/src/components/Label.d.ts +7 -0
  236. package/dist/ui/src/components/LoadingButton.d.ts +7 -0
  237. package/dist/ui/src/components/Markdown.d.ts +10 -0
  238. package/dist/ui/src/components/Menu.d.ts +23 -0
  239. package/dist/ui/src/components/Menubar.d.ts +80 -0
  240. package/dist/ui/src/components/MultiSelect.d.ts +48 -0
  241. package/dist/ui/src/components/Paper.d.ts +6 -0
  242. package/dist/ui/src/components/Popover.d.ts +24 -0
  243. package/dist/ui/src/components/RadioGroup.d.ts +28 -0
  244. package/dist/ui/src/components/ResizablePanels.d.ts +18 -0
  245. package/dist/ui/src/components/SearchBar.d.ts +22 -0
  246. package/dist/ui/src/components/Select.d.ts +43 -0
  247. package/dist/ui/src/components/Separator.d.ts +5 -0
  248. package/dist/ui/src/components/Sheet.d.ts +22 -0
  249. package/dist/ui/src/components/Skeleton.d.ts +6 -0
  250. package/dist/ui/src/components/Slider.d.ts +21 -0
  251. package/dist/ui/src/components/Table.d.ts +34 -0
  252. package/dist/ui/src/components/Tabs.d.ts +19 -0
  253. package/dist/ui/src/components/TextField.d.ts +58 -0
  254. package/dist/ui/src/components/TextareaAutosize.d.ts +43 -0
  255. package/dist/ui/src/components/ToggleButtonGroup.d.ts +30 -0
  256. package/dist/ui/src/components/Tooltip.d.ts +19 -0
  257. package/dist/ui/src/components/Typography.d.ts +36 -0
  258. package/dist/ui/src/components/VirtualTable/VirtualTable.d.ts +11 -0
  259. package/dist/ui/src/components/VirtualTable/VirtualTableCell.d.ts +21 -0
  260. package/dist/ui/src/components/VirtualTable/VirtualTableHeader.d.ts +29 -0
  261. package/dist/ui/src/components/VirtualTable/VirtualTableHeaderRow.d.ts +2 -0
  262. package/dist/ui/src/components/VirtualTable/VirtualTableProps.d.ts +243 -0
  263. package/dist/ui/src/components/VirtualTable/VirtualTableRow.d.ts +3 -0
  264. package/dist/ui/src/components/VirtualTable/index.d.ts +3 -0
  265. package/dist/ui/src/components/VirtualTable/types.d.ts +38 -0
  266. package/dist/ui/src/components/common/SelectInputLabel.d.ts +5 -0
  267. package/dist/ui/src/components/index.d.ts +53 -0
  268. package/dist/ui/src/hooks/PortalContainerContext.d.ts +31 -0
  269. package/dist/ui/src/hooks/index.d.ts +6 -0
  270. package/dist/ui/src/hooks/useDebounceCallback.d.ts +1 -0
  271. package/dist/ui/src/hooks/useDebounceValue.d.ts +1 -0
  272. package/dist/ui/src/hooks/useDebouncedCallback.d.ts +1 -0
  273. package/dist/ui/src/hooks/useInjectStyles.d.ts +7 -0
  274. package/dist/ui/src/hooks/useOutsideAlerter.d.ts +5 -0
  275. package/dist/ui/src/icons/GitHubIcon.d.ts +2 -0
  276. package/dist/ui/src/icons/HandleIcon.d.ts +1 -0
  277. package/dist/ui/src/icons/Icon.d.ts +20 -0
  278. package/dist/ui/src/icons/cool_icon_keys.d.ts +1 -0
  279. package/dist/ui/src/icons/icon_keys.d.ts +1 -0
  280. package/dist/ui/src/icons/index.d.ts +6 -0
  281. package/dist/ui/src/index.d.ts +5 -0
  282. package/dist/ui/src/styles.d.ts +12 -0
  283. package/dist/ui/src/util/chip_colors.d.ts +4 -0
  284. package/dist/ui/src/util/cls.d.ts +2 -0
  285. package/dist/ui/src/util/debounce.d.ts +10 -0
  286. package/dist/ui/src/util/hash.d.ts +1 -0
  287. package/dist/ui/src/util/index.d.ts +4 -0
  288. package/dist/ui/src/util/key_to_icon_component.d.ts +1 -0
  289. package/package.json +80 -0
  290. package/src/components/CollectionInsightsInline.tsx +38 -0
  291. package/src/components/HomeCardInsightSlot.tsx +40 -0
  292. package/src/components/HomeInsightsSlot.tsx +30 -0
  293. package/src/components/InsightWidget.tsx +69 -0
  294. package/src/components/InsightWidgetSkeleton.tsx +204 -0
  295. package/src/components/InsightsScorecardView.tsx +160 -0
  296. package/src/engine/InsightsCache.ts +52 -0
  297. package/src/engine/InsightsProvider.tsx +38 -0
  298. package/src/engine/useInsightsData.ts +100 -0
  299. package/src/index.ts +22 -0
  300. package/src/types/engine.ts +95 -0
  301. package/src/types/index.ts +5 -0
  302. package/src/types/widgets.ts +66 -0
  303. package/src/useInsightsPlugin.tsx +117 -0
@@ -0,0 +1,1045 @@
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, context) {
90
+ const $ = c(18);
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}:${context.path ?? context.collectionSlug ?? "global"}`;
104
+ let t0;
105
+ if ($[0] !== authReady || $[1] !== cache || $[2] !== cacheKey || $[3] !== context || $[4] !== 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(context);
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] = context;
162
+ $[4] = definition;
163
+ $[5] = t0;
164
+ } else {
165
+ t0 = $[5];
166
+ }
167
+ let t1;
168
+ if ($[6] !== authReady || $[7] !== cache || $[8] !== cacheKey || $[9] !== context.collectionSlug || $[10] !== context.path || $[11] !== definition.data || $[12] !== definition.id) {
169
+ t1 = [definition.id, definition.data, context.path, context.collectionSlug, cacheKey, cache, authReady];
170
+ $[6] = authReady;
171
+ $[7] = cache;
172
+ $[8] = cacheKey;
173
+ $[9] = context.collectionSlug;
174
+ $[10] = context.path;
175
+ $[11] = definition.data;
176
+ $[12] = definition.id;
177
+ $[13] = t1;
178
+ } else {
179
+ t1 = $[13];
180
+ }
181
+ useEffect(t0, t1);
182
+ let t2;
183
+ if ($[14] !== data || $[15] !== error || $[16] !== loading) {
184
+ t2 = {
185
+ data,
186
+ loading,
187
+ error
188
+ };
189
+ $[14] = data;
190
+ $[15] = error;
191
+ $[16] = loading;
192
+ $[17] = t2;
193
+ } else {
194
+ t2 = $[17];
195
+ }
196
+ return t2;
197
+ }
198
+ function formatNumber(value, format) {
199
+ if (value === null || value === void 0) return "N/A";
200
+ const options = {
201
+ style: format?.style ?? "decimal",
202
+ notation: format?.notation ?? "standard",
203
+ maximumFractionDigits: format?.decimals ?? 1,
204
+ minimumFractionDigits: format?.decimals ?? 1
205
+ };
206
+ if (format?.style === "currency") {
207
+ options.currency = format.currency ?? "USD";
208
+ }
209
+ let formatted = new Intl.NumberFormat("en-US", options).format(value);
210
+ if (format?.showSign && value > 0) {
211
+ formatted = "+" + formatted;
212
+ }
213
+ return formatted;
214
+ }
215
+ function InsightsScorecardView(t0) {
216
+ const $ = c(58);
217
+ const {
218
+ config,
219
+ data,
220
+ title,
221
+ compact: t1,
222
+ embedded: t2
223
+ } = t0;
224
+ const compact = t1 === void 0 ? false : t1;
225
+ const embedded = t2 === void 0 ? false : t2;
226
+ const containerRef = useRef(null);
227
+ const [containerWidth, setContainerWidth] = useState(null);
228
+ let t3;
229
+ let t4;
230
+ if ($[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
231
+ t3 = () => {
232
+ if (!containerRef.current) {
233
+ return;
234
+ }
235
+ setContainerWidth(containerRef.current.offsetWidth);
236
+ const observer = new ResizeObserver((entries) => {
237
+ for (const entry of entries) {
238
+ setContainerWidth(entry.contentRect.width);
239
+ }
240
+ });
241
+ observer.observe(containerRef.current);
242
+ return () => observer.disconnect();
243
+ };
244
+ t4 = [];
245
+ $[0] = t3;
246
+ $[1] = t4;
247
+ } else {
248
+ t3 = $[0];
249
+ t4 = $[1];
250
+ }
251
+ React.useLayoutEffect(t3, t4);
252
+ const mainValue = data[config.value.field];
253
+ let t5;
254
+ if ($[2] !== config.value.format || $[3] !== mainValue) {
255
+ t5 = typeof mainValue === "number" ? formatNumber(mainValue, config.value.format) : String(mainValue ?? "N/A");
256
+ $[2] = config.value.format;
257
+ $[3] = mainValue;
258
+ $[4] = t5;
259
+ } else {
260
+ t5 = $[4];
261
+ }
262
+ const formattedValue = t5;
263
+ let comparisonElement = null;
264
+ if (config.comparison) {
265
+ const comparisonValue = data[config.comparison.field];
266
+ if (typeof comparisonValue === "number") {
267
+ let t62;
268
+ if ($[5] !== comparisonValue || $[6] !== config.comparison.format) {
269
+ t62 = formatNumber(comparisonValue, config.comparison.format);
270
+ $[5] = comparisonValue;
271
+ $[6] = config.comparison.format;
272
+ $[7] = t62;
273
+ } else {
274
+ t62 = $[7];
275
+ }
276
+ const formattedComparison = t62;
277
+ const isPositive = comparisonValue > 0;
278
+ const isNegative = comparisonValue < 0;
279
+ let colorClass = "text-surface-500 dark:text-surface-400";
280
+ if (config.comparison.intent === "increase_is_good") {
281
+ if (isPositive) {
282
+ colorClass = "text-emerald-500";
283
+ }
284
+ if (isNegative) {
285
+ colorClass = "text-red-500";
286
+ }
287
+ } else {
288
+ if (config.comparison.intent === "decrease_is_good") {
289
+ if (isPositive) {
290
+ colorClass = "text-red-500";
291
+ }
292
+ if (isNegative) {
293
+ colorClass = "text-emerald-500";
294
+ }
295
+ }
296
+ }
297
+ const t72 = `font-medium ${compact ? "text-[10px]" : "text-xs"} ${colorClass}`;
298
+ let t82;
299
+ if ($[8] !== formattedComparison || $[9] !== t72) {
300
+ t82 = /* @__PURE__ */ jsx("span", { className: t72, children: formattedComparison });
301
+ $[8] = formattedComparison;
302
+ $[9] = t72;
303
+ $[10] = t82;
304
+ } else {
305
+ t82 = $[10];
306
+ }
307
+ comparisonElement = t82;
308
+ }
309
+ }
310
+ const isSmall = compact || containerWidth !== null && containerWidth < 200;
311
+ let t6;
312
+ if ($[11] !== config.icon || $[12] !== isSmall) {
313
+ t6 = config.icon ? getIcon(config.icon, "text-surface-400 dark:text-surface-500", void 0, isSmall ? 14 : 18) : null;
314
+ $[11] = config.icon;
315
+ $[12] = isSmall;
316
+ $[13] = t6;
317
+ } else {
318
+ t6 = $[13];
319
+ }
320
+ const iconElement = t6;
321
+ if (compact) {
322
+ let t72;
323
+ if ($[14] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
324
+ t72 = cls("flex flex-col gap-0.5 px-2.5 py-2 rounded-md bg-transparent border min-w-0", defaultBorderMixin);
325
+ $[14] = t72;
326
+ } else {
327
+ t72 = $[14];
328
+ }
329
+ let t82;
330
+ if ($[15] !== title) {
331
+ t82 = /* @__PURE__ */ jsx("span", { className: "text-[10px] uppercase tracking-wider text-surface-400 dark:text-surface-500 truncate", children: title });
332
+ $[15] = title;
333
+ $[16] = t82;
334
+ } else {
335
+ t82 = $[16];
336
+ }
337
+ let t92;
338
+ if ($[17] !== formattedValue) {
339
+ t92 = /* @__PURE__ */ jsx("span", { className: "text-sm font-semibold tabular-nums text-surface-800 dark:text-surface-100", children: formattedValue });
340
+ $[17] = formattedValue;
341
+ $[18] = t92;
342
+ } else {
343
+ t92 = $[18];
344
+ }
345
+ let t102;
346
+ if ($[19] !== comparisonElement || $[20] !== t92) {
347
+ t102 = /* @__PURE__ */ jsxs("div", { className: "flex items-baseline gap-1.5", children: [
348
+ t92,
349
+ comparisonElement
350
+ ] });
351
+ $[19] = comparisonElement;
352
+ $[20] = t92;
353
+ $[21] = t102;
354
+ } else {
355
+ t102 = $[21];
356
+ }
357
+ let t112;
358
+ if ($[22] !== t102 || $[23] !== t82) {
359
+ t112 = /* @__PURE__ */ jsxs("div", { className: t72, children: [
360
+ t82,
361
+ t102
362
+ ] });
363
+ $[22] = t102;
364
+ $[23] = t82;
365
+ $[24] = t112;
366
+ } else {
367
+ t112 = $[24];
368
+ }
369
+ return t112;
370
+ }
371
+ let t7;
372
+ if ($[25] !== embedded || $[26] !== isSmall) {
373
+ 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");
374
+ $[25] = embedded;
375
+ $[26] = isSmall;
376
+ $[27] = t7;
377
+ } else {
378
+ t7 = $[27];
379
+ }
380
+ const baseClass = t7;
381
+ let t8;
382
+ if ($[28] !== embedded || $[29] !== isSmall) {
383
+ t8 = embedded ? void 0 : {
384
+ minHeight: isSmall ? 68 : 92
385
+ };
386
+ $[28] = embedded;
387
+ $[29] = isSmall;
388
+ $[30] = t8;
389
+ } else {
390
+ t8 = $[30];
391
+ }
392
+ const t9 = `flex items-center justify-between ${isSmall ? "mb-1" : "mb-2"}`;
393
+ const t10 = `font-medium leading-snug truncate text-surface-500 dark:text-surface-400 ${isSmall ? "text-[11px]" : "text-xs"}`;
394
+ let t11;
395
+ if ($[31] !== t10 || $[32] !== title) {
396
+ t11 = /* @__PURE__ */ jsx("span", { className: t10, children: title });
397
+ $[31] = t10;
398
+ $[32] = title;
399
+ $[33] = t11;
400
+ } else {
401
+ t11 = $[33];
402
+ }
403
+ let t12;
404
+ if ($[34] !== config.dateRange || $[35] !== isSmall) {
405
+ t12 = config.dateRange && !isSmall && /* @__PURE__ */ jsx("span", { className: "text-[10px] text-surface-400 dark:text-surface-500 truncate mt-0.5", children: config.dateRange });
406
+ $[34] = config.dateRange;
407
+ $[35] = isSmall;
408
+ $[36] = t12;
409
+ } else {
410
+ t12 = $[36];
411
+ }
412
+ let t13;
413
+ if ($[37] !== t11 || $[38] !== t12) {
414
+ t13 = /* @__PURE__ */ jsxs("div", { className: "flex flex-col min-w-0", children: [
415
+ t11,
416
+ t12
417
+ ] });
418
+ $[37] = t11;
419
+ $[38] = t12;
420
+ $[39] = t13;
421
+ } else {
422
+ t13 = $[39];
423
+ }
424
+ let t14;
425
+ if ($[40] !== iconElement) {
426
+ t14 = iconElement && /* @__PURE__ */ jsx("span", { className: "ml-2 shrink-0", children: iconElement });
427
+ $[40] = iconElement;
428
+ $[41] = t14;
429
+ } else {
430
+ t14 = $[41];
431
+ }
432
+ let t15;
433
+ if ($[42] !== t13 || $[43] !== t14 || $[44] !== t9) {
434
+ t15 = /* @__PURE__ */ jsxs("div", { className: t9, children: [
435
+ t13,
436
+ t14
437
+ ] });
438
+ $[42] = t13;
439
+ $[43] = t14;
440
+ $[44] = t9;
441
+ $[45] = t15;
442
+ } else {
443
+ t15 = $[45];
444
+ }
445
+ 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"}`;
446
+ let t17;
447
+ if ($[46] !== formattedValue || $[47] !== t16) {
448
+ t17 = /* @__PURE__ */ jsx("div", { className: t16, children: formattedValue });
449
+ $[46] = formattedValue;
450
+ $[47] = t16;
451
+ $[48] = t17;
452
+ } else {
453
+ t17 = $[48];
454
+ }
455
+ let t18;
456
+ if ($[49] !== comparisonElement || $[50] !== isSmall) {
457
+ t18 = comparisonElement && /* @__PURE__ */ jsx("div", { className: isSmall ? "mt-0.5" : "mt-1", children: comparisonElement });
458
+ $[49] = comparisonElement;
459
+ $[50] = isSmall;
460
+ $[51] = t18;
461
+ } else {
462
+ t18 = $[51];
463
+ }
464
+ let t19;
465
+ if ($[52] !== baseClass || $[53] !== t15 || $[54] !== t17 || $[55] !== t18 || $[56] !== t8) {
466
+ t19 = /* @__PURE__ */ jsxs("div", { ref: containerRef, className: baseClass, style: t8, children: [
467
+ t15,
468
+ t17,
469
+ t18
470
+ ] });
471
+ $[52] = baseClass;
472
+ $[53] = t15;
473
+ $[54] = t17;
474
+ $[55] = t18;
475
+ $[56] = t8;
476
+ $[57] = t19;
477
+ } else {
478
+ t19 = $[57];
479
+ }
480
+ return t19;
481
+ }
482
+ InsightsScorecardView.displayName = "InsightsScorecardView";
483
+ function InsightWidgetSkeleton(t0) {
484
+ const $ = c(17);
485
+ const {
486
+ config,
487
+ compact: t1,
488
+ embedded: t2
489
+ } = t0;
490
+ const compact = t1 === void 0 ? false : t1;
491
+ const embedded = t2 === void 0 ? false : t2;
492
+ const hasComparison = Boolean(config.comparison);
493
+ const hasIcon = Boolean(config.icon);
494
+ const hasDateRange = Boolean(config.dateRange);
495
+ if (compact) {
496
+ 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";
497
+ const t4 = !embedded && defaultBorderMixin;
498
+ let t5;
499
+ if ($[0] !== t32 || $[1] !== t4) {
500
+ t5 = cls("animate-pulse", t32, t4);
501
+ $[0] = t32;
502
+ $[1] = t4;
503
+ $[2] = t5;
504
+ } else {
505
+ t5 = $[2];
506
+ }
507
+ let t6;
508
+ if ($[3] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
509
+ t6 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded-sm", style: {
510
+ height: 14,
511
+ width: 48
512
+ } });
513
+ $[3] = t6;
514
+ } else {
515
+ t6 = $[3];
516
+ }
517
+ let t7;
518
+ if ($[4] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
519
+ t7 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded-sm", style: {
520
+ height: 20,
521
+ width: 40
522
+ } });
523
+ $[4] = t7;
524
+ } else {
525
+ t7 = $[4];
526
+ }
527
+ let t8;
528
+ if ($[5] !== hasComparison) {
529
+ t8 = hasComparison && /* @__PURE__ */ jsx("div", { className: "bg-surface-200/60 dark:bg-surface-700/60 rounded-sm", style: {
530
+ height: 14,
531
+ width: 28
532
+ } });
533
+ $[5] = hasComparison;
534
+ $[6] = t8;
535
+ } else {
536
+ t8 = $[6];
537
+ }
538
+ let t9;
539
+ if ($[7] !== t8) {
540
+ t9 = /* @__PURE__ */ jsxs("div", { className: "flex items-baseline gap-1.5", children: [
541
+ t7,
542
+ t8
543
+ ] });
544
+ $[7] = t8;
545
+ $[8] = t9;
546
+ } else {
547
+ t9 = $[8];
548
+ }
549
+ let t10;
550
+ if ($[9] !== t5 || $[10] !== t9) {
551
+ t10 = /* @__PURE__ */ jsxs("div", { className: t5, children: [
552
+ t6,
553
+ t9
554
+ ] });
555
+ $[9] = t5;
556
+ $[10] = t9;
557
+ $[11] = t10;
558
+ } else {
559
+ t10 = $[11];
560
+ }
561
+ return t10;
562
+ }
563
+ let t3;
564
+ if ($[12] !== embedded || $[13] !== hasComparison || $[14] !== hasDateRange || $[15] !== hasIcon) {
565
+ t3 = /* @__PURE__ */ jsx(StandardSkeleton, { hasComparison, hasIcon, hasDateRange, embedded });
566
+ $[12] = embedded;
567
+ $[13] = hasComparison;
568
+ $[14] = hasDateRange;
569
+ $[15] = hasIcon;
570
+ $[16] = t3;
571
+ } else {
572
+ t3 = $[16];
573
+ }
574
+ return t3;
575
+ }
576
+ function StandardSkeleton(t0) {
577
+ const $ = c(36);
578
+ const {
579
+ hasComparison,
580
+ hasIcon,
581
+ hasDateRange,
582
+ embedded
583
+ } = t0;
584
+ const containerRef = useRef(null);
585
+ const [containerWidth, setContainerWidth] = useState(null);
586
+ let t1;
587
+ let t2;
588
+ if ($[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
589
+ t1 = () => {
590
+ if (!containerRef.current) {
591
+ return;
592
+ }
593
+ setContainerWidth(containerRef.current.offsetWidth);
594
+ const observer = new ResizeObserver((entries) => {
595
+ for (const entry of entries) {
596
+ setContainerWidth(entry.contentRect.width);
597
+ }
598
+ });
599
+ observer.observe(containerRef.current);
600
+ return () => observer.disconnect();
601
+ };
602
+ t2 = [];
603
+ $[0] = t1;
604
+ $[1] = t2;
605
+ } else {
606
+ t1 = $[0];
607
+ t2 = $[1];
608
+ }
609
+ React.useLayoutEffect(t1, t2);
610
+ const isSmall = containerWidth !== null && containerWidth < 200;
611
+ const titleHeight = isSmall ? 15 : 16.5;
612
+ const valueHeight = isSmall ? 22.5 : containerWidth !== null && containerWidth < 300 ? 25 : 30;
613
+ const iconSize = isSmall ? 14 : 18;
614
+ let t3;
615
+ let t4;
616
+ if ($[2] !== embedded || $[3] !== isSmall) {
617
+ const baseClass = 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");
618
+ t3 = containerRef;
619
+ t4 = cls("animate-pulse", baseClass);
620
+ $[2] = embedded;
621
+ $[3] = isSmall;
622
+ $[4] = t3;
623
+ $[5] = t4;
624
+ } else {
625
+ t3 = $[4];
626
+ t4 = $[5];
627
+ }
628
+ let t5;
629
+ if ($[6] !== embedded || $[7] !== isSmall) {
630
+ t5 = embedded ? void 0 : {
631
+ minHeight: isSmall ? 68 : 92
632
+ };
633
+ $[6] = embedded;
634
+ $[7] = isSmall;
635
+ $[8] = t5;
636
+ } else {
637
+ t5 = $[8];
638
+ }
639
+ const t6 = `flex items-center justify-between ${isSmall ? "mb-1" : "mb-2"}`;
640
+ let t7;
641
+ if ($[9] !== titleHeight) {
642
+ t7 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded", style: {
643
+ height: titleHeight,
644
+ width: "60%"
645
+ } });
646
+ $[9] = titleHeight;
647
+ $[10] = t7;
648
+ } else {
649
+ t7 = $[10];
650
+ }
651
+ let t8;
652
+ if ($[11] !== hasDateRange || $[12] !== isSmall) {
653
+ t8 = hasDateRange && !isSmall && /* @__PURE__ */ jsx("div", { className: "bg-surface-200/60 dark:bg-surface-700/60 rounded mt-0.5", style: {
654
+ height: 14,
655
+ width: "40%"
656
+ } });
657
+ $[11] = hasDateRange;
658
+ $[12] = isSmall;
659
+ $[13] = t8;
660
+ } else {
661
+ t8 = $[13];
662
+ }
663
+ let t9;
664
+ if ($[14] !== t7 || $[15] !== t8) {
665
+ t9 = /* @__PURE__ */ jsxs("div", { className: "flex flex-col min-w-0", children: [
666
+ t7,
667
+ t8
668
+ ] });
669
+ $[14] = t7;
670
+ $[15] = t8;
671
+ $[16] = t9;
672
+ } else {
673
+ t9 = $[16];
674
+ }
675
+ let t10;
676
+ if ($[17] !== hasIcon || $[18] !== iconSize) {
677
+ t10 = hasIcon && /* @__PURE__ */ jsx("span", { className: "ml-2 shrink-0", children: /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded", style: {
678
+ height: iconSize,
679
+ width: iconSize
680
+ } }) });
681
+ $[17] = hasIcon;
682
+ $[18] = iconSize;
683
+ $[19] = t10;
684
+ } else {
685
+ t10 = $[19];
686
+ }
687
+ let t11;
688
+ if ($[20] !== t10 || $[21] !== t6 || $[22] !== t9) {
689
+ t11 = /* @__PURE__ */ jsxs("div", { className: t6, children: [
690
+ t9,
691
+ t10
692
+ ] });
693
+ $[20] = t10;
694
+ $[21] = t6;
695
+ $[22] = t9;
696
+ $[23] = t11;
697
+ } else {
698
+ t11 = $[23];
699
+ }
700
+ let t12;
701
+ if ($[24] !== valueHeight) {
702
+ t12 = /* @__PURE__ */ jsx("div", { className: "bg-surface-200 dark:bg-surface-700 rounded", style: {
703
+ height: valueHeight,
704
+ width: "40%"
705
+ } });
706
+ $[24] = valueHeight;
707
+ $[25] = t12;
708
+ } else {
709
+ t12 = $[25];
710
+ }
711
+ let t13;
712
+ if ($[26] !== hasComparison || $[27] !== isSmall) {
713
+ t13 = hasComparison && /* @__PURE__ */ jsx("div", { className: isSmall ? "mt-0.5" : "mt-1", children: /* @__PURE__ */ jsx("div", { className: "bg-surface-200/60 dark:bg-surface-700/60 rounded", style: {
714
+ height: 16,
715
+ width: "25%"
716
+ } }) });
717
+ $[26] = hasComparison;
718
+ $[27] = isSmall;
719
+ $[28] = t13;
720
+ } else {
721
+ t13 = $[28];
722
+ }
723
+ let t14;
724
+ if ($[29] !== t11 || $[30] !== t12 || $[31] !== t13 || $[32] !== t3 || $[33] !== t4 || $[34] !== t5) {
725
+ t14 = /* @__PURE__ */ jsxs("div", { ref: t3, className: t4, style: t5, children: [
726
+ t11,
727
+ t12,
728
+ t13
729
+ ] });
730
+ $[29] = t11;
731
+ $[30] = t12;
732
+ $[31] = t13;
733
+ $[32] = t3;
734
+ $[33] = t4;
735
+ $[34] = t5;
736
+ $[35] = t14;
737
+ } else {
738
+ t14 = $[35];
739
+ }
740
+ return t14;
741
+ }
742
+ InsightWidgetSkeleton.displayName = "InsightWidgetSkeleton";
743
+ function InsightWidget(t0) {
744
+ const $ = c(25);
745
+ const {
746
+ definition,
747
+ collectionSlug,
748
+ path,
749
+ parentCollectionSlugs,
750
+ compact: t1,
751
+ embedded: t2
752
+ } = t0;
753
+ const compact = t1 === void 0 ? false : t1;
754
+ const embedded = t2 === void 0 ? false : t2;
755
+ let t3;
756
+ if ($[0] !== collectionSlug || $[1] !== parentCollectionSlugs || $[2] !== path) {
757
+ t3 = {
758
+ path,
759
+ collectionSlug,
760
+ parentCollectionSlugs
761
+ };
762
+ $[0] = collectionSlug;
763
+ $[1] = parentCollectionSlugs;
764
+ $[2] = path;
765
+ $[3] = t3;
766
+ } else {
767
+ t3 = $[3];
768
+ }
769
+ const {
770
+ data,
771
+ loading,
772
+ error
773
+ } = useInsightsData(definition, t3);
774
+ if (loading) {
775
+ let t42;
776
+ if ($[4] !== compact || $[5] !== definition.scorecard || $[6] !== embedded) {
777
+ t42 = /* @__PURE__ */ jsx(InsightWidgetSkeleton, { config: definition.scorecard, compact, embedded });
778
+ $[4] = compact;
779
+ $[5] = definition.scorecard;
780
+ $[6] = embedded;
781
+ $[7] = t42;
782
+ } else {
783
+ t42 = $[7];
784
+ }
785
+ return t42;
786
+ }
787
+ if (error) {
788
+ const t42 = `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"}`}`;
789
+ let t52;
790
+ if ($[8] !== definition.title) {
791
+ t52 = /* @__PURE__ */ jsx("div", { className: "font-semibold mb-1", children: definition.title });
792
+ $[8] = definition.title;
793
+ $[9] = t52;
794
+ } else {
795
+ t52 = $[9];
796
+ }
797
+ let t6;
798
+ if ($[10] !== error.message) {
799
+ t6 = /* @__PURE__ */ jsx("div", { children: error.message });
800
+ $[10] = error.message;
801
+ $[11] = t6;
802
+ } else {
803
+ t6 = $[11];
804
+ }
805
+ let t7;
806
+ if ($[12] !== t42 || $[13] !== t52 || $[14] !== t6) {
807
+ t7 = /* @__PURE__ */ jsxs("div", { className: t42, children: [
808
+ t52,
809
+ t6
810
+ ] });
811
+ $[12] = t42;
812
+ $[13] = t52;
813
+ $[14] = t6;
814
+ $[15] = t7;
815
+ } else {
816
+ t7 = $[15];
817
+ }
818
+ return t7;
819
+ }
820
+ if (!data || data.rows.length === 0) {
821
+ const t42 = `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"}`}`;
822
+ let t52;
823
+ if ($[16] !== definition.title || $[17] !== t42) {
824
+ t52 = /* @__PURE__ */ jsxs("div", { className: t42, children: [
825
+ definition.title,
826
+ " — No data"
827
+ ] });
828
+ $[16] = definition.title;
829
+ $[17] = t42;
830
+ $[18] = t52;
831
+ } else {
832
+ t52 = $[18];
833
+ }
834
+ return t52;
835
+ }
836
+ const t4 = data.rows[0];
837
+ let t5;
838
+ if ($[19] !== compact || $[20] !== definition.scorecard || $[21] !== definition.title || $[22] !== embedded || $[23] !== t4) {
839
+ t5 = /* @__PURE__ */ jsx(InsightsScorecardView, { config: definition.scorecard, data: t4, title: definition.title, compact, embedded });
840
+ $[19] = compact;
841
+ $[20] = definition.scorecard;
842
+ $[21] = definition.title;
843
+ $[22] = embedded;
844
+ $[23] = t4;
845
+ $[24] = t5;
846
+ } else {
847
+ t5 = $[24];
848
+ }
849
+ return t5;
850
+ }
851
+ InsightWidget.displayName = "InsightWidget";
852
+ function HomeCardInsightSlot(t0) {
853
+ const $ = c(10);
854
+ const {
855
+ slug,
856
+ insights
857
+ } = t0;
858
+ if (!insights || insights.length === 0) {
859
+ return null;
860
+ }
861
+ const estimatedRows = Math.ceil(insights.length / 2);
862
+ const minHeight = estimatedRows * 42 + (estimatedRows - 1) * 6;
863
+ let t1;
864
+ if ($[0] !== minHeight) {
865
+ t1 = {
866
+ minHeight
867
+ };
868
+ $[0] = minHeight;
869
+ $[1] = t1;
870
+ } else {
871
+ t1 = $[1];
872
+ }
873
+ let t2;
874
+ if ($[2] !== insights || $[3] !== slug) {
875
+ let t32;
876
+ if ($[5] !== slug) {
877
+ t32 = (def) => /* @__PURE__ */ jsx(InsightWidget, { definition: def, collectionSlug: slug, compact: true }, def.id);
878
+ $[5] = slug;
879
+ $[6] = t32;
880
+ } else {
881
+ t32 = $[6];
882
+ }
883
+ t2 = insights.map(t32);
884
+ $[2] = insights;
885
+ $[3] = slug;
886
+ $[4] = t2;
887
+ } else {
888
+ t2 = $[4];
889
+ }
890
+ let t3;
891
+ if ($[7] !== t1 || $[8] !== t2) {
892
+ t3 = /* @__PURE__ */ jsx("div", { className: "flex flex-wrap items-center gap-1.5 mt-2", style: t1, children: t2 });
893
+ $[7] = t1;
894
+ $[8] = t2;
895
+ $[9] = t3;
896
+ } else {
897
+ t3 = $[9];
898
+ }
899
+ return t3;
900
+ }
901
+ HomeCardInsightSlot.displayName = "HomeCardInsightSlot";
902
+ function HomeInsightsSlot(t0) {
903
+ const $ = c(5);
904
+ const {
905
+ insights
906
+ } = t0;
907
+ if (!insights || insights.length === 0) {
908
+ return null;
909
+ }
910
+ let t1;
911
+ if ($[0] === /* @__PURE__ */ Symbol.for("react.memo_cache_sentinel")) {
912
+ t1 = {
913
+ minHeight: 92
914
+ };
915
+ $[0] = t1;
916
+ } else {
917
+ t1 = $[0];
918
+ }
919
+ let t2;
920
+ if ($[1] !== insights) {
921
+ t2 = insights.map(_temp);
922
+ $[1] = insights;
923
+ $[2] = t2;
924
+ } else {
925
+ t2 = $[2];
926
+ }
927
+ let t3;
928
+ if ($[3] !== t2) {
929
+ 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 });
930
+ $[3] = t2;
931
+ $[4] = t3;
932
+ } else {
933
+ t3 = $[4];
934
+ }
935
+ return t3;
936
+ }
937
+ function _temp(def) {
938
+ return /* @__PURE__ */ jsx(InsightWidget, { definition: def }, def.id);
939
+ }
940
+ HomeInsightsSlot.displayName = "HomeInsightsSlot";
941
+ function CollectionInsightsInline(t0) {
942
+ const $ = c(11);
943
+ const {
944
+ insights,
945
+ path,
946
+ parentCollectionSlugs,
947
+ parentEntityIds
948
+ } = t0;
949
+ if (!insights || insights.length === 0) {
950
+ return null;
951
+ }
952
+ let t1;
953
+ if ($[0] !== insights || $[1] !== parentCollectionSlugs || $[2] !== parentEntityIds || $[3] !== path) {
954
+ let t22;
955
+ if ($[5] !== parentCollectionSlugs || $[6] !== parentEntityIds || $[7] !== path) {
956
+ t22 = (def) => /* @__PURE__ */ jsx(InsightWidget, { definition: def, path, parentCollectionSlugs, parentEntityIds }, def.id);
957
+ $[5] = parentCollectionSlugs;
958
+ $[6] = parentEntityIds;
959
+ $[7] = path;
960
+ $[8] = t22;
961
+ } else {
962
+ t22 = $[8];
963
+ }
964
+ t1 = insights.map(t22);
965
+ $[0] = insights;
966
+ $[1] = parentCollectionSlugs;
967
+ $[2] = parentEntityIds;
968
+ $[3] = path;
969
+ $[4] = t1;
970
+ } else {
971
+ t1 = $[4];
972
+ }
973
+ let t2;
974
+ if ($[9] !== t1) {
975
+ t2 = /* @__PURE__ */ jsx("div", { className: "grid grid-cols-2 sm:grid-cols-3 lg:grid-cols-4 gap-3 pb-4", children: t1 });
976
+ $[9] = t1;
977
+ $[10] = t2;
978
+ } else {
979
+ t2 = $[10];
980
+ }
981
+ return t2;
982
+ }
983
+ CollectionInsightsInline.displayName = "CollectionInsightsInline";
984
+ function useInsightsPlugin(config) {
985
+ const {
986
+ insights,
987
+ cacheTTL
988
+ } = config;
989
+ const slots = [];
990
+ if (insights.home && insights.home.length > 0) {
991
+ const homeInsights = insights.home;
992
+ slots.push({
993
+ slot: "home.children.start",
994
+ Component: (props) => /* @__PURE__ */ jsx(HomeInsightsSlot, { ...props, insights: homeInsights }),
995
+ order: 10
996
+ });
997
+ }
998
+ if (insights.collections) {
999
+ for (const [slug, defs] of Object.entries(insights.collections)) {
1000
+ if (defs.length === 0) continue;
1001
+ const collectionInsights = defs;
1002
+ slots.push({
1003
+ slot: "collection.insights",
1004
+ Component: (props) => {
1005
+ const path = props.path;
1006
+ const collectionSlug = path?.split("/").filter(Boolean).pop() ?? "";
1007
+ if (collectionSlug !== slug) return null;
1008
+ return /* @__PURE__ */ jsx(CollectionInsightsInline, { ...props, insights: collectionInsights });
1009
+ },
1010
+ order: 10
1011
+ });
1012
+ slots.push({
1013
+ slot: "home.card.insight",
1014
+ Component: (props) => {
1015
+ const cardSlug = props.slug;
1016
+ if (cardSlug !== slug) return null;
1017
+ return /* @__PURE__ */ jsx(HomeCardInsightSlot, { ...props, insights: collectionInsights });
1018
+ },
1019
+ order: 10
1020
+ });
1021
+ }
1022
+ }
1023
+ return {
1024
+ key: "plugin-insights",
1025
+ slots,
1026
+ providers: [{
1027
+ scope: "root",
1028
+ Component: InsightsProvider,
1029
+ props: {
1030
+ cacheTTL
1031
+ }
1032
+ }]
1033
+ };
1034
+ }
1035
+ export {
1036
+ InsightWidget,
1037
+ InsightWidgetSkeleton,
1038
+ InsightsCache,
1039
+ InsightsProvider,
1040
+ InsightsScorecardView,
1041
+ useInsightsData,
1042
+ useInsightsEngine,
1043
+ useInsightsPlugin
1044
+ };
1045
+ //# sourceMappingURL=index.es.js.map