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
7616cfb5
Commit
7616cfb5
authored
Jan 11, 2018
by
Johannes Schill
Committed by
Daniel Lee
Jan 25, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dashfolders: wip - Move Permissions into React #10275
parent
bc5fae53
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
429 additions
and
0 deletions
+429
-0
public/app/core/angular_wrappers.ts
+9
-0
public/app/core/components/Permissions/Permissions.tsx
+256
-0
public/app/core/components/Permissions/PermissionsList.tsx
+81
-0
public/app/core/components/Permissions/PermissionsListItem.tsx
+60
-0
public/app/features/dashboard/acl/acl.html
+23
-0
No files found.
public/app/core/angular_wrappers.ts
View file @
7616cfb5
...
@@ -6,6 +6,7 @@ import LoginBackground from './components/Login/LoginBackground';
...
@@ -6,6 +6,7 @@ import LoginBackground from './components/Login/LoginBackground';
import
{
SearchResult
}
from
'./components/search/SearchResult'
;
import
{
SearchResult
}
from
'./components/search/SearchResult'
;
import
UserPicker
from
'./components/UserPicker/UserPicker'
;
import
UserPicker
from
'./components/UserPicker/UserPicker'
;
import
{
TagFilter
}
from
'./components/TagFilter/TagFilter'
;
import
{
TagFilter
}
from
'./components/TagFilter/TagFilter'
;
import
Permissions
from
'./components/Permissions/Permissions'
;
export
function
registerAngularDirectives
()
{
export
function
registerAngularDirectives
()
{
react2AngularDirective
(
'passwordStrength'
,
PasswordStrength
,
[
'password'
]);
react2AngularDirective
(
'passwordStrength'
,
PasswordStrength
,
[
'password'
]);
...
@@ -19,4 +20,12 @@ export function registerAngularDirectives() {
...
@@ -19,4 +20,12 @@ export function registerAngularDirectives() {
[
'onSelect'
,
{
watchDepth
:
'reference'
}],
[
'onSelect'
,
{
watchDepth
:
'reference'
}],
[
'tagOptions'
,
{
watchDepth
:
'reference'
}],
[
'tagOptions'
,
{
watchDepth
:
'reference'
}],
]);
]);
react2AngularDirective
(
'permissions'
,
Permissions
,
[
'error'
,
'newType'
,
'aclTypes'
,
'typeChanged'
,
'backendSrv'
,
'dashboardId'
,
]);
}
}
public/app/core/components/Permissions/Permissions.tsx
0 → 100644
View file @
7616cfb5
import
React
,
{
Component
}
from
'react'
;
import
PermissionsList
from
'./PermissionsList'
;
import
_
from
'lodash'
;
export
interface
DashboardAcl
{
id
?:
number
;
dashboardId
?:
number
;
userId
?:
number
;
userLogin
?:
string
;
userEmail
?:
string
;
teamId
?:
number
;
team
?:
string
;
permission
?:
number
;
permissionName
?:
string
;
role
?:
string
;
icon
?:
string
;
nameHtml
?:
string
;
inherited
?:
boolean
;
sortName
?:
string
;
sortRank
?:
number
;
}
export
interface
IProps
{
error
:
any
;
newType
:
any
;
aclTypes
:
any
;
typeChanged
:
any
;
backendSrv
:
any
;
dashboardId
:
number
;
}
class
Permissions
extends
Component
<
IProps
,
any
>
{
dashboardId
:
any
;
meta
:
any
;
items
:
DashboardAcl
[];
dummyItems
:
DashboardAcl
[];
permissionOptions
=
[{
value
:
1
,
text
:
'View'
},
{
value
:
2
,
text
:
'Edit'
},
{
value
:
4
,
text
:
'Admin'
}];
backendSrv
:
any
;
aclTypes
=
[
{
value
:
'Group'
,
text
:
'Team'
},
{
value
:
'User'
,
text
:
'User'
},
{
value
:
'Viewer'
,
text
:
'Everyone With Viewer Role'
},
{
value
:
'Editor'
,
text
:
'Everyone With Editor Role'
},
];
newType
:
string
;
canUpdate
:
boolean
;
error
:
string
;
readonly
duplicateError
=
'This permission exists already.'
;
constructor
(
props
)
{
super
(
props
);
this
.
dashboardId
=
this
.
props
.
dashboardId
;
this
.
backendSrv
=
this
.
props
.
backendSrv
;
this
.
permissionChanged
=
this
.
permissionChanged
.
bind
(
this
);
console
.
log
(
'this.setState'
,
this
.
setState
);
this
.
state
=
{
items
:
[],
newType
:
''
,
canUpdate
:
false
,
error
:
''
,
};
}
componentWillMount
()
{
this
.
getAcl
(
this
.
props
.
dashboardId
);
}
getAcl
(
dashboardId
:
number
)
{
return
this
.
backendSrv
.
get
(
`/api/dashboards/id/
${
dashboardId
}
/acl`
).
then
(
result
=>
{
console
.
log
(
'this'
,
this
.
setState
);
const
items
=
result
.
map
(
this
.
prepareViewModel
.
bind
(
this
));
// this.items = _.map(result, this.prepareViewModel.bind(this));
this
.
setState
(
prevState
=>
{
return
{
...
prevState
,
items
:
this
.
sortItems
(
items
),
};
});
});
}
sortItems
(
items
)
{
return
_
.
orderBy
(
items
,
[
'sortRank'
,
'sortName'
],
[
'desc'
,
'asc'
]);
}
permissionChanged
()
{
this
.
setState
(
prevState
=>
{
return
{
...
prevState
,
canUpdate
:
true
,
};
});
}
removeItem
(
index
)
{
this
.
setState
(
prevState
=>
{
return
{
...
prevState
,
items
:
this
.
state
.
items
.
splice
(
index
,
1
),
canUpdate
:
true
,
};
});
}
update
()
{
var
updated
=
[];
for
(
let
item
of
this
.
state
.
items
)
{
if
(
item
.
inherited
)
{
continue
;
}
updated
.
push
({
id
:
item
.
id
,
userId
:
item
.
userId
,
teamId
:
item
.
teamId
,
role
:
item
.
role
,
permission
:
item
.
permission
,
});
}
return
this
.
backendSrv
.
post
(
`/api/dashboards/id/
${
this
.
dashboardId
}
/acl`
,
{
items
:
updated
,
})
.
then
(()
=>
{
this
.
setState
(
prevState
=>
{
return
{
...
prevState
,
canUpdate
:
false
,
};
});
});
}
prepareViewModel
(
item
:
DashboardAcl
):
DashboardAcl
{
// TODO: this.meta
// item.inherited = !this.meta.isFolder && this.dashboardId !== item.dashboardId;
item
.
inherited
=
this
.
dashboardId
!==
item
.
dashboardId
;
item
.
sortRank
=
0
;
if
(
item
.
userId
>
0
)
{
item
.
icon
=
'fa fa-fw fa-user'
;
// item.nameHtml = this.$sce.trustAsHtml(item.userLogin);
item
.
nameHtml
=
item
.
userLogin
;
item
.
sortName
=
item
.
userLogin
;
item
.
sortRank
=
10
;
}
else
if
(
item
.
teamId
>
0
)
{
item
.
icon
=
'fa fa-fw fa-users'
;
// item.nameHtml = this.$sce.trustAsHtml(item.team);
item
.
nameHtml
=
item
.
team
;
item
.
sortName
=
item
.
team
;
item
.
sortRank
=
20
;
}
else
if
(
item
.
role
)
{
item
.
icon
=
'fa fa-fw fa-street-view'
;
// item.nameHtml = this.$sce.trustAsHtml(`Everyone with <span class="query-keyword">${item.role}</span> Role`);
item
.
nameHtml
=
`Everyone with <span class="query-keyword">
${
item
.
role
}
</span> Role`
;
item
.
sortName
=
item
.
role
;
item
.
sortRank
=
30
;
if
(
item
.
role
===
'Viewer'
)
{
item
.
sortRank
+=
1
;
}
}
if
(
item
.
inherited
)
{
item
.
sortRank
+=
100
;
}
return
item
;
}
// componentWillUpdate(nextProps, nextState) {
// console.log('nextProps', nextProps);
// console.log('nextState', nextState);
// }
// componentWillReceiveProps(nextProps) {
// console.log('nextPropzzzz', nextProps);
// }
render
()
{
const
{
error
,
newType
,
aclTypes
,
typeChanged
}
=
this
.
props
;
const
{
items
,
canUpdate
}
=
this
.
state
;
const
handleTypeChange
=
()
=>
{
typeChanged
();
};
return
(
<
div
className=
"gf-form-group"
>
asd
<
PermissionsList
permissions=
{
items
}
permissionsOptions=
{
this
.
permissionOptions
}
removeItem=
{
this
.
removeItem
}
permissionChanged=
{
this
.
permissionChanged
}
/>
asd2
<
div
className=
"gf-form-inline"
>
<
form
name=
"addPermission"
className=
"gf-form-group"
>
<
h6
className=
"muted"
>
Add Permission For
</
h6
>
<
div
className=
"gf-form-inline"
>
<
div
className=
"gf-form"
>
<
div
className=
"gf-form-select-wrapper"
>
<
select
className=
"gf-form-input gf-size-auto"
onChange=
{
handleTypeChange
}
>
{
aclTypes
.
map
((
option
,
idx
)
=>
{
return
(
<
option
key=
{
idx
}
value=
{
option
.
value
}
>
{
option
.
text
}
</
option
>
);
})
}
</
select
>
{
/* <select
className="gf-form-input gf-size-auto"
ng-model="ctrl.newType"
ng-options="p.value as p.text for p in ctrl.aclTypes"
ng-change="ctrl.typeChanged()"
/> */
}
</
div
>
</
div
>
{
newType
===
'User'
?
(
<
div
className=
"gf-form"
>
<
user
-
picker
user
-
picked=
"ctrl.userPicked($user)"
/>
</
div
>
)
:
null
}
{
newType
===
'Group'
?
(
<
div
className=
"gf-form"
>
<
team
-
picker
team
-
picked=
"ctrl.groupPicked($group)"
/>
</
div
>
)
:
null
}
</
div
>
</
form
>
{
error
?
(
<
div
className=
"gf-form width-17"
>
<
span
ng
-
if=
"ctrl.error"
className=
"text-error p-l-1"
>
<
i
className=
"fa fa-warning"
/>
{
error
}
</
span
>
</
div
>
)
:
null
}
</
div
>
<
div
className=
"gf-form-button-row"
>
<
button
type=
"button"
className=
"btn btn-danger"
onClick=
{
this
.
update
}
disabled=
{
!
canUpdate
}
>
Update Permissions
</
button
>
</
div
>
asd3
</
div
>
);
}
}
export
default
Permissions
;
public/app/core/components/Permissions/PermissionsList.tsx
0 → 100644
View file @
7616cfb5
import
React
,
{
Component
}
from
'react'
;
import
PermissionsListItem
from
'./PermissionsListItem'
;
export
interface
IProps
{
permissions
:
any
[];
permissionsOptions
:
any
[];
removeItem
:
any
;
permissionChanged
:
any
;
}
class
PermissionsList
extends
Component
<
IProps
,
any
>
{
// componentWillUpdate(nextProps, nextState) {
// console.log('nextProps', nextProps);
// console.log('nextState', nextState);
// }
// componentWillReceiveProps(nextProps) {
// console.log('nextPropzzzz', nextProps);
// }
render
()
{
const
{
permissions
,
permissionsOptions
,
removeItem
,
permissionChanged
}
=
this
.
props
;
return
(
<
table
className=
"filter-table gf-form-group"
>
<
tbody
>
{
permissions
.
map
((
item
,
idx
)
=>
{
return
(
<
PermissionsListItem
key=
{
item
.
id
}
item=
{
item
}
itemIndex=
{
idx
}
permissionsOptions=
{
permissionsOptions
}
removeItem=
{
removeItem
}
permissionChanged=
{
permissionChanged
}
/>
);
})
}
{
/* <tr ng-repeat="acl in ctrl.items" ng-class="{'gf-form-disabled': acl.inherited}">
<td><!-- 100% -->
<i className="{{acl.icon}}"></i>
<span ng-bind-html="acl.nameHtml"></span>
</td>
<td>
<em className="muted no-wrap" ng-show="acl.inherited">Inherited from folder</em>
</td>
<td className="query-keyword">Can</td>
<td>
<div className="gf-form-select-wrapper">
<select className="gf-form-input gf-size-auto"
ng-model="acl.permission"
ng-options="p.value as p.text for p in ctrl.permissionOptions"
ng-change="ctrl.permissionChanged(acl)"
ng-disabled="acl.inherited"></select>
</div>
</td>
<td>
<a className="btn btn-inverse btn-small" ng-click="ctrl.removeItem($index)" ng-hide="acl.inherited">
<i className="fa fa-remove"></i>
</a>
</td>
</tr>
<tr ng-show="ctrl.aclItems.length === 0">
<td colSpan={4}>
<em>No permissions are set. Will only be accessible by admins.</em>
</td>
</tr> */
}
{
permissions
.
length
<
1
?
(
<
tr
>
<
td
colSpan=
{
4
}
>
<
em
>
No permissions are set. Will only be accessible by admins.
</
em
>
</
td
>
</
tr
>
)
:
null
}
</
tbody
>
</
table
>
);
}
}
export
default
PermissionsList
;
public/app/core/components/Permissions/PermissionsListItem.tsx
0 → 100644
View file @
7616cfb5
import
React
from
'react'
;
const
setClassNameHelper
=
inherited
=>
{
return
inherited
?
'gf-form-disabled'
:
''
;
};
export
default
({
item
,
permissionsOptions
,
removeItem
,
permissionChanged
,
itemIndex
})
=>
{
const
handleRemoveItem
=
evt
=>
{
evt
.
preventDefault
();
removeItem
(
itemIndex
);
};
const
handleChangePermission
=
evt
=>
{
evt
.
preventDefault
();
permissionChanged
();
};
return
(
<
tr
className=
{
setClassNameHelper
(
item
.
inherited
)
}
>
<
td
style=
{
{
width
:
'100%'
}
}
>
{
/* style="width: 100%;" */
}
<
i
className=
{
item
.
icon
}
/>
<
span
dangerouslySetInnerHTML=
{
{
__html
:
item
.
nameHtml
}
}
/>
</
td
>
<
td
>
{
item
.
inherited
?
<
em
className=
"muted no-wrap"
>
Inherited from folder
</
em
>
:
null
}
</
td
>
<
td
className=
"query-keyword"
>
Can
</
td
>
<
td
>
<
div
className=
"gf-form-select-wrapper"
>
<
select
value=
{
item
.
permission
}
className=
"gf-form-input gf-size-auto"
onChange=
{
handleChangePermission
}
disabled=
{
item
.
inherited
}
>
{
permissionsOptions
.
map
((
option
,
idx
)
=>
{
return
(
<
option
key=
{
idx
}
value=
{
option
.
value
}
>
{
option
.
text
}
</
option
>
);
})
}
</
select
>
{
/* <select className="gf-form-input gf-size-auto"
ng-model="acl.permission"
ng-options="p.value as p.text for p in ctrl.permissionOptions"
ng-change="ctrl.permissionChanged(acl)"
ng-disabled="acl.inherited" /> */
}
</
div
>
</
td
>
<
td
>
{
!
item
.
inherited
?
(
<
a
className=
"btn btn-inverse btn-small"
onClick=
{
handleRemoveItem
}
>
<
i
className=
"fa fa-remove"
/>
</
a
>
)
:
null
}
</
td
>
</
tr
>
);
};
public/app/features/dashboard/acl/acl.html
View file @
7616cfb5
<permissions
error=
"{{ctrl.error}}"
newType=
"ctrl.newType"
aclTypes=
"{{ctrl.aclTypes}}"
typeChanged=
"ctrl.typeChanged"
dashboardId=
"ctrl.dashboard.id"
backendSrv=
"ctrl.backendSrv"
/>
<per
m
i
s
sions
permissions=
"{{ctrl.dummyItems}}"
permissionsOptions=
"{{ctrl.permissionOptions}}"
removeItem=
"ctrl.removeItem"
permissionChanged=
"ctrl.permissionChanged"
error=
"{{ctrl.error}}"
newType=
"ctrl.newType"
aclTypes=
"{{ctrl.aclTypes}}"
typeChanged=
"ctrl.typeChanged"
dashboardId=
"ctrl.dashboard.id"
backendSrv=
"ctrl.backendSrv"
/>
<div
class=
"gf-form-group"
>
<div
class=
"gf-form-group"
>
<table
class=
"filter-table gf-form-group"
>
<table
class=
"filter-table gf-form-group"
>
<tr
ng-repeat=
"acl in ctrl.items"
ng-class=
"{'gf-form-disabled': acl.inherited}"
>
<tr
ng-repeat=
"acl in ctrl.items"
ng-class=
"{'gf-form-disabled': acl.inherited}"
>
...
...
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