@cccsaurora/clue-ui 1.2.0-dev.254 → 1.2.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 (179) hide show
  1. package/ActionForm-pWyIi01Z.js +4460 -0
  2. package/AnnotationDetails-11P7yhyx.js +160 -0
  3. package/AnnotationPreview-BGqlBBcp.js +140 -0
  4. package/ClueEnrichContext-DDZf646J.js +418 -0
  5. package/FlexOne-BXWFOd1T.js +6 -0
  6. package/_MapCache-BiTi0iqu.js +180 -0
  7. package/_Uint8Array-TJBs9NS2.js +101 -0
  8. package/_baseAssignValue-CNMLQZco.js +20 -0
  9. package/_baseClone-DajKHDCs.js +207 -0
  10. package/_baseExtremum-DhV10dXG.js +27 -0
  11. package/_baseFlatten-C8CjmqQ-.js +72 -0
  12. package/_baseGet-DSZygzyq.js +79 -0
  13. package/_baseIsEqual-C08cUUpA.js +147 -0
  14. package/_baseIteratee-DGZdhdqr.js +95 -0
  15. package/_baseSlice-M5RKzt1A.js +10 -0
  16. package/_baseSum-wEbgNeUs.js +10 -0
  17. package/_baseUniq-CGlHphLr.js +79 -0
  18. package/_commonjsHelpers-DaMA6jEr.js +8 -0
  19. package/_createAggregator-BvcoTZto.js +53 -0
  20. package/_getPrototype-Dm06JiGv.js +5 -0
  21. package/_getTag-Cfxlub3L.js +90 -0
  22. package/_setToArray-C7yMOeww.js +29 -0
  23. package/cloneDeep-wjl3XmFj.js +8 -0
  24. package/components/AnnotationBody.js +35 -49
  25. package/components/AnnotationDetailPopover.js +30 -36
  26. package/components/AnnotationDetails.js +7 -7
  27. package/components/AnnotationEntry.js +35 -35
  28. package/components/AnnotationPreview.js +5 -5
  29. package/components/ClassificationChip.js +23 -44
  30. package/components/CountBadge.js +26 -31
  31. package/components/EnrichedCard.js +97 -110
  32. package/components/EnrichedChip.js +105 -130
  33. package/components/EnrichedTypography.js +107 -133
  34. package/components/ErrorBoundary.js +24 -28
  35. package/components/RetryFailedEnrichments.js +9 -10
  36. package/components/SourcePicker.js +49 -57
  37. package/components/actions/ActionForm.js +4 -4
  38. package/components/actions/ExecutePopover.js +59 -75
  39. package/components/actions/ResultModal.js +4 -4
  40. package/components/actions/form/schemaAdapter.js +23 -39
  41. package/components/actions/formats/FileResult.js +59 -86
  42. package/components/actions/formats/index.js +10 -21
  43. package/components/display/graph/ExpandMoreButton.js +10 -10
  44. package/components/display/graph/elements/NodeCard.js +91 -111
  45. package/components/display/graph/elements/NodeTag.js +13 -15
  46. package/components/display/graph/index.js +202 -261
  47. package/components/display/graph/visualizations/Leaf.js +69 -88
  48. package/components/display/graph/visualizations/cloud/index.js +81 -98
  49. package/components/display/graph/visualizations/icons/BaseIcon.js +21 -26
  50. package/components/display/graph/visualizations/icons/BugIcon.js +12 -12
  51. package/components/display/graph/visualizations/icons/HostIcon.js +12 -12
  52. package/components/display/graph/visualizations/icons/NetworkIcon.js +12 -12
  53. package/components/display/graph/visualizations/icons/ProcessIcon.js +12 -12
  54. package/components/display/graph/visualizations/icons/TargetIcon.js +13 -13
  55. package/components/display/graph/visualizations/icons/index.js +13 -14
  56. package/components/display/graph/visualizations/panels/NodePanel.js +8 -10
  57. package/components/display/graph/visualizations/tree/BundleLine.js +81 -108
  58. package/components/display/graph/visualizations/tree/Triangle.js +13 -13
  59. package/components/display/graph/visualizations/tree/index.js +305 -407
  60. package/components/display/icons/Iconified.js +12 -27
  61. package/components/display/json/index.js +4 -4
  62. package/components/display/markdown/index.js +5770 -8678
  63. package/components/enrichment/EnrichPopover.js +46 -54
  64. package/components/fetchers/Fetcher.js +117 -155
  65. package/components/fetchers/PreviewModal.js +17 -20
  66. package/components/fetchers/StatusChip.js +17 -21
  67. package/components/group/Entry.js +11 -13
  68. package/components/group/Group.js +10 -13
  69. package/components/group/GroupControl.js +65 -76
  70. package/components/stats/QueryStatus.js +33 -43
  71. package/countBy-pIyxNZhO.js +8 -0
  72. package/data/event.js +4 -6
  73. package/database/index.js +2 -2
  74. package/debounce-DryYcbJ4.js +56 -0
  75. package/get-CH7kz5Ix.js +8 -0
  76. package/groupBy-yNrpdipq.js +8 -0
  77. package/hooks/ClueActionContext.js +6 -6
  78. package/hooks/ClueComponentContext.js +23 -29
  79. package/hooks/ClueConfigProvider.js +12 -14
  80. package/hooks/ClueDatabaseContext.js +13 -19
  81. package/hooks/ClueEnrichContext.js +8 -8
  82. package/hooks/ClueFetcherContext.js +56 -83
  83. package/hooks/ClueGroupContext.js +14 -17
  84. package/hooks/CluePopupContext.js +5 -5
  85. package/hooks/ClueProvider.js +10 -12
  86. package/hooks/selectors.js +7 -7
  87. package/hooks/useActionResult.js +2 -2
  88. package/hooks/useAnnotations.js +31 -47
  89. package/hooks/useClue.js +4 -6
  90. package/hooks/useClueActions.js +3 -3
  91. package/hooks/useClueConfig.js +4 -6
  92. package/hooks/useClueTypeConfig.js +3 -3
  93. package/hooks/useComparator.js +435 -722
  94. package/hooks/useErrors.js +18 -22
  95. package/hooks/useFetcherResult.js +24 -33
  96. package/hooks/useMyHighlights.js +36 -66
  97. package/hooks/useMyLocalStorage.js +37 -66
  98. package/iconify-BBckr5AQ.js +1263 -0
  99. package/icons/Action.js +49 -66
  100. package/icons/Assessment.js +68 -84
  101. package/icons/Context.js +63 -77
  102. package/icons/Opinion.js +65 -77
  103. package/icons/iconMap.js +2 -2
  104. package/identity-ByMq8VxU.js +6 -0
  105. package/index-BHAe_V9n.js +12768 -0
  106. package/index-CA5CUNZO.js +975 -0
  107. package/index-D_ZywK71.js +358 -0
  108. package/index-Dj5C04IX.js +568 -0
  109. package/index-p5_wX7q1.js +11729 -0
  110. package/isNil-CjWwlQS3.js +6 -0
  111. package/isObject-B53jY8Qg.js +7 -0
  112. package/isObjectLike-BatpeCIi.js +29 -0
  113. package/isSymbol-C3_SC0Qp.js +8 -0
  114. package/last-7CdUxN0r.js +7 -0
  115. package/main.js +60 -60
  116. package/package.json +1 -1
  117. package/sortBy-0BpKRt8p.js +79 -0
  118. package/sumBy-Do6Ff4Bw.js +8 -0
  119. package/text/Frequency.js +23 -42
  120. package/toFinite-BMy6GObD.js +14 -0
  121. package/toNumber-YVhnnJv4.js +31 -0
  122. package/useClueTypeConfig-77zd_zdF.js +2292 -0
  123. package/utils/chain.js +64 -91
  124. package/utils/classificationParser.js +256 -519
  125. package/utils/constants.js +10 -35
  126. package/utils/graph.js +45 -72
  127. package/utils/hashUtil.js +7 -7
  128. package/utils/line.js +81 -131
  129. package/utils/loggerUtil.js +3 -5
  130. package/utils/sessionStorage.js +27 -41
  131. package/utils/time.js +423 -423
  132. package/utils/utils.js +9 -9
  133. package/utils/window.js +10 -21
  134. package/utils-D5hPDE7N.js +129 -0
  135. package/ActionForm-C0aE9HUv.js +0 -5941
  136. package/AnnotationDetails-CEou0vCc.js +0 -175
  137. package/AnnotationPreview-CLMVD6Ec.js +0 -188
  138. package/ClueEnrichContext-BkD9ZwM9.js +0 -541
  139. package/FlexOne-BSYAhhtG.js +0 -9
  140. package/_MapCache-WmuDdwuH.js +0 -222
  141. package/_Uint8Array-DdG4KLKn.js +0 -128
  142. package/_baseAssignValue-CGTuELqU.js +0 -25
  143. package/_baseClone-BpWiBnMp.js +0 -283
  144. package/_baseExtremum-BY663UjY.js +0 -33
  145. package/_baseFlatten-B69cDsaV.js +0 -92
  146. package/_baseGet-Bx3A4Qfp.js +0 -108
  147. package/_baseIsEqual-B4IufFlL.js +0 -208
  148. package/_baseIteratee-7AQvAy1o.js +0 -126
  149. package/_baseSlice-GAv_YFTT.js +0 -20
  150. package/_baseSum-D0WC1dN0.js +0 -13
  151. package/_baseUniq-B8fK6hI-.js +0 -115
  152. package/_commonjsHelpers-DWwsNxpa.js +0 -8
  153. package/_createAggregator-CwGPThny.js +0 -63
  154. package/_getPrototype-CblfEidB.js +0 -5
  155. package/_getTag-jwz4XLoZ.js +0 -126
  156. package/_setToArray-CaPKQhcz.js +0 -33
  157. package/cloneDeep-DmUylbkM.js +0 -8
  158. package/countBy-DqlU5OwT.js +0 -14
  159. package/debounce-bV0h5FC5.js +0 -92
  160. package/get-DSsNkRQs.js +0 -8
  161. package/groupBy-ChDRT7uy.js +0 -14
  162. package/iconify-CXMreGTg.js +0 -1782
  163. package/identity-CPGTqrE4.js +0 -6
  164. package/index-AMfoEg_6.js +0 -696
  165. package/index-B6C2a_Lg.js +0 -1172
  166. package/index-C12gPw2W.js +0 -17698
  167. package/index-DCKkHTvx.js +0 -15750
  168. package/index-UkW8Sur3.js +0 -465
  169. package/isNil-CIubwp4T.js +0 -6
  170. package/isObject-FTY-5JQX.js +0 -7
  171. package/isObjectLike-OAgjjZye.js +0 -48
  172. package/isSymbol-Xd2FsJyp.js +0 -8
  173. package/last-CUCl67Im.js +0 -7
  174. package/sortBy-C7mGPI_D.js +0 -100
  175. package/sumBy-CGALjmwQ.js +0 -8
  176. package/toFinite-Bc55msYj.js +0 -16
  177. package/toNumber-DPxy1FBy.js +0 -39
  178. package/useClueTypeConfig-D2tf4-NM.js +0 -3289
  179. package/utils-71DpzFrA.js +0 -199
