WIP: dashboard search by type (folder or dash)

pull/9488/head
Daniel Lee 9 years ago
parent b4576edc90
commit 68b9342de3
  1. 2
      pkg/api/search.go
  2. 1
      pkg/services/search/handlers.go
  3. 2
      pkg/services/search/models.go
  4. 8
      pkg/services/sqlstore/dashboard.go

@ -14,6 +14,7 @@ func Search(c *middleware.Context) {
tags := c.QueryStrings("tag")
starred := c.Query("starred")
limit := c.QueryInt("limit")
dashboardType := c.Query("type")
if limit == 0 {
limit = 1000
@ -35,6 +36,7 @@ func Search(c *middleware.Context) {
IsStarred: starred == "true",
OrgId: c.OrgId,
DashboardIds: dbids,
Type: dashboardType,
}
err := bus.Dispatch(&searchQuery)

@ -45,6 +45,7 @@ func searchHandler(query *Query) error {
IsStarred: query.IsStarred,
OrgId: query.OrgId,
DashboardIds: query.DashboardIds,
Type: query.Type,
}
if err := bus.Dispatch(&dashQuery); err != nil {

@ -46,6 +46,7 @@ type Query struct {
UserId int64
Limit int
IsStarred bool
Type string
DashboardIds []int
Result HitList
@ -57,6 +58,7 @@ type FindPersistedDashboardsQuery struct {
UserId int64
IsStarred bool
DashboardIds []int
Type string
Result HitList
}

@ -201,6 +201,14 @@ func findDashboards(query *search.FindPersistedDashboardsQuery) ([]DashboardSear
params = append(params, "%"+query.Title+"%")
}
if len(query.Type) > 0 && query.Type == "dash-folder" {
sql.WriteString(" AND dashboard.is_folder = 1")
}
if len(query.Type) > 0 && query.Type == "dash-db" {
sql.WriteString(" AND dashboard.is_folder = 0")
}
sql.WriteString(fmt.Sprintf(" ORDER BY dashboard.title ASC LIMIT 1000"))
var res []DashboardSearchProjection

Loading…
Cancel
Save