mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Add Alert rules tab
* Add pagination and a simple name-based filtering
* Add name and label based filtering
* Improve pagination, handle the no results case
* Add tests for alerts folder view
* Add label filtering by clicking a tag
* Add tests for matcher to string method
* Add sorting, improve styles
* Use simple Select component for sorting
* Update default page size
* Remove unused code
* Use existingc thunk
* chore: update swagger spec
* Revert "chore: update swagger spec"
This reverts commit ee79ec7341.
* Code cleanup
* Fix ts
Co-authored-by: gillesdemey <gilles.de.mey@gmail.com>
83 lines
1.7 KiB
TypeScript
83 lines
1.7 KiB
TypeScript
import { NavModel, NavModelItem } from '@grafana/data';
|
|
|
|
import { FolderDTO } from 'app/types';
|
|
|
|
export function buildNavModel(folder: FolderDTO): NavModelItem {
|
|
const model = {
|
|
icon: 'folder',
|
|
id: 'manage-folder',
|
|
subTitle: 'Manage folder dashboards and permissions',
|
|
url: '',
|
|
text: folder.title,
|
|
breadcrumbs: [{ title: 'Dashboards', url: 'dashboards' }],
|
|
children: [
|
|
{
|
|
active: false,
|
|
icon: 'apps',
|
|
id: `folder-dashboards-${folder.uid}`,
|
|
text: 'Dashboards',
|
|
url: folder.url,
|
|
},
|
|
],
|
|
};
|
|
|
|
model.children.push({
|
|
active: false,
|
|
icon: 'library-panel',
|
|
id: `folder-library-panels-${folder.uid}`,
|
|
text: 'Panels',
|
|
url: `${folder.url}/library-panels`,
|
|
});
|
|
|
|
model.children.push({
|
|
active: false,
|
|
icon: 'bell',
|
|
id: `folder-alerting-${folder.uid}`,
|
|
text: 'Alert rules',
|
|
url: `${folder.url}/alerting`,
|
|
});
|
|
|
|
if (folder.canAdmin) {
|
|
model.children.push({
|
|
active: false,
|
|
icon: 'lock',
|
|
id: `folder-permissions-${folder.uid}`,
|
|
text: 'Permissions',
|
|
url: `${folder.url}/permissions`,
|
|
});
|
|
}
|
|
|
|
if (folder.canSave) {
|
|
model.children.push({
|
|
active: false,
|
|
icon: 'cog',
|
|
id: `folder-settings-${folder.uid}`,
|
|
text: 'Settings',
|
|
url: `${folder.url}/settings`,
|
|
});
|
|
}
|
|
|
|
return model;
|
|
}
|
|
|
|
export function getLoadingNav(tabIndex: number): NavModel {
|
|
const main = buildNavModel({
|
|
id: 1,
|
|
uid: 'loading',
|
|
title: 'Loading',
|
|
url: 'url',
|
|
canSave: true,
|
|
canEdit: true,
|
|
canAdmin: true,
|
|
canDelete: true,
|
|
version: 0,
|
|
});
|
|
|
|
main.children![tabIndex].active = true;
|
|
|
|
return {
|
|
main: main,
|
|
node: main.children![tabIndex],
|
|
};
|
|
}
|