릴리스: v0.1.20 게임 카드 3열 레이아웃 정리

This commit is contained in:
2026-03-19 18:25:02 +09:00
parent d4ab4b2cd1
commit 2374cd9272
4 changed files with 45 additions and 19 deletions

View File

@@ -10,7 +10,7 @@ const auth = useAuthStore()
const items = ref([])
const error = ref('')
const games = computed(() => items.value)
const games = computed(() => items.value.filter((item) => item.id !== 'freeform'))
onMounted(async () => {
try {
@@ -50,13 +50,6 @@ function thumbUrl(g) {
<div v-if="error" class="error">{{ error }}</div>
<section class="grid">
<button class="card card--freeform" @click="goFreeform">
<div class="thumbWrap thumbWrap--freeform">
<div class="thumbFallback">+</div>
</div>
<div class="card__eyebrow">{{ auth.user ? '템플릿 없이 시작' : '로그인 후 작성 가능' }}</div>
<div class="card__title">직접 티어표 만들기</div>
</button>
<button v-for="g in games" :key="g.id" class="card" @click="goGame(g.id)">
<div class="thumbWrap">
<img v-if="thumbUrl(g)" class="thumb" :src="thumbUrl(g)" :alt="g.name" />
@@ -64,6 +57,13 @@ function thumbUrl(g) {
</div>
<div class="card__title">{{ g.name }}</div>
</button>
<button class="card card--freeform" @click="goFreeform">
<div class="thumbWrap thumbWrap--freeform">
<div class="thumbFallback">+</div>
</div>
<div class="card__eyebrow">{{ auth.user ? '템플릿 없이 시작' : '로그인 후 작성 가능' }}</div>
<div class="card__title">직접 티어표 만들기</div>
</button>
</section>
</template>
@@ -83,7 +83,7 @@ function thumbUrl(g) {
}
.grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 14px;
margin-top: 14px;
}
@@ -115,7 +115,7 @@ function thumbUrl(g) {
}
.thumbWrap {
width: 100%;
height: 140px;
aspect-ratio: 16 / 9;
border-radius: 14px;
border: 1px solid rgba(255, 255, 255, 0.12);
background: rgba(0, 0, 0, 0.18);
@@ -154,4 +154,9 @@ function thumbUrl(g) {
grid-template-columns: 1fr;
}
}
@media (min-width: 721px) and (max-width: 1100px) {
.grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
</style>