17 changed files with 655 additions and 112 deletions
@ -0,0 +1,11 @@ |
|||||
|
// axios
|
||||
|
import request from '@/utils/request' |
||||
|
|
||||
|
// 获取积分记录
|
||||
|
export function selectChangeByUserId(data) { |
||||
|
return request({ |
||||
|
url: '/voluntary/points/selectChangeByUserId', |
||||
|
method: 'post', |
||||
|
data |
||||
|
}) |
||||
|
} |
@ -0,0 +1,8 @@ |
|||||
|
import request from '@/utils/request' |
||||
|
export function userdemandAdd(data) { |
||||
|
return request({ |
||||
|
url: `/governance/userdemand/add`, |
||||
|
method: 'post', |
||||
|
data |
||||
|
}) |
||||
|
} |
@ -0,0 +1,304 @@ |
|||||
|
<template> |
||||
|
<div> |
||||
|
<div class="flex flex-mean" style="background-color: #FFFFFF;"> |
||||
|
<van-search class="flex flex-1" v-model="searchValue" shape="round" placeholder="请输入搜索关键词"> |
||||
|
<template #action> |
||||
|
<!-- 添加样式确保按钮显示,并设置合适的宽高和对齐 --> |
||||
|
<!-- <div @click="onSearch" |
||||
|
style="display: flex; align-items: center; justify-content: center; padding: 0 10px; cursor: pointer;"> |
||||
|
a搜索 |
||||
|
</div> --> |
||||
|
</template> |
||||
|
</van-search> |
||||
|
<van-button round type="info" class="custom-button font-size13 m-top10 m-right12" @click="handleSearch">查询</van-button> |
||||
|
|
||||
|
</div> |
||||
|
<!-- <van-search v-model="searchKey" placeholder="请输入搜索关键词" shape="round" class="custom-search" |
||||
|
@search="$router.push({ path: '/search', query: { searchKey: searchKey } })" /> --> |
||||
|
<div class='container'> |
||||
|
<div class="flex flex-y flex1 flex-end" v-if="PublicityList.length !== 0"> |
||||
|
<van-list v-model="loading" :finished="finished" finished-text="没有更多了" |
||||
|
@load="communityPublicity" class="card" :offset="50"> |
||||
|
<div class="activity_content flex flex-y" v-for="(item, index) in PublicityList" |
||||
|
:key="index" @click="toDetail(item)"> |
||||
|
<div class="flex flex1 oh"> |
||||
|
<div class="flex flex-y flex1 m-right10 oh"> |
||||
|
<span class="van-multi-ellipsis--l2 text1" > |
||||
|
{{ item.title }} |
||||
|
</span> |
||||
|
<div class="flex flex-end text2"> |
||||
|
<span class="van-ellipsis y66666 font-size15"> |
||||
|
{{ item.name }} </span> |
||||
|
|
||||
|
<div class="">{{ item.time }}</div> |
||||
|
</div> |
||||
|
|
||||
|
</div> |
||||
|
<img v-if="item.coverPic" :src="item.coverPic" style="width: 130px;height: 100px;border-radius: 20;" |
||||
|
alt=""> |
||||
|
</div> |
||||
|
<div class="flex flex-end flex-center gray m-top10 font-size13"> |
||||
|
<!-- <div class="flex flex-center"><img src="@/assets/images/icons/support.png" alt="" |
||||
|
class="img_16 m-right7"><span>{{ item.likes || 0 }}</span> |
||||
|
</div> --> |
||||
|
|
||||
|
</div> |
||||
|
</div> |
||||
|
</van-list> |
||||
|
</div> |
||||
|
<div v-else class="no-data"> |
||||
|
暂无数据~ |
||||
|
</div> |
||||
|
|
||||
|
|
||||
|
</div> |
||||
|
<Android></Android> |
||||
|
</div> |
||||
|
|
||||
|
|
||||
|
</template> |
||||
|
|
||||
|
<script> |
||||
|
import { advertisingTag, communityPublicity } from '@/api/home'; |
||||
|
export default { |
||||
|
data() { |
||||
|
return { |
||||
|
PublicityList: [ |
||||
|
{ |
||||
|
title:"70岁以上高龄老人补贴福利发放于1月1日", |
||||
|
name:"胡冰", |
||||
|
time:"2024-09-10 09:30" |
||||
|
}, |
||||
|
{ |
||||
|
title:"70岁以上高龄老人补贴福利发放于1月1日", |
||||
|
name:"胡冰", |
||||
|
time:"2024-09-10 09:30" |
||||
|
}, |
||||
|
{ |
||||
|
title:"70岁以上高龄老人补贴福利发放于1月1日", |
||||
|
name:"胡冰", |
||||
|
time:"2024-09-10 09:30" |
||||
|
}, |
||||
|
{ |
||||
|
title:"70岁以上高龄老人补贴福利发放于1月1日", |
||||
|
name:"胡冰", |
||||
|
time:"2024-09-10 09:30" |
||||
|
}, |
||||
|
], |
||||
|
tagList:[{ |
||||
|
id:"0", |
||||
|
tagName:"日常征集" |
||||
|
}, |
||||
|
{ |
||||
|
id:"1", |
||||
|
tagName:"专题征集" |
||||
|
}, |
||||
|
], |
||||
|
tagActive: 'new', |
||||
|
tagId: null, |
||||
|
pageSize: 5, |
||||
|
pageNo: 1, |
||||
|
agencyId: null, |
||||
|
finished: false, |
||||
|
loading: true, |
||||
|
showRegister: false, |
||||
|
searchValue: "" |
||||
|
}; |
||||
|
}, |
||||
|
created() { |
||||
|
// this.agencyId = this.$route.query.agencyId?this.$route.query.agencyId: this.$store.state.app.agencyId; |
||||
|
// this.advertisingTag();//获取社区讯息菜单 |
||||
|
// this.communityPublicity()//获取讯息列表 |
||||
|
}, |
||||
|
methods: { |
||||
|
toDetail(item){ |
||||
|
this.$router.push({name:'topicListDetail',query:{id:item.id}}) |
||||
|
}, |
||||
|
handleSearch(){ |
||||
|
this.PublicityList = []; |
||||
|
this.pageNo = 1; |
||||
|
this.communityPublicity() |
||||
|
}, |
||||
|
filterTagId(tagId) { |
||||
|
return this.tagList.filter(item => item.id === tagId)[0].tagName || '--'; |
||||
|
}, |
||||
|
// async advertisingTag() { |
||||
|
// let parm = { |
||||
|
// pageSize: 10, |
||||
|
// pageNo: 1, |
||||
|
// status: 1, |
||||
|
// tagName: null |
||||
|
// } |
||||
|
// let res = await advertisingTag(parm) |
||||
|
// if (res.code === 0) { |
||||
|
// this.tagList = res.data.list; |
||||
|
// this.tagList.unshift({ tagName: '最新', id: 'new' }) |
||||
|
// } |
||||
|
// }, |
||||
|
async communityPublicity() { |
||||
|
let parm = { |
||||
|
pageSize: 10, |
||||
|
pageNo: 1, |
||||
|
title: this.searchValue, |
||||
|
tagId: this.tagId, |
||||
|
startTime: '', |
||||
|
endTime: '', |
||||
|
agencyId: this.agencyId, |
||||
|
status:1 |
||||
|
} |
||||
|
let res = await communityPublicity(parm) |
||||
|
if (res.code === 0) { |
||||
|
this.loading = false; |
||||
|
res.data.list.forEach(item => { |
||||
|
if (item.content) { |
||||
|
item.newContent = this.extractChineseCharactersAndPunctuation(item.content) |
||||
|
} |
||||
|
}) |
||||
|
if (!res.data || res.data.list.length < this.pageSize) { |
||||
|
this.finished = true; |
||||
|
} |
||||
|
this.PublicityList = this.PublicityList.concat(res.data.list); |
||||
|
} |
||||
|
}, |
||||
|
extractChineseCharactersAndPunctuation(str) { |
||||
|
const chineseCharsAndPunctuation = str.match(/[\u4e00-\u9fa5\u3000-\u303F\uff00-\uffef]/g); |
||||
|
return chineseCharsAndPunctuation ? chineseCharsAndPunctuation.join('') : ''; |
||||
|
}, |
||||
|
handelChangeTags(val, title) { |
||||
|
this.PublicityList = []; |
||||
|
if (val !== 0) { |
||||
|
this.tagId = this.tagList[val].id; |
||||
|
} else { |
||||
|
this.tagId = ''; |
||||
|
} |
||||
|
this.communityPublicity() |
||||
|
}, |
||||
|
}, |
||||
|
components: {}, |
||||
|
computed: {}, |
||||
|
watch: {}, |
||||
|
} |
||||
|
</script> |
||||
|
|
||||
|
<style lang='less' scoped> |
||||
|
.text2{ |
||||
|
font-family: PingFang SC; |
||||
|
font-weight: 500; |
||||
|
font-size: 12px; |
||||
|
color: #999999; |
||||
|
line-height: 30px; |
||||
|
} |
||||
|
.text1{ |
||||
|
font-family: PingFang SC; |
||||
|
font-weight: 500; |
||||
|
font-size: 18px; |
||||
|
color: #000000; |
||||
|
; |
||||
|
} |
||||
|
.custom-button { |
||||
|
width: 60px; |
||||
|
height: 33px; |
||||
|
} |
||||
|
|
||||
|
.activity_content { |
||||
|
padding-bottom: 10px; |
||||
|
box-sizing: border-box; |
||||
|
width: 100%; |
||||
|
border-bottom: 1px solid #EAEAEA; |
||||
|
margin-top: 14px; |
||||
|
min-height: 50px; |
||||
|
|
||||
|
.img { |
||||
|
width: 231px; |
||||
|
height: 33px; |
||||
|
margin: 5px 3px 0 3px; |
||||
|
} |
||||
|
|
||||
|
&:last-child { |
||||
|
border-bottom: none; |
||||
|
} |
||||
|
|
||||
|
|
||||
|
.content { |
||||
|
|
||||
|
width: 325px; |
||||
|
height: 40px; |
||||
|
font-family: PingFang SC; |
||||
|
font-weight: 500; |
||||
|
font-size: 16px; |
||||
|
color: #333333; |
||||
|
line-height: 23px; |
||||
|
} |
||||
|
|
||||
|
.dianzan { |
||||
|
width: 325px; |
||||
|
height: 20px; |
||||
|
display: flex; |
||||
|
font-size: 13px; |
||||
|
color: #AAAAAA; |
||||
|
flex-direction: row; |
||||
|
justify-content: space-evenly; |
||||
|
align-items: center; |
||||
|
|
||||
|
.img { |
||||
|
width: 14.5px; |
||||
|
height: 15px; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
|
||||
|
} |
||||
|
|
||||
|
.header {} |
||||
|
|
||||
|
.header .input_search { |
||||
|
width: 279px; |
||||
|
height: 33px; |
||||
|
background: rgba(193, 193, 193, 0.16); |
||||
|
border-radius: 17px; |
||||
|
// flex: 1; |
||||
|
color: #333333; |
||||
|
border: none; |
||||
|
/* 取消边框 */ |
||||
|
margin-left: 10px; |
||||
|
} |
||||
|
|
||||
|
.header .btn_search { |
||||
|
width: 60px; |
||||
|
height: 33px; |
||||
|
background: #3974F6; |
||||
|
border-radius: 17px; |
||||
|
font-family: PingFang SC; |
||||
|
font-weight: 500; |
||||
|
font-size: 14px; |
||||
|
color: #FFFFFF; |
||||
|
line-height: 23px; |
||||
|
border: none; |
||||
|
/* 取消边框 */ |
||||
|
margin-right: 10px; |
||||
|
} |
||||
|
::v-deep .van-search__content { |
||||
|
background-color: white; |
||||
|
border: 1px solid #3974F6; |
||||
|
} |
||||
|
|
||||
|
::v-deep .van-search__input { |
||||
|
color: #000; |
||||
|
} |
||||
|
|
||||
|
::v-deep .van-field__control::placeholder { |
||||
|
color: #A0A0A0; |
||||
|
} |
||||
|
:deep(.van-field__control) { |
||||
|
font-size: 13px; |
||||
|
} |
||||
|
.van-tab__title { |
||||
|
padding: 5px 12px; /* 内边距调整 */ |
||||
|
font-size: 14px; /* 字体大小 */ |
||||
|
} |
||||
|
|
||||
|
.van-tabs__nav { |
||||
|
justify-content: space-between; /* 平均分布 */ |
||||
|
} |
||||
|
|
||||
|
</style> |
Loading…
Reference in new issue