Merge pull request #2235 from vector-im/wmwragg/two-state-sublist-headers
Wmwragg/two state sublist headers
This commit is contained in:
commit
de26d1a8ce
|
@ -85,8 +85,7 @@ var RoomSubList = React.createClass({
|
||||||
getInitialState: function() {
|
getInitialState: function() {
|
||||||
return {
|
return {
|
||||||
hidden: this.props.startAsHidden || false,
|
hidden: this.props.startAsHidden || false,
|
||||||
capTruncate: this.props.list.length > TRUNCATE_AT,
|
truncateAt: TRUNCATE_AT,
|
||||||
truncateAt: this.props.list.length > TRUNCATE_AT ? TRUNCATE_AT : -1,
|
|
||||||
sortedList: [],
|
sortedList: [],
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
@ -218,10 +217,17 @@ var RoomSubList = React.createClass({
|
||||||
return roomNotifState != RoomNotifs.MUTE;
|
return roomNotifState != RoomNotifs.MUTE;
|
||||||
},
|
},
|
||||||
|
|
||||||
roomNotificationCount: function() {
|
/**
|
||||||
|
* Total up all the notification counts from the rooms
|
||||||
|
*
|
||||||
|
* @param {Number} If supplied will only total notifications for rooms outside the truncation number
|
||||||
|
* @returns {Array} The array takes the form [total, highlight] where highlight is a bool
|
||||||
|
*/
|
||||||
|
roomNotificationCount: function(truncateAt) {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
return this.props.list.reduce(function(result, room) {
|
return this.props.list.reduce(function(result, room, index) {
|
||||||
|
if (truncateAt === undefined || index >= truncateAt) {
|
||||||
var roomNotifState = RoomNotifs.getRoomNotifsState(room.roomId);
|
var roomNotifState = RoomNotifs.getRoomNotifsState(room.roomId);
|
||||||
var highlight = room.getUnreadNotificationCount('highlight') > 0 || self.props.label === 'Invites';
|
var highlight = room.getUnreadNotificationCount('highlight') > 0 || self.props.label === 'Invites';
|
||||||
var notificationCount = room.getUnreadNotificationCount();
|
var notificationCount = room.getUnreadNotificationCount();
|
||||||
|
@ -236,6 +242,7 @@ var RoomSubList = React.createClass({
|
||||||
result[1] = true;
|
result[1] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return result;
|
return result;
|
||||||
}, [0, false]);
|
}, [0, false]);
|
||||||
},
|
},
|
||||||
|
@ -423,14 +430,26 @@ var RoomSubList = React.createClass({
|
||||||
},
|
},
|
||||||
|
|
||||||
_createOverflowTile: function(overflowCount, totalCount) {
|
_createOverflowTile: function(overflowCount, totalCount) {
|
||||||
var BaseAvatar = sdk.getComponent('avatars.BaseAvatar');
|
var content = <div className="mx_RoomSubList_chevronDown"></div>;
|
||||||
// XXX: this is duplicated from RoomTile - factor it out
|
|
||||||
|
var overflowNotifications = this.roomNotificationCount(TRUNCATE_AT);
|
||||||
|
var overflowNotifCount = overflowNotifications[0];
|
||||||
|
var overflowNotifHighlight = overflowNotifications[1];
|
||||||
|
if (overflowNotifCount && !this.props.collapsed) {
|
||||||
|
content = overflowNotifCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
var badgeClasses = classNames({
|
||||||
|
'mx_RoomSubList_moreBadge': true,
|
||||||
|
'mx_RoomSubList_moreBadgeNotify': overflowNotifCount && !this.props.collapsed,
|
||||||
|
'mx_RoomSubList_moreBadgeHighlight': overflowNotifHighlight && !this.props.collapsed,
|
||||||
|
});
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="mx_RoomTile mx_RoomTile_ellipsis" onClick={this._showFullMemberList}>
|
<div className="mx_RoomSubList_ellipsis" onClick={this._showFullMemberList}>
|
||||||
<div className="mx_RoomTile_avatar">
|
<div className="mx_RoomSubList_line"></div>
|
||||||
<BaseAvatar url="img/ellipsis.svg" name="..." width={24} height={24} />
|
<div className="mx_RoomSubList_more">more</div>
|
||||||
</div>
|
<div className={ badgeClasses }>{ content }</div>
|
||||||
<div className="mx_RoomTile_name">and { overflowCount } others...</div>
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
|
@ -25,8 +25,8 @@ limitations under the License.
|
||||||
.mx_RoomTile_tooltip {
|
.mx_RoomTile_tooltip {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
position: relative;
|
position: relative;
|
||||||
top: -62px;
|
top: -54px;
|
||||||
left: 46px;
|
left: -12px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -113,18 +113,12 @@ limitations under the License.
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
}
|
}
|
||||||
|
|
||||||
.mx_RoomTile_ellipsis .mx_RoomTile_name {
|
|
||||||
font-style: italic;
|
|
||||||
color: #454545;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mx_RoomTile_invite {
|
.mx_RoomTile_invite {
|
||||||
/* color: rgba(69, 69, 69, 0.5);
|
/* color: rgba(69, 69, 69, 0.5); */
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.collapsed .mx_RoomTile_nameContainer {
|
.collapsed .mx_RoomTile_nameContainer {
|
||||||
height: 0;
|
width: 60px; /* colapsed panel width */
|
||||||
}
|
}
|
||||||
|
|
||||||
.collapsed .mx_RoomTile_name {
|
.collapsed .mx_RoomTile_name {
|
||||||
|
|
|
@ -147,3 +147,95 @@ limitations under the License.
|
||||||
border-left: 6px solid #76cfa6;
|
border-left: 6px solid #76cfa6;
|
||||||
border-bottom: 5px solid transparent;
|
border-bottom: 5px solid transparent;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* The overflow section */
|
||||||
|
.mx_RoomSubList_ellipsis {
|
||||||
|
display: block;
|
||||||
|
line-height: 11px;
|
||||||
|
height: 18px;
|
||||||
|
position: relative;
|
||||||
|
cursor: pointer;
|
||||||
|
font-size: 13px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.collapsed .mx_RoomSubList_ellipsis {
|
||||||
|
height: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mx_RoomSubList_line {
|
||||||
|
display: inline-block;
|
||||||
|
width: 159px;
|
||||||
|
border-top: dotted 2px #76cfa6;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.collapsed .mx_RoomSubList_line {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mx_RoomSubList_more {
|
||||||
|
display: inline-block;
|
||||||
|
text-transform: uppercase;
|
||||||
|
font-size: 10px;
|
||||||
|
font-weight: 600;
|
||||||
|
text-align: left;
|
||||||
|
color: #76cfa6;
|
||||||
|
padding-left: 7px;
|
||||||
|
padding-right: 7px;
|
||||||
|
padding-left: 7px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.collapsed .mx_RoomSubList_more {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mx_RoomSubList_moreBadge {
|
||||||
|
display: inline-block;
|
||||||
|
min-width: 15px;
|
||||||
|
height: 13px;
|
||||||
|
position: absolute;
|
||||||
|
right: 8px; /*gutter */
|
||||||
|
top: -2px;
|
||||||
|
border-radius: 8px;
|
||||||
|
border: solid 1px #76cfa6;
|
||||||
|
color: #fff;
|
||||||
|
font-weight: 600;
|
||||||
|
font-size: 10px;
|
||||||
|
text-align: center;
|
||||||
|
padding-top: 1px;
|
||||||
|
padding-left: 3px;
|
||||||
|
padding-right: 3px;
|
||||||
|
background-color: #fff;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mx_RoomSubList_moreBadge.mx_RoomSubList_moreBadgeNotify {
|
||||||
|
background-color: #76cfa6;
|
||||||
|
border: 0;
|
||||||
|
padding-top: 3px;
|
||||||
|
padding-left: 4px;
|
||||||
|
padding-right: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mx_RoomSubList_moreBadge.mx_RoomSubList_moreBadgeHighlight {
|
||||||
|
background-color: #ff0064;
|
||||||
|
border: 0;
|
||||||
|
padding-top: 3px;
|
||||||
|
padding-left: 4px;
|
||||||
|
padding-right: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.collapsed .mx_RoomSubList_moreBadge {
|
||||||
|
position: static;
|
||||||
|
margin-left: 16px;
|
||||||
|
margin-top: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mx_RoomSubList_ellipsis .mx_RoomSubList_chevronDown {
|
||||||
|
position: relative;
|
||||||
|
top: 4px;
|
||||||
|
left: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -48,5 +48,6 @@ limitations under the License.
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
line-height: 14px;
|
line-height: 14px;
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
|
color: rgba(0, 0, 0, 0.7);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue