grafana/public/app/features/datasources/DataSourcesList.tsx

40 lines
1.0 KiB
TypeScript
Raw Normal View History

// Libraries
2018-10-02 02:27:02 -05:00
import React, { PureComponent } from 'react';
2018-12-25 04:42:23 -06:00
import classNames from 'classnames';
// Components
import DataSourcesListItem from './DataSourcesListItem';
// Types
import { DataSourceSettings } from '@grafana/data';
import { LayoutMode, LayoutModes } from '../../core/components/LayoutSelector/LayoutSelector';
export interface Props {
dataSources: DataSourceSettings[];
layoutMode: LayoutMode;
}
2018-10-02 02:27:02 -05:00
export class DataSourcesList extends PureComponent<Props> {
render() {
const { dataSources, layoutMode } = this.props;
2018-10-02 02:27:02 -05:00
const listStyle = classNames({
'card-section': true,
'card-list-layout-grid': layoutMode === LayoutModes.Grid,
'card-list-layout-list': layoutMode === LayoutModes.List,
});
2018-10-02 02:27:02 -05:00
return (
<section className={listStyle}>
<ol className="card-list">
{dataSources.map((dataSource, index) => {
return <DataSourcesListItem dataSource={dataSource} key={`${dataSource.id}-${index}`} />;
})}
</ol>
</section>
);
}
}
export default DataSourcesList;