mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-03 18:20:27 +00:00
61 lines
1.7 KiB
JavaScript
61 lines
1.7 KiB
JavaScript
import page from 'page';
|
|
|
|
import { route } from '../actions/app-actions';
|
|
import AppStore from '../stores/app-store';
|
|
|
|
//
|
|
// page.js won't match the routes below if ":state" has a slash in it, so replace those before we
|
|
// load the state into the URL.
|
|
//
|
|
const SLASH = '/';
|
|
const SLASH_REPLACEMENT = '<SLASH>';
|
|
|
|
function encodeURL(url) {
|
|
return url.replace(new RegExp(SLASH, 'g'), SLASH_REPLACEMENT);
|
|
}
|
|
|
|
function decodeURL(url) {
|
|
return decodeURIComponent(url.replace(new RegExp(SLASH_REPLACEMENT, 'g'), SLASH));
|
|
}
|
|
|
|
function shouldReplaceState(prevState, nextState) {
|
|
// Opening a new terminal while an existing one is open.
|
|
const terminalToTerminal = (prevState.controlPipe && nextState.controlPipe);
|
|
// Closing a terminal.
|
|
const closingTheTerminal = (prevState.controlPipe && !nextState.controlPipe);
|
|
|
|
return terminalToTerminal || closingTheTerminal;
|
|
}
|
|
|
|
export function updateRoute() {
|
|
const state = AppStore.getAppState();
|
|
const stateUrl = encodeURL(JSON.stringify(state));
|
|
const dispatch = false;
|
|
const urlStateString = window.location.hash
|
|
.replace('#!/state/', '')
|
|
.replace('#!/', '') || '{}';
|
|
const prevState = JSON.parse(decodeURL(urlStateString));
|
|
|
|
if (shouldReplaceState(prevState, state)) {
|
|
// Replace the top of the history rather than pushing on a new item.
|
|
page.replace(`/state/${stateUrl}`, state, dispatch);
|
|
} else {
|
|
page.show(`/state/${stateUrl}`, state, dispatch);
|
|
}
|
|
}
|
|
|
|
page('/', () => {
|
|
updateRoute();
|
|
});
|
|
|
|
page('/state/:state', (ctx) => {
|
|
const state = JSON.parse(ctx.params.state);
|
|
route(state);
|
|
});
|
|
|
|
export function getRouter() {
|
|
// strip any trailing '/'s.
|
|
page.base(window.location.pathname.replace(/\/$/, ''));
|
|
return page;
|
|
}
|