@contractspec/example.analytics-dashboard 1.57.0 → 1.58.0

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 (173) hide show
  1. package/dist/browser/dashboard/dashboard.enum.js +34 -0
  2. package/dist/browser/dashboard/dashboard.operation.js +289 -0
  3. package/dist/browser/dashboard/dashboard.presentation.js +197 -0
  4. package/dist/browser/dashboard/dashboard.schema.js +126 -0
  5. package/dist/browser/dashboard/dashboard.test-spec.js +213 -0
  6. package/dist/browser/dashboard/index.js +299 -0
  7. package/dist/browser/dashboard.feature.js +84 -0
  8. package/dist/browser/datasource/posthog-datasource.js +289 -0
  9. package/dist/browser/docs/analytics-dashboard.docblock.js +103 -0
  10. package/dist/browser/docs/index.js +103 -0
  11. package/dist/browser/events.js +81 -0
  12. package/dist/browser/example.js +42 -0
  13. package/dist/browser/handlers/analytics.handlers.js +278 -0
  14. package/dist/browser/handlers/index.js +571 -0
  15. package/dist/browser/handlers/query.handlers.js +294 -0
  16. package/dist/browser/index.js +1677 -0
  17. package/dist/browser/query/index.js +159 -0
  18. package/dist/browser/query/query.enum.js +11 -0
  19. package/dist/browser/query/query.operation.js +154 -0
  20. package/dist/browser/query/query.presentation.js +119 -0
  21. package/dist/browser/query/query.schema.js +70 -0
  22. package/dist/browser/query/query.test-spec.js +113 -0
  23. package/dist/browser/query-engine/index.js +491 -0
  24. package/dist/browser/seeders/index.js +20 -0
  25. package/dist/browser/ui/AnalyticsDashboard.js +394 -0
  26. package/dist/browser/ui/hooks/index.js +69 -0
  27. package/dist/browser/ui/hooks/useAnalyticsData.js +66 -0
  28. package/dist/browser/ui/index.js +671 -0
  29. package/dist/browser/ui/renderers/analytics.markdown.js +275 -0
  30. package/dist/browser/ui/renderers/index.js +275 -0
  31. package/dist/dashboard/dashboard.enum.d.ts +3 -8
  32. package/dist/dashboard/dashboard.enum.d.ts.map +1 -1
  33. package/dist/dashboard/dashboard.enum.js +31 -39
  34. package/dist/dashboard/dashboard.operation.d.ts +444 -450
  35. package/dist/dashboard/dashboard.operation.d.ts.map +1 -1
  36. package/dist/dashboard/dashboard.operation.js +284 -207
  37. package/dist/dashboard/dashboard.presentation.d.ts +3 -8
  38. package/dist/dashboard/dashboard.presentation.d.ts.map +1 -1
  39. package/dist/dashboard/dashboard.presentation.js +193 -85
  40. package/dist/dashboard/dashboard.schema.d.ts +289 -294
  41. package/dist/dashboard/dashboard.schema.d.ts.map +1 -1
  42. package/dist/dashboard/dashboard.schema.js +119 -228
  43. package/dist/dashboard/dashboard.test-spec.d.ts +4 -9
  44. package/dist/dashboard/dashboard.test-spec.d.ts.map +1 -1
  45. package/dist/dashboard/dashboard.test-spec.js +209 -228
  46. package/dist/dashboard/index.d.ts +7 -4
  47. package/dist/dashboard/index.d.ts.map +1 -0
  48. package/dist/dashboard/index.js +299 -4
  49. package/dist/dashboard.feature.d.ts +1 -6
  50. package/dist/dashboard.feature.d.ts.map +1 -1
  51. package/dist/dashboard.feature.js +83 -175
  52. package/dist/datasource/posthog-datasource.d.ts +15 -19
  53. package/dist/datasource/posthog-datasource.d.ts.map +1 -1
  54. package/dist/datasource/posthog-datasource.js +274 -238
  55. package/dist/docs/analytics-dashboard.docblock.d.ts +2 -1
  56. package/dist/docs/analytics-dashboard.docblock.d.ts.map +1 -0
  57. package/dist/docs/analytics-dashboard.docblock.js +45 -56
  58. package/dist/docs/index.d.ts +2 -1
  59. package/dist/docs/index.d.ts.map +1 -0
  60. package/dist/docs/index.js +104 -1
  61. package/dist/events.d.ts +109 -115
  62. package/dist/events.d.ts.map +1 -1
  63. package/dist/events.js +74 -120
  64. package/dist/example.d.ts +2 -6
  65. package/dist/example.d.ts.map +1 -1
  66. package/dist/example.js +41 -55
  67. package/dist/handlers/analytics.handlers.d.ts +110 -109
  68. package/dist/handlers/analytics.handlers.d.ts.map +1 -1
  69. package/dist/handlers/analytics.handlers.js +267 -298
  70. package/dist/handlers/index.d.ts +3 -3
  71. package/dist/handlers/index.d.ts.map +1 -0
  72. package/dist/handlers/index.js +571 -3
  73. package/dist/handlers/query.handlers.d.ts +7 -11
  74. package/dist/handlers/query.handlers.d.ts.map +1 -1
  75. package/dist/handlers/query.handlers.js +292 -7
  76. package/dist/index.d.ts +12 -13
  77. package/dist/index.d.ts.map +1 -0
  78. package/dist/index.js +1678 -14
  79. package/dist/node/dashboard/dashboard.enum.js +34 -0
  80. package/dist/node/dashboard/dashboard.operation.js +289 -0
  81. package/dist/node/dashboard/dashboard.presentation.js +197 -0
  82. package/dist/node/dashboard/dashboard.schema.js +126 -0
  83. package/dist/node/dashboard/dashboard.test-spec.js +213 -0
  84. package/dist/node/dashboard/index.js +299 -0
  85. package/dist/node/dashboard.feature.js +84 -0
  86. package/dist/node/datasource/posthog-datasource.js +289 -0
  87. package/dist/node/docs/analytics-dashboard.docblock.js +103 -0
  88. package/dist/node/docs/index.js +103 -0
  89. package/dist/node/events.js +81 -0
  90. package/dist/node/example.js +42 -0
  91. package/dist/node/handlers/analytics.handlers.js +278 -0
  92. package/dist/node/handlers/index.js +571 -0
  93. package/dist/node/handlers/query.handlers.js +294 -0
  94. package/dist/node/index.js +1677 -0
  95. package/dist/node/query/index.js +159 -0
  96. package/dist/node/query/query.enum.js +11 -0
  97. package/dist/node/query/query.operation.js +154 -0
  98. package/dist/node/query/query.presentation.js +119 -0
  99. package/dist/node/query/query.schema.js +70 -0
  100. package/dist/node/query/query.test-spec.js +113 -0
  101. package/dist/node/query-engine/index.js +491 -0
  102. package/dist/node/seeders/index.js +20 -0
  103. package/dist/node/ui/AnalyticsDashboard.js +394 -0
  104. package/dist/node/ui/hooks/index.js +69 -0
  105. package/dist/node/ui/hooks/useAnalyticsData.js +66 -0
  106. package/dist/node/ui/index.js +671 -0
  107. package/dist/node/ui/renderers/analytics.markdown.js +275 -0
  108. package/dist/node/ui/renderers/index.js +275 -0
  109. package/dist/query/index.d.ts +7 -4
  110. package/dist/query/index.d.ts.map +1 -0
  111. package/dist/query/index.js +159 -4
  112. package/dist/query/query.enum.d.ts +1 -6
  113. package/dist/query/query.enum.d.ts.map +1 -1
  114. package/dist/query/query.enum.js +10 -14
  115. package/dist/query/query.operation.d.ts +148 -154
  116. package/dist/query/query.operation.d.ts.map +1 -1
  117. package/dist/query/query.operation.js +151 -109
  118. package/dist/query/query.presentation.d.ts +2 -7
  119. package/dist/query/query.presentation.d.ts.map +1 -1
  120. package/dist/query/query.presentation.js +116 -56
  121. package/dist/query/query.schema.d.ts +121 -126
  122. package/dist/query/query.schema.d.ts.map +1 -1
  123. package/dist/query/query.schema.js +66 -152
  124. package/dist/query/query.test-spec.d.ts +2 -7
  125. package/dist/query/query.test-spec.d.ts.map +1 -1
  126. package/dist/query/query.test-spec.js +111 -121
  127. package/dist/query-engine/index.d.ts +84 -88
  128. package/dist/query-engine/index.d.ts.map +1 -1
  129. package/dist/query-engine/index.js +489 -188
  130. package/dist/seeders/index.d.ts +4 -8
  131. package/dist/seeders/index.d.ts.map +1 -1
  132. package/dist/seeders/index.js +18 -16
  133. package/dist/ui/AnalyticsDashboard.d.ts +1 -6
  134. package/dist/ui/AnalyticsDashboard.d.ts.map +1 -1
  135. package/dist/ui/AnalyticsDashboard.js +389 -259
  136. package/dist/ui/hooks/index.d.ts +2 -2
  137. package/dist/ui/hooks/index.d.ts.map +1 -0
  138. package/dist/ui/hooks/index.js +69 -4
  139. package/dist/ui/hooks/useAnalyticsData.d.ts +16 -20
  140. package/dist/ui/hooks/useAnalyticsData.d.ts.map +1 -1
  141. package/dist/ui/hooks/useAnalyticsData.js +63 -69
  142. package/dist/ui/index.d.ts +7 -6
  143. package/dist/ui/index.d.ts.map +1 -0
  144. package/dist/ui/index.js +671 -5
  145. package/dist/ui/renderers/analytics.markdown.d.ts +13 -14
  146. package/dist/ui/renderers/analytics.markdown.d.ts.map +1 -1
  147. package/dist/ui/renderers/analytics.markdown.js +266 -254
  148. package/dist/ui/renderers/index.d.ts +2 -2
  149. package/dist/ui/renderers/index.d.ts.map +1 -0
  150. package/dist/ui/renderers/index.js +275 -2
  151. package/package.json +328 -67
  152. package/dist/dashboard/dashboard.enum.js.map +0 -1
  153. package/dist/dashboard/dashboard.operation.js.map +0 -1
  154. package/dist/dashboard/dashboard.presentation.js.map +0 -1
  155. package/dist/dashboard/dashboard.schema.js.map +0 -1
  156. package/dist/dashboard/dashboard.test-spec.js.map +0 -1
  157. package/dist/dashboard.feature.js.map +0 -1
  158. package/dist/datasource/posthog-datasource.js.map +0 -1
  159. package/dist/docs/analytics-dashboard.docblock.js.map +0 -1
  160. package/dist/events.js.map +0 -1
  161. package/dist/example.js.map +0 -1
  162. package/dist/handlers/analytics.handlers.js.map +0 -1
  163. package/dist/handlers/query.handlers.js.map +0 -1
  164. package/dist/query/query.enum.js.map +0 -1
  165. package/dist/query/query.operation.js.map +0 -1
  166. package/dist/query/query.presentation.js.map +0 -1
  167. package/dist/query/query.schema.js.map +0 -1
  168. package/dist/query/query.test-spec.js.map +0 -1
  169. package/dist/query-engine/index.js.map +0 -1
  170. package/dist/seeders/index.js.map +0 -1
  171. package/dist/ui/AnalyticsDashboard.js.map +0 -1
  172. package/dist/ui/hooks/useAnalyticsData.js.map +0 -1
  173. package/dist/ui/renderers/analytics.markdown.js.map +0 -1
