@parca/profile 0.19.140 → 0.19.142

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 (253) hide show
  1. package/CHANGELOG.md +5 -1
  2. package/dist/GraphTooltipArrow/Content.js +224 -30
  3. package/dist/GraphTooltipArrow/DockedGraphTooltip/index.js +192 -33
  4. package/dist/GraphTooltipArrow/ExpandOnHoverValue.js +53 -3
  5. package/dist/GraphTooltipArrow/index.d.ts.map +1 -1
  6. package/dist/GraphTooltipArrow/index.js +86 -56
  7. package/dist/GraphTooltipArrow/useGraphTooltip/index.js +37 -37
  8. package/dist/GraphTooltipArrow/useGraphTooltipMetaInfo/index.d.ts.map +1 -1
  9. package/dist/GraphTooltipArrow/useGraphTooltipMetaInfo/index.js +104 -72
  10. package/dist/MatchersInput/SuggestionItem.js +91 -12
  11. package/dist/MatchersInput/SuggestionsList.d.ts +2 -1
  12. package/dist/MatchersInput/SuggestionsList.d.ts.map +1 -1
  13. package/dist/MatchersInput/SuggestionsList.js +371 -157
  14. package/dist/MatchersInput/SuggestionsList.test.d.ts +2 -0
  15. package/dist/MatchersInput/SuggestionsList.test.d.ts.map +1 -0
  16. package/dist/MatchersInput/index.js +308 -115
  17. package/dist/MetricsCircle/index.js +39 -3
  18. package/dist/MetricsGraph/MetricsContextMenu/index.js +119 -19
  19. package/dist/MetricsGraph/MetricsInfoPanel/index.js +81 -20
  20. package/dist/MetricsGraph/MetricsTooltip/index.d.ts.map +1 -1
  21. package/dist/MetricsGraph/MetricsTooltip/index.js +107 -74
  22. package/dist/MetricsGraph/index.js +552 -203
  23. package/dist/MetricsGraph/useMetricsGraphDimensions.js +46 -25
  24. package/dist/MetricsGraph/utils/colorMapping.js +24 -17
  25. package/dist/MetricsSeries/index.js +70 -7
  26. package/dist/PreSelectedMatchers/index.d.ts.map +1 -1
  27. package/dist/PreSelectedMatchers/index.js +249 -102
  28. package/dist/ProfileExplorer/ProfileExplorerCompare.d.ts.map +1 -1
  29. package/dist/ProfileExplorer/ProfileExplorerCompare.js +241 -45
  30. package/dist/ProfileExplorer/ProfileExplorerSingle.js +98 -11
  31. package/dist/ProfileExplorer/index.js +183 -32
  32. package/dist/ProfileFlameChart/SamplesStrips/SamplesGraph/index.js +333 -148
  33. package/dist/ProfileFlameChart/SamplesStrips/SamplesStrips.stories.js +69 -35
  34. package/dist/ProfileFlameChart/SamplesStrips/index.d.ts +2 -2
  35. package/dist/ProfileFlameChart/SamplesStrips/index.d.ts.map +1 -1
  36. package/dist/ProfileFlameChart/SamplesStrips/index.js +645 -134
  37. package/dist/ProfileFlameChart/SamplesStrips/labelSetUtils.js +114 -55
  38. package/dist/ProfileFlameChart/index.d.ts.map +1 -1
  39. package/dist/ProfileFlameChart/index.js +267 -129
  40. package/dist/ProfileFlameGraph/FlameGraphArrow/ContextMenu.d.ts.map +1 -1
  41. package/dist/ProfileFlameGraph/FlameGraphArrow/ContextMenu.js +288 -89
  42. package/dist/ProfileFlameGraph/FlameGraphArrow/ContextMenuWrapper.js +56 -20
  43. package/dist/ProfileFlameGraph/FlameGraphArrow/FlameGraphNodes.js +211 -140
  44. package/dist/ProfileFlameGraph/FlameGraphArrow/MemoizedTooltip.js +133 -38
  45. package/dist/ProfileFlameGraph/FlameGraphArrow/MiniMap.js +261 -216
  46. package/dist/ProfileFlameGraph/FlameGraphArrow/TextWithEllipsis.d.ts.map +1 -1
  47. package/dist/ProfileFlameGraph/FlameGraphArrow/TextWithEllipsis.js +72 -47
  48. package/dist/ProfileFlameGraph/FlameGraphArrow/TooltipContext.d.ts.map +1 -1
  49. package/dist/ProfileFlameGraph/FlameGraphArrow/TooltipContext.js +58 -28
  50. package/dist/ProfileFlameGraph/FlameGraphArrow/ZoomControls.d.ts.map +1 -1
  51. package/dist/ProfileFlameGraph/FlameGraphArrow/ZoomControls.js +59 -8
  52. package/dist/ProfileFlameGraph/FlameGraphArrow/index.js +396 -179
  53. package/dist/ProfileFlameGraph/FlameGraphArrow/useBatchedRendering.d.ts.map +1 -1
  54. package/dist/ProfileFlameGraph/FlameGraphArrow/useBatchedRendering.js +68 -50
  55. package/dist/ProfileFlameGraph/FlameGraphArrow/useMappingList.js +62 -38
  56. package/dist/ProfileFlameGraph/FlameGraphArrow/useNodeColor.js +14 -6
  57. package/dist/ProfileFlameGraph/FlameGraphArrow/useScrollViewport.js +124 -82
  58. package/dist/ProfileFlameGraph/FlameGraphArrow/useVisibleNodes.js +160 -98
  59. package/dist/ProfileFlameGraph/FlameGraphArrow/useZoom.js +232 -112
  60. package/dist/ProfileFlameGraph/FlameGraphArrow/utils.js +137 -114
  61. package/dist/ProfileFlameGraph/benchmarks/benchdata/populateData.js +85 -0
  62. package/dist/ProfileFlameGraph/index.d.ts.map +1 -1
  63. package/dist/ProfileFlameGraph/index.js +324 -150
  64. package/dist/ProfileMetricsGraph/hooks/useQueryRange.js +140 -32
  65. package/dist/ProfileMetricsGraph/index.d.ts.map +1 -1
  66. package/dist/ProfileMetricsGraph/index.js +519 -258
  67. package/dist/ProfileSelector/CompareButton.js +132 -12
  68. package/dist/ProfileSelector/MetricsGraphSection.d.ts.map +1 -1
  69. package/dist/ProfileSelector/MetricsGraphSection.js +236 -64
  70. package/dist/ProfileSelector/index.d.ts.map +1 -1
  71. package/dist/ProfileSelector/index.js +727 -141
  72. package/dist/ProfileSelector/useAutoQuerySelector.js +249 -130
  73. package/dist/ProfileSource.js +230 -163
  74. package/dist/ProfileTypeSelector/index.js +214 -125
  75. package/dist/ProfileView/components/ActionButtons/GroupByDropdown.js +50 -4
  76. package/dist/ProfileView/components/ActionButtons/SortByDropdown.d.ts.map +1 -1
  77. package/dist/ProfileView/components/ActionButtons/SortByDropdown.js +141 -35
  78. package/dist/ProfileView/components/ColorStackLegend.d.ts.map +1 -1
  79. package/dist/ProfileView/components/ColorStackLegend.js +185 -55
  80. package/dist/ProfileView/components/DashboardItems/index.js +87 -28
  81. package/dist/ProfileView/components/DashboardLayout/index.js +108 -16
  82. package/dist/ProfileView/components/DiffLegend.js +172 -29
  83. package/dist/ProfileView/components/GroupByLabelsDropdown/index.js +199 -55
  84. package/dist/ProfileView/components/InvertCallStack/index.d.ts.map +1 -1
  85. package/dist/ProfileView/components/InvertCallStack/index.js +100 -12
  86. package/dist/ProfileView/components/ProfileFilters/filterPresets.js +260 -315
  87. package/dist/ProfileView/components/ProfileFilters/index.js +518 -215
  88. package/dist/ProfileView/components/ProfileFilters/useProfileFilters.js +370 -306
  89. package/dist/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.d.ts +2 -1
  90. package/dist/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.d.ts.map +1 -1
  91. package/dist/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.js +188 -118
  92. package/dist/ProfileView/components/ProfileHeader/index.js +105 -11
  93. package/dist/ProfileView/components/ShareButton/ResultBox.js +119 -16
  94. package/dist/ProfileView/components/ShareButton/index.js +352 -62
  95. package/dist/ProfileView/components/Toolbars/MultiLevelDropdown.d.ts.map +1 -1
  96. package/dist/ProfileView/components/Toolbars/MultiLevelDropdown.js +678 -194
  97. package/dist/ProfileView/components/Toolbars/SwitchMenuItem.js +94 -7
  98. package/dist/ProfileView/components/Toolbars/TableColumnsDropdown.d.ts.map +1 -1
  99. package/dist/ProfileView/components/Toolbars/TableColumnsDropdown.js +199 -157
  100. package/dist/ProfileView/components/Toolbars/index.d.ts +2 -2
  101. package/dist/ProfileView/components/Toolbars/index.d.ts.map +1 -1
  102. package/dist/ProfileView/components/Toolbars/index.js +441 -21
  103. package/dist/ProfileView/components/ViewSelector/Dropdown.js +233 -22
  104. package/dist/ProfileView/components/ViewSelector/index.d.ts.map +1 -1
  105. package/dist/ProfileView/components/ViewSelector/index.js +212 -86
  106. package/dist/ProfileView/components/VisualizationContainer/index.d.ts.map +1 -1
  107. package/dist/ProfileView/components/VisualizationContainer/index.js +52 -7
  108. package/dist/ProfileView/components/VisualizationPanel.js +185 -8
  109. package/dist/ProfileView/context/DashboardContext.d.ts.map +1 -1
  110. package/dist/ProfileView/context/DashboardContext.js +85 -29
  111. package/dist/ProfileView/context/ProfileViewContext.js +56 -15
  112. package/dist/ProfileView/hooks/useAutoSelectDimension.js +71 -41
  113. package/dist/ProfileView/hooks/useProfileMetadata.js +50 -18
  114. package/dist/ProfileView/hooks/useResetFlameGraphState.d.ts.map +1 -1
  115. package/dist/ProfileView/hooks/useResetFlameGraphState.js +32 -12
  116. package/dist/ProfileView/hooks/useResetStateOnProfileTypeChange.d.ts.map +1 -1
  117. package/dist/ProfileView/hooks/useResetStateOnProfileTypeChange.js +71 -27
  118. package/dist/ProfileView/hooks/useResetStateOnSeriesChange.d.ts.map +1 -1
  119. package/dist/ProfileView/hooks/useResetStateOnSeriesChange.js +40 -19
  120. package/dist/ProfileView/hooks/useVisualizationState.d.ts +3 -3
  121. package/dist/ProfileView/hooks/useVisualizationState.d.ts.map +1 -1
  122. package/dist/ProfileView/hooks/useVisualizationState.js +258 -67
  123. package/dist/ProfileView/index.js +383 -45
  124. package/dist/ProfileView/types/visualization.js +1 -13
  125. package/dist/ProfileView/utils/colorUtils.js +8 -7
  126. package/dist/ProfileViewWithData.d.ts.map +1 -1
  127. package/dist/ProfileViewWithData.js +332 -228
  128. package/dist/QueryControls/index.js +418 -47
  129. package/dist/Sandwich/components/CalleesSection.js +54 -4
  130. package/dist/Sandwich/components/CallersSection.js +97 -27
  131. package/dist/Sandwich/components/TableSection.js +77 -4
  132. package/dist/Sandwich/index.d.ts.map +1 -1
  133. package/dist/Sandwich/index.js +126 -14
  134. package/dist/Sandwich/utils/processRowData.js +48 -39
  135. package/dist/SelectWithRefresh/index.js +102 -28
  136. package/dist/SimpleMatchers/Select.js +520 -187
  137. package/dist/SimpleMatchers/index.js +590 -288
  138. package/dist/SourceView/Highlighter.js +230 -70
  139. package/dist/SourceView/LineNo.js +72 -17
  140. package/dist/SourceView/index.d.ts.map +1 -1
  141. package/dist/SourceView/index.js +178 -104
  142. package/dist/SourceView/lang-detector/ext-to-lang.json +798 -798
  143. package/dist/SourceView/lang-detector/index.js +28 -14
  144. package/dist/SourceView/useSelectedLineRange.d.ts.map +1 -1
  145. package/dist/SourceView/useSelectedLineRange.js +99 -23
  146. package/dist/Table/ColorCell.js +42 -1
  147. package/dist/Table/ColumnsVisibility.js +114 -6
  148. package/dist/Table/MoreDropdown.d.ts.map +1 -1
  149. package/dist/Table/MoreDropdown.js +122 -25
  150. package/dist/Table/TableContextMenu.d.ts.map +1 -1
  151. package/dist/Table/TableContextMenu.js +151 -137
  152. package/dist/Table/TableContextMenuWrapper.js +59 -14
  153. package/dist/Table/hooks/useColorManagement.js +58 -16
  154. package/dist/Table/hooks/useTableConfiguration.d.ts.map +1 -1
  155. package/dist/Table/hooks/useTableConfiguration.js +333 -169
  156. package/dist/Table/index.d.ts.map +1 -1
  157. package/dist/Table/index.js +222 -128
  158. package/dist/Table/utils/functions.js +169 -144
  159. package/dist/Table/utils/topAndBottomExpandedRowModel.js +69 -52
  160. package/dist/TimelineGuide/index.js +209 -16
  161. package/dist/TopTable/benchmarks/benchdata/populateData.js +91 -0
  162. package/dist/TopTable/index.d.ts.map +1 -1
  163. package/dist/TopTable/index.js +342 -123
  164. package/dist/contexts/LabelsQueryProvider.js +94 -32
  165. package/dist/contexts/UnifiedLabelsContext.js +114 -49
  166. package/dist/contexts/utils.js +37 -15
  167. package/dist/hooks/useCompareModeMeta.d.ts.map +1 -1
  168. package/dist/hooks/useCompareModeMeta.js +158 -64
  169. package/dist/hooks/useLabels.js +295 -52
  170. package/dist/hooks/useQueryState.d.ts +3 -3
  171. package/dist/hooks/useQueryState.d.ts.map +1 -1
  172. package/dist/hooks/useQueryState.js +373 -332
  173. package/dist/index.d.ts +2 -3
  174. package/dist/index.d.ts.map +1 -1
  175. package/dist/index.js +22 -8
  176. package/dist/testdata/fg-diff.json +3750 -0
  177. package/dist/testdata/fg-simple.json +1879 -0
  178. package/dist/testdata/link_data.json +56 -0
  179. package/dist/testdata/tabular.json +30 -0
  180. package/dist/testdata/test_flamegraph.json +26846 -0
  181. package/dist/testdata/test_graph.json +53 -0
  182. package/dist/useDelayedLoader.js +32 -18
  183. package/dist/useGrpcQuery/index.js +71 -11
  184. package/dist/useHasProfileData.js +90 -12
  185. package/dist/useQuery.js +205 -64
  186. package/dist/useSumBy.d.ts +1 -1
  187. package/dist/useSumBy.d.ts.map +1 -1
  188. package/dist/useSumBy.js +294 -138
  189. package/dist/utils.js +62 -30
  190. package/package.json +9 -10
  191. package/src/GraphTooltipArrow/index.tsx +3 -0
  192. package/src/GraphTooltipArrow/useGraphTooltipMetaInfo/index.ts +13 -11
  193. package/src/MatchersInput/SuggestionsList.test.tsx +70 -0
  194. package/src/MatchersInput/SuggestionsList.tsx +11 -10
  195. package/src/MatchersInput/index.tsx +1 -1
  196. package/src/MetricsGraph/MetricsTooltip/index.tsx +22 -34
  197. package/src/PreSelectedMatchers/index.tsx +3 -0
  198. package/src/ProfileExplorer/ProfileExplorerCompare.tsx +9 -4
  199. package/src/ProfileFlameChart/SamplesStrips/index.tsx +2 -2
  200. package/src/ProfileFlameChart/index.tsx +28 -21
  201. package/src/ProfileFlameGraph/FlameGraphArrow/ContextMenu.tsx +9 -10
  202. package/src/ProfileFlameGraph/FlameGraphArrow/TextWithEllipsis.tsx +6 -5
  203. package/src/ProfileFlameGraph/FlameGraphArrow/TooltipContext.tsx +3 -0
  204. package/src/ProfileFlameGraph/FlameGraphArrow/ZoomControls.tsx +3 -0
  205. package/src/ProfileFlameGraph/FlameGraphArrow/useBatchedRendering.ts +3 -0
  206. package/src/ProfileFlameGraph/index.tsx +9 -6
  207. package/src/ProfileMetricsGraph/index.tsx +8 -6
  208. package/src/ProfileSelector/MetricsGraphSection.tsx +10 -5
  209. package/src/ProfileSelector/index.tsx +61 -39
  210. package/src/ProfileView/components/ActionButtons/SortByDropdown.tsx +6 -10
  211. package/src/ProfileView/components/ColorStackLegend.tsx +4 -2
  212. package/src/ProfileView/components/InvertCallStack/index.tsx +4 -5
  213. package/src/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.test.tsx +192 -94
  214. package/src/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.ts +21 -21
  215. package/src/ProfileView/components/Toolbars/MultiLevelDropdown.tsx +28 -24
  216. package/src/ProfileView/components/Toolbars/TableColumnsDropdown.tsx +5 -4
  217. package/src/ProfileView/components/Toolbars/index.tsx +3 -3
  218. package/src/ProfileView/components/ViewSelector/index.tsx +16 -9
  219. package/src/ProfileView/components/VisualizationContainer/index.tsx +3 -0
  220. package/src/ProfileView/context/DashboardContext.tsx +6 -6
  221. package/src/ProfileView/hooks/useResetFlameGraphState.ts +4 -6
  222. package/src/ProfileView/hooks/useResetStateOnProfileTypeChange.ts +26 -24
  223. package/src/ProfileView/hooks/useResetStateOnSeriesChange.ts +8 -16
  224. package/src/ProfileView/hooks/useVisualizationState.ts +69 -61
  225. package/src/ProfileViewWithData.tsx +35 -29
  226. package/src/Sandwich/index.tsx +3 -4
  227. package/src/SourceView/index.tsx +2 -4
  228. package/src/SourceView/useSelectedLineRange.ts +19 -34
  229. package/src/Table/MoreDropdown.tsx +11 -9
  230. package/src/Table/TableContextMenu.tsx +13 -10
  231. package/src/Table/hooks/useTableConfiguration.tsx +11 -16
  232. package/src/Table/index.tsx +21 -12
  233. package/src/TopTable/index.tsx +4 -3
  234. package/src/hooks/useCompareModeMeta.ts +91 -61
  235. package/src/hooks/useQueryState.test.tsx +345 -275
  236. package/src/hooks/useQueryState.ts +118 -136
  237. package/src/index.tsx +15 -16
  238. package/src/useDelayedLoader.ts +10 -10
  239. package/src/useSumBy.ts +15 -21
  240. package/dist/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.test.js +0 -455
  241. package/dist/hooks/urlParsers.d.ts +0 -18
  242. package/dist/hooks/urlParsers.d.ts.map +0 -1
  243. package/dist/hooks/urlParsers.js +0 -32
  244. package/dist/hooks/useColorBy.d.ts +0 -5
  245. package/dist/hooks/useColorBy.d.ts.map +0 -1
  246. package/dist/hooks/useColorBy.js +0 -26
  247. package/dist/hooks/useDashboardItems.d.ts +0 -5
  248. package/dist/hooks/useDashboardItems.d.ts.map +0 -1
  249. package/dist/hooks/useDashboardItems.js +0 -27
  250. package/dist/hooks/useQueryState.test.js +0 -868
  251. package/src/hooks/urlParsers.ts +0 -38
  252. package/src/hooks/useColorBy.ts +0 -42
  253. package/src/hooks/useDashboardItems.ts +0 -46
