Files
blog/sass/_article-list.scss

332 lines
8.1 KiB
SCSS

#article-list {
display: flex;
flex-direction: column;
gap: 1rem;
margin-block-start: 2rem;
article {
position: relative;
transition: var(--transition-longer);
outline-color: transparent;
outline-style: dashed;
outline-width: 0.125rem;
box-shadow: var(--edge-highlight);
border-radius: var(--rounded-corner);
border-start-end-radius: 2.125rem;
border-end-end-radius: 1.8125rem;
background-color: var(--primary-color-alpha);
padding: 1rem;
overflow: hidden;
&:hover {
outline-color: var(--primary-color);
outline-offset: 0.5rem;
}
.heading {
display: flex;
justify-content: space-between;
}
h3 {
margin: 0;
}
.tags a {
background-color: var(--primary-color-alpha);
color: var(--primary-color);
&:hover {
background-color: var(--primary-color);
color: var(--contrast-color);
}
}
&.draft {
--icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M12.277.832c-.578.008-1.168.23-1.691.754l-9 9A2 2 0 0 0 1 12v3h3c.531 0 1.04-.21 1.414-.586l9-9c1.79-1.789.082-4.39-1.89-4.57-.083-.012-.165-.012-.247-.012M10.5 4.437 11.563 5.5 4.5 12.563 3.438 11.5zm0 0'/%3E%3C/svg%3E");
background-color: var(--fg-muted-1);
&::before {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--fg-muted-1);
}
&:hover {
outline-color: var(--fg-muted-4);
&::before {
transform: translateY(-50%) rotate(-10deg) scale(1.5);
}
}
h3 a {
color: var(--fg-muted-4);
}
.tags a {
background-color: var(--fg-muted-1);
color: var(--fg-muted-4);
&:hover {
background-color: var(--fg-muted-4);
color: var(--fg-contrast);
}
}
}
&.archive {
// --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M4 1a1 1 0 0 0-.926.625l-2 5A1 1 0 0 0 1 7v7s0 2 2 2h10s2 0 2-2l.004-6.937c0-.149-.004-.297-.074-.438l-2-5A1 1 0 0 0 12 1zm.676 2h6.644l1.203 3h-9.05zM7 8h2v3h2a1 1 0 0 1-.293.707l-2 2a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1-.285-.7L5 11h2zm0 0'/%3E%3C/svg%3E");
--icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M2 1C.89 1 0 1.89 0 3v2c0 .751.41 1.402 1.018 1.744A2 2 0 0 0 1 7v7c0 1.11.89 2 2 2h10c1.11 0 2-.89 2-2V7a2 2 0 0 0-.018-.256A2 2 0 0 0 16 5V3c0-1.11-.89-2-2-2zm0 2h12v2H2zm1 4h10v7H3zm3 1v1h4V8z'/%3E%3C/svg%3E");
background-color: var(--purple-bg);
&::before {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--purple-bg);
}
&:hover {
outline-color: var(--purple-fg);
&::before {
transform: translateY(-50%) rotate(-10deg) scale(1.5);
}
}
h3 a {
color: var(--purple-fg);
}
.tags a {
background-color: var(--purple-bg);
color: var(--purple-fg);
&:hover {
background-color: var(--purple-fg);
color: var(--fg-contrast);
}
}
}
&.featured {
--icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M8 0a1 1 0 0 0-.95.684l-1.448 4.34-4.59-.016C.032 5.004-.371 6.266.43 6.828l3.625 2.555-1.5 4.285c-.317.902.687 1.691 1.492 1.172l4.004-2.594 3.894 2.586c.801.531 1.817-.258 1.5-1.16l-1.504-4.29 3.645-2.577c.789-.563.394-1.809-.574-1.813l-4.66-.015L8.949.69A1 1 0 0 0 8 0m0 0'/%3E%3C/svg%3E");
background-color: var(--yellow-bg);
&::before {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--yellow-bg);
}
&:hover {
outline-color: var(--yellow-fg);
&::before {
transform: translateY(-50%) rotate(62deg) scale(1.5);
}
}
h3 a {
color: var(--yellow-fg);
}
.tags a {
background-color: var(--yellow-bg);
color: var(--yellow-fg);
&:hover {
background-color: var(--yellow-fg);
color: var(--fg-contrast);
}
}
}
&.hot {
--icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M9.184.973C4.957 3.113 5.586 6.273 7 9 5.762 7.36 5.016 5.48 5 4 3.375 5 2 7 2 9a6.005 6.005 0 0 0 3.969 5.648c-.492-.84-.367-1.96.703-3.015 2.14-2.11 1.558-2.735 1.558-2.735 2.266 1.149-.32 3.137.418 3.88.563.558 1.758-1.391 1.77-2.184.848.96 1.246 1.676 1.246 2.75q0 .273-.035.52c2.512-1.805 3.273-5.41.46-8.184C8.095 1.742 9.185.973 9.185.973m0 0'/%3E%3C/svg%3E");
// --icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M9.184.973C4.957 3.113 5.586 6.273 7 9 5.762 7.36 5.016 5.48 5 4 3.375 5 2 7 2 9c0 3.313 2.688 6 6 6 5 0 8-5.465 4.09-9.32C8.094 1.742 9.184.973 9.184.973m0 0'/%3E%3C/svg%3E");
background-color: var(--red-bg);
&::before {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--red-bg);
}
&:hover {
outline-color: var(--red-fg);
&::before {
transform: translateY(-50%) rotate(-10deg) scale(1.5);
}
}
h3 a {
color: var(--red-fg);
}
.tags a {
background-color: var(--red-bg);
color: var(--red-fg);
&:hover {
background-color: var(--red-fg);
color: var(--fg-contrast);
}
}
}
&.poor {
--icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16'%3E%3Cpath d='M8.963 1.514A4 4 0 0 1 5 5H4c-1.108 0-2 .892-2 2s.892 2 2 2H3c-1.662 0-3 1.338-3 3s1.338 3 3 3h10c1.662 0 3-1.338 3-3s-1.338-3-3-3h-1c1.108 0 2-.892 2-2s-.892-2-2-2h-1a4 4 0 0 0-2.037-3.486'/%3E%3C/svg%3E");
background-color: var(--brown-bg);
&::before {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--brown-bg);
}
&:hover {
outline-color: var(--brown-fg);
&::before {
transform: translateY(-50%) rotate(-10deg) scale(1.5);
}
}
h3 a {
color: var(--brown-fg);
}
.tags a {
background-color: var(--brown-bg);
color: var(--brown-fg);
&:hover {
background-color: var(--brown-fg);
color: var(--fg-contrast);
}
}
}
&.draft,
&.archive,
&.featured,
&.hot,
&.poor {
&::before {
-webkit-mask-size: cover;
position: absolute;
top: 50%;
right: -3rem;
transform: translateY(-50%);
opacity: 0.5;
z-index: -1;
mask-size: cover;
transition: var(--transition-longer);
width: 12rem;
height: 12rem;
content: "";
:root[dir*="rtl"] & {
right: unset;
left: -3rem;
}
}
:root[dir*="rtl"] &:hover::before {
transform: translateY(-50%) rotate(-62deg) scale(1.5);
}
}
.draft-badge,
.archive-badge,
.featured-badge,
.hot-badge,
.poor-badge {
display: block;
box-shadow: var(--edge-highlight);
border-radius: 999px;
padding: 0.5rem 0.75rem;
height: fit-content;
font-weight: bold;
line-height: 1.25;
white-space: nowrap;
.icon {
vertical-align: -0.125em;
margin-inline-end: 0.25rem;
width: 1rem;
height: 1rem;
}
:root[dir*="rtl"] & {
right: unset;
left: 0;
}
}
.draft-badge {
background-color: var(--fg-muted-1);
color: var(--fg-muted-4);
.icon {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--fg-muted-4);
}
}
.archive-badge {
background-color: var(--purple-bg);
color: var(--purple-fg);
.icon {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--purple-fg);
}
}
.featured-badge {
background-color: var(--yellow-bg);
color: var(--yellow-fg);
.icon {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--yellow-fg);
}
}
.hot-badge {
background-color: var(--red-bg);
color: var(--red-fg);
.icon {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--red-fg);
}
}
.poor-badge {
background-color: var(--brown-bg);
color: var(--brown-fg);
.icon {
-webkit-mask-image: var(--icon);
mask-image: var(--icon);
background-color: var(--brown-fg);
}
}
.details {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
gap: 0.25rem;
}
}
}