@parca/profile 0.19.139 → 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.
- package/CHANGELOG.md +8 -0
- package/dist/GraphTooltipArrow/Content.js +224 -30
- package/dist/GraphTooltipArrow/DockedGraphTooltip/index.js +192 -33
- package/dist/GraphTooltipArrow/ExpandOnHoverValue.js +53 -3
- package/dist/GraphTooltipArrow/index.d.ts.map +1 -1
- package/dist/GraphTooltipArrow/index.js +86 -56
- package/dist/GraphTooltipArrow/useGraphTooltip/index.js +37 -37
- package/dist/GraphTooltipArrow/useGraphTooltipMetaInfo/index.js +103 -73
- package/dist/MatchersInput/SuggestionItem.js +91 -12
- package/dist/MatchersInput/SuggestionsList.d.ts +2 -1
- package/dist/MatchersInput/SuggestionsList.d.ts.map +1 -1
- package/dist/MatchersInput/SuggestionsList.js +371 -157
- package/dist/MatchersInput/SuggestionsList.test.d.ts +2 -0
- package/dist/MatchersInput/SuggestionsList.test.d.ts.map +1 -0
- package/dist/MatchersInput/index.js +308 -115
- package/dist/MetricsCircle/index.js +39 -3
- package/dist/MetricsGraph/MetricsContextMenu/index.js +119 -19
- package/dist/MetricsGraph/MetricsInfoPanel/index.js +81 -20
- package/dist/MetricsGraph/MetricsTooltip/index.d.ts.map +1 -1
- package/dist/MetricsGraph/MetricsTooltip/index.js +107 -74
- package/dist/MetricsGraph/index.js +552 -203
- package/dist/MetricsGraph/useMetricsGraphDimensions.js +46 -25
- package/dist/MetricsGraph/utils/colorMapping.js +24 -17
- package/dist/MetricsSeries/index.js +70 -7
- package/dist/PreSelectedMatchers/index.d.ts.map +1 -1
- package/dist/PreSelectedMatchers/index.js +249 -102
- package/dist/ProfileExplorer/ProfileExplorerCompare.js +240 -49
- package/dist/ProfileExplorer/ProfileExplorerSingle.js +98 -11
- package/dist/ProfileExplorer/index.js +183 -32
- package/dist/ProfileFlameChart/SamplesStrips/SamplesGraph/index.js +333 -148
- package/dist/ProfileFlameChart/SamplesStrips/SamplesStrips.stories.js +69 -35
- package/dist/ProfileFlameChart/SamplesStrips/index.js +645 -134
- package/dist/ProfileFlameChart/SamplesStrips/labelSetUtils.js +114 -55
- package/dist/ProfileFlameChart/index.js +266 -134
- package/dist/ProfileFlameGraph/FlameGraphArrow/ContextMenu.js +287 -88
- package/dist/ProfileFlameGraph/FlameGraphArrow/ContextMenuWrapper.js +56 -20
- package/dist/ProfileFlameGraph/FlameGraphArrow/FlameGraphNodes.js +211 -140
- package/dist/ProfileFlameGraph/FlameGraphArrow/MemoizedTooltip.js +133 -38
- package/dist/ProfileFlameGraph/FlameGraphArrow/MiniMap.js +261 -216
- package/dist/ProfileFlameGraph/FlameGraphArrow/TextWithEllipsis.d.ts.map +1 -1
- package/dist/ProfileFlameGraph/FlameGraphArrow/TextWithEllipsis.js +71 -45
- package/dist/ProfileFlameGraph/FlameGraphArrow/TooltipContext.d.ts.map +1 -1
- package/dist/ProfileFlameGraph/FlameGraphArrow/TooltipContext.js +58 -28
- package/dist/ProfileFlameGraph/FlameGraphArrow/ZoomControls.d.ts.map +1 -1
- package/dist/ProfileFlameGraph/FlameGraphArrow/ZoomControls.js +59 -8
- package/dist/ProfileFlameGraph/FlameGraphArrow/index.js +396 -179
- package/dist/ProfileFlameGraph/FlameGraphArrow/useBatchedRendering.d.ts.map +1 -1
- package/dist/ProfileFlameGraph/FlameGraphArrow/useBatchedRendering.js +68 -50
- package/dist/ProfileFlameGraph/FlameGraphArrow/useMappingList.js +62 -38
- package/dist/ProfileFlameGraph/FlameGraphArrow/useNodeColor.js +14 -6
- package/dist/ProfileFlameGraph/FlameGraphArrow/useScrollViewport.js +124 -82
- package/dist/ProfileFlameGraph/FlameGraphArrow/useVisibleNodes.js +160 -98
- package/dist/ProfileFlameGraph/FlameGraphArrow/useZoom.js +232 -112
- package/dist/ProfileFlameGraph/FlameGraphArrow/utils.js +137 -114
- package/dist/ProfileFlameGraph/benchmarks/benchdata/populateData.js +85 -0
- package/dist/ProfileFlameGraph/index.js +324 -148
- package/dist/ProfileMetricsGraph/hooks/useQueryRange.js +140 -32
- package/dist/ProfileMetricsGraph/index.js +518 -259
- package/dist/ProfileSelector/CompareButton.js +132 -12
- package/dist/ProfileSelector/MetricsGraphSection.js +234 -67
- package/dist/ProfileSelector/index.d.ts.map +1 -1
- package/dist/ProfileSelector/index.js +730 -142
- package/dist/ProfileSelector/useAutoQuerySelector.js +249 -130
- package/dist/ProfileSource.js +230 -163
- package/dist/ProfileTypeSelector/index.js +214 -125
- package/dist/ProfileView/components/ActionButtons/GroupByDropdown.js +50 -4
- package/dist/ProfileView/components/ActionButtons/SortByDropdown.js +139 -33
- package/dist/ProfileView/components/ColorStackLegend.js +184 -55
- package/dist/ProfileView/components/DashboardItems/index.js +87 -28
- package/dist/ProfileView/components/DashboardLayout/index.js +108 -16
- package/dist/ProfileView/components/DiffLegend.js +172 -29
- package/dist/ProfileView/components/GroupByLabelsDropdown/index.js +199 -55
- package/dist/ProfileView/components/InvertCallStack/index.js +99 -10
- package/dist/ProfileView/components/ProfileFilters/filterPresets.js +260 -315
- package/dist/ProfileView/components/ProfileFilters/index.js +518 -215
- package/dist/ProfileView/components/ProfileFilters/useProfileFilters.js +370 -306
- package/dist/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.js +188 -120
- package/dist/ProfileView/components/ProfileHeader/index.js +105 -11
- package/dist/ProfileView/components/ShareButton/ResultBox.js +119 -16
- package/dist/ProfileView/components/ShareButton/index.js +352 -62
- package/dist/ProfileView/components/Toolbars/MultiLevelDropdown.d.ts.map +1 -1
- package/dist/ProfileView/components/Toolbars/MultiLevelDropdown.js +675 -195
- package/dist/ProfileView/components/Toolbars/SwitchMenuItem.js +94 -7
- package/dist/ProfileView/components/Toolbars/TableColumnsDropdown.js +198 -157
- package/dist/ProfileView/components/Toolbars/index.js +441 -21
- package/dist/ProfileView/components/ViewSelector/Dropdown.js +233 -22
- package/dist/ProfileView/components/ViewSelector/index.js +211 -91
- package/dist/ProfileView/components/VisualizationContainer/index.d.ts.map +1 -1
- package/dist/ProfileView/components/VisualizationContainer/index.js +52 -7
- package/dist/ProfileView/components/VisualizationPanel.js +185 -8
- package/dist/ProfileView/context/DashboardContext.js +84 -28
- package/dist/ProfileView/context/ProfileViewContext.js +56 -15
- package/dist/ProfileView/hooks/useAutoSelectDimension.js +71 -41
- package/dist/ProfileView/hooks/useProfileMetadata.js +50 -18
- package/dist/ProfileView/hooks/useResetFlameGraphState.js +31 -10
- package/dist/ProfileView/hooks/useResetStateOnProfileTypeChange.js +72 -29
- package/dist/ProfileView/hooks/useResetStateOnSeriesChange.js +39 -13
- package/dist/ProfileView/hooks/useVisualizationState.js +262 -87
- package/dist/ProfileView/index.js +383 -45
- package/dist/ProfileView/types/visualization.js +1 -13
- package/dist/ProfileView/utils/colorUtils.js +8 -7
- package/dist/ProfileViewWithData.js +332 -237
- package/dist/QueryControls/index.js +418 -47
- package/dist/Sandwich/components/CalleesSection.js +54 -4
- package/dist/Sandwich/components/CallersSection.js +97 -27
- package/dist/Sandwich/components/TableSection.js +77 -4
- package/dist/Sandwich/index.js +125 -12
- package/dist/Sandwich/utils/processRowData.js +48 -39
- package/dist/SelectWithRefresh/index.js +102 -28
- package/dist/SimpleMatchers/Select.js +520 -187
- package/dist/SimpleMatchers/index.js +590 -288
- package/dist/SourceView/Highlighter.js +230 -70
- package/dist/SourceView/LineNo.js +72 -17
- package/dist/SourceView/index.js +177 -101
- package/dist/SourceView/lang-detector/ext-to-lang.json +798 -798
- package/dist/SourceView/lang-detector/index.js +28 -14
- package/dist/SourceView/useSelectedLineRange.js +97 -16
- package/dist/Table/ColorCell.js +42 -1
- package/dist/Table/ColumnsVisibility.js +114 -6
- package/dist/Table/MoreDropdown.js +121 -27
- package/dist/Table/TableContextMenu.js +150 -139
- package/dist/Table/TableContextMenuWrapper.js +59 -14
- package/dist/Table/hooks/useColorManagement.js +58 -16
- package/dist/Table/hooks/useTableConfiguration.d.ts.map +1 -1
- package/dist/Table/hooks/useTableConfiguration.js +331 -168
- package/dist/Table/index.js +222 -126
- package/dist/Table/utils/functions.js +169 -144
- package/dist/Table/utils/topAndBottomExpandedRowModel.js +69 -52
- package/dist/TimelineGuide/index.js +209 -16
- package/dist/TopTable/benchmarks/benchdata/populateData.js +91 -0
- package/dist/TopTable/index.js +340 -122
- package/dist/contexts/LabelsQueryProvider.js +94 -32
- package/dist/contexts/UnifiedLabelsContext.js +114 -49
- package/dist/contexts/utils.js +37 -15
- package/dist/hooks/useCompareModeMeta.js +157 -94
- package/dist/hooks/useLabels.js +295 -52
- package/dist/hooks/useQueryState.js +371 -330
- package/dist/index.js +21 -16
- package/dist/testdata/fg-diff.json +3750 -0
- package/dist/testdata/fg-simple.json +1879 -0
- package/dist/testdata/link_data.json +56 -0
- package/dist/testdata/tabular.json +30 -0
- package/dist/testdata/test_flamegraph.json +26846 -0
- package/dist/testdata/test_graph.json +53 -0
- package/dist/useDelayedLoader.js +32 -18
- package/dist/useGrpcQuery/index.js +71 -11
- package/dist/useHasProfileData.js +90 -12
- package/dist/useQuery.js +205 -64
- package/dist/useSumBy.d.ts.map +1 -1
- package/dist/useSumBy.js +294 -138
- package/dist/utils.js +62 -30
- package/package.json +9 -9
- package/src/GraphTooltipArrow/index.tsx +3 -0
- package/src/MatchersInput/SuggestionsList.test.tsx +70 -0
- package/src/MatchersInput/SuggestionsList.tsx +11 -10
- package/src/MatchersInput/index.tsx +1 -1
- package/src/MetricsGraph/MetricsTooltip/index.tsx +22 -34
- package/src/PreSelectedMatchers/index.tsx +3 -0
- package/src/ProfileFlameGraph/FlameGraphArrow/TextWithEllipsis.tsx +3 -0
- package/src/ProfileFlameGraph/FlameGraphArrow/TooltipContext.tsx +3 -0
- package/src/ProfileFlameGraph/FlameGraphArrow/ZoomControls.tsx +3 -0
- package/src/ProfileFlameGraph/FlameGraphArrow/useBatchedRendering.ts +3 -0
- package/src/ProfileSelector/index.tsx +30 -7
- package/src/ProfileView/components/Toolbars/MultiLevelDropdown.tsx +3 -0
- package/src/ProfileView/components/VisualizationContainer/index.tsx +3 -0
- package/src/Table/hooks/useTableConfiguration.tsx +7 -13
- package/src/useDelayedLoader.ts +10 -10
- package/src/useSumBy.ts +12 -18
- package/dist/ProfileView/components/ProfileFilters/useProfileFiltersUrlState.test.js +0 -541
- package/dist/hooks/useQueryState.test.js +0 -984
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { c as _c } from "react-compiler-runtime";
|
|
1
2
|
// Copyright 2022 The Parca Authors
|
|
2
3
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
4
|
// you may not use this file except in compliance with the License.
|
|
@@ -10,25 +11,56 @@
|
|
|
10
11
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
12
|
// See the License for the specific language governing permissions and
|
|
12
13
|
// limitations under the License.
|
|
14
|
+
|
|
13
15
|
import { useMemo } from 'react';
|
|
14
16
|
import { tableFromIPC } from '@uwdata/flechette';
|
|
15
|
-
import useMappingList, { useFilenamesList
|
|
17
|
+
import useMappingList, { useFilenamesList } from '../../ProfileFlameGraph/FlameGraphArrow/useMappingList';
|
|
16
18
|
import { alignedUint8Array } from '../../utils';
|
|
17
|
-
export
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
19
|
+
export var useProfileMetadata = function useProfileMetadata(t0) {
|
|
20
|
+
var $ = _c(8);
|
|
21
|
+
var flamegraphArrow = t0.flamegraphArrow,
|
|
22
|
+
metadataMappingFiles = t0.metadataMappingFiles,
|
|
23
|
+
metadataLoading = t0.metadataLoading,
|
|
24
|
+
colorBy = t0.colorBy;
|
|
25
|
+
var t1;
|
|
26
|
+
bb0: {
|
|
27
|
+
if (flamegraphArrow === undefined) {
|
|
28
|
+
t1 = null;
|
|
29
|
+
break bb0;
|
|
30
|
+
}
|
|
31
|
+
var _t;
|
|
32
|
+
if ($[0] !== flamegraphArrow.record) {
|
|
33
|
+
_t = tableFromIPC(alignedUint8Array(flamegraphArrow.record), {
|
|
34
|
+
useBigInt: true
|
|
35
|
+
});
|
|
36
|
+
$[0] = flamegraphArrow.record;
|
|
37
|
+
$[1] = _t;
|
|
38
|
+
} else {
|
|
39
|
+
_t = $[1];
|
|
40
|
+
}
|
|
41
|
+
t1 = _t;
|
|
42
|
+
}
|
|
43
|
+
var table = t1;
|
|
44
|
+
var mappingsList = useMappingList(metadataMappingFiles);
|
|
45
|
+
var filenamesList = useFilenamesList(table);
|
|
46
|
+
var colorMappings = colorBy === "binary" || colorBy === "" ? mappingsList : filenamesList;
|
|
47
|
+
var t2;
|
|
48
|
+
if ($[2] !== colorMappings || $[3] !== filenamesList || $[4] !== mappingsList || $[5] !== metadataLoading || $[6] !== table) {
|
|
49
|
+
t2 = {
|
|
50
|
+
table: table,
|
|
51
|
+
mappingsList: mappingsList,
|
|
52
|
+
filenamesList: filenamesList,
|
|
53
|
+
colorMappings: colorMappings,
|
|
54
|
+
metadataLoading: metadataLoading
|
|
33
55
|
};
|
|
34
|
-
|
|
56
|
+
$[2] = colorMappings;
|
|
57
|
+
$[3] = filenamesList;
|
|
58
|
+
$[4] = mappingsList;
|
|
59
|
+
$[5] = metadataLoading;
|
|
60
|
+
$[6] = table;
|
|
61
|
+
$[7] = t2;
|
|
62
|
+
} else {
|
|
63
|
+
t2 = $[7];
|
|
64
|
+
}
|
|
65
|
+
return t2;
|
|
66
|
+
};
|
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
2
|
+
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."); }
|
|
3
|
+
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; } }
|
|
4
|
+
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; }
|
|
5
|
+
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; } }
|
|
6
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
7
|
+
import { c as _c } from "react-compiler-runtime";
|
|
1
8
|
// Copyright 2022 The Parca Authors
|
|
2
9
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
10
|
// you may not use this file except in compliance with the License.
|
|
@@ -10,15 +17,29 @@
|
|
|
10
17
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
18
|
// See the License for the specific language governing permissions and
|
|
12
19
|
// limitations under the License.
|
|
20
|
+
|
|
13
21
|
import { useURLState } from '@parca/components';
|
|
14
|
-
export
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
22
|
+
export var useResetFlameGraphState = function useResetFlameGraphState() {
|
|
23
|
+
var $ = _c(3);
|
|
24
|
+
var _useURLState = useURLState("cur_path"),
|
|
25
|
+
_useURLState2 = _slicedToArray(_useURLState, 2),
|
|
26
|
+
val = _useURLState2[0],
|
|
27
|
+
setCurPath = _useURLState2[1];
|
|
28
|
+
var t0;
|
|
29
|
+
if ($[0] !== setCurPath || $[1] !== val) {
|
|
30
|
+
t0 = function t0() {
|
|
31
|
+
setTimeout(function () {
|
|
32
|
+
if (val === undefined) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
setCurPath(undefined);
|
|
36
|
+
});
|
|
23
37
|
};
|
|
24
|
-
|
|
38
|
+
$[0] = setCurPath;
|
|
39
|
+
$[1] = val;
|
|
40
|
+
$[2] = t0;
|
|
41
|
+
} else {
|
|
42
|
+
t0 = $[2];
|
|
43
|
+
}
|
|
44
|
+
return t0;
|
|
45
|
+
};
|
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
2
|
+
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."); }
|
|
3
|
+
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; } }
|
|
4
|
+
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; }
|
|
5
|
+
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; } }
|
|
6
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
7
|
+
import { c as _c } from "react-compiler-runtime";
|
|
1
8
|
// Copyright 2022 The Parca Authors
|
|
2
9
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
10
|
// you may not use this file except in compliance with the License.
|
|
@@ -10,35 +17,71 @@
|
|
|
10
17
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
18
|
// See the License for the specific language governing permissions and
|
|
12
19
|
// limitations under the License.
|
|
20
|
+
|
|
13
21
|
import { useURLState, useURLStateBatch } from '@parca/components';
|
|
14
22
|
import { useProfileFilters } from '../components/ProfileFilters/useProfileFilters';
|
|
15
|
-
export
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
23
|
+
export var useResetStateOnProfileTypeChange = function useResetStateOnProfileTypeChange() {
|
|
24
|
+
var $ = _c(13);
|
|
25
|
+
var _useURLState = useURLState("group_by"),
|
|
26
|
+
_useURLState2 = _slicedToArray(_useURLState, 2),
|
|
27
|
+
groupBy = _useURLState2[0],
|
|
28
|
+
setGroupBy = _useURLState2[1];
|
|
29
|
+
var _useURLState3 = useURLState("cur_path"),
|
|
30
|
+
_useURLState4 = _slicedToArray(_useURLState3, 2),
|
|
31
|
+
curPath = _useURLState4[0],
|
|
32
|
+
setCurPath = _useURLState4[1];
|
|
33
|
+
var _useURLState5 = useURLState("sum_by_a"),
|
|
34
|
+
_useURLState6 = _slicedToArray(_useURLState5, 2),
|
|
35
|
+
sumByA = _useURLState6[0],
|
|
36
|
+
setSumByA = _useURLState6[1];
|
|
37
|
+
var _useURLState7 = useURLState("sum_by_b"),
|
|
38
|
+
_useURLState8 = _slicedToArray(_useURLState7, 2),
|
|
39
|
+
sumByB = _useURLState8[0],
|
|
40
|
+
setSumByB = _useURLState8[1];
|
|
41
|
+
var _useProfileFilters = useProfileFilters(),
|
|
42
|
+
resetFilters = _useProfileFilters.resetFilters;
|
|
43
|
+
var _useURLState9 = useURLState("sandwich_function_name"),
|
|
44
|
+
_useURLState0 = _slicedToArray(_useURLState9, 2),
|
|
45
|
+
sandwichFunctionName = _useURLState0[0],
|
|
46
|
+
setSandwichFunctionName = _useURLState0[1];
|
|
47
|
+
var batchUpdates = useURLStateBatch();
|
|
48
|
+
var t0;
|
|
49
|
+
if ($[0] !== batchUpdates || $[1] !== curPath || $[2] !== groupBy || $[3] !== resetFilters || $[4] !== sandwichFunctionName || $[5] !== setCurPath || $[6] !== setGroupBy || $[7] !== setSandwichFunctionName || $[8] !== setSumByA || $[9] !== setSumByB || $[10] !== sumByA || $[11] !== sumByB) {
|
|
50
|
+
t0 = function t0() {
|
|
51
|
+
batchUpdates(function () {
|
|
52
|
+
if (groupBy !== undefined) {
|
|
53
|
+
setGroupBy(undefined);
|
|
54
|
+
}
|
|
55
|
+
if (curPath !== undefined) {
|
|
56
|
+
setCurPath(undefined);
|
|
57
|
+
}
|
|
58
|
+
if (sandwichFunctionName !== undefined) {
|
|
59
|
+
setSandwichFunctionName(undefined);
|
|
60
|
+
}
|
|
61
|
+
if (sumByA !== undefined) {
|
|
62
|
+
setSumByA(undefined);
|
|
63
|
+
}
|
|
64
|
+
if (sumByB !== undefined) {
|
|
65
|
+
setSumByB(undefined);
|
|
66
|
+
}
|
|
67
|
+
resetFilters();
|
|
68
|
+
});
|
|
43
69
|
};
|
|
44
|
-
|
|
70
|
+
$[0] = batchUpdates;
|
|
71
|
+
$[1] = curPath;
|
|
72
|
+
$[2] = groupBy;
|
|
73
|
+
$[3] = resetFilters;
|
|
74
|
+
$[4] = sandwichFunctionName;
|
|
75
|
+
$[5] = setCurPath;
|
|
76
|
+
$[6] = setGroupBy;
|
|
77
|
+
$[7] = setSandwichFunctionName;
|
|
78
|
+
$[8] = setSumByA;
|
|
79
|
+
$[9] = setSumByB;
|
|
80
|
+
$[10] = sumByA;
|
|
81
|
+
$[11] = sumByB;
|
|
82
|
+
$[12] = t0;
|
|
83
|
+
} else {
|
|
84
|
+
t0 = $[12];
|
|
85
|
+
}
|
|
86
|
+
return t0;
|
|
87
|
+
};
|
|
@@ -1,3 +1,10 @@
|
|
|
1
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
2
|
+
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."); }
|
|
3
|
+
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; } }
|
|
4
|
+
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; }
|
|
5
|
+
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; } }
|
|
6
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
7
|
+
import { c as _c } from "react-compiler-runtime";
|
|
1
8
|
// Copyright 2022 The Parca Authors
|
|
2
9
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
3
10
|
// you may not use this file except in compliance with the License.
|
|
@@ -10,18 +17,37 @@
|
|
|
10
17
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
11
18
|
// See the License for the specific language governing permissions and
|
|
12
19
|
// limitations under the License.
|
|
20
|
+
|
|
13
21
|
import { useURLState } from '@parca/components';
|
|
14
|
-
export
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
22
|
+
export var useResetStateOnSeriesChange = function useResetStateOnSeriesChange() {
|
|
23
|
+
var $ = _c(5);
|
|
24
|
+
var _useURLState = useURLState("cur_path"),
|
|
25
|
+
_useURLState2 = _slicedToArray(_useURLState, 2),
|
|
26
|
+
curPath = _useURLState2[0],
|
|
27
|
+
setCurPath = _useURLState2[1];
|
|
28
|
+
var _useURLState3 = useURLState("sandwich_function_name"),
|
|
29
|
+
_useURLState4 = _slicedToArray(_useURLState3, 2),
|
|
30
|
+
sandwichFunctionName = _useURLState4[0],
|
|
31
|
+
setSandwichFunctionName = _useURLState4[1];
|
|
32
|
+
var t0;
|
|
33
|
+
if ($[0] !== curPath || $[1] !== sandwichFunctionName || $[2] !== setCurPath || $[3] !== setSandwichFunctionName) {
|
|
34
|
+
t0 = function t0() {
|
|
35
|
+
setTimeout(function () {
|
|
36
|
+
if (curPath !== undefined) {
|
|
37
|
+
setCurPath(undefined);
|
|
38
|
+
}
|
|
39
|
+
if (sandwichFunctionName !== undefined) {
|
|
40
|
+
setSandwichFunctionName(undefined);
|
|
41
|
+
}
|
|
42
|
+
});
|
|
26
43
|
};
|
|
27
|
-
|
|
44
|
+
$[0] = curPath;
|
|
45
|
+
$[1] = sandwichFunctionName;
|
|
46
|
+
$[2] = setCurPath;
|
|
47
|
+
$[3] = setSandwichFunctionName;
|
|
48
|
+
$[4] = t0;
|
|
49
|
+
} else {
|
|
50
|
+
t0 = $[4];
|
|
51
|
+
}
|
|
52
|
+
return t0;
|
|
53
|
+
};
|
|
@@ -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,95 +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 { JSONParser, JSONSerializer, useURLState, useURLStateBatch, useURLStateCustom
|
|
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
|
|
28
|
+
import { FIELD_FUNCTION_FILE_NAME, FIELD_FUNCTION_NAME, FIELD_LABELS, FIELD_LOCATION_ADDRESS, FIELD_MAPPING_FILE } from '../../ProfileFlameGraph/FlameGraphArrow';
|
|
17
29
|
import { useResetFlameGraphState } from './useResetFlameGraphState';
|
|
18
|
-
export
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
alwaysReturnArray: true,
|
|
36
|
-
});
|
|
37
|
-
const [sandwichFunctionName, setSandwichFunctionName] = useURLState('sandwich_function_name');
|
|
38
|
-
const [flamechartDimension, setStoreFlamechartDimension] = useURLState('flamechart_dimension', {
|
|
39
|
-
alwaysReturnArray: true,
|
|
40
|
-
});
|
|
41
|
-
const resetFlameGraphState = useResetFlameGraphState();
|
|
42
|
-
const batchUpdates = useURLStateBatch();
|
|
43
|
-
const levelsOfProfiling = useMemo(() => [
|
|
44
|
-
FIELD_FUNCTION_NAME,
|
|
45
|
-
FIELD_FUNCTION_FILE_NAME,
|
|
46
|
-
FIELD_LOCATION_ADDRESS,
|
|
47
|
-
FIELD_MAPPING_FILE,
|
|
48
|
-
], []);
|
|
49
|
-
const setGroupBy = useCallback((keys) => {
|
|
50
|
-
setStoreGroupBy(keys);
|
|
51
|
-
}, [setStoreGroupBy]);
|
|
52
|
-
const toggleGroupBy = useCallback((key) => {
|
|
53
|
-
// Batch updates to combine setGroupBy + resetFlameGraphState into single URL navigation
|
|
54
|
-
batchUpdates(() => {
|
|
55
|
-
if (groupBy.includes(key)) {
|
|
56
|
-
setGroupBy(groupBy.filter(v => v !== key)); // remove
|
|
57
|
-
}
|
|
58
|
-
else {
|
|
59
|
-
const filteredGroupBy = groupBy.filter(item => !levelsOfProfiling.includes(item));
|
|
60
|
-
setGroupBy([...filteredGroupBy, key]); // add
|
|
61
|
-
}
|
|
62
|
-
resetFlameGraphState();
|
|
63
|
-
});
|
|
64
|
-
}, [groupBy, setGroupBy, levelsOfProfiling, resetFlameGraphState, batchUpdates]);
|
|
65
|
-
const setGroupByLabels = useCallback((labels) => {
|
|
66
|
-
// Batch updates to combine setGroupBy + resetFlameGraphState into single URL navigation
|
|
67
|
-
batchUpdates(() => {
|
|
68
|
-
setGroupBy(groupBy.filter(l => !l.startsWith(`${FIELD_LABELS}.`)).concat(labels));
|
|
69
|
-
resetFlameGraphState();
|
|
70
|
-
});
|
|
71
|
-
}, [groupBy, setGroupBy, resetFlameGraphState, batchUpdates]);
|
|
72
|
-
const setFlamechartDimension = useCallback((labels) => {
|
|
73
|
-
setStoreFlamechartDimension(labels.filter(l => l.startsWith(`${FIELD_LABELS}.`)));
|
|
74
|
-
}, [setStoreFlamechartDimension]);
|
|
75
|
-
const resetSandwichFunctionName = useCallback(() => {
|
|
76
|
-
setSandwichFunctionName(undefined);
|
|
77
|
-
}, [setSandwichFunctionName]);
|
|
78
|
-
const setColorBy = useCallback((value) => {
|
|
79
|
-
setStoreColorBy(value);
|
|
80
|
-
setColorByPreference(value);
|
|
81
|
-
}, [setStoreColorBy, setColorByPreference]);
|
|
82
|
-
const setAlignFunctionName = useCallback((value) => {
|
|
83
|
-
setStoreAlignFunctionName(value);
|
|
84
|
-
setAlignFunctionNamePreference(value);
|
|
85
|
-
}, [setStoreAlignFunctionName, setAlignFunctionNamePreference]);
|
|
86
|
-
return {
|
|
87
|
-
curPathArrow,
|
|
88
|
-
setCurPathArrow,
|
|
89
|
-
colorStackLegend,
|
|
90
|
-
colorBy: colorBy ?? '',
|
|
91
|
-
setColorBy,
|
|
92
|
-
groupBy,
|
|
93
|
-
setGroupBy,
|
|
94
|
-
toggleGroupBy,
|
|
95
|
-
setGroupByLabels,
|
|
96
|
-
flamechartDimension,
|
|
97
|
-
setFlamechartDimension,
|
|
98
|
-
sandwichFunctionName,
|
|
99
|
-
setSandwichFunctionName,
|
|
100
|
-
resetSandwichFunctionName,
|
|
101
|
-
alignFunctionName: alignFunctionName ?? 'left',
|
|
102
|
-
setAlignFunctionName,
|
|
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: "[]"
|
|
103
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 () {
|
|
143
|
+
if (groupBy.includes(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]));
|
|
152
|
+
}
|
|
153
|
+
resetFlameGraphState();
|
|
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));
|
|
170
|
+
resetFlameGraphState();
|
|
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
|
|
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;
|
|
104
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
|
+
}
|