@@ -1,3 +1,14 @@
1
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
2
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
3
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
4
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
5
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
6
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
7
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
8
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
9
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
10
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
11
+ import { c as _c } from "react-compiler-runtime";
1
12
  // Copyright 2022 The Parca Authors
2
13
  // Licensed under the Apache License, Version 2.0 (the "License");
3
14
  // you may not use this file except in compliance with the License.
@@ -10,79 +21,259 @@
10
21
  // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
22
  // See the License for the specific language governing permissions and
12
23
  // limitations under the License.
24
+
13
25
  import { useCallback, useMemo } from 'react';
14
- import { useQueryState } from 'nuqs';
26
+ import { JSONParser, JSONSerializer, useURLState, useURLStateBatch, useURLStateCustom } from '@parca/components';
15
27
  import { USER_PREFERENCES, useUserPreference } from '@parca/hooks';
16
- import { FIELD_FUNCTION_FILE_NAME, FIELD_FUNCTION_NAME, FIELD_LABELS, FIELD_LOCATION_ADDRESS, FIELD_MAPPING_FILE, } from '../../ProfileFlameGraph/FlameGraphArrow';
17
- import { flamechartDimensionParser, groupByParser, jsonParser, stringParam, } from '../../hooks/urlParsers';
18
- import { useColorBy } from '../../hooks/useColorBy';
28
+ import { FIELD_FUNCTION_FILE_NAME, FIELD_FUNCTION_NAME, FIELD_LABELS, FIELD_LOCATION_ADDRESS, FIELD_MAPPING_FILE } from '../../ProfileFlameGraph/FlameGraphArrow';
19
29
  import { useResetFlameGraphState } from './useResetFlameGraphState';
