Improved site and network pages. Fixed various issues.

This commit is contained in:
2019-11-12 01:22:20 +01:00
parent 3c76d39301
commit 832e96ced1
118 changed files with 327 additions and 224 deletions

View File

@@ -3,46 +3,35 @@
v-if="network"
class="content network"
>
<div class="header">
<span class="intro">
<h2 class="title">
{{ network.name }}
<a
v-if="network.url"
:href="network.url"
target="_blank"
rel="noopener noreferrer"
>
<Icon
icon="new-tab"
class="icon-href"
/>
</a>
</h2>
<span class="description">{{ network.description }}</span>
</span>
<a
v-if="network.url"
:href="network.url"
target="_blank"
rel="noopener noreferrer"
>
<object
:data="`/img/logos/${network.slug}/network.png`"
type="image/png"
class="logo"
>{{ network.name }}</object>
</a>
</div>
<div class="content-inner">
<div class="header">
<a
v-if="network.url"
:href="network.url"
target="_blank"
rel="noopener noreferrer"
class="title"
>
<object
:data="`/img/logos/${network.slug}/network.png`"
type="image/png"
class="logo"
><h2>{{ network.name }}</h2></object>
<Icon
icon="new-tab"
class="icon-href"
/>
</a>
<p class="description">{{ network.description }}</p>
</div>
<h3 class="heading">Sites</h3>
<ul class="nolist sites">
<li
v-for="site in network.sites"
v-for="site in sites"
:key="`site-${site.id}`"
>
<SiteTile :site="site" />
@@ -71,6 +60,8 @@ async function mounted() {
[this.network] = await this.$store.dispatch('fetchNetworks', this.$route.params.networkSlug);
this.releases = await this.$store.dispatch('fetchNetworkReleases', this.$route.params.networkSlug);
this.sites = this.network.sites.sort(({ name: nameA }, { name: nameB }) => nameA.localeCompare(nameB));
this.pageTitle = this.network.name;
}
@@ -82,6 +73,7 @@ export default {
data() {
return {
network: null,
sites: null,
releases: null,
pageTitle: null,
};
@@ -95,31 +87,42 @@ export default {
.header {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
padding: 1rem;
align-items: top;
margin: 0 0 2rem 0;
}
.title {
display: inline-block;
margin: 0 .5rem 0 0;
}
display: inline-flex;
align-items: top;
margin: 0 1rem 0 0;
.heading {
padding: 0;
margin: 0 0 1rem 0;
&:hover .icon {
fill: $primary;
}
}
.logo {
height: 3rem;
width: 20rem;
max-height: 8rem;
object-fit: contain;
margin: 0 .5rem 0 0;
}
.sites {
display: grid;
grid-gap: 1rem;
margin: 0 0 1rem 0;
margin: 0 0 2rem 0;
}
.sites {
grid-template-columns: repeat(auto-fit, 15rem);
}
@media(max-width: $breakpoint) {
.sites {
grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
}
}
</style>

View File

@@ -3,62 +3,48 @@
v-if="site"
class="content site"
>
<div class="header">
<span class="intro">
<h2 class="title">
{{ site.name }}
<a
v-if="site.url"
:href="site.url"
target="_blank"
rel="noopener noreferrer"
>
<Icon
icon="new-tab"
class="icon-href"
/>
</a>
</h2>
<span class="description">{{ site.description }}</span>
</span>
<span class="link">
<div class="content-inner">
<div class="header">
<a
v-if="site.url"
:href="site.url"
target="_blank"
rel="noopener noreferrer"
class="logo-link"
class="title"
>
<object
:data="`/img/logos/${site.network.slug}/${site.slug}.png`"
:title="site.name"
type="image/png"
class="logo"
>{{ site.name }}</object>
><h2>{{ site.name }}</h2></object>
<Icon
icon="new-tab"
class="icon-href"
/>
</a>
<span class="networklogo-container">
Part of
<a
:href="site.network.url"
target="_blank"
rel="noopener noreferrer"
class="networklogo-link"
>
<object
:data="`/img/logos/${site.network.slug}/network.png`"
:title="site.network.name"
type="image/png"
class="networklogo"
>{{ site.network.name }}</object>
</a>
<span class="link">
<span class="networklogo-container">
Part of
<a
:href="`/network/${site.network.slug}`"
class="networklogo-link"
>
<object
:data="`/img/logos/${site.network.slug}/network.png`"
:title="site.network.name"
type="image/png"
class="networklogo"
>{{ site.network.name }}</object>
</a>
</span>
</span>
</span>
</div>
</div>
<p class="description">{{ site.description }}</p>
<div class="content-inner">
<h3 class="heading">Latest releases</h3>
<ul class="nolist scenes">
@@ -103,13 +89,18 @@ export default {
.header {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
padding: 1rem;
}
.title {
display: inline-block;
margin: 0 .5rem 0 0;
display: inline-flex;
align-items: top;
margin: 0 1rem 0 0;
&:hover .icon {
fill: $primary;
}
}
.heading {
@@ -125,19 +116,25 @@ export default {
}
.logo {
height: 3rem;
width: 15rem;
max-height: 8rem;
object-fit: contain;
margin: 0 .5rem 1rem 0;
}
.networklogo-container {
color: $shadow;
display: block;
margin: .5rem 0 0 0;
display: flex;
align-items: center;
}
.networklogo {
color: $text;
height: 1rem;
width: 15rem;
max-height: 6rem;
font-weight: bold;
object-fit: contain;
object-position: 100% 0;
margin: 0 0 0 .5rem;
}
.sites,

View File

@@ -4,7 +4,7 @@
<span class="details">
<a
:href="`/site/${release.site.slug}`"
:title="release.network.name"
:title="`Part of ${release.network.name}`"
class="site site-link"
>{{ release.site.name }}</a>

View File

@@ -1,6 +1,7 @@
<template>
<a
:href="`/site/${site.slug}`"
:title="site.name"
class="tile"
>
<object
@@ -42,12 +43,12 @@ export default {
}
.logo {
color: $text;
width: 100%;
height: 5rem;
color: $text;
display: flex;
align-items: center;
justify-content: center;
height: 3rem;
object-fit: contain;
font-size: 1rem;
font-weight: bold;