astro/examples/basics/src/components/Card.astro

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

62 lines
1.1 KiB
Text
Raw Normal View History

2022-05-04 00:08:15 +00:00
---
interface Props {
2022-05-04 00:08:15 +00:00
title: string;
body: string;
href: string;
}
const { href, title, body } = Astro.props;
2022-05-04 00:08:15 +00:00
---
2022-07-08 20:08:32 +00:00
2022-05-04 00:08:15 +00:00
<li class="link-card">
<a href={href}>
<h2>
2022-09-28 15:48:55 +00:00
{title}
<span>&rarr;</span>
2022-05-04 00:08:15 +00:00
</h2>
<p>
{body}
</p>
</a>
</li>
<style>
.link-card {
list-style: none;
display: flex;
padding: 1px;
2023-07-24 21:43:14 +00:00
background-color: #23262d;
background-image: none;
2022-05-04 00:08:15 +00:00
background-size: 400%;
border-radius: 7px;
2022-05-04 00:08:15 +00:00
background-position: 100%;
transition: background-position 0.6s cubic-bezier(0.22, 1, 0.36, 1);
2023-07-24 21:43:14 +00:00
box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
2022-05-04 00:08:15 +00:00
}
.link-card > a {
width: 100%;
text-decoration: none;
line-height: 1.4;
padding: calc(1.5rem - 1px);
border-radius: 8px;
color: white;
2023-07-24 21:43:14 +00:00
background-color: #23262d;
2022-05-04 00:08:15 +00:00
opacity: 0.8;
}
h2 {
margin: 0;
2022-09-28 15:47:19 +00:00
font-size: 1.25rem;
2022-05-04 00:08:15 +00:00
transition: color 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
p {
2022-09-28 15:47:19 +00:00
margin-top: 0.5rem;
2022-05-04 00:08:15 +00:00
margin-bottom: 0;
}
.link-card:is(:hover, :focus-within) {
background-position: 0;
background-image: var(--accent-gradient);
2022-05-04 00:08:15 +00:00
}
.link-card:is(:hover, :focus-within) h2 {
color: rgb(var(--accent-light));
2022-05-04 00:08:15 +00:00
}
</style>