mirror of
https://github.com/haiwen/seahub.git
synced 2025-09-04 16:31:13 +00:00
fix (#2517)
This commit is contained in:
@@ -43,8 +43,6 @@ class AddReviewerDialog extends React.Component {
|
||||
|
||||
loadOptions = (value, callback) => {
|
||||
if (value.trim().length > 0) {
|
||||
this.Options = [];
|
||||
let that = this;
|
||||
seafileAPI.searchUsers(value.trim()).then((res) => {
|
||||
for (let i = 0 ; i < res.data.users.length; i++) {
|
||||
let obj = {};
|
||||
@@ -55,7 +53,8 @@ class AddReviewerDialog extends React.Component {
|
||||
<img src={res.data.users[i].avatar_url} className="avatar reviewer-select-avatar" alt=""/>
|
||||
<span className='reviewer-select-name'>{res.data.users[i].name}</span>
|
||||
</React.Fragment>;
|
||||
that.Options.push(obj);
|
||||
this.Options.splice(0, this.Options.length);
|
||||
this.Options.push(obj);
|
||||
}
|
||||
callback(this.Options);
|
||||
});
|
||||
@@ -131,7 +130,7 @@ class AddReviewerDialog extends React.Component {
|
||||
<Button color="primary" onClick={this.addReviewers}>{gettext('Submit')}</Button>
|
||||
}
|
||||
<Button color="secondary" onClick={this.props.toggleAddReviewerDialog}>
|
||||
{gettext('Cancel')}</Button>
|
||||
{gettext('Close')}</Button>
|
||||
</ModalFooter>
|
||||
</Modal>
|
||||
);
|
||||
|
@@ -31,12 +31,15 @@ class ReviewComments extends React.Component {
|
||||
this.accountInfo = {};
|
||||
}
|
||||
|
||||
listComments = () => {
|
||||
listComments = (scroll) => {
|
||||
seafileAPI.listReviewComments(reviewID).then((response) => {
|
||||
response.data.comments.reverse();
|
||||
this.setState({
|
||||
commentsList: response.data.comments
|
||||
});
|
||||
if (scroll) {
|
||||
this.refs.commentsList.scrollTo(0, 10000);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@@ -59,7 +62,7 @@ class ReviewComments extends React.Component {
|
||||
let comment = this.refs.commentTextarea.value;
|
||||
if (comment.trim().length > 0) {
|
||||
seafileAPI.addReviewComment(reviewID, comment.trim()).then((res) => {
|
||||
this.listComments();
|
||||
this.listComments(true);
|
||||
this.props.getCommentsNumber();
|
||||
});
|
||||
this.refs.commentTextarea.value = '';
|
||||
@@ -108,6 +111,16 @@ class ReviewComments extends React.Component {
|
||||
onResizeMouseMove = (event) => {
|
||||
let rate = 100 - (event.nativeEvent.clientY - 50 ) / this.refs.comment.clientHeight * 100;
|
||||
if (rate < 20 || rate > 70) {
|
||||
if (rate < 20) {
|
||||
this.setState({
|
||||
commentFooterHeight: 25
|
||||
});
|
||||
}
|
||||
if (rate > 70) {
|
||||
this.setState({
|
||||
commentFooterHeight: 65
|
||||
});
|
||||
}
|
||||
this.setState({
|
||||
inResizing: false
|
||||
});
|
||||
@@ -150,28 +163,30 @@ class ReviewComments extends React.Component {
|
||||
<div className="comment-vacant">{gettext('No comment yet.')}</div>
|
||||
</div>
|
||||
}
|
||||
{ (this.state.commentsList.length == 0 && this.props.commentsNumber > 0) &&
|
||||
<div><Loading/></div>
|
||||
{ (this.state.commentsList.length === 0 && this.props.commentsNumber > 0) &&
|
||||
<div className={'seafile-comment-list'}><Loading/></div>
|
||||
}
|
||||
{ this.state.commentsList.length > 0 &&
|
||||
<ul className={'seafile-comment-list'} ref='commentsList'>
|
||||
{ (this.state.commentsList.length > 0 && this.props.commentsNumber > 0) &&
|
||||
this.state.commentsList.map((item, index = 0, arr) => {
|
||||
let oldTime = (new Date(item.created_at)).getTime();
|
||||
let time = moment(oldTime).format('YYYY-MM-DD HH:mm');
|
||||
return (
|
||||
<CommentItem id={item.id} time={time} headUrl={item.avatar_url}
|
||||
comment={item.comment} name={item.user_name}
|
||||
user_email={item.user_email} key={index} resolved={item.resolved}
|
||||
deleteComment={this.deleteComment}
|
||||
resolveComment={this.resolveComment}
|
||||
commentsList={this.state.commentsList}
|
||||
accountInfo={this.accountInfo}
|
||||
showResolvedComment={this.state.showResolvedComment}
|
||||
/>
|
||||
);
|
||||
})
|
||||
}
|
||||
</ul>
|
||||
}
|
||||
<ul className={'seafile-comment-list'}>
|
||||
{ (this.state.commentsList.length > 0 && this.props.commentsNumber > 0) &&
|
||||
this.state.commentsList.map((item, index = 0, arr) => {
|
||||
let oldTime = (new Date(item.created_at)).getTime();
|
||||
let time = moment(oldTime).format('YYYY-MM-DD HH:mm');
|
||||
return (
|
||||
<CommentItem id={item.id} time={time} headUrl={item.avatar_url}
|
||||
comment={item.comment} name={item.user_name}
|
||||
user_email={item.user_email} key={index} resolved={item.resolved}
|
||||
deleteComment={this.deleteComment}
|
||||
resolveComment={this.resolveComment}
|
||||
commentsList={this.state.commentsList}
|
||||
accountInfo={this.accountInfo}
|
||||
showResolvedComment={this.state.showResolvedComment}
|
||||
/>
|
||||
);
|
||||
})
|
||||
}
|
||||
</ul>
|
||||
</div>
|
||||
<div className="seafile-comment-footer" style={{height:this.state.commentFooterHeight+'%'}}>
|
||||
<div className="seafile-comment-row-resize" onMouseDown={this.onResizeMouseDown}></div>
|
||||
|
Reference in New Issue
Block a user