mirror of
https://github.com/grafana/grafana.git
synced 2025-07-30 15:32:08 +08:00

* chore(angularsupport): delete feature toggle to disable angular * feat(angular-support): remove config.angularSupportEnabled * chore(jest): remove angular from setup file * chore(angular): delete angular deprecation ui components * refactor(angular): move migration featureflags into migration notice * chore(dashboard): remove angular deprecation notices * chore(annotations): remove angular editor loader * feat(appwrapper): no more angular app loading * feat(pluginscatalog): clean up angular plugin warnings and logic * chore(angular): delete angular app and associated files * feat(plugins): delete old angular graph plugin * feat(plugins): delete old angular table panel * feat(frontend): remove unused appEvent type * feat(dashboards): clean up angular from panel options and menu * feat(plugins): remove graph and table-old from built in plugins and delete sdk * feat(frontend): remove angular related imports in routes and explore graph * feat(theme): remove angular panel styles from global styles * chore(i18n): run make i18n-extract * test(api_plugins_test): refresh snapshot due to deleting old graph and table plugins * chore(angulardeprecation): delete angular migration notice components and usage * test(frontend): clean up tests that assert rendering angular deprecation notices * chore(backend): remove autoMigrateOldPanels feature flag * chore(config): remove angularSupportEnabled from config preventing loading angular plugins * chore(graphpanel): remove autoMigrateGraphPanel from feature toggles * chore(tablepanel): delete autoMigrateTablePanel feature flag * chore(piechart): delete autoMigratePiechartPanel feature flag * chore(worldmappanel): remove autoMigrateWorldmapPanel feature toggle * chore(statpanel): remove autoMigrateStatPanel feature flag * feat(dashboards): remove automigrate feature flags and always auto migrate angular panels * test(pluginsintegration): fix failing loader test * test(frontend): wip: fix failures and skip erroring migration tests * chore(codeowners): remove deleted angular related files and directories * test(graphite): remove angular mock from test file * test(dashboards): skip failing exporter test, remove angularSupportEnabled flags * test(dashbaord): skip another failing panel menu test * Tests: fixes pkg/services/pluginsintegration/loader/loader_test.go (#100505) * Tests: fixes pkg/services/pluginsintegration/plugins_integration_test.go * Trigger Build * chore(dashboards): remove angularComponent from getPanelMenu, update test * feat(dashboards): remove all usage of AngularComponent and getAngularLoader * chore(betterer): refresh results file * feat(plugins): remove PluginAngularBadge component and usage * feat(datasource_srv): remove usage of getLegacyAngularInjector * feat(queryeditor): delete AngularQueryComponentScope type * Chore: removes Angular from plugin_loader * Chore: remove angular from getPlugin * Chore: fix i18n * Trigger Build * Chore: remove more Angular from importPanelPlugin * Chore: remove search options warning * Chore: remove and deprecate Angular related * chore(angular): remove angular dependencies from core and runtime * chore(runtime): delete angular injector * chore(data): delete angular scope from event bus * chore(plugin-catalog): remove code pushing app plugins angular config page * chore(yarn): refresh lock file * chore(frontend): remove ng-loader from webpack configs, remove systemjs cjs plugin * chore(navigation): remove tether-drop cleanup from GrafanaRouter, delete dependency * chore(runtime): delete AngularLoader * chore(betterer): refresh results file * chore(betterer): fix out of sync results file * feat(query): fix type and import errors in QueryEditorRow * test(dashboards): delete skipped angular related tests * Tests: add back tests and fix betterer * Tests: fix broken test * Trigger build * chore(i18n): remove angular deprecation related strings * test: clean up connections and plugins catalog tests * chore(betterer): update results file --------- Co-authored-by: Hugo Häggmark <hugo.haggmark@gmail.com>
101 lines
3.2 KiB
TypeScript
101 lines
3.2 KiB
TypeScript
import { Suspense, useEffect, useLayoutEffect } from 'react';
|
|
import { Navigate, useLocation } from 'react-router-dom-v5-compat';
|
|
|
|
import { locationSearchToObject, navigationLogger, reportPageview } from '@grafana/runtime';
|
|
import { ErrorBoundary } from '@grafana/ui';
|
|
|
|
import { useGrafana } from '../context/GrafanaContext';
|
|
import { contextSrv } from '../services/context_srv';
|
|
|
|
import { GrafanaRouteError } from './GrafanaRouteError';
|
|
import { GrafanaRouteLoading } from './GrafanaRouteLoading';
|
|
import { GrafanaRouteComponentProps, RouteDescriptor } from './types';
|
|
|
|
export interface Props extends Pick<GrafanaRouteComponentProps, 'route' | 'location'> {}
|
|
|
|
export function GrafanaRoute(props: Props) {
|
|
const { chrome, keybindings } = useGrafana();
|
|
|
|
chrome.setMatchedRoute(props.route);
|
|
|
|
useLayoutEffect(() => {
|
|
keybindings.clearAndInitGlobalBindings(props.route);
|
|
}, [keybindings, props.route]);
|
|
|
|
useEffect(() => {
|
|
updateBodyClassNames(props.route);
|
|
cleanupDOM();
|
|
navigationLogger('GrafanaRoute', false, 'Mounted', props.route);
|
|
|
|
return () => {
|
|
navigationLogger('GrafanaRoute', false, 'Unmounted', props.route);
|
|
updateBodyClassNames(props.route, true);
|
|
};
|
|
// props.match instance change even though only query params changed so to make this effect only trigger on route mount we have to disable exhaustive-deps
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, []);
|
|
|
|
useEffect(() => {
|
|
cleanupDOM();
|
|
reportPageview();
|
|
navigationLogger('GrafanaRoute', false, 'Updated', props);
|
|
});
|
|
|
|
navigationLogger('GrafanaRoute', false, 'Rendered', props.route);
|
|
|
|
return (
|
|
<ErrorBoundary dependencies={[props.route]}>
|
|
{({ error, errorInfo }) => {
|
|
if (error) {
|
|
return <GrafanaRouteError error={error} errorInfo={errorInfo} />;
|
|
}
|
|
|
|
return (
|
|
<Suspense fallback={<GrafanaRouteLoading />}>
|
|
<props.route.component {...props} queryParams={locationSearchToObject(props.location.search)} />
|
|
</Suspense>
|
|
);
|
|
}}
|
|
</ErrorBoundary>
|
|
);
|
|
}
|
|
|
|
export function GrafanaRouteWrapper({ route }: Pick<Props, 'route'>) {
|
|
const location = useLocation();
|
|
const roles = route.roles ? route.roles() : [];
|
|
if (roles?.length) {
|
|
if (!roles.some((r: string) => contextSrv.hasRole(r))) {
|
|
return <Navigate replace to="/" />;
|
|
}
|
|
}
|
|
|
|
return <GrafanaRoute route={route} location={location} />;
|
|
}
|
|
function getPageClasses(route: RouteDescriptor) {
|
|
return route.pageClass ? route.pageClass.split(' ') : [];
|
|
}
|
|
|
|
function updateBodyClassNames(route: RouteDescriptor, clear = false) {
|
|
for (const cls of getPageClasses(route)) {
|
|
if (clear) {
|
|
document.body.classList.remove(cls);
|
|
} else {
|
|
document.body.classList.add(cls);
|
|
}
|
|
}
|
|
}
|
|
|
|
function cleanupDOM() {
|
|
document.body.classList.remove('sidemenu-open--xs');
|
|
|
|
// cleanup tooltips
|
|
const tooltipById = document.getElementById('tooltip');
|
|
tooltipById?.parentElement?.removeChild(tooltipById);
|
|
|
|
const tooltipsByClass = document.querySelectorAll('.tooltip');
|
|
for (let i = 0; i < tooltipsByClass.length; i++) {
|
|
const tooltip = tooltipsByClass[i];
|
|
tooltip.parentElement?.removeChild(tooltip);
|
|
}
|
|
}
|