20
- export const useVisualizationState = () => {
21
- const [alignFunctionNamePreference, setAlignFunctionNamePreference] = useUserPreference(USER_PREFERENCES.ALIGN_FUNCTION_NAME.key);
22
- const [curPathArrow, setRawCurPathArrow] = useQueryState('cur_path', jsonParser().withDefault([]));
23
- const setCurPathArrow = useCallback((path) => {
24
- void setRawCurPathArrow(path);
25
- }, [setRawCurPathArrow]);
26
- const [colorStackLegend] = useQueryState('color_stack_legend', stringParam);
27
- const { colorBy, setColorBy } = useColorBy();
28
- const [alignFunctionNameRaw, setStoreAlignFunctionName] = useQueryState('align_function_name', stringParam);
29
- const alignFunctionName = alignFunctionNameRaw ?? alignFunctionNamePreference ?? 'left';
30
- const [groupBy, setStoreGroupBy] = useQueryState('group_by', groupByParser.withDefault([FIELD_FUNCTION_NAME]));
31
- const [sandwichFunctionName, setRawSandwichFunctionName] = useQueryState('sandwich_function_name', stringParam);
32
- const setSandwichFunctionName = useCallback((name) => {
33
- void setRawSandwichFunctionName(name);
34
- }, [setRawSandwichFunctionName]);
35
- const [flamechartDimension, setStoreFlamechartDimension] = useQueryState('flamechart_dimension', flamechartDimensionParser.withDefault([]));
36
- const resetFlameGraphState = useResetFlameGraphState();
37
- const levelsOfProfiling = useMemo(() => [
38
- FIELD_FUNCTION_NAME,
39
- FIELD_FUNCTION_FILE_NAME,
40
- FIELD_LOCATION_ADDRESS,
41
- FIELD_MAPPING_FILE,
42
- ], []);
43
- const setGroupBy = useCallback((keys) => {
44
- void setStoreGroupBy(keys);
45
- }, [setStoreGroupBy]);
46
- const toggleGroupBy = useCallback((key) => {
30
+ export var useVisualizationState = function useVisualizationState() {
31
+ var _ref, _ref2;
32
+ var $ = _c(47);
33
+ var _useUserPreference = useUserPreference(USER_PREFERENCES.COLOR_BY.key),
34
+ _useUserPreference2 = _slicedToArray(_useUserPreference, 2),
35
+ colorByPreference = _useUserPreference2[0],
36
+ setColorByPreference = _useUserPreference2[1];
37
+ var _useUserPreference3 = useUserPreference(USER_PREFERENCES.ALIGN_FUNCTION_NAME.key),
38
+ _useUserPreference4 = _slicedToArray(_useUserPreference3, 2),
39
+ alignFunctionNamePreference = _useUserPreference4[0],
40
+ setAlignFunctionNamePreference = _useUserPreference4[1];
41
+ var t0;
42
+ if ($[0] === Symbol["for"]("react.memo_cache_sentinel")) {
43
+ t0 = {
44
+ parse: JSONParser,
45
+ stringify: JSONSerializer,
46
+ defaultValue: "[]"
47
+ };
48
+ $[0] = t0;
49
+ } else {
50
+ t0 = $[0];
51
+ }
52
+ var _useURLStateCustom = useURLStateCustom("cur_path", t0),
53
+ _useURLStateCustom2 = _slicedToArray(_useURLStateCustom, 2),
54
+ curPathArrow = _useURLStateCustom2[0],
55
+ setCurPathArrow = _useURLStateCustom2[1];
56
+ var _useURLState = useURLState("color_stack_legend"),
57
+ _useURLState2 = _slicedToArray(_useURLState, 1),
58
+ colorStackLegend = _useURLState2[0];
59
+ var t1;
60
+ if ($[1] !== colorByPreference) {
61
+ t1 = {
62
+ defaultValue: colorByPreference
63
+ };
64
+ $[1] = colorByPreference;
65
+ $[2] = t1;
66
+ } else {
67
+ t1 = $[2];
68
+ }
69
+ var _useURLState3 = useURLState("color_by", t1),
70
+ _useURLState4 = _slicedToArray(_useURLState3, 2),
71
+ colorBy = _useURLState4[0],
72
+ setStoreColorBy = _useURLState4[1];
73
+ var t2;
74
+ if ($[3] !== alignFunctionNamePreference) {
75
+ t2 = {
76
+ defaultValue: alignFunctionNamePreference
77
+ };
78
+ $[3] = alignFunctionNamePreference;
79
+ $[4] = t2;
80
+ } else {
81
+ t2 = $[4];
82
+ }
83
+ var _useURLState5 = useURLState("align_function_name", t2),
84
+ _useURLState6 = _slicedToArray(_useURLState5, 2),
85
+ alignFunctionName = _useURLState6[0],
86
+ setStoreAlignFunctionName = _useURLState6[1];
87
+ var t3;
88
+ if ($[5] === Symbol["for"]("react.memo_cache_sentinel")) {
89
+ t3 = {
90
+ defaultValue: [FIELD_FUNCTION_NAME],
91
+ alwaysReturnArray: true
92
+ };
93
+ $[5] = t3;
94
+ } else {
95
+ t3 = $[5];
96
+ }
97
+ var _useURLState7 = useURLState("group_by", t3),
98
+ _useURLState8 = _slicedToArray(_useURLState7, 2),
99
+ groupBy = _useURLState8[0],
100
+ setStoreGroupBy = _useURLState8[1];
101
+ var _useURLState9 = useURLState("sandwich_function_name"),
102
+ _useURLState0 = _slicedToArray(_useURLState9, 2),
103
+ sandwichFunctionName = _useURLState0[0],
104
+ setSandwichFunctionName = _useURLState0[1];
105
+ var t4;
106
+ if ($[6] === Symbol["for"]("react.memo_cache_sentinel")) {
107
+ t4 = {
108
+ alwaysReturnArray: true
109
+ };
110
+ $[6] = t4;
111
+ } else {
112
+ t4 = $[6];
113
+ }
114
+ var _useURLState1 = useURLState("flamechart_dimension", t4),
115
+ _useURLState10 = _slicedToArray(_useURLState1, 2),
116
+ flamechartDimension = _useURLState10[0],
117
+ setStoreFlamechartDimension = _useURLState10[1];
118
+ var resetFlameGraphState = useResetFlameGraphState();
119
+ var batchUpdates = useURLStateBatch();
120
+ var t5;
121
+ if ($[7] === Symbol["for"]("react.memo_cache_sentinel")) {
122
+ t5 = [FIELD_FUNCTION_NAME, FIELD_FUNCTION_FILE_NAME, FIELD_LOCATION_ADDRESS, FIELD_MAPPING_FILE];
123
+ $[7] = t5;
124
+ } else {
125
+ t5 = $[7];
126
+ }
127
+ var levelsOfProfiling = t5;
128
+ var t6;
129
+ if ($[8] !== setStoreGroupBy) {
130
+ t6 = function t6(keys) {
131
+ setStoreGroupBy(keys);
132
+ };
133
+ $[8] = setStoreGroupBy;
134
+ $[9] = t6;
135
+ } else {
136
+ t6 = $[9];
137
+ }
138
+ var setGroupBy = t6;
139
+ var t7;
140
+ if ($[10] !== batchUpdates || $[11] !== groupBy || $[12] !== resetFlameGraphState || $[13] !== setGroupBy) {
141
+ t7 = function t7(key) {
142
+ batchUpdates(function () {
47
143
  if (groupBy.includes(key)) {
48
- setGroupBy(groupBy.filter(v => v !== key));
49
- }
50
- else {
51
- const filteredGroupBy = groupBy.filter(item => !levelsOfProfiling.includes(item));
52
- setGroupBy([...filteredGroupBy, key]);
144
+ setGroupBy(groupBy.filter(function (v) {
145
+ return v !== key;
146
+ }));
147
+ } else {
148
+ var filteredGroupBy = groupBy.filter(function (item) {
149
+ return !levelsOfProfiling.includes(item);
150
+ });
151
+ setGroupBy([].concat(_toConsumableArray(filteredGroupBy), [key]));
53
152
  }
54
153
  resetFlameGraphState();
55
- }, [groupBy, setGroupBy, levelsOfProfiling, resetFlameGraphState]);
56
- const setGroupByLabels = useCallback((labels) => {
57
- setGroupBy(groupBy.filter(l => !l.startsWith(`${FIELD_LABELS}.`)).concat(labels));
154
+ });
155
+ };
156
+ $[10] = batchUpdates;
157
+ $[11] = groupBy;
158
+ $[12] = resetFlameGraphState;
159
+ $[13] = setGroupBy;
160
+ $[14] = t7;
161
+ } else {
162
+ t7 = $[14];
163
+ }
164
+ var toggleGroupBy = t7;
165
+ var t8;
166
+ if ($[15] !== batchUpdates || $[16] !== groupBy || $[17] !== resetFlameGraphState || $[18] !== setGroupBy) {
167
+ t8 = function t8(labels) {
168
+ batchUpdates(function () {
169
+ setGroupBy(groupBy.filter(_temp).concat(labels));
58
170
  resetFlameGraphState();
59
- }, [groupBy, setGroupBy, resetFlameGraphState]);
60
- const setFlamechartDimension = useCallback((labels) => {
61
- void setStoreFlamechartDimension(labels.filter(l => l.startsWith(`${FIELD_LABELS}.`)));
62
- }, [setStoreFlamechartDimension]);
63
- const resetSandwichFunctionName = useCallback(() => {
64
- setSandwichFunctionName(null);
65
- }, [setSandwichFunctionName]);
66
- const setAlignFunctionName = useCallback((value) => {
67
- void setStoreAlignFunctionName(value);
68
- setAlignFunctionNamePreference(value);
69
- }, [setStoreAlignFunctionName, setAlignFunctionNamePreference]);
70
- return {
71
- curPathArrow,
72
- setCurPathArrow,
73
- colorStackLegend,
74
- colorBy,
75
- setColorBy,
76
- groupBy,
77
- setGroupBy,
78
- toggleGroupBy,
79
- setGroupByLabels,
80
- flamechartDimension,
81
- setFlamechartDimension,
82
- sandwichFunctionName,
83
- setSandwichFunctionName,
84
- resetSandwichFunctionName,
85
- alignFunctionName,
86
- setAlignFunctionName,
171
+ });
172
+ };
173
+ $[15] = batchUpdates;
174
+ $[16] = groupBy;
175
+ $[17] = resetFlameGraphState;
176
+ $[18] = setGroupBy;
177
+ $[19] = t8;
178
+ } else {
179
+ t8 = $[19];
180
+ }
181
+ var setGroupByLabels = t8;
182
+ var t9;
183
+ if ($[20] !== setStoreFlamechartDimension) {
184
+ t9 = function t9(labels_0) {
185
+ setStoreFlamechartDimension(labels_0.filter(_temp2));
186
+ };
187
+ $[20] = setStoreFlamechartDimension;
188
+ $[21] = t9;
189
+ } else {
190
+ t9 = $[21];
191
+ }
192
+ var setFlamechartDimension = t9;
193
+ var t10;
194
+ if ($[22] !== setSandwichFunctionName) {
195
+ t10 = function t10() {
196
+ setSandwichFunctionName(undefined);
197
+ };
198
+ $[22] = setSandwichFunctionName;
199
+ $[23] = t10;
200
+ } else {
201
+ t10 = $[23];
202
+ }
203
+ var resetSandwichFunctionName = t10;
204
+ var t11;
205
+ if ($[24] !== setColorByPreference || $[25] !== setStoreColorBy) {
206
+ t11 = function t11(value) {
207
+ setStoreColorBy(value);
208
+ setColorByPreference(value);
209
+ };
210
+ $[24] = setColorByPreference;
211
+ $[25] = setStoreColorBy;
212
+ $[26] = t11;
213
+ } else {
214
+ t11 = $[26];
215
+ }
216
+ var setColorBy = t11;
217
+ var t12;
218
+ if ($[27] !== setAlignFunctionNamePreference || $[28] !== setStoreAlignFunctionName) {
219
+ t12 = function t12(value_0) {
220
+ setStoreAlignFunctionName(value_0);
221
+ setAlignFunctionNamePreference(value_0);
222
+ };
223
+ $[27] = setAlignFunctionNamePreference;
224
+ $[28] = setStoreAlignFunctionName;
225
+ $[29] = t12;
226
+ } else {
227
+ t12 = $[29];
228
+ }
229
+ var setAlignFunctionName = t12;
230
+ var t13 = (_ref = colorBy) !== null && _ref !== void 0 ? _ref : "";
231
+ var t14 = (_ref2 = alignFunctionName) !== null && _ref2 !== void 0 ? _ref2 : "left";
232
+ var t15;
233
+ if ($[30] !== colorStackLegend || $[31] !== curPathArrow || $[32] !== flamechartDimension || $[33] !== groupBy || $[34] !== resetSandwichFunctionName || $[35] !== sandwichFunctionName || $[36] !== setAlignFunctionName || $[37] !== setColorBy || $[38] !== setCurPathArrow || $[39] !== setFlamechartDimension || $[40] !== setGroupBy || $[41] !== setGroupByLabels || $[42] !== setSandwichFunctionName || $[43] !== t13 || $[44] !== t14 || $[45] !== toggleGroupBy) {
234
+ t15 = {
235
+ curPathArrow: curPathArrow,
236
+ setCurPathArrow: setCurPathArrow,
237
+ colorStackLegend: colorStackLegend,
238
+ colorBy: t13,
239
+ setColorBy: setColorBy,
240
+ groupBy: groupBy,
241
+ setGroupBy: setGroupBy,
242
+ toggleGroupBy: toggleGroupBy,
243
+ setGroupByLabels: setGroupByLabels,
244
+ flamechartDimension: flamechartDimension,
245
+ setFlamechartDimension: setFlamechartDimension,
246
+ sandwichFunctionName: sandwichFunctionName,
247
+ setSandwichFunctionName: setSandwichFunctionName,
248
+ resetSandwichFunctionName: resetSandwichFunctionName,
249
+ alignFunctionName: t14,
250
+ setAlignFunctionName: setAlignFunctionName
87
251
  };
252
+ $[30] = colorStackLegend;
253
+ $[31] = curPathArrow;
254
+ $[32] = flamechartDimension;
255
+ $[33] = groupBy;
256
+ $[34] = resetSandwichFunctionName;
257
+ $[35] = sandwichFunctionName;
258
+ $[36] = setAlignFunctionName;
259
+ $[37] = setColorBy;
260
+ $[38] = setCurPathArrow;
261
+ $[39] = setFlamechartDimension;
262
+ $[40] = setGroupBy;
263
+ $[41] = setGroupByLabels;
264
+ $[42] = setSandwichFunctionName;
265
+ $[43] = t13;
266
+ $[44] = t14;
267
+ $[45] = toggleGroupBy;
268
+ $[46] = t15;
269
+ } else {
270
+ t15 = $[46];
271
+ }
272
+ return t15;
88
273
  };
274
+ function _temp(l) {
275
+ return !l.startsWith("".concat(FIELD_LABELS, "."));
276
+ }
277
+ function _temp2(l_0) {
278
+ return l_0.startsWith("".concat(FIELD_LABELS, "."));
279
+ }