chore: use reactive props

This commit is contained in:
Daniel Chen 2024-10-16 13:25:13 -04:00
parent 5fd2150beb
commit 6bf5d77a01
8 changed files with 41 additions and 43 deletions

View File

@ -2,10 +2,10 @@
import { getPrettyDate, getUtcDate } from "~~/shared/metadata"; import { getPrettyDate, getUtcDate } from "~~/shared/metadata";
import type { AnyParsedContent } from "~~/shared/types"; import type { AnyParsedContent } from "~~/shared/types";
const props = defineProps<{ doc: AnyParsedContent }>(); const { doc } = defineProps<{ doc: AnyParsedContent }>();
const prettyDate = getPrettyDate(props.doc); const prettyDate = getPrettyDate(doc);
const utcDate = getUtcDate(props.doc); const utcDate = getUtcDate(doc);
</script> </script>
<template> <template>

View File

@ -1,8 +1,12 @@
<script setup lang="ts"> <script setup lang="ts">
import type { Color, ViewportLength } from "csstype"; import type { Color, ViewportLength } from "csstype";
const props = withDefaults( const {
defineProps<{ color = "pink",
darkcolor = "#c88994",
clearstyles = false,
...props
} = defineProps<{
href?: string; href?: string;
id?: string; id?: string;
color?: Color; color?: Color;
@ -10,11 +14,9 @@ const props = withDefaults(
title?: string; title?: string;
clearstyles?: boolean; clearstyles?: boolean;
forceheight?: ViewportLength<"rem">; forceheight?: ViewportLength<"rem">;
}>(), }>();
{ color: "pink", darkcolor: "#c88994", clearstyles: false }
);
const padding = props.clearstyles ? "0" : "1rem"; const padding = clearstyles ? "0" : "1rem";
const height = props.forceheight ?? "100%"; const height = props.forceheight ?? "100%";
// v-bind DOES NOT WORK on initial render // v-bind DOES NOT WORK on initial render
@ -23,8 +25,8 @@ const height = props.forceheight ?? "100%";
const cssVars = { const cssVars = {
"--padding": padding, "--padding": padding,
"--height": height, "--height": height,
"--color": props.color, "--color": color,
"--darkcolor": props.darkcolor, "--darkcolor": darkcolor,
}; };
</script> </script>

View File

@ -1,8 +1,6 @@
<script setup lang="ts"> <script setup lang="ts">
import ColourPicker from "./ColourPicker.vue"; import ColourPicker from "./ColourPicker.vue";
import { navItems } from "@/data/navItems"; import { navItems } from "@/data/navItems";
const props = defineProps<{ activeItem?: string }>();
</script> </script>
<template> <template>
@ -85,9 +83,15 @@ li.home-text {
* { * {
--trans: 0.2s ease; --trans: 0.2s ease;
--box-trans-time: 0.4s; --box-trans-time: 0.4s;
transition: opacity var(--trans), transform var(--trans), gap var(--trans), transition:
width var(--trans), box-shadow var(--box-trans-time) ease, opacity var(--trans),
filter var(--trans), padding-left var(--trans), padding-right var(--trans); transform var(--trans),
gap var(--trans),
width var(--trans),
box-shadow var(--box-trans-time) ease,
filter var(--trans),
padding-left var(--trans),
padding-right var(--trans);
} }
@media screen and (max-width: 600px) { @media screen and (max-width: 600px) {

View File

@ -4,15 +4,15 @@ import { calcReadingTime } from "@/shared/metadata";
import { SpecialTags } from "@/data/specialTags"; import { SpecialTags } from "@/data/specialTags";
import IconStar from "@/assets/images/star.svg?component"; import IconStar from "@/assets/images/star.svg?component";
const props = defineProps<{ const { post, type } = defineProps<{
post: AnyParsedContent; post: AnyParsedContent;
type: "stories" | "blog"; type: "stories" | "blog";
highlighttags?: string[]; highlighttags?: string[];
}>(); }>();
const readingTime = calcReadingTime(props.post); const readingTime = calcReadingTime(post);
const descText = const descText =
props.type === "stories" type === "stories"
? `${readingTime.words.total} words` ? `${readingTime.words.total} words`
: `${readingTime.minutes} min read`; : `${readingTime.minutes} min read`;
</script> </script>
@ -22,10 +22,7 @@ const descText =
class="break-words max-w-full rounded-lg p-4 shadow-md border border-2 border-gray-300 dark:border-gray-600" class="break-words max-w-full rounded-lg p-4 shadow-md border border-2 border-gray-300 dark:border-gray-600"
> >
<h3 class="m-0 flex items-center gap-1.5"> <h3 class="m-0 flex items-center gap-1.5">
<a <a :href="`/tags/${type}/featured`" v-if="post.tags.includes('featured')">
:href="`/tags/${props.type}/featured`"
v-if="post.tags.includes('featured')"
>
<IconStar class="fill-yellow-500 outline-none" /> <IconStar class="fill-yellow-500 outline-none" />
</a> </a>
<a <a

View File

@ -1,14 +1,12 @@
<script setup lang="ts"> <script setup lang="ts">
import type { Project } from "@/data/projects"; import type { Project } from "@/data/projects";
import { unref as _unref } from "vue"; import { unref as _unref } from "vue";
const props = defineProps<{ const { project } = defineProps<{
project: Project; project: Project;
reverse?: boolean; reverse?: boolean;
}>(); }>();
const imgUrl = props.project.img const imgUrl = project.img ? `url(/images/projects/${project.img})` : "none";
? `url(/images/projects/${props.project.img})`
: "none";
</script> </script>
<template> <template>

View File

@ -1,5 +1,5 @@
<script setup lang="ts"> <script setup lang="ts">
const props = defineProps<{ const { img } = defineProps<{
name: string; name: string;
href: string; href: string;
img: string; img: string;
@ -7,7 +7,7 @@ const props = defineProps<{
broken?: boolean; broken?: boolean;
}>(); }>();
const imgUrl = `/images/services/${props.img}`; const imgUrl = `/images/services/${img}`;
</script> </script>
<template> <template>
@ -17,7 +17,7 @@ const imgUrl = `/images/services/${props.img}`;
> >
<div class="card flex flex-col items-center justify-around"> <div class="card flex flex-col items-center justify-around">
<img class="m-0" :src="imgUrl" :alt="`${name} logo`" /> <img class="m-0" :src="imgUrl" :alt="`${name} logo`" />
<h3 class="m-0">{{ props.name }}</h3> <h3 class="m-0">{{ name }}</h3>
<p class="desc-text text-gray-600 dark:text-gray-200"><slot /></p> <p class="desc-text text-gray-600 dark:text-gray-200"><slot /></p>
</div> </div>
</a> </a>

View File

@ -1,5 +1,5 @@
<script setup lang="ts"> <script setup lang="ts">
const props = defineProps<{ const { highlight } = defineProps<{
name: string; name: string;
dest: string; dest: string;
highlight?: boolean; highlight?: boolean;
@ -9,7 +9,7 @@ const props = defineProps<{
const isLinkableTag = true; const isLinkableTag = true;
const tagClass = [ const tagClass = [
"inline-block text-xs rounded-lg py-1 px-2 mt-1 mr-1 transition border border-pink-200 dark:border-pink-900 border-2 font-medium no-underline", "inline-block text-xs rounded-lg py-1 px-2 mt-1 mr-1 transition border border-pink-200 dark:border-pink-900 border-2 font-medium no-underline",
{ "bg-pink-200 dark:bg-pink-900": props.highlight }, { "bg-pink-200 dark:bg-pink-900": highlight },
{ "shadow-md": isLinkableTag }, { "shadow-md": isLinkableTag },
]; ];
</script> </script>

View File

@ -1,9 +1,6 @@
<script setup lang="ts"> <script setup lang="ts">
const props = withDefaults(defineProps<{ src: string; alt?: string }>(), { const { src, alt = "" } = defineProps<{ src: string; alt?: string }>();
alt: "",
});
const src = props.src;
const imgSrc = const imgSrc =
src.startsWith("http://") || src.startsWith("https://") src.startsWith("http://") || src.startsWith("https://")
? src ? src