@@ -1,2 +1,2 @@
1
- import { AnalyticsStats, useAnalyticsData } from "./useAnalyticsData.js";
2
- export { type AnalyticsStats, useAnalyticsData };
1
+ export { useAnalyticsData, type AnalyticsStats } from './useAnalyticsData';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ui/hooks/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC"}
@@ -1,5 +1,70 @@
1
- 'use client';
1
+ // @bun
2
+ // src/ui/hooks/useAnalyticsData.ts
3
+ import { useCallback, useEffect, useState } from "react";
4
+ import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
5
+ "use client";
6
+ function useAnalyticsData(projectId = "local-project") {
7
+ const { handlers } = useTemplateRuntime();
8
+ const analytics = handlers.analytics;
9
+ const [dashboards, setDashboards] = useState([]);
10
+ const [queries, setQueries] = useState([]);
11
+ const [selectedDashboard, setSelectedDashboard] = useState(null);
12
+ const [widgets, setWidgets] = useState([]);
13
+ const [loading, setLoading] = useState(true);
14
+ const [error, setError] = useState(null);
15
+ const fetchData = useCallback(async () => {
16
+ try {
17
+ setLoading(true);
18
+ setError(null);
19
+ const [dashResult, queryResult] = await Promise.all([
20
+ analytics.listDashboards({ projectId, limit: 100 }),
21
+ analytics.listQueries({ projectId, limit: 100 })
22
+ ]);
23
+ setDashboards(dashResult.dashboards);
24
+ setQueries(queryResult.queries);
25
+ if (dashResult.dashboards.length > 0 && !selectedDashboard) {
26
+ const first = dashResult.dashboards[0];
27
+ if (first) {
28
+ setSelectedDashboard(first);
29
+ const dashboardWidgets = await analytics.getWidgets(first.id);
30
+ setWidgets(dashboardWidgets);
31
+ }
32
+ }
33
+ } catch (err) {
34
+ setError(err instanceof Error ? err : new Error("Failed to load analytics"));
35
+ } finally {
36
+ setLoading(false);
37
+ }
38
+ }, [analytics, projectId, selectedDashboard]);
39
+ useEffect(() => {
40
+ fetchData();
41
+ }, [fetchData]);
42
+ const selectDashboard = useCallback(async (dashboard) => {
43
+ setSelectedDashboard(dashboard);
44
+ const dashboardWidgets = await analytics.getWidgets(dashboard.id);
45
+ setWidgets(dashboardWidgets);
46
+ }, [analytics]);
47
+ const stats = {
48
+ totalDashboards: dashboards.length,
49
+ publishedDashboards: dashboards.filter((d) => d.status === "PUBLISHED").length,
50
+ totalQueries: queries.length,
51
+ sharedQueries: queries.filter((q) => q.isShared).length
52
+ };
53
+ return {
54
+ dashboards,
55
+ queries,
56
+ selectedDashboard,
57
+ widgets,
58
+ loading,
59
+ error,
60
+ stats,
61
+ refetch: fetchData,
62
+ selectDashboard
63
+ };
64
+ }
2
65
 
