Skip to content

Commit

Permalink
Combine permisssions in the ui on token overlay
Browse files Browse the repository at this point in the history
  • Loading branch information
Palakp41 committed Feb 13, 2019
1 parent e41efd5 commit a9b6a1e
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 88 deletions.
53 changes: 17 additions & 36 deletions ui/src/me/components/account/ViewTokenOverlay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,21 +15,26 @@ import {Authorization, Permission} from '@influxdata/influx'
// Actions
import {NotificationAction} from 'src/types'

const {Write, Read} = Permission.ActionEnum

interface Props {
onNotify: NotificationAction
auth: Authorization
onDismissOverlay: () => void
}

const actions = [Read, Write]

export default class ViewTokenOverlay extends PureComponent<Props> {
public render() {
const {description, permissions} = this.props.auth
const {onNotify} = this.props

const obj = {}
for (const key of permissions) {
if (obj[key.resource.type]) {
obj[key.resource.type].push(key.action)
} else {
obj[key.resource.type] = [key.action]
}
}

return (
<OverlayContainer>
<OverlayHeading title={description} onDismiss={this.handleDismiss} />
Expand All @@ -39,20 +44,20 @@ export default class ViewTokenOverlay extends PureComponent<Props> {
mode={PermissionsWidgetMode.Read}
heightPixels={500}
>
{permissions.map((p, i) => {
{Object.keys(obj).map((p, i) => {
return (
<PermissionsWidget.Section
key={i}
id={this.id(p)}
id={p}
title={this.title(p)}
mode={PermissionsWidgetMode.Read}
>
{actions.map((a, i) => (
{obj[p].map((a, i) => (
<PermissionsWidget.Item
key={i}
id={this.itemID(p, a)}
label={a}
selected={this.selected(p, a)}
selected={PermissionsWidgetSelection.Selected}
/>
))}
</PermissionsWidget.Section>
Expand All @@ -64,39 +69,15 @@ export default class ViewTokenOverlay extends PureComponent<Props> {
)
}

private selected = (
permission: Permission,
action: Permission.ActionEnum
): PermissionsWidgetSelection => {
if (permission.action === action) {
return PermissionsWidgetSelection.Selected
}

return PermissionsWidgetSelection.Unselected
}

private itemID = (
permission: Permission,
permission: string,
action: Permission.ActionEnum
): string => {
return `${permission.resource.type}-${action}-${permission.resource.id ||
'*'}-${permission.resource.orgID || '*'}`
}

private id = (permission: Permission): string => {
return permission.resource.type
return `${permission}-${action}-${permission || '*'}-${permission || '*'}`
}

private title = (permission: Permission): string => {
const org = permission.resource.org || '*'
const name = permission.resource.name || '*'
const type = permission.resource.type

if (permission.resource.name || permission.resource.org) {
return `${org}:${type}:${name}`
}

return `${permission.resource.type}:*`
private title = (permission: string): string => {
return `${permission}:*`
}

private handleDismiss = () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -314,33 +314,8 @@ exports[`Account rendering renders! 1`] = `
className="permissions-widget--section-list"
>
<PermissionsWidgetItem
id="orgs-read-*-*"
id="orgs-write-orgs-orgs"
key=".$0"
label="read"
mode="read"
selected="unselected"
>
<li
className="permissions-widget--item unselected"
onClick={[Function]}
>
<div
className="permissions-widget--icon"
>
<span
className="icon remove"
/>
</div>
<label
className="permissions-widget--item-label"
>
read
</label>
</li>
</PermissionsWidgetItem>
<PermissionsWidgetItem
id="orgs-write-*-*"
key=".$1"
label="write"
mode="read"
selected="selected"
Expand Down Expand Up @@ -388,33 +363,8 @@ exports[`Account rendering renders! 1`] = `
className="permissions-widget--section-list"
>
<PermissionsWidgetItem
id="buckets-read-*-*"
id="buckets-write-buckets-buckets"
key=".$0"
label="read"
mode="read"
selected="unselected"
>
<li
className="permissions-widget--item unselected"
onClick={[Function]}
>
<div
className="permissions-widget--icon"
>
<span
className="icon remove"
/>
</div>
<label
className="permissions-widget--item-label"
>
read
</label>
</li>
</PermissionsWidgetItem>
<PermissionsWidgetItem
id="buckets-write-*-*"
key=".$1"
label="write"
mode="read"
selected="selected"
Expand Down

0 comments on commit a9b6a1e

Please sign in to comment.