mirror of
https://github.com/haiwen/seahub.git
synced 2025-08-28 11:41:18 +00:00
[activities] improvement (#5749)
This commit is contained in:
parent
620ab4d329
commit
43505270eb
@ -10,12 +10,16 @@
|
|||||||
margin-bottom: .2em;
|
margin-bottom: .2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activity-modifier:hover {
|
.cur-activity-modifiers {
|
||||||
|
margin-left: -0.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.cur-activity-modifiers:hover {
|
||||||
background: #f5f5f5;
|
background: #f5f5f5;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activity-modifier .toggle-icon {
|
.cur-activity-modifiers .toggle-icon {
|
||||||
color: #999;
|
color: #999;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,6 +35,7 @@
|
|||||||
min-height: 2rem;
|
min-height: 2rem;
|
||||||
background: #f6f6f6;
|
background: #f6f6f6;
|
||||||
border-bottom: 1px solid #dde2ea;
|
border-bottom: 1px solid #dde2ea;
|
||||||
|
line-height: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activity-selected-modifier {
|
.activity-selected-modifier {
|
||||||
|
@ -28,6 +28,21 @@ class UserSelector extends Component {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
componentDidMount() {
|
||||||
|
document.addEventListener('click', this.handleOutsideClick);
|
||||||
|
}
|
||||||
|
|
||||||
|
componentWillUnmount() {
|
||||||
|
document.removeEventListener('click', this.handleOutsideClick);
|
||||||
|
}
|
||||||
|
|
||||||
|
handleOutsideClick = (e) => {
|
||||||
|
const { isPopoverOpen } = this.state;
|
||||||
|
if (isPopoverOpen && !this.userSelector.contains(e.target)) {
|
||||||
|
this.togglePopover();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
togglePopover = () => {
|
togglePopover = () => {
|
||||||
this.setState({
|
this.setState({
|
||||||
isPopoverOpen: !this.state.isPopoverOpen
|
isPopoverOpen: !this.state.isPopoverOpen
|
||||||
@ -40,6 +55,11 @@ class UserSelector extends Component {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
onToggleClick = (e) => {
|
||||||
|
e.stopPropagation();
|
||||||
|
this.togglePopover();
|
||||||
|
}
|
||||||
|
|
||||||
searchUsers = (e) => {
|
searchUsers = (e) => {
|
||||||
const { availableUsers } = this.state;
|
const { availableUsers } = this.state;
|
||||||
const query = e.target.value.trim();
|
const query = e.target.value.trim();
|
||||||
@ -49,7 +69,8 @@ class UserSelector extends Component {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
toggleSelectItem = (targetItem) => {
|
toggleSelectItem = (e, targetItem) => {
|
||||||
|
e.stopPropagation();
|
||||||
const { availableUsers } = this.state;
|
const { availableUsers } = this.state;
|
||||||
const handleItem = (item) => {
|
const handleItem = (item) => {
|
||||||
if (item.email == targetItem.email) {
|
if (item.email == targetItem.email) {
|
||||||
@ -59,7 +80,7 @@ class UserSelector extends Component {
|
|||||||
};
|
};
|
||||||
|
|
||||||
this.setState({
|
this.setState({
|
||||||
availableUsers: availableUsers.map(handleItem),
|
availableUsers: availableUsers.map(handleItem)
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -69,7 +90,7 @@ class UserSelector extends Component {
|
|||||||
const selectedUsers = availableUsers.filter(item => item.isSelected);
|
const selectedUsers = availableUsers.filter(item => item.isSelected);
|
||||||
return (
|
return (
|
||||||
<div className="mt-4 position-relative">
|
<div className="mt-4 position-relative">
|
||||||
<span className="d-inline-block p-2 activity-modifier rounded" onClick={this.togglePopover}>
|
<span className="cur-activity-modifiers d-inline-block p-2 rounded" onClick={this.onToggleClick}>
|
||||||
{gettext('Modified by:')}
|
{gettext('Modified by:')}
|
||||||
{currentSelectedUsers.length > 0 && (
|
{currentSelectedUsers.length > 0 && (
|
||||||
<span className="d-inline-block ml-1">{currentSelectedUsers.map(item => item.name).join(', ')}</span>
|
<span className="d-inline-block ml-1">{currentSelectedUsers.map(item => item.name).join(', ')}</span>
|
||||||
@ -77,14 +98,14 @@ class UserSelector extends Component {
|
|||||||
<i className="fas fa-caret-down ml-2 toggle-icon"></i>
|
<i className="fas fa-caret-down ml-2 toggle-icon"></i>
|
||||||
</span>
|
</span>
|
||||||
{isPopoverOpen && (
|
{isPopoverOpen && (
|
||||||
<div className="position-absolute activity-modifier-selector-container rounded shadow">
|
<div className="position-absolute activity-modifier-selector-container rounded shadow" ref={ref => this.userSelector = ref}>
|
||||||
<ul className="activity-selected-modifiers px-3 py-2 list-unstyled d-flex">
|
<ul className="activity-selected-modifiers px-3 py-2 list-unstyled">
|
||||||
{selectedUsers.map((item, index) => {
|
{selectedUsers.map((item, index) => {
|
||||||
return (
|
return (
|
||||||
<li key={index} className="activity-selected-modifier">
|
<li key={index} className="activity-selected-modifier">
|
||||||
<img src={item.avatar_url} className="select-module select-module-icon avatar" alt="" />
|
<img src={item.avatar_url} className="avatar w-5 h-5" alt="" />
|
||||||
<span className='select-module select-module-name'>{item.name}</span>
|
<span className="ml-2">{item.name}</span>
|
||||||
<i className="sf2-icon-close unselect-activity-user ml-2" onClick={this.toggleSelectItem.bind(this, item)}></i>
|
<i className="sf2-icon-close unselect-activity-user ml-2" onClick={(e) => {this.toggleSelectItem(e, item);}}></i>
|
||||||
</li>
|
</li>
|
||||||
);
|
);
|
||||||
})}
|
})}
|
||||||
@ -99,10 +120,10 @@ class UserSelector extends Component {
|
|||||||
<ul className="activity-user-list list-unstyled">
|
<ul className="activity-user-list list-unstyled">
|
||||||
{filteredAvailableUsers.map((item, index) => {
|
{filteredAvailableUsers.map((item, index) => {
|
||||||
return (
|
return (
|
||||||
<li key={index} className="activity-user-item h-6 p-1 rounded d-flex justify-content-between align-items-center" onClick={this.toggleSelectItem.bind(this, item)}>
|
<li key={index} className="activity-user-item h-6 p-1 rounded d-flex justify-content-between align-items-center" onClick={(e) => {this.toggleSelectItem(e, item);}}>
|
||||||
<div>
|
<div>
|
||||||
<img src={item.avatar_url} className="select-module select-module-icon avatar" alt="" />
|
<img src={item.avatar_url} className="avatar w-5 h-5" alt="" />
|
||||||
<span className='select-module select-module-name'>{item.name}</span>
|
<span className="ml-2">{item.name}</span>
|
||||||
</div>
|
</div>
|
||||||
{item.isSelected && <i className="sf2-icon-tick text-gray"></i>}
|
{item.isSelected && <i className="sf2-icon-tick text-gray"></i>}
|
||||||
</li>
|
</li>
|
||||||
|
@ -535,6 +535,7 @@ a, a:hover { color: #ec8000; }
|
|||||||
color: #eb8205;
|
color: #eb8205;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
border-bottom: 0.125rem solid #eb8205;
|
border-bottom: 0.125rem solid #eb8205;
|
||||||
|
z-index: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.nav-pills .nav-item .nav-link {
|
.nav-pills .nav-item .nav-link {
|
||||||
|
Loading…
Reference in New Issue
Block a user