1
0
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:
llj 2023-11-09 18:51:38 +08:00 committed by GitHub
parent 620ab4d329
commit 43505270eb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 40 additions and 13 deletions

View File

@ -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 {

View File

@ -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>

View File

@ -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 {