mirror of
				https://github.com/flarum/core.git
				synced 2025-10-25 21:56:18 +02:00 
			
		
		
		
	Mobile responsive design with a very native feel, all in pure CSS (no templating differences between versions — even though some things are in very different positions.) I’ve been working on this whole thing in my head for a while now, planning out how certain components will be laid out on the mobile version, and how to reason about them in the templates so that a substantially different layout can still be achieved by only using CSS. Today I finally wrote the CSS and it’s come together pretty damn perfectly. Still to come: - Swiping left or right on discussions to reveal controls - Tablet version
		
			
				
	
	
		
			349 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			349 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| // ------------------------------------
 | |
| // Sidebar
 | |
| 
 | |
| .index-nav > ul {
 | |
|   margin: 0;
 | |
|   padding: 0;
 | |
|   list-style: none;
 | |
| }
 | |
| 
 | |
| // On phones, the index sidebar will pretty much take care of itself. The
 | |
| // navigation list is a .dropdown-select and will be shown as the title-
 | |
| // control; the new discussion button is the primary-control. On anything
 | |
| // larger than a phone, however, we need to affix the sidebar and expand the
 | |
| // .dropdown-select into a plain list.
 | |
| @media @tablet, @desktop, @desktop-hd {
 | |
|   .index-nav {
 | |
|     float: left;
 | |
| 
 | |
|     &, & > ul {
 | |
|       width: 175px;
 | |
|     }
 | |
|     & > ul {
 | |
|       margin-top: 30px;
 | |
| 
 | |
|       &.affix {
 | |
|         top: 56px;
 | |
|       }
 | |
|       & > li {
 | |
|         margin-bottom: 10px;
 | |
|       }
 | |
|     }
 | |
|     & .new-discussion {
 | |
|       display: block;
 | |
|       margin-bottom: 20px;
 | |
|     }
 | |
| 
 | |
|     // Expand the dropdown-select component into a normal nav list
 | |
|     // @todo Extract this into a mixin as we'll probably need to do it elsewhere.
 | |
|     & .dropdown-select {
 | |
|       display: block;
 | |
| 
 | |
|       .expand-dropdown();
 | |
| 
 | |
|       & .dropdown-menu {
 | |
|         & > li > a {
 | |
|           padding: 8px 0;
 | |
|           color: @fl-body-muted-color;
 | |
| 
 | |
|           &:hover {
 | |
|             background: none;
 | |
|             color: @link-hover-color;
 | |
|           }
 | |
| 
 | |
|           & .fa {
 | |
|             margin-right: 8px;
 | |
|             font-size: 15px;
 | |
|           }
 | |
|         }
 | |
|         & > li.active > a {
 | |
|           background: none;
 | |
|           color: @fl-body-primary-color;
 | |
|           font-weight: bold;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| // ------------------------------------
 | |
| // Results
 | |
| 
 | |
| .index-toolbar {
 | |
|   margin-bottom: 15px;
 | |
| }
 | |
| .index-toolbar-view {
 | |
|   display: inline-block;
 | |
| 
 | |
|   & .control-show {
 | |
|     margin-right: 10px;
 | |
|   }
 | |
| }
 | |
| .index-toolbar-action {
 | |
|   float: right;
 | |
| }
 | |
| .index-results .loading-indicator {
 | |
|   height: 46px;
 | |
| }
 | |
| 
 | |
| @media @phone {
 | |
|   .index-results {
 | |
|     margin-top: 15px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media @tablet, @desktop, @desktop-hd {
 | |
|   .index-results {
 | |
|     margin-top: 30px;
 | |
|     margin-left: 225px;
 | |
|   }
 | |
| }
 | |
| 
 | |
| // ------------------------------------
 | |
| // Discussions Pane
 | |
| 
 | |
| .index-area.paned {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| @media @tablet, @desktop, @desktop-hd {
 | |
|   .index-area {
 | |
|     left: -@index-pane-width;
 | |
|     width: 100%;
 | |
| 
 | |
|     &.paned {
 | |
|       position: fixed;
 | |
|       z-index: @zindex-pane;
 | |
|       overflow: auto;
 | |
|       top: 56px;
 | |
|       bottom: 0;
 | |
|       width: @index-pane-width;
 | |
|       background: @fl-body-bg;
 | |
|       padding-bottom: 200px;
 | |
|       .box-shadow(2px 2px 6px -2px @fl-shadow-color);
 | |
|       .transition(left 0.2s);
 | |
| 
 | |
|       &.showing, .with-pane & {
 | |
|         left: 0;
 | |
|       }
 | |
|       .with-pane & {
 | |
|         z-index: @zindex-composer - 1;
 | |
|         .transition(none);
 | |
|       }
 | |
|       & .container {
 | |
|         width: auto;
 | |
|         margin: 0;
 | |
|         padding: 0 !important;
 | |
|       }
 | |
|       & .index-results {
 | |
|         margin: 0;
 | |
|       }
 | |
|       & .hero, & .index-nav, & .index-toolbar {
 | |
|         display: none;
 | |
|       }
 | |
|       & .discussions-list > li {
 | |
|         margin: 0;
 | |
|         padding-left: 65px + 15px;
 | |
|         padding-right: 65px + 15px;
 | |
|         &.active {
 | |
|           background: @fl-body-control-bg;
 | |
|         }
 | |
|       }
 | |
|       & .discussion-summary {
 | |
|         & .title {
 | |
|           font-size: 14px;
 | |
|         }
 | |
|         & .count strong {
 | |
|           font-size: 18px;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   // When the pane is pinned, move the other page content inwards
 | |
|   .global-main, .global-footer {
 | |
|     .with-pane & {
 | |
|       margin-left: @index-pane-width;
 | |
|       & .container {
 | |
|         max-width: 100%;
 | |
|         padding: 0 30px;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
|   .global-header .container {
 | |
|     .with-pane & {
 | |
|       width: 100%;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| // ------------------------------------
 | |
| // Discussions List
 | |
| 
 | |
| .discussions-list {
 | |
|   margin: 0;
 | |
|   padding: 0;
 | |
|   list-style-type: none;
 | |
|   position: relative;
 | |
| }
 | |
| 
 | |
| @media @phone {
 | |
|   .discussions-list > li {
 | |
|     padding-right: 45px;
 | |
| 
 | |
|     & .contextual-controls {
 | |
|       display: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media @tablet, @desktop, @desktop-hd {
 | |
|   .discussions-list {
 | |
|     & > li {
 | |
|       margin-right: -25px;
 | |
|       padding-right: 65px + 25px;
 | |
| 
 | |
|       & .contextual-controls {
 | |
|         position: absolute;
 | |
|         right: 0;
 | |
|         top: 18px;
 | |
|         visibility: hidden;
 | |
|       }
 | |
|       &:hover .contextual-controls, & .contextual-controls.open {
 | |
|         visibility: visible;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .discussion-summary {
 | |
|   position: relative;
 | |
| 
 | |
|   &, & a {
 | |
|     color: @fl-body-muted-color;
 | |
|     text-decoration: none;
 | |
|   }
 | |
|   & .author {
 | |
|     float: left;
 | |
|     margin-top: 18px;
 | |
|   }
 | |
|   & .main {
 | |
|     display: inline-block;
 | |
|     width: 100%;
 | |
|     padding: 20px 0;
 | |
|   }
 | |
|   &.active {
 | |
|     text-decoration: none;
 | |
|   }
 | |
|   &:hover .title {
 | |
|     text-decoration: underline;
 | |
|   }
 | |
|   & .title {
 | |
|     margin: 0 0 5px;
 | |
|     line-height: 1.3;
 | |
|   }
 | |
|   &.unread .title {
 | |
|     color: @fl-body-heading-color;
 | |
|     font-weight: bold;
 | |
|   }
 | |
|   & .info {
 | |
|     list-style-type: none;
 | |
|     padding: 0;
 | |
|     margin: 0;
 | |
| 
 | |
|     & > li {
 | |
|       display: inline-block;
 | |
|     }
 | |
|   }
 | |
|   & .username {
 | |
|     font-weight: bold;
 | |
|   }
 | |
|   & .count {
 | |
|     float: right;
 | |
|     margin-top: 18px;
 | |
|     text-decoration: none;
 | |
| 
 | |
|     .unread& {
 | |
|       cursor: pointer;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| .load-more {
 | |
|   text-align: center;
 | |
|   margin-top: 10px;
 | |
| }
 | |
| 
 | |
| @media @phone {
 | |
|   .discussion-summary {
 | |
|     padding-left: 45px;
 | |
|     padding-right: 45px;
 | |
| 
 | |
|     & .author {
 | |
|       margin-left: -45px;
 | |
|     }
 | |
|     & .avatar {
 | |
|       .avatar-size(32px);
 | |
|     }
 | |
|     & .main {
 | |
|       margin-right: -45px;
 | |
|     }
 | |
|     & .title {
 | |
|       font-size: 14px;
 | |
|     }
 | |
|     & .count {
 | |
|       margin-right: -45px;
 | |
|       background: @fl-body-control-bg;
 | |
|       color: @fl-body-control-color;
 | |
|       border-radius: @border-radius-base;
 | |
|       font-size: 12px;
 | |
|       padding: 1px 6px;
 | |
| 
 | |
|       .unread& {
 | |
|         background: @fl-body-primary-color;
 | |
|         color: #fff;
 | |
|         font-weight: bold;
 | |
|       }
 | |
| 
 | |
|       & .label {
 | |
|         display: none;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| @media @tablet, @desktop, @desktop-hd {
 | |
|   .discussion-summary {
 | |
|     padding-left: 65px;
 | |
|     padding-right: 65px;
 | |
| 
 | |
|     & .author {
 | |
|       margin-left: -65px;
 | |
|     }
 | |
|     & .main {
 | |
|       margin-right: -65px;
 | |
|     }
 | |
|     & .title {
 | |
|       font-size: 15px;
 | |
|     }
 | |
|     & .count {
 | |
|       margin-right: -65px;
 | |
|       width: 60px;
 | |
|       text-align: center;
 | |
|       text-transform: uppercase;
 | |
|       color: @fl-body-muted-color;
 | |
|       font-size: 20px;
 | |
|       font-weight: 300;
 | |
| 
 | |
|       & .label {
 | |
|         font-size: 11px;
 | |
|         display: block;
 | |
|         font-weight: normal;
 | |
|       }
 | |
|       .unread& {
 | |
|         color: @fl-body-heading-color;
 | |
|         font-weight: bold;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 |