package/icons/Action.js CHANGED
@@ -1,90 +1,73 @@
1
- import { jsx, jsxs } from "react/jsx-runtime";
2
- import { I as Icon } from "../iconify-CXMreGTg.js";
3
- import { useTheme, Stack, Divider, Typography } from "@mui/material";
4
- import CountBadge from "../components/CountBadge.js";
5
- import { C as CluePopupContext } from "../AnnotationPreview-CLMVD6Ec.js";
6
- import { u as useClueActions } from "../ActionForm-C0aE9HUv.js";
7
- import { g as groupBy } from "../groupBy-ChDRT7uy.js";
8
- import { memo, useRef, useMemo, useEffect } from "react";
9
- import { u as useContextSelector } from "../index-AMfoEg_6.js";
10
- const ResultDetails = ({ result }) => {
11
- return /* @__PURE__ */ jsxs(Stack, { p: 1, children: [
12
- /* @__PURE__ */ jsx(Typography, { variant: "body1", children: result.action.name }),
13
- /* @__PURE__ */ jsx(Typography, { variant: "caption", color: "text.secondary", children: result.summary })
14
- ] });
15
- };
16
- const ActionIcon = ({ value, counters = true, disableTooltip = false, ...otherProps }) => {
17
- const theme = useTheme();
18
- const showInfo = useContextSelector(CluePopupContext, (state) => state.showInfo);
19
- const closeInfo = useContextSelector(CluePopupContext, (state) => state.closeInfo);
20
- const successAnchorRef = useRef();
21
- const failureAnchorRef = useRef();
22
- const { getActionResults } = useClueActions();
23
- const actionResults = useMemo(
24
- () => getActionResults(value.type, value.value, value.classification),
25
- [getActionResults, value.classification, value.type, value.value]
1
+ import { jsx as e, jsxs as z } from "react/jsx-runtime";
2
+ import { I } from "../iconify-BBckr5AQ.js";
3
+ import { useTheme as j, Stack as i, Divider as l, Typography as C } from "@mui/material";
4
+ import R from "../components/CountBadge.js";
5
+ import { C as v } from "../AnnotationPreview-BGqlBBcp.js";
6
+ import { u as B } from "../ActionForm-pWyIi01Z.js";
7
+ import { g as D } from "../groupBy-yNrpdipq.js";
8
+ import { memo as L, useRef as A, useMemo as s, useEffect as O } from "react";
9
+ import { u as M } from "../index-Dj5C04IX.js";
10
+ const k = ({ result: o }) => /* @__PURE__ */ z(i, { p: 1, children: [
11
+ /* @__PURE__ */ e(C, { variant: "body1", children: o.action.name }),
12
+ /* @__PURE__ */ e(C, { variant: "caption", color: "text.secondary", children: o.summary })
13
+ ] }), b = ({ value: o, counters: f = !0, disableTooltip: c = !1, ...d }) => {
14
+ const p = j(), h = M(v, (t) => t.showInfo), a = M(v, (t) => t.closeInfo), y = A(), g = A(), { getActionResults: x } = B(), n = s(
15
+ () => x(o.type, o.value, o.classification),
16
+ [x, o.classification, o.type, o.value]
26
17
  );
27
- useEffect(() => {
28
- if (disableTooltip) {
29
- closeInfo("context", value);
30
- }
31
- }, [disableTooltip]);
32
- const [successes, failures] = useMemo(() => {
33
- const outcomes = groupBy(actionResults, (result) => result.outcome);
34
- return [outcomes.success ?? [], outcomes.failure ?? []];
35
- }, [actionResults]);
36
- const successContent = useMemo(() => {
37
- const entries = successes.map((result) => /* @__PURE__ */ jsx(ResultDetails, { result }, result.actionId));
38
- return /* @__PURE__ */ jsx(Stack, { spacing: 1, divider: /* @__PURE__ */ jsx(Divider, { flexItem: true, orientation: "horizontal" }), children: entries });
39
- }, [successes]);
40
- const failureContent = useMemo(() => {
41
- const entries = failures.map((result) => /* @__PURE__ */ jsx(ResultDetails, { result }, result.summary));
42
- return /* @__PURE__ */ jsx(Stack, { spacing: 1, divider: /* @__PURE__ */ jsx(Divider, { flexItem: true, orientation: "horizontal" }), children: entries });
43
- }, [failures]);
44
- if ((actionResults == null ? void 0 : actionResults.length) < 1) {
45
- return null;
46
- }
47
- return /* @__PURE__ */ jsxs(Stack, { direction: "row", spacing: 1, children: [
48
- /* @__PURE__ */ jsx(Divider, { flexItem: true, orientation: "vertical" }),
49
- successes.length > 0 && /* @__PURE__ */ jsx(
18
+ O(() => {
19
+ c && a("context", o);
20
+ }, [c]);
21
+ const [m, u] = s(() => {
22
+ const t = D(n, (r) => r.outcome);
23
+ return [t.success ?? [], t.failure ?? []];
24
+ }, [n]), S = s(() => {
25
+ const t = m.map((r) => /* @__PURE__ */ e(k, { result: r }, r.actionId));
26
+ return /* @__PURE__ */ e(i, { spacing: 1, divider: /* @__PURE__ */ e(l, { flexItem: !0, orientation: "horizontal" }), children: t });
27
+ }, [m]), w = s(() => {
28
+ const t = u.map((r) => /* @__PURE__ */ e(k, { result: r }, r.summary));
29
+ return /* @__PURE__ */ e(i, { spacing: 1, divider: /* @__PURE__ */ e(l, { flexItem: !0, orientation: "horizontal" }), children: t });
30
+ }, [u]);
31
+ return (n == null ? void 0 : n.length) < 1 ? null : /* @__PURE__ */ z(i, { direction: "row", spacing: 1, children: [
32
+ /* @__PURE__ */ e(l, { flexItem: !0, orientation: "vertical" }),
33
+ m.length > 0 && /* @__PURE__ */ e(
50
34
  "span",
51
35
  {
52
- ref: successAnchorRef,
36
+ ref: y,
53
37
  style: { display: "flex" },
54
- onMouseOver: disableTooltip ? void 0 : () => showInfo("actionResults", successAnchorRef.current, value, { content: successContent }),
55
- onMouseLeave: disableTooltip ? void 0 : () => closeInfo("actionResults", value),
56
- children: /* @__PURE__ */ jsx(CountBadge, { disabled: !counters, count: actionResults.filter((result) => result.outcome === "success").length, children: /* @__PURE__ */ jsx(
57
- Icon,
38
+ onMouseOver: c ? void 0 : () => h("actionResults", y.current, o, { content: S }),
39
+ onMouseLeave: c ? void 0 : () => a("actionResults", o),
40
+ children: /* @__PURE__ */ e(R, { disabled: !f, count: n.filter((t) => t.outcome === "success").length, children: /* @__PURE__ */ e(
41
+ I,
58
42
  {
59
43
  icon: "material-symbols:bookmark-check-rounded",
60
- color: theme.palette.success.main,
44
+ color: p.palette.success.main,
61
45
  fontSize: "1.5em",
62
- ...otherProps
46
+ ...d
63
47
  }
64
48
  ) })
65
49
  }
66
50
  ),
67
- failures.length > 0 && /* @__PURE__ */ jsx(
51
+ u.length > 0 && /* @__PURE__ */ e(
68
52
  "span",
69
53
  {
70
- ref: failureAnchorRef,
54
+ ref: g,
71
55
  style: { display: "flex" },
72
- onMouseOver: disableTooltip ? void 0 : () => showInfo("actionResults", failureAnchorRef.current, value, { content: failureContent }),
73
- onMouseLeave: disableTooltip ? void 0 : () => closeInfo("actionResults", value),
74
- children: /* @__PURE__ */ jsx(CountBadge, { disabled: !counters, count: actionResults.filter((result) => result.outcome === "failure").length, children: /* @__PURE__ */ jsx(
75
- Icon,
56
+ onMouseOver: c ? void 0 : () => h("actionResults", g.current, o, { content: w }),
57
+ onMouseLeave: c ? void 0 : () => a("actionResults", o),
58
+ children: /* @__PURE__ */ e(R, { disabled: !f, count: n.filter((t) => t.outcome === "failure").length, children: /* @__PURE__ */ e(
59
+ I,
76
60
  {
77
61
  icon: "material-symbols:cancel-presentation-rounded",
78
- color: theme.palette.error.main,
62
+ color: p.palette.error.main,
79
63
  fontSize: "1.5em",
80
- ...otherProps
64
+ ...d
81
65
  }
82
66
  ) })
83
67
  }
84
68
  )
85
69
  ] });
86
- };
87
- const ActionIcon$1 = memo(ActionIcon);
70
+ }, P = L(b);
88
71
  export {
89
- ActionIcon$1 as default
72
+ P as default
90
73
  };
@@ -1,123 +1,107 @@
1
- import { jsxs, Fragment, jsx } from "react/jsx-runtime";
2
- import { I as Icon } from "../iconify-CXMreGTg.js";
3
- import { useTheme, Stack, Chip, Divider, Grid, Tooltip } from "@mui/material";
4
- import CountBadge from "../components/CountBadge.js";
5
- import { C as CluePopupContext } from "../AnnotationPreview-CLMVD6Ec.js";
6
- import { g as groupBy } from "../groupBy-ChDRT7uy.js";
7
- import { l as last } from "../last-CUCl67Im.js";
8
- import { m as maxBy, s as sortBy } from "../sortBy-C7mGPI_D.js";
9
- import { s as sumBy } from "../sumBy-CGALjmwQ.js";
10
- import { memo, useRef, useState, useMemo, useEffect } from "react";
11
- import { u as useContextSelector } from "../index-AMfoEg_6.js";
12
- const AssessmentIcon = ({ annotations, value, counters = true, disableTooltip = false, ubiquitous = false, ...otherProps }) => {
13
- const theme = useTheme();
14
- const showInfo = useContextSelector(CluePopupContext, (state) => state.showInfo);
15
- const closeInfo = useContextSelector(CluePopupContext, (state) => state.closeInfo);
16
- const anchorRef = useRef();
17
- const [showTooltip, setShowTooltip] = useState(false);
18
- const assessmentAnnotations = useMemo(
19
- () => annotations.filter((annotation) => (annotation == null ? void 0 : annotation.type) === "assessment" && (annotation == null ? void 0 : annotation.ubiquitous) === ubiquitous),
20
- [annotations, ubiquitous]
21
- );
22
- const sortedAssessments = useMemo(
23
- () => Object.entries(groupBy(assessmentAnnotations, "value")).map(([_value, _annotations]) => [
24
- _value,
25
- sumBy(_annotations, "quantity")
1
+ import { jsxs as b, Fragment as k, jsx as s } from "react/jsx-runtime";
2
+ import { I as l } from "../iconify-BBckr5AQ.js";
3
+ import { useTheme as j, Stack as y, Chip as I, Divider as q, Grid as C, Tooltip as A } from "@mui/material";
4
+ import z from "../components/CountBadge.js";
5
+ import { C as w } from "../AnnotationPreview-BGqlBBcp.js";
6
+ import { g as O } from "../groupBy-yNrpdipq.js";
7
+ import { l as P } from "../last-7CdUxN0r.js";
8
+ import { m as L, s as R } from "../sortBy-0BpKRt8p.js";
9
+ import { s as W } from "../sumBy-Do6Ff4Bw.js";
10
+ import { memo as D, useRef as E, useState as F, useMemo as d, useEffect as G } from "react";
11
+ import { u as S } from "../index-Dj5C04IX.js";
12
+ const H = ({ annotations: u, value: i, counters: f = !0, disableTooltip: r = !1, ubiquitous: h = !1, ...v }) => {
13
+ const o = j(), g = S(w, (e) => e.showInfo), x = S(w, (e) => e.closeInfo), c = E(), [$, B] = F(!1), t = d(
14
+ () => u.filter((e) => (e == null ? void 0 : e.type) === "assessment" && (e == null ? void 0 : e.ubiquitous) === h),
15
+ [u, h]
16
+ ), m = d(
17
+ () => Object.entries(O(t, "value")).map(([e, p]) => [
18
+ e,
19
+ W(p, "quantity")
26
20
  ]),
27
- [assessmentAnnotations]
28
- );
29
- const popularAssessment = useMemo(() => maxBy(sortedAssessments, last), [sortedAssessments]);
30
- useEffect(() => {
31
- if (disableTooltip) {
32
- setShowTooltip(false);
33
- }
34
- }, [disableTooltip]);
35
- if ((assessmentAnnotations == null ? void 0 : assessmentAnnotations.length) < 1) {
21
+ [t]
22
+ ), n = d(() => L(m, P), [m]);
23
+ if (G(() => {
24
+ r && B(!1);
25
+ }, [r]), (t == null ? void 0 : t.length) < 1)
36
26
  return null;
37
- }
38
- const tooltipProps = {
27
+ const M = {
39
28
  tooltip: {
40
29
  sx: {
41
30
  maxWidth: "500px",
42
- backgroundColor: theme.palette.background.paper,
43
- border: `thin solid ${theme.palette.divider}`,
31
+ backgroundColor: o.palette.background.paper,
32
+ border: `thin solid ${o.palette.divider}`,
44
33
  p: 1,
45
- boxShadow: theme.shadows[2]
34
+ boxShadow: o.shadows[2]
46
35
  }
47
36
  }
48
- };
49
- const tooltipContent = /* @__PURE__ */ jsxs(Stack, { spacing: 1, onClick: (e) => e.stopPropagation(), children: [
50
- assessmentAnnotations.length > 1 && /* @__PURE__ */ jsxs(Fragment, { children: [
51
- /* @__PURE__ */ jsx(Stack, { direction: "row", children: sortedAssessments.map(([type, count]) => /* @__PURE__ */ jsx(
52
- Chip,
37
+ }, a = /* @__PURE__ */ b(y, { spacing: 1, onClick: (e) => e.stopPropagation(), children: [
38
+ t.length > 1 && /* @__PURE__ */ b(k, { children: [
39
+ /* @__PURE__ */ s(y, { direction: "row", children: m.map(([e, p]) => /* @__PURE__ */ s(
40
+ I,
53
41
  {
54
42
  size: "small",
55
43
  variant: "outlined",
56
- label: `${type}: ${count}`,
57
- icon: /* @__PURE__ */ jsx(
58
- Icon,
44
+ label: `${e}: ${p}`,
45
+ icon: /* @__PURE__ */ s(
46
+ l,
59
47
  {
60
- icon: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(type) ? "healthicons:hazardous" : "fluent-mdl2:ribbon-solid"
48
+ icon: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(e) ? "healthicons:hazardous" : "fluent-mdl2:ribbon-solid"
61
49
  }
62
50
  ),
63
- color: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(type) ? "error" : "success"
51
+ color: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(e) ? "error" : "success"
64
52
  },
65
- type
53
+ e
66
54
  )) }),
67
- /* @__PURE__ */ jsx(Divider, { orientation: "horizontal", flexItem: true })
55
+ /* @__PURE__ */ s(q, { orientation: "horizontal", flexItem: !0 })
68
56
  ] }),
69
- /* @__PURE__ */ jsx(
70
- Grid,
57
+ /* @__PURE__ */ s(
58
+ C,
71
59
  {
72
60
  sx: {
73
- mt: assessmentAnnotations.length < 2 && `${theme.spacing(-0.5)} !important`,
74
- ml: `${theme.spacing(-0.5)} !important`
61
+ mt: t.length < 2 && `${o.spacing(-0.5)} !important`,
62
+ ml: `${o.spacing(-0.5)} !important`
75
63
  },
76
- container: true,
64
+ container: !0,
77
65
  spacing: 0.5,
78
66
  maxWidth: "500px",
79
- children: sortBy(assessmentAnnotations, "value").map((annotation) => /* @__PURE__ */ jsx(Grid, { item: true, children: /* @__PURE__ */ jsx(
80
- Chip,
67
+ children: R(t, "value").map((e) => /* @__PURE__ */ s(C, { item: !0, children: /* @__PURE__ */ s(
68
+ I,
81
69
  {
82
70
  size: "small",
83
71
  variant: "outlined",
84
- label: annotation.analytic + (annotation.quantity > 1 ? ` (x${annotation.quantity})` : ""),
85
- icon: /* @__PURE__ */ jsx(
86
- Icon,
72
+ label: e.analytic + (e.quantity > 1 ? ` (x${e.quantity})` : ""),
73
+ icon: /* @__PURE__ */ s(
74
+ l,
87
75
  {
88
- icon: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(annotation.value) ? "healthicons:hazardous" : "fluent-mdl2:ribbon-solid"
76
+ icon: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(e.value) ? "healthicons:hazardous" : "fluent-mdl2:ribbon-solid"
89
77
  }
90
78
  ),
91
- color: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(annotation.value) ? "error" : "success"
79
+ color: ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(e.value) ? "error" : "success"
92
80
  }
93
- ) }, annotation.analytic + annotation.value))
81
+ ) }, e.analytic + e.value))
94
82
  }
95
83
  )
96
84
  ] });
97
- if (["trivial", "recon", "attempt", "compromise", "mitigated"].includes(popularAssessment[0])) {
98
- return /* @__PURE__ */ jsx(
99
- "span",
100
- {
101
- ref: anchorRef,
102
- style: { display: "flex" },
103
- onMouseOver: disableTooltip ? void 0 : () => showInfo("assessment", anchorRef.current, value, { content: tooltipContent }),
104
- onMouseLeave: disableTooltip ? void 0 : () => closeInfo("assessment", value),
105
- children: /* @__PURE__ */ jsx(CountBadge, { disabled: !counters, color: "error", count: popularAssessment[1], children: /* @__PURE__ */ jsx(Icon, { fontSize: "1.5em", ...otherProps, icon: "healthicons:hazardous", color: theme.palette.error.main }) })
106
- }
107
- );
108
- }
109
- return /* @__PURE__ */ jsx(
85
+ return ["trivial", "recon", "attempt", "compromise", "mitigated"].includes(n[0]) ? /* @__PURE__ */ s(
110
86
  "span",
111
87
  {
112
- ref: anchorRef,
88
+ ref: c,
113
89
  style: { display: "flex" },
114
- onMouseOver: disableTooltip ? void 0 : () => showInfo("assessment", anchorRef.current, value, { content: tooltipContent }),
115
- onMouseLeave: disableTooltip ? void 0 : () => closeInfo("assessment", value),
116
- children: /* @__PURE__ */ jsx(Tooltip, { disableInteractive: true, componentsProps: tooltipProps, open: showTooltip, title: tooltipContent, children: /* @__PURE__ */ jsx(CountBadge, { disabled: !counters, count: popularAssessment[1], children: /* @__PURE__ */ jsx(Icon, { fontSize: "1.5em", ...otherProps, icon: "fluent-mdl2:ribbon-solid", color: theme.palette.success.main }) }) })
90
+ onMouseOver: r ? void 0 : () => g("assessment", c.current, i, { content: a }),
91
+ onMouseLeave: r ? void 0 : () => x("assessment", i),
92
+ children: /* @__PURE__ */ s(z, { disabled: !f, color: "error", count: n[1], children: /* @__PURE__ */ s(l, { fontSize: "1.5em", ...v, icon: "healthicons:hazardous", color: o.palette.error.main }) })
93
+ }
94
+ ) : /* @__PURE__ */ s(
95
+ "span",
96
+ {
97
+ ref: c,
98
+ style: { display: "flex" },
99
+ onMouseOver: r ? void 0 : () => g("assessment", c.current, i, { content: a }),
100
+ onMouseLeave: r ? void 0 : () => x("assessment", i),
101
+ children: /* @__PURE__ */ s(A, { disableInteractive: !0, componentsProps: M, open: $, title: a, children: /* @__PURE__ */ s(z, { disabled: !f, count: n[1], children: /* @__PURE__ */ s(l, { fontSize: "1.5em", ...v, icon: "fluent-mdl2:ribbon-solid", color: o.palette.success.main }) }) })
117
102
  }
118
103
  );
119
- };
120
- const AssessmentIcon$1 = memo(AssessmentIcon);
104
+ }, ee = D(H);
121
105
  export {
122
- AssessmentIcon$1 as default
106
+ ee as default
123
107
  };
package/icons/Context.js CHANGED
@@ -1,86 +1,72 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { I as Icon } from "../iconify-CXMreGTg.js";
3
- import { Stack, Divider } from "@mui/material";
4
- import AnnotationEntry from "../components/AnnotationEntry.js";
5
- import CountBadge from "../components/CountBadge.js";
6
- import Iconified from "../components/display/icons/Iconified.js";
7
- import { C as CluePopupContext } from "../AnnotationPreview-CLMVD6Ec.js";
8
- import { g as groupBy } from "../groupBy-ChDRT7uy.js";
9
- import { memo, useRef, useMemo, useEffect } from "react";
10
- import { u as useContextSelector } from "../index-AMfoEg_6.js";
11
- const ContextIcon = ({
12
- annotations,
13
- value,
14
- counters = true,
15
- disableTooltip = false,
16
- showExtraIcon = false,
17
- ubiquitous = false,
18
- ...otherProps
1
+ import { jsx as o } from "react/jsx-runtime";
2
+ import { I as w } from "../iconify-BBckr5AQ.js";
3
+ import { Stack as u, Divider as z } from "@mui/material";
4
+ import v from "../components/AnnotationEntry.js";
5
+ import E from "../components/CountBadge.js";
6
+ import M from "../components/display/icons/Iconified.js";
7
+ import { C as x } from "../AnnotationPreview-BGqlBBcp.js";
8
+ import { g as O } from "../groupBy-yNrpdipq.js";
9
+ import { memo as j, useRef as k, useMemo as h, useEffect as B } from "react";
10
+ import { u as g } from "../index-Dj5C04IX.js";
11
+ const R = ({
12
+ annotations: l,
13
+ value: c,
14
+ counters: y = !0,
15
+ disableTooltip: n = !1,
16
+ showExtraIcon: I = !1,
17
+ ubiquitous: m = !1,
18
+ ...r
19
19
  }) => {
20
- const showInfo = useContextSelector(CluePopupContext, (state) => state.showInfo);
21
- const closeInfo = useContextSelector(CluePopupContext, (state) => state.closeInfo);
22
- const anchorRef = useRef();
23
- const contextAnnotations = useMemo(
24
- () => annotations.filter((annotation) => annotation.type === "context" && annotation.ubiquitous === ubiquitous),
25
- [annotations, ubiquitous]
20
+ const C = g(x, (e) => e.showInfo), p = g(x, (e) => e.closeInfo), a = k(), t = h(
21
+ () => l.filter((e) => e.type === "context" && e.ubiquitous === m),
22
+ [l, m]
23
+ ), s = h(
24
+ () => t.filter((e) => e.icon || e.analytic_icon),
25
+ [t]
26
26
  );
27
- const additionalIcons = useMemo(
28
- () => contextAnnotations.filter((annotation) => annotation.icon || annotation.analytic_icon),
29
- [contextAnnotations]
30
- );
31
- useEffect(() => {
32
- if (disableTooltip) {
33
- closeInfo("context", value);
34
- }
35
- }, [disableTooltip]);
36
- if ((contextAnnotations == null ? void 0 : contextAnnotations.length) < 1) {
27
+ if (B(() => {
28
+ n && p("context", c);
29
+ }, [n]), (t == null ? void 0 : t.length) < 1)
37
30
  return null;
38
- }
39
- const icons = [];
40
- if (additionalIcons.length) {
41
- Object.entries(groupBy(additionalIcons, (annotation) => annotation.icon || annotation.analytic_icon)).forEach(
42
- ([icon, _annotations]) => icons.push(
43
- /* @__PURE__ */ jsx(
44
- "span",
45
- {
46
- ref: anchorRef,
47
- style: { display: "flex" },
48
- onMouseOver: disableTooltip ? void 0 : () => showInfo("context", anchorRef.current, value, {
49
- content: /* @__PURE__ */ jsx(
50
- Stack,
51
- {
52
- onClick: (e) => e.stopPropagation(),
53
- spacing: 1,
54
- divider: /* @__PURE__ */ jsx(Divider, { flexItem: true, orientation: "horizontal" }),
55
- children: _annotations.map((annotation) => /* @__PURE__ */ jsx(AnnotationEntry, { annotation }, JSON.stringify(annotation)))
56
- }
57
- )
58
- }),
59
- onMouseLeave: disableTooltip ? void 0 : () => closeInfo("context", value),
60
- children: /* @__PURE__ */ jsx(
61
- Icon,
31
+ const f = [];
32
+ s.length && Object.entries(O(s, (e) => e.icon || e.analytic_icon)).forEach(
33
+ ([e, S]) => f.push(
34
+ /* @__PURE__ */ o(
35
+ "span",
36
+ {
37
+ ref: a,
38
+ style: { display: "flex" },
39
+ onMouseOver: n ? void 0 : () => C("context", a.current, c, {
40
+ content: /* @__PURE__ */ o(
41
+ u,
62
42
  {
63
- icon,
64
- fontSize: otherProps.fontSize ?? "1.25em",
65
- style: { filter: "drop-shadow(0px 0px 1px rgb(0 0 0 / 0.4))", ...otherProps.style ?? {} },
66
- ...otherProps
43
+ onClick: (i) => i.stopPropagation(),
44
+ spacing: 1,
45
+ divider: /* @__PURE__ */ o(z, { flexItem: !0, orientation: "horizontal" }),
46
+ children: S.map((i) => /* @__PURE__ */ o(v, { annotation: i }, JSON.stringify(i)))
67
47
  }
68
48
  )
69
- },
70
- icon
71
- )
49
+ }),
50
+ onMouseLeave: n ? void 0 : () => p("context", c),
51
+ children: /* @__PURE__ */ o(
52
+ w,
53
+ {
54
+ icon: e,
55
+ fontSize: r.fontSize ?? "1.25em",
56
+ style: { filter: "drop-shadow(0px 0px 1px rgb(0 0 0 / 0.4))", ...r.style ?? {} },
57
+ ...r
58
+ }
59
+ )
60
+ },
61
+ e
72
62
  )
73
- );
74
- }
75
- const additionalSize = contextAnnotations.length - additionalIcons.length;
76
- if (additionalSize > 0 && showExtraIcon) {
77
- icons.push(
78
- /* @__PURE__ */ jsx(CountBadge, { disabled: !counters, count: additionalSize, children: /* @__PURE__ */ jsx(Iconified, { icon: "ic:baseline-newspaper", style: { zIndex: 2, ...otherProps.style ?? {} } }) }, "extra")
79
- );
80
- }
81
- return /* @__PURE__ */ jsx(Stack, { direction: "row", spacing: 1, children: icons });
82
- };
83
- const ContextIcon$1 = memo(ContextIcon);
63
+ )
64
+ );
65
+ const d = t.length - s.length;
66
+ return d > 0 && I && f.push(
67
+ /* @__PURE__ */ o(E, { disabled: !y, count: d, children: /* @__PURE__ */ o(M, { icon: "ic:baseline-newspaper", style: { zIndex: 2, ...r.style ?? {} } }) }, "extra")
68
+ ), /* @__PURE__ */ o(u, { direction: "row", spacing: 1, children: f });
69
+ }, G = j(R);
84
70
  export {
85
- ContextIcon$1 as default
71
+ G as default
86
72
  };