first commit

This commit is contained in:
PC-202306242200\Administrator
2026-03-28 23:10:55 +08:00
commit 1c24452b6c
1735 changed files with 150474 additions and 0 deletions

293
pages/index/index.vue Normal file
View File

@@ -0,0 +1,293 @@
<template>
<view class="home">
<!-- <view class="my-capsule-like-button" :style="capsuleButtonStyle">自定义按钮</view> -->
<view style="width: 100%; height: 582rpx" class="home_top">
<image src="/static/homeBanner.png" style="width: 750rpx; height: 582rpx; position: absolute; top: 0; left: 0; z-index: -1"></image>
<wd-navbar :bordered="false" custom-style="background-color: transparent !important;" safeAreaInsetTop>
<template #left>
<view style="display: flex; align-items: center">
<image
src="/static/logo.png"
style="width: 96rpx; height: 96rpx; margin-right: 25rpx; background-color: rgba(255, 255, 255, 0.3); border-radius: 50%"
></image>
<view style="color: #fff; font-size: 40rpx; font-weight: bold">苗草古方</view>
</view>
</template>
</wd-navbar>
<view class="p30" style="display: flex; align-items: center; justify-content: space-between">
<view style="background-color: #fff; width: 324rpx; border-radius: 20rpx; overflow: hidden" @click="toPrefecture">
<wd-swiper customItemClass="bannerRadius" height="292rpx" :list="['/static/homeY.png']" autoplay v-model:current="current">
<template #indicator="{ current, total }">
<!-- <view style="position: absolute; bottom: -60rpx; right: 24rpx; display: flex; align-items: center; background: #cbcbcb; border-radius: 14rpx">
<view
v-for="i in total"
:key="i"
style="width: 24rpx; height: 8rpx; border-radius: 14rpx"
:style="{ background: current + 1 == i ? '#8FAB7F' : '#cbcbcb' }"
></view>
</view> -->
<!-- <view class="custom-insdicator" style="position: absolute; bottom: 24rpx; right: 24rpx">{{ current + 1 }}/{{ total }}</view> -->
</template>
</wd-swiper>
<view style="height: 72rpx; display: flex; align-items: center; padding: 20rpx; font-size: 28rpx; font-weight: bold">进货专区</view>
</view>
<view class="home_top_block">
<view class="home_top_block_view" style="color: #776926" @click="navTo('/pages/equity/equity', true)">
<image src="/static/hui.png"></image>
<view>
<view style="font-size: 32rpx; font-weight: bold">权益包</view>
<view style="font-size: 24rpx; margin-top: 10rpx">购买权益包</view>
<view style="font-size: 24rpx">至高享七折优惠</view>
</view>
</view>
<view class="home_top_block_view" style="background: #eef4f1; color: #175b39" @click="openCode">
<image src="/static/yao.png"></image>
<view>
<view style="font-size: 32rpx; font-weight: bold">推荐好友</view>
<view style="font-size: 24rpx; margin-top: 10rpx">推荐好友加盟</view>
<view style="font-size: 24rpx">边拿奖励边赚钱</view>
</view>
</view>
</view>
</view>
</view>
<view class="p30">
<wd-swiper :list="swiperList" value-key="image" autoplay v-model:current="current"></wd-swiper>
<view class="mt30" @click="toNotice">
<wd-notice-bar color="#90B77B" background-color="#E2ECDC">
<view slot="prefix">
<image src="/static/warn.png" style="width: 60rpx; height: 60rpx"></image>
</view>
<view style="font-size: 28rpx">{{ noticeList.content }}</view>
</wd-notice-bar>
</view>
<z-paging ref="paging" v-model="dataList" use-page-scroll @query="queryList">
<view class="home_block mt30" @click="toGoods(item.id)" v-for="(item, index) in dataList" :key="index">
<image class="home_block_left" :src="item.cover"></image>
<view class="home_block_right">
<view class="home_block_right_title">{{ item.name }}</view>
<view class="home_block_right_info">{{ item.specs }}</view>
<view style="display: flex; justify-content: space-between; align-items: center; margin-top: 25rpx">
<view style="font-size: 36rpx; font-weight: bold; color: #ff2929">{{ item.currentPrice }}</view>
<view class="home_block_right_button">下单</view>
</view>
</view>
</view>
</z-paging>
<!-- <view>
</view> -->
</view>
<uni-popup ref="popup" type="center" border-radius="16rpx">
<view class="shareBlock">
<view style="width: 100%; text-align: right"><image @click="$refs.popup.close()" src="/static/icons/cha.png" class="shareBlock_close"></image></view>
<image class="shareBlock_code" :src="userInfo.inviteCodeImg"></image>
<view class="shareBlock_info">打开微信扫描二维码注册时输入邀请码</view>
<view class="shareBlock_codeInfo">
<view class="shareBlock_codeInfo_left">
邀请码
<text style="text-decoration: underline">{{ userInfo.inviteCode }}</text>
</view>
<view class="shareBlock_codeInfo_right" @click="copy(userInfo.inviteCode)">点击复制</view>
</view>
</view>
</uni-popup>
</view>
</template>
<script lang="ts" setup>
import { ref, computed } from 'vue';
import { onLoad, onShareAppMessage, onShareTimeline } from '@dcloudio/uni-app';
import { Store } from '@/store';
import { copy } from '@/utils/fun';
import api from '@/api/index';
const store = Store();
const userInfo = computed(() => store.userInfo || {});
const popup = ref();
const current = ref<number>(0);
const showShare = ref(false);
const swiperList = ref([]);
const noticeList = ref({
content: ''
});
const list = ref([]);
const paging = ref(null);
const dataList = ref([]);
import { useNav } from '@/hooks/useNav';
const { navTo } = useNav();
const queryList = (pageNo, pageSize) => {
api.goodsPage({ pageNo, pageSize,recommended:1 })
.then((res: any) => {
paging.value.complete(res.list);
})
.catch((res) => {
paging.value.complete(false);
});
};
onLoad(() => {
api.banner({
imageAddress: 1
}).then((res) => {
swiperList.value = res.list;
});
api.noticePage({ type: 1 }).then((res) => {
if (res.list != 0) {
noticeList.value = res.list[0];
}
});
});
const openCode = async () => {
await store.usersGetInfo();
popup.value.open();
};
const toGoods = (e) => {
uni.navigateTo({
url: `/pages/goods/goods?id=${e}`
});
};
const toPrefecture = () => {
uni.navigateTo({
url: '/pages/goods/prefecture'
});
};
const toEquity = () => {
uni.navigateTo({
url: '/pages/equity/equity'
});
};
const toNotice = () => {
uni.navigateTo({
url: '/pages/notice/notice'
});
};
</script>
<style lang="scss" scoped>
.home {
&_top {
--wot-swiper-radius: 0;
&_block {
height: 364rpx;
display: flex;
flex-direction: column;
justify-content: space-between;
&_view {
width: 346rpx;
height: 170rpx;
background: #f7f4e5;
border-radius: 30rpx 30rpx 30rpx 30rpx;
padding: 25rpx;
display: flex;
align-items: center;
image {
width: 100rpx;
height: 100rpx;
margin-right: 24rpx;
}
}
}
}
.custom-indicator {
}
&_block {
width: 690rpx;
height: 250rpx;
background: #ffffff;
border-radius: 8rpx 8rpx 8rpx 8rpx;
display: flex;
align-items: center;
padding-right: 25rpx;
&_left {
width: 250rpx;
height: 250rpx;
border-radius: 8rpx 8rpx 8rpx 8rpx;
margin-right: 25rpx;
}
&_right {
flex: 1;
&_title {
font-weight: 600;
font-size: 28rpx;
color: #232323;
}
&_info {
font-weight: 400;
font-size: 24rpx;
color: #232323;
margin-top: 25rpx;
}
&_button {
width: 128rpx;
height: 48rpx;
background: #ff2a2a;
box-shadow: 0rpx 2rpx 4rpx 2rpx #dbdbdb;
border-radius: 10rpx 10rpx 10rpx 10rpx;
display: flex;
align-items: center;
justify-content: center;
font-weight: 800;
font-size: 20rpx;
color: #ffffff;
}
}
}
}
.shareBlock {
margin: auto;
width: 650rpx;
height: 688rpx;
background: #ffffff;
border-radius: 16rpx 16rpx 16rpx 16rpx;
padding: 20rpx;
display: flex;
flex-direction: column;
align-items: center;
&_close {
width: 68rpx;
height: 68rpx;
}
&_code {
width: 392rpx;
height: 392rpx;
}
&_info {
font-size: 24rpx;
color: #cccccc;
margin: 24rpx 0;
}
&_codeInfo {
display: flex;
align-items: center;
&_left {
font-weight: bold;
font-size: 32rpx;
color: #232323;
}
&_right {
margin-left: 20rpx;
font-size: 24rpx;
color: #999999;
}
}
}
</style>