You've already forked AstralRinth
forked from didirus/AstralRinth
Make responsive (#8)
* Refactor ModResult to use CSS Grid * Mobile support for ModResult * Mobile navbar * Mobile fixes, get rid of x overflow * Mobile filter support * Fully responsive * Collapse categories view later * Mobile-first * Fix version selector width
This commit is contained in:
@@ -1,7 +1,7 @@
|
|||||||
.columns {
|
.columns {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
|
||||||
@for $i from 1 through 4 {
|
@for $i from 1 through 5 {
|
||||||
.column-grow-#{$i} {
|
.column-grow-#{$i} {
|
||||||
flex-grow: $i;
|
flex-grow: $i;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="result rows">
|
<div class="result rows">
|
||||||
<img class="result-icon" :src="iconUrl" />
|
<img class="result-icon" :src="iconUrl" />
|
||||||
<div class="column-grow-3">
|
<div class="rows result-name-author">
|
||||||
<div class="rows column-grow-2">
|
|
||||||
<h2 class="mod-name">
|
<h2 class="mod-name">
|
||||||
<a :href="pageUrl">{{ name }}</a>
|
<a :href="pageUrl">{{ name }}</a>
|
||||||
</h2>
|
</h2>
|
||||||
@@ -10,7 +9,7 @@
|
|||||||
by <a :href="authorUrl">{{ author }}</a>
|
by <a :href="authorUrl">{{ author }}</a>
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<p class="column-grow-1">
|
<p class="result-summary">
|
||||||
{{ description }}
|
{{ description }}
|
||||||
</p>
|
</p>
|
||||||
<div class="column-grow-1 columns result-infos">
|
<div class="column-grow-1 columns result-infos">
|
||||||
@@ -102,7 +101,6 @@
|
|||||||
</svg>
|
</svg>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
<div class="categories">
|
<div class="categories">
|
||||||
<p v-if="categories.includes('technology')">
|
<p v-if="categories.includes('technology')">
|
||||||
<svg
|
<svg
|
||||||
@@ -375,10 +373,18 @@ export default {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.result {
|
.result {
|
||||||
align-items: center;
|
display: grid;
|
||||||
|
grid-template-columns: 80px auto;
|
||||||
|
grid-template-rows: auto auto auto 30px;
|
||||||
|
max-width: 100vw;
|
||||||
margin-bottom: 10px;
|
margin-bottom: 10px;
|
||||||
background: var(--color-bg);
|
background: var(--color-bg);
|
||||||
box-shadow: 0 2px 3px 1px var(--color-grey-2);
|
box-shadow: 0 2px 3px 1px var(--color-grey-2);
|
||||||
|
|
||||||
|
// Columns are larger to accomodate larger screens
|
||||||
|
@media screen and (min-width: 1375px) {
|
||||||
|
grid-template-columns: 120px auto;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.result * {
|
.result * {
|
||||||
@@ -388,26 +394,80 @@ export default {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.result-icon {
|
.result-icon {
|
||||||
|
width: 60px;
|
||||||
|
height: 60px;
|
||||||
|
margin: 5px !important;
|
||||||
|
border-radius: 0.5rem;
|
||||||
|
grid-row-start: 1;
|
||||||
|
grid-row-end: 4;
|
||||||
|
grid-column-start: 1;
|
||||||
|
|
||||||
|
@media screen and (min-width: 900px) {
|
||||||
|
margin: 10px 20px 10px 10px !important;
|
||||||
|
width: 70px;
|
||||||
|
height: 70px;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Larger screen, larger icon
|
||||||
|
@media screen and (min-width: 1375px) {
|
||||||
width: 90px;
|
width: 90px;
|
||||||
height: 90px;
|
height: 90px;
|
||||||
margin: 10px 20px 10px 10px !important;
|
}
|
||||||
border-radius: 0.5rem;
|
}
|
||||||
|
|
||||||
|
.result-name-author {
|
||||||
|
display: block;
|
||||||
|
margin-top: 10px;
|
||||||
|
min-height: 38px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.result-summary {
|
||||||
|
grid-row: 2;
|
||||||
|
grid-column: 2;
|
||||||
|
max-height: 150px;
|
||||||
|
font-size: 11pt;
|
||||||
}
|
}
|
||||||
|
|
||||||
.mod-name {
|
.mod-name {
|
||||||
align-self: flex-end;
|
align-self: flex-end;
|
||||||
|
font-size: 13pt;
|
||||||
}
|
}
|
||||||
|
|
||||||
.author {
|
.author {
|
||||||
margin-left: 5px;
|
|
||||||
margin-bottom: 2px !important;
|
margin-bottom: 2px !important;
|
||||||
align-self: flex-end;
|
align-self: flex-end;
|
||||||
|
font-size: 12pt;
|
||||||
}
|
}
|
||||||
|
|
||||||
.result-infos {
|
.result-infos {
|
||||||
margin-top: 5px !important;
|
display: grid;
|
||||||
|
grid-template-columns: 115px 115px auto;
|
||||||
|
grid-template-rows: 20px 20px;
|
||||||
|
margin-top: 5px;
|
||||||
|
grid-column: 2;
|
||||||
align-self: flex-end;
|
align-self: flex-end;
|
||||||
align-items: center;
|
align-items: flex-start;
|
||||||
|
align-self: flex-start;
|
||||||
|
|
||||||
|
.columns:nth-child(2) {
|
||||||
|
grid-column: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.columns:nth-child(3) {
|
||||||
|
grid-column: 2;
|
||||||
|
grid-row: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.result-image {
|
||||||
|
p {
|
||||||
|
font-size: 10pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
svg {
|
||||||
|
width: 14px;
|
||||||
|
height: 14px;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.result-image svg {
|
.result-image svg {
|
||||||
@@ -426,7 +486,9 @@ export default {
|
|||||||
.categories {
|
.categories {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
margin: auto 20px 20px auto;
|
margin: 0 0 5px 0;
|
||||||
|
grid-column: 1;
|
||||||
|
margin-bottom: auto;
|
||||||
}
|
}
|
||||||
|
|
||||||
.categories p {
|
.categories p {
|
||||||
@@ -447,6 +509,8 @@ export default {
|
|||||||
|
|
||||||
.loaders {
|
.loaders {
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
grid-column: 1;
|
||||||
|
grid-row: 3;
|
||||||
img {
|
img {
|
||||||
width: 15px;
|
width: 15px;
|
||||||
}
|
}
|
||||||
@@ -457,4 +521,83 @@ export default {
|
|||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Larger tablet-sized screens
|
||||||
|
@media screen and (min-width: 900px) {
|
||||||
|
.result {
|
||||||
|
grid-template-columns: 90px auto;
|
||||||
|
grid-template-rows: auto auto 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.result-infos {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
margin-top: 0;
|
||||||
|
.result-image {
|
||||||
|
p {
|
||||||
|
font-size: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
svg {
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.loaders {
|
||||||
|
svg {
|
||||||
|
width: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.categories {
|
||||||
|
margin: 0 0 10px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.result-name-author {
|
||||||
|
display: flex;
|
||||||
|
margin-top: 0;
|
||||||
|
.author {
|
||||||
|
margin-left: 5px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.mod-name {
|
||||||
|
font-size: 16pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
.result-summary {
|
||||||
|
max-height: 100px;
|
||||||
|
font-size: 13pt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Larger screens
|
||||||
|
@media screen and (min-width: 1375px) {
|
||||||
|
.result {
|
||||||
|
margin: 5px 0 5px 15px;
|
||||||
|
grid-column: 1;
|
||||||
|
grid-template-columns: 110px auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.categories {
|
||||||
|
margin: auto 0 5px auto;
|
||||||
|
grid-row: 3;
|
||||||
|
grid-column: 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.mod-name {
|
||||||
|
font-size: 18pt;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Desktop
|
||||||
|
@media screen and (min-width: 1500px) {
|
||||||
|
.result-name-author {
|
||||||
|
display: flex;
|
||||||
|
min-height: 38px;
|
||||||
|
grid-column: 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -1,6 +1,14 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="layout">
|
<div class="layout">
|
||||||
<aside>
|
<aside>
|
||||||
|
<input
|
||||||
|
class="hamburger-button"
|
||||||
|
alt="Open navigation menu"
|
||||||
|
type="checkbox"
|
||||||
|
@click="toggleNavMenu()"
|
||||||
|
/>
|
||||||
|
<!-- TODO: Probably shouldn't be a Unicode symbol -->
|
||||||
|
<div class="hamburger-icon">☰</div>
|
||||||
<div class="logo-wrapper">
|
<div class="logo-wrapper">
|
||||||
<img class="logo" src="~/assets/images/logo.svg" />
|
<img class="logo" src="~/assets/images/logo.svg" />
|
||||||
<span class="name">modrinth</span>
|
<span class="name">modrinth</span>
|
||||||
@@ -223,6 +231,10 @@ export default {
|
|||||||
localStorage.setItem('data-theme', theme)
|
localStorage.setItem('data-theme', theme)
|
||||||
document.documentElement.setAttribute('data-theme', theme)
|
document.documentElement.setAttribute('data-theme', theme)
|
||||||
},
|
},
|
||||||
|
toggleNavMenu() {
|
||||||
|
document.body.style.overflow =
|
||||||
|
document.body.style.overflow !== 'hidden' ? 'hidden' : 'auto'
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
@@ -230,30 +242,37 @@ export default {
|
|||||||
<style lang="scss">
|
<style lang="scss">
|
||||||
.layout {
|
.layout {
|
||||||
display: flex;
|
display: flex;
|
||||||
|
flex-flow: column;
|
||||||
min-height: 100vh;
|
min-height: 100vh;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
|
||||||
|
// Desktop
|
||||||
|
@media screen and (min-width: 1145px) {
|
||||||
|
flex-flow: row;
|
||||||
|
}
|
||||||
|
|
||||||
aside {
|
aside {
|
||||||
top: 0;
|
top: 0;
|
||||||
position: -webkit-sticky;
|
|
||||||
position: sticky;
|
position: sticky;
|
||||||
max-height: 100vh;
|
border-right: 0;
|
||||||
border-right: 1px solid var(--color-grey-2);
|
|
||||||
display: flex; // Flex here to safely expand navigation height
|
display: flex; // Flex here to safely expand navigation height
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
max-width: 15%;
|
width: 100vw;
|
||||||
min-width: 15%;
|
max-height: 100vh;
|
||||||
|
background: var(--color-bg);
|
||||||
|
z-index: 10;
|
||||||
|
|
||||||
.logo-wrapper {
|
.logo-wrapper {
|
||||||
align-items: center;
|
align-items: center;
|
||||||
display: flex;
|
display: flex;
|
||||||
height: 3.5rem;
|
height: 3.5rem;
|
||||||
padding: 0 1.5rem;
|
width: 100vw;
|
||||||
font-family: 'Montserrat', sans-serif;
|
font-family: 'Montserrat', sans-serif;
|
||||||
|
|
||||||
.logo {
|
.logo {
|
||||||
height: 2rem;
|
height: 2rem;
|
||||||
width: auto;
|
width: auto;
|
||||||
|
margin-left: 2.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.name {
|
.name {
|
||||||
@@ -263,14 +282,53 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.hamburger-button {
|
||||||
|
position: absolute;
|
||||||
|
display: block;
|
||||||
|
left: 10px;
|
||||||
|
opacity: 0;
|
||||||
|
margin: 0;
|
||||||
|
top: 1.2rem;
|
||||||
|
width: 30px;
|
||||||
|
height: 30px;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hamburger-icon {
|
||||||
|
display: block;
|
||||||
|
position: absolute;
|
||||||
|
left: 15px;
|
||||||
|
top: 1.2rem;
|
||||||
|
pointer-events: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hamburger-button:checked ~ nav {
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
|
||||||
nav {
|
nav {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
|
position: absolute;
|
||||||
|
height: calc(100vh - 3.5rem);
|
||||||
|
width: 100vw;
|
||||||
|
left: -100vw;
|
||||||
|
top: 3.5rem;
|
||||||
|
transition: left 150ms;
|
||||||
|
background: var(--color-bg);
|
||||||
|
overflow-y: auto;
|
||||||
|
z-index: 10;
|
||||||
|
|
||||||
|
// Larger screens that still need a collapsed menu
|
||||||
|
@media screen and (min-width: 900px) {
|
||||||
|
width: 300px;
|
||||||
|
left: -300px;
|
||||||
|
}
|
||||||
|
|
||||||
& > * {
|
& > * {
|
||||||
padding: 0 1.5rem;
|
padding: 0 0.75rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.links {
|
.links {
|
||||||
@@ -285,7 +343,6 @@ export default {
|
|||||||
|
|
||||||
section {
|
section {
|
||||||
border-left: 4px solid var(--color-grey-3);
|
border-left: 4px solid var(--color-grey-3);
|
||||||
margin-left: 0.5rem;
|
|
||||||
|
|
||||||
a {
|
a {
|
||||||
align-items: center;
|
align-items: center;
|
||||||
@@ -309,6 +366,7 @@ export default {
|
|||||||
svg {
|
svg {
|
||||||
height: 1rem;
|
height: 1rem;
|
||||||
width: 1rem;
|
width: 1rem;
|
||||||
|
flex-shrink: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
span {
|
span {
|
||||||
@@ -350,6 +408,33 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Desktop
|
||||||
|
@media screen and (min-width: 1145px) {
|
||||||
|
border-right: 1px solid var(--color-grey-2);
|
||||||
|
max-width: 270px;
|
||||||
|
|
||||||
|
nav {
|
||||||
|
height: 100%;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
transition: none;
|
||||||
|
position: static;
|
||||||
|
}
|
||||||
|
|
||||||
|
.logo-wrapper {
|
||||||
|
padding: 0 0 0 1.5rem;
|
||||||
|
width: 100%;
|
||||||
|
.logo {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.hamburger-button,
|
||||||
|
.hamburger-icon {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
main {
|
main {
|
||||||
background-color: var(--color-grey-0);
|
background-color: var(--color-grey-0);
|
||||||
@@ -399,7 +484,18 @@ export default {
|
|||||||
}
|
}
|
||||||
|
|
||||||
.content {
|
.content {
|
||||||
padding: 1rem 3rem 1rem 2rem;
|
// Default is for small phone sizes (like iPhone 5/SE)
|
||||||
|
padding: 0.5rem 0.35rem 0.5rem 0.35rem;
|
||||||
|
|
||||||
|
// Larger phones
|
||||||
|
@media screen and (min-width: 500px) {
|
||||||
|
padding: 1rem 0.5rem 1rem 0.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Desktop
|
||||||
|
@media screen and (min-width: 1145px) {
|
||||||
|
padding: 1rem;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -413,4 +509,12 @@ export default {
|
|||||||
text-decoration: var(--color-grey-2) underline;
|
text-decoration: var(--color-grey-2) underline;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Hack for very small (iPhone 5/SE) sized phones
|
||||||
|
// an x overflow existed and I was unable to figure out why
|
||||||
|
@media screen and (max-width: 360px) {
|
||||||
|
body {
|
||||||
|
overflow-x: hidden !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
122
pages/mods.vue
122
pages/mods.vue
@@ -1,6 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="columns">
|
<div class="columns">
|
||||||
<div class="content column-grow-4">
|
<div class="content column-grow-5">
|
||||||
<h2>Mods</h2>
|
<h2>Mods</h2>
|
||||||
<section class="search-bar">
|
<section class="search-bar">
|
||||||
<div class="iconified-input column-grow-2">
|
<div class="iconified-input column-grow-2">
|
||||||
@@ -24,6 +24,7 @@
|
|||||||
<line x1="21" y1="21" x2="16.65" y2="16.65" />
|
<line x1="21" y1="21" x2="16.65" y2="16.65" />
|
||||||
</svg>
|
</svg>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="sort-paginate">
|
||||||
<div class="iconified-select">
|
<div class="iconified-select">
|
||||||
<select id="sort-type" @input="changeSortType">
|
<select id="sort-type" @input="changeSortType">
|
||||||
<option value="relevance" selected>Relevance</option>
|
<option value="relevance" selected>Relevance</option>
|
||||||
@@ -43,6 +44,10 @@
|
|||||||
<polyline points="6 9 12 15 18 9"></polyline>
|
<polyline points="6 9 12 15 18 9"></polyline>
|
||||||
</svg>
|
</svg>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="mobile-filters-button">
|
||||||
|
<button @click="toggleFiltersMenu">Filter...</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<pagination
|
<pagination
|
||||||
:current-page="currentPage"
|
:current-page="currentPage"
|
||||||
:pages="pages"
|
:pages="pages"
|
||||||
@@ -96,10 +101,13 @@
|
|||||||
></pagination>
|
></pagination>
|
||||||
</section>
|
</section>
|
||||||
</div>
|
</div>
|
||||||
<section class="filters">
|
<section id="filters" class="filters">
|
||||||
<!--#region filters -->
|
<!--#region filters -->
|
||||||
<div class="filters-wrapper">
|
<div class="filters-wrapper">
|
||||||
<section class="filter-group">
|
<section class="filter-group">
|
||||||
|
<button class="filter-button-done" @click="toggleFiltersMenu">
|
||||||
|
Done
|
||||||
|
</button>
|
||||||
<button @click="clearFilters">Clear Filters</button>
|
<button @click="clearFilters">Clear Filters</button>
|
||||||
<h3>Categories</h3>
|
<h3>Categories</h3>
|
||||||
<p
|
<p
|
||||||
@@ -411,6 +419,7 @@ export default {
|
|||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
document.getElementById('sort-type').value = this.sortType
|
document.getElementById('sort-type').value = this.sortType
|
||||||
|
if (this.pages.length > 1)
|
||||||
document.getElementById('max-results').value = this.maxResults
|
document.getElementById('max-results').value = this.maxResults
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
@@ -566,6 +575,13 @@ export default {
|
|||||||
formatNumber(x) {
|
formatNumber(x) {
|
||||||
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',')
|
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',')
|
||||||
},
|
},
|
||||||
|
toggleFiltersMenu() {
|
||||||
|
const filters = document.getElementById('filters')
|
||||||
|
const currentlyActive = filters.className === 'filters active'
|
||||||
|
filters.className = `filters${currentlyActive ? '' : ' active'}`
|
||||||
|
document.body.style.overflow =
|
||||||
|
document.body.style.overflow !== 'hidden' ? 'hidden' : 'auto'
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
@@ -576,6 +592,38 @@ export default {
|
|||||||
align-items: center;
|
align-items: center;
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
|
flex-flow: column;
|
||||||
|
.iconified-input {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.iconified-select {
|
||||||
|
width: 100%;
|
||||||
|
margin-left: 0;
|
||||||
|
select {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.sort-paginate {
|
||||||
|
display: flex;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
@media screen and (min-width: 900px) {
|
||||||
|
flex-flow: row;
|
||||||
|
.iconified-input {
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
.iconified-select {
|
||||||
|
width: auto;
|
||||||
|
margin-left: 1em;
|
||||||
|
select {
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.sort-paginate {
|
||||||
|
display: block;
|
||||||
|
width: auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.search-bottom {
|
.search-bottom {
|
||||||
@@ -592,20 +640,39 @@ export default {
|
|||||||
min-height: 96vh;
|
min-height: 96vh;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.mobile-filters-button {
|
||||||
|
display: inline-block;
|
||||||
|
button {
|
||||||
|
background: var(--color-bg);
|
||||||
|
border: 2px solid var(--color-grey-3);
|
||||||
|
border-radius: var(--size-rounded-sm);
|
||||||
|
padding: 0.5rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hide button on larger screens where it's not needed
|
||||||
|
@media screen and (min-width: 900px) {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.filters {
|
.filters {
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
background-color: var(--color-bg);
|
background-color: var(--color-bg);
|
||||||
border-left: 1px solid var(--color-grey-2);
|
border-left: 1px solid var(--color-grey-2);
|
||||||
top: 0;
|
position: fixed;
|
||||||
position: -webkit-sticky;
|
width: 100vw;
|
||||||
position: sticky;
|
right: -100vw;
|
||||||
max-height: 100vh;
|
max-height: 100vh;
|
||||||
min-width: 15%;
|
min-width: 15%;
|
||||||
max-width: 15%;
|
overflow-y: auto;
|
||||||
}
|
top: 3.5rem;
|
||||||
|
height: calc(100vh - 3.5rem);
|
||||||
|
transition: right 150ms;
|
||||||
|
flex-shrink: 0; // Stop shrinking when page contents change
|
||||||
|
|
||||||
.filters-wrapper {
|
.filters-wrapper {
|
||||||
padding: 0 1.5rem;
|
padding: 0 0.75rem;
|
||||||
|
}
|
||||||
|
|
||||||
h3 {
|
h3 {
|
||||||
color: #718096;
|
color: #718096;
|
||||||
@@ -615,10 +682,28 @@ export default {
|
|||||||
margin-top: 1.5rem;
|
margin-top: 1.5rem;
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Larger screens that don't need to collapse
|
||||||
|
@media screen and (min-width: 900px) {
|
||||||
|
position: sticky;
|
||||||
|
width: 215px;
|
||||||
|
padding-right: 1rem;
|
||||||
|
transition: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Desktop
|
||||||
|
@media screen and (min-width: 1145px) {
|
||||||
|
top: 0;
|
||||||
|
height: 100vh;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.active {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.filter-group {
|
.filter-group {
|
||||||
margin-top: 2em;
|
margin-top: 1em;
|
||||||
|
|
||||||
button {
|
button {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
@@ -635,6 +720,10 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.filter-button-done {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
p {
|
p {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
@@ -650,6 +739,7 @@ export default {
|
|||||||
svg {
|
svg {
|
||||||
margin-right: 5px;
|
margin-right: 5px;
|
||||||
height: 1rem;
|
height: 1rem;
|
||||||
|
flex-shrink: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
&:hover,
|
&:hover,
|
||||||
@@ -664,6 +754,18 @@ export default {
|
|||||||
color: var(--color-text);
|
color: var(--color-text);
|
||||||
border-left: 4px solid var(--color-brand);
|
border-left: 4px solid var(--color-brand);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Large screens that don't collapse
|
||||||
|
@media screen and (min-width: 900px) {
|
||||||
|
.filter-button-done {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Desktop
|
||||||
|
@media screen and (min-width: 1145px) {
|
||||||
|
margin-top: 2em;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.iconified-select {
|
.iconified-select {
|
||||||
|
|||||||
Reference in New Issue
Block a user