Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
nexpie-grafana-theme
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Registry
Registry
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kornkitt Poolsup
nexpie-grafana-theme
Commits
8574dca0
Commit
8574dca0
authored
Feb 06, 2019
by
Torkel Ödegaard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
making changes suggested in review and improving typings
parent
a53c3b45
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
97 additions
and
45 deletions
+97
-45
public/app/features/dashboard/services/DashboardSrv.ts
+15
-15
public/app/features/dashboard/state/DashboardModel.ts
+3
-3
public/app/features/dashboard/state/actions.ts
+1
-6
public/app/features/dashboard/state/initDashboard.ts
+23
-14
public/app/routes/GrafanaCtrl.ts
+8
-3
public/app/types/dashboard.ts
+37
-4
public/app/types/store.ts
+10
-0
No files found.
public/app/features/dashboard/services/DashboardSrv.ts
View file @
8574dca0
...
...
@@ -5,7 +5,7 @@ import { DashboardModel } from '../state/DashboardModel';
import
{
removePanel
}
from
'../utils/panel'
;
export
class
DashboardSrv
{
dash
:
DashboardModel
;
dash
board
:
DashboardModel
;
/** @ngInject */
constructor
(
private
backendSrv
,
private
$rootScope
,
private
$location
)
{
...
...
@@ -19,11 +19,11 @@ export class DashboardSrv {
}
setCurrent
(
dashboard
:
DashboardModel
)
{
this
.
dash
=
dashboard
;
this
.
dash
board
=
dashboard
;
}
getCurrent
():
DashboardModel
{
return
this
.
dash
;
return
this
.
dash
board
;
}
onRemovePanel
=
(
panelId
:
number
)
=>
{
...
...
@@ -124,10 +124,10 @@ export class DashboardSrv {
}
postSave
(
clone
,
data
)
{
this
.
dash
.
version
=
data
.
version
;
this
.
dash
board
.
version
=
data
.
version
;
// important that these happens before location redirect below
this
.
$rootScope
.
appEvent
(
'dashboard-saved'
,
this
.
dash
);
this
.
$rootScope
.
appEvent
(
'dashboard-saved'
,
this
.
dash
board
);
this
.
$rootScope
.
appEvent
(
'alert-success'
,
[
'Dashboard saved'
]);
const
newUrl
=
locationUtil
.
stripBaseFromUrl
(
data
.
url
);
...
...
@@ -137,12 +137,12 @@ export class DashboardSrv {
this
.
$location
.
url
(
newUrl
).
replace
();
}
return
this
.
dash
;
return
this
.
dash
board
;
}
save
(
clone
,
options
)
{
options
=
options
||
{};
options
.
folderId
=
options
.
folderId
>=
0
?
options
.
folderId
:
this
.
dash
.
meta
.
folderId
||
clone
.
folderId
;
options
.
folderId
=
options
.
folderId
>=
0
?
options
.
folderId
:
this
.
dash
board
.
meta
.
folderId
||
clone
.
folderId
;
return
this
.
backendSrv
.
saveDashboard
(
clone
,
options
)
...
...
@@ -152,26 +152,26 @@ export class DashboardSrv {
saveDashboard
(
options
?,
clone
?)
{
if
(
clone
)
{
this
.
setCurrent
(
this
.
create
(
clone
,
this
.
dash
.
meta
));
this
.
setCurrent
(
this
.
create
(
clone
,
this
.
dash
board
.
meta
));
}
if
(
this
.
dash
.
meta
.
provisioned
)
{
if
(
this
.
dash
board
.
meta
.
provisioned
)
{
return
this
.
showDashboardProvisionedModal
();
}
if
(
!
this
.
dash
.
meta
.
canSave
&&
options
.
makeEditable
!==
true
)
{
if
(
!
this
.
dash
board
.
meta
.
canSave
&&
options
.
makeEditable
!==
true
)
{
return
Promise
.
resolve
();
}
if
(
this
.
dash
.
title
===
'New dashboard'
)
{
if
(
this
.
dash
board
.
title
===
'New dashboard'
)
{
return
this
.
showSaveAsModal
();
}
if
(
this
.
dash
.
version
>
0
)
{
if
(
this
.
dash
board
.
version
>
0
)
{
return
this
.
showSaveModal
();
}
return
this
.
save
(
this
.
dash
.
getSaveModelClone
(),
options
);
return
this
.
save
(
this
.
dash
board
.
getSaveModelClone
(),
options
);
}
saveJSONDashboard
(
json
:
string
)
{
...
...
@@ -212,8 +212,8 @@ export class DashboardSrv {
}
return
promise
.
then
(
res
=>
{
if
(
this
.
dash
&&
this
.
dash
.
id
===
dashboardId
)
{
this
.
dash
.
meta
.
isStarred
=
res
;
if
(
this
.
dash
board
&&
this
.
dashboard
.
id
===
dashboardId
)
{
this
.
dash
board
.
meta
.
isStarred
=
res
;
}
return
res
;
});
...
...
public/app/features/dashboard/state/DashboardModel.ts
View file @
8574dca0
...
...
@@ -15,7 +15,7 @@ import sortByKeys from 'app/core/utils/sort_by_keys';
import
{
PanelModel
}
from
'./PanelModel'
;
import
{
DashboardMigrator
}
from
'./DashboardMigrator'
;
import
{
TimeRange
}
from
'@grafana/ui/src'
;
import
{
UrlQueryValue
}
from
'app/types'
;
import
{
UrlQueryValue
,
KIOSK_MODE_TV
,
DashboardMeta
}
from
'app/types'
;
export
class
DashboardModel
{
id
:
any
;
...
...
@@ -49,7 +49,7 @@ export class DashboardModel {
// repeat process cycles
iteration
:
number
;
meta
:
any
;
meta
:
DashboardMeta
;
events
:
Emitter
;
static
nonPersistedProperties
:
{
[
str
:
string
]:
boolean
}
=
{
...
...
@@ -887,7 +887,7 @@ export class DashboardModel {
}
// add back navbar height
if
(
kioskMode
===
'tv'
)
{
if
(
kioskMode
===
KIOSK_MODE_TV
)
{
visibleHeight
+=
55
;
}
...
...
public/app/features/dashboard/state/actions.ts
View file @
8574dca0
// Libaries
import
{
ThunkAction
}
from
'redux-thunk'
;
// Services & Utils
import
{
getBackendSrv
}
from
'app/core/services/backend_srv'
;
import
{
actionCreatorFactory
,
noPayloadActionCreatorFactory
}
from
'app/core/redux'
;
...
...
@@ -11,7 +8,7 @@ import { loadPluginDashboards } from '../../plugins/state/actions';
import
{
notifyApp
}
from
'app/core/actions'
;
// Types
import
{
StoreState
}
from
'app/types'
;
import
{
ThunkResult
}
from
'app/types'
;
import
{
DashboardAcl
,
DashboardAclDTO
,
...
...
@@ -26,8 +23,6 @@ export const setDashboardLoadingState = actionCreatorFactory<DashboardLoadingSta
export
const
setDashboardModel
=
actionCreatorFactory
<
MutableDashboard
>
(
'SET_DASHBOARD_MODEL'
).
create
();
export
const
setDashboardLoadingSlow
=
noPayloadActionCreatorFactory
(
'SET_DASHBOARD_LOADING_SLOW'
).
create
();
export
type
ThunkResult
<
R
>
=
ThunkAction
<
R
,
StoreState
,
undefined
,
any
>
;
export
function
getDashboardPermissions
(
id
:
number
):
ThunkResult
<
void
>
{
return
async
dispatch
=>
{
const
permissions
=
await
getBackendSrv
().
get
(
`/api/dashboards/id/
${
id
}
/permissions`
);
...
...
public/app/features/dashboard/state/initDashboard.ts
View file @
8574dca0
// Libraries
import
{
ThunkDispatch
}
from
'redux-thunk'
;
// Services & Utils
import
{
createErrorNotification
}
from
'app/core/copy/appNotification'
;
import
{
getBackendSrv
}
from
'app/core/services/backend_srv'
;
import
{
DashboardSrv
}
from
'app/features/dashboard/services/DashboardSrv'
;
import
{
DashboardLoaderSrv
}
from
'app/features/dashboard/services/DashboardLoaderSrv'
;
import
{
TimeSrv
}
from
'app/features/dashboard/services/TimeSrv'
;
import
{
AnnotationsSrv
}
from
'app/features/annotations/annotations_srv'
;
import
{
VariableSrv
}
from
'app/features/templating/variable_srv'
;
...
...
@@ -14,14 +12,19 @@ import { KeybindingSrv } from 'app/core/services/keybindingSrv';
import
{
updateLocation
}
from
'app/core/actions'
;
import
{
notifyApp
}
from
'app/core/actions'
;
import
locationUtil
from
'app/core/utils/location_util'
;
import
{
setDashboardLoadingState
,
ThunkResult
,
setDashboardModel
,
setDashboardLoadingSlow
}
from
'./actions'
;
import
{
setDashboardLoadingState
,
setDashboardModel
,
setDashboardLoadingSlow
}
from
'./actions'
;
// Types
import
{
DashboardLoadingState
,
DashboardRouteInfo
,
StoreState
}
from
'app/types'
;
import
{
DashboardLoadingState
,
DashboardRouteInfo
,
StoreState
,
ThunkDispatch
,
ThunkResult
,
DashboardDTO
,
}
from
'app/types'
;
import
{
DashboardModel
}
from
'./DashboardModel'
;
export
type
Dispatch
=
ThunkDispatch
<
StoreState
,
undefined
,
any
>
;
export
interface
InitDashboardArgs
{
$injector
:
any
;
$scope
:
any
;
...
...
@@ -33,7 +36,7 @@ export interface InitDashboardArgs {
fixUrl
:
boolean
;
}
async
function
redirectToNewUrl
(
slug
:
string
,
dispatch
:
Dispatch
,
currentPath
:
string
)
{
async
function
redirectToNewUrl
(
slug
:
string
,
dispatch
:
Thunk
Dispatch
,
currentPath
:
string
)
{
const
res
=
await
getBackendSrv
().
getDashboardBySlug
(
slug
);
if
(
res
)
{
...
...
@@ -49,18 +52,22 @@ async function redirectToNewUrl(slug: string, dispatch: Dispatch, currentPath: s
}
}
async
function
fetchDashboard
(
args
:
InitDashboardArgs
,
dispatch
:
Dispatch
,
getState
:
()
=>
StoreState
):
Promise
<
any
>
{
async
function
fetchDashboard
(
args
:
InitDashboardArgs
,
dispatch
:
ThunkDispatch
,
getState
:
()
=>
StoreState
):
Promise
<
DashboardDTO
|
null
>
{
try
{
switch
(
args
.
routeInfo
)
{
case
DashboardRouteInfo
.
Home
:
{
// load home dash
const
dashDTO
=
await
getBackendSrv
().
get
(
'/api/dashboards/home'
);
const
dashDTO
:
DashboardDTO
=
await
getBackendSrv
().
get
(
'/api/dashboards/home'
);
// if user specified a custom home dashboard redirect to that
if
(
dashDTO
.
redirectUri
)
{
const
newUrl
=
locationUtil
.
stripBaseFromUrl
(
dashDTO
.
redirectUri
);
dispatch
(
updateLocation
({
path
:
newUrl
,
replace
:
true
}));
return
;
return
null
;
}
// disable some actions on the default home dashboard
...
...
@@ -76,8 +83,8 @@ async function fetchDashboard(args: InitDashboardArgs, dispatch: Dispatch, getSt
return
null
;
}
const
loaderSrv
=
args
.
$injector
.
get
(
'dashboardLoaderSrv'
);
const
dashDTO
=
await
loaderSrv
.
loadDashboard
(
args
.
urlType
,
args
.
urlSlug
,
args
.
urlUid
);
const
loaderSrv
:
DashboardLoaderSrv
=
args
.
$injector
.
get
(
'dashboardLoaderSrv'
);
const
dashDTO
:
DashboardDTO
=
await
loaderSrv
.
loadDashboard
(
args
.
urlType
,
args
.
urlSlug
,
args
.
urlUid
);
if
(
args
.
fixUrl
&&
dashDTO
.
meta
.
url
)
{
// check if the current url is correct (might be old slug)
...
...
@@ -95,6 +102,8 @@ async function fetchDashboard(args: InitDashboardArgs, dispatch: Dispatch, getSt
case
DashboardRouteInfo
.
New
:
{
return
getNewDashboardModelData
(
args
.
urlFolderId
);
}
default
:
throw
{
message
:
'Unknown route '
+
args
.
routeInfo
};
}
}
catch
(
err
)
{
dispatch
(
setDashboardLoadingState
(
DashboardLoadingState
.
Error
));
...
...
@@ -149,7 +158,7 @@ export function initDashboard(args: InitDashboardArgs): ThunkResult<void> {
}
// add missing orgId query param
const
storeState
=
getState
()
;
const
storeState
=
getState
();
if
(
!
storeState
.
location
.
query
.
orgId
)
{
dispatch
(
updateLocation
({
query
:
{
orgId
:
storeState
.
user
.
orgId
},
partial
:
true
,
replace
:
true
}));
}
...
...
public/app/routes/GrafanaCtrl.ts
View file @
8574dca0
import
config
from
'app/core/config'
;
// Libraries
import
_
from
'lodash'
;
import
$
from
'jquery'
;
import
Drop
from
'tether-drop'
;
import
{
colors
}
from
'@grafana/ui'
;
// Utils and servies
import
{
colors
}
from
'@grafana/ui'
;
import
config
from
'app/core/config'
;
import
coreModule
from
'app/core/core_module'
;
import
{
profiler
}
from
'app/core/profiler'
;
import
appEvents
from
'app/core/app_events'
;
...
...
@@ -13,6 +15,9 @@ import { DatasourceSrv, setDatasourceSrv } from 'app/features/plugins/datasource
import
{
AngularLoader
,
setAngularLoader
}
from
'app/core/services/AngularLoader'
;
import
{
configureStore
}
from
'app/store/configureStore'
;
// Types
import
{
KioskUrlValue
}
from
'app/types'
;
export
class
GrafanaCtrl
{
/** @ngInject */
constructor
(
...
...
@@ -67,7 +72,7 @@ export class GrafanaCtrl {
}
}
function
setViewModeBodyClass
(
body
,
mode
,
sidemenuOpen
:
boolean
)
{
function
setViewModeBodyClass
(
body
,
mode
:
KioskUrlValue
,
sidemenuOpen
:
boolean
)
{
body
.
removeClass
(
'view-mode--tv'
);
body
.
removeClass
(
'view-mode--kiosk'
);
body
.
removeClass
(
'view-mode--inactive'
);
...
...
public/app/types/dashboard.ts
View file @
8574dca0
import
{
DashboardAcl
}
from
'./acl'
;
export
interface
MutableDashboard
{
meta
:
{
fullscreen
:
boolean
;
isEditing
:
boolean
;
};
meta
:
DashboardMeta
;
}
export
interface
DashboardDTO
{
redirectUri
?:
string
;
dashboard
:
DashboardDataDTO
;
meta
:
DashboardMeta
;
}
export
interface
DashboardMeta
{
canSave
?:
boolean
;
canEdit
?:
boolean
;
canShare
?:
boolean
;
canStar
?:
boolean
;
canAdmin
?:
boolean
;
url
?:
string
;
folderId
?:
number
;
fullscreen
?:
boolean
;
isEditing
?:
boolean
;
canMakeEditable
?:
boolean
;
submenuEnabled
?:
boolean
;
provisioned
?:
boolean
;
focusPanelId
?:
boolean
;
isStarred
?:
boolean
;
showSettings
?:
boolean
;
expires
:
string
;
isSnapshot
?:
boolean
;
folderTitle
?:
string
;
folderUrl
?:
string
;
created
?:
string
;
}
export
interface
DashboardDataDTO
{
title
:
string
;
}
export
enum
DashboardRouteInfo
{
...
...
@@ -22,6 +52,9 @@ export enum DashboardLoadingState {
Done
=
'Done'
,
}
export
const
KIOSK_MODE_TV
=
'tv'
;
export
type
KioskUrlValue
=
'tv'
|
'1'
|
true
;
export
interface
DashboardState
{
model
:
MutableDashboard
|
null
;
loadingState
:
DashboardLoadingState
;
...
...
public/app/types/store.ts
View file @
8574dca0
import
{
ThunkAction
,
ThunkDispatch
as
GenericThunkDispatch
}
from
'redux-thunk'
;
import
{
ActionOf
}
from
'app/core/redux'
;
import
{
NavIndex
}
from
'./navModel'
;
import
{
LocationState
}
from
'./location'
;
import
{
AlertRulesState
}
from
'./alerting'
;
...
...
@@ -27,3 +30,10 @@ export interface StoreState {
user
:
UserState
;
plugins
:
PluginsState
;
}
/*
* Utility type to get strongly types thunks
*/
export
type
ThunkResult
<
R
>
=
ThunkAction
<
R
,
StoreState
,
undefined
,
ActionOf
<
any
>>
;
export
type
ThunkDispatch
=
GenericThunkDispatch
<
StoreState
,
undefined
,
any
>
;
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment