Allow making posts "featured", tweak article list styles
This commit is contained in:
@ -1,34 +1,143 @@
|
||||
#article-list {
|
||||
margin-top: 2rem;
|
||||
|
||||
article {
|
||||
position: relative;
|
||||
|
||||
&.draft,
|
||||
&.archive,
|
||||
&.featured {
|
||||
position: relative;
|
||||
|
||||
h3 {
|
||||
margin-right: 8rem;
|
||||
|
||||
:root[dir="rtl"] & {
|
||||
margin-right: unset;
|
||||
margin-left: 8rem;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
&.draft {
|
||||
transform: scale(0.95);
|
||||
opacity: 0.6;
|
||||
transition: var(--transition-longer);
|
||||
outline: 0.125rem dashed var(--fg-muted-2);
|
||||
outline: 0.125rem dashed var(--fg-muted-4);
|
||||
outline-offset: 1rem;
|
||||
border-radius: 1rem;
|
||||
border-radius: var(--rounded-corner);
|
||||
border-top-right-radius: 1.125rem;
|
||||
|
||||
&:hover {
|
||||
transform: scale(1);
|
||||
opacity: 1;
|
||||
outline: 0.125rem dashed transparent;
|
||||
outline-offset: 0;
|
||||
}
|
||||
}
|
||||
|
||||
&:has(.draft-badge, .archive-badge) h3 {
|
||||
margin-right: 7rem;
|
||||
h3 a {
|
||||
color: var(--fg-muted-4);
|
||||
}
|
||||
|
||||
.tags a:hover {
|
||||
background-color: var(--fg-muted-1);
|
||||
color: var(--fg-muted-4);
|
||||
}
|
||||
|
||||
:root[dir="rtl"] & {
|
||||
margin-right: unset;
|
||||
margin-left: 7rem;
|
||||
border-top-right-radius: var(--rounded-corner);
|
||||
border-top-left-radius: 1.125rem;
|
||||
}
|
||||
}
|
||||
|
||||
&.archive {
|
||||
h3 a {
|
||||
color: var(--purple-fg);
|
||||
}
|
||||
|
||||
.tags a:hover {
|
||||
background-color: var(--purple-bg);
|
||||
color: var(--purple-fg);
|
||||
}
|
||||
}
|
||||
|
||||
&.featured {
|
||||
transition: var(--transition-longer);
|
||||
outline: 0.125rem dashed transparent;
|
||||
outline-offset: 0;
|
||||
box-shadow: var(--edge-highlight);
|
||||
border-radius: var(--rounded-corner);
|
||||
border-top-right-radius: 2.125rem;
|
||||
background-color: var(--faves-bg);
|
||||
padding: 1rem;
|
||||
overflow: hidden;
|
||||
|
||||
&::before {
|
||||
$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");
|
||||
-webkit-mask-image: $icon;
|
||||
-webkit-mask-size: cover;
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
right: -3rem;
|
||||
transform: translateY(-50%) rotate(-10deg);
|
||||
opacity: 0.5;
|
||||
z-index: -1;
|
||||
mask-image: $icon;
|
||||
mask-size: cover;
|
||||
transition: var(--transition-longer);
|
||||
background-color: var(--star-featured);
|
||||
width: 12rem;
|
||||
height: 12rem;
|
||||
content: "";
|
||||
|
||||
:root[dir="rtl"] & {
|
||||
right: unset;
|
||||
left: -3rem;
|
||||
transform: translateY(-50%) rotate(10deg);
|
||||
}
|
||||
}
|
||||
|
||||
&:hover {
|
||||
outline: 0.125rem dashed var(--faves-fg);
|
||||
outline-offset: 0.5rem;
|
||||
|
||||
&::before {
|
||||
transform: translateY(-50%) rotate(62deg) scale(1.5);
|
||||
}
|
||||
}
|
||||
|
||||
h3 {
|
||||
margin-top: unset;
|
||||
|
||||
a {
|
||||
color: var(--faves-fg);
|
||||
}
|
||||
}
|
||||
|
||||
.featured-badge {
|
||||
top: 1rem;
|
||||
right: 1rem;
|
||||
|
||||
:root[dir="rtl"] & {
|
||||
left: 1rem;
|
||||
}
|
||||
}
|
||||
|
||||
.tags a:hover {
|
||||
background-color: var(--faves-bg);
|
||||
color: var(--faves-fg);
|
||||
}
|
||||
|
||||
:root[dir="rtl"] & {
|
||||
border-top-right-radius: var(--rounded-corner);
|
||||
border-top-left-radius: 2.125rem;
|
||||
|
||||
&:hover::before {
|
||||
transform: translateY(-50%) rotate(-62deg) scale(1.5);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.draft-badge,
|
||||
.archive-badge {
|
||||
.archive-badge,
|
||||
.featured-badge {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
right: 0;
|
||||
@ -73,6 +182,18 @@
|
||||
background-color: var(--purple-fg);
|
||||
}
|
||||
}
|
||||
|
||||
.featured-badge {
|
||||
background-color: var(--faves-bg);
|
||||
color: var(--faves-fg);
|
||||
|
||||
.icon {
|
||||
$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");
|
||||
-webkit-mask-image: $icon;
|
||||
mask-image: $icon;
|
||||
background-color: var(--faves-fg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
hr:last-of-type {
|
||||
|
@ -6,7 +6,7 @@
|
||||
nav {
|
||||
margin: 0 auto 2rem;
|
||||
box-shadow: var(--edge-highlight);
|
||||
border-radius: 22px;
|
||||
border-radius: 1.375rem;
|
||||
background-color: var(--fg-muted-1);
|
||||
padding: 0.25rem;
|
||||
width: fit-content;
|
||||
|
4
sass/_last-updated.scss
Normal file
4
sass/_last-updated.scss
Normal file
@ -0,0 +1,4 @@
|
||||
.last-updated {
|
||||
display: block;
|
||||
margin-top: 1rem;
|
||||
}
|
@ -156,6 +156,7 @@
|
||||
&#dropdown {
|
||||
details {
|
||||
position: relative;
|
||||
box-shadow: unset;
|
||||
border-radius: unset;
|
||||
background-color: unset;
|
||||
padding: 0;
|
||||
|
@ -2,9 +2,19 @@
|
||||
display: inline-flex;
|
||||
flex-wrap: wrap;
|
||||
gap: 0.25rem;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
list-style: none;
|
||||
|
||||
&.inline {
|
||||
margin-left: 0.25rem;
|
||||
|
||||
:root[dir="rtl"] & {
|
||||
margin-right: 0.25rem;
|
||||
margin-left: unset;
|
||||
}
|
||||
}
|
||||
|
||||
li {
|
||||
display: flex;
|
||||
transition: var(--transition);
|
||||
|
@ -147,6 +147,7 @@ details {
|
||||
border-radius: var(--rounded-corner);
|
||||
background-color: var(--fg-muted-1);
|
||||
padding: 1rem;
|
||||
box-shadow: var(--edge-highlight);
|
||||
|
||||
&>summary {
|
||||
cursor: pointer;
|
||||
|
@ -18,6 +18,7 @@
|
||||
--boosts-fg: rgb(145, 65, 172);
|
||||
--faves-bg: rgba(229, 165, 10, 0.1);
|
||||
--faves-fg: rgb(229, 165, 10);
|
||||
--star-featured: rgba(229, 165, 10, 0.15);
|
||||
|
||||
// VARIABLES
|
||||
--active: 0.9;
|
||||
@ -70,6 +71,7 @@
|
||||
--boosts-fg: rgb(220, 138, 221);
|
||||
--faves-bg: rgba(249, 240, 107, 0.1);
|
||||
--faves-fg: rgb(249, 240, 107);
|
||||
--star-featured: rgba(249, 240, 107, 0.05);
|
||||
|
||||
color-scheme: dark;
|
||||
}
|
||||
|
@ -20,6 +20,7 @@
|
||||
@use "hidden";
|
||||
@use "icon";
|
||||
@use "input";
|
||||
@use "last-updated";
|
||||
@use "media";
|
||||
@use "nav";
|
||||
@use "not-found";
|
||||
|
Reference in New Issue
Block a user