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
96aa4ae1
Commit
96aa4ae1
authored
Mar 12, 2019
by
Hugo Häggmark
Committed by
Leonard Gram
Mar 19, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
teams: remov permission select for non admin users
parent
b9cf09a2
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
1214 additions
and
117 deletions
+1214
-117
public/app/core/components/sidemenu/BottomNavLinks.test.tsx
+1
-0
public/app/core/services/context_srv.ts
+1
-0
public/app/features/teams/TeamMembers.test.tsx
+75
-7
public/app/features/teams/TeamMembers.tsx
+33
-12
public/app/features/teams/__snapshots__/TeamMembers.test.tsx.snap
+1104
-98
No files found.
public/app/core/components/sidemenu/BottomNavLinks.test.tsx
View file @
96aa4ae1
...
...
@@ -12,6 +12,7 @@ const setup = (propOverrides?: object) => {
{
link
:
{},
user
:
{
id
:
1
,
isGrafanaAdmin
:
false
,
isSignedIn
:
false
,
orgCount
:
2
,
...
...
public/app/core/services/context_srv.ts
View file @
96aa4ae1
...
...
@@ -3,6 +3,7 @@ import _ from 'lodash';
import
coreModule
from
'app/core/core_module'
;
export
class
User
{
id
:
number
;
isGrafanaAdmin
:
any
;
isSignedIn
:
any
;
orgRole
:
any
;
...
...
public/app/features/teams/TeamMembers.test.tsx
View file @
96aa4ae1
...
...
@@ -4,8 +4,25 @@ import { TeamMembers, Props, State } from './TeamMembers';
import
{
TeamMember
,
TeamPermissionLevel
}
from
'../../types'
;
import
{
getMockTeamMember
,
getMockTeamMembers
}
from
'./__mocks__/teamMocks'
;
import
{
SelectOptionItem
}
from
'@grafana/ui'
;
import
{
contextSrv
}
from
'app/core/services/context_srv'
;
const
setup
=
(
propOverrides
?:
object
)
=>
{
jest
.
mock
(
'app/core/services/context_srv'
,
()
=>
({
contextSrv
:
{
isGrafanaAdmin
:
false
,
hasRole
:
role
=>
false
,
user
:
{
id
:
1
},
},
}));
const
originalContextSrv
=
contextSrv
;
interface
SetupProps
{
propOverrides
?:
object
;
isGrafanaAdmin
?:
boolean
;
isOrgAdmin
?:
boolean
;
}
const
setup
=
(
setupProps
:
SetupProps
)
=>
{
const
props
:
Props
=
{
members
:
[]
as
TeamMember
[],
searchMemberQuery
:
''
,
...
...
@@ -15,9 +32,13 @@ const setup = (propOverrides?: object) => {
removeTeamMember
:
jest
.
fn
(),
updateTeamMember
:
jest
.
fn
(),
syncEnabled
:
false
,
editorsCanAdmin
:
false
,
};
Object
.
assign
(
props
,
propOverrides
);
contextSrv
.
isGrafanaAdmin
=
setupProps
.
isGrafanaAdmin
||
false
;
contextSrv
.
hasRole
=
role
=>
setupProps
.
isOrgAdmin
||
false
;
Object
.
assign
(
props
,
setupProps
.
propOverrides
);
const
wrapper
=
shallow
(<
TeamMembers
{
...
props
}
/>);
const
instance
=
wrapper
.
instance
()
as
TeamMembers
;
...
...
@@ -29,15 +50,22 @@ const setup = (propOverrides?: object) => {
};
describe
(
'Render'
,
()
=>
{
beforeEach
(()
=>
{
contextSrv
.
isGrafanaAdmin
=
originalContextSrv
.
isGrafanaAdmin
;
contextSrv
.
hasRole
=
originalContextSrv
.
hasRole
;
});
it
(
'should render component'
,
()
=>
{
const
{
wrapper
}
=
setup
();
const
{
wrapper
}
=
setup
(
{}
);
expect
(
wrapper
).
toMatchSnapshot
();
});
it
(
'should render team members'
,
()
=>
{
const
{
wrapper
}
=
setup
({
propOverrides
:
{
members
:
getMockTeamMembers
(
5
),
},
});
expect
(
wrapper
).
toMatchSnapshot
();
...
...
@@ -45,18 +73,58 @@ describe('Render', () => {
it
(
'should render team members when sync enabled'
,
()
=>
{
const
{
wrapper
}
=
setup
({
propOverrides
:
{
members
:
getMockTeamMembers
(
5
),
syncEnabled
:
true
,
},
});
expect
(
wrapper
).
toMatchSnapshot
();
});
describe
(
'when feature toggle editorsCanAdmin is turned on'
,
()
=>
{
it
(
'should render permissions select if user is Grafana Admin'
,
()
=>
{
const
members
=
getMockTeamMembers
(
5
);
members
[
4
].
permission
=
TeamPermissionLevel
.
Admin
;
const
{
wrapper
}
=
setup
({
propOverrides
:
{
members
,
editorsCanAdmin
:
true
},
isGrafanaAdmin
:
true
,
isOrgAdmin
:
false
,
});
expect
(
wrapper
).
toMatchSnapshot
();
});
it
(
'should render permissions select if user is Org Admin'
,
()
=>
{
const
members
=
getMockTeamMembers
(
5
);
members
[
4
].
permission
=
TeamPermissionLevel
.
Admin
;
const
{
wrapper
}
=
setup
({
propOverrides
:
{
members
,
editorsCanAdmin
:
true
},
isGrafanaAdmin
:
false
,
isOrgAdmin
:
true
,
});
expect
(
wrapper
).
toMatchSnapshot
();
});
it
(
'should render permissions select if user is team admin'
,
()
=>
{
const
members
=
getMockTeamMembers
(
5
);
members
[
0
].
permission
=
TeamPermissionLevel
.
Admin
;
const
{
wrapper
}
=
setup
({
propOverrides
:
{
members
,
editorsCanAdmin
:
true
},
isGrafanaAdmin
:
false
,
isOrgAdmin
:
false
,
});
expect
(
wrapper
).
toMatchSnapshot
();
});
});
});
describe
(
'Functions'
,
()
=>
{
describe
(
'on search member query change'
,
()
=>
{
it
(
'it should call setSearchMemberQuery'
,
()
=>
{
const
{
instance
}
=
setup
();
const
{
instance
}
=
setup
(
{}
);
instance
.
onSearchQueryChange
(
'member'
);
...
...
@@ -65,7 +133,7 @@ describe('Functions', () => {
});
describe
(
'on remove member'
,
()
=>
{
const
{
instance
}
=
setup
();
const
{
instance
}
=
setup
(
{}
);
const
mockTeamMember
=
getMockTeamMember
();
instance
.
onRemoveMember
(
mockTeamMember
);
...
...
@@ -74,7 +142,7 @@ describe('Functions', () => {
});
describe
(
'on add user to team'
,
()
=>
{
const
{
wrapper
,
instance
}
=
setup
();
const
{
wrapper
,
instance
}
=
setup
(
{}
);
const
state
=
wrapper
.
state
()
as
State
;
state
.
newTeamMember
=
{
...
...
@@ -90,7 +158,7 @@ describe('Functions', () => {
});
describe
(
'on update permision for user in team'
,
()
=>
{
const
{
instance
}
=
setup
();
const
{
instance
}
=
setup
(
{}
);
const
permission
=
TeamPermissionLevel
.
Admin
;
const
item
:
SelectOptionItem
=
{
value
:
permission
};
const
member
:
TeamMember
=
{
...
...
public/app/features/teams/TeamMembers.tsx
View file @
96aa4ae1
...
...
@@ -4,7 +4,7 @@ import SlideDown from 'app/core/components/Animations/SlideDown';
import
{
UserPicker
}
from
'app/core/components/Select/UserPicker'
;
import
{
DeleteButton
,
Select
,
SelectOptionItem
}
from
'@grafana/ui'
;
import
{
TagBadge
}
from
'app/core/components/TagFilter/TagBadge'
;
import
{
TeamMember
,
User
,
teamsPermissionLevels
}
from
'app/types'
;
import
{
TeamMember
,
User
,
teamsPermissionLevels
,
TeamPermissionLevel
,
OrgRole
}
from
'app/types'
;
import
{
loadTeamMembers
,
addTeamMember
,
...
...
@@ -16,6 +16,7 @@ import { getSearchMemberQuery, getTeamMembers } from './state/selectors';
import
{
FilterInput
}
from
'app/core/components/FilterInput/FilterInput'
;
import
{
WithFeatureToggle
}
from
'app/core/components/WithFeatureToggle'
;
import
{
config
}
from
'app/core/config'
;
import
{
contextSrv
}
from
'app/core/services/context_srv'
;
export
interface
Props
{
members
:
TeamMember
[];
...
...
@@ -26,6 +27,7 @@ export interface Props {
setSearchMemberQuery
:
typeof
setSearchMemberQuery
;
updateTeamMember
:
typeof
updateTeamMember
;
syncEnabled
:
boolean
;
editorsCanAdmin
?:
boolean
;
}
export
interface
State
{
...
...
@@ -37,6 +39,7 @@ export class TeamMembers extends PureComponent<Props, State> {
constructor
(
props
)
{
super
(
props
);
this
.
state
=
{
isAdding
:
false
,
newTeamMember
:
null
};
this
.
renderPermissionsSelect
=
this
.
renderPermissionsSelect
.
bind
(
this
);
}
componentDidMount
()
{
...
...
@@ -85,27 +88,44 @@ export class TeamMembers extends PureComponent<Props, State> {
this
.
props
.
updateTeamMember
(
updatedTeamMember
);
};
renderMember
(
member
:
TeamMember
,
syncEnabled
:
boolean
)
{
renderPermissionsSelect
(
member
:
TeamMember
)
{
const
{
members
,
editorsCanAdmin
}
=
this
.
props
;
const
userInMembers
=
members
.
find
(
m
=>
m
.
userId
===
contextSrv
.
user
.
id
);
const
isUserTeamAdmin
=
contextSrv
.
isGrafanaAdmin
||
contextSrv
.
hasRole
(
OrgRole
.
Admin
)
?
true
:
userInMembers
&&
userInMembers
.
permission
===
TeamPermissionLevel
.
Admin
;
const
value
=
teamsPermissionLevels
.
find
(
dp
=>
dp
.
value
===
member
.
permission
);
return
(
<
tr
key=
{
member
.
userId
}
>
<
td
className=
"width-4 text-center"
>
<
img
className=
"filter-table__avatar"
src=
{
member
.
avatarUrl
}
/>
</
td
>
<
td
>
{
member
.
login
}
</
td
>
<
td
>
{
member
.
email
}
</
td
>
<
WithFeatureToggle
featureToggle=
{
config
.
editorsCanAdmin
}
>
<
WithFeatureToggle
featureToggle=
{
editorsCanAdmin
}
>
<
td
>
<
div
className=
"gf-form"
>
{
isUserTeamAdmin
&&
(
<
Select
isSearchable=
{
false
}
options=
{
teamsPermissionLevels
}
onChange=
{
item
=>
this
.
onPermissionChange
(
item
,
member
)
}
className=
"gf-form-select-box__control--menu-right"
value=
{
teamsPermissionLevels
.
find
(
dp
=>
dp
.
value
===
member
.
permission
)
}
value=
{
value
}
/>
)
}
{
!
isUserTeamAdmin
&&
<
span
>
{
value
.
label
}
</
span
>
}
</
div
>
</
td
>
</
WithFeatureToggle
>
);
}
renderMember
(
member
:
TeamMember
,
syncEnabled
:
boolean
)
{
return
(
<
tr
key=
{
member
.
userId
}
>
<
td
className=
"width-4 text-center"
>
<
img
className=
"filter-table__avatar"
src=
{
member
.
avatarUrl
}
/>
</
td
>
<
td
>
{
member
.
login
}
</
td
>
<
td
>
{
member
.
email
}
</
td
>
{
this
.
renderPermissionsSelect
(
member
)
}
{
syncEnabled
&&
this
.
renderLabels
(
member
.
labels
)
}
<
td
className=
"text-right"
>
<
DeleteButton
onConfirm=
{
()
=>
this
.
onRemoveMember
(
member
)
}
/>
...
...
@@ -116,7 +136,7 @@ export class TeamMembers extends PureComponent<Props, State> {
render
()
{
const
{
isAdding
}
=
this
.
state
;
const
{
searchMemberQuery
,
members
,
syncEnabled
}
=
this
.
props
;
const
{
searchMemberQuery
,
members
,
syncEnabled
,
editorsCanAdmin
}
=
this
.
props
;
return
(
<
div
>
<
div
className=
"page-action-bar"
>
...
...
@@ -161,7 +181,7 @@ export class TeamMembers extends PureComponent<Props, State> {
<
th
/>
<
th
>
Name
</
th
>
<
th
>
Email
</
th
>
<
WithFeatureToggle
featureToggle=
{
config
.
editorsCanAdmin
}
>
<
WithFeatureToggle
featureToggle=
{
editorsCanAdmin
}
>
<
th
>
Permission
</
th
>
</
WithFeatureToggle
>
{
syncEnabled
&&
<
th
/>
}
...
...
@@ -180,6 +200,7 @@ function mapStateToProps(state) {
return
{
members
:
getTeamMembers
(
state
.
team
),
searchMemberQuery
:
getSearchMemberQuery
(
state
.
team
),
editorsCanAdmin
:
config
.
editorsCanAdmin
,
// this makes the feature toggle mockable/controllable from tests,
};
}
...
...
public/app/features/teams/__snapshots__/TeamMembers.test.tsx.snap
View file @
96aa4ae1
...
...
@@ -201,6 +201,1093 @@ exports[`Render should render team members 1`] = `
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="2"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-2
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="3"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-3
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="4"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-4
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="5"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-5
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
</tbody>
</table>
</div>
</div>
`;
exports[`Render should render team members when sync enabled 1`] = `
<div>
<div
className="page-action-bar"
>
<div
className="gf-form gf-form--grow"
>
<ForwardRef
inputClassName="gf-form-input"
labelClassName="gf-form--has-input-icon gf-form--grow"
onChange={[Function]}
placeholder="Search members"
value=""
/>
</div>
<div
className="page-action-bar__spacer"
/>
<button
className="btn btn-primary pull-right"
disabled={false}
onClick={[Function]}
>
Add member
</button>
</div>
<Component
in={false}
>
<div
className="cta-form"
>
<button
className="cta-form__close btn btn-transparent"
onClick={[Function]}
>
<i
className="fa fa-close"
/>
</button>
<h5>
Add team member
</h5>
<div
className="gf-form-inline"
>
<UserPicker
className="min-width-30"
onSelected={[Function]}
/>
</div>
</div>
</Component>
<div
className="admin-list-table"
>
<table
className="filter-table filter-table--hover form-inline"
>
<thead>
<tr>
<th />
<th>
Name
</th>
<th>
Email
</th>
<Component
featureToggle={false}
>
<th>
Permission
</th>
</Component>
<th />
<th
style={
Object {
"width": "1%",
}
}
/>
</tr>
</thead>
<tbody>
<tr
key="1"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-1
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="2"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-2
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="3"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-3
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="4"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-4
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="5"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-5
</td>
<td>
test@test.com
</td>
<Component
featureToggle={false}
>
<td>
<div
className="gf-form"
>
<span>
Member
</span>
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
</tbody>
</table>
</div>
</div>
`;
exports[`Render when feature toggle editorsCanAdmin is turned on should render permissions select if user is Grafana Admin 1`] = `
<div>
<div
className="page-action-bar"
>
<div
className="gf-form gf-form--grow"
>
<ForwardRef
inputClassName="gf-form-input"
labelClassName="gf-form--has-input-icon gf-form--grow"
onChange={[Function]}
placeholder="Search members"
value=""
/>
</div>
<div
className="page-action-bar__spacer"
/>
<button
className="btn btn-primary pull-right"
disabled={false}
onClick={[Function]}
>
Add member
</button>
</div>
<Component
in={false}
>
<div
className="cta-form"
>
<button
className="cta-form__close btn btn-transparent"
onClick={[Function]}
>
<i
className="fa fa-close"
/>
</button>
<h5>
Add team member
</h5>
<div
className="gf-form-inline"
>
<UserPicker
className="min-width-30"
onSelected={[Function]}
/>
</div>
</div>
</Component>
<div
className="admin-list-table"
>
<table
className="filter-table filter-table--hover form-inline"
>
<thead>
<tr>
<th />
<th>
Name
</th>
<th>
Email
</th>
<Component
featureToggle={true}
>
<th>
Permission
</th>
</Component>
<th
style={
Object {
"width": "1%",
}
}
/>
</tr>
</thead>
<tbody>
<tr
key="1"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-1
</td>
<td>
test@test.com
</td>
<Component
featureToggle={true}
>
<td>
<div
className="gf-form"
>
<Select
autoFocus={false}
backspaceRemovesValue={true}
className="gf-form-select-box__control--menu-right"
isClearable={false}
isDisabled={false}
isLoading={false}
isMulti={false}
isSearchable={false}
maxMenuHeight={300}
onChange={[Function]}
openMenuOnFocus={false}
options={
Array [
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
},
Object {
"description": "Can add/remove permissions and delete team.",
"label": "Admin",
"value": 4,
},
]
}
value={
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
}
}
width={null}
/>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="2"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-2
</td>
<td>
test@test.com
</td>
<Component
featureToggle={true}
>
<td>
<div
className="gf-form"
>
<Select
autoFocus={false}
backspaceRemovesValue={true}
className="gf-form-select-box__control--menu-right"
isClearable={false}
isDisabled={false}
isLoading={false}
isMulti={false}
isSearchable={false}
maxMenuHeight={300}
onChange={[Function]}
openMenuOnFocus={false}
options={
Array [
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
},
Object {
"description": "Can add/remove permissions and delete team.",
"label": "Admin",
"value": 4,
},
]
}
value={
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
}
}
width={null}
/>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="3"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-3
</td>
<td>
test@test.com
</td>
<Component
featureToggle={true}
>
<td>
<div
className="gf-form"
>
<Select
autoFocus={false}
backspaceRemovesValue={true}
className="gf-form-select-box__control--menu-right"
isClearable={false}
isDisabled={false}
isLoading={false}
isMulti={false}
isSearchable={false}
maxMenuHeight={300}
onChange={[Function]}
openMenuOnFocus={false}
options={
Array [
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
},
Object {
"description": "Can add/remove permissions and delete team.",
"label": "Admin",
"value": 4,
},
]
}
value={
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
}
}
width={null}
/>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="4"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-4
</td>
<td>
test@test.com
</td>
<Component
featureToggle={true}
>
<td>
<div
className="gf-form"
>
<Select
autoFocus={false}
backspaceRemovesValue={true}
className="gf-form-select-box__control--menu-right"
isClearable={false}
isDisabled={false}
isLoading={false}
isMulti={false}
isSearchable={false}
maxMenuHeight={300}
onChange={[Function]}
openMenuOnFocus={false}
options={
Array [
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
},
Object {
"description": "Can add/remove permissions and delete team.",
"label": "Admin",
"value": 4,
},
]
}
value={
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
}
}
width={null}
/>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
<tr
key="5"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-5
</td>
<td>
test@test.com
</td>
<Component
featureToggle={true}
>
<td>
<div
className="gf-form"
>
<Select
autoFocus={false}
backspaceRemovesValue={true}
className="gf-form-select-box__control--menu-right"
isClearable={false}
isDisabled={false}
isLoading={false}
isMulti={false}
isSearchable={false}
maxMenuHeight={300}
onChange={[Function]}
openMenuOnFocus={false}
options={
Array [
Object {
"description": "Is team member",
"label": "Member",
"value": 0,
},
Object {
"description": "Can add/remove permissions and delete team.",
"label": "Admin",
"value": 4,
},
]
}
value={
Object {
"description": "Can add/remove permissions and delete team.",
"label": "Admin",
"value": 4,
}
}
width={null}
/>
</div>
</td>
</Component>
<td
className="text-right"
>
<DeleteButton
onConfirm={[Function]}
/>
</td>
</tr>
</tbody>
</table>
</div>
</div>
`;
exports[`Render when feature toggle editorsCanAdmin is turned on should render permissions select if user is Org Admin 1`] = `
<div>
<div
className="page-action-bar"
>
<div
className="gf-form gf-form--grow"
>
<ForwardRef
inputClassName="gf-form-input"
labelClassName="gf-form--has-input-icon gf-form--grow"
onChange={[Function]}
placeholder="Search members"
value=""
/>
</div>
<div
className="page-action-bar__spacer"
/>
<button
className="btn btn-primary pull-right"
disabled={false}
onClick={[Function]}
>
Add member
</button>
</div>
<Component
in={false}
>
<div
className="cta-form"
>
<button
className="cta-form__close btn btn-transparent"
onClick={[Function]}
>
<i
className="fa fa-close"
/>
</button>
<h5>
Add team member
</h5>
<div
className="gf-form-inline"
>
<UserPicker
className="min-width-30"
onSelected={[Function]}
/>
</div>
</div>
</Component>
<div
className="admin-list-table"
>
<table
className="filter-table filter-table--hover form-inline"
>
<thead>
<tr>
<th />
<th>
Name
</th>
<th>
Email
</th>
<Component
featureToggle={true}
>
<th>
Permission
</th>
</Component>
<th
style={
Object {
"width": "1%",
}
}
/>
</tr>
</thead>
<tbody>
<tr
key="1"
>
<td
className="width-4 text-center"
>
<img
className="filter-table__avatar"
src="some/url/"
/>
</td>
<td>
testUser-1
</td>
<td>
test@test.com
</td>
<Component
featureToggle={true}
>
<td>
<div
className="gf-form"
>
<Select
autoFocus={false}
backspaceRemovesValue={true}
...
...
@@ -265,7 +1352,7 @@ exports[`Render should render team members 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -335,7 +1422,7 @@ exports[`Render should render team members 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -405,7 +1492,7 @@ exports[`Render should render team members 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -475,7 +1562,7 @@ exports[`Render should render team members 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -509,9 +1596,9 @@ exports[`Render should render team members 1`] = `
}
value={
Object {
"description": "
Is team member
",
"label": "
Member
",
"value":
0
,
"description": "
Can add/remove permissions and delete team.
",
"label": "
Admin
",
"value":
4
,
}
}
width={null}
...
...
@@ -533,7 +1620,7 @@ exports[`Render should render team members 1`] = `
</div>
`;
exports[`Render
should render team members when sync enabled
1`] = `
exports[`Render
when feature toggle editorsCanAdmin is turned on should render permissions select if user is team admin
1`] = `
<div>
<div
className="page-action-bar"
...
...
@@ -603,13 +1690,12 @@ exports[`Render should render team members when sync enabled 1`] = `
Email
</th>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<th>
Permission
</th>
</Component>
<th />
<th
style={
Object {
...
...
@@ -638,7 +1724,7 @@ exports[`Render should render team members when sync enabled 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -672,9 +1758,9 @@ exports[`Render should render team members when sync enabled 1`] = `
}
value={
Object {
"description": "
Is team member
",
"label": "
Member
",
"value":
0
,
"description": "
Can add/remove permissions and delete team.
",
"label": "
Admin
",
"value":
4
,
}
}
width={null}
...
...
@@ -682,22 +1768,6 @@ exports[`Render should render team members when sync enabled 1`] = `
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
...
...
@@ -724,7 +1794,7 @@ exports[`Render should render team members when sync enabled 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -768,22 +1838,6 @@ exports[`Render should render team members when sync enabled 1`] = `
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
...
...
@@ -810,7 +1864,7 @@ exports[`Render should render team members when sync enabled 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -854,22 +1908,6 @@ exports[`Render should render team members when sync enabled 1`] = `
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
...
...
@@ -896,7 +1934,7 @@ exports[`Render should render team members when sync enabled 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -940,22 +1978,6 @@ exports[`Render should render team members when sync enabled 1`] = `
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
...
...
@@ -982,7 +2004,7 @@ exports[`Render should render team members when sync enabled 1`] = `
test@test.com
</td>
<Component
featureToggle={
fals
e}
featureToggle={
tru
e}
>
<td>
<div
...
...
@@ -1026,22 +2048,6 @@ exports[`Render should render team members when sync enabled 1`] = `
</div>
</td>
</Component>
<td>
<TagBadge
count={0}
key="label 1"
label="label 1"
onClick={[Function]}
removeIcon={false}
/>
<TagBadge
count={0}
key="label 2"
label="label 2"
onClick={[Function]}
removeIcon={false}
/>
</td>
<td
className="text-right"
>
...
...
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