Nuxt Content 3 migration #12

Merged
eggy merged 81 commits from js into master 2022-08-10 18:38:39 -04:00
7 changed files with 67 additions and 36 deletions
Showing only changes of commit 070b0383c9 - Show all commits

View File

@ -12,18 +12,19 @@ const docs = await queryContent<BlogParsedContent>("/blog")
.where({ _draft: false }) .where({ _draft: false })
.find(); .find();
const latest = docs.at(-1); const latest = docs.at(-1) as BlogParsedContent;
const latestDate = dayjs(latest.date).utc(); const latestDate = dayjs(latest.date).utc();
const prettyDate = latestDate.format("DD MMM YYYY"); const prettyDate = latestDate.format("DD MMM YYYY");
</script> </script>
<template> <template>
<div class="prose dark:prose-invert"> <div class="prose dark:prose-invert flex">
<HomeStatBox <HomeStatBox
:href="latest._path" :href="latest._path"
color="lightblue" color="lightblue"
title="Latest blog post" title="Latest blog post"
:clearstyles="false"
> >
<h2 class="m-0 mt-4 mb-1">{{ latest.title }}</h2> <h2 class="m-0 mt-4 mb-1">{{ latest.title }}</h2>
<p class="text-sm text-gray-500 m-0"> <p class="text-sm text-gray-500 m-0">

View File

@ -2,25 +2,21 @@
import dayjs from "dayjs"; import dayjs from "dayjs";
import utc from "dayjs/plugin/utc.js"; import utc from "dayjs/plugin/utc.js";
import tz from "dayjs/plugin/timezone.js"; import tz from "dayjs/plugin/timezone.js";
import type { GithubPushEvent } from "@/shared/github"; import type { GithubCommit, GithubPushEvent } from "@/shared/github";
import type { Ref } from "vue"; import type { Ref } from "vue";
const FEED_URL = "https://api.github.com/users/potatoeggy/events"; const FEED_URL = "https://api.github.com/users/potatoeggy/events";
const results = (await useFetch(FEED_URL)).data as Ref<GithubPushEvent[]>; const results = (await useFetch(FEED_URL)).data as Ref<GithubPushEvent[]>;
const imgUrl = ref(""); const latestEvent = results.value.find(
const href = ref(""); (event) => event.type === "PushEvent"
for (const r of results.value) { ) as GithubPushEvent;
if (r.type === "PushEvent") { const latestCommit = latestEvent.payload.commits[0];
{ const imgUrl = `https://opengraph.githubassets.com/hash/${latestEvent.repo.name}/commit/${latestCommit.sha}`;
const latest = r.payload.commits[0]; const href = `https://github.com/${latestEvent.repo.name}/commit/${latestCommit.sha}`;
imgUrl.value = `https://opengraph.githubassets.com/hash/${r.repo.name}/commit/${latest.sha}`;
href.value = `https://github.com/${r.repo.name}/commit/${latest.sha}`; const [title, description] = latestCommit.message.split("\n\n");
}
break;
}
}
</script> </script>
<template> <template>
@ -31,7 +27,13 @@ for (const r of results.value) {
title="Latest commit" title="Latest commit"
:clearstyles="true" :clearstyles="true"
> >
<img class="m-0 w-full h-full" :src="imgUrl" v-if="imgUrl !== ''" /> <img class="m-0 w-full h-full" :src="imgUrl" />
<!--
<div>
<h2>{{ title }}</h2>
<p v-if="description">{{ description }}</p>
</div>
-->
</HomeStatBox> </HomeStatBox>
</div> </div>
</template> </template>

View File

@ -1,23 +1,30 @@
<script setup lang="ts"> <script setup lang="ts">
import type { Color } from "csstype"; import type { Color, ViewportLength } from "csstype";
// fix ReferenceError: _unref is not defined
// https://github.com/nuxt/framework/issues/5546
import { unref as _unref } from "vue";
const { const {
href, href,
color = "pink", color = "pink",
title, title,
clearstyles = false, clearstyles = false,
forceheight,
} = defineProps<{ } = defineProps<{
href?: string; href?: string;
color?: Color; color?: Color;
title?: string; title?: string;
clearstyles?: boolean; clearstyles?: boolean;
forceheight?: ViewportLength<"rem">;
}>(); }>();
const padding = clearstyles ? "0" : "1rem"; const padding = clearstyles ? "0" : "1rem";
const height = forceheight ?? "auto";
</script> </script>
<template> <template>
<a class="no-underline" :href="href"> <a class="no-underline inline-block flex" :href="href">
<div class="container box"> <div class="container box">
<p class="m-0 w-full title">{{ title }}</p> <p class="m-0 w-full title">{{ title }}</p>
<div class="main-content"> <div class="main-content">
@ -34,7 +41,7 @@ const padding = clearstyles ? "0" : "1rem";
* mobile * mobile
*/ */
width: 28rem; width: 28rem;
height: 16.25rem; height: v-bind(height);
border: 0.5rem solid v-bind(color); border: 0.5rem solid v-bind(color);
border-radius: 0.5rem; border-radius: 0.5rem;
} }

