🔧 웹훅 URL을 HTTPS로 수정
Some checks failed
🚀 Deploy - Demo / deployment (push) Has been cancelled

- 웹훅 URL을 https://admin.youtooplay.com/webhook로 변경
- Nginx 리버스 프록시 설정 파일 추가
- 배포 가이드 업데이트
This commit is contained in:
2025-10-01 01:47:51 +09:00
parent f331b52e64
commit 83b162d2bd
713 changed files with 98449 additions and 38378 deletions

View File

@@ -0,0 +1,48 @@
<script setup lang="ts">
interface Props {
title: string
color?: string
icon: string
stats: number
change: number
}
const props = withDefaults(defineProps<Props>(), {
color: 'primary',
})
const isPositive = controlledComputed(() => props.change, () => Math.sign(props.change) === 1)
</script>
<template>
<VCard>
<VCardText class="d-flex align-center">
<VAvatar
size="44"
rounded
:color="props.color"
variant="tonal"
class="me-4"
>
<VIcon
:icon="props.icon"
size="30"
/>
</VAvatar>
<div>
<span class="text-caption">{{ props.title }}</span>
<div class="d-flex align-center flex-wrap">
<span class="text-h6 font-weight-semibold">{{ kFormatter(props.stats) }}</span>
<div
v-if="props.change"
:class="`${isPositive ? 'text-success' : 'text-error'} mt-1`"
>
<VIcon :icon="isPositive ? 'bx-chevron-up' : 'bx-chevron-down'" />
<span class="text-caption font-weight-semibold">{{ Math.abs(props.change) }}%</span>
</div>
</div>
</div>
</VCardText>
</VCard>
</template>

View File

@@ -0,0 +1,56 @@
<script setup lang="ts">
interface Props {
title: string
image: string
stats: string
change: number
}
const props = defineProps<Props>()
const isPositive = controlledComputed(() => props.change, () => Math.sign(props.change) === 1)
const moreList = [
{ title: 'Yesterday', value: 'Yesterday' },
{ title: 'Last Week', value: 'Last Week' },
{ title: 'Last Month', value: 'Last Month' },
]
</script>
<template>
<VCard>
<VCardText class="d-flex align-center pb-4">
<img
width="42"
:src="props.image"
alt="image"
>
<VSpacer />
<MoreBtn
class="me-n3 mt-n4"
:menu-list="moreList"
/>
</VCardText>
<VCardText>
<p class="mb-1">
{{ props.title }}
</p>
<h5 class="text-h5 text-no-wrap mb-3">
{{ props.stats }}
</h5>
<span
:class="isPositive ? 'text-success' : 'text-error'"
class="d-flex align-center gap-1 text-sm"
>
<VIcon
size="18"
:icon="isPositive ? 'bx-up-arrow-alt' : 'bx-down-arrow-alt'"
/>
{{ isPositive ? Math.abs(props.change) : props.change }}%
</span>
</VCardText>
</VCard>
</template>

View File

@@ -0,0 +1,65 @@
<script setup lang="ts">
interface Props {
title: string
subtitle: string
stats: string
change: number
image: string
color?: string
}
const props = withDefaults(defineProps<Props>(), {
color: 'primary',
})
const isPositive = controlledComputed(() => props.change, () => Math.sign(props.change) === 1)
</script>
<template>
<VCard class="overflow-visible">
<div class="d-flex position-relative">
<VCardText>
<h6 class="text-base font-weight-semibold mb-4">
{{ props.title }}
</h6>
<div class="d-flex align-center flex-wrap mb-4">
<h5 class="text-h5 font-weight-semibold me-2">
{{ props.stats }}
</h5>
<span
class="text-caption"
:class="isPositive ? 'text-success' : 'text-error'"
>
{{ isPositive ? `+${props.change}` : props.change }}%
</span>
</div>
<VChip
v-if="props.subtitle"
size="small"
:color="props.color"
>
{{ props.subtitle }}
</VChip>
</VCardText>
<VSpacer />
<div class="illustrator-img">
<VImg
v-if="props.image"
:src="props.image"
:width="110"
/>
</div>
</div>
</VCard>
</template>
<style lang="scss">
.illustrator-img {
position: absolute;
inset-block-end: 0;
inset-inline-end: 5%;
}
</style>