public/components/HomeStatBox.vue

88 lines
1.7 KiB
Vue
Raw Normal View History

<script setup lang="ts">
2022-08-09 15:37:32 -04:00
import type { Color, ViewportLength } from "csstype";
2024-10-16 13:25:13 -04:00
const {
color = "pink",
darkcolor = "#c88994",
clearstyles = false,
...props
} = defineProps<{
href?: string;
id?: string;
color?: Color;
darkcolor?: Color;
title?: string;
clearstyles?: boolean;
forceheight?: ViewportLength<"rem">;
}>();
2024-10-16 13:25:13 -04:00
const padding = clearstyles ? "0" : "1rem";
const height = props.forceheight ?? "100%";
2022-08-10 10:56:49 -04:00
// v-bind DOES NOT WORK on initial render
// so unfortunately we have to use the old way
const cssVars = {
"--padding": padding,
"--height": height,
2024-10-16 13:25:13 -04:00
"--color": color,
"--darkcolor": darkcolor,
2022-08-10 10:56:49 -04:00
};
</script>
2022-07-22 16:08:55 -04:00
2022-07-22 15:32:00 -04:00
<template>
2024-10-16 13:30:57 -04:00
<a class="no-underline inline-block flex flex-col items-stretch" :href :id>
2022-08-10 10:56:49 -04:00
<div class="container box" :style="cssVars">
<p class="m-0 w-full title">{{ title }}</p>
2022-08-08 18:41:29 -04:00
<div class="main-content">
<slot />
</div>
</div>
</a>
2022-07-22 15:32:00 -04:00
</template>
2022-07-22 16:08:55 -04:00
<style scoped>
.container {
/* make sure width is good for fullscreen 1080p,
* fullscreen 1080p at 1.25 scaling,
* mobile
*/
width: 28rem;
2022-08-10 10:56:49 -04:00
height: var(--height);
border: 0.5rem solid var(--color);
border-radius: 0.5rem;
2022-08-09 19:31:13 -04:00
transition: transform 0.2s ease;
box-shadow: 0 0.1rem 0.5rem 0 gray;
}
.container:hover,
.container:active {
transform: scale(1.05);
}
2022-08-09 16:25:23 -04:00
html.dark .container {
2022-08-10 11:12:36 -04:00
border: 0.5rem solid var(--darkcolor);
2022-08-09 19:31:13 -04:00
box-shadow: 0 0.1rem 0.5rem 0 black;
2022-08-09 16:25:23 -04:00
}
.main-content {
2022-08-10 10:56:49 -04:00
padding: var(--padding);
padding-top: 0;
2022-08-09 15:54:17 -04:00
overflow-wrap: break-word;
}
.title {
2022-08-10 10:56:49 -04:00
background: var(--color);
}
2022-08-09 16:25:23 -04:00
html.dark .title {
2022-08-10 11:12:36 -04:00
background: var(--darkcolor);
2022-08-09 16:25:23 -04:00
}
@media screen and (max-width: 600px) {
.container {
2022-08-09 16:00:55 -04:00
width: 90vw;
}
2022-07-22 16:08:55 -04:00
}
</style>