*/
import ProjectManagementActions from './projectMgmtActions.js';
import ProjectManagementSource from './projectMgmtSource.js';
+import ROLES from 'utils/roleConstants.js';
import _ from 'lodash';
export default class ProjectManagementStore {
constructor() {
this.projectUsers = [];
this.selectedUser = null;
this.selectedRole = null;
- this.roles = ['rw-project:project-admin', 'rw-project:project-oper', 'rw-project:project-create'
- // ,'some_other_role', 'yet_another_role', 'operator_role', 'some_other_role', 'yet_another_role'
- ];
+ this.roles = Object.keys(ROLES.PROJECT).filter((p) => {
+ return p != "TYPE";
+ }).map((p) => {
+ return ROLES.PROJECT[p];
+ })
+ // this.roles = ['rw-project:project-admin', 'rw-project:project-oper', 'rw-project:project-create'];
this.users = [];
this.activeIndex = null;
this.isReadOnly = true;
projectRoles
});
}
- viewProject(data) {
+ viewProject() {
+ let data = arguments[0];
let project = data[0];
let projectIndex = data[1];
+ let isReadOnly = data[2];
- let ProjectUser = {
+ let ProjectData = {
'name': project['name'],
'description': project['description'],
- 'projectUsers': project['project-config'] && project['project-config']['user'] || []
+ 'projectUsers': (project['project-config'] && project['project-config']['user'] || [])
}
let state = _.merge({
activeIndex: projectIndex,
projectOpen: true,
isEdit: true,
- isReadOnly: true
- }, ProjectUser);
+ isReadOnly: isReadOnly
+ }, ProjectData);
this.setState(state)
}
- editProject(isEdit) {
- this.setState({
- isReadOnly: isEdit
- })
+ editProject(isReadOnly) {
+ this.viewProject([this.projects[this.activeIndex], this.activeIndex, isReadOnly]);
+
}
handleCloseProjectPanel() {
this.setState({
let {userIndex, roleIndex, checked} = data;
let projectUsers = this.projectUsers;
let selectedRole = self.roles[roleIndex];
+ let roleType = (ROLES.PROJECT.TYPE[selectedRole] == 'rw-project-mano') ? "rw-project-mano:mano-role" : "role";
+ //
if(checked) {
- if(!projectUsers[userIndex].role) projectUsers[userIndex].role = [];
- projectUsers[userIndex].role.push({
+ if (!projectUsers[userIndex][roleType]) {
+ projectUsers[userIndex][roleType] = [];
+ }
+ projectUsers[userIndex][roleType].push({
role: self.roles[roleIndex]
})
} else {
- let role = projectUsers[userIndex].role;
+ let role = projectUsers[userIndex][roleType];
let roleIndex = _.findIndex(role, {role:selectedRole})
- projectUsers[userIndex].role.splice(roleIndex, 1)
+ projectUsers[userIndex][roleType].splice(roleIndex, 1)
}
self.setState({projectUsers});