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.
		
		
		
		
		
			
		
			
				
					
					
						
							493 lines
						
					
					
						
							10 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							493 lines
						
					
					
						
							10 KiB
						
					
					
				| $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; | |
|             } | |
|         } | |
|     } | |
| }
 | |
| 
 |