View File

@ -2,24 +2,24 @@
import dayjs from "dayjs"; import dayjs from "dayjs";
import utc from "dayjs/plugin/utc.js"; import utc from "dayjs/plugin/utc.js";
import tz from "dayjs/plugin/timezone.js"; import tz from "dayjs/plugin/timezone.js";
import type { BlogParsedContent } from "@/shared/types"; import type { BlogParsedContent, StoryParsedContent } from "@/shared/types";
dayjs.extend(utc); dayjs.extend(utc);
dayjs.extend(tz); dayjs.extend(tz);
const docs = await queryContent<BlogParsedContent>("/stories") const docs = await queryContent<StoryParsedContent>("/stories")
.sort({ date: 1 }) .sort({ date: 1 })
.where({ _draft: false }) .where({ _draft: false })
.find(); .find();
const latest = docs.at(-1); const latest = docs.at(-1) as StoryParsedContent;
const latestDate = dayjs(latest.date).utc(); const latestDate = dayjs(latest.date).utc();
const prettyDate = latestDate.format("DD MMM YYYY"); const prettyDate = latestDate.format("DD MMM YYYY");
</script> </script>
<template> <template>
<div class="prose dark:prose-invert"> <div class="prose dark:prose-invert flex">
<HomeStatBox :href="latest._path" color="lightgreen" title="Latest story"> <HomeStatBox :href="latest._path" color="lightgreen" title="Latest story">
<h2 class="m-0 mt-4 mb-1">{{ latest.title }}</h2> <h2 class="m-0 mt-4 mb-1">{{ latest.title }}</h2>
<p class="text-sm text-gray-500 m-0"> <p class="text-sm text-gray-500 m-0">

View File

@ -44,4 +44,6 @@ export default defineNuxtConfig({
experimental: { experimental: {
reactivityTransform: true, reactivityTransform: true,
}, },
target: "static",
ssr: true,
}); });

View File

@ -1,21 +1,40 @@
<script setup lang="ts"></script> <script setup lang="ts">
import type { BlogParsedContent, StoryParsedContent } from "@/shared/types";
import dayjs from "dayjs";
import utc from "dayjs/plugin/utc.js";
import tz from "dayjs/plugin/timezone.js";
dayjs.extend(utc);
dayjs.extend(tz);
type GeneralParsedContent = BlogParsedContent | StoryParsedContent;
const route = useRoute();
// we're not using ContentDoc because i need control
const doc = await queryContent<GeneralParsedContent>(route.path).findOne();
</script>
<template> <template>
<ContentDoc tag="article" class="prose dark:prose-invert"> <div class="container prose dark:prose-invert w-full">
<template #not-found> <h1>{{ doc.title }}</h1>
<!-- 404 --> <ContentRenderer tag="article" :value="doc" class="pt-0 w-full">
<main class="prose dark:prose-invert h-full"> <ContentRendererMarkdown :value="doc" />
<template #empty>
<p>No description found.</p>
</template>
<template #not-found>
<h1>404 - Not Found</h1> <h1>404 - Not Found</h1>
<p>Maybe you can find somewhere else?</p> </template>
</main> </ContentRenderer>
</template> </div>
</ContentDoc>
</template> </template>
<style> <style scoped>
article { .container {
width: 80%; width: 80%;
height: 100%; max-width: 72ch;
padding-top: 2rem; padding-top: 2rem;
} }

View File

@ -9,7 +9,7 @@ useTitle("Home");
<main class="flex flex-col items-center justify-around gap-8"> <main class="flex flex-col items-center justify-around gap-8">
<h1>Welcome!</h1> <h1>Welcome!</h1>
<p>What are you here to see?</p> <p>What are you here to see?</p>
<div class="flex justify-around items-center w-full flex-wrap gap-y-10"> <div class="flex justify-around items-stretch w-full flex-wrap gap-y-10">
<BlogStatBox /> <BlogStatBox />
<StoryStatBox /> <StoryStatBox />
<CommitStatBox /> <CommitStatBox />