PC-mj/components/MyPopup.vue

473 lines
15 KiB
Vue
Raw Normal View History

2023-12-18 03:12:07 +00:00
<template>
2023-12-25 10:39:49 +00:00
<el-dialog v-model="show" width="750px" align-center class="dialog-box">
<!-- <div class="popup-mask flexcenter"> -->
2023-12-18 03:12:07 +00:00
<div class="box flexflex">
2024-01-03 11:11:30 +00:00
<img class="cross" src="@/assets/img/cross-icon.png" alt @click="closeDialog()" />
2023-12-18 03:12:07 +00:00
<div class="tba-list flexcenter">
2023-12-25 10:39:49 +00:00
<div class="tab-item flexcenter" :class="{ pitch: MyPopupState == 'collect' }" @click="cutMy('collect')">
2023-12-18 03:12:07 +00:00
我的收藏
2024-01-04 06:11:30 +00:00
<div class="value">{{ collectCount > 0 ? collectCount : count["collect"] }}</div>
2023-12-18 03:12:07 +00:00
</div>
2023-12-25 10:39:49 +00:00
<div class="tab-item flexcenter" :class="{ pitch: MyPopupState == 'mj' }" @click="cutMy('mj')">
2023-12-18 03:12:07 +00:00
我的面经
2023-12-25 10:39:49 +00:00
<div class="value">{{ count["publish"] }}</div>
2023-12-18 03:12:07 +00:00
</div>
</div>
2024-01-03 11:11:30 +00:00
<div class="empty-box flexcenter" v-loading="true" v-if="(MyPopupState == 'collect' && collectLoading) || (MyPopupState == 'mj' && publisloading)"></div>
<div class="empty-box flexcenter" v-else-if="showList.length == 0">
2023-12-25 10:39:49 +00:00
<Empty></Empty>
</div>
<div class="content" v-else @scroll="handleListScroll">
2023-12-29 10:37:38 +00:00
<div class="item flexflex" v-for="(item, index) in showList" :key="index" @click="goDetails(item['uniqid'] || item?.data?.uniqid)">
2023-12-18 03:12:07 +00:00
<div class="left flexflex">
2023-12-29 10:37:38 +00:00
<div class="name">{{ item["school"] || item["data"]["school"] }}</div>
2023-12-18 03:12:07 +00:00
<div class="info-box flexflex">
2023-12-29 10:37:38 +00:00
<div class="info-item flexacenter" v-if="item['profession'] || item?.['data']?.['profession']">
2023-12-18 03:12:07 +00:00
<div class="info-item-name">专业</div>
2023-12-29 10:37:38 +00:00
<div class="info-item-value">{{ item["profession"] || item["data"]["profession"] }}</div>
2023-12-25 10:39:49 +00:00
</div>
2023-12-29 10:37:38 +00:00
<div class="info-item flexacenter" v-if="item['project'] || item?.data?.project">
2023-12-25 10:39:49 +00:00
<div class="info-item-name">项目</div>
2023-12-29 10:37:38 +00:00
<div class="info-item-value">{{ item["project"] || item?.data?.project }}</div>
2023-12-18 03:12:07 +00:00
</div>
</div>
<div class="text-box flexacenter">
2023-12-29 10:37:38 +00:00
<div class="text-time" v-if="item?.releasetime">{{ handleDate(item?.releasetime) }}发布</div>
<div class="text-message flex1 ellipsis">{{ item["message"] || item["data"]["message"] }}</div>
2023-12-18 03:12:07 +00:00
</div>
</div>
<div class="operate-area flexacenter">
2024-01-09 10:49:37 +00:00
<img class="delete-icon" v-if="MyPopupState == 'collect'" @click.stop="cancelCollection(item['token'], index, item?.data?.uniqid)" src="@/assets/img/delete-icon.svg" />
2023-12-29 10:37:38 +00:00
<div class="anonymous-box flexacenter" v-else @click.stop="openAnonymousState(index)">
2023-12-25 10:39:49 +00:00
<div class="text">{{ item["anonymous"] == 1 ? "匿名" : "公开" }}</div>
2023-12-18 03:12:07 +00:00
<img class="arrow-icon" src="@/assets/img/arrow-gray.svg" />
2023-12-25 10:39:49 +00:00
<div class="state-popup flexflex" v-if="item['anonymousState']" @click.stop="">
2023-12-29 10:37:38 +00:00
<div class="state-popup-item flexacenter flex1" :class="{ 'pitch': item['anonymous'] == 0 }" @click="handleAnonymousState(item['token'], index, 0)">
2023-12-25 10:39:49 +00:00
<div class>公开发表</div>
2023-12-18 03:12:07 +00:00
<img class="state-popup-icon" src="@/assets/img/tick-green.svg" />
</div>
2023-12-29 10:37:38 +00:00
<div class="state-popup-item flexacenter flex1" :class="{ 'pitch': item['anonymous'] == 1 }" @click="handleAnonymousState(item['token'], index, 1)">
2023-12-25 10:39:49 +00:00
<div class>匿名发表</div>
2023-12-18 03:12:07 +00:00
<img class="state-popup-icon" src="@/assets/img/tick-green.svg" />
</div>
</div>
</div>
</div>
</div>
</div>
</div>
2023-12-25 10:39:49 +00:00
</el-dialog>
<!-- </div> -->
2023-12-18 03:12:07 +00:00
</template>
2023-12-25 10:39:49 +00:00
<script setup>
2024-01-08 08:18:40 +00:00
// let props = defineProps({
// // MyPopupState: String, // collect mj
// count: Object,
// })
let count = inject("count")
2023-12-25 10:39:49 +00:00
let show = ref(false)
const router = useRouter()
2024-01-02 11:03:39 +00:00
const route = useRoute()
2023-12-25 10:39:49 +00:00
let MyPopupState = ref("") // collect mj
onMounted(() => {
// if (MyPopupState.value == "collect") getCollect();
// else if (MyPopupState.value == "mj") getPublish();
})
// 展示的 列表数据
let showList = ref([])
let collectList = []
2023-12-29 10:37:38 +00:00
let collectPage = 1
2024-01-03 11:11:30 +00:00
let collectLoading = ref(false)
2023-12-29 10:37:38 +00:00
let collectCount = ref(0)
2023-12-25 10:39:49 +00:00
const getCollect = () => {
2024-01-03 11:11:30 +00:00
if (collectPage == 0 || collectLoading.value) return
collectLoading.value = true
2023-12-29 10:37:38 +00:00
MyUserCollectHttp({ page: collectPage })
.then(res => {
if (res.code != 200) return
let data = res.data
collectList = collectList.concat(data.data)
showList.value = collectList
if (collectList.length < data["count"]) collectPage++
else collectPage = 0
collectCount.value = data["count"]
2024-01-03 10:31:15 +00:00
2024-01-03 11:11:30 +00:00
// MyPopupState.value = "collect"
// show.value = true
2023-12-29 10:37:38 +00:00
})
2024-01-03 11:11:30 +00:00
.finally(() => (collectLoading.value = false))
2023-12-25 10:39:49 +00:00
}
let publishList = []
let publisPage = 1
2024-01-03 11:11:30 +00:00
let publisloading = ref(false)
2023-12-25 10:39:49 +00:00
const getPublish = () => {
2024-01-03 11:11:30 +00:00
if (publisPage == 0 && !publisloading.value) return
2023-12-25 10:39:49 +00:00
2024-01-03 11:11:30 +00:00
publisloading.value = true
2023-12-25 10:39:49 +00:00
MyUserPublishHttp({ limit: 4, page: publisPage })
.then(res => {
if (res.code != 200) return
let data = res.data
publishList = publishList.concat(data.data)
if (publishList.length < data["count"]) publisPage++
else publisPage = 0
showList.value = publishList
2024-01-03 10:31:15 +00:00
2024-01-03 11:11:30 +00:00
// MyPopupState.value = "mj"
// show.value = true
2023-12-25 10:39:49 +00:00
})
2024-01-03 11:11:30 +00:00
.finally(() => (publisloading.value = false))
2023-12-25 10:39:49 +00:00
}
2024-01-04 03:12:34 +00:00
// 切换 isEmpty 是否清空收藏数据, 因为不确定用户是否有新收藏
const cutMy = (key, isEmpty) => {
if (isEmpty) {
collectList = []
collectPage = 1
collectCount.value = 0
}
2023-12-25 10:39:49 +00:00
if (key == "collect" && collectList.length == 0) getCollect()
else if (key == "mj" && publishList.length == 0) getPublish()
if (key == "collect") showList.value = collectList
else if (key == "mj") showList.value = publishList
2024-01-03 11:11:30 +00:00
MyPopupState.value = key
2023-12-25 10:39:49 +00:00
2024-01-03 11:11:30 +00:00
if (MyPopupState.value) show.value = true
2023-12-25 10:39:49 +00:00
}
// 打开匿名弹窗
const openAnonymousState = index => {
publishList.forEach(element => {
element["anonymousState"] = false
})
publishList[index]["anonymousState"] = true
showList.value = [...publishList]
}
2023-12-29 10:37:38 +00:00
// 关闭全部匿名弹窗
const closeAllAnonymousState = () => {
publishList.forEach(element => {
element["anonymousState"] = false
})
showList.value = [...publishList]
}
2023-12-25 10:39:49 +00:00
// 修改匿名状态
2023-12-29 10:37:38 +00:00
const handleAnonymousState = (token, index, anonymous) => {
changeAnonymousHttp({ token, anonymous }).then(res => {
if (res.code != 200) return
publishList[index]["anonymous"] = anonymous
showList.value = [...publishList]
closeAllAnonymousState()
2024-01-02 11:03:39 +00:00
ElMessage.success(res.message)
2023-12-29 10:37:38 +00:00
})
2023-12-25 10:39:49 +00:00
}
// 详情页滚动事件
const handleListScroll = e => {
const el = e.target
// 判断滚动到底部
if (el.scrollHeight - el.scrollTop !== el.clientHeight) return
if (MyPopupState.value == "collect") getCollect()
if (MyPopupState.value == "mj") getPublish()
}
2024-01-03 07:28:16 +00:00
let clearAllData = inject("clearAllData") || null
let getDetails = inject("getDetails") || null
2024-01-02 11:03:39 +00:00
2023-12-25 10:39:49 +00:00
// 打开详情页
const goDetails = uniqid => {
2024-01-02 11:03:39 +00:00
let path = route["path"] || ""
if (path.indexOf("/details/") != -1) {
clearAllData()
nextTick(() => getDetails())
}
2024-01-03 07:28:16 +00:00
// router.replace(`/details/${uniqid}`)
2024-01-04 03:12:34 +00:00
goToURL(`/details/${uniqid}`, false)
2024-01-02 11:03:39 +00:00
show.value = false
MyPopupState.value = ""
2023-12-25 10:39:49 +00:00
}
//暴露state和play方法
defineExpose({
cutMy,
})
2024-01-03 11:11:30 +00:00
// 关闭弹窗
const closeDialog = () => {
show.value = false
}
2023-12-25 10:39:49 +00:00
// const emit = defineEmits(["cutMy"]);
2024-01-09 10:49:37 +00:00
const unbookmarkSamePage = inject("unbookmarkSamePage")
2023-12-29 10:37:38 +00:00
// 处理取消收藏
2024-01-09 10:49:37 +00:00
const cancelCollection = (token, index, uniqid) => {
const id = route.params["id"]
2023-12-29 10:37:38 +00:00
MyUserDeleteCollectHttp({ token }).then(res => {
if (res.code != 200) {
ElMessage.error(res.message)
return
}
collectList.splice(index, 1)
showList.value = [...collectList]
2024-01-08 08:18:40 +00:00
count.value.collect--
collectCount.value--
2024-01-09 10:49:37 +00:00
if (id == uniqid) unbookmarkSamePage()
2023-12-29 10:37:38 +00:00
})
}
2023-12-25 10:39:49 +00:00
</script>
2023-12-18 03:12:07 +00:00
<style lang="less" scoped>
.popup-mask {
width: 100vw;
height: 100vh;
background: rgba(0, 0, 0, 0.5);
position: fixed;
top: 0;
left: 0;
max-width: none;
max-height: none;
border: none;
outline: none;
2023-12-25 10:39:49 +00:00
z-index: 1;
}
.box {
width: 750px;
height: 606px;
background-color: rgba(255, 255, 255, 1);
border-radius: 10px;
-moz-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.117647058823529);
-webkit-box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.117647058823529);
box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.117647058823529);
flex-direction: column;
padding: 30px 30px 46px;
position: relative;
.cross {
position: absolute;
top: 12px;
right: 12px;
width: 12px;
height: 12px;
cursor: pointer;
}
.tba-list {
font-size: 16px;
margin-bottom: 29px;
.tab-item {
color: #aaaaaa;
padding: 0 22px;
cursor: pointer;
position: relative;
&:first-of-type::after {
content: "";
width: 1px;
height: 16px;
background: #d7d7d7;
position: absolute;
right: 0;
}
.value {
margin-left: 10px;
}
&.pitch {
font-weight: 650;
color: #000000;
.value {
color: #555;
font-weight: 400;
}
}
}
}
.empty-box {
width: 100%;
height: 100%;
2023-12-18 03:12:07 +00:00
background-color: rgba(255, 255, 255, 1);
2023-12-25 10:39:49 +00:00
border: 1px solid rgba(235, 235, 235, 1);
border-radius: 6px;
margin: 0 auto;
}
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.content {
width: 100%;
height: 100%;
// background: #000000;
overflow: auto;
padding-right: 10px;
padding-bottom: 35px;
.item {
// flex-direction: column;
border-bottom: 1px dotted #ebebeb;
padding-bottom: 20px;
cursor: pointer;
margin-left: 22px;
margin-bottom: 21px;
.left {
flex-direction: column;
// padding-left: 22px;
position: relative;
&::after {
2023-12-18 03:12:07 +00:00
content: "";
position: absolute;
2023-12-25 10:39:49 +00:00
top: 4px;
left: -22px;
width: 5px;
height: 12px;
background-color: rgba(49, 215, 46, 1);
border-radius: 25px;
2023-12-18 03:12:07 +00:00
}
2023-12-25 10:39:49 +00:00
.name {
2023-12-18 03:12:07 +00:00
font-weight: 650;
2023-12-25 10:39:49 +00:00
font-size: 14px;
2023-12-18 03:12:07 +00:00
color: #000000;
2023-12-25 10:39:49 +00:00
margin-bottom: 10px;
2023-12-18 03:12:07 +00:00
}
2023-12-25 10:39:49 +00:00
.info-box {
flex-direction: column;
margin-bottom: 7px;
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.info-item {
line-height: 24px;
&:not(:last-of-type) {
margin-bottom: 3px;
}
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.info-item-name {
color: #7f7f7f;
font-size: 13px;
margin-right: 12px;
}
.info-item-value {
font-size: 13px;
color: #333333;
}
2023-12-18 03:12:07 +00:00
}
2023-12-25 10:39:49 +00:00
}
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.text-box {
width: 580px;
height: 45px;
line-height: 45px;
background-color: rgba(246, 246, 246, 1);
border-radius: 5px;
color: #000000;
font-size: 13px;
padding: 0 16px;
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.text-time {
color: #7f7f7f;
padding-right: 16px;
position: relative;
&::after {
content: "|";
position: absolute;
right: 8px;
color: #d7d7d7;
2023-12-18 03:12:07 +00:00
}
}
2023-12-25 10:39:49 +00:00
}
}
.operate-area {
flex: 1;
display: flex;
justify-content: flex-end;
.delete-icon {
width: 12px;
cursor: pointer;
}
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.anonymous-box {
.text {
2023-12-18 03:12:07 +00:00
font-size: 13px;
2023-12-25 10:39:49 +00:00
color: #333333;
2023-12-18 03:12:07 +00:00
}
2023-12-25 10:39:49 +00:00
.arrow-icon {
width: 8px;
height: 5px;
margin-left: 6px;
2023-12-18 03:12:07 +00:00
}
2023-12-25 10:39:49 +00:00
position: relative;
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.state-popup {
position: absolute;
top: 30px;
right: 0;
width: 140px;
height: 101px;
background-color: rgba(255, 255, 255, 1);
border-radius: 10px;
-moz-box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.203921568627451);
-webkit-box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.203921568627451);
box-shadow: 0px 0px 6px rgba(0, 0, 0, 0.203921568627451);
flex-direction: column;
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
.state-popup-item {
justify-content: space-between;
color: #555;
font-size: 14px;
padding: 0 10px;
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
&:hover {
color: #000000;
}
2023-12-18 03:12:07 +00:00
2023-12-25 10:39:49 +00:00
&.pitch {
color: #72db86;
2023-12-18 03:12:07 +00:00
.state-popup-icon {
2023-12-25 10:39:49 +00:00
display: block;
2023-12-18 03:12:07 +00:00
}
}
2023-12-25 10:39:49 +00:00
&:not(:last-of-type) {
border-bottom: 1px dotted #e3e3e3;
}
.state-popup-icon {
width: 11px;
height: 8px;
display: none;
}
2023-12-18 03:12:07 +00:00
}
}
}
}
}
}
}
</style>
2023-12-25 10:39:49 +00:00
<style lang="less">
.dialog-box {
header {
display: none;
}
border-radius: 10px;
.el-dialog__body {
padding: 0;
}
}
</style>