You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1179 lines
31 KiB

8 months ago
<template>
<view :style="viewColor">
<view class="page_con">
<view class="grass_header" :style="{'background-image': `url(${domain}/static/images/grass_header.png)`}">
<view v-if="!navShow" class="header">
<view class="navTab">
<view v-if="community_status == 1" @click="goRelease" class="release_btn acea-row row-center-wrapper">
<text class="iconfont icon-fabu"></text></view>
<view class="acea-row row-center-wrapper">
<view :class="tabActive == 0 ? 'on' : ''" class="nav-item" @click="tabActive=0;">关注</view>
<view :class="tabActive == 1 ? 'on' : ''" class="nav-item" @click="tabActive=1;">发现</view>
</view>
<navigator v-if="isLogin && community_status == 1" :url="'/pages/plantGrass/plant_user/index?id='+userInfo.uid">
<image class="avatar" :src="userInfo.avatar ? userInfo.avatar : '/static/images/f.png'"></image>
</navigator>
</view>
<view class="search_count">
<navigator url="/pages/plantGrass/plant_search/index" hover-class="none" class="search"><text class="iconfont icon-xiazai5"></text>搜索想看的文章</navigator>
<navigator class="search_topic" url="/pages/plantGrass/plant_topic/index">
<image class="topic_icon" :src="`${domain}/static/images/topic_cate.png`"></image>
</navigator>
</view>
</view>
<view class="longTab" v-if="tabActive == 1">
<scroll-view scroll-x="true" style="white-space: nowrap; display: flex;" scroll-with-animation class="menu" :scroll-left="tabLeft" show-scrollbar="true">
<view class="longItem"
:data-index="index"
:class="index === tabClick ? 'click' : ''"
v-for="(item, index) in menuList"
:key="index"
:id="'id' + index"
@click.stop="selectMenu(item, index, true)">{{ item.cate_name }}</view>
</scroll-view>
</view>
</view>
<scroll-view class="main" :class="{'scroll-main' : tabActive == 0}" scroll-y="true" @scroll="followScroll">
<view class="tab-cont" id="main" @touchmove="onTouchmove">
<!-- 关注 -->
<view v-if="tabActive === 0">
<view v-if="isLogin && followList.length > 0" class="follow_count" :class="(newData.status && newData.status.status && showTab) ? 'showFoot' : ''">
<block v-for="(item, index) in followList" :key="index">
<view class="list_count">
<view class="title">
<navigator hover-class="none" :url="'/pages/plantGrass/plant_user/index?id='+item.uid" v-if="item.author" class="author">
<easy-loadimage class="picture" mode="widthFix" :image-src="item.author&&item.author.avatar || '/static/images/f.png'"></easy-loadimage>
<text class="name">{{item.author.nickname || ''}}</text>
</navigator>
<view class="time">{{item.time}}</view>
</view>
<view class="product">
<productConSwiper v-if="item.is_type == 1" :imgUrls="item.image"></productConSwiper>
<view v-else class="videoSwiper" @click="goVideo(item)">
<image class="image" :src="item.image[0]"></image>
<image v-if="item.is_type == 2" class="video_img" src="../../static/images/stop.png"></image>
</view>
</view>
<view class="pro_describle">
<view class="mentioned" v-if="item.relevance && item.relevance.length > 0" @click="openMore(item)">
<text class="title">查看TA提到的宝贝({{item.relevance.length}})</text>
<view class="product_more">
<view class="item">
<easy-loadimage v-if="indexn<4" v-for="(itemn, indexn) in item.relevance" :key="indexn" mode="widthFix" :image-src="(itemn.spu && itemn.spu.image) || itemn.image" class="more_image"></easy-loadimage>
</view>
<text class="iconfont icon-gengduo3"></text>
</view>
</view>
<view v-if="!item.show && item.content.length > 110" class="product_info">
<text class="text">
{{item.content.substring(0,90)+'...'}}
</text>
<text @click.stop="showMore(item)" class="unfold_btn">展开</text>
</view>
<view v-else class="product_info">
<text class="text">
{{item.content}}
</text>
</view>
<navigator v-if="item.topic" hover-class="none" class="product_cate" :url="'/pages/plantGrass/plant_search_list/index?id='+item.topic.topic_id">
<view>
<text class="icon">#</text><text class="text">{{item.topic.topic_name}}</text>
</view>
</navigator>
<view class="foot_bar">
<!-- #ifdef MP -->
<button class="time iconfont icon-fenxiang2" open-type="share" hover-class='none' @click="shareFriend(item)"></button>
<!-- #endif -->
<!-- #ifndef MP -->
<button></button>
<!-- #endif -->
<view class="item">
<view class="item_count" @click.stop="likeToggle(item)">
<text class="iconfont" :class="item.relevance_id ? 'icon-shoucang1' : 'icon-dianzan'"></text>
<text>{{item.count_start > 0 ? item.count_start : '点赞'}}</text>
</view>
<view v-if="community_reply_status == 1" class="item_count" @click="openCommon(item,index)">
<text class="iconfont icon-pinglun"></text>
<text>{{item.count_reply > 0 ? item.count_reply : '评论'}}</text>
</view>
</view>
</view>
</view>
</view>
</block>
</view>
<view v-if="followList.length == 0 && !focusLoading && isLogin" class="empty">
<image :src="`${domain}/static/images/no_thing.png`"></image>
<text>暂无内容~</text>
</view>
<view v-if="!isLogin" class="empty no_login">
<image :src="`${domain}/static/images/no_login.png`"></image>
<view class="title">暂未登录</view>
<text>登录后可查看关注用户的发布哦~</text>
<button class="login_btn" @click="authOpen">立即登录</button>
</view>
</view>
<!-- 发现 -->
<view v-show="tabActive === 1">
<!-- 商品 -->
<swiper :interval="interval" indicator-color="rgba(255,255,255,0.6)" :current="swiperCurrent" @change="swiperChange" :style="'height:'+swiperHeight+'px;'" >
<block v-for="(item,index) in menuList" :key="index">
<swiper-item :item-id="`${item.category_id}`">
<scroll-view @scroll="scrollLeft" scroll-y="true" :style="'height:'+swiperHeight+'px'" id="goods"
refresher-enabled="true" :refresher-threshold="100"
:refresher-triggered="triggeredDiscover"
@refresherrefresh="onRefreshDiscover" @refresherpulling="onPulling"
@refresherrestore="onRestore" @refresherabort="onAbort">
<view v-if="cateGoods[item.category_id] && cateGoods[item.category_id].goods.length" class="goods-wrap" id="goods">
<view class="goods">
<WaterfallsFlow :isShow="false" :wfList='cateGoods[item.category_id].goods' :isFind="true" @likeToggle="likeToggle"/>
</view>
</view>
<view :hidden="cateGoods[item.category_id] && !cateGoods[item.category_id].goodsLoading" class="acea-row row-center-wrapper loadingicon">
<text class="iconfont icon-jiazai loading"></text>{{!cateGoods[item.category_id] ? 0 : cateGoods[item.category_id].goodsLoading}}
</view>
<view v-if="cateGoods[item.category_id] && cateGoods[item.category_id].goods.length == 0 && !cateGoods[item.category_id].goodsLoading" class="empty">
<image :src="`${domain}/static/images/no_thing.png`"></image>
<text>{{item.category_id == -1 ? '暂无视频' : '暂无文章'}}~</text>
</view>
</scroll-view>
</swiper-item>
</block>
</swiper>
</view>
</view>
</scroll-view>
</view>
<!-- 他提到的宝贝弹窗 -->
<mentioned ref="mentioned" :isHome="true" @close="closePopup" :list="moreList" :uid="authorUid"></mentioned>
<!-- 评论弹窗 -->
<comment ref="comment" :isShow="showComment" :userInfo="userInfo" :bottom="bottom" @successFul="commentSucces" @close="close"></comment>
<!--自定义底部tab栏-->
<customTab :newData="newData" :activeRouter="activeRouter"></customTab>
</view>
</template>
<script>
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
import WaterfallsFlow from '@/components/plantWaterfallsFlow/WaterfallsFlow.vue'
import mentioned from '@/components/mentioned.vue';
import comment from '@/components/comment.vue';
import { getNavigation } from '@/api/public.js';
import customTab from '@/components/customTab';
import { graphicLstApi, getTopicList, graphicStartApi, focusArticleLst } from '@/api/community.js';
import { getUserInfo } from '@/api/user.js';
import { mapGetters } from "vuex";
import productConSwiper from '@/components/plantConSwiper';
import easyLoadimage from '@/components/easy-loadimage/easy-loadimage.vue';
import { HTTP_REQUEST_URL } from '@/config/app';
import { toLogin } from '@/libs/login.js';
import { configMap } from '@/utils';
const app = getApp();
export default {
components: {
WaterfallsFlow,
productConSwiper,
mentioned,
comment,
easyLoadimage,
customTab
},
data() {
return {
domain: HTTP_REQUEST_URL,
// #ifdef MP
menuButtonInfo: uni.getMenuButtonBoundingClientRect(),
// #endif
tabClick: 0,
tabLeft: 0,
isLeft: 0, //导航栏下划线位置
isWidth: 0, //每个导航栏占位
windowHeight: 0,
swiperHeight: 0,
childIndex: 0,
showComment: false,
triggered: false,
triggeredDiscover: false,
userInfo: {},
goods: [], // 商铺商品
followList: [], //关注列表
menuList: [],
moreList: [],
commList: [], //评论列表
goodsList: [],
navShow: false,
navActive: 0,
tabActive: 1, // 底部切换
keyword: '',
sortPrice: true, // 价格排序
focusLoading: false,
goodsLoading: false,
goodsLoaded: false,
focusLoaded: false,
loadTitle: '加载更多',
where: {
category_id: 0,
page: 1,
limit: 30
},
focusWhere: {
page: 1,
limit: 30
},
storeScroll: true,
_freshing: false,
storeTop: 0,
storeHeight: 0,
navHeight: 0,
avatar: '',
hederBg: '../static/images/plant_header.png',
top: 300,
shareInfo: {},
actionSheetHidden: true,
authorUid: 0,
swiperCur: 0,
circular: true,
isScroll: false,
interval: 3000,
currentItemId: 0,
swiperCurrent: 0,
scrollTop: 0,
cateGoods:{},
newData: {},
activeRouter: '',
showTab: false,
//#ifdef MP||APP-PLUS
bottom: 0,
//#endif
//#ifndef MP||APP-PLUS
bottom: 90,
//#endif
}
},
// 滚动监听
onPageScroll({scrollTop}) {
uni.$emit('scroll');
},
created() {
var that = this;
// 获取设备宽度
uni.getSystemInfo({
success(e) {
that.isWidth = e.windowWidth / 6;
that.windowHeight = e.windowHeight;
// that.swiperHeight = that.windowHeight - 205
that.$set(that, 'swiperHeight', that.windowHeight-150);
}
});
},
computed: {
...mapGetters(['isLogin', 'uid', 'viewColor']),
...configMap({community_reply_status: 0,community_app_switch: [],community_status: 0,navigation: {}})
},
watch: {},
onLoad: function(options) {
let that = this;
uni.$on('startLike',function(data){
for(var i = 0; i < that.cateGoods[that.currentItemId]['goods'].length; i++){
let item = that.cateGoods[that.currentItemId]['goods'][i]
if(data.community_id == item['community_id']){
item['count_start'] = data.relevance_id ? item['count_start']+1 : item['count_start']-1
item['relevance_id'] = data.relevance_id ? true : false
}
}
})
},
onShow() {
app.getConfigData();
this.getCateList();
this.getGoods();
let that = this
let routes = getCurrentPages();
let curRoute = routes[routes.length - 1].route
this.activeRouter = '/' + curRoute
this.getNav();
if (that.isLogin) {
that.focusLoading = false;
that.focusLoaded = false;
that.focusWhere.page = 1;
that.followList = [];
this.getUserInfo();
this.getFocusArtical();
} else {
this.userInfo = {}
}
},
mounted: function() {
const query = uni.createSelectorQuery().in(this);
query.select('#main').boundingClientRect(data => {
this.storeHeight = data.height;
this.storeTop = data.top;
}).exec();
},
/**
* 用户点击右上角分享
*/
// #ifdef MP
onShareAppMessage: function() {
let that = this;
that.$set(that, 'actionSheetHidden', !that.actionSheetHidden);
return {
title: that.shareInfo.title || '',
imageUrl: that.shareInfo.image[0] || '',
path: '/pages/plantGrass/plant_detail/index?id=' + that.shareInfo.community_id + '&spid=' + that.uid,
}
},
onShareTimeline: function() {
let that = this;
that.$set(that, 'actionSheetHidden', !that.actionSheetHidden);
return {
title: that.shareInfo.title || '',
query: {
id: that.shareInfo.community_id,
spid: that.uid
},
imageUrl: that.shareInfo.image[0] || ''
}
},
// #endif
methods: {
getNav() {
getNavigation().then(res => {
this.newData = res.data
if (this.newData.status && this.newData.status.status) {
uni.hideTabBar()
this.$set(this, 'swiperHeight', this.windowHeight-50);
} else {
uni.showTabBar()
}
})
},
goRelease(){
if(this.isLogin){
uni.navigateTo({
url: '/pages/plantGrass/plant_release/index'
});
}else{
toLogin()
}
},
followScroll(e){
uni.$emit('scroll');
},
//分享信息
shareFriend(item){
this.shareInfo = item
},
// 打开授权
authOpen: function() {
toLogin()
},
/**
* 获取个人用户信息
*/
getUserInfo: function() {
let that = this;
getUserInfo().then(res => {
that.userInfo = res.data
});
},
/*获取分类列表*/
getCateList(){
getTopicList().then(res => {
let data = [{cate_name: "推荐",category_id: 0,children: []}]
if(this.community_app_switch.length == 2 || this.community_app_switch[0]==2){
data = [{cate_name: "推荐",category_id: 0,children: []},{cate_name: "视频",category_id: -1,children: []}]
}
this.menuList = Array.from(new Set([...data,...res.data]));
})
},
swiperChange(e) {
let { current, source, currentItemId } = e.detail;
if (source === 'autoplay' || source === 'touch') {
this.currentItemId = currentItemId;
this.swiperCur = current
this.selectMenu(this.menuList[this.swiperCur],this.swiperCur,false)
if (this.menuList.length > 6) {
var tempIndex = this.swiperCur - 2;
tempIndex = tempIndex <= 0 ? 0 : tempIndex;
let tabLeft = (this.swiperCur - 2) * this.isWidth; //设置下划线位置
this.$nextTick(function() {
this.$set(this, 'tabLeft', tabLeft);
});
}
}
},
// 点击列表头部
selectMenu(item, index, isScroll) {
this.currentItemId = item.category_id;
this.swiperCurrent = index;
this.swiperCur = index
this.isScroll = isScroll;
this.tabClick = index; //设置导航点击了哪一个
this.isLeft = index * this.isWidth; //设置下划线位置
this.setMenuLeft(index);
},
/*导航栏移动位置*/
setMenuLeft(index) {
this.getGoods();
},
showMore(item){
this.$set(item,'show', true);
},
scrollLeft: function(e){
uni.$emit('scroll');
this.scrollTop = e.detail.scrollTop
this.navShow = e.detail.scrollTop >= this.storeHeight - 200;
if(this.navShow){
this.$set(this, 'swiperHeight', this.windowHeight-50);
}
if(e.detail.scrollTop > e.detail.scrollHeight - 1500){
this.getGoods();
}
},
// 获取发现商品
getGoods: function() {
let that = this;
if(!this.cateGoods[this.currentItemId]) {
this.$set(this.cateGoods, this.currentItemId, {
where: {...this.where, category_id: this.currentItemId},
goods: []
})
}
const data = this.cateGoods[this.currentItemId];
const cateId = this.currentItemId;
if (data.goodsLoading || data.goodsLoaded) return;
data.goodsLoading = true;
data.loadTitle = "";
graphicLstApi(data.where).then(res => {
data.goodsLoading = false;
data.goodsLoaded = res.data.list.length < that.where.limit;
if(data.where.page == 1 ){
data.goods = [];
}
data.goods.push.apply(data.goods, res.data.list);
data.where.page = data.where.page + 1;
this.$set(this.cateGoods,cateId, {...data});
this.triggeredDiscover = false;
this.$forceUpdate()
}).catch(err => {
data.goodsLoading = false;
uni.showToast({
title: err,
icon: 'none'
})
this.$set(this.cateGoods,cateId, data);
});
},
/*获取关注的人的文章列表*/
getFocusArtical(){
let that = this;
if (that.focusLoading || that.focusLoaded) return;
that.focusLoading = true;
that.loadTitle = "";
focusArticleLst(that.focusWhere).then(res => {
that.focusLoading = false;
that.focusLoaded = res.data.list.length < that.focusWhere.limit;
res.data.list.forEach((item)=>{
item.show = false
})
that.followList.push.apply(that.followList, res.data.list);
that.focusWhere.page = that.focusWhere.page + 1;
}).catch(err => {
that.focusLoading = false;
uni.showToast({
title: err,
icon: 'none'
})
});
},
onPulling(e) {
if (e.detail.deltaY < 0) return // 防止上滑页面也触发下拉
if (this.tabActive == 1) {
this.triggeredDiscover = true;
} else {
this.triggered = true;
}
},
onRefreshDiscover() {
if (this._freshing) return;
this._freshing = true;
setTimeout(() => {
this._freshing = false;
this.cateGoods = {}
this.getGoods();
this.triggeredDiscover = false;
this.scrollTop = 0;
uni.stopPullDownRefresh();
this._freshing = false;
}, 1000)
},
onRefresh() {
if (this._freshing) return;
this._freshing = true;
setTimeout(() => {
this.loadendfollow = false;
this.loadend = false;
this.followList = [];
this.focusWhere.page = 1;
this.params.page = 1;
this.getFocusArtical();
setTimeout(() => {
if(this.followList.length === 0 || this.focusLoaded) this.getGoods();
}, 400)
this.triggered = false
uni.stopPullDownRefresh();
this._freshing = false;
}, 1000)
},
onRestore() {
this.triggeredDiscover = false;
},
onAbort() {
console.log("onAbort");
},
// 商铺首页滚动 navbar 吸顶
scrollHome: function(e) {
this.navShow = e.detail.scrollTop >= this.storeHeight - 20;
},
likeToggle(item){
let status = item.relevance_id ? 0 : 1
graphicStartApi(item.community_id,{status: status}).then(res => {
if(item.relevance_id){
item.count_start--;
item.count_start = item.count_start == 0 ? 0 : item.count_start
item.relevance_id = false
}else{
item.count_start++;
item.relevance_id = true
}
});
},
/*查看提到的宝贝*/
openMore(item){
this.$refs.mentioned.showPopup()
this.moreList = item.relevance;
this.authorUid = item.uid
},
openCommon(item,index){
this.switchTab(0);
this.showComment = true
this.$refs.comment.getData(item,index);
},
commentSucces(index){
this.followList[index]['count_reply']++
},
closePopup(){
this.$refs.mentioned.closePopup()
},
close(){
this.switchTab(1);
this.showComment = false;
},
onTouchmove(e){
const query = uni.createSelectorQuery().in(this);
query.select('#goods').boundingClientRect(data => {
if(data.bottom < 1500) {
if(this.tabActive == 1){
this.getGoods();
}else{
this.getFocusArtical();
}
}
}).exec();
// 模拟触底刷新
},
switchTab(type){ //1打开0关闭
this.newData = this.navigation
if (this.newData.status && this.newData.status.status) {
if(type == 1){
this.showTab = true;
uni.hideTabBar()
}else{
this.showTab = false;
uni.hideTabBar()
}
} else {
if(type == 1){
this.showTab = false;
uni.showTabBar()
}else{
this.showTab = false;
uni.hideTabBar()
}
}
},
goVideo(item) {
uni.navigateTo({
//#ifdef APP
url: '/pages/short_video/appSwiper/index?id='+item.community_id
//#endif
//#ifndef APP
url: '/pages/short_video/nvueSwiper/index?id='+item.community_id
//#endif
});
},
},
onReachBottom() {
if(this.tabActive == 1){
this.getGoods();
}else{
this.getFocusArtical();
}
},
beforeDestroy() {
uni.$off('startLike');
}
}
</script>
<style lang="scss" scoped>
page{
background: #fff;
}
.page_con{
position: fixed;
top: 0;
right: 0;
bottom: 0;
left: 0;
display: flex;
flex-direction: column;
background-color: #fff;
}
.longTab {
display: flex;
width: 100%;
background: #fff;
border-radius: 16rpx 16rpx 0 0;
padding: 20rpx;
.longItem {
height: 50upx;
display: inline-block;
line-height: 50upx;
text-align: center;
font-size: 30rpx;
color: #999999;
max-width: 160rpx;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
overflow-x: scroll;
overflow-y: hidden;
margin-right: 56rpx;
&:last-child{
margin-right: 0;
}
/*解决ios上滑动不流畅*/
-webkit-overflow-scrolling: touch;
position: relative;
&.click {
font-weight: bold;
font-size: 34rpx;
color: var(--view-theme);
&::after{
content: "";
display: block;
width: 60rpx;
height: 4rpx;
background-color: var(--view-theme);
display: flex;
position: absolute;
left: 50%;
margin-left: -32rpx;
bottom: 0rpx;
}
.underline {
opacity: 1;
}
}
}
.underlineBox {
height: 3px;
width: 20%;
display: flex;
align-content: center;
justify-content: center;
.underline {
opacity: 0;
width: 60rpx;
height: 4rpx;
background-color: #e93323;
}
}
}
.tab-cont{
border-radius: 16rpx 16rpx 0 0;
}
.showFoot{
padding: 20rpx 20rpx calc(120rpx+ constant(safe-area-inset-bottom));
padding: 20rpx 20rpx calc(120rpx + env(safe-area-inset-bottom));
}
.follow_count{
background: #ffffff;
/* #ifndef MP */
padding: 20rpx 20rpx 100rpx;
/* #endif */
/* #ifdef MP */
padding: 20rpx 20rpx calc(0rpx+ constant(safe-area-inset-bottom));
padding: 20rpx 20rpx calc(0rpx + env(safe-area-inset-bottom));
/* #endif */
.title{
display: flex;
align-items: center;
justify-content: space-between;
}
.author{
display: flex;
align-items: center;
.picture{
width: 78rpx;
height: 78rpx;
border-radius: 100%;
overflow: hidden;
}
/deep/image,/deep/.easy-loadimage,uni-image{
height: 78rpx;
}
.name{
margin-left: 20rpx;
color: #333333;
font-size: 32rpx;
font-weight: bold;
}
}
.time{
color: #999999;
font-size: 24rpx;
}
.product{
margin-top: 20rpx;
border-radius: 16rpx;
}
.icon-fenxiang2{
color: #282828;
font-size: 46rpx;
background: transparent;
}
}
.list_count{
margin-bottom: 70rpx;
&:last-child{
margin-bottom: 0;
}
}
.videoSwiper{
width: 710rpx;
height: 710rpx;
position: relative;
border-radius: 16rpx;
.image{
width: 710rpx;
height: 710rpx;
border-radius: 16rpx;
}
.video_img{
width: 100rpx;
height: 100rpx;
position: absolute;
top: 50%;
left: 50%;
margin-left: -50rpx;
margin-top: -50rpx;
z-index: 10;
}
}
.pro_describle{
.mentioned{
padding: 20rpx 0;
display: flex;
align-items: center;
justify-content: space-between;
border-bottom: 1px solid #F5F5F5;
.title{
color: #666666;
font-size: 26rpx;
}
}
.product_more{
max-width: 360rpx;
display: flex;
align-items: center;
.more_image{
width: 58rpx;
height: 58rpx;
border-radius: 5rpx;
margin-right: 12rpx;
display: inline-block;
border: 1px solid #BBBBBB;
}
/deep/image,/deep/.easy-loadimage,uni-image{
width: 58rpx;
height: 58rpx;
}
.iconfont{
color: #CCCCCC;
margin-left: 10rpx;
}
}
.product_info{
line-height: 45rpx;
margin: 20rpx 0;
.text{
font-size: 28rpx;
color: #282828;
}
.unfold_btn{
margin-left: 30rpx;
font-size: 30rpx;
color: #282828;
font-weight: bold;
}
}
.product_cate{
margin: 20rpx 0;
display: inline-block;
>view{
display: flex;
align-items: center;
background: var(--view-minorColor);
border-radius: 30rpx;
padding: 0 25rpx;
line-height: 56rpx;
height: 56rpx;
color: var(--view-theme);
.text{
font-size: 28rpx;
}
.icon{
font-size: 35rpx;
font-weight: bold;
margin-right: 10rpx;
}
}
}
.foot_bar{
display: flex;
align-items: center;
justify-content: space-between;
.item{
display: flex;
align-items: center;
color: #282828;
&.icon-fenxiang2{
font-size: 46rpx;
}
}
.item_count{
font-size: 26rpx;
display: flex;
align-items: center;
&:first-child{
margin-right: 30rpx;
}
.iconfont{
font-size: 40rpx;
margin-right: 5rpx;
}
.icon-shoucang1{
color: var(--view-priceColor);
}
}
}
}
.grass_header {
display: flex;
flex-direction: column;
background-size: cover;
background-color: #ffffff;
width: 100%;
z-index: 10;
}
.header {
padding: 0 30rpx 20rpx;
.navTab{
position: relative;
padding: 20rpx 0 40rpx 0;
.nav-item{
font-size: 32rpx;
color: #666666;
&:first-child{
margin-right: 70rpx;
}
&.on{
font-size: 38rpx;
color: #282828;
font-weight: bold;
}
}
.release_btn{
width: 58rpx;
height: 58rpx;
border-radius: 100%;
background-image: linear-gradient(126deg, var(--view-bntColor21) 0%, var(--view-bntColor22) 100%);
color: #fff;
position: absolute;
top: 20rpx;
left: 0;
.iconfont{
font-size: 28rpx;
}
}
.avatar{
width: 58rpx;
height: 58rpx;
border-radius: 100%;
border: 3rpx solid rgba(0,0,0,.05);
position: absolute;
top: 20rpx;
right: 0;
}
}
.search_count{
display: flex;
align-items: center;
justify-content: space-between;
.search_topic{
width: 46rpx;
height: 46rpx;
image,.topic_icon,uni-image{
width: 46rpx;
height: 46rpx;
}
}
}
.search {
display: flex;
align-items: center;
min-width: 0;
height: 58rpx;
border-radius: 29rpx;
background-color: #FFFFFF;
font-weight: 500;
font-size: 24rpx;
color: #999999;
width: 609rpx;
.iconfont {
margin-right: 13rpx;
margin-left: 30rpx;
font-size: 24rpx;
}
}
}
.main_count{
background-color: #ffffff;
padding: 30rpx 20rpx;
.list{
width: 710rpx;
height: 280rpx;
margin-bottom: 30rpx;
position: relative;
.picture{
width: 710rpx;
height: 280rpx;
border-radius: 16rpx;
}
}
}
.main {
flex: 1;
height: auto;
&.scroll-main{
min-height: 60vh;
}
}
.nav.fixed {
position: fixed;
left: 0;
width: 100%;
.nav-cont {
position: absolute;
width: 100%;
}
}
.goods {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
padding: 0 20rpx;
background: #ffffff;
width: 750rpx;
/* #ifdef H5 */
padding-bottom: 100rpx;
padding-bottom: calc(100rpx+ constant(safe-area-inset-bottom)); ///兼容 IOS<11.2/
padding-bottom: calc(100rpx + env(safe-area-inset-bottom)); ///兼容 IOS>11.2/
/* #endif */
.item {
width: 345rpx;
border-radius: 16rpx;
margin-bottom: 20rpx;
background-color: #FFFFFF;
overflow: hidden;
/deep/.image,/deep/.easy-loadimage,uni-image {
width: 345rpx;
height: 345rpx;
image {
display: block;
width: 100%;
height: 100%;
}
}
.text {
padding: 20rpx 20rpx 25rpx;
.name {
font-weight: 500;
font-size: 30rpx;
line-height: 1;
color: #222222;
display: flex;
align-items: center;
.name_text{
display: inline-block;
max-width: 400rpx;
}
}
.money-wrap {
display: flex;
align-items: center;
margin-top: 43rpx;
.money {
font-weight: bold;
font-size: 26rpx;
color: $theme-color;
text {
font-size: 34rpx;
line-height: 1;
}
}
.ticket {
height: 26rpx;
padding-right: 9rpx;
padding-left: 9rpx;
border: 1px solid $theme-color;
border-radius: 4rpx;
margin-left: 10rpx;
font-weight: 500;
font-size: 20rpx;
line-height: 24rpx;
color: $theme-color;
}
}
.score {
margin-top: 20rpx;
font-weight: 500;
font-size: 20rpx;
line-height: 1;
color: #737373;
}
}
.foot {
display: flex;
justify-content: center;
align-items: center;
height: 52rpx;
background: linear-gradient(to right, #F11B09, #F67A38);
font-weight: 500;
font-size: 24rpx;
color: #FFFFFF;
.iconfont {
margin-right: 10rpx;
font-size: 22rpx;
line-height: 1;
}
}
}
}
.empty{
width: 100%;
text-align: center;
position:relative;
top: 200rpx;
/* #ifdef MP */
// top: 100rpx;
/* #endif */
image,uni-image{
display: inline-block;
width: 414rpx;
height: 305rpx;
}
.title{
font-size: 28rpx;
color: #282828;
font-weight: bold;
margin-bottom: 14rpx;
}
text{
display: block;
color: #999999;
font-size: 26rpx;
}
.login_btn{
width: 440rpx;
text-align: center;
height: 76rpx;
line-height: 76rpx;
color: var(--view-theme);
border: 1px solid var(--view-theme);
border-radius: 40rpx;
margin: 44rpx auto 0;
font-size: 32rpx;
}
}
.page-footer {
position: fixed;
bottom: 0;
z-index: 30;
display: flex;
align-items: center;
justify-content: space-around;
width: 100%;
height: 98rpx;
height: calc(98rpx+ constant(safe-area-inset-bottom)); ///兼容 IOS<11.2/
height: calc(98rpx + env(safe-area-inset-bottom)); ///兼容 IOS>11.2/
box-sizing: border-box;
border-top: solid 1px #F3F3F3;
background-color: #fff;
box-shadow: 0px 0px 17rpx 1rpx rgba(206, 206, 206, 0.32);
padding-bottom: constant(safe-area-inset-bottom); ///兼容 IOS<11.2/
padding-bottom: env(safe-area-inset-bottom); ///兼容 IOS>11.2/
.foot-item {
display: flex;
width: max-content;
align-items: center;
justify-content: center;
flex-direction: column;
position: relative;
.count-num {
position: absolute;
display: flex;
justify-content: center;
align-items: center;
width: 40rpx;
height: 40rpx;
top: 0rpx;
right: -15rpx;
color: #fff;
font-size: 20rpx;
background-color: #FD502F;
border-radius: 50%;
padding: 4rpx;
}
}
.foot-item image {
height: 50rpx;
width: 50rpx;
text-align: center;
margin: 0 auto;
}
.foot-item .txt {
font-size: 24rpx;
}
}
</style>