diff --git a/samples/react-securitygrid/src/webparts/spSecurity/SpSecurityWebPart.ts b/samples/react-securitygrid/src/webparts/spSecurity/SpSecurityWebPart.ts index 2ea5204a9c..09dda075c5 100644 --- a/samples/react-securitygrid/src/webparts/spSecurity/SpSecurityWebPart.ts +++ b/samples/react-securitygrid/src/webparts/spSecurity/SpSecurityWebPart.ts @@ -12,7 +12,7 @@ import * as ReactDom from "react-dom"; import { ISpSecurityProps } from "./components/ISpSecurityProps"; import SpSecurity from "./components/SpSecurity"; import { PropertyFieldSelectedPermissions } from "./containers/PropertyFieldSelectedPermissions"; -import { ISpSecurityWebPartProps } from "./ISpSecurityWebPartProps"; +import { ISelectedPermission, ISpSecurityWebPartProps } from "./ISpSecurityWebPartProps"; export default class SpSecurityWebPart extends BaseClientSideWebPart { private _sp: SPFI = null; @@ -70,18 +70,22 @@ export default class SpSecurityWebPart extends BaseClientSideWebPart { + const existingPermission = this.properties.selectedPermissions.find(permission => permission.permission === newPerm.permission); + return existingPermission ? { ...existingPermission, ...newPerm } : newPerm; + }); + this.properties.selectedPermissions = updatedPermissions; this.context.propertyPane.refresh(); this.render(); break; + } default: break; } } - protected getPropertyPaneConfiguration(): IPropertyPaneConfiguration { return { pages: [ diff --git a/samples/react-securitygrid/src/webparts/spSecurity/components/SpSecurity.tsx b/samples/react-securitygrid/src/webparts/spSecurity/components/SpSecurity.tsx index 12d93df997..85314035a4 100644 --- a/samples/react-securitygrid/src/webparts/spSecurity/components/SpSecurity.tsx +++ b/samples/react-securitygrid/src/webparts/spSecurity/components/SpSecurity.tsx @@ -107,7 +107,8 @@ const SpSecurity: React.FC = (props) => { setState({ ...state }); }; - const expandCollapseList = (item: SPList | SPListItem): void => { + const expandCollapseList = (item: SPList | SPListItem, event: React.MouseEvent): void => { + event.stopPropagation(); if (item.itemCount === 0) return; if (item.isExpanded) { @@ -130,7 +131,7 @@ const SpSecurity: React.FC = (props) => { const renderListTitle = (item: SPList): JSX.Element => { const iconName = item.itemCount > 0 ? 'FabricFormLibrary' : 'FabricFolder'; return ( -
expandCollapseList(item)}> +
expandCollapseList(item, event)}>  {item.title}
@@ -141,7 +142,7 @@ const SpSecurity: React.FC = (props) => { const style = { marginLeft: `${item.level * 20}px` }; const iconName = item.itemCount > 0 ? 'FabricFormLibrary' : 'FabricFolder'; return ( -
expandCollapseList(item)}> +
expandCollapseList(item, event)}>  {item.title}
@@ -160,8 +161,8 @@ const SpSecurity: React.FC = (props) => { }; const addUserColumns = ( - columns: IColumn[], - users: SPSiteUser[], + columns: IColumn[], + users: SPSiteUser[], effectivePermissions: ISelectedPermission[] ): IColumn[] => { for (const user of users) { @@ -252,11 +253,12 @@ const SpSecurity: React.FC = (props) => { column: IColumn, effectivePermissions: ISelectedPermission[] ): JSX.Element => { + const user = find(state.securityInfo.siteUsers, (su) => su.upn.toString() === column.key); - - for (const selectedPermission of effectivePermissions) { + + const icons = effectivePermissions.map((selectedPermission) => { const permissionKey = selectedPermission.permission as keyof typeof SPPermission; - + if (user && Helpers.doesUserHavePermission( item, user, @@ -266,20 +268,36 @@ const SpSecurity: React.FC = (props) => { state.securityInfo.adGroups )) { return ( - expandCollapseList(item)} - /> +
expandCollapseList(item, event)}> + {icons} + +
); } - } - + + return null; + }); + return ( - expandCollapseList(item)} /> +
expandCollapseList(item, event)}> + {icons} +
+ +
+
); }; - + + if (!state.securityInfoLoaded) { + return ( +
+ +
+ ); + } if (!state.securityInfoLoaded) { return (
diff --git a/samples/react-securitygrid/src/webparts/spSecurity/containers/PropertyFieldSelectedPermissionsHost.tsx b/samples/react-securitygrid/src/webparts/spSecurity/containers/PropertyFieldSelectedPermissionsHost.tsx index 7dd24c00cb..9184cddc02 100644 --- a/samples/react-securitygrid/src/webparts/spSecurity/containers/PropertyFieldSelectedPermissionsHost.tsx +++ b/samples/react-securitygrid/src/webparts/spSecurity/containers/PropertyFieldSelectedPermissionsHost.tsx @@ -114,13 +114,16 @@ export default class PropertyFieldSelectedPermissionsHost extends React.Componen { - this.setState({ SelectedPermissions: [...newval] }); - this.props.onPropertyChange("SelectedPermissions", this.props.SelectedPermissions, newval); + const updatedPermissions = newval.map(newPerm => { + const existingPermission = this.state.SelectedPermissions.find(permission => permission.permission === newPerm.permission); + return existingPermission ? { ...existingPermission, ...newPerm } : newPerm; + }); + this.setState({ SelectedPermissions: updatedPermissions }); + this.props.onPropertyChange("SelectedPermissions", this.props.SelectedPermissions, updatedPermissions); }} closePanel={() => { this.onClosePanel(); }} SelectedPermissions={this.props.SelectedPermissions} - /> -
+ />
); } }