/usr/share/grafana/public/build
{"version":3,"file":"9147.8309cadbc384209d62e5.js","mappings":"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","sources":["webpack://grafana/./public/app/plugins/panel/nodeGraph/panelcfg.gen.ts","webpack://grafana/./node_modules/react-use/lib/useIsomorphicLayoutEffect.js","webpack://grafana/./public/app/plugins/panel/nodeGraph/EdgeArrowMarker.tsx","webpack://grafana/./public/app/plugins/panel/nodeGraph/Edge.tsx","webpack://grafana/./public/app/plugins/panel/nodeGraph/EdgeLabel.tsx","webpack://grafana/./public/app/plugins/panel/nodeGraph/Legend.tsx","webpack://grafana/./public/app/plugins/panel/nodeGraph/Marker.tsx","webpack://grafana/./public/app/plugins/panel/nodeGraph/ViewControls.tsx","webpack://grafana/./public/app/plugins/panel/nodeGraph/createLayoutWorker.ts","webpack://grafana/./public/app/plugins/panel/nodeGraph/useNodeLimit.ts","webpack://grafana/./public/app/plugins/panel/nodeGraph/layout.ts","webpack://grafana/./public/app/plugins/panel/nodeGraph/useContextMenu.tsx","webpack://grafana/./public/app/plugins/panel/nodeGraph/useFocusPositionOnLayout.ts","webpack://grafana/./public/app/plugins/panel/nodeGraph/useHighlight.ts","webpack://grafana/./public/app/plugins/panel/nodeGraph/usePanning.ts","webpack://grafana/./public/app/plugins/panel/nodeGraph/useZoom.ts","webpack://grafana/./public/app/plugins/panel/nodeGraph/NodeGraph.tsx","webpack://grafana/./node_modules/react-use/lib/misc/util.js","webpack://grafana/./node_modules/react-use/lib/useMeasure.js","webpack://grafana/./node_modules/react-use/lib/usePrevious.js","webpack://grafana/./public/app/plugins/panel/nodeGraph/useCategorizeFrames.ts"],"sourcesContent":["// Code generated - EDITING IS FUTILE. DO NOT EDIT.\n//\n// Generated by:\n// public/app/plugins/gen.go\n// Using jennies:\n// TSTypesJenny\n// PluginTsTypesJenny\n//\n// Run 'make gen-cue' from repository root to regenerate.\n\nexport interface ArcOption {\n /**\n * The color of the arc.\n */\n color?: string;\n /**\n * Field from which to get the value. Values should be less than 1, representing fraction of a circle.\n */\n field?: string;\n}\n\nexport enum ZoomMode {\n Cooperative = 'cooperative',\n Greedy = 'greedy',\n}\n\nexport enum LayoutAlgorithm {\n Force = 'force',\n Grid = 'grid',\n Layered = 'layered',\n}\n\nexport interface Options {\n edges?: {\n /**\n * Unit for the main stat to override what ever is set in the data frame.\n */\n mainStatUnit?: string;\n /**\n * Unit for the secondary stat to override what ever is set in the data frame.\n */\n secondaryStatUnit?: string;\n };\n /**\n * How to layout the nodes in the node graph\n */\n layoutAlgorithm?: LayoutAlgorithm;\n nodes?: {\n /**\n * Unit for the main stat to override what ever is set in the data frame.\n */\n mainStatUnit?: string;\n /**\n * Unit for the secondary stat to override what ever is set in the data frame.\n */\n secondaryStatUnit?: string;\n /**\n * Define which fields are shown as part of the node arc (colored circle around the node).\n */\n arcs?: Array<ArcOption>;\n };\n /**\n * How to handle zoom/scroll events in the node graph\n */\n zoomMode?: ZoomMode;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = require(\"react\");\nvar util_1 = require(\"./misc/util\");\nvar useIsomorphicLayoutEffect = util_1.isBrowser ? react_1.useLayoutEffect : react_1.useEffect;\nexports.default = useIsomorphicLayoutEffect;\n","import { defaultEdgeColor } from './Edge';\n\n/**\n * In SVG you need to supply this kind of marker that can be then referenced from a line segment as an ending of the\n * line turning in into arrow. Needs to be included in the svg element and then referenced as markerEnd=\"url(#triangle)\"\n */\nexport function EdgeArrowMarker({\n id = 'triangle',\n fill = defaultEdgeColor,\n headHeight = 10,\n}: {\n id?: string;\n fill?: string;\n headHeight?: number;\n}) {\n return (\n <defs>\n <marker\n id={id}\n viewBox=\"0 0 10 10\"\n refX=\"1\" // shift the arrow head slightly closer to the center of the line it will be attached to, to ensure no empty space is shown between the line and the arrow head\n refY=\"5\"\n markerUnits=\"userSpaceOnUse\"\n markerWidth={headHeight} // equal to the height just for simplicily\n markerHeight={headHeight}\n orient=\"auto\"\n >\n <path d=\"M 0 0 L 10 5 L 0 10 z\" fill={fill} />\n </marker>\n </defs>\n );\n}\n","import { MouseEvent, memo } from 'react';\n\nimport { t } from '@grafana/i18n';\n\nimport { EdgeArrowMarker } from './EdgeArrowMarker';\nimport { computeNodeCircumferenceStrokeWidth, nodeR } from './Node';\nimport { EdgeDatumLayout, NodeDatum } from './types';\nimport { shortenLine } from './utils';\n\nexport const defaultHighlightedEdgeColor = '#a00';\nexport const defaultEdgeColor = '#999';\n\ninterface Props {\n edge: EdgeDatumLayout;\n hovering: boolean;\n svgIdNamespace: string;\n onClick: (event: MouseEvent<SVGElement>, link: EdgeDatumLayout) => void;\n onMouseEnter: (id: string) => void;\n onMouseLeave: (id: string) => void;\n}\n\nexport const Edge = memo(function Edge(props: Props) {\n const { edge, onClick, onMouseEnter, onMouseLeave, hovering, svgIdNamespace } = props;\n\n // Not great typing but after we do layout these properties are full objects not just references\n const { source, target, sourceNodeRadius, targetNodeRadius } = edge as {\n source: NodeDatum;\n target: NodeDatum;\n sourceNodeRadius: number;\n targetNodeRadius: number;\n };\n const arrowHeadHeight = 10 + edge.thickness * 2; // resized value, just to make the UI nicer\n\n // As the nodes have some radius we want edges to end outside of the node circle.\n const line = shortenLine(\n {\n x1: source.x!,\n y1: source.y!,\n x2: target.x!,\n y2: target.y!,\n },\n sourceNodeRadius + computeNodeCircumferenceStrokeWidth(sourceNodeRadius) / 2 || nodeR,\n targetNodeRadius + computeNodeCircumferenceStrokeWidth(targetNodeRadius) / 2 || nodeR,\n arrowHeadHeight\n );\n\n const edgeColor = edge.color || defaultEdgeColor;\n\n // @deprecated -- until 'highlighted' is removed we'll prioritize 'color'\n // in case both are provided\n const highlightedEdgeColor = edge.color || defaultHighlightedEdgeColor;\n\n const markerId = `triangle-${svgIdNamespace}-${edge.id}`;\n const coloredMarkerId = `triangle-colored-${svgIdNamespace}-${edge.id}`;\n\n return (\n <>\n <EdgeArrowMarker id={markerId} fill={edgeColor} headHeight={arrowHeadHeight} />\n <EdgeArrowMarker id={coloredMarkerId} fill={highlightedEdgeColor} headHeight={arrowHeadHeight} />\n <g\n onClick={(event) => onClick(event, edge)}\n style={{ cursor: 'pointer' }}\n aria-label={t('nodeGraph.edge.aria-label-from-to', 'Edge from: {{from}} to: {{to}}', {\n from: source.id,\n to: target.id,\n })}\n >\n <line\n strokeWidth={(hovering ? 1 : 0) + (edge.highlighted ? 1 : 0) + edge.thickness}\n stroke={edge.highlighted ? highlightedEdgeColor : edgeColor}\n x1={line.x1}\n y1={line.y1}\n x2={line.x2}\n y2={line.y2}\n strokeDasharray={edge.strokeDasharray}\n markerEnd={`url(#${edge.highlighted ? coloredMarkerId : markerId})`}\n />\n <line\n stroke={'transparent'}\n x1={line.x1}\n y1={line.y1}\n x2={line.x2}\n y2={line.y2}\n strokeWidth={20}\n onMouseEnter={() => {\n onMouseEnter(edge.id);\n }}\n onMouseLeave={() => {\n onMouseLeave(edge.id);\n }}\n />\n </g>\n </>\n );\n});\n","import { css } from '@emotion/css';\nimport { memo } from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { useStyles2 } from '@grafana/ui';\n\nimport { nodeR } from './Node';\nimport { EdgeDatumLayout } from './types';\nimport { shortenLine } from './utils';\n\nconst getStyles = (theme: GrafanaTheme2) => {\n return {\n mainGroup: css({\n pointerEvents: 'none',\n fontSize: '8px',\n }),\n\n background: css({\n fill: theme.components.tooltip.background,\n }),\n\n text: css({\n fill: theme.components.tooltip.text,\n }),\n };\n};\n\ninterface Props {\n edge: EdgeDatumLayout;\n}\nexport const EdgeLabel = memo(function EdgeLabel(props: Props) {\n const { edge } = props;\n // Not great typing, but after we do layout these properties are full objects not just references\n const { source, target, sourceNodeRadius, targetNodeRadius } = edge;\n\n // As the nodes have some radius we want edges to end outside the node circle.\n const line = shortenLine(\n {\n x1: source.x!,\n y1: source.y!,\n x2: target.x!,\n y2: target.y!,\n },\n sourceNodeRadius || nodeR,\n targetNodeRadius || nodeR\n );\n\n const middle = {\n x: line.x1 + (line.x2 - line.x1) / 2,\n y: line.y1 + (line.y2 - line.y1) / 2,\n };\n const styles = useStyles2(getStyles);\n\n const stats = [edge.mainStat, edge.secondaryStat].filter((x) => x);\n const height = stats.length > 1 ? '30' : '15';\n const middleOffset = stats.length > 1 ? 15 : 7.5;\n let offset = stats.length > 1 ? -5 : 2.5;\n\n const contents: JSX.Element[] = [];\n stats.forEach((stat, index) => {\n contents.push(\n <text key={index} className={styles.text} x={middle.x} y={middle.y + offset} textAnchor={'middle'}>\n {stat}\n </text>\n );\n offset += 15;\n });\n\n return (\n <g className={styles.mainGroup}>\n <rect\n className={styles.background}\n x={middle.x - 40}\n y={middle.y - middleOffset}\n width=\"80\"\n height={height}\n rx=\"5\"\n />\n {contents}\n </g>\n );\n});\n","import { css } from '@emotion/css';\nimport { useCallback } from 'react';\n\nimport { Field, FieldColorModeId, GrafanaTheme2 } from '@grafana/data';\nimport { LegendDisplayMode } from '@grafana/schema';\nimport { Icon, useStyles2, useTheme2, VizLegend, VizLegendItem, VizLegendListItem } from '@grafana/ui';\n\nimport { Config } from './layout';\nimport { NodeDatum } from './types';\n\nfunction getStyles() {\n return {\n item: css({\n label: 'LegendItem',\n flexGrow: 0,\n }),\n\n legend: css({\n label: 'Legend',\n pointerEvents: 'all',\n }),\n };\n}\n\ninterface Props {\n nodes: NodeDatum[];\n onSort: (sort: Config['sort']) => void;\n sort?: Config['sort'];\n sortable: boolean;\n}\n\nexport const Legend = function Legend(props: Props) {\n const { nodes, onSort, sort, sortable } = props;\n\n const theme = useTheme2();\n const styles = useStyles2(getStyles);\n const colorItems = getColorLegendItems(nodes, theme);\n\n const onClick = useCallback(\n (item: VizLegendItem<ItemData>) => {\n onSort({\n field: item.data!.field,\n ascending: item.data!.field === sort?.field ? !sort?.ascending : false,\n });\n },\n [sort, onSort]\n );\n\n return (\n <VizLegend<ItemData>\n className={styles.legend}\n displayMode={LegendDisplayMode.List}\n placement={'bottom'}\n items={colorItems}\n itemRenderer={(item) => {\n return (\n <>\n <VizLegendListItem item={item} className={styles.item} onLabelClick={sortable ? onClick : undefined} />\n {sortable &&\n (sort?.field === item.data!.field ? <Icon name={sort!.ascending ? 'arrow-up' : 'arrow-down'} /> : '')}\n </>\n );\n }}\n />\n );\n};\n\ninterface ItemData {\n field: Field;\n}\n\nfunction getColorLegendItems(nodes: NodeDatum[], theme: GrafanaTheme2): Array<VizLegendItem<ItemData>> {\n if (!nodes.length) {\n return [];\n }\n const fields = [nodes[0].mainStat, nodes[0].secondaryStat].filter((item): item is NonNullable<typeof item> =>\n Boolean(item)\n );\n\n const node = nodes.find((n) => n.arcSections.length > 0);\n if (node) {\n if (node.arcSections[0]!.config?.color?.mode === FieldColorModeId.Fixed) {\n // We assume in this case we have a set of fixed colors which map neatly into a basic legend.\n\n // Lets collect and deduplicate as there isn't a requirement for 0 size arc section to be defined\n fields.push(...new Set(nodes.map((n) => n.arcSections).flat()));\n }\n }\n\n if (nodes[0].color) {\n fields.push(nodes[0].color);\n }\n\n return fields.map((f) => {\n const item: VizLegendItem = {\n label: f.config.displayName || f.name,\n yAxis: 0,\n data: { field: f },\n };\n if (f.config.color?.mode === FieldColorModeId.Fixed && f.config.color?.fixedColor) {\n item.color = theme.visualization.getColorByName(f.config.color?.fixedColor || '');\n } else if (f.config.color?.mode) {\n item.gradient = f.config.color?.mode;\n }\n\n if (!(item.color || item.gradient)) {\n // Defaults to gray color\n item.color = theme.visualization.getColorByName('');\n }\n\n return item;\n });\n}\n","import { css } from '@emotion/css';\nimport { MouseEvent, memo } from 'react';\n\nimport { GrafanaTheme2 } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { useStyles2 } from '@grafana/ui';\n\nimport { NodesMarker } from './types';\n\nconst nodeR = 40;\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n mainGroup: css({\n cursor: 'pointer',\n fontSize: '10px',\n }),\n\n mainCircle: css({\n fill: theme.components.panel.background,\n stroke: theme.colors.border.strong,\n }),\n text: css({\n width: '50px',\n height: '50px',\n textAlign: 'center',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n }),\n});\n\nexport const Marker = memo(function Marker(props: {\n marker: NodesMarker;\n onClick?: (event: MouseEvent<SVGElement>, marker: NodesMarker) => void;\n}) {\n const { marker, onClick } = props;\n const { node } = marker;\n const styles = useStyles2(getStyles);\n\n if (!(node.x !== undefined && node.y !== undefined)) {\n return null;\n }\n\n return (\n <g\n data-node-id={node.id}\n className={styles.mainGroup}\n onClick={(event) => {\n onClick?.(event, marker);\n }}\n aria-label={t('nodeGraph.marker.aria-label-hidden-marker', 'Hidden nodes marker: {{marker}}', {\n marker: node.id,\n })}\n >\n <circle className={styles.mainCircle} r={nodeR} cx={node.x} cy={node.y} />\n <g>\n <foreignObject x={node.x - 25} y={node.y - 25} width=\"50\" height=\"50\">\n <div className={styles.text}>\n {/* we limit the count to 101 so if we have more than 100 nodes we don't have exact count */}\n <span>\n {marker.count > 100\n ? t('nodeGraph.marker.100-node-count', '>100 nodes')\n : t('nodeGraph.marker.node-count', '{{count}} nodes', { count: marker.count })}\n </span>\n </div>\n </foreignObject>\n </g>\n </g>\n );\n});\n","import { css } from '@emotion/css';\nimport { useState } from 'react';\n\nimport { t } from '@grafana/i18n';\nimport { Button, Stack, useStyles2 } from '@grafana/ui';\n\nfunction getStyles() {\n return {\n wrapper: css({\n label: 'wrapper',\n pointerEvents: 'all',\n }),\n };\n}\n\ninterface Props<Config> {\n config: Config;\n onConfigChange: (config: Config) => void;\n onPlus: () => void;\n onMinus: () => void;\n scale: number;\n disableZoomOut?: boolean;\n disableZoomIn?: boolean;\n}\n\n/**\n * Control buttons for zoom but also some layout config inputs mainly for debugging.\n */\nexport function ViewControls<Config extends Record<string, any>>(props: Props<Config>) {\n const { config, onConfigChange, onPlus, onMinus, disableZoomOut, disableZoomIn } = props;\n const [showConfig, setShowConfig] = useState(false);\n\n // For debugging the layout, should be removed here and maybe moved to panel config later on\n const allowConfiguration = false;\n const styles = useStyles2(getStyles);\n\n return (\n <div className={styles.wrapper}>\n <Stack direction=\"column\" gap={1}>\n <Stack gap={0.5}>\n <Button\n icon={'plus-circle'}\n onClick={onPlus}\n size={'md'}\n aria-label={t('nodeGraph.view-controls.title-zoom-in', 'Zoom in')}\n variant=\"secondary\"\n disabled={disableZoomIn}\n />\n <Button\n icon={'minus-circle'}\n onClick={onMinus}\n size={'md'}\n aria-label={t('nodeGraph.view-controls.title-zoom-out', 'Zoom out')}\n variant=\"secondary\"\n disabled={disableZoomOut}\n />\n </Stack>\n </Stack>\n\n {allowConfiguration && (\n <Button size={'xs'} fill=\"text\" onClick={() => setShowConfig((showConfig) => !showConfig)}>\n {showConfig\n ? t('nodeGraph.view-controls.hide-config', 'Hide config')\n : t('nodeGraph.view-controls.show-config', 'Show config')}\n </Button>\n )}\n\n {allowConfiguration &&\n showConfig &&\n Object.keys(config)\n .filter((k) => k !== 'show')\n .map((k) => (\n <div key={k}>\n {k}\n <input\n style={{ width: 50 }}\n type={'number'}\n value={config[k]}\n onChange={(e) => {\n onConfigChange({ ...config, [k]: parseFloat(e.target.value) });\n }}\n />\n </div>\n ))}\n </div>\n );\n}\n","import { CorsWorker as Worker } from 'app/core/utils/CorsWorker';\n\nexport const createWorker = () => new Worker(new URL('./layout.worker.js', import.meta.url));\nexport const createMsaglWorker = () => new Worker(new URL('./layeredLayout.worker.js', import.meta.url));\n","import { fromPairs, uniq } from 'lodash';\nimport { useMemo } from 'react';\n\nimport { Config } from './layout';\nimport { EdgeDatumLayout, NodeDatum, NodesMarker } from './types';\n\ntype NodesMap = Record<string, NodeDatum>;\ntype EdgesMap = Record<string, EdgeDatumLayout[]>;\n\n/**\n * Limits the number of nodes by going from the roots breadth first until we have desired number of nodes.\n */\nexport function useNodeLimit(\n nodes: NodeDatum[],\n edges: EdgeDatumLayout[],\n limit: number,\n config: Config,\n rootId?: string\n): { nodes: NodeDatum[]; edges: EdgeDatumLayout[]; markers?: NodesMarker[] } {\n // This is pretty expensive also this happens once in the layout code when initializing position but it's a bit\n // tricky to do it only once and reuse the results because layout directly modifies the nodes.\n const [edgesMap, nodesMap] = useMemo(() => {\n // Make sure we don't compute this until we have all the data.\n if (!(nodes.length && edges.length)) {\n return [{}, {}];\n }\n\n const edgesMap = edges.reduce<EdgesMap>((acc, e) => {\n acc[e.source.id] = [...(acc[e.source.id] ?? []), e];\n acc[e.target.id] = [...(acc[e.target.id] ?? []), e];\n return acc;\n }, {});\n\n const nodesMap = nodes.reduce<NodesMap>((acc, node) => {\n acc[node.id] = node;\n return acc;\n }, {});\n return [edgesMap, nodesMap];\n }, [edges, nodes]);\n\n return useMemo(() => {\n if (nodes.length <= limit) {\n return { nodes, edges };\n }\n\n if (config.gridLayout) {\n return limitGridLayout(nodes, limit, rootId);\n }\n\n return limitGraphLayout(nodes, edges, nodesMap, edgesMap, limit, rootId);\n }, [edges, edgesMap, limit, nodes, nodesMap, rootId, config.gridLayout]);\n}\n\nexport function limitGraphLayout(\n nodes: NodeDatum[],\n edges: EdgeDatumLayout[],\n nodesMap: NodesMap,\n edgesMap: EdgesMap,\n limit: number,\n rootId?: string\n) {\n let roots;\n if (rootId) {\n roots = [nodesMap[rootId]];\n } else {\n roots = nodes.filter((n) => n.incoming === 0);\n // TODO: same code as layout\n if (!roots.length) {\n roots = [nodes[0]];\n }\n }\n\n const { visibleNodes, markers } = collectVisibleNodes(limit, roots, nodesMap, edgesMap);\n\n const markersWithStats = collectMarkerStats(markers, visibleNodes, nodesMap, edgesMap);\n const markersMap = fromPairs(markersWithStats.map((m) => [m.node.id, m]));\n\n for (const marker of markersWithStats) {\n if (marker.count === 1) {\n delete markersMap[marker.node.id];\n visibleNodes[marker.node.id] = marker.node;\n }\n }\n\n // Show all edges between visible nodes or placeholder markers\n const visibleEdges = edges.filter(\n (e) =>\n (visibleNodes[e.source.id] || markersMap[e.source.id]) && (visibleNodes[e.target.id] || markersMap[e.target.id])\n );\n\n return {\n nodes: Object.values(visibleNodes),\n edges: visibleEdges,\n markers: Object.values(markersMap),\n };\n}\n\nexport function limitGridLayout(nodes: NodeDatum[], limit: number, rootId?: string) {\n let start = 0;\n let stop = limit;\n let markers: NodesMarker[] = [];\n\n if (rootId) {\n const index = nodes.findIndex((node) => node.id === rootId);\n const prevLimit = Math.floor(limit / 2);\n let afterLimit = prevLimit;\n start = index - prevLimit;\n if (start < 0) {\n afterLimit += Math.abs(start);\n start = 0;\n }\n stop = index + afterLimit + 1;\n\n if (stop > nodes.length) {\n if (start > 0) {\n start = Math.max(0, start - (stop - nodes.length));\n }\n stop = nodes.length;\n }\n\n if (start > 1) {\n markers.push({ node: nodes[start - 1], count: start });\n }\n\n if (nodes.length - stop > 1) {\n markers.push({ node: nodes[stop], count: nodes.length - stop });\n }\n } else {\n if (nodes.length - limit > 1) {\n markers = [{ node: nodes[limit], count: nodes.length - limit }];\n }\n }\n\n return {\n nodes: nodes.slice(start, stop),\n edges: [],\n markers,\n };\n}\n\n/**\n * Breath first traverse of the graph collecting all the nodes until we reach the limit. It also returns markers which\n * are nodes on the edges which did not make it into the limit but can be used as clickable markers for manually\n * expanding the graph.\n * @param limit\n * @param roots - Nodes where to start the traversal. In case of exploration this can be any node that user clicked on.\n * @param nodesMap - Node id to node\n * @param edgesMap - This is a map of node id to a list of edges (both ingoing and outgoing)\n */\nfunction collectVisibleNodes(\n limit: number,\n roots: NodeDatum[],\n nodesMap: Record<string, NodeDatum>,\n edgesMap: Record<string, EdgeDatumLayout[]>\n): { visibleNodes: Record<string, NodeDatum>; markers: NodeDatum[] } {\n const visibleNodes: Record<string, NodeDatum> = {};\n let stack = [...roots];\n\n while (Object.keys(visibleNodes).length < limit && stack.length > 0) {\n let current = stack.shift()!;\n\n // We are already showing this node. This can happen because graphs can be cyclic\n if (visibleNodes[current!.id]) {\n continue;\n }\n\n // Show this node\n visibleNodes[current.id] = current;\n const edges = edgesMap[current.id] || [];\n\n // Add any nodes that are connected to it on top of the stack to be considered in the next pass\n const connectedNodes = edges.map((e) => {\n // We don't care about direction here. Should not make much difference but argument could be made that with\n // directed graphs it should walk the graph directionally. Problem is when we focus on a node in the middle of\n // graph (not going from the \"natural\" root) we also want to show what was \"before\".\n const id = e.source.id === current.id ? e.target.id : e.source.id;\n return nodesMap[id];\n });\n stack = stack.concat(connectedNodes);\n }\n\n // Right now our stack contains all the nodes which are directly connected to the graph but did not make the cut.\n // Some of them though can be nodes we already are showing so we have to filter them and then use them as markers.\n const markers = uniq(stack.filter((n) => !visibleNodes[n.id]));\n\n return { visibleNodes, markers };\n}\n\nfunction collectMarkerStats(\n markers: NodeDatum[],\n visibleNodes: Record<string, NodeDatum>,\n nodesMap: Record<string, NodeDatum>,\n edgesMap: Record<string, EdgeDatumLayout[]>\n): NodesMarker[] {\n return markers.map((marker) => {\n const nodesToCount: Record<string, NodeDatum> = {};\n let count = 0;\n let stack = [marker];\n while (stack.length > 0 && count <= 101) {\n let current = stack.shift()!;\n\n // We are showing this node so not going to count it as hidden.\n if (visibleNodes[current.id] || nodesToCount[current.id]) {\n continue;\n }\n\n if (!nodesToCount[current.id]) {\n count++;\n }\n nodesToCount[current.id] = current;\n\n const edges = edgesMap[current.id] || [];\n\n const connectedNodes = edges.map((e) => {\n const id = e.source.id === current.id ? e.target.id : e.source.id;\n return nodesMap[id];\n });\n stack = stack.concat(connectedNodes);\n }\n\n return {\n node: marker,\n count: count,\n };\n });\n}\n","import { fromPairs } from 'lodash';\nimport { useEffect, useMemo, useRef, useState } from 'react';\nimport { useUnmount } from 'react-use';\nimport useMountedState from 'react-use/lib/useMountedState';\n\nimport { Field } from '@grafana/data';\n\nimport { createWorker, createMsaglWorker } from './createLayoutWorker';\nimport { LayoutAlgorithm } from './panelcfg.gen';\nimport { EdgeDatum, EdgeDatumLayout, NodeDatum } from './types';\nimport { useNodeLimit } from './useNodeLimit';\nimport { graphBounds } from './utils';\n\nexport interface Config {\n layoutAlgorithm: LayoutAlgorithm;\n linkDistance: number;\n linkStrength: number;\n forceX: number;\n forceXStrength: number;\n forceCollide: number;\n tick: number;\n gridLayout: boolean;\n sort?: {\n // Either a arc field or stats field\n field: Field;\n ascending: boolean;\n };\n}\n\n// Config mainly for the layout but also some other parts like current layout. The layout variables can be changed only\n// if you programmatically enable the config editor (for development only) see ViewControls. These could be moved to\n// panel configuration at some point (apart from gridLayout as that can be switched be user right now.).\nexport const defaultConfig: Config = {\n layoutAlgorithm: LayoutAlgorithm.Layered,\n linkDistance: 150,\n linkStrength: 0.5,\n forceX: 2000,\n forceXStrength: 0.02,\n forceCollide: 100,\n tick: 300,\n gridLayout: false,\n};\n\nexport interface LayoutCache {\n [LayoutAlgorithm.Force]?: { nodes: NodeDatum[]; edges: EdgeDatumLayout[] };\n [LayoutAlgorithm.Layered]?: { nodes: NodeDatum[]; edges: EdgeDatumLayout[] };\n}\n\n/**\n * This will return copy of the nods and edges with x,y positions filled in. Also the layout changes source/target props\n * in edges from string ids to actual nodes.\n */\nexport function useLayout(\n rawNodes: NodeDatum[],\n rawEdges: EdgeDatum[],\n config: Config = defaultConfig,\n nodeCountLimit: number,\n width: number,\n rootNodeId?: string,\n hasFixedPositions?: boolean,\n layoutCache?: LayoutCache\n) {\n const [nodesGraph, setNodesGraph] = useState<NodeDatum[]>([]);\n const [edgesGraph, setEdgesGraph] = useState<EdgeDatumLayout[]>([]);\n\n const [loading, setLoading] = useState(false);\n\n // Store current data signature to detect changes\n const dataSignatureRef = useRef<string>('');\n const currentSignature = createDataSignature(rawNodes, rawEdges);\n\n const isMounted = useMountedState();\n const layoutWorkerCancelRef = useRef<(() => void) | undefined>();\n\n useUnmount(() => {\n if (layoutWorkerCancelRef.current) {\n layoutWorkerCancelRef.current();\n }\n });\n\n // Also we compute both layouts here. Grid layout should not add much time and we can more easily just cache both\n // so this should happen only once for a given response data.\n //\n // Also important note is that right now this works on all the nodes even if they are not visible. This means that\n // the node position is stable even when expanding different parts of graph. It seems like a reasonable thing but\n // implications are that:\n // - limiting visible nodes count does not have a positive perf effect\n // - graphs with high node count can seem weird (very sparse or spread out) when we show only some nodes but layout\n // is done for thousands of nodes but we also do this only once in the graph lifecycle.\n // We could re-layout this on visible nodes change but this may need smaller visible node limit to keep the perf\n // (as we would run layout on every click) and also would be very weird without any animation to understand what is\n // happening as already visible nodes would change positions.\n useEffect(() => {\n if (rawNodes.length === 0) {\n setNodesGraph([]);\n setEdgesGraph([]);\n setLoading(false);\n return;\n }\n\n if (hasFixedPositions) {\n setNodesGraph(rawNodes);\n // The layout function turns source and target fields from string to NodeDatum, so we do that here as well.\n const nodesMap = fromPairs(rawNodes.map((node) => [node.id, node]));\n setEdgesGraph(\n rawEdges.map(\n (e): EdgeDatumLayout => ({\n ...e,\n source: nodesMap[e.source],\n target: nodesMap[e.target],\n })\n )\n );\n setLoading(false);\n return;\n }\n\n // Layered layout is better but also more expensive.\n let layoutType: 'force' | 'layered' = 'force';\n let algorithmType = LayoutAlgorithm.Force;\n\n if (config.layoutAlgorithm === LayoutAlgorithm.Layered) {\n layoutType = 'layered';\n algorithmType = LayoutAlgorithm.Layered;\n }\n\n // Check if data has changed since last render\n const hasDataChanged = dataSignatureRef.current !== currentSignature;\n\n // Clear cache if data has changed\n if (hasDataChanged) {\n dataSignatureRef.current = currentSignature;\n\n if (layoutCache) {\n delete layoutCache[LayoutAlgorithm.Force];\n delete layoutCache[LayoutAlgorithm.Layered];\n }\n }\n\n // Check if we have a cached layout for this algorithm\n if (layoutCache && layoutCache[algorithmType]) {\n setNodesGraph(layoutCache[algorithmType]?.nodes ?? []);\n setEdgesGraph(layoutCache[algorithmType]?.edges ?? []);\n setLoading(false);\n return;\n }\n\n setLoading(true);\n\n const cancel = layout(rawNodes, rawEdges, layoutType, ({ nodes, edges }) => {\n if (isMounted()) {\n setNodesGraph(nodes);\n setEdgesGraph(edges);\n setLoading(false);\n\n // Cache the calculated layout\n if (layoutCache) {\n layoutCache[algorithmType] = { nodes, edges };\n }\n }\n });\n layoutWorkerCancelRef.current = cancel;\n return cancel;\n }, [hasFixedPositions, rawNodes, rawEdges, isMounted, config.layoutAlgorithm, layoutCache, currentSignature]);\n\n // Compute grid separately as it is sync and do not need to be inside effect. Also it is dependant on width while\n // default layout does not care and we don't want to recalculate that on panel resize.\n const [nodesGrid, edgesGrid] = useMemo(() => {\n if (rawNodes.length === 0) {\n return [[], []];\n }\n\n const rawNodesCopy = rawNodes.map((n) => ({ ...n }));\n const rawEdgesCopy = rawEdges.map((e) => ({ ...e }));\n gridLayout(rawNodesCopy, width, config.sort);\n\n return [rawNodesCopy, rawEdgesCopy as EdgeDatumLayout[]];\n }, [config.sort, rawNodes, rawEdges, width]);\n\n // Limit the nodes so we don't show all for performance reasons. Here we don't compute both at the same time so\n // changing the layout can trash internal memoization at the moment.\n const {\n nodes: nodesWithLimit,\n edges: edgesWithLimit,\n markers,\n } = useNodeLimit(\n config.gridLayout ? nodesGrid : nodesGraph,\n config.gridLayout ? edgesGrid : edgesGraph,\n nodeCountLimit,\n config,\n rootNodeId\n );\n\n // Get bounds based on current limited number of nodes.\n const bounds = useMemo(\n () => graphBounds([...nodesWithLimit, ...(markers || []).map((m) => m.node)]),\n [nodesWithLimit, markers]\n );\n\n return {\n nodes: nodesWithLimit,\n edges: edgesWithLimit,\n markers,\n bounds,\n hiddenNodesCount: rawNodes.length - nodesWithLimit.length,\n loading,\n };\n}\n\n/**\n * Wraps the layout code in a worker as it can take long and we don't want to block the main thread.\n * Returns a cancel function to terminate the worker.\n */\nfunction layout(\n nodes: NodeDatum[],\n edges: EdgeDatum[],\n engine: 'force' | 'layered',\n done: (data: { nodes: NodeDatum[]; edges: EdgeDatumLayout[] }) => void\n) {\n const worker = engine === 'force' ? createWorker() : createMsaglWorker();\n\n worker.onmessage = (event: MessageEvent<{ nodes: NodeDatum[]; edges: EdgeDatumLayout[] }>) => {\n const nodesMap = fromPairs(nodes.map((node) => [node.id, node]));\n\n // Add the x,y coordinates from the layout algorithm to the original nodes.\n event.data.nodes = event.data.nodes.map((node) => {\n return {\n ...nodesMap[node.id],\n ...node,\n };\n });\n\n done(event.data);\n };\n\n worker.postMessage({\n nodes: nodes.map((n) => ({\n id: n.id,\n incoming: n.incoming,\n })),\n edges,\n config: defaultConfig,\n });\n\n return () => {\n worker.terminate();\n };\n}\n\n/**\n * Set the nodes in simple grid layout sorted by some stat.\n */\nfunction gridLayout(\n nodes: NodeDatum[],\n width: number,\n sort?: {\n field: Field;\n ascending: boolean;\n }\n) {\n const spacingVertical = 140;\n const spacingHorizontal = 120;\n const padding = spacingHorizontal / 2;\n const perRow = Math.min(Math.floor((width - padding * 2) / spacingVertical), nodes.length);\n const midPoint = Math.floor(((perRow - 1) * spacingHorizontal) / 2);\n\n if (sort) {\n nodes.sort((node1, node2) => {\n const val1 = sort!.field.values[node1.dataFrameRowIndex];\n const val2 = sort!.field.values[node2.dataFrameRowIndex];\n\n // Let's pretend we don't care about type of the stats for a while (they can be strings)\n return sort!.ascending ? val1 - val2 : val2 - val1;\n });\n }\n\n for (const [index, node] of nodes.entries()) {\n const row = Math.floor(index / perRow);\n const column = index % perRow;\n node.x = column * spacingHorizontal - midPoint;\n node.y = -60 + row * spacingVertical;\n }\n}\n\nfunction createDataSignature(nodes: NodeDatum[], edges: EdgeDatum[]): string {\n const signature = [`n:${nodes.length}`, `e:${edges.length}`];\n\n if (nodes.length > 0) {\n const firstNode = nodes[0].id ?? '';\n signature.push(`f:${firstNode}`);\n\n // Middle node (if there are at least 3 nodes)\n if (nodes.length >= 3) {\n const middleIndex = Math.floor(nodes.length / 2);\n const middleNode = nodes[middleIndex].id ?? '';\n signature.push(`m:${middleNode}`);\n }\n\n const lastNode = nodes[nodes.length - 1].id ?? '';\n signature.push(`l:${lastNode}`);\n\n // Add basic connectivity information\n let connectedNodesCount = 0;\n let maxConnections = 0;\n\n for (const node of nodes) {\n const connections = node.incoming || 0;\n if (connections > 0) {\n connectedNodesCount++;\n }\n maxConnections = Math.max(maxConnections, connections);\n }\n\n signature.push(`cn:${connectedNodesCount}`);\n signature.push(`mc:${maxConnections}`);\n }\n\n return signature.join('_');\n}\n","import { css } from '@emotion/css';\nimport { MouseEvent, useCallback, useState } from 'react';\nimport * as React from 'react';\n\nimport { DataFrame, Field, GrafanaTheme2, LinkModel, LinkTarget } from '@grafana/data';\nimport { t } from '@grafana/i18n';\nimport { ContextMenu, MenuGroup, MenuItem, useStyles2 } from '@grafana/ui';\n\nimport { Config } from './layout';\nimport { EdgeDatumLayout, NodeDatum } from './types';\nimport { getEdgeFields, getNodeFields, statToString } from './utils';\n\n/**\n * Hook that contains state of the context menu, both for edges and nodes and provides appropriate component when\n * opened context menu should be opened.\n */\nexport function useContextMenu(\n getLinks: (dataFrame: DataFrame, rowIndex: number) => LinkModel[],\n // This can be undefined if we only use edge dataframe\n nodes: DataFrame | undefined,\n // This can be undefined if we have only single node\n edges: DataFrame | undefined,\n config: Config,\n setConfig: (config: Config) => void,\n setFocusedNodeId: (id: string) => void\n): {\n onEdgeOpen: (event: MouseEvent<SVGElement>, edge: EdgeDatumLayout) => void;\n onNodeOpen: (event: MouseEvent<SVGElement>, node: NodeDatum) => void;\n MenuComponent: React.ReactNode;\n} {\n const [menu, setMenu] = useState<JSX.Element | undefined>(undefined);\n\n const onNodeOpen = useCallback(\n (event: MouseEvent<SVGElement>, node: NodeDatum) => {\n const [label, showGridLayout] = config.gridLayout\n ? ['Show in Graph layout', false]\n : ['Show in Grid layout', true];\n\n const extraNodeItem = [\n {\n label: label,\n onClick: (node: NodeDatum) => {\n setFocusedNodeId(node.id);\n setConfig({ ...config, gridLayout: showGridLayout });\n setMenu(undefined);\n },\n },\n ];\n\n const links = nodes ? getLinks(nodes, node.dataFrameRowIndex) : [];\n const renderer = getItemsRenderer(links, node, extraNodeItem);\n setMenu(makeContextMenu(<NodeHeader node={node} nodes={nodes} />, event, setMenu, renderer));\n },\n [config, nodes, getLinks, setMenu, setConfig, setFocusedNodeId]\n );\n\n const onEdgeOpen = useCallback(\n (event: MouseEvent<SVGElement>, edge: EdgeDatumLayout) => {\n if (!edges) {\n // This could happen if we have only one node and no edges, in which case this is not needed as there is no edge\n // to click on.\n return;\n }\n const links = getLinks(edges, edge.dataFrameRowIndex);\n const renderer = getItemsRenderer(links, edge);\n setMenu(makeContextMenu(<EdgeHeader edge={edge} edges={edges} />, event, setMenu, renderer));\n },\n [edges, getLinks, setMenu]\n );\n\n return { onEdgeOpen, onNodeOpen, MenuComponent: menu };\n}\n\nfunction makeContextMenu(\n header: JSX.Element,\n event: MouseEvent<SVGElement>,\n setMenu: (el: JSX.Element | undefined) => void,\n renderer?: () => React.ReactNode\n) {\n return (\n <ContextMenu\n renderHeader={() => header}\n renderMenuItems={renderer}\n onClose={() => setMenu(undefined)}\n x={event.pageX}\n y={event.pageY - window.scrollY}\n />\n );\n}\n\nfunction getItemsRenderer<T extends NodeDatum | EdgeDatumLayout>(\n links: LinkModel[],\n item: T,\n extraItems?: Array<LinkData<T>> | undefined\n) {\n if (!(links.length || extraItems?.length)) {\n return undefined;\n }\n const items = getItems(links);\n return () => {\n let groups = items?.map((group, index) => (\n <MenuGroup key={`${group.label}${index}`} label={group.label}>\n {(group.items || []).map(mapMenuItem(item))}\n </MenuGroup>\n ));\n\n if (extraItems) {\n groups = [...extraItems.map(mapMenuItem(item)), ...groups];\n }\n return groups;\n };\n}\n\nfunction mapMenuItem<T extends NodeDatum | EdgeDatumLayout>(item: T) {\n return function NodeGraphMenuItem(link: LinkData<T>) {\n return (\n <MenuItem\n key={link.label}\n url={link.url}\n label={link.label}\n ariaLabel={link.ariaLabel}\n onClick={\n link.onClick\n ? (event) => {\n if (!(event?.ctrlKey || event?.metaKey || event?.shiftKey)) {\n event?.preventDefault();\n event?.stopPropagation();\n link.onClick?.(item);\n }\n }\n : undefined\n }\n target={link.target || '_self'}\n />\n );\n };\n}\n\ntype LinkData<T extends NodeDatum | EdgeDatumLayout> = {\n label: string;\n ariaLabel?: string;\n url?: string;\n onClick?: (item: T) => void;\n target?: LinkTarget;\n};\n\nfunction getItems(links: LinkModel[]) {\n const defaultGroup = 'Open in Explore';\n const groups = links.reduce<{ [group: string]: Array<{ l: LinkModel; newTitle?: string }> }>((acc, l) => {\n let group;\n let title;\n if (l.title.indexOf('/') !== -1) {\n group = l.title.split('/')[0];\n title = l.title.split('/')[1];\n acc[group] = acc[group] || [];\n acc[group].push({ l, newTitle: title });\n } else {\n acc[defaultGroup] = acc[defaultGroup] || [];\n acc[defaultGroup].push({ l });\n }\n\n return acc;\n }, {});\n\n return Object.keys(groups).map((key) => {\n return {\n label: key,\n ariaLabel: key,\n items: groups[key].map((link) => ({\n label: link.newTitle || link.l.title,\n ariaLabel: link.newTitle || link.l.title,\n url: link.l.href,\n onClick: link.l.onClick,\n target: link.l.target,\n })),\n };\n });\n}\n\nfunction FieldRow({ field, index }: { field: Field; index: number }) {\n return (\n <HeaderRow\n label={field.config?.displayName || field.name}\n value={statToString(field.config, field.values[index] || '')}\n />\n );\n}\n\nfunction HeaderRow({ label, value }: { label: string; value: string }) {\n const styles = useStyles2(getLabelStyles);\n return (\n <tr>\n <td className={styles.label}>{label}: </td>\n <td className={styles.value}>{value}</td>\n </tr>\n );\n}\n\n/**\n * Shows some field values in a table on top of the context menu.\n */\nfunction NodeHeader({ node, nodes }: { node: NodeDatum; nodes?: DataFrame }) {\n const rows = [];\n if (nodes) {\n const fields = getNodeFields(nodes);\n for (const f of [fields.title, fields.subTitle, fields.mainStat, fields.secondaryStat, ...fields.details]) {\n if (f && f.values[node.dataFrameRowIndex]) {\n rows.push(<FieldRow key={f.name} field={f} index={node.dataFrameRowIndex} />);\n }\n }\n } else {\n // Fallback if we don't have nodes dataFrame. Can happen if we use just the edges frame to construct this.\n if (node.title) {\n rows.push(<HeaderRow key=\"title\" label={t('nodeGraph.node-header.label-title', 'Title')} value={node.title} />);\n }\n if (node.subTitle) {\n rows.push(\n <HeaderRow key=\"subtitle\" label={t('nodeGraph.node-header.label-subtitle', 'Subtitle')} value={node.subTitle} />\n );\n }\n }\n\n return (\n <table style={{ width: '100%' }}>\n <tbody>{rows}</tbody>\n </table>\n );\n}\n\n/**\n * Shows some of the field values in a table on top of the context menu.\n */\nfunction EdgeHeader(props: { edge: EdgeDatumLayout; edges: DataFrame }) {\n const index = props.edge.dataFrameRowIndex;\n const fields = getEdgeFields(props.edges);\n const valueSource = fields.source?.values[index] || '';\n const valueTarget = fields.target?.values[index] || '';\n\n const rows = [];\n if (valueSource && valueTarget) {\n rows.push(\n <HeaderRow\n key={'header-row'}\n label={t('nodeGraph.edge-header.label-source-target', 'Source → Target')}\n value={`${valueSource} → ${valueTarget}`}\n />\n );\n }\n\n for (const f of [fields.mainStat, fields.secondaryStat, ...fields.details]) {\n if (f && f.values[index]) {\n rows.push(<FieldRow key={`field-row-${index}`} field={f} index={index} />);\n }\n }\n\n return (\n <table style={{ width: '100%' }}>\n <tbody>{rows}</tbody>\n </table>\n );\n}\n\nexport const getLabelStyles = (theme: GrafanaTheme2) => {\n return {\n label: css({\n label: 'Label',\n lineHeight: 1.25,\n color: theme.colors.text.disabled,\n fontSize: theme.typography.size.sm,\n fontWeight: theme.typography.fontWeightMedium,\n paddingRight: theme.spacing(1),\n }),\n value: css({\n label: 'Value',\n fontSize: theme.typography.size.sm,\n fontWeight: theme.typography.fontWeightMedium,\n color: theme.colors.text.primary,\n }),\n };\n};\n","import usePrevious from 'react-use/lib/usePrevious';\n\nimport { Config } from './layout';\nimport { NodeDatum } from './types';\n\nexport function useFocusPositionOnLayout(config: Config, nodes: NodeDatum[], focusedNodeId: string | undefined) {\n const prevLayoutGrid = usePrevious(config.gridLayout);\n let focusPosition;\n if (prevLayoutGrid === true && !config.gridLayout && focusedNodeId) {\n const node = nodes.find((n) => n.id === focusedNodeId);\n if (node) {\n focusPosition = {\n x: -node.x!,\n y: -node.y!,\n };\n }\n }\n\n return focusPosition;\n}\n","import { useEffect, useState } from 'react';\nimport useMountedState from 'react-use/lib/useMountedState';\n\nexport function useHighlight(focusedNodeId?: string) {\n const [highlightId, setHighlightId] = useState<string>();\n const mounted = useMountedState();\n useEffect(() => {\n if (focusedNodeId) {\n setHighlightId(focusedNodeId);\n setTimeout(() => {\n if (mounted()) {\n setHighlightId(undefined);\n }\n }, 500);\n }\n }, [focusedNodeId, mounted]);\n\n return highlightId;\n}\n","import { useEffect, useRef, RefObject, useState, useMemo } from 'react';\nimport useMountedState from 'react-use/lib/useMountedState';\nimport usePrevious from 'react-use/lib/usePrevious';\n\nimport { Bounds } from './utils';\n\nexport interface State {\n isPanning: boolean;\n position: {\n x: number;\n y: number;\n };\n}\n\ninterface Options {\n scale?: number;\n bounds?: Bounds;\n focus?: {\n x: number;\n y: number;\n };\n}\n\n/**\n * Based on https://github.com/streamich/react-use/blob/master/src/useSlider.ts\n * Returns position x/y coordinates which can be directly used in transform: translate().\n * @param scale - Can be used when we want to scale the movement if we are moving a scaled element. We need to do it\n * here because we don't want to change the pos when scale changes.\n * @param bounds - If set the panning cannot go outside of those bounds.\n * @param focus - Position to focus on.\n */\nexport function usePanning<T extends Element>({ scale = 1, bounds, focus }: Options = {}): {\n state: State;\n ref: RefObject<T>;\n} {\n const isMounted = useMountedState();\n const isPanning = useRef(false);\n const frame = useRef(0);\n const panRef = useRef<T>(null);\n\n const initial = { x: 0, y: 0 };\n // As we return a diff of the view port to be applied we need as translate coordinates we have to invert the\n // bounds of the content to get the bounds of the view port diff.\n const viewBounds = useMemo(\n () => ({\n right: bounds ? -bounds.left : Infinity,\n left: bounds ? -bounds.right : -Infinity,\n bottom: bounds ? -bounds.top : -Infinity,\n top: bounds ? -bounds.bottom : Infinity,\n }),\n [bounds]\n );\n\n // We need to keep some state so we can compute the position diff and add that to the previous position.\n const startMousePosition = useRef(initial);\n const prevPosition = useRef(initial);\n // We cannot use the state as that would rerun the effect on each state change which we don't want so we have to keep\n // separate variable for the state that won't cause useEffect eval\n const currentPosition = useRef(initial);\n\n const [state, setState] = useState<State>({\n isPanning: false,\n position: initial,\n });\n\n useEffect(() => {\n const startPanning = (event: Event) => {\n if (!isPanning.current && isMounted()) {\n isPanning.current = true;\n // Snapshot the current position of both mouse pointer and the element\n startMousePosition.current = getEventXY(event);\n prevPosition.current = { ...currentPosition.current };\n setState((state) => ({ ...state, isPanning: true }));\n bindEvents();\n }\n };\n\n const stopPanning = () => {\n if (isPanning.current && isMounted()) {\n isPanning.current = false;\n setState((state) => ({ ...state, isPanning: false }));\n unbindEvents();\n }\n };\n\n const onPanStart = (event: Event) => {\n startPanning(event);\n onPan(event);\n };\n\n const bindEvents = () => {\n document.addEventListener('mousemove', onPan);\n document.addEventListener('mouseup', stopPanning);\n document.addEventListener('touchmove', onPan);\n document.addEventListener('touchend', stopPanning);\n };\n\n const unbindEvents = () => {\n document.removeEventListener('mousemove', onPan);\n document.removeEventListener('mouseup', stopPanning);\n document.removeEventListener('touchmove', onPan);\n document.removeEventListener('touchend', stopPanning);\n };\n\n const onPan = (event: Event) => {\n cancelAnimationFrame(frame.current);\n const pos = getEventXY(event);\n\n frame.current = requestAnimationFrame(() => {\n if (isMounted() && panRef.current) {\n // Get the diff by which we moved the mouse.\n let xDiff = pos.x - startMousePosition.current.x;\n let yDiff = pos.y - startMousePosition.current.y;\n\n // Add the diff to the position from the moment we started panning.\n currentPosition.current = {\n x: inBounds(prevPosition.current.x + xDiff / scale, viewBounds.left, viewBounds.right),\n y: inBounds(prevPosition.current.y + yDiff / scale, viewBounds.top, viewBounds.bottom),\n };\n setState((state) => ({\n ...state,\n position: {\n ...currentPosition.current,\n },\n }));\n }\n });\n };\n\n const ref = panRef.current;\n if (ref) {\n ref.addEventListener('mousedown', onPanStart);\n ref.addEventListener('touchstart', onPanStart);\n }\n return () => {\n if (ref) {\n ref.removeEventListener('mousedown', onPanStart);\n ref.removeEventListener('touchstart', onPanStart);\n }\n };\n }, [scale, viewBounds, isMounted]);\n\n const previousFocus = usePrevious(focus);\n\n // We need to update the state in case need to focus on something but we want to do it only once when the focus\n // changes to something new.\n useEffect(() => {\n if (focus && previousFocus?.x !== focus.x && previousFocus?.y !== focus.y) {\n const position = {\n x: inBounds(focus.x, viewBounds.left, viewBounds.right),\n y: inBounds(focus.y, viewBounds.top, viewBounds.bottom),\n };\n setState({\n position,\n isPanning: false,\n });\n\n currentPosition.current = position;\n prevPosition.current = position;\n }\n }, [focus, previousFocus, viewBounds, currentPosition, prevPosition]);\n\n let position = state.position;\n // This part prevents an ugly jump from initial position to the focused one as the set state in the effects is after\n // initial render.\n if (focus && previousFocus?.x !== focus.x && previousFocus?.y !== focus.y) {\n position = focus;\n }\n\n return {\n state: {\n ...state,\n position: {\n x: inBounds(position.x, viewBounds.left, viewBounds.right),\n y: inBounds(position.y, viewBounds.top, viewBounds.bottom),\n },\n },\n ref: panRef,\n };\n}\n\nfunction inBounds(value: number, min: number | undefined, max: number | undefined) {\n return Math.min(Math.max(value, min ?? -Infinity), max ?? Infinity);\n}\n\n// The issue here is that TouchEvent is undefined while using instanceof in Firefox and Safari\n// which will throw an exception but if it's event.changedTouches it will be undefined\n// and the if check will fail so it will go to the else but will not throw an exception\nfunction getEventXY(event: Event): { x: number; y: number } {\n if ('changedTouches' in event && event instanceof TouchEvent) {\n return { x: event.changedTouches[0].clientX, y: event.changedTouches[0].clientY };\n } else if (event instanceof MouseEvent) {\n return { x: event.clientX, y: event.clientY };\n }\n return { x: 0, y: 0 };\n}\n","import { useCallback, useEffect, useRef, useState } from 'react';\n\nimport { ZoomMode } from './panelcfg.gen';\n\nconst defaultOptions: Required<Options> = {\n stepUp: (s) => s * 1.5,\n stepDown: (s) => s / 1.5,\n min: 0.13,\n max: 2.25,\n zoomMode: ZoomMode.Cooperative,\n};\n\ninterface Options {\n /**\n * Allows you to specify how the step up will be handled so you can do fractional steps based on previous value.\n */\n stepUp?: (scale: number) => number;\n stepDown?: (scale: number) => number;\n\n /**\n * Set max and min values. If stepUp/down overshoots these bounds this will return min or max but internal scale value\n * will still be what ever the step functions returned last.\n */\n min?: number;\n max?: number;\n\n /**\n * Sets how to handle zoom events when user is interacting with the page\n */\n zoomMode?: ZoomMode;\n}\n\n/**\n * Keeps state and returns handlers that can be used to implement zooming functionality ideally by using it with\n * 'transform: scale'. It returns handler for manual buttons with zoom in/zoom out function and a ref that can be\n * used to zoom in/out with mouse wheel.\n */\nexport function useZoom(options: Options = defaultOptions) {\n const { min, max, zoomMode } = { ...defaultOptions, ...options };\n const stepUp = options.stepUp ?? defaultOptions.stepUp;\n const stepDown = options.stepDown ?? defaultOptions.stepDown;\n\n const ref = useRef<HTMLElement | null>(null);\n const [scale, setScale] = useState(1);\n\n const onStepUp = useCallback(() => {\n if (scale < (max ?? Infinity)) {\n setScale(stepUp(scale));\n }\n }, [scale, stepUp, max]);\n\n const onStepDown = useCallback(() => {\n if (scale > (min ?? -Infinity)) {\n setScale(stepDown(scale));\n }\n }, [scale, stepDown, min]);\n\n const onWheel = useCallback(\n function (wheelEvent: WheelEvent) {\n // Seems like typing for the addEventListener is lacking a bit\n\n // Only do this with special key pressed similar to how google maps work.\n // TODO: I would guess this won't work very well with touch right now\n if (wheelEvent.ctrlKey || wheelEvent.metaKey || zoomMode === ZoomMode.Greedy) {\n wheelEvent.preventDefault();\n\n setScale(Math.min(Math.max(min ?? -Infinity, scale + Math.min(wheelEvent.deltaY, 2) * -0.01), max ?? Infinity));\n\n if (wheelEvent.deltaY < 0) {\n const newScale = scale + Math.max(wheelEvent.deltaY, -4) * -0.015;\n setScale(Math.max(min ?? -Infinity, newScale));\n } else if (wheelEvent.deltaY > 0) {\n const newScale = scale + Math.min(wheelEvent.deltaY, 4) * -0.015;\n setScale(Math.min(max ?? Infinity, newScale));\n }\n }\n },\n [min, max, scale, zoomMode]\n );\n\n useEffect(() => {\n if (!ref.current) {\n return;\n }\n\n const zoomRef = ref.current;\n\n // Adds listener for wheel event, we need the passive: false to be able to prevent default otherwise that\n // cannot be used with passive listeners.\n zoomRef.addEventListener('wheel', onWheel, { passive: false });\n return () => {\n if (zoomRef) {\n zoomRef.removeEventListener('wheel', onWheel);\n }\n };\n }, [onWheel]);\n\n return {\n onStepUp,\n onStepDown,\n scale: Math.max(Math.min(scale, max ?? Infinity), min ?? -Infinity),\n isMax: scale >= (max ?? Infinity),\n isMin: scale <= (min ?? -Infinity),\n ref,\n };\n}\n","import { css } from '@emotion/css';\nimport cx from 'classnames';\nimport { memo, MouseEvent, useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport useMeasure from 'react-use/lib/useMeasure';\n\nimport { DataFrame, GrafanaTheme2, LinkModel } from '@grafana/data';\nimport { Trans, t } from '@grafana/i18n';\nimport { Icon, RadioButtonGroup, Spinner, useStyles2 } from '@grafana/ui';\n\nimport { Edge } from './Edge';\nimport { EdgeLabel } from './EdgeLabel';\nimport { Legend } from './Legend';\nimport { Marker } from './Marker';\nimport { Node } from './Node';\nimport { ViewControls } from './ViewControls';\nimport { Config, defaultConfig, useLayout, LayoutCache } from './layout';\nimport { LayoutAlgorithm } from './panelcfg.gen';\nimport { EdgeDatumLayout, NodeDatum, NodesMarker, ZoomMode } from './types';\nimport { useCategorizeFrames } from './useCategorizeFrames';\nimport { useContextMenu } from './useContextMenu';\nimport { useFocusPositionOnLayout } from './useFocusPositionOnLayout';\nimport { useHighlight } from './useHighlight';\nimport { usePanning } from './usePanning';\nimport { useZoom } from './useZoom';\nimport { processNodes, Bounds, findConnectedNodesForEdge, findConnectedNodesForNode } from './utils';\n\nconst getStyles = (theme: GrafanaTheme2) => ({\n wrapper: css({\n label: 'wrapper',\n height: '100%',\n width: '100%',\n overflow: 'hidden',\n position: 'relative',\n }),\n\n svg: css({\n label: 'svg',\n height: '100%',\n width: '100%',\n overflow: 'visible',\n fontSize: '10px',\n cursor: 'move',\n }),\n\n svgPanning: css({\n label: 'svgPanning',\n userSelect: 'none',\n }),\n\n noDataMsg: css({\n height: '100%',\n width: '100%',\n display: 'grid',\n placeItems: 'center',\n fontSize: theme.typography.h4.fontSize,\n color: theme.colors.text.secondary,\n }),\n\n mainGroup: css({\n label: 'mainGroup',\n willChange: 'transform',\n }),\n\n viewControls: css({\n label: 'viewControls',\n position: 'absolute',\n left: '2px',\n bottom: '3px',\n right: 0,\n display: 'flex',\n alignItems: 'flex-end',\n justifyContent: 'space-between',\n pointerEvents: 'none',\n }),\n layoutAlgorithm: css({\n label: 'layoutAlgorithm',\n pointerEvents: 'all',\n position: 'absolute',\n top: '8px',\n right: '8px',\n zIndex: 1,\n }),\n legend: css({\n label: 'legend',\n background: theme.colors.background.secondary,\n boxShadow: theme.shadows.z1,\n paddingBottom: '5px',\n marginRight: '10px',\n }),\n viewControlsWrapper: css({\n marginLeft: 'auto',\n }),\n alert: css({\n label: 'alert',\n padding: '5px 8px',\n fontSize: '10px',\n textShadow: '0 1px 0 rgba(0, 0, 0, 0.2)',\n borderRadius: theme.shape.radius.default,\n alignItems: 'center',\n position: 'absolute',\n right: 0,\n background: theme.colors.warning.main,\n color: theme.colors.warning.contrastText,\n }),\n loadingWrapper: css({\n label: 'loadingWrapper',\n height: '100%',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n }),\n});\n\n// Limits the number of visible nodes, mainly for performance reasons. Nodes above the limit are accessible by expanding\n// parts of the graph. The specific number is arbitrary but should be a number of nodes where panning, zooming and other\n// interactions will be without any lag for most users.\nconst defaultNodeCountLimit = 200;\n\nexport const layeredLayoutThreshold = 500;\n\ninterface Props {\n dataFrames: DataFrame[];\n getLinks: (dataFrame: DataFrame, rowIndex: number) => LinkModel[];\n nodeLimit?: number;\n panelId?: string;\n zoomMode?: ZoomMode;\n layoutAlgorithm?: LayoutAlgorithm;\n}\nexport function NodeGraph({ getLinks, dataFrames, nodeLimit, panelId, zoomMode, layoutAlgorithm }: Props) {\n const nodeCountLimit = nodeLimit || defaultNodeCountLimit;\n const { edges: edgesDataFrames, nodes: nodesDataFrames } = useCategorizeFrames(dataFrames);\n\n const [measureRef, { width, height }] = useMeasure();\n const [config, setConfig] = useState<Config>(defaultConfig);\n\n // Layout cache to avoid recalculating layouts\n const layoutCacheRef = useRef<LayoutCache>({});\n\n // Update the config when layoutAlgorithm changes via the panel options\n useEffect(() => {\n if (layoutAlgorithm) {\n setConfig((prevConfig) => {\n return {\n ...prevConfig,\n gridLayout: layoutAlgorithm === LayoutAlgorithm.Grid,\n layoutAlgorithm,\n };\n });\n }\n }, [layoutAlgorithm]);\n\n const firstNodesDataFrame = nodesDataFrames[0];\n const firstEdgesDataFrame = edgesDataFrames[0];\n\n // Ensure we use unique IDs for the marker tip elements, since IDs are global\n // in the entire HTML document. This prevents hidden tips when an earlier\n // occurence is hidden (editor is open in front of an existing node graph\n // panel) or when the earlier tips have different properties (color, size, or\n // shape for example).\n const svgIdNamespace = panelId || 'nodegraphpanel';\n\n // TODO we should be able to allow multiple dataframes for both edges and nodes, could be issue with node ids which in\n // that case should be unique or figure a way to link edges and nodes dataframes together.\n const processed = useMemo(\n () => processNodes(firstNodesDataFrame, firstEdgesDataFrame),\n [firstEdgesDataFrame, firstNodesDataFrame]\n );\n\n // We need hover state here because for nodes we also highlight edges and for edges have labels separate to make\n // sure they are visible on top of everything else\n const { nodeHover, setNodeHover, clearNodeHover, edgeHover, setEdgeHover, clearEdgeHover } = useHover();\n const [hoveringIds, setHoveringIds] = useState<string[]>([]);\n useEffect(() => {\n let linked: string[] = [];\n if (nodeHover) {\n linked = findConnectedNodesForNode(processed.nodes, processed.edges, nodeHover);\n } else if (edgeHover) {\n linked = findConnectedNodesForEdge(processed.nodes, processed.edges, edgeHover);\n }\n setHoveringIds(linked);\n }, [nodeHover, edgeHover, processed]);\n\n // This is used for navigation from grid to graph view. This node will be centered and briefly highlighted.\n const [focusedNodeId, setFocusedNodeId] = useState<string>();\n const setFocused = useCallback((e: MouseEvent, m: NodesMarker) => setFocusedNodeId(m.node.id), [setFocusedNodeId]);\n\n // May seem weird that we do layout first and then limit the nodes shown but the problem is we want to keep the node\n // position stable which means we need the full layout first and then just visually hide the nodes. As hiding/showing\n // nodes should not have effect on layout it should not be recalculated.\n const { nodes, edges, markers, bounds, hiddenNodesCount, loading } = useLayout(\n processed.nodes,\n processed.edges,\n config,\n nodeCountLimit,\n width,\n focusedNodeId,\n processed.hasFixedPositions,\n layoutCacheRef.current\n );\n\n // If we move from grid to graph layout, and we have focused node lets get its position to center there. We want to\n // do it specifically only in that case.\n const focusPosition = useFocusPositionOnLayout(config, nodes, focusedNodeId);\n const { panRef, zoomRef, onStepUp, onStepDown, isPanning, position, scale, isMaxZoom, isMinZoom } = usePanAndZoom(\n bounds,\n focusPosition,\n zoomMode\n );\n\n const { onEdgeOpen, onNodeOpen, MenuComponent } = useContextMenu(\n getLinks,\n firstNodesDataFrame,\n firstEdgesDataFrame,\n config,\n setConfig,\n setFocusedNodeId\n );\n const styles = useStyles2(getStyles);\n\n // This cannot be inline func, or it will create infinite render cycle.\n const topLevelRef = useCallback(\n (r: HTMLDivElement) => {\n measureRef(r);\n zoomRef.current = r;\n },\n [measureRef, zoomRef]\n );\n\n const highlightId = useHighlight(focusedNodeId);\n\n const handleLayoutChange = (cfg: Config) => {\n if (cfg.layoutAlgorithm !== config.layoutAlgorithm) {\n setFocusedNodeId(undefined);\n }\n setConfig(cfg);\n };\n\n // Clear the layout cache when data changes\n useEffect(() => {\n layoutCacheRef.current = {};\n }, [firstNodesDataFrame, firstEdgesDataFrame]);\n\n return (\n <div ref={topLevelRef} className={styles.wrapper}>\n {loading ? (\n <div className={styles.loadingWrapper}>\n <Trans i18nKey=\"nodeGraph.node-graph.computing-layout\">Computing layout</Trans> \n <Spinner />\n </div>\n ) : null}\n\n {!panelId && (\n <div className={styles.layoutAlgorithm}>\n <RadioButtonGroup\n size=\"sm\"\n options={[\n { label: 'Layered', value: LayoutAlgorithm.Layered },\n { label: 'Force', value: LayoutAlgorithm.Force },\n { label: 'Grid', value: LayoutAlgorithm.Grid },\n ]}\n value={config.gridLayout ? LayoutAlgorithm.Grid : config.layoutAlgorithm}\n onChange={(value) => {\n handleLayoutChange({\n ...config,\n gridLayout: value === LayoutAlgorithm.Grid,\n layoutAlgorithm: value,\n });\n }}\n />\n </div>\n )}\n\n {dataFrames.length && processed.nodes.length ? (\n <svg\n ref={panRef}\n viewBox={`${-(width / 2)} ${-(height / 2)} ${width} ${height}`}\n className={cx(styles.svg, isPanning && styles.svgPanning)}\n >\n <g\n className={styles.mainGroup}\n style={{ transform: `scale(${scale}) translate(${Math.floor(position.x)}px, ${Math.floor(position.y)}px)` }}\n >\n {!config.gridLayout && (\n <Edges\n edges={edges}\n nodeHoveringId={nodeHover}\n edgeHoveringId={edgeHover}\n onClick={onEdgeOpen}\n onMouseEnter={setEdgeHover}\n onMouseLeave={clearEdgeHover}\n svgIdNamespace={svgIdNamespace}\n processedNodesLength={processed.nodes.length}\n processedEdgesLength={processed.edges.length}\n />\n )}\n <Nodes\n nodes={nodes}\n onMouseEnter={setNodeHover}\n onMouseLeave={clearNodeHover}\n onClick={onNodeOpen}\n hoveringIds={hoveringIds || [highlightId]}\n />\n\n <Markers markers={markers || []} onClick={setFocused} />\n {/*We split the labels from edges so that they are shown on top of everything else*/}\n {!config.gridLayout && <EdgeLabels edges={edges} nodeHoveringId={nodeHover} edgeHoveringId={edgeHover} />}\n </g>\n </svg>\n ) : (\n <div className={styles.noDataMsg}>\n <Trans i18nKey=\"nodeGraph.node-graph.no-data\">No data</Trans>\n </div>\n )}\n\n <div className={styles.viewControls}>\n {nodes.length ? (\n <div className={styles.legend}>\n <Legend\n sortable={config.gridLayout}\n nodes={nodes}\n sort={config.sort}\n onSort={(sort) => {\n setConfig({\n ...config,\n sort: sort,\n });\n }}\n />\n </div>\n ) : null}\n\n <div className={styles.viewControlsWrapper}>\n <ViewControls<Config>\n config={config}\n onConfigChange={handleLayoutChange}\n onMinus={onStepDown}\n onPlus={onStepUp}\n scale={scale}\n disableZoomIn={isMaxZoom}\n disableZoomOut={isMinZoom}\n />\n </div>\n </div>\n\n {hiddenNodesCount > 0 && (\n <div\n className={styles.alert}\n style={{ top: panelId ? '0px' : '40px' }} // panelId is undefined in Explore\n aria-label={t('nodeGraph.node-graph.aria-label-nodes-hidden-warning', 'Nodes hidden warning')}\n >\n <Trans i18nKey=\"nodeGraph.node-graph.hidden-nodes\" count={hiddenNodesCount}>\n <Icon size=\"sm\" name={'info-circle'} /> {'{{count}}'} nodes are hidden for performance reasons.\n </Trans>\n </div>\n )}\n\n {config.layoutAlgorithm === LayoutAlgorithm.Layered && processed.nodes.length > layeredLayoutThreshold && (\n <div\n className={styles.alert}\n style={{ top: panelId ? '30px' : '70px' }}\n aria-label={t(\n 'nodeGraph.node-graph.aria-label-layered-layout-performance-warning',\n 'Layered layout performance warning'\n )}\n >\n <Trans i18nKey=\"nodeGraph.node-graph.processed-nodes\" count={processed.nodes.length}>\n <Icon size=\"sm\" name={'exclamation-triangle'} /> Layered layout may be slow with {'{{count}}'} nodes.\n </Trans>\n </div>\n )}\n\n {MenuComponent}\n </div>\n );\n}\n\n// Active -> emphasized, inactive -> de-emphasized, and default -> normal styling\nexport type HoverState = 'active' | 'inactive' | 'default';\n\n// These components are here as a perf optimisation to prevent going through all nodes and edges on every pan/zoom.\ninterface NodesProps {\n nodes: NodeDatum[];\n onMouseEnter: (id: string) => void;\n onMouseLeave: (id: string) => void;\n onClick: (event: MouseEvent<SVGElement>, node: NodeDatum) => void;\n hoveringIds?: string[];\n}\nconst Nodes = memo(function Nodes(props: NodesProps) {\n return (\n <>\n {props.nodes.map((n) => (\n <Node\n key={n.id}\n node={n}\n onMouseEnter={props.onMouseEnter}\n onMouseLeave={props.onMouseLeave}\n onClick={props.onClick}\n hovering={\n !props.hoveringIds || props.hoveringIds.length === 0\n ? 'default'\n : props.hoveringIds?.includes(n.id)\n ? 'active'\n : 'inactive'\n }\n />\n ))}\n </>\n );\n});\n\ninterface MarkersProps {\n markers: NodesMarker[];\n onClick: (event: MouseEvent<SVGElement>, marker: NodesMarker) => void;\n}\nconst Markers = memo(function Nodes(props: MarkersProps) {\n return (\n <>\n {props.markers.map((m) => (\n <Marker key={'marker-' + m.node.id} marker={m} onClick={props.onClick} />\n ))}\n </>\n );\n});\n\ninterface EdgesProps {\n edges: EdgeDatumLayout[];\n nodeHoveringId?: string;\n edgeHoveringId?: string;\n svgIdNamespace: string;\n onClick: (event: MouseEvent<SVGElement>, link: EdgeDatumLayout) => void;\n onMouseEnter: (id: string) => void;\n onMouseLeave: (id: string) => void;\n processedNodesLength: number;\n processedEdgesLength: number;\n}\nconst Edges = memo(function Edges(props: EdgesProps) {\n return (\n <>\n {props.edges.map((e, index) => {\n return (\n <Edge\n key={`${e.id}-${e.source.y ?? ''}-${props.processedNodesLength}-${props.processedEdgesLength}-${index}`}\n edge={e}\n hovering={\n (e.source as NodeDatum).id === props.nodeHoveringId ||\n (e.target as NodeDatum).id === props.nodeHoveringId ||\n props.edgeHoveringId === e.id\n }\n onClick={props.onClick}\n onMouseEnter={props.onMouseEnter}\n onMouseLeave={props.onMouseLeave}\n svgIdNamespace={props.svgIdNamespace}\n />\n );\n })}\n </>\n );\n});\n\ninterface EdgeLabelsProps {\n edges: EdgeDatumLayout[];\n nodeHoveringId?: string;\n edgeHoveringId?: string;\n}\nconst EdgeLabels = memo(function EdgeLabels(props: EdgeLabelsProps) {\n return (\n <>\n {props.edges.map((e) => {\n // We show the edge label in case user hovers over the edge directly or if they hover over node edge is\n // connected to.\n const shouldShow =\n (e.source as NodeDatum).id === props.nodeHoveringId ||\n (e.target as NodeDatum).id === props.nodeHoveringId ||\n props.edgeHoveringId === e.id;\n\n const hasStats = e.mainStat || e.secondaryStat;\n return shouldShow && hasStats && <EdgeLabel key={e.id} edge={e} />;\n })}\n </>\n );\n});\n\nfunction usePanAndZoom(bounds: Bounds, focus?: { x: number; y: number }, zoomMode?: ZoomMode) {\n const { scale, onStepDown, onStepUp, ref, isMax, isMin } = useZoom({ zoomMode });\n const { state: panningState, ref: panRef } = usePanning<SVGSVGElement>({\n scale,\n bounds,\n focus,\n });\n const { position, isPanning } = panningState;\n return { zoomRef: ref, panRef, position, isPanning, scale, onStepDown, onStepUp, isMaxZoom: isMax, isMinZoom: isMin };\n}\n\nfunction useHover() {\n const [nodeHover, setNodeHover] = useState<string | undefined>(undefined);\n const clearNodeHover = useCallback(() => setNodeHover(undefined), [setNodeHover]);\n const [edgeHover, setEdgeHover] = useState<string | undefined>(undefined);\n const clearEdgeHover = useCallback(() => setEdgeHover(undefined), [setEdgeHover]);\n\n return { nodeHover, setNodeHover, clearNodeHover, edgeHover, setEdgeHover, clearEdgeHover };\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isNavigator = exports.isBrowser = exports.off = exports.on = exports.noop = void 0;\nvar noop = function () { };\nexports.noop = noop;\nfunction on(obj) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n if (obj && obj.addEventListener) {\n obj.addEventListener.apply(obj, args);\n }\n}\nexports.on = on;\nfunction off(obj) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n if (obj && obj.removeEventListener) {\n obj.removeEventListener.apply(obj, args);\n }\n}\nexports.off = off;\nexports.isBrowser = typeof window !== 'undefined';\nexports.isNavigator = typeof navigator !== 'undefined';\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar tslib_1 = require(\"tslib\");\nvar react_1 = require(\"react\");\nvar useIsomorphicLayoutEffect_1 = tslib_1.__importDefault(require(\"./useIsomorphicLayoutEffect\"));\nvar util_1 = require(\"./misc/util\");\nvar defaultState = {\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n};\nfunction useMeasure() {\n var _a = react_1.useState(null), element = _a[0], ref = _a[1];\n var _b = react_1.useState(defaultState), rect = _b[0], setRect = _b[1];\n var observer = react_1.useMemo(function () {\n return new window.ResizeObserver(function (entries) {\n if (entries[0]) {\n var _a = entries[0].contentRect, x = _a.x, y = _a.y, width = _a.width, height = _a.height, top_1 = _a.top, left = _a.left, bottom = _a.bottom, right = _a.right;\n setRect({ x: x, y: y, width: width, height: height, top: top_1, left: left, bottom: bottom, right: right });\n }\n });\n }, []);\n useIsomorphicLayoutEffect_1.default(function () {\n if (!element)\n return;\n observer.observe(element);\n return function () {\n observer.disconnect();\n };\n }, [element]);\n return [ref, rect];\n}\nexports.default = util_1.isBrowser && typeof window.ResizeObserver !== 'undefined'\n ? useMeasure\n : (function () { return [util_1.noop, defaultState]; });\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = require(\"react\");\nfunction usePrevious(state) {\n var ref = react_1.useRef();\n react_1.useEffect(function () {\n ref.current = state;\n });\n return ref.current;\n}\nexports.default = usePrevious;\n","import { useMemo } from 'react';\n\nimport { DataFrame } from '@grafana/data';\n\nimport { getGraphFrame } from './utils';\n\n/**\n * As we need 2 dataframes for the service map, one with nodes and one with edges we have to figure out which is which.\n * Right now we do not have any metadata for it so we just check preferredVisualisationType and then column names.\n * TODO: maybe we could use column labels to have a better way to do this\n */\nexport function useCategorizeFrames(series: DataFrame[]) {\n return useMemo(() => {\n return getGraphFrame(series);\n }, [series]);\n}\n"],"names":["ZoomMode","LayoutAlgorithm","exports","react_1","util_1","useIsomorphicLayoutEffect","EdgeArrowMarker","id","fill","defaultEdgeColor","headHeight","defaultHighlightedEdgeColor","Edge","props","edge","onClick","onMouseEnter","onMouseLeave","hovering","svgIdNamespace","source","target","sourceNodeRadius","targetNodeRadius","arrowHeadHeight","line","edgeColor","highlightedEdgeColor","markerId","coloredMarkerId","event","getStyles","theme","EdgeLabel","middle","styles","stats","x","height","middleOffset","offset","contents","stat","index","Legend","nodes","onSort","sort","sortable","colorItems","getColorLegendItems","item","VizLegend","VizLegendListItem","Icon","fields","node","n","f","nodeR","Marker","marker","ViewControls","config","onConfigChange","onPlus","onMinus","disableZoomOut","disableZoomIn","showConfig","setShowConfig","allowConfiguration","Stack","Button","k","e","createWorker","createMsaglWorker","useNodeLimit","edges","limit","rootId","edgesMap","nodesMap","acc","limitGridLayout","limitGraphLayout","roots","visibleNodes","markers","collectVisibleNodes","markersWithStats","collectMarkerStats","markersMap","m","visibleEdges","start","stop","prevLimit","afterLimit","stack","current","connectedNodes","nodesToCount","count","defaultConfig","useLayout","rawNodes","rawEdges","nodeCountLimit","width","rootNodeId","hasFixedPositions","layoutCache","nodesGraph","setNodesGraph","edgesGraph","setEdgesGraph","loading","setLoading","dataSignatureRef","currentSignature","createDataSignature","isMounted","useMountedState","layoutWorkerCancelRef","useUnmount","layoutType","algorithmType","cancel","layout","nodesGrid","edgesGrid","rawNodesCopy","rawEdgesCopy","gridLayout","nodesWithLimit","edgesWithLimit","bounds","engine","done","worker","perRow","midPoint","node1","node2","val1","val2","row","column","signature","firstNode","middleIndex","middleNode","lastNode","connectedNodesCount","maxConnections","connections","useContextMenu","getLinks","setConfig","setFocusedNodeId","menu","setMenu","onNodeOpen","label","showGridLayout","extraNodeItem","links","renderer","getItemsRenderer","makeContextMenu","NodeHeader","EdgeHeader","header","ContextMenu","extraItems","items","getItems","groups","group","MenuGroup","mapMenuItem","link","MenuItem","defaultGroup","l","title","key","FieldRow","field","HeaderRow","value","getLabelStyles","rows","valueSource","valueTarget","useFocusPositionOnLayout","focusedNodeId","prevLayoutGrid","usePrevious","focusPosition","useHighlight","highlightId","setHighlightId","mounted","usePanning","scale","focus","isPanning","frame","panRef","initial","viewBounds","startMousePosition","prevPosition","currentPosition","state","setState","startPanning","getEventXY","bindEvents","stopPanning","unbindEvents","onPanStart","onPan","pos","xDiff","yDiff","inBounds","ref","previousFocus","position","min","max","defaultOptions","s","useZoom","options","zoomMode","stepUp","stepDown","setScale","onStepUp","onStepDown","onWheel","wheelEvent","newScale","zoomRef","defaultNodeCountLimit","layeredLayoutThreshold","NodeGraph","dataFrames","nodeLimit","panelId","layoutAlgorithm","edgesDataFrames","nodesDataFrames","useCategorizeFrames","measureRef","useMeasure","layoutCacheRef","prevConfig","firstNodesDataFrame","firstEdgesDataFrame","processed","nodeHover","setNodeHover","clearNodeHover","edgeHover","setEdgeHover","clearEdgeHover","useHover","hoveringIds","setHoveringIds","linked","setFocused","hiddenNodesCount","isMaxZoom","isMinZoom","usePanAndZoom","onEdgeOpen","MenuComponent","topLevelRef","r","handleLayoutChange","cfg","Spinner","RadioButtonGroup","Edges","Nodes","Markers","EdgeLabels","Node","shouldShow","hasStats","isMax","isMin","panningState","noop","on","obj","args","_i","off","tslib_1","useIsomorphicLayoutEffect_1","defaultState","_a","element","_b","rect","setRect","observer","entries","y","top_1","left","bottom","right","series"],"sourceRoot":""}
.
Edit
..
Edit
1117.145ac642f59357bc40d8.js
Edit
1117.145ac642f59357bc40d8.js.map
Edit
1118.c684d1aadf16a6c70620.js
Edit
1118.c684d1aadf16a6c70620.js.map
Edit
1122.5fbf0d7cd148c610616d.js
Edit
1122.5fbf0d7cd148c610616d.js.map
Edit
1142.a4b35a0e8699cafd901e.js
Edit
1142.a4b35a0e8699cafd901e.js.map
Edit
1162.81868b3ac499fa5ea04b.js
Edit
1162.81868b3ac499fa5ea04b.js.map
Edit
1183.7444f51e5996a7f23c7d.js
Edit
1183.7444f51e5996a7f23c7d.js.map
Edit
1282.ae38cac1b732d8ac1d96.js
Edit
1282.ae38cac1b732d8ac1d96.js.map
Edit
130.a58aaeea748f37ee6482.js
Edit
130.a58aaeea748f37ee6482.js.map
Edit
1419.59f53ae25085b28e1e11.js
Edit
1419.59f53ae25085b28e1e11.js.map
Edit
1420.e63ce495727f83b8887d.js
Edit
1420.e63ce495727f83b8887d.js.map
Edit
1438.ccdd05d7188edf4191ff.js
Edit
1438.ccdd05d7188edf4191ff.js.map
Edit
1446.fe7b1f4563629b80793f.js
Edit
1446.fe7b1f4563629b80793f.js.map
Edit
1484.3da94e44ecdadcd342d4.js
Edit
1484.3da94e44ecdadcd342d4.js.map
Edit
1492.4026c6e7130c3afdae87.js
Edit
1494.ef220afb67ff6c52c7af.js
Edit
1494.ef220afb67ff6c52c7af.js.map
Edit
1560.538cd2395be11ba4e2c9.js
Edit
1560.538cd2395be11ba4e2c9.js.map
Edit
1579.c391ef869d4f7bfc0d1c.js
Edit
1579.c391ef869d4f7bfc0d1c.js.map
Edit
1646.d7d87a40853795910533.js
Edit
1646.d7d87a40853795910533.js.map
Edit
1710.7db3f56c6714c0c340e0.js
Edit
1710.7db3f56c6714c0c340e0.js.map
Edit
1716.f71f518289da5d2229bc.js
Edit
1716.f71f518289da5d2229bc.js.map
Edit
1740.baf38e7ee007e1a6935e.js
Edit
1740.baf38e7ee007e1a6935e.js.map
Edit
1821.c9a2456dc8d78cf6b02f.js
Edit
1821.c9a2456dc8d78cf6b02f.js.map
Edit
1888.d33142738af4fbf8a230.js
Edit
1888.d33142738af4fbf8a230.js.map
Edit
1914.5f33b3c2133b5bb7ea6e.js
Edit
1914.5f33b3c2133b5bb7ea6e.js.map
Edit
198.65a768ff6c601d19ea3f.js
Edit
198.65a768ff6c601d19ea3f.js.map
Edit
1990.9171129a8deabb59bf30.js
Edit
1990.9171129a8deabb59bf30.js.map
Edit
2018.5ff00ee0456301c1cf43.js
Edit
2018.5ff00ee0456301c1cf43.js.map
Edit
205.2eb73847215c8d021cc9.js
Edit
205.2eb73847215c8d021cc9.js.map
Edit
2077.a5848ca4b4b9fdebca17.js
Edit
2077.a5848ca4b4b9fdebca17.js.map
Edit
2094.97e7f0876201e76a77fd.js
Edit
2094.97e7f0876201e76a77fd.js.map
Edit
2150.7576285186c713978b39.js
Edit
2150.7576285186c713978b39.js.map
Edit
2152.b55841e6f422682a3891.js
Edit
2152.b55841e6f422682a3891.js.map
Edit
221.0fc4d14d0a67f3a25d64.js
Edit
221.0fc4d14d0a67f3a25d64.js.map
Edit
2218.623d73bd0985ddf5f8c4.js
Edit
2218.623d73bd0985ddf5f8c4.js.map
Edit
2223.e65417164a45701ed9dc.js
Edit
2223.e65417164a45701ed9dc.js.map
Edit
2244.70c156ada2487a05595c.js
Edit
2244.70c156ada2487a05595c.js.map
Edit
2278.f887de0a65e1b784ea9f.js
Edit
2278.f887de0a65e1b784ea9f.js.map
Edit
2288.6a65ba08c6c0f4f83435.js
Edit
2288.6a65ba08c6c0f4f83435.js.map
Edit
2311.73e1a2b949d289f5d6c9.js
Edit
2311.73e1a2b949d289f5d6c9.js.map
Edit
2398.d142e32be48079fc63c0.js
Edit
2398.d142e32be48079fc63c0.js.map
Edit
2405.c1b37a7cc8182472f6a6.js
Edit
2405.c1b37a7cc8182472f6a6.js.map
Edit
2446.0418c7ea000998178d8b.js
Edit
2446.0418c7ea000998178d8b.js.map
Edit
2450.d73c024ff7273aebf911.js
Edit
2450.d73c024ff7273aebf911.js.map
Edit
2586.668c65b61e9ea31b5bca.js
Edit
2586.668c65b61e9ea31b5bca.js.map
Edit
265.ed6933785cc750cbd9ed.js
Edit
265.ed6933785cc750cbd9ed.js.map
Edit
2658.7f70ebc378803654a814.js
Edit
2658.7f70ebc378803654a814.js.map
Edit
2686.ae267304ddd1380c30c7.js
Edit
2686.ae267304ddd1380c30c7.js.map
Edit
2692.fa24ada7d987a7ee05f1.js
Edit
2692.fa24ada7d987a7ee05f1.js.map
Edit
2699.b79e57051a1a63376320.js
Edit
2699.b79e57051a1a63376320.js.map
Edit
2710.e1ac8e57578a838f5bd8.js
Edit
2710.e1ac8e57578a838f5bd8.js.map
Edit
2744.d6b14bf01022bdb8eab5.js
Edit
2744.d6b14bf01022bdb8eab5.js.map
Edit
2745.8049d948cb362dfc6cb3.js
Edit
2745.8049d948cb362dfc6cb3.js.map
Edit
2835.01beb5b1a252d779aad7.js
Edit
2835.01beb5b1a252d779aad7.js.map
Edit
2961.4b27b21453fdbb115dd4.js
Edit
2961.4b27b21453fdbb115dd4.js.map
Edit
2962.85c9dc0cca68efab5e0c.js
Edit
2962.85c9dc0cca68efab5e0c.js.map
Edit
2975.e64aaea6ff35a7d3b3fd.js
Edit
2975.e64aaea6ff35a7d3b3fd.js.map
Edit
3003.f51365051eb27cf765d8.js
Edit
3003.f51365051eb27cf765d8.js.map
Edit
3042.44bad7d2d0536000b808.js
Edit
3042.44bad7d2d0536000b808.js.map
Edit
3062.ad5844391370fcc7525a.js
Edit
3062.ad5844391370fcc7525a.js.map
Edit
3082.704af6779ad700a5fa42.js
Edit
3082.704af6779ad700a5fa42.js.map
Edit
3096.aed61083f1ba4803ae84.js
Edit
3096.aed61083f1ba4803ae84.js.map
Edit
3126.10c85e1f02105e470a69.js
Edit
3126.10c85e1f02105e470a69.js.map
Edit
3169.0b88a5a2340f70961599.js
Edit
3169.0b88a5a2340f70961599.js.map
Edit
3171.c79c28e2611563e2dbcb.js
Edit
3171.c79c28e2611563e2dbcb.js.map
Edit
3182.831f754ed3b6f10441a0.js
Edit
3182.831f754ed3b6f10441a0.js.map
Edit
3192.2cb90eadf3399270363e.js
Edit
3192.2cb90eadf3399270363e.js.map
Edit
3217.c6faaa4f5637068f90f3.js
Edit
3217.c6faaa4f5637068f90f3.js.map
Edit
3259.c8e4d6ad93201a56e49f.js
Edit
3259.c8e4d6ad93201a56e49f.js.map
Edit
3284.79c2897655286b0c1f6d.js
Edit
3284.79c2897655286b0c1f6d.js.map
Edit
3303.225dae64cff0c2280c3b.js
Edit
3303.225dae64cff0c2280c3b.js.map
Edit
3326.cabc370d66d7ecfbd2c3.js
Edit
3326.cabc370d66d7ecfbd2c3.js.map
Edit
344.85cff3029cbbb5463c7e.js
Edit
344.85cff3029cbbb5463c7e.js.map
Edit
3466.fda7da0cb4150e59da98.js
Edit
3466.fda7da0cb4150e59da98.js.map
Edit
3474.74dfd856a9528c758a57.js
Edit
3474.74dfd856a9528c758a57.js.map
Edit
348.fd20e2547f12dbed76c7.js
Edit
348.fd20e2547f12dbed76c7.js.map
Edit
3495.9c1ae6f61edf7aef207b.js
Edit
3495.9c1ae6f61edf7aef207b.js.map
Edit
3501.a0ee7c2b24136aa91eb5.js
Edit
3501.a0ee7c2b24136aa91eb5.js.map
Edit
3520.a3c2b474e2dcaf9879fc.js
Edit
3520.a3c2b474e2dcaf9879fc.js.map
Edit
3605.41e3c44dfe2ca2966198.js
Edit
3605.41e3c44dfe2ca2966198.js.map
Edit
362.e5ce68af98ee6713a4e7.js
Edit
362.e5ce68af98ee6713a4e7.js.map
Edit
3622.0b196041f825b42c5233.js
Edit
3622.0b196041f825b42c5233.js.map
Edit
3630.1ffe9229d5c27fd0823a.js
Edit
3630.1ffe9229d5c27fd0823a.js.map
Edit
3659.f5dc1bb19d36546aadb8.js
Edit
3659.f5dc1bb19d36546aadb8.js.map
Edit
3688.ec5e74c60569e9498687.js
Edit
3688.ec5e74c60569e9498687.js.map
Edit
3718.b570aa4fa35f8dfc686e.js
Edit
3718.b570aa4fa35f8dfc686e.js.map
Edit
3726.84ef8bb1304f7adbc7f3.js
Edit
3726.84ef8bb1304f7adbc7f3.js.map
Edit
398.ceeafcf522343c717c4b.js
Edit
398.ceeafcf522343c717c4b.js.map
Edit
4064.e52eb763993ad947e4a1.js
Edit
4064.e52eb763993ad947e4a1.js.map
Edit
407.594046bd73cc88c29e80.js
Edit
407.594046bd73cc88c29e80.js.map
Edit
4113.3fa5432815c4662eb03e.js
Edit
4113.3fa5432815c4662eb03e.js.map
Edit
4114.c4741f0a73781d3f87dc.js
Edit
4114.c4741f0a73781d3f87dc.js.map
Edit
4120.968e1408d894f8515330.js
Edit
4120.968e1408d894f8515330.js.map
Edit
4162.8b8a683fa98d677f9137.js
Edit
4162.8b8a683fa98d677f9137.js.map
Edit
4209.de7f2b850ee1292a67e5.js
Edit
4209.de7f2b850ee1292a67e5.js.map
Edit
4224.cc13db0c6e3f7fdb05c9.js
Edit
4224.cc13db0c6e3f7fdb05c9.js.map
Edit
4251.28e90ad13c8fe749062c.js
Edit
4251.28e90ad13c8fe749062c.js.map
Edit
4334.396d65b7ba31733108e9.js
Edit
4334.396d65b7ba31733108e9.js.map
Edit
4350.6db49924324f8061d361.js
Edit
4350.6db49924324f8061d361.js.map
Edit
4463.24a3e34bed64cbbb8b99.js
Edit
4463.24a3e34bed64cbbb8b99.js.map
Edit
4514.03e966fee9064d7305dd.js
Edit
4514.03e966fee9064d7305dd.js.map
Edit
4564.ea4a09ba96ddbf74a0ee.js
Edit
4564.ea4a09ba96ddbf74a0ee.js.map
Edit
46.7809585ddbb4791e248a.js
Edit
46.7809585ddbb4791e248a.js.map
Edit
4630.54d7f3b9d384c6b95bbc.js
Edit
4630.54d7f3b9d384c6b95bbc.js.map
Edit
4656.a07d832134b096826a58.js
Edit
4656.a07d832134b096826a58.js.map
Edit
468.d3a2ba8b0d226ca1475b.js
Edit
468.d3a2ba8b0d226ca1475b.js.map
Edit
4680.abd86af55b75e75326ab.js
Edit
4680.abd86af55b75e75326ab.js.map
Edit
4691.2f69f76af87a66a1513c.js
Edit
4691.2f69f76af87a66a1513c.js.map
Edit
4698.c9a2c562b12da12dc66e.js
Edit
4698.c9a2c562b12da12dc66e.js.map
Edit
4791.fc3ef0337811ab73b164.js
Edit
4791.fc3ef0337811ab73b164.js.map
Edit
4814.2d8cb562606e508512d8.js
Edit
4814.2d8cb562606e508512d8.js.map
Edit
4824.2da8107f19d58bf153e0.js
Edit
4824.2da8107f19d58bf153e0.js.map
Edit
4839.f4d2edd5c2678ef2b624.js
Edit
4839.f4d2edd5c2678ef2b624.js.map
Edit
4857.4971a98037d2ec3b663d.js
Edit
4857.4971a98037d2ec3b663d.js.map
Edit
4865.be02c1283a83523c4414.js
Edit
4865.be02c1283a83523c4414.js.map
Edit
494.5463fc5a297eaedd150f.js
Edit
494.5463fc5a297eaedd150f.js.map
Edit
4958.226af5f19bf47305a407.js
Edit
4958.226af5f19bf47305a407.js.map
Edit
4962.bbff24c5a85e9314600a.js
Edit
4962.bbff24c5a85e9314600a.js.map
Edit
4964.1f2cc5acc0078feb7b08.js
Edit
4964.1f2cc5acc0078feb7b08.js.map
Edit
4965.ccdc00d808390be53820.js
Edit
4965.ccdc00d808390be53820.js.map
Edit
5065.a2c71dab50ccb4174ee2.js
Edit
5065.a2c71dab50ccb4174ee2.js.map
Edit
5074.92e2d1ae98dcd913506e.js
Edit
5074.92e2d1ae98dcd913506e.js.map
Edit
5091.987ffc33b70121541e5d.js
Edit
5091.987ffc33b70121541e5d.js.map
Edit
5106.581eaf66a6592320d97a.js
Edit
5106.581eaf66a6592320d97a.js.map
Edit
5110.96d49ea826be96c65045.js
Edit
5110.96d49ea826be96c65045.js.map
Edit
5130.cbdddcd716a093bdbaac.js
Edit
5130.cbdddcd716a093bdbaac.js.map
Edit
5196.9b7364caf64a8583ad01.js
Edit
5196.9b7364caf64a8583ad01.js.map
Edit
5198.2cd64d4e16a385dd9b91.js
Edit
5198.2cd64d4e16a385dd9b91.js.map
Edit
5280.2c29942977baa2dfbe0e.js
Edit
5280.2c29942977baa2dfbe0e.js.map
Edit
5364.0288d9c98f74f26b73e7.js
Edit
5364.0288d9c98f74f26b73e7.js.map
Edit
5446.ad01d0b233122dd49849.js
Edit
5446.ad01d0b233122dd49849.js.map
Edit
5550.5bf3e7d23d6b104740fd.js
Edit
5550.5bf3e7d23d6b104740fd.js.map
Edit
5618.909592bbe054b70f2377.js
Edit
5618.909592bbe054b70f2377.js.map
Edit
5648.a1fc2b0cbbca9bfa1d94.js
Edit
5648.a1fc2b0cbbca9bfa1d94.js.map
Edit
5664.c55be32f6d459ac3f3d8.js
Edit
5664.c55be32f6d459ac3f3d8.js.map
Edit
5671.e1e396b75d7b95ef461f.js
Edit
5671.e1e396b75d7b95ef461f.js.map
Edit
5742.117597ec799ab75cb2f4.js
Edit
5742.117597ec799ab75cb2f4.js.map
Edit
5747.b9389680058c12ffba68.js
Edit
5747.b9389680058c12ffba68.js.map
Edit
5757.5a4b7f2368dd09da42be.js
Edit
5786.c45dfaf9e1d969472e5e.js
Edit
5786.c45dfaf9e1d969472e5e.js.map
Edit
5790.29b0a5797fd46e9664f5.js
Edit
5790.29b0a5797fd46e9664f5.js.map
Edit
5923.b9c876b4bf528d8511cb.js
Edit
5923.b9c876b4bf528d8511cb.js.map
Edit
5984.1efdc4bb85100bd19ca9.js
Edit
5984.1efdc4bb85100bd19ca9.js.map
Edit
5995.5c7a375f33ea1cd16daa.js
Edit
5995.5c7a375f33ea1cd16daa.js.map
Edit
6018.befdd11bf701ea71f7bf.js
Edit
6018.befdd11bf701ea71f7bf.js.map
Edit
6029.bdcbf27bcdd36812f646.js
Edit
6029.bdcbf27bcdd36812f646.js.map
Edit
6088.7f526abfdb4003574c68.js
Edit
6088.7f526abfdb4003574c68.js.map
Edit
613.084d33252856771cf6e1.js
Edit
613.084d33252856771cf6e1.js.map
Edit
6185.2a7c893c6b3f2f0dadb8.js
Edit
6185.2a7c893c6b3f2f0dadb8.js.map
Edit
6208.571f272269524cfd14e7.js
Edit
6208.571f272269524cfd14e7.js.map
Edit
6236.30d1fa6aee173c946c50.js
Edit
6236.30d1fa6aee173c946c50.js.map
Edit
6244.64f83fc5d05560979c51.js
Edit
6244.64f83fc5d05560979c51.js.map
Edit
6260.b8be95165766a81dade2.js
Edit
6260.b8be95165766a81dade2.js.map
Edit
630.56b78dcdaeeb9d9c2967.js
Edit
630.56b78dcdaeeb9d9c2967.js.map
Edit
6302.a2ffa52069511df9772f.js
Edit
6302.a2ffa52069511df9772f.js.map
Edit
6315.f4d87fc6f8ae3cb40e38.js
Edit
6315.f4d87fc6f8ae3cb40e38.js.map
Edit
6414.7520859a2d9cc0a63d7f.js
Edit
6414.7520859a2d9cc0a63d7f.js.map
Edit
6446.1d75a8140260005fffbd.js
Edit
6446.1d75a8140260005fffbd.js.map
Edit
6743.67a52a99e2fdd1ae1e10.js
Edit
6743.67a52a99e2fdd1ae1e10.js.map
Edit
6759.0454d3c1e41385379bdc.js
Edit
6759.0454d3c1e41385379bdc.js.map
Edit
6772.0d4a074848bc323be8f8.js
Edit
6772.0d4a074848bc323be8f8.js.map
Edit
680.726adca366b4ecb272db.js
Edit
680.726adca366b4ecb272db.js.map
Edit
6830.a4b0ecf3a6d784ca7609.js
Edit
6830.a4b0ecf3a6d784ca7609.js.map
Edit
6834.0c9ef40e2f2b5428983d.js
Edit
6834.0c9ef40e2f2b5428983d.js.map
Edit
6857.252a60422ee275193aa7.js
Edit
6857.252a60422ee275193aa7.js.map
Edit
6940.b6c74df14413f0188f0d.js
Edit
6940.b6c74df14413f0188f0d.js.map
Edit
6990.d663924714fc213b17c6.js
Edit
6990.d663924714fc213b17c6.js.map
Edit
7018.5a037d2577fedc8d10f1.js
Edit
7018.5a037d2577fedc8d10f1.js.map
Edit
7031.047b15171c23b248efa0.js
Edit
7031.047b15171c23b248efa0.js.map
Edit
7033.141597840e42815ef6a4.js
Edit
7033.141597840e42815ef6a4.js.map
Edit
7048.3746fc9a274bf8ff72f1.js
Edit
7048.3746fc9a274bf8ff72f1.js.map
Edit
7051.604a402d305e093c00c2.js
Edit
7051.604a402d305e093c00c2.js.map
Edit
7061.f18464bcd6c6d7455662.js
Edit
7061.f18464bcd6c6d7455662.js.map
Edit
7080.9cdd1b7a0bf62b48e1fe.js
Edit
7080.9cdd1b7a0bf62b48e1fe.js.map
Edit
7200.d4425528f6cee80f9931.js
Edit
7200.d4425528f6cee80f9931.js.map
Edit
7235.46f071d3e4d0bb976223.js
Edit
7235.46f071d3e4d0bb976223.js.map
Edit
7246.03f5a8496e53f64602e2.js
Edit
7246.03f5a8496e53f64602e2.js.map
Edit
7249.3bea4aaf890f89fdad45.js
Edit
7249.3bea4aaf890f89fdad45.js.map
Edit
7299.cdff402b076dfea09ead.js
Edit
7299.cdff402b076dfea09ead.js.map
Edit
7348.6fd722455e8c7e077815.js
Edit
7348.6fd722455e8c7e077815.js.map
Edit
7396.ded473b7a47dc42fbb59.js
Edit
7396.ded473b7a47dc42fbb59.js.map
Edit
7466.b7c17c526c7b734dd5f7.js
Edit
7466.b7c17c526c7b734dd5f7.js.map
Edit
7539.5f405cae3b15e1e2f6fa.js
Edit
7539.5f405cae3b15e1e2f6fa.js.map
Edit
7585.084552e02c66201a55be.js
Edit
7585.084552e02c66201a55be.js.map
Edit
7626.38819cc0696f2d25cf99.js
Edit
7626.38819cc0696f2d25cf99.js.map
Edit
7651.5024ed8dd1beb08d01ab.js
Edit
7651.5024ed8dd1beb08d01ab.js.map
Edit
7681.7ef7b4f86e99abd7b7e1.js
Edit
7681.7ef7b4f86e99abd7b7e1.js.map
Edit
7691.0ad86f0c686b19ce829e.js
Edit
7691.0ad86f0c686b19ce829e.js.map
Edit
7790.4c141092868e7208a087.js
Edit
7790.4c141092868e7208a087.js.map
Edit
7806.dff3509790e494ca5a45.js
Edit
7806.dff3509790e494ca5a45.js.map
Edit
7836.afe37ef4be354f0a3b91.js
Edit
7836.afe37ef4be354f0a3b91.js.map
Edit
7882.e1721e9d6ac2d421bcda.js
Edit
7882.e1721e9d6ac2d421bcda.js.map
Edit
7886.8499ded396232466be7d.js
Edit
7886.8499ded396232466be7d.js.map
Edit
7887.a6dcfd824d57598ba1c3.js
Edit
7887.a6dcfd824d57598ba1c3.js.map
Edit
7969.a048d8060cabf1aede33.js
Edit
7969.a048d8060cabf1aede33.js.map
Edit
7996.bd232896e4559d37a26f.js
Edit
7996.bd232896e4559d37a26f.js.map
Edit
8016.8145cd87abcdd0646db2.js
Edit
8016.8145cd87abcdd0646db2.js.map
Edit
8018.c31846109f2dff21d8c4.js
Edit
8018.c31846109f2dff21d8c4.js.map
Edit
8056.4e8f71ed4d507f89b487.js
Edit
8056.4e8f71ed4d507f89b487.js.map
Edit
8177.52abd0953ac914f69e26.js
Edit
8177.52abd0953ac914f69e26.js.map
Edit
8220.aeea4a8f0893b3447b56.js
Edit
8220.aeea4a8f0893b3447b56.js.map
Edit
8224.75bd73bf51ff7a2fc4a0.js
Edit
8224.75bd73bf51ff7a2fc4a0.js.map
Edit
8230.d65bce2998eec95c6082.js
Edit
8230.d65bce2998eec95c6082.js.map
Edit
8260.c1da67af19b9259d5651.js
Edit
8260.c1da67af19b9259d5651.js.map
Edit
8271.0ee36e030014244adb47.js
Edit
8271.0ee36e030014244adb47.js.map
Edit
8332.a62e8632a336661f2969.js
Edit
8332.a62e8632a336661f2969.js.map
Edit
8334.1196f5ddcef25711fc25.js
Edit
8334.1196f5ddcef25711fc25.js.map
Edit
8347.de402f9280cd7a316c57.js
Edit
8347.de402f9280cd7a316c57.js.map
Edit
8390.9de755da2e214cc845a3.js
Edit
8390.9de755da2e214cc845a3.js.map
Edit
8393.30e95ae45cbe5455dcda.js
Edit
8393.30e95ae45cbe5455dcda.js.map
Edit
8477.4dad0537d13cf9315e86.js
Edit
8477.4dad0537d13cf9315e86.js.map
Edit
8494.659892f00c9d15ae441a.js
Edit
8494.659892f00c9d15ae441a.js.map
Edit
8530.0460c988ee4a40ce7769.js
Edit
8530.0460c988ee4a40ce7769.js.map
Edit
8542.317c15ed57f68fcf0c97.js
Edit
8542.317c15ed57f68fcf0c97.js.map
Edit
8547.390120a5caf7646e0e3e.js
Edit
8547.390120a5caf7646e0e3e.js.map
Edit
8566.5c8f392bb383ab92eed0.js
Edit
8566.5c8f392bb383ab92eed0.js.map
Edit
8622.5acf73c1485a11dfb0ab.js
Edit
8622.5acf73c1485a11dfb0ab.js.map
Edit
8706.f17afa6bcdfd511d5b03.js
Edit
8706.f17afa6bcdfd511d5b03.js.map
Edit
874.d24410518317d605c708.js
Edit
874.d24410518317d605c708.js.map
Edit
8813.e5137844631f6ddedbce.js
Edit
8813.e5137844631f6ddedbce.js.map
Edit
8856.2720526447b3adb5c75f.js
Edit
8856.2720526447b3adb5c75f.js.map
Edit
886.5f3383e84b10a6530b97.js
Edit
886.5f3383e84b10a6530b97.js.map
Edit
8864.2f4ee982114c25634e55.js
Edit
8864.2f4ee982114c25634e55.js.map
Edit
8902.71f14964ec6cea84dc8e.js
Edit
8902.71f14964ec6cea84dc8e.js.map
Edit
8932.e59e50ddb63414e0f2b9.js
Edit
8932.e59e50ddb63414e0f2b9.js.map
Edit
8990.665213a5c89afd6b2f83.js
Edit
8990.665213a5c89afd6b2f83.js.map
Edit
9034.a32e36472481cbe5d72d.js
Edit
9034.a32e36472481cbe5d72d.js.map
Edit
9038.f03b25f160057d4a0bf6.js
Edit
9038.f03b25f160057d4a0bf6.js.map
Edit
904.b68cd2a0cd6d68c5f1ae.js
Edit
904.b68cd2a0cd6d68c5f1ae.js.map
Edit
9044.441f64d6d946cc93be46.js
Edit
9044.441f64d6d946cc93be46.js.map
Edit
9147.8309cadbc384209d62e5.js
Edit
9147.8309cadbc384209d62e5.js.map
Edit
9150.38487365ffd149b730af.js
Edit
9150.38487365ffd149b730af.js.map
Edit
9292.e6befb57f8f116ad95a8.js
Edit
9292.e6befb57f8f116ad95a8.js.map
Edit
9355.95d7e1782f93f339549e.js
Edit
9355.95d7e1782f93f339549e.js.map
Edit
9388.88d95a230e9432e7037b.js
Edit
9388.88d95a230e9432e7037b.js.map
Edit
9390.c72fcd228017f7647b38.js
Edit
9390.c72fcd228017f7647b38.js.map
Edit
9414.642bfe0d5eb16efd0c16.js
Edit
9414.642bfe0d5eb16efd0c16.js.map
Edit
9449.502f2a824d0203e88d4d.js
Edit
9449.502f2a824d0203e88d4d.js.map
Edit
946.48c5e8c688cf29424295.js
Edit
946.48c5e8c688cf29424295.js.map
Edit
9473.e6fc327da88d88712828.js
Edit
9473.e6fc327da88d88712828.js.map
Edit
9510.1e255e96fe40aad2ed6f.js
Edit
9510.1e255e96fe40aad2ed6f.js.map
Edit
9521.e65411d726c29d77c526.js
Edit
9521.e65411d726c29d77c526.js.map
Edit
9538.a2289ff9ad06e24e391f.js
Edit
9538.a2289ff9ad06e24e391f.js.map
Edit
957.3c35d66aa698d8bdfe05.js
Edit
957.3c35d66aa698d8bdfe05.js.map
Edit
9571.41558d40bff9ea8c0726.js
Edit
9571.41558d40bff9ea8c0726.js.map
Edit
9578.9cfae16465bb9bc1f336.js
Edit
9578.9cfae16465bb9bc1f336.js.map
Edit
968.d4b150f9211c478b7b05.js
Edit
968.d4b150f9211c478b7b05.js.map
Edit
970.46f17b76711e4961a575.js
Edit
970.46f17b76711e4961a575.js.map
Edit
9700.02180b7a06c8a1f7606b.js
Edit
9700.02180b7a06c8a1f7606b.js.map
Edit
9744.aa6baaf988a68fa6a9ba.js
Edit
9744.aa6baaf988a68fa6a9ba.js.map
Edit
9820.6b462d83575efd05c883.js
Edit
9820.6b462d83575efd05c883.js.map
Edit
9838.06bd7dfd4290786f80e3.js
Edit
9838.06bd7dfd4290786f80e3.js.map
Edit
9992.fb08517d3ff77e887443.js
Edit
9992.fb08517d3ff77e887443.js.map
Edit
9996.21c451f22ff76b4bb683.js
Edit
9996.21c451f22ff76b4bb683.js.map
Edit
AdminAuthentication.076c98c6380fd1e42f7e.js
Edit
AdminAuthentication.076c98c6380fd1e42f7e.js.map
Edit
AdminEditOrgPage.8df8167ea6ff8f4803bd.js
Edit
AdminEditOrgPage.8df8167ea6ff8f4803bd.js.map
Edit
AdminListOrgsPage.176dac9ed391bda8952b.js
Edit
AdminListOrgsPage.176dac9ed391bda8952b.js.map
Edit
AdminSettings.7373ed8fa9b943bb2098.js
Edit
AdminSettings.7373ed8fa9b943bb2098.js.map
Edit
AlertGroups.81264e6e5009c36eed6e.js
Edit
AlertGroups.81264e6e5009c36eed6e.js.map
Edit
AlertRuleListIndex.98e7328feeaa2ffe67eb.js
Edit
AlertRuleListIndex.98e7328feeaa2ffe67eb.js.map
Edit
AlertingDisabled.b2c834be0ca4666dd793.js
Edit
AlertingDisabled.b2c834be0ca4666dd793.js.map
Edit
AlertingGroupDetails.3a2c6ef8085b505852e4.js
Edit
AlertingGroupDetails.3a2c6ef8085b505852e4.js.map
Edit
AlertingGroupEdit.69cfe9d5f37a1fc65326.js
Edit
AlertingGroupEdit.69cfe9d5f37a1fc65326.js.map
Edit
AlertingHome.06f307ab9a2a5d8b7f93.js
Edit
AlertingHome.06f307ab9a2a5d8b7f93.js.map
Edit
AlertingImportFromDSRules.f1224bcb622d25e2c94f.js
Edit
AlertingImportFromDSRules.f1224bcb622d25e2c94f.js.map
Edit
AlertingRedirectToRule.9ed1d16829d6833d2827.js
Edit
AlertingRedirectToRule.9ed1d16829d6833d2827.js.map
Edit
AlertingRuleForm.2e69d3f00eb6221e7355.js
Edit
AlertingRuleForm.2e69d3f00eb6221e7355.js.map
Edit
AlertingSettings.7a5f782f877cec4790cb.js
Edit
AlertingSettings.7a5f782f877cec4790cb.js.map
Edit
AlertingTriage.1174f36b4937ad0047c1.js
Edit
AlertingTriage.1174f36b4937ad0047c1.js.map
Edit
BenchmarksPage.ef387f4598ba2b2236ad.js
Edit
BenchmarksPage.ef387f4598ba2b2236ad.js.map
Edit
BookmarksPage.8fe93eb7377073f0c985.js
Edit
BookmarksPage.8fe93eb7377073f0c985.js.map
Edit
ChangePasswordPage.f21b0b1dd107ccd33c1a.js
Edit
ChangePasswordPage.f21b0b1dd107ccd33c1a.js.map
Edit
Connections.949b6389e73bcadb2109.js
Edit
Connections.949b6389e73bcadb2109.js.map
Edit
ContactPoints.9ae2d1927d60c6169b87.js
Edit
ContactPoints.9ae2d1927d60c6169b87.js.map
Edit
CorrelationsFeatureToggle.ec2f1aefce6b456e15eb.js
Edit
CorrelationsFeatureToggle.ec2f1aefce6b456e15eb.js.map
Edit
CorrelationsPage.bd7fcd24ed0b5fe8ac3e.js
Edit
CorrelationsPage.bd7fcd24ed0b5fe8ac3e.js.map
Edit
CreateTeam.429acf93986740280312.js
Edit
CreateTeam.429acf93986740280312.js.map
Edit
DashboardImport.3e9b6f980b81d6f1c755.js
Edit
DashboardImport.3e9b6f980b81d6f1c755.js.map
Edit
DashboardListPage.abeb0c29f072f888f9fb.js
Edit
DashboardListPage.abeb0c29f072f888f9fb.js.map
Edit
DashboardPage.72557fe6dd1a022b7d48.js
Edit
DashboardPage.72557fe6dd1a022b7d48.js.map
Edit
DashboardPageProxy.80adfefad8a885d8e2ef.js
Edit
DashboardPageProxy.80adfefad8a885d8e2ef.js.map
Edit
DashboardScenePage.83fe1fa9509b50120d65.js
Edit
DashboardScenePage.83fe1fa9509b50120d65.js.map
Edit
EditContactPoint.0c33428ddc8ba974d946.js
Edit
EditContactPoint.0c33428ddc8ba974d946.js.map
Edit
EditMuteTiming.8760cc9c77560acf0cd6.js
Edit
EditMuteTiming.8760cc9c77560acf0cd6.js.map
Edit
EditRepositoryPage.d71faaab1af2c8d70a22.js
Edit
EditRepositoryPage.d71faaab1af2c8d70a22.js.map
Edit
EmbeddedDashboard.57de550bce819e3d52e6.js
Edit
EmbeddedDashboard.57de550bce819e3d52e6.js.map
Edit
FileHistoryPage.154ab77c19bbe0ebed20.js
Edit
FileHistoryPage.154ab77c19bbe0ebed20.js.map
Edit
FileStatusPage.36f58cd61202ec603d22.js
Edit
FileStatusPage.36f58cd61202ec603d22.js.map
Edit
FolderAlerting.0b9acb6c42276aaee57d.js
Edit
FolderAlerting.0b9acb6c42276aaee57d.js.map
Edit
FolderLibraryPanelsPage.44f8cabf542ec314d176.js
Edit
FolderLibraryPanelsPage.44f8cabf542ec314d176.js.map
Edit
GettingStartedPage.4bea37f1c9bdcfd0f41b.js
Edit
GettingStartedPage.4bea37f1c9bdcfd0f41b.js.map
Edit
GlobalConfig.1377596507974d18caf6.js
Edit
GlobalConfig.1377596507974d18caf6.js.map
Edit
HistoryPage.4da98f4fa313ee3676ca.js
Edit
HistoryPage.4da98f4fa313ee3676ca.js.map
Edit
LdapSettingsPage.0e9f08d5e59150ecf466.js
Edit
LdapSettingsPage.0e9f08d5e59150ecf466.js.map
Edit
LibraryPanelsPage.824580d7751526c658e2.js
Edit
LibraryPanelsPage.824580d7751526c658e2.js.map
Edit
ListPublicDashboardPage.64c26ffd3ebe6c9076f3.js
Edit
ListPublicDashboardPage.64c26ffd3ebe6c9076f3.js.map
Edit
LoginPage.db48423ed1b455431daa.js
Edit
LoginPage.db48423ed1b455431daa.js.map
Edit
MetricsDrilldownRedirect.fcad4bdff346974952f4.js
Edit
MetricsDrilldownRedirect.fcad4bdff346974952f4.js.map
Edit
MigrateToCloud.5b474ad00e8a3d979750.js
Edit
MigrateToCloud.5b474ad00e8a3d979750.js.map
Edit
NewMuteTiming.2f6302420674f1c73aba.js
Edit
NewMuteTiming.2f6302420674f1c73aba.js.map
Edit
NewOrgPage.be31eaee06e2043d609b.js
Edit
NewOrgPage.be31eaee06e2043d609b.js.map
Edit
NewReceiverView.f1d83eb66a39882b8661.js
Edit
NewReceiverView.f1d83eb66a39882b8661.js.map
Edit
NewSilencePage.2643a48031f7e5d8f376.js
Edit
NewSilencePage.2643a48031f7e5d8f376.js.map
Edit
NotificationPoliciesPage.9333d10ecad1452ebf27.js
Edit
NotificationPoliciesPage.9333d10ecad1452ebf27.js.map
Edit
NotificationsPage.57df4ff5ba1433a4345d.js
Edit
NotificationsPage.57df4ff5ba1433a4345d.js.map
Edit
OrgDetailsPage.7b5835c30585aae81343.js
Edit
OrgDetailsPage.7b5835c30585aae81343.js.map
Edit
PlaylistEditPage.8310e384af659e40c313.js
Edit
PlaylistEditPage.8310e384af659e40c313.js.map
Edit
PlaylistNewPage.f45b642a98a747e28c0d.js
Edit
PlaylistNewPage.f45b642a98a747e28c0d.js.map
Edit
PlaylistPage.9af74957a1cdfb125338.js
Edit
PlaylistPage.9af74957a1cdfb125338.js.map
Edit
PlaylistStartPage.8011a98267ac64c7fa05.js
Edit
PlaylistStartPage.8011a98267ac64c7fa05.js.map
Edit
PluginExtensionsLog.54c02047d569b0c05823.js
Edit
PluginExtensionsLog.54c02047d569b0c05823.js.map
Edit
PluginListPage.e50c18fed21c23ca4ee8.js
Edit
PluginListPage.e50c18fed21c23ca4ee8.js.map
Edit
PluginPage.ae424531bce63dd4721e.js
Edit
PluginPage.ae424531bce63dd4721e.js.map
Edit
ProfileFeatureTogglePage.27378dcbb7520611348e.js
Edit
ProfileFeatureTogglePage.27378dcbb7520611348e.js.map
Edit
ProvisioningWizardPage.c4e4a8f431b4719b0e95.js
Edit
ProvisioningWizardPage.c4e4a8f431b4719b0e95.js.map
Edit
PublicDashboardPage.33d6ec8f685f1b70b9a6.js
Edit
PublicDashboardPage.33d6ec8f685f1b70b9a6.js.map
Edit
RecentlyDeleted.5e0ec16474d939fd9683.js
Edit
RecentlyDeleted.5e0ec16474d939fd9683.js.map
Edit
RecentlyDeletedPage.1dbc2b80b28204de8237.js
Edit
RecentlyDeletedPage.1dbc2b80b28204de8237.js.map
Edit
RepositoryListPage.ec3a0af1cbe2740800bf.js
Edit
RepositoryListPage.ec3a0af1cbe2740800bf.js.map
Edit
RepositoryStatusPage.9aee60589e35a4a19ec2.js
Edit
RepositoryStatusPage.9aee60589e35a4a19ec2.js.map
Edit
SelectOrgPage.910a8d842019a6d7fe93.js
Edit
SelectOrgPage.910a8d842019a6d7fe93.js.map
Edit
SendResetMailPage.513361d6980f98ff8139.js
Edit
SendResetMailPage.513361d6980f98ff8139.js.map
Edit
ServerStats.2830ca154f465dbdecea.js
Edit
ServerStats.2830ca154f465dbdecea.js.map
Edit
ServiceAccountCreatePage.80fcbdd2b7f5aa4e2da1.js
Edit
ServiceAccountCreatePage.80fcbdd2b7f5aa4e2da1.js.map
Edit
ServiceAccountPage.48944056459bb412ff33.js
Edit
ServiceAccountPage.48944056459bb412ff33.js.map
Edit
ServiceAccountsPage.d20b1eb9f87661f10b45.js
Edit
ServiceAccountsPage.d20b1eb9f87661f10b45.js.map
Edit
SignupInvited.fe2c29f380e9888c28cf.js
Edit
SignupInvited.fe2c29f380e9888c28cf.js.map
Edit
SilencesTablePage.b998fdbdcc3d60a81739.js
Edit
SilencesTablePage.b998fdbdcc3d60a81739.js.map
Edit
SnapshotListPage.6feaf24adb92e6a302ec.js
Edit
SnapshotListPage.6feaf24adb92e6a302ec.js.map
Edit
SoloPanelPage.7fc6a934aaadf4c1f84d.js
Edit
SoloPanelPage.7fc6a934aaadf4c1f84d.js.map
Edit
SoloPanelPageOld.bde57e000dd0a0108685.js
Edit
SoloPanelPageOld.bde57e000dd0a0108685.js.map
Edit
SupportBundles.1f46603ad3494624d67a.js
Edit
SupportBundles.1f46603ad3494624d67a.js.map
Edit
SupportBundlesCreate.5eaea61a9713f057277b.js
Edit
SupportBundlesCreate.5eaea61a9713f057277b.js.map
Edit
TeamList.6b088f83e6e8cb66b21d.js
Edit
TeamList.6b088f83e6e8cb66b21d.js.map
Edit
TeamPages.9d8b5dceef8be43c6923.js
Edit
TeamPages.9d8b5dceef8be43c6923.js.map
Edit
Templates.7a02a8497ebca052dcfb.js
Edit
Templates.7a02a8497ebca052dcfb.js.map
Edit
TestStuffPage.982c641592b2f7c9db40.js
Edit
TestStuffPage.982c641592b2f7c9db40.js.map
Edit
ThemePlayground.aeeec77fd8e9c1482f55.js
Edit
ThemePlayground.aeeec77fd8e9c1482f55.js.map
Edit
UserAdminPage.fc4d562eef05d9f59aca.js
Edit
UserAdminPage.fc4d562eef05d9f59aca.js.map
Edit
UserCreatePage.b7036214c66612fb31e9.js
Edit
UserCreatePage.b7036214c66612fb31e9.js.map
Edit
UserInvitePage.4a9bcd4084d7ae454c73.js
Edit
UserInvitePage.4a9bcd4084d7ae454c73.js.map
Edit
UserListPage.a452e1153ae820f58ac9.js
Edit
UserListPage.a452e1153ae820f58ac9.js.map
Edit
UserProfileEditPage.82c11690282e669eabb1.js
Edit
UserProfileEditPage.82c11690282e669eabb1.js.map
Edit
alert-rules-drawer-content.c95bb5ddd3fc813cae92.js
Edit
alert-rules-drawer-content.c95bb5ddd3fc813cae92.js.map
Edit
alert-rules-toolbar-button.0d86c1adae7edb55ff76.js
Edit
alert-rules-toolbar-button.0d86c1adae7edb55ff76.js.map
Edit
alertListPanel.0110106a8d1ab70d65d5.js
Edit
alertListPanel.0110106a8d1ab70d65d5.js.map
Edit
alertmanagerPlugin.2b59de5e7b7a556f87f1.js
Edit
alertmanagerPlugin.2b59de5e7b7a556f87f1.js.map
Edit
annoListPanel.0005a0eab0b05e24d970.js
Edit
annoListPanel.0005a0eab0b05e24d970.js.map
Edit
app.8385deda1df49aa75ec2.js
Edit
app.8385deda1df49aa75ec2.js.map
Edit
assets-manifest.json
Edit
barChartPanel.eecdaeab7d146d477721.js
Edit
barChartPanel.eecdaeab7d146d477721.js.map
Edit
barGaugePanel.6d9e94bbb72ba92a0e9b.js
Edit
barGaugePanel.6d9e94bbb72ba92a0e9b.js.map
Edit
candlestickPanel.af0e0decd06e7b7ab286.js
Edit
candlestickPanel.af0e0decd06e7b7ab286.js.map
Edit
canvasPanel.ddab72fab6e58c3419b2.js
Edit
canvasPanel.ddab72fab6e58c3419b2.js.map
Edit
cloudwatchPlugin.06ef34f60000c4f7ea37.js
Edit
cloudwatchPlugin.06ef34f60000c4f7ea37.js.map
Edit
dark.b66fa87185b9a313ec14.js
Edit
dashListPanel.23b954da0c4888602048.js
Edit
dashListPanel.23b954da0c4888602048.js.map
Edit
dataGridPanel.bb5d4b678cba38dd380b.js
Edit
debugPanel.fff63da32084d7a2e236.js
Edit
debugPanel.fff63da32084d7a2e236.js.map
Edit
elasticsearchPlugin.3f2edb012f5162b48903.js
Edit
elasticsearchPlugin.3f2edb012f5162b48903.js.map
Edit
explore-feature-toggle-page.3de03fa91c88d05cea1c.js
Edit
explore-feature-toggle-page.3de03fa91c88d05cea1c.js.map
Edit
explore.dd32637df83326225e0d.js
Edit
explore.dd32637df83326225e0d.js.map
Edit
flamegraphPanel.cc6c5b4bcd69e406fbb7.js
Edit
flamegraphPanel.cc6c5b4bcd69e406fbb7.js.map
Edit
gaugePanel.5da3c4e39a652e281cc4.js
Edit
gaugePanel.5da3c4e39a652e281cc4.js.map
Edit
gazetteer
Edit
geomapPanel.67ebb4567e9b5fa5074b.js
Edit
gettingStartedPanel.833059170dbbf8d5c4bf.js
Edit
gettingStartedPanel.833059170dbbf8d5c4bf.js.map
Edit
grafana.1492.25120d27db88f863e058.css
Edit
grafana.4350.a45e45977094df4a0bc9.css
Edit
grafana.5790.ffb3a9cd952d3cd7471b.css
Edit
grafana.DashboardPage.a66335f88cd003e4a44f.css
Edit
grafana.DashboardPageProxy.a66335f88cd003e4a44f.css
Edit
grafana.app.1f6473bb54b1e1647be8.css
Edit
grafana.dark.1e8d85816912aadbbba5.css
Edit
grafana.dataGridPanel.c1fc5db1829b1b31eb4d.css
Edit
grafana.geomapPanel.0057d964fa972bb207ec.css
Edit
grafana.light.111a5a99fcebc0962ddc.css
Edit
grafana.livePanel.25120d27db88f863e058.css
Edit
grafana.react-monaco-editor.ffb3a9cd952d3cd7471b.css
Edit
grafana.swagger.d0a2da197b9827204ac1.css
Edit
grafana.tablePanel.25120d27db88f863e058.css
Edit
grafanaPlugin.f21cdb4b84a732cc9dd8.js
Edit
grafanaPlugin.f21cdb4b84a732cc9dd8.js.map
Edit
heatmapPanel.7834b997bc573eddba88.js
Edit
heatmapPanel.7834b997bc573eddba88.js.map
Edit
histogramPanel.9953bfeccf8774500c0c.js
Edit
histogramPanel.9953bfeccf8774500c0c.js.map
Edit
img
Edit
influxdbPlugin.7a899e63be0a65d41e13.js
Edit
influxdbPlugin.7a899e63be0a65d41e13.js.map
Edit
light.827d442410485e491818.js
Edit
livePanel.2a43f499bc746d928d45.js
Edit
livePanel.2a43f499bc746d928d45.js.map
Edit
logsPanel.a328022d248508a083c1.js
Edit
logsPanel.a328022d248508a083c1.js.map
Edit
loki-query-field.f9a0b82b636d4821760c.js
Edit
loki-query-field.f9a0b82b636d4821760c.js.map
Edit
maps
Edit
mixedPlugin.3a69de93f366afbb2f85.js
Edit
newsPanel.c17f40f7c88ea14620e7.js
Edit
newsPanel.c17f40f7c88ea14620e7.js.map
Edit
nodeGraphPanel.f717a9075d994a9a8af4.js
Edit
nodeGraphPanel.f717a9075d994a9a8af4.js.map
Edit
opentsdbPlugin.1795eab1c223ea030c2e.js
Edit
opentsdbPlugin.1795eab1c223ea030c2e.js.map
Edit
pieChartPanel.45166aa6d57d163817ea.js
Edit
pieChartPanel.45166aa6d57d163817ea.js.map
Edit
prometheusPlugin.c3a55eb5353085fc3d2b.js
Edit
prometheusPlugin.c3a55eb5353085fc3d2b.js.map
Edit
radialBarPanel.294c52d497d8f5c2bebb.js
Edit
radialBarPanel.294c52d497d8f5c2bebb.js.map
Edit
runtime.a37cc2f12a959f33871a.js
Edit
runtime.a37cc2f12a959f33871a.js.map
Edit
sql-query-editor.e767d4a2aef360034bd9.js
Edit
sql-query-editor.e767d4a2aef360034bd9.js.map
Edit
statPanel.3a7f191bfb27fd320014.js
Edit
statPanel.3a7f191bfb27fd320014.js.map
Edit
stateTimelinePanel.08d857b143ef89dc195f.js
Edit
stateTimelinePanel.08d857b143ef89dc195f.js.map
Edit
static
Edit
statusHistoryPanel.29f7b8dc01039ba795af.js
Edit
statusHistoryPanel.29f7b8dc01039ba795af.js.map
Edit
swagger.06875a6266679f54141d.js
Edit
swagger.06875a6266679f54141d.js.map
Edit
tablePanel.43861ce2a60617dcd19d.js
Edit
tablePanel.43861ce2a60617dcd19d.js.map
Edit
textPanel.867ee60d01b2039aa159.js
Edit
textPanel.867ee60d01b2039aa159.js.map
Edit
timeseriesPanel.b4a947da450030262a31.js
Edit
timeseriesPanel.b4a947da450030262a31.js.map
Edit
tracesPanel.35bfc3e5ff6bea4212a3.js
Edit
tracesPanel.35bfc3e5ff6bea4212a3.js.map
Edit
trendPanel.001aff2bd153e737c464.js
Edit
trendPanel.001aff2bd153e737c464.js.map
Edit
vis-data.b34535ebabc0fcb91557.js
Edit
vis-data.b34535ebabc0fcb91557.js.map
Edit
vis-network.1b41caf21892c9525709.js
Edit
vis-network.1b41caf21892c9525709.js.map
Edit
welcomeBanner.1a693c9dc02006be4f0b.js
Edit
welcomeBanner.1a693c9dc02006be4f0b.js.map
Edit
xychart.cb20af67a6c495ba6ccd.js
Edit
xychart.cb20af67a6c495ba6ccd.js.map
Edit