@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
package/dist/SourceView/index.js
CHANGED
|
@@ -1,4 +1,13 @@
|
|
|
1
|
-
|
|
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; }
|
|
2
11
|
// Copyright 2022 The Parca Authors
|
|
3
12
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
13
|
// you may not use this file except in compliance with the License.
|
|
@@ -11,6 +20,7 @@ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-run
|
|
|
11
20
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
21
|
// See the License for the specific language governing permissions and
|
|
13
22
|
// limitations under the License.
|
|
23
|
+
|
|
14
24
|
import React, { useCallback, useEffect, useMemo } from 'react';
|
|
15
25
|
import { tableFromIPC } from '@uwdata/flechette';
|
|
16
26
|
import { AnimatePresence, motion } from 'framer-motion';
|
|
@@ -20,110 +30,176 @@ import { ExpandOnHover } from '../GraphTooltipArrow/ExpandOnHoverValue';
|
|
|
20
30
|
import { alignedUint8Array, truncateStringReverse } from '../utils';
|
|
21
31
|
import { Highlighter, profileAwareRenderer } from './Highlighter';
|
|
22
32
|
import useLineRange from './useSelectedLineRange';
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
33
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
34
|
+
var MENU_ID = 'source-view-context-menu';
|
|
35
|
+
export var SourceView = /*#__PURE__*/React.memo(function SourceView(_ref) {
|
|
36
|
+
var data = _ref.data,
|
|
37
|
+
loading = _ref.loading,
|
|
38
|
+
total = _ref.total,
|
|
39
|
+
filtered = _ref.filtered,
|
|
40
|
+
setActionButtons = _ref.setActionButtons;
|
|
41
|
+
var _useURLState = useURLState('source_filename'),
|
|
42
|
+
_useURLState2 = _slicedToArray(_useURLState, 1),
|
|
43
|
+
sourceFileName = _useURLState2[0];
|
|
44
|
+
var _useParcaContext = useParcaContext(),
|
|
45
|
+
isDarkMode = _useParcaContext.isDarkMode,
|
|
46
|
+
_useParcaContext$sour = _useParcaContext.sourceViewContextMenuItems,
|
|
47
|
+
sourceViewContextMenuItems = _useParcaContext$sour === void 0 ? [] : _useParcaContext$sour;
|
|
48
|
+
var sourceCode = useMemo(function () {
|
|
49
|
+
if (data === undefined) {
|
|
50
|
+
return [''];
|
|
51
|
+
}
|
|
52
|
+
// To use the array index as line number
|
|
53
|
+
return [''].concat(_toConsumableArray(data.source.split('\n')));
|
|
54
|
+
}, [data]);
|
|
55
|
+
var _useContextMenu = useContextMenu({
|
|
56
|
+
id: MENU_ID
|
|
57
|
+
}),
|
|
58
|
+
show = _useContextMenu.show;
|
|
59
|
+
var _useLineRange = useLineRange(),
|
|
60
|
+
startLine = _useLineRange.startLine,
|
|
61
|
+
endLine = _useLineRange.endLine;
|
|
62
|
+
var sourceTable = useMemo(function () {
|
|
63
|
+
if (data === undefined) {
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
var table = tableFromIPC(alignedUint8Array(data.record), {
|
|
67
|
+
useBigInt: true
|
|
36
68
|
});
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
const midVal = Number(lineNumbers.get(mid));
|
|
60
|
-
if (midVal === lineNumber) {
|
|
61
|
-
return {
|
|
62
|
-
cumulative: cumulative?.get(mid) ?? 0n,
|
|
63
|
-
flat: flat?.get(mid) ?? 0n,
|
|
64
|
-
};
|
|
65
|
-
}
|
|
66
|
-
if (midVal < lineNumber) {
|
|
67
|
-
lo = mid + 1;
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
hi = mid - 1;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
return undefined;
|
|
74
|
-
}, [sourceTable]);
|
|
75
|
-
const getProfileDataForLine = useCallback((line) => {
|
|
76
|
-
const data = getLineData(line);
|
|
77
|
-
if (data === undefined) {
|
|
78
|
-
return undefined;
|
|
79
|
-
}
|
|
80
|
-
if (data.cumulative === 0n && data.flat === 0n) {
|
|
81
|
-
return undefined;
|
|
82
|
-
}
|
|
69
|
+
return {
|
|
70
|
+
numRows: table.numRows,
|
|
71
|
+
lineNumbers: table.getChild('line_number'),
|
|
72
|
+
cumulative: table.getChild('cumulative'),
|
|
73
|
+
flat: table.getChild('flat')
|
|
74
|
+
};
|
|
75
|
+
}, [data]);
|
|
76
|
+
var getLineData = useCallback(function (lineNumber) {
|
|
77
|
+
if (sourceTable === null || sourceTable.lineNumbers === null) {
|
|
78
|
+
return undefined;
|
|
79
|
+
}
|
|
80
|
+
var numRows = sourceTable.numRows,
|
|
81
|
+
lineNumbers = sourceTable.lineNumbers,
|
|
82
|
+
cumulative = sourceTable.cumulative,
|
|
83
|
+
flat = sourceTable.flat;
|
|
84
|
+
var lo = 0;
|
|
85
|
+
var hi = numRows - 1;
|
|
86
|
+
while (lo <= hi) {
|
|
87
|
+
var mid = lo + hi >>> 1;
|
|
88
|
+
var midVal = Number(lineNumbers.get(mid));
|
|
89
|
+
if (midVal === lineNumber) {
|
|
90
|
+
var _ref2, _ref3;
|
|
83
91
|
return {
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
flat: Number(data.flat),
|
|
92
|
+
cumulative: (_ref2 = cumulative === null || cumulative === void 0 ? void 0 : cumulative.get(mid)) !== null && _ref2 !== void 0 ? _ref2 : 0n,
|
|
93
|
+
flat: (_ref3 = flat === null || flat === void 0 ? void 0 : flat.get(mid)) !== null && _ref3 !== void 0 ? _ref3 : 0n
|
|
87
94
|
};
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
const profileData = [];
|
|
95
|
-
const profileDataForLine = getProfileDataForLine(startLine);
|
|
96
|
-
if (profileDataForLine != null) {
|
|
97
|
-
profileData.push(profileDataForLine);
|
|
98
|
-
}
|
|
99
|
-
return [sourceCode[startLine - 1], profileData];
|
|
100
|
-
}
|
|
101
|
-
let code = '';
|
|
102
|
-
const profileData = [];
|
|
103
|
-
for (let i = startLine; i <= endLine; i++) {
|
|
104
|
-
code += sourceCode[i] + '\n';
|
|
105
|
-
const profileDataForLine = getProfileDataForLine(i);
|
|
106
|
-
if (profileDataForLine != null) {
|
|
107
|
-
profileData.push(profileDataForLine);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
return [code, profileData];
|
|
111
|
-
}, [startLine, endLine, sourceCode, getProfileDataForLine]);
|
|
112
|
-
useEffect(() => {
|
|
113
|
-
setActionButtons?.(_jsx("div", { className: "px-2", children: _jsx(ExpandOnHover, { value: sourceFileName, displayValue: truncateStringReverse(sourceFileName, 50) }) }));
|
|
114
|
-
}, [sourceFileName, setActionButtons]);
|
|
115
|
-
if (loading) {
|
|
116
|
-
return (_jsx("div", { className: "h-auto overflow-clip", children: _jsx(SourceSkeleton, { isDarkMode: isDarkMode }) }));
|
|
95
|
+
}
|
|
96
|
+
if (midVal < lineNumber) {
|
|
97
|
+
lo = mid + 1;
|
|
98
|
+
} else {
|
|
99
|
+
hi = mid - 1;
|
|
100
|
+
}
|
|
117
101
|
}
|
|
118
|
-
|
|
119
|
-
|
|
102
|
+
return undefined;
|
|
103
|
+
}, [sourceTable]);
|
|
104
|
+
var getProfileDataForLine = useCallback(function (line) {
|
|
105
|
+
var data_0 = getLineData(line);
|
|
106
|
+
if (data_0 === undefined) {
|
|
107
|
+
return undefined;
|
|
120
108
|
}
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
109
|
+
if (data_0.cumulative === 0n && data_0.flat === 0n) {
|
|
110
|
+
return undefined;
|
|
111
|
+
}
|
|
112
|
+
return {
|
|
113
|
+
line: line,
|
|
114
|
+
cumulative: Number(data_0.cumulative),
|
|
115
|
+
flat: Number(data_0.flat)
|
|
126
116
|
};
|
|
127
|
-
|
|
117
|
+
}, [getLineData]);
|
|
118
|
+
var _useMemo = useMemo(function () {
|
|
119
|
+
if (startLine === -1 && endLine === -1) {
|
|
120
|
+
return ['', []];
|
|
121
|
+
}
|
|
122
|
+
if (startLine === endLine) {
|
|
123
|
+
var profileData = [];
|
|
124
|
+
var profileDataForLine = getProfileDataForLine(startLine);
|
|
125
|
+
if (profileDataForLine != null) {
|
|
126
|
+
profileData.push(profileDataForLine);
|
|
127
|
+
}
|
|
128
|
+
return [sourceCode[startLine - 1], profileData];
|
|
129
|
+
}
|
|
130
|
+
var code = '';
|
|
131
|
+
var profileData_0 = [];
|
|
132
|
+
for (var i = startLine; i <= endLine; i++) {
|
|
133
|
+
code += sourceCode[i] + '\n';
|
|
134
|
+
var profileDataForLine_0 = getProfileDataForLine(i);
|
|
135
|
+
if (profileDataForLine_0 != null) {
|
|
136
|
+
profileData_0.push(profileDataForLine_0);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
return [code, profileData_0];
|
|
140
|
+
}, [startLine, endLine, sourceCode, getProfileDataForLine]),
|
|
141
|
+
_useMemo2 = _slicedToArray(_useMemo, 2),
|
|
142
|
+
selectedCode = _useMemo2[0],
|
|
143
|
+
profileData_1 = _useMemo2[1];
|
|
144
|
+
useEffect(function () {
|
|
145
|
+
setActionButtons === null || setActionButtons === void 0 || setActionButtons(/*#__PURE__*/_jsx("div", {
|
|
146
|
+
className: "px-2",
|
|
147
|
+
children: /*#__PURE__*/_jsx(ExpandOnHover, {
|
|
148
|
+
value: sourceFileName,
|
|
149
|
+
displayValue: truncateStringReverse(sourceFileName, 50)
|
|
150
|
+
})
|
|
151
|
+
}));
|
|
152
|
+
}, [sourceFileName, setActionButtons]);
|
|
153
|
+
if (loading) {
|
|
154
|
+
return /*#__PURE__*/_jsx("div", {
|
|
155
|
+
className: "h-auto overflow-clip",
|
|
156
|
+
children: /*#__PURE__*/_jsx(SourceSkeleton, {
|
|
157
|
+
isDarkMode: isDarkMode
|
|
158
|
+
})
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
if (data === undefined) {
|
|
162
|
+
return /*#__PURE__*/_jsx(_Fragment, {
|
|
163
|
+
children: "Source code not uploaded for this build."
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
168
|
+
var onContextMenu = function onContextMenu(event) {
|
|
169
|
+
show({
|
|
170
|
+
event: event
|
|
171
|
+
});
|
|
172
|
+
};
|
|
173
|
+
return /*#__PURE__*/_jsx(AnimatePresence, {
|
|
174
|
+
children: /*#__PURE__*/_jsxs(motion.div, {
|
|
175
|
+
className: "h-full w-full",
|
|
176
|
+
initial: {
|
|
177
|
+
display: 'none',
|
|
178
|
+
opacity: 0
|
|
179
|
+
},
|
|
180
|
+
animate: {
|
|
181
|
+
display: 'block',
|
|
182
|
+
opacity: 1
|
|
183
|
+
},
|
|
184
|
+
transition: {
|
|
185
|
+
duration: 0.5
|
|
186
|
+
},
|
|
187
|
+
children: [/*#__PURE__*/_jsx(Highlighter, {
|
|
188
|
+
file: sourceFileName,
|
|
189
|
+
content: data.source,
|
|
190
|
+
renderer: profileAwareRenderer(getLineData, total, filtered, onContextMenu)
|
|
191
|
+
}), sourceViewContextMenuItems.length > 0 ? /*#__PURE__*/_jsx(Menu, {
|
|
192
|
+
id: MENU_ID,
|
|
193
|
+
children: sourceViewContextMenuItems.map(function (item) {
|
|
194
|
+
return /*#__PURE__*/_jsx(Item, {
|
|
195
|
+
onClick: function onClick() {
|
|
196
|
+
return item.action(selectedCode, profileData_1);
|
|
197
|
+
},
|
|
198
|
+
children: item.label
|
|
199
|
+
}, item.id);
|
|
200
|
+
})
|
|
201
|
+
}) : null]
|
|
202
|
+
}, "source-view-loaded")
|
|
203
|
+
});
|
|
128
204
|
});
|
|
129
|
-
export default SourceView;
|
|
205
|
+
export default SourceView;
|