3
- import { useAnalyticsData } from "./useAnalyticsData.js";
4
-
5
- export { useAnalyticsData };
66
+ // src/ui/hooks/index.ts
67
+ "use client";
68
+ export {
69
+ useAnalyticsData
70
+ };
@@ -1,23 +1,19 @@
1
- import { Dashboard, Query, Widget } from "../../handlers/analytics.handlers.js";
2
-
3
- //#region src/ui/hooks/useAnalyticsData.d.ts
4
- interface AnalyticsStats {
5
- totalDashboards: number;
6
- publishedDashboards: number;
7
- totalQueries: number;
8
- sharedQueries: number;
1
+ import type { Dashboard, Query, Widget } from '../../handlers/analytics.handlers';
2
+ export interface AnalyticsStats {
3
+ totalDashboards: number;
4
+ publishedDashboards: number;
5
+ totalQueries: number;
6
+ sharedQueries: number;
9
7
  }
10
- declare function useAnalyticsData(projectId?: string): {
11
- dashboards: Dashboard[];
12
- queries: Query[];
13
- selectedDashboard: Dashboard | null;
14
- widgets: Widget[];
15
- loading: boolean;
16
- error: Error | null;
17
- stats: AnalyticsStats;
18
- refetch: () => Promise<void>;
19
- selectDashboard: (dashboard: Dashboard) => Promise<void>;
8
+ export declare function useAnalyticsData(projectId?: string): {
9
+ dashboards: Dashboard[];
10
+ queries: Query[];
11
+ selectedDashboard: Dashboard | null;
12
+ widgets: Widget[];
13
+ loading: boolean;
14
+ error: Error | null;
15
+ stats: AnalyticsStats;
16
+ refetch: () => Promise<void>;
17
+ selectDashboard: (dashboard: Dashboard) => Promise<void>;
20
18
  };
21
- //#endregion
22
- export { AnalyticsStats, useAnalyticsData };
23
19
  //# sourceMappingURL=useAnalyticsData.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useAnalyticsData.d.ts","names":[],"sources":["../../../src/ui/hooks/useAnalyticsData.ts"],"mappings":";;;UAWiB,cAAA;EACf,eAAA;EACA,mBAAA;EACA,YAAA;EACA,aAAA;AAAA;AAAA,iBAGc,gBAAA,CAAiB,SAAA;;;;;;;;;+BAgDX,SAAA,KAAS,OAAA;AAAA"}
1
+ {"version":3,"file":"useAnalyticsData.d.ts","sourceRoot":"","sources":["../../../src/ui/hooks/useAnalyticsData.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAEV,SAAS,EACT,KAAK,EACL,MAAM,EACP,MAAM,mCAAmC,CAAC;AAG3C,MAAM,WAAW,cAAc;IAC7B,eAAe,EAAE,MAAM,CAAC;IACxB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,wBAAgB,gBAAgB,CAAC,SAAS,SAAkB;;;;;;;;;iCAgDtC,SAAS;EA2B9B"}
@@ -1,73 +1,67 @@
1
- 'use client';
2
-
1
+ // @bun
2
+ // src/ui/hooks/useAnalyticsData.ts
3
3
  import { useCallback, useEffect, useState } from "react";
4
4
  import { useTemplateRuntime } from "@contractspec/lib.example-shared-ui";
5
-
6
- //#region src/ui/hooks/useAnalyticsData.ts
5
+ "use client";
7
6
  function useAnalyticsData(projectId = "local-project") {
8
- const { handlers } = useTemplateRuntime();
9
- const analytics = handlers.analytics;
10
- const [dashboards, setDashboards] = useState([]);
11
- const [queries, setQueries] = useState([]);
12
- const [selectedDashboard, setSelectedDashboard] = useState(null);
13
- const [widgets, setWidgets] = useState([]);
14
- const [loading, setLoading] = useState(true);
15
- const [error, setError] = useState(null);
16
- const fetchData = useCallback(async () => {
17
- try {
18
- setLoading(true);
19
- setError(null);
20
- const [dashResult, queryResult] = await Promise.all([analytics.listDashboards({
21
- projectId,
22
- limit: 100
23
- }), analytics.listQueries({
24
- projectId,
25
- limit: 100
26
- })]);
27
- setDashboards(dashResult.dashboards);
28
- setQueries(queryResult.queries);
29
- if (dashResult.dashboards.length > 0 && !selectedDashboard) {
30
- const first = dashResult.dashboards[0];
31
- if (first) {
32
- setSelectedDashboard(first);
33
- setWidgets(await analytics.getWidgets(first.id));
34
- }
35
- }
36
- } catch (err) {
37
- setError(err instanceof Error ? err : /* @__PURE__ */ new Error("Failed to load analytics"));
38
- } finally {
39
- setLoading(false);
40
- }
41
- }, [
42
- analytics,
43
- projectId,
44
- selectedDashboard
45
- ]);
46
- useEffect(() => {
47
- fetchData();
48
- }, [fetchData]);
49
- const selectDashboard = useCallback(async (dashboard) => {
50
- setSelectedDashboard(dashboard);
51
- setWidgets(await analytics.getWidgets(dashboard.id));
52
- }, [analytics]);
53
- return {
54
- dashboards,
55
- queries,
56
- selectedDashboard,
57
- widgets,
58
- loading,
59
- error,
60
- stats: {
61
- totalDashboards: dashboards.length,
62
- publishedDashboards: dashboards.filter((d) => d.status === "PUBLISHED").length,
63
- totalQueries: queries.length,
64
- sharedQueries: queries.filter((q) => q.isShared).length
65
- },
66
- refetch: fetchData,
67
- selectDashboard
68
- };
7
+ const { handlers } = useTemplateRuntime();
8
+ const analytics = handlers.analytics;
9
+ const [dashboards, setDashboards] = useState([]);
10
+ const [queries, setQueries] = useState([]);
11
+ const [selectedDashboard, setSelectedDashboard] = useState(null);
12
+ const [widgets, setWidgets] = useState([]);
13
+ const [loading, setLoading] = useState(true);
14
+ const [error, setError] = useState(null);
15
+ const fetchData = useCallback(async () => {
16
+ try {
17
+ setLoading(true);
18
+ setError(null);
19
+ const [dashResult, queryResult] = await Promise.all([
20
+ analytics.listDashboards({ projectId, limit: 100 }),
21
+ analytics.listQueries({ projectId, limit: 100 })
22
+ ]);
23
+ setDashboards(dashResult.dashboards);
24
+ setQueries(queryResult.queries);
25
+ if (dashResult.dashboards.length > 0 && !selectedDashboard) {
26
+ const first = dashResult.dashboards[0];
27
+ if (first) {
28
+ setSelectedDashboard(first);
29
+ const dashboardWidgets = await analytics.getWidgets(first.id);
30
+ setWidgets(dashboardWidgets);
31
+ }
32
+ }
33
+ } catch (err) {
34
+ setError(err instanceof Error ? err : new Error("Failed to load analytics"));
35
+ } finally {
36
+ setLoading(false);
37
+ }
38
+ }, [analytics, projectId, selectedDashboard]);
39
+ useEffect(() => {
40
+ fetchData();
41
+ }, [fetchData]);
42
+ const selectDashboard = useCallback(async (dashboard) => {
43
+ setSelectedDashboard(dashboard);
44
+ const dashboardWidgets = await analytics.getWidgets(dashboard.id);
45
+ setWidgets(dashboardWidgets);
46
+ }, [analytics]);
47
+ const stats = {
48
+ totalDashboards: dashboards.length,
49
+ publishedDashboards: dashboards.filter((d) => d.status === "PUBLISHED").length,
50
+ totalQueries: queries.length,
51
+ sharedQueries: queries.filter((q) => q.isShared).length
52
+ };
53
+ return {
54
+ dashboards,
55
+ queries,
56
+ selectedDashboard,
57
+ widgets,
58
+ loading,
59
+ error,
60
+ stats,
61
+ refetch: fetchData,
62
+ selectDashboard
63
+ };
69
64
  }
70
-
71
- //#endregion
72
- export { useAnalyticsData };
73
- //# sourceMappingURL=useAnalyticsData.js.map
65
+ export {
66
+ useAnalyticsData
67
+ };
@@ -1,6 +1,7 @@
1
- import { analyticsDashboardMarkdownRenderer, dashboardListMarkdownRenderer, queryBuilderMarkdownRenderer } from "./renderers/analytics.markdown.js";
2
- import "./renderers/index.js";
3
- import { AnalyticsDashboard } from "./AnalyticsDashboard.js";
4
- import { AnalyticsStats, useAnalyticsData } from "./hooks/useAnalyticsData.js";
5
- import "./hooks/index.js";
6
- export { AnalyticsDashboard, AnalyticsStats, analyticsDashboardMarkdownRenderer, dashboardListMarkdownRenderer, queryBuilderMarkdownRenderer, useAnalyticsData };
1
+ /**
2
+ * Analytics Dashboard Template Components
3
+ */
4
+ export * from './renderers';
5
+ export { AnalyticsDashboard } from './AnalyticsDashboard';
6
+ export * from './hooks';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ui/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,cAAc,SAAS,CAAC"}