mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
* upgrade to typescript 3.9.3 * Fix errors that surfaced with update * Null check fixs * FIx null checks Co-authored-by: Dominik Prokop <dominik.prokop@grafana.com>
53 lines
1.7 KiB
TypeScript
53 lines
1.7 KiB
TypeScript
import React, { FC, memo } from 'react';
|
|
import { useAsync } from 'react-use';
|
|
import { connect, MapStateToProps } from 'react-redux';
|
|
import { NavModel, locationUtil } from '@grafana/data';
|
|
import { getLocationSrv } from '@grafana/runtime';
|
|
import { FolderDTO, StoreState } from 'app/types';
|
|
import { getNavModel } from 'app/core/selectors/navModel';
|
|
import { getRouteParams, getUrl } from 'app/core/selectors/location';
|
|
import Page from 'app/core/components/Page/Page';
|
|
import { loadFolderPage } from '../loaders';
|
|
import ManageDashboards from './ManageDashboards';
|
|
|
|
interface Props {
|
|
navModel: NavModel;
|
|
uid?: string;
|
|
url: string;
|
|
}
|
|
|
|
export const DashboardListPage: FC<Props> = memo(({ navModel, uid, url }) => {
|
|
const { loading, value } = useAsync<{ folder?: FolderDTO; pageNavModel: NavModel }>(() => {
|
|
if (!uid || !url.startsWith('/dashboards')) {
|
|
return Promise.resolve({ pageNavModel: navModel });
|
|
}
|
|
return loadFolderPage(uid!, 'manage-folder-dashboards').then(({ folder, model }) => {
|
|
const path = locationUtil.stripBaseFromUrl(folder.url);
|
|
|
|
if (path !== location.pathname) {
|
|
getLocationSrv().update({ path });
|
|
}
|
|
|
|
return { folder, pageNavModel: { ...navModel, ...model } };
|
|
});
|
|
}, [uid]);
|
|
|
|
return (
|
|
<Page navModel={value?.pageNavModel}>
|
|
<Page.Contents isLoading={loading}>
|
|
<ManageDashboards folder={value?.folder} />
|
|
</Page.Contents>
|
|
</Page>
|
|
);
|
|
});
|
|
|
|
const mapStateToProps: MapStateToProps<Props, {}, StoreState> = state => {
|
|
return {
|
|
navModel: getNavModel(state.navIndex, 'manage-dashboards'),
|
|
uid: getRouteParams(state.location).uid as string | undefined,
|
|
url: getUrl(state.location),
|
|
};
|
|
};
|
|
|
|
export default connect(mapStateToProps)(DashboardListPage);
|