Import image from path

Update page title based on post/project title
Use more optimised Image element
leg
This commit is contained in:
Michał 2024-05-24 19:47:03 +01:00
parent 5c41d81288
commit 44a15873f4
9 changed files with 60 additions and 25 deletions

View file

@ -3,21 +3,24 @@ const { certificate } = Astro.props;
--- ---
<div class="certificate"> <div class="certificate">
<h3>{certificate.data.title}</h3> <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 256 256"><rect width="256" height="256" fill="none"/><path d="M168,157.94h0a44,44,0,1,1,56-67.88h0V56a8,8,0,0,0-8-8H40a8,8,0,0,0-8,8V184a8,8,0,0,0,8,8H168Z" opacity="0.2"/><line x1="72" y1="136" x2="120" y2="136" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="16"/><line x1="72" y1="104" x2="120" y2="104" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="16"/><circle cx="196" cy="124" r="44" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="16"/><path d="M168,192H40a8,8,0,0,1-8-8V56a8,8,0,0,1,8-8H216a8,8,0,0,1,8,8V90.06" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="16"/><polyline points="168 157.94 168 224 196 208 224 224 224 157.94" fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="16"/></svg>
<p>{certificate.data.achieved}</p> <div class="certificate-front">
<p>By: {certificate.data.provider}</p> <h3>{certificate.data.title}</h3>
<p>{certificate.data.achieved}</p>
<p>By: {certificate.data.provider}</p>
{certificate.data.skills && ( {certificate.data.skills && (
<ul class="pill-list"> <ul class="pill-list">
{certificate.data.skills.map(skill => ( {certificate.data.skills.map(skill => (
<li class="pill">{skill}</li> <li class="pill">{skill}</li>
))} ))}
</ul> </ul>
)} )}
{certificate.data.link && ( {certificate.data.link && (
<a href={certificate.data.link} class="button">View</a> <a href={certificate.data.link} class="button">View</a>
)} )}
</div>
</div> </div>
<style lang="scss"> <style lang="scss">
@ -28,6 +31,31 @@ const { certificate } = Astro.props;
height: 100%; height: 100%;
position: relative;
border-radius: $radius;
border: 2px solid $gray;
background-color: $dark;
color: $light;
overflow: hidden;
> svg {
width: 200px;
height: 200px;
position: absolute;
top: -37px;
left: -25px;
opacity: 0.03;
z-index: +1;
}
}
.certificate-front {
position: relative;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
justify-content: center; justify-content: center;
@ -37,10 +65,8 @@ const { certificate } = Astro.props;
text-decoration: none; text-decoration: none;
text-align: center; text-align: center;
border-radius: $radius; z-index: +2;
border: 2px solid $gray;
background-color: $dark;
color: $light;
> h3 { > h3 {
margin-bottom: 4px; margin-bottom: 4px;

View file

@ -1,8 +1,11 @@
--- ---
import { Image } from "astro:assets";
import leg from "../../public/leg.webp";
--- ---
<a class="button" id="music" href="https://www.last.fm/user/Fluffy_Bean_" target="_blank"> <a class="button" id="music" href="https://www.last.fm/user/Fluffy_Bean_" target="_blank">
<img src="/leg.webp" alt="Track cover art" id="music-image"/> <Image src={leg} width="64" height="64" loading="eager" alt="Track cover art" id="music-image" />
<ul> <ul>
<li id="music-title">Track Name</li> <li id="music-title">Track Name</li>
<li id="music-artist">by Artist</li> <li id="music-artist">by Artist</li>

View file

@ -1,6 +1,8 @@
--- ---
import "../styles/styles.scss"; import "../styles/styles.scss";
import { Image } from "astro:assets";
interface Props { interface Props {
title: string; title: string;
src?: string, src?: string,
@ -28,7 +30,7 @@ const { title, src, alt } = Astro.props;
<body> <body>
<div class="banner"> <div class="banner">
{src && ( {src && (
<img src={src} alt={alt} /> <Image src={src} width="1080" height="700" loading="eager" alt={alt} />
<script> <script>
const img = document.querySelector(".banner > img"); const img = document.querySelector(".banner > img");
document.addEventListener("scroll", () => { document.addEventListener("scroll", () => {

View file

@ -6,6 +6,7 @@ import Layout from "../layouts/Layout.astro";
import Card from "../components/Card.astro"; import Card from "../components/Card.astro";
import Certificate from "../components/Certificate.astro"; import Certificate from "../components/Certificate.astro";
import Music from "../components/Music.astro"; import Music from "../components/Music.astro";
import BannerImg from "../../public/banner-alt.webp";
const tools = ["Proxmox", "JetBrain IDEs", "Docker", "Linux", "SQLite", "Postgres", "MySQL"]; const tools = ["Proxmox", "JetBrain IDEs", "Docker", "Linux", "SQLite", "Postgres", "MySQL"];
const languages = ["Go", "Python", "HTML", "CSS", "Sass", "TypeScript", "JavaScript", "Scratch", "PHP", "SQL", "Bash"]; const languages = ["Go", "Python", "HTML", "CSS", "Sass", "TypeScript", "JavaScript", "Scratch", "PHP", "SQL", "Bash"];
@ -15,7 +16,7 @@ const projects = await getPosts("projects");
const posts = await getPosts("posts"); const posts = await getPosts("posts");
--- ---
<Layout title="Leggy Land" src="/banner-alt.webp" alt="Temporary Banner"> <Layout title="Leggy Land" src={BannerImg} alt="Temporary Banner">
<h1>Leggy Land</h1> <h1>Leggy Land</h1>
<p>Made with Coffee, lots of it.</p> <p>Made with Coffee, lots of it.</p>

View file

@ -1,8 +1,9 @@
--- ---
import Layout from "../layouts/Layout.astro"; import Layout from "../layouts/Layout.astro";
import BannerImg from "../../../public/banner-alt.webp";
--- ---
<Layout title="Leggy Land" src="/banner-alt.webp" alt="Temporary Banner"> <Layout title="LEG LEG LEG LEG LEG LEG LEG LEG LEG LEG LEG LEG LEG" src={BannerImg} alt="Temporary Banner">
<a class="button" href="/" id="home">Home</a> <a class="button" href="/" id="home">Home</a>
<h1>Maned Wolf Jumpscare</h1> <h1>Maned Wolf Jumpscare</h1>

View file

@ -19,6 +19,6 @@ export async function getStaticPaths() {
const { post, prev, next } = Astro.props; const { post, prev, next } = Astro.props;
--- ---
<Layout title="Leggy Land" src={post.data.image.url} alt={post.data.image.alt}> <Layout title=`Leggy Land - ${post.data.title}` src={post.data.image.url} alt={post.data.image.alt}>
<Markdown {post} {prev} {next} base="/posts" /> <Markdown {post} {prev} {next} base="/posts" />
</Layout> </Layout>

View file

@ -3,11 +3,12 @@ import { getCollection } from 'astro:content';
import Layout from "../../layouts/Layout.astro"; import Layout from "../../layouts/Layout.astro";
import Card from "../../components/Card.astro"; import Card from "../../components/Card.astro";
import BannerImg from "../../../public/banner-alt.webp";
const posts = await getCollection('posts'); const posts = await getCollection('posts');
--- ---
<Layout title="Leggy Land" src="/banner-alt.webp" alt="Temporary Banner"> <Layout title="Leggy Land - All Posts" src={BannerImg} alt="Temporary Banner">
<a class="button" id="home" href="/">Home</a> <a class="button" id="home" href="/">Home</a>
<h1>All Posts</h1> <h1>All Posts</h1>

View file

@ -19,6 +19,6 @@ export async function getStaticPaths() {
const { post, prev, next } = Astro.props; const { post, prev, next } = Astro.props;
--- ---
<Layout title="Leggy Land" src={post.data.image.url} alt={post.data.image.alt}> <Layout title=`Leggy Land - ${post.data.title}` src={post.data.image.url} alt={post.data.image.alt}>
<Markdown {post} {prev} {next} base="/projects" /> <Markdown {post} {prev} {next} base="/projects" />
</Layout> </Layout>

View file

@ -3,11 +3,12 @@ import { getCollection } from 'astro:content';
import Layout from "../../layouts/Layout.astro"; import Layout from "../../layouts/Layout.astro";
import Card from "../../components/Card.astro"; import Card from "../../components/Card.astro";
import BannerImg from "../../../public/banner-alt.webp";
const projects = await getCollection('projects'); const projects = await getCollection('projects');
--- ---
<Layout title="Leggy Land" src="/banner-alt.webp" alt="Temporary Banner"> <Layout title="Leggy Land - All Projects" src={BannerImg} alt="Temporary Banner">
<a class="button" id="home" href="/">Home</a> <a class="button" id="home" href="/">Home</a>
<h1>All Projects</h1> <h1>All Projects</h1>
<p>Come back next week for 4 new projects!</p> <p>Come back next week for 4 new projects!</p>