2020-04-17 15:29:20 +03:00
|
|
|
import React, { FC, memo } from 'react';
|
|
|
|
|
import { useAsync } from 'react-use';
|
|
|
|
|
import { connect, MapStateToProps } from 'react-redux';
|
2020-04-20 07:37:38 +02:00
|
|
|
import { NavModel, locationUtil } from '@grafana/data';
|
2020-04-17 15:29:20 +03:00
|
|
|
import { getLocationSrv } from '@grafana/runtime';
|
2020-06-17 04:26:01 -06:00
|
|
|
import { FolderDTO, StoreState } from 'app/types';
|
2020-04-17 15:29:20 +03:00
|
|
|
import { getNavModel } from 'app/core/selectors/navModel';
|
2020-04-24 11:08:06 +03:00
|
|
|
import { getRouteParams, getUrl } from 'app/core/selectors/location';
|
2020-04-17 15:29:20 +03:00
|
|
|
import Page from 'app/core/components/Page/Page';
|
2020-04-22 11:24:29 +03:00
|
|
|
import { loadFolderPage } from '../loaders';
|
2020-06-16 11:52:10 +03:00
|
|
|
import ManageDashboards from './ManageDashboards';
|
2020-04-17 15:29:20 +03:00
|
|
|
|
|
|
|
|
interface Props {
|
|
|
|
|
navModel: NavModel;
|
|
|
|
|
uid?: string;
|
2020-04-24 11:08:06 +03:00
|
|
|
url: string;
|
2020-04-17 15:29:20 +03:00
|
|
|
}
|
|
|
|
|
|
2020-04-24 11:08:06 +03:00
|
|
|
export const DashboardListPage: FC<Props> = memo(({ navModel, uid, url }) => {
|
2020-06-17 04:26:01 -06:00
|
|
|
const { loading, value } = useAsync<{ folder?: FolderDTO; pageNavModel: NavModel }>(() => {
|
2020-04-24 11:08:06 +03:00
|
|
|
if (!uid || !url.startsWith('/dashboards')) {
|
2020-04-22 11:24:29 +03:00
|
|
|
return Promise.resolve({ pageNavModel: navModel });
|
|
|
|
|
}
|
2020-07-08 11:05:20 +02:00
|
|
|
|
2021-02-17 12:40:28 +01:00
|
|
|
return loadFolderPage(uid!).then(({ folder, folderNav }) => {
|
2020-04-24 11:08:06 +03:00
|
|
|
const path = locationUtil.stripBaseFromUrl(folder.url);
|
2020-04-17 15:29:20 +03:00
|
|
|
|
2020-04-24 11:08:06 +03:00
|
|
|
if (path !== location.pathname) {
|
|
|
|
|
getLocationSrv().update({ path });
|
2020-04-22 11:24:29 +03:00
|
|
|
}
|
2020-04-17 15:29:20 +03:00
|
|
|
|
2021-02-17 12:40:28 +01:00
|
|
|
return { folder, pageNavModel: { ...navModel, main: folderNav } };
|
2020-04-22 11:24:29 +03:00
|
|
|
});
|
2020-04-17 15:29:20 +03:00
|
|
|
}, [uid]);
|
|
|
|
|
|
|
|
|
|
return (
|
2020-07-08 11:05:20 +02:00
|
|
|
<Page navModel={value?.pageNavModel ?? navModel}>
|
2020-04-17 15:29:20 +03:00
|
|
|
<Page.Contents isLoading={loading}>
|
2020-05-06 12:53:28 +03:00
|
|
|
<ManageDashboards folder={value?.folder} />
|
2020-04-17 15:29:20 +03:00
|
|
|
</Page.Contents>
|
|
|
|
|
</Page>
|
|
|
|
|
);
|
|
|
|
|
});
|
2021-02-17 12:40:28 +01:00
|
|
|
|
2020-12-01 23:19:52 +08:00
|
|
|
DashboardListPage.displayName = 'DashboardListPage';
|
2020-04-17 15:29:20 +03:00
|
|
|
|
2021-01-20 07:59:48 +01:00
|
|
|
const mapStateToProps: MapStateToProps<Props, {}, StoreState> = (state) => {
|
2020-04-24 11:08:06 +03:00
|
|
|
return {
|
|
|
|
|
navModel: getNavModel(state.navIndex, 'manage-dashboards'),
|
|
|
|
|
uid: getRouteParams(state.location).uid as string | undefined,
|
|
|
|
|
url: getUrl(state.location),
|
|
|
|
|
};
|
|
|
|
|
};
|
2020-04-17 15:29:20 +03:00
|
|
|
|
|
|
|
|
export default connect(mapStateToProps)(DashboardListPage);
|