grafana/public/app/core/components/NavBar/utils.ts

45 lines
1.4 KiB
TypeScript
Raw Normal View History

import { NavModelItem } from '@grafana/data';
import { getConfig } from 'app/core/config';
import { Location } from 'history';
export const getForcedLoginUrl = (url: string) => {
const queryParams = new URLSearchParams(url.split('?')[1]);
queryParams.append('forceLogin', 'true');
return `${getConfig().appSubUrl}${url.split('?')[0]}?${queryParams.toString()}`;
};
export const isLinkActive = (pathname: string, link: NavModelItem) => {
// strip out any query params
const linkPathname = link.url?.split('?')[0];
if (linkPathname) {
if (linkPathname === pathname) {
// exact match
return true;
} else if (linkPathname !== '/' && pathname.startsWith(linkPathname)) {
// partial match
return true;
} else if (linkPathname === '/alerting/list' && pathname.startsWith('/alerting/notification/')) {
// alert channel match
// TODO refactor routes such that we don't need this custom logic
return true;
} else if (linkPathname === '/' && pathname.startsWith('/d/')) {
// dashboard match
// TODO refactor routes such that we don't need this custom logic
return true;
}
}
// child match
if (link.children?.some((childLink) => isLinkActive(pathname, childLink))) {
return true;
}
return false;
};
export const isSearchActive = (location: Location<unknown>) => {
const query = new URLSearchParams(location.search);
return query.get('search') === 'open';
};