mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-05 11:11:13 +00:00
* Added resource view selector button * Showing resource boxes in the resource view * Crude CPU resource view prototype * Improved the viewMode state logic * Extracted zooming into a separate wrapper component * Split the layout selectors between graph-view and resource-view * Proper zooming logic for the resource view * Moved all node networks utils to selectors * Improved the zoom caching logic * Further refactoring of selectors * Added sticky labels to the resource boxes * Added panning translation limits in the resource view * Renamed GridModeSelector -> ViewModeSelector * Polished the topology resource view selection logic * Search bar hidden in the resource view * Added per-layer topology names to the resource view * Made metric selectors work for the resource view * Adjusted the viewport selectors * Renamed viewport selector to canvas (+ maximal zoom fix) * Showing more useful metric info in the resource box labels * Fetching only necessary nodes for the resource view * Refactored the resource view layer component * Addressed first batch UI comments (from the Scope meeting) * Switch to deep zooming transform in the resource view to avoid SVG precision errors * Renamed and moved resource view components * Polished all the resource view components * Changing the available metrics selection * Improved and polished the state transition logic for the resource view * Separated zoom limits from the zoom active state * Renaming and bunch of comments * Addressed all the UI comments (@davkal + @fons) * Made graph view selectors independent from resource view selectors
34 lines
1.3 KiB
JavaScript
34 lines
1.3 KiB
JavaScript
import { createSelector } from 'reselect';
|
|
import { Map as makeMap } from 'immutable';
|
|
|
|
import { isGraphViewModeSelector, activeTopologyOptionsSelector } from './topology';
|
|
|
|
|
|
export const activeTopologyZoomCacheKeyPathSelector = createSelector(
|
|
[
|
|
isGraphViewModeSelector,
|
|
state => state.get('topologyViewMode'),
|
|
state => state.get('currentTopologyId'),
|
|
state => state.get('pinnedMetricType'),
|
|
state => JSON.stringify(activeTopologyOptionsSelector(state)),
|
|
],
|
|
(isGraphViewMode, viewMode, topologyId, pinnedMetricType, topologyOptions) => (
|
|
isGraphViewMode ?
|
|
// In graph view, selecting different options/filters produces a different layout.
|
|
['zoomCache', viewMode, topologyId, topologyOptions] :
|
|
// Otherwise we're in the resource view where the options are hidden (for now),
|
|
// but pinning different metrics can result in very different layouts.
|
|
// TODO: Take `topologyId` into account once the resource
|
|
// view layouts start differing between the topologies.
|
|
['zoomCache', viewMode, pinnedMetricType]
|
|
)
|
|
);
|
|
|
|
export const activeLayoutCachedZoomSelector = createSelector(
|
|
[
|
|
state => state.get('zoomCache'),
|
|
activeTopologyZoomCacheKeyPathSelector,
|
|
],
|
|
(zoomCache, keyPath) => zoomCache.getIn(keyPath.slice(1), makeMap())
|
|
);
|