dashersupply/src/components/BrandCard.astro

77 lines
2.1 KiB
Plaintext

---
import type { Brand } from "../data/models/multis/Brand";
import { getAssetById } from "../data/api-client";
import path from "node:path";
import type { Multilingual, SquidexEditable } from "./SharedProperties";
interface Props extends Multilingual, SquidexEditable {
brand: Brand,
}
const { brand, editToken, locale } = Astro.props;
let brandLogoImage = path.posix.join('/img', (await getAssetById(brand.logoImage[locale]))
.links['content']
.href
//The purpose of .split('/').reverse().filter(...2...).reverse().join('/') is to
//extract the last two directories from the end of the path, which we will
//use to form the path to the ../pages/img/[...imageLookup].astro handler, e.g.,
//in the form of `/img/${uuid}/${fileName}.${ext}`.
.split('/')
.reverse()
.filter((_value, index, array) => index < (array.length - index - 2))
.reverse()
.join('/'));
---
<li class="brand-card" data-squidex-token={editToken}>
<a href={`/${brand.slug[locale]}/`}>
<img src={brandLogoImage} alt={brand.brandName[locale]} title={brand.brandName[locale]} />
</a>
</li>
<style>
.brand-card {
list-style: none;
display: flex;
padding: 1px;
background-color: #23262d;
background-image: none;
background-size: 400%;
border-radius: 7px;
background-position: 100%;
transition: background-position 0.6s cubic-bezier(0.22, 1, 0.36, 1);
box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
text-align: center;
max-width: 8em;
}
.brand-card > a {
width: 100%;
text-decoration: none;
line-height: 1.4;
padding: calc(0.5rem - 1px);
border-radius: 8px;
color: white;
background-color: #23262d;
opacity: 0.8;
}
.brand-card img {
max-width: 100%;
}
.brand-card h2 {
margin: 0;
font-size: 1.25rem;
transition: color 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.brand-card p {
margin-top: 0.5rem;
margin-bottom: 0;
}
.brand-card:is(:hover, :focus-within) {
background-position: 0;
background-image: var(--accent-gradient);
}
.brand-card:is(:hover, :focus-within) h2 {
color: rgb(var(--accent-light));
}
</style>