mirror of
https://github.com/grafana/grafana.git
synced 2025-01-09 23:53:25 -06:00
Merge branch 'datasource-lists-cards'
This commit is contained in:
commit
4144f71e23
@ -1,8 +1,11 @@
|
|||||||
package api
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"sort"
|
||||||
|
|
||||||
"github.com/grafana/grafana/pkg/api/dtos"
|
"github.com/grafana/grafana/pkg/api/dtos"
|
||||||
"github.com/grafana/grafana/pkg/bus"
|
"github.com/grafana/grafana/pkg/bus"
|
||||||
|
"github.com/grafana/grafana/pkg/plugins"
|
||||||
//"github.com/grafana/grafana/pkg/log"
|
//"github.com/grafana/grafana/pkg/log"
|
||||||
"github.com/grafana/grafana/pkg/middleware"
|
"github.com/grafana/grafana/pkg/middleware"
|
||||||
m "github.com/grafana/grafana/pkg/models"
|
m "github.com/grafana/grafana/pkg/models"
|
||||||
@ -17,9 +20,10 @@ func GetDataSources(c *middleware.Context) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
result := make([]*dtos.DataSource, len(query.Result))
|
result := make(dtos.DataSourceList, 0)
|
||||||
for i, ds := range query.Result {
|
for _, ds := range query.Result {
|
||||||
result[i] = &dtos.DataSource{
|
|
||||||
|
dsItem := dtos.DataSource{
|
||||||
Id: ds.Id,
|
Id: ds.Id,
|
||||||
OrgId: ds.OrgId,
|
OrgId: ds.OrgId,
|
||||||
Name: ds.Name,
|
Name: ds.Name,
|
||||||
@ -32,8 +36,17 @@ func GetDataSources(c *middleware.Context) {
|
|||||||
BasicAuth: ds.BasicAuth,
|
BasicAuth: ds.BasicAuth,
|
||||||
IsDefault: ds.IsDefault,
|
IsDefault: ds.IsDefault,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if plugin, exists := plugins.DataSources[ds.Type]; exists {
|
||||||
|
dsItem.TypeLogoUrl = plugin.Info.Logos.Small
|
||||||
|
} else {
|
||||||
|
dsItem.TypeLogoUrl = "public/img/plugin-default-logo_dark.svg"
|
||||||
|
}
|
||||||
|
|
||||||
|
result = append(result, dsItem)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sort.Sort(result)
|
||||||
c.JSON(200, result)
|
c.JSON(200, result)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,6 +62,7 @@ type DataSource struct {
|
|||||||
OrgId int64 `json:"orgId"`
|
OrgId int64 `json:"orgId"`
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
Type string `json:"type"`
|
Type string `json:"type"`
|
||||||
|
TypeLogoUrl string `json:"typeLogoUrl"`
|
||||||
Access m.DsAccess `json:"access"`
|
Access m.DsAccess `json:"access"`
|
||||||
Url string `json:"url"`
|
Url string `json:"url"`
|
||||||
Password string `json:"password"`
|
Password string `json:"password"`
|
||||||
@ -75,6 +76,20 @@ type DataSource struct {
|
|||||||
JsonData *simplejson.Json `json:"jsonData,omitempty"`
|
JsonData *simplejson.Json `json:"jsonData,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type DataSourceList []DataSource
|
||||||
|
|
||||||
|
func (slice DataSourceList) Len() int {
|
||||||
|
return len(slice)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (slice DataSourceList) Less(i, j int) bool {
|
||||||
|
return slice[i].Name < slice[j].Name
|
||||||
|
}
|
||||||
|
|
||||||
|
func (slice DataSourceList) Swap(i, j int) {
|
||||||
|
slice[i], slice[j] = slice[j], slice[i]
|
||||||
|
}
|
||||||
|
|
||||||
type MetricQueryResultDto struct {
|
type MetricQueryResultDto struct {
|
||||||
Data []MetricQueryResultDataDto `json:"data"`
|
Data []MetricQueryResultDataDto `json:"data"`
|
||||||
}
|
}
|
||||||
|
@ -134,6 +134,24 @@ export class DataSourceEditCtrl {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
confirmDelete() {
|
||||||
|
this.backendSrv.delete('/api/datasources/' + this.current.id).then(() => {
|
||||||
|
this.$location.path('datasources');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
delete(s) {
|
||||||
|
this.$scope.appEvent('confirm-modal', {
|
||||||
|
title: 'Delete',
|
||||||
|
text: 'Are you sure you want to delete this datasource?',
|
||||||
|
yesText: "Delete",
|
||||||
|
icon: "fa-trash",
|
||||||
|
onConfirm: () => {
|
||||||
|
this.confirmDelete();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
coreModule.controller('DataSourceEditCtrl', DataSourceEditCtrl);
|
coreModule.controller('DataSourceEditCtrl', DataSourceEditCtrl);
|
||||||
|
@ -66,6 +66,9 @@
|
|||||||
<button type="submit" class="btn btn-success" ng-show="!ctrl.isNew" ng-click="ctrl.saveChanges()">Save</button>
|
<button type="submit" class="btn btn-success" ng-show="!ctrl.isNew" ng-click="ctrl.saveChanges()">Save</button>
|
||||||
<button type="submit" class="btn btn-secondary" ng-show="!ctrl.isNew" ng-click="ctrl.saveChanges(true)">
|
<button type="submit" class="btn btn-secondary" ng-show="!ctrl.isNew" ng-click="ctrl.saveChanges(true)">
|
||||||
Test Connection
|
Test Connection
|
||||||
|
</button>
|
||||||
|
<button type="submit" class="btn btn-danger" ng-show="!ctrl.isNew" ng-click="ctrl.delete()">
|
||||||
|
Delete
|
||||||
</button>
|
</button>
|
||||||
<a class="btn btn-link" href="datasources">Cancel</a>
|
<a class="btn btn-link" href="datasources">Cancel</a>
|
||||||
</div>
|
</div>
|
||||||
|
@ -13,55 +13,39 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<br>
|
<section class="card-section" layout-mode>
|
||||||
|
<layout-selector></layout-selector>
|
||||||
|
|
||||||
<div ng-if="ctrl.datasources.length === 0">
|
<ol class="card-list" >
|
||||||
<em>No data sources defined</em>
|
<li class="card-item-wrapper" ng-repeat="ds in ctrl.datasources">
|
||||||
</div>
|
<a class="card-item" href="datasources/edit/{{ds.id}}/">
|
||||||
|
<div class="card-item-header">
|
||||||
<table class="filter-table" ng-if="ctrl.datasources.length > 0">
|
<i class="icon-gf icon-gf-{{ds.type}}"></i>
|
||||||
<thead>
|
{{ds.type}}
|
||||||
<tr>
|
</div>
|
||||||
<th><strong>name</strong></th>
|
<div class="card-item-body">
|
||||||
<th><strong>type</strong></th>
|
<figure class="card-item-figure">
|
||||||
<th><strong>url</strong></th>
|
<img ng-src="{{ds.typeLogoUrl}}">
|
||||||
<th style="width: 60px;"></th>
|
</figure>
|
||||||
<th style="width: 85px;"></th>
|
<div class="card-item-details">
|
||||||
<th style="width: 44px;"></th>
|
<div class="card-item-name">
|
||||||
</tr>
|
{{ds.name}}
|
||||||
</thead>
|
<span ng-if="ds.isDefault">
|
||||||
<tbody>
|
<span class="btn btn-secondary btn-mini">default</span>
|
||||||
<tr ng-repeat="ds in ctrl.datasources">
|
</span>
|
||||||
<td>
|
</div>
|
||||||
<a href="datasources/edit/{{ds.id}}">
|
<div class="card-item-sub-name">
|
||||||
<i class="icon-gf inline-icon-gf icon-gf-datasources"></i> {{ds.name}}
|
{{ds.url}}
|
||||||
</a>
|
</div>
|
||||||
</td>
|
</div>
|
||||||
<td>
|
</div>
|
||||||
<span>{{ds.type}}</span>
|
</a>
|
||||||
</td>
|
</li>
|
||||||
<td>
|
</ol>
|
||||||
<span>{{ds.url}}</span>
|
</section>
|
||||||
</td>
|
|
||||||
<td class="text-center">
|
|
||||||
<span ng-if="ds.isDefault">
|
|
||||||
<span class="btn btn-secondary btn-mini">default</span>
|
|
||||||
</span>
|
|
||||||
</td>
|
|
||||||
<td class="text-right">
|
|
||||||
<a href="datasources/edit/{{ds.id}}" class="btn btn-inverse btn-small">
|
|
||||||
<i class="fa fa-edit"></i>
|
|
||||||
Edit
|
|
||||||
</a>
|
|
||||||
</td>
|
|
||||||
<td class="text-right">
|
|
||||||
<a ng-click="ctrl.removeDataSource(ds)" class="btn btn-danger btn-small">
|
|
||||||
<i class="fa fa-remove"></i>
|
|
||||||
</a>
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
|
<div ng-if="ctrl.datasources.length === 0">
|
||||||
|
<em>No data sources defined</em>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
<img ng-src="{{plugin.info.logos.small}}">
|
<img ng-src="{{plugin.info.logos.small}}">
|
||||||
</figure>
|
</figure>
|
||||||
<div class="card-item-details">
|
<div class="card-item-details">
|
||||||
<div class="card-item-name" href="plugins/{{plugin.id}}/edit">{{plugin.name}}</div>
|
<div class="card-item-name">{{plugin.name}}</div>
|
||||||
<div class="card-item-sub-name">By {{plugin.info.author.name}}</div>
|
<div class="card-item-sub-name">By {{plugin.info.author.name}}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -56,7 +56,10 @@
|
|||||||
|
|
||||||
.card-item-header {
|
.card-item-header {
|
||||||
color: $text-color-weak;
|
color: $text-color-weak;
|
||||||
|
text-transform: uppercase;
|
||||||
margin-bottom: $spacer;
|
margin-bottom: $spacer;
|
||||||
|
font-size: $font-size-sm;
|
||||||
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
|
|
||||||
.card-item-name {
|
.card-item-name {
|
||||||
@ -103,8 +106,14 @@
|
|||||||
.card-list-layout-list {
|
.card-list-layout-list {
|
||||||
|
|
||||||
.card-item-wrapper {
|
.card-item-wrapper {
|
||||||
|
padding: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
padding: 0 0 1.5rem 0rem;
|
}
|
||||||
|
|
||||||
|
.card-item {
|
||||||
|
border-bottom: .2rem solid $page-bg;
|
||||||
|
border-radius: 0;
|
||||||
|
box-shadow: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.card-item-header {
|
.card-item-header {
|
||||||
|
Loading…
Reference in New Issue
Block a user