mirror of
https://github.com/haiwen/seahub.git
synced 2025-07-21 18:32:37 +00:00
218 lines
7.6 KiB
JavaScript
218 lines
7.6 KiB
JavaScript
import React, { Fragment } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { Alert, FormGroup, Input, Label, Tooltip } from 'reactstrap';
|
|
import { gettext } from '../../../utils/constants';
|
|
import Loading from '../../loading';
|
|
import OpIcon from '../../op-icon';
|
|
|
|
const propTypes = {
|
|
mode: PropTypes.string,
|
|
permission: PropTypes.object,
|
|
onChangeMode: PropTypes.func.isRequired,
|
|
onUpdateCustomPermission: PropTypes.func.isRequired,
|
|
};
|
|
|
|
class CustomPermissionEditor extends React.Component {
|
|
|
|
static defaultProps = {
|
|
mode: 'add'
|
|
};
|
|
|
|
constructor(props) {
|
|
super(props);
|
|
this.state = {
|
|
isLoading: true,
|
|
permission_name: '',
|
|
permission_desc: '',
|
|
permission: {
|
|
upload: false,
|
|
download: false,
|
|
modify: false,
|
|
copy: false,
|
|
delete: false,
|
|
preview: false,
|
|
download_external_link: false,
|
|
},
|
|
errMessage: '',
|
|
tooltipOpen: false,
|
|
};
|
|
}
|
|
|
|
componentDidMount() {
|
|
const { permission } = this.props;
|
|
if (permission) {
|
|
this.setState({
|
|
permission_name: permission.name,
|
|
permission_desc: permission.description,
|
|
permission: permission.permission,
|
|
isLoading: false
|
|
});
|
|
} else {
|
|
this.setState({ isLoading: false });
|
|
}
|
|
|
|
}
|
|
|
|
onChangePermissionName = (evt) => {
|
|
const { permission_name } = this.state;
|
|
const newName = evt.target.value;
|
|
if (newName === permission_name) return;
|
|
this.setState({ permission_name: newName });
|
|
};
|
|
|
|
onChangePermissionDescription = (evt) => {
|
|
const { permission_desc } = this.state;
|
|
const newDescription = evt.target.value;
|
|
if (newDescription === permission_desc) return;
|
|
this.setState({ permission_desc: newDescription });
|
|
};
|
|
|
|
onChangePermission = (type) => {
|
|
return () => {
|
|
const { permission } = this.state;
|
|
const value = !permission[type];
|
|
const newPermission = Object.assign({}, permission, { [type]: value });
|
|
this.setState({ permission: newPermission });
|
|
};
|
|
};
|
|
|
|
validParams = () => {
|
|
const { permission_name, permission_desc } = this.state;
|
|
let isValid = false;
|
|
let errMessage = '';
|
|
if (!permission_name || !permission_name.trim()) {
|
|
errMessage = gettext('Name is required');
|
|
return { isValid, errMessage };
|
|
}
|
|
if (!permission_desc || !permission_desc.trim()) {
|
|
errMessage = gettext('Description is required');
|
|
return { isValid, errMessage };
|
|
}
|
|
|
|
isValid = true;
|
|
return { isValid };
|
|
};
|
|
|
|
onUpdateCustomPermission = () => {
|
|
const { permission_name, permission_desc, permission } = this.state;
|
|
const { isValid, errMessage } = this.validParams();
|
|
if (!isValid) {
|
|
this.setState({ errMessage });
|
|
return;
|
|
}
|
|
this.props.onUpdateCustomPermission(permission_name, permission_desc, permission);
|
|
};
|
|
|
|
toggle = () => {
|
|
this.setState({ tooltipOpen: !this.state.tooltipOpen });
|
|
};
|
|
|
|
render() {
|
|
|
|
const { mode } = this.props;
|
|
const title = mode === 'add' ? gettext('Add permission') : gettext('Edit permission');
|
|
|
|
const { isLoading, permission_name, permission_desc, permission, errMessage } = this.state;
|
|
|
|
return (
|
|
<div className="custom-permission">
|
|
<div className="permission-header">
|
|
<div className="d-flex align-items-center">
|
|
<OpIcon
|
|
className="sf3-font sf3-font-arrow rotate-180 d-inline-block back-icon"
|
|
op={this.props.onChangeMode}
|
|
title={gettext('Back')}
|
|
/>
|
|
<span>{title}</span>
|
|
</div>
|
|
<div className="operation">
|
|
<button type="button" className="btn btn-sm btn-outline-primary" onClick={this.onUpdateCustomPermission}>{gettext('Submit')}</button>
|
|
</div>
|
|
</div>
|
|
<div className="permission-main mt-4">
|
|
{isLoading && <Loading />}
|
|
{!isLoading && (
|
|
<Fragment>
|
|
<div className="permission-name-desc d-flex">
|
|
<FormGroup className="permission-name">
|
|
<Label>{gettext('Permission name')}</Label>
|
|
<Input value={permission_name || ''} onChange={this.onChangePermissionName} />
|
|
</FormGroup>
|
|
<FormGroup className="permission-desc">
|
|
<Label>{gettext('Description')}</Label>
|
|
<Input value={permission_desc || ''} onChange={this.onChangePermissionDescription} />
|
|
</FormGroup>
|
|
</div>
|
|
{errMessage && <Alert color="danger">{errMessage}</Alert>}
|
|
<div className="permission-options">
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('upload')} checked={permission.upload}/>
|
|
<span>{gettext('Upload')}</span>
|
|
</Label>
|
|
</FormGroup>
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('download')} checked={permission.download}/>
|
|
<span>{gettext('Download')}</span>
|
|
</Label>
|
|
</FormGroup>
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('create')} checked={permission.create}/>
|
|
<span>{gettext('Create')}</span>
|
|
</Label>
|
|
</FormGroup>
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('modify')} checked={permission.modify}/>
|
|
<span>{gettext('Modify')}</span>
|
|
<span id="modify-tip" className="sf3-font sf3-font-tips ml-2" style={{ color: '#999' }}></span>
|
|
<Tooltip
|
|
toggle={this.toggle}
|
|
delay={{ show: 0, hide: 0 }}
|
|
target={'modify-tip'}
|
|
placement='bottom'
|
|
isOpen={this.state.tooltipOpen}>
|
|
({gettext('Modify includes modify file, move/rename file and folder')})
|
|
</Tooltip>
|
|
</Label>
|
|
</FormGroup>
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('copy')} checked={permission.copy}/>
|
|
<span>{gettext('Copy')}</span>
|
|
</Label>
|
|
</FormGroup>
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('delete')} checked={permission.delete}/>
|
|
<span>{gettext('Delete')}</span>
|
|
</Label>
|
|
</FormGroup>
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('preview')} checked={permission.preview}/>
|
|
<span>{gettext('Preview online')}</span>
|
|
</Label>
|
|
</FormGroup>
|
|
<FormGroup check>
|
|
<Label check>
|
|
<Input type="checkbox" onChange={this.onChangePermission('download_external_link')} checked={permission.download_external_link}/>
|
|
<span>{gettext('Generate share link')}</span>
|
|
</Label>
|
|
</FormGroup>
|
|
</div>
|
|
</Fragment>
|
|
)}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
}
|
|
|
|
CustomPermissionEditor.propTypes = propTypes;
|
|
|
|
export default CustomPermissionEditor;
|