mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-03 02:00:43 +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
49 lines
1.4 KiB
JavaScript
49 lines
1.4 KiB
JavaScript
import { createSelector } from 'reselect';
|
|
import { createMapSelector } from 'reselect-map';
|
|
import { fromJS, List as makeList, Map as makeMap } from 'immutable';
|
|
|
|
|
|
const NETWORKS_ID = 'docker_container_networks';
|
|
|
|
// TODO: Move this setting of networks as toplevel node field to backend,
|
|
// to not rely on field IDs here. should be determined by topology implementer.
|
|
export const nodeNetworksSelector = createMapSelector(
|
|
[
|
|
state => state.get('nodes'),
|
|
],
|
|
(node) => {
|
|
const metadata = node.get('metadata', makeList());
|
|
const networks = metadata.find(f => f.get('id') === NETWORKS_ID) || makeMap();
|
|
const networkValues = networks.has('value') ? networks.get('value').split(', ') : [];
|
|
|
|
return fromJS(networkValues.map(network => ({
|
|
id: network, label: network, colorKey: network
|
|
})));
|
|
}
|
|
);
|
|
|
|
export const availableNetworksSelector = createSelector(
|
|
[
|
|
nodeNetworksSelector
|
|
],
|
|
networksMap => networksMap.toList().flatten(true).toSet().toList()
|
|
.sortBy(m => m.get('label'))
|
|
);
|
|
|
|
export const selectedNetworkNodesIdsSelector = createSelector(
|
|
[
|
|
nodeNetworksSelector,
|
|
state => state.get('selectedNetwork'),
|
|
],
|
|
(nodeNetworks, selectedNetworkId) => {
|
|
const nodeIds = [];
|
|
nodeNetworks.forEach((networks, nodeId) => {
|
|
const networksIds = networks.map(n => n.get('id'));
|
|
if (networksIds.contains(selectedNetworkId)) {
|
|
nodeIds.push(nodeId);
|
|
}
|
|
});
|
|
return fromJS(nodeIds);
|
|
}
|
|
);
|