You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
494 lines
10 KiB
494 lines
10 KiB
7 years ago
|
$toggle-width: 25px;
|
||
|
$standard-border: 1px solid #ddd;
|
||
|
$region-container-height: 500px;
|
||
|
$region-container-width: 380px;
|
||
|
$region-container-z-index: 1;
|
||
|
$region-header-height: 25px;
|
||
|
$region-footer-height: 30px;
|
||
|
$content-item-hover-colour-bg: #79b5e6;
|
||
|
$content-item-hover-colour-text: #fff;
|
||
|
$content-item-selected-colour-bg: #4f94cd;
|
||
|
$content-item-unread-colour: #f4f4f4;
|
||
|
$content-header-footer-height: $region-header-height + $region-footer-height;
|
||
|
|
||
|
@mixin invisible() {
|
||
|
opacity: 0;
|
||
|
visibility: hidden;
|
||
|
}
|
||
|
|
||
|
@mixin visible() {
|
||
|
opacity: 1;
|
||
|
visibility: visible;
|
||
|
}
|
||
|
|
||
|
.popover-region {
|
||
|
float: right;
|
||
|
position: relative;
|
||
|
|
||
|
&.collapsed {
|
||
|
.popover-region-toggle {
|
||
|
&:before,
|
||
|
&:after {
|
||
|
display: none;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.popover-region-container {
|
||
|
@include invisible();
|
||
|
|
||
|
height: 0;
|
||
|
overflow: hidden;
|
||
|
transition: height 0.25s, opacity 101ms 0.25s, visibility 101ms 0.25s;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.popover-region-toggle {
|
||
|
cursor: pointer;
|
||
|
|
||
|
&::before {
|
||
|
content: '';
|
||
|
display: inline-block;
|
||
|
border-left: 10px solid transparent;
|
||
|
border-right: 10px solid transparent;
|
||
|
border-bottom: 10px solid #ddd;
|
||
|
position: absolute;
|
||
|
bottom: 0;
|
||
|
right: 7px;
|
||
|
}
|
||
|
|
||
|
&::after {
|
||
|
content: '';
|
||
|
display: inline-block;
|
||
|
border-left: 9px solid transparent;
|
||
|
border-right: 9px solid transparent;
|
||
|
border-bottom: 9px solid #fff;
|
||
|
position: absolute;
|
||
|
bottom: -1px;
|
||
|
right: 8px;
|
||
|
z-index: $region-container-z-index + 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.count-container {
|
||
|
padding: 2px;
|
||
|
border-radius: 2px;
|
||
|
background-color: red;
|
||
|
color: white;
|
||
|
font-size: 10px;
|
||
|
line-height: 10px;
|
||
|
position: absolute;
|
||
|
top: 5px;
|
||
|
right: 0;
|
||
|
}
|
||
|
|
||
|
.popover-region-container {
|
||
|
@include visible();
|
||
|
|
||
|
position: absolute;
|
||
|
right: 0;
|
||
|
top: 0;
|
||
|
height: $region-container-height;
|
||
|
width: $region-container-width;
|
||
|
border: $standard-border;
|
||
|
transition: height 0.25s;
|
||
|
background-color: #fff;
|
||
|
z-index: $region-container-z-index;
|
||
|
}
|
||
|
|
||
|
.popover-region-header-container {
|
||
|
height: $region-header-height;
|
||
|
line-height: $region-header-height;
|
||
|
padding-left: 5px;
|
||
|
padding-right: 5px;
|
||
|
border-bottom: $standard-border;
|
||
|
box-sizing: border-box;
|
||
|
}
|
||
|
|
||
|
.popover-region-footer-container {
|
||
|
height: $region-footer-height;
|
||
|
text-align: center;
|
||
|
border-top: $standard-border;
|
||
|
background-color: $popover-bg;
|
||
|
padding-top: 3px;
|
||
|
}
|
||
|
|
||
|
.popover-region-header-text {
|
||
|
float: left;
|
||
|
margin: 0;
|
||
|
font-size: 14px;
|
||
|
line-height: $region-header-height;
|
||
|
}
|
||
|
|
||
|
.popover-region-header-actions {
|
||
|
float: right;
|
||
|
|
||
|
> * {
|
||
|
margin-left: 10px;
|
||
|
min-width: 20px;
|
||
|
display: inline-block;
|
||
|
}
|
||
|
.loading-icon {
|
||
|
display: none;
|
||
|
height: 12px;
|
||
|
width: 12px;
|
||
|
}
|
||
|
|
||
|
.newmessage-link {
|
||
|
margin-right: 10px;
|
||
|
}
|
||
|
|
||
|
label {
|
||
|
display: inline-block;
|
||
|
text-align: center;
|
||
|
margin-bottom: 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.popover-region-content-container {
|
||
|
height: calc(100% - #{$content-header-footer-height});
|
||
|
width: 100%;
|
||
|
overflow-y: auto;
|
||
|
-webkit-overflow-scrolling: touch;
|
||
|
|
||
|
> .loading-icon {
|
||
|
display: none;
|
||
|
text-align: center;
|
||
|
padding: 5px;
|
||
|
box-sizing: border-box;
|
||
|
}
|
||
|
|
||
|
.empty-message {
|
||
|
display: none;
|
||
|
text-align: center;
|
||
|
padding: 10px;
|
||
|
}
|
||
|
|
||
|
&.loading {
|
||
|
> .loading-icon {
|
||
|
display: block;
|
||
|
}
|
||
|
|
||
|
.empty-message {
|
||
|
display: none;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.navbar {
|
||
|
.popover-region {
|
||
|
float: right;
|
||
|
margin-right: 10px;
|
||
|
|
||
|
&.collapsed {
|
||
|
.popover-region-container {
|
||
|
@include invisible();
|
||
|
|
||
|
height: 0;
|
||
|
overflow: hidden;
|
||
|
transition: height 0.25s, opacity 101ms 0.25s, visibility 101ms 0.25s;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.popover-region-toggle {
|
||
|
width: $toggle-width;
|
||
|
}
|
||
|
|
||
|
.count-container {
|
||
|
padding: 2px;
|
||
|
border-radius: 2px;
|
||
|
background-color: red;
|
||
|
color: white;
|
||
|
font-size: 10px;
|
||
|
line-height: 10px;
|
||
|
position: absolute;
|
||
|
top: 5px;
|
||
|
right: 0;
|
||
|
}
|
||
|
|
||
|
.popover-region-container {
|
||
|
top: $line-height-base * 1.4 * $font-size-base;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
.content-item-container {
|
||
|
width: 100%;
|
||
|
border-bottom: $standard-border;
|
||
|
box-sizing: border-box;
|
||
|
padding: 5px;
|
||
|
position: relative;
|
||
|
margin: 0;
|
||
|
display: block;
|
||
|
color: inherit;
|
||
|
text-decoration: none;
|
||
|
|
||
|
&:hover {
|
||
|
color: $content-item-hover-colour-text;
|
||
|
background-color: $content-item-hover-colour-bg;
|
||
|
|
||
|
.content-item-footer {
|
||
|
.timestamp {
|
||
|
color: $content-item-hover-colour-text;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
&.unread {
|
||
|
margin: 0;
|
||
|
background-color: $content-item-unread-colour;
|
||
|
|
||
|
&:hover {
|
||
|
color: $content-item-hover-colour-text;
|
||
|
background-color: $content-item-hover-colour-bg;
|
||
|
}
|
||
|
|
||
|
.content-item-body {
|
||
|
.notification-message {
|
||
|
font-weight: 600;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.context-link {
|
||
|
color: inherit;
|
||
|
text-decoration: none;
|
||
|
}
|
||
|
|
||
|
.content-item-body {
|
||
|
box-sizing: border-box;
|
||
|
margin-bottom: 5px;
|
||
|
}
|
||
|
|
||
|
.content-item-footer {
|
||
|
text-align: left;
|
||
|
box-sizing: border-box;
|
||
|
|
||
|
.timestamp {
|
||
|
font-size: 10px;
|
||
|
line-height: 10px;
|
||
|
margin: 0;
|
||
|
color: #666;
|
||
|
margin-left: 24px;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.view-more {
|
||
|
position: absolute;
|
||
|
bottom: 5px;
|
||
|
right: 5px;
|
||
|
font-size: 12px;
|
||
|
line-height: 12px;
|
||
|
}
|
||
|
|
||
|
&.notification {
|
||
|
.content-item-body {
|
||
|
.notification-image {
|
||
|
display: inline-block;
|
||
|
width: 24px;
|
||
|
height: 24px;
|
||
|
float: left;
|
||
|
|
||
|
img {
|
||
|
height: 75%;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.notification-message {
|
||
|
display: inline-block;
|
||
|
font-size: 12px;
|
||
|
width: calc(100% - 24px);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
&.selected {
|
||
|
background-color: $content-item-selected-colour-bg;
|
||
|
color: $content-item-hover-colour-text;
|
||
|
border-color: $content-item-selected-colour-bg;
|
||
|
|
||
|
.content-item-footer {
|
||
|
.timestamp {
|
||
|
color: $content-item-hover-colour-text;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.popover-region-notifications {
|
||
|
.popover-region-header-container {
|
||
|
.mark-all-read-button {
|
||
|
.normal-icon {
|
||
|
display: inline-block;
|
||
|
}
|
||
|
|
||
|
&.loading {
|
||
|
.normal-icon {
|
||
|
display: none;
|
||
|
}
|
||
|
.loading-icon {
|
||
|
display: inline-block;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.all-notifications {
|
||
|
@include visible();
|
||
|
|
||
|
height: auto;
|
||
|
overflow: hidden;
|
||
|
|
||
|
&:empty + .empty-message {
|
||
|
display: block;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.notification-image {
|
||
|
display: inline-block;
|
||
|
width: 8%;
|
||
|
vertical-align: top;
|
||
|
|
||
|
img {
|
||
|
height: 75%;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.notification-message {
|
||
|
display: inline-block;
|
||
|
font-size: 12px;
|
||
|
}
|
||
|
|
||
|
.popover-region-content-container {
|
||
|
&.loading {
|
||
|
.all-notifications {
|
||
|
&:empty + .empty-message {
|
||
|
display: none;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.popover-region-messages {
|
||
|
.mark-all-read-button {
|
||
|
.normal-icon {
|
||
|
display: inline-block;
|
||
|
}
|
||
|
|
||
|
&.loading {
|
||
|
.normal-icon {
|
||
|
display: none;
|
||
|
}
|
||
|
.loading-icon {
|
||
|
display: inline-block;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.popover-region-content-container {
|
||
|
&.loading {
|
||
|
.popover-region-content {
|
||
|
.messages {
|
||
|
&:empty + .empty-message {
|
||
|
display: none;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.messages {
|
||
|
&:empty + .empty-message {
|
||
|
display: block;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.content-item-container {
|
||
|
&.unread {
|
||
|
.content-item-body {
|
||
|
font-weight: 600;
|
||
|
width: calc(90% - 30px);
|
||
|
}
|
||
|
|
||
|
.unread-count-container {
|
||
|
display: inline-block;
|
||
|
width: 10%;
|
||
|
text-align: center;
|
||
|
float: right;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.content-item {
|
||
|
height: 100%;
|
||
|
width: 100%;
|
||
|
box-sizing: border-box;
|
||
|
}
|
||
|
|
||
|
.profile-image-container {
|
||
|
width: 30px;
|
||
|
display: inline-block;
|
||
|
text-align: center;
|
||
|
float: left;
|
||
|
|
||
|
img {
|
||
|
width: 100%;
|
||
|
display: inline-block;
|
||
|
vertical-align: middle;
|
||
|
border-radius: 50%;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.content-item-body {
|
||
|
display: inline-block;
|
||
|
box-sizing: border-box;
|
||
|
width: calc(100% - 30px);
|
||
|
font-size: 12px;
|
||
|
padding-left: 10px;
|
||
|
overflow: hidden;
|
||
|
|
||
|
h3 {
|
||
|
font-size: 12px;
|
||
|
line-height: 12px;
|
||
|
margin: 0;
|
||
|
width: 100%;
|
||
|
}
|
||
|
|
||
|
p {
|
||
|
margin: 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.unread-count-container {
|
||
|
display: none;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@media (max-width: 767px) {
|
||
|
.navbar {
|
||
|
.popover-region {
|
||
|
.popover-region-container {
|
||
|
right: -70px;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@media (max-width: 480px) {
|
||
|
.navbar {
|
||
|
.popover-region {
|
||
|
.popover-region-container {
|
||
|
position: fixed;
|
||
|
top: 46px;
|
||
|
right: 0;
|
||
|
left: 0;
|
||
|
bottom: 0;
|
||
|
width: auto;
|
||
|
height: auto;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|