Skip to content

Commit

Permalink
[Featrue] CSID-DGU#6 - 아코스탬프 팔로워, 팔로잉 목록 구현
Browse files Browse the repository at this point in the history
  • Loading branch information
Minn-Choi committed Oct 28, 2024
1 parent c607437 commit 2f8b129
Showing 1 changed file with 140 additions and 7 deletions.
147 changes: 140 additions & 7 deletions src/views/feed/AkoStampFollow.vue
Original file line number Diff line number Diff line change
@@ -1,15 +1,148 @@
<!-- AkoStampFollow.vue -->
<template>
<div>
<h1>Ako Stamp Follow</h1>
<!-- 추가적인 내용 -->
<div class="min-h-screen bg-[#FFF9F2] font-pretendard flex justify-center">
<div
class="w-[395px] min-w-[340px] bg-[#FAE8DA] min-h-screen relative overflow-y-auto"
>
<header
class="bg-white shadow-sm py-3 px-4 fixed top-0 left-1/2 transform -translate-x-1/2 w-[395px] min-w-[340px] z-10"
>
<div class="flex items-center justify-between">
<img src="@/assets/images/Akoming.svg" alt="로고" class="h-8" />
</div>
</header>

<main class="flex flex-col px-6 pt-20 pb-24">
<img
src="@/assets/images/back.svg"
alt="이전"
style="width: 24px; height: 24px; margin-top: 10px; margin-bottom: 20px; cursor: pointer;"
/>

<div class="bg-white rounded-2xl mb-4" style="height: 300px; display: flex; justify-content: center;">

<div class="follower font-NaL" style="width:50%; display: flex; flex-direction: column; align-items: center; margin-top:10px;">
<div @click="showFollowers = true; showFollowings = false" style="cursor: pointer;">
팔로워 {{ followerCount }}
</div>
<div class="followerline" :style="{ width: '100%', height: '2px', background: showFollowers ? '#FF7F00' : '#B3B3B3', marginBottom: '15px' }"></div>
<div style="width: 150%; margin-left: 90%; z-index:20;">
<ul v-show="showFollowers" style="padding: 20; width: 100%;">
<li v-for="follower in followers" :key="follower.followingId" class="flex justify-between items-center mb-4">
<span class='font-NaR'>{{ follower.nickname }}</span>
<button @click="blockFollower(follower.followingId)" class="followerDelete-btn">삭제</button>
</li>
</ul>
</div>
</div>

<div class="following font-NaL" style="width:50%; display: flex; flex-direction: column; align-items: center; margin-top:10px;">
<div @click="showFollowers = false; showFollowings = true" style="cursor: pointer;">
팔로잉 {{ followingCount }}
</div>
<div class="followingline" :style="{ width: '100%', height: '2px', background: showFollowings ? '#FF7F00' : '#B3B3B3', marginBottom: '15px' }"></div>
<div style="width: 100%;"></div>
<ul v-show="showFollowings" style="padding-right: 110%; width: 260%;">
<li v-for="following in followings" :key="following.followingId" class="flex justify-between items-center mb-4">
<span class='font-NaR'>{{ following.nickname }}</span>
<button @click="unfollow(following.followingId)" class="unfollow-button">팔로우 취소</button>
</li>
</ul>
</div>
</div>
</main>
<Footer />
</div>
</div>
</template>

<script setup>
// 필요한 JavaScript 코드
import { ref, onMounted } from 'vue';
import Footer from '@/components/layout/Footer.vue';
const followerCount = ref(0);
const followingCount = ref(0);
const followers = ref([]);
const followings = ref([]);
const showFollowers = ref(true); // 팔로워 리스트 보이기
const showFollowings = ref(false); // 팔로잉 리스트 보이기
// 팔로워 및 팔로잉 수 가져오기 (임시 데이터 사용)
function fetchFollowerCount() {
// 임시 팔로워 데이터
followers.value = [
{ followingId: 1, nickname: '미니', email: '[email protected]' },
{ followingId: 2, nickname: '토니', email: '[email protected]' },
{ followingId: 3, nickname: '서혀니', email: '[email protected]' },
];
followerCount.value = followers.value.length;
}
function fetchFollowingCount() {
// 임시 팔로잉 데이터
followings.value = [
{ followingId: 4, nickname: '동국이', email: '[email protected]' },
{ followingId: 5, nickname: '미니', email: '[email protected]' },
{ followingId: 6, nickname: '동동이', email: '[email protected]' },
];
followingCount.value = followings.value.length;
}
// 팔로워 차단
function blockFollower(id) {
const index = followers.value.findIndex(follower => follower.followingId === id);
if (index !== -1) {
followers.value.splice(index, 1);
followerCount.value--;
}
}
// 팔로우 취소
function unfollow(id) {
followings.value = followings.value.filter(following => following.followingId !== id);
followingCount.value--;
}
onMounted(() => {
fetchFollowerCount();
fetchFollowingCount();
});
</script>

<style>
/* 컴포넌트 스타일 */
<style scoped>
.unfollow-button {
font-size: 11px;
width: 62px;
height: 24px;
margin-left: 8px;
font-family: 'NaR';
border-radius: 20px;
color: white;
font-style: normal;
font-weight: 300;
line-height: normal;
background: #FF7F00;
cursor: pointer;
transition: background-color 0.3s;
}
.unfollow-button:hover,
.followerDelete-btn:hover {
background-color: #E0E0E0;
}
.followerDelete-btn {
font-size: 15px;
width: 62px;
height: 24px;
margin-left: 8px;
font-family: 'NaR';
border-radius: 20px;
color: white;
font-style: normal;
font-weight: 300;
line-height: normal;
background: #FF7F00;
cursor: pointer;
transition: background-color 0.3s;
}
</style>

0 comments on commit 2f8b129

Please sign in to comment.