Browse Source

消息通知功能

Rockery 4 năm trước cách đây
mục cha
commit
869721a103

+ 296 - 0
h5_web/pages/notification/notification.vue

@@ -0,0 +1,296 @@
+<!-- 
+ * @title 消息通知 
+ * @author Rockery(1113269755@qq.com)
+-->
+
+<template>
+	<view class="notification">
+		<view class="wrap">
+			<view class="u-tabs-box notice-tabsswiper">
+				<u-tabs-swiper bg-color="transparent" ref="noticeTabsSwiper" :list="tabsSwiperList" :current="current" @change="tabsSwiperChange" :is-scroll="false"></u-tabs-swiper>
+			</view>
+      <view class="notice-search">
+        <u-search placeholder="请输入您关键词" v-model="noticeKeyword" bg-color="#FFFFFF" input-align="center" :show-action="false" class="notice-search-btn"></u-search>
+      </view>
+			<swiper class="swiper-box" :current="swiperCurrent" @transition="transition" @animationfinish="animationfinish">
+				<swiper-item class="swiper-item">
+					<scroll-view scroll-y style="height: 100%;width: 100%;" @scrolltolower="reachBottom">
+            <view class="page-box">
+              <view class="notice-container" v-for="(consultItem, index) in dataList[0]" :key="index + 'consultitem'">
+                <view class="title">{{consultItem.title}}</view>
+                <view class="content">{{consultItem.content}}</view>
+                <view class="footer">
+                  <view class="left">{{consultItem.dateTime}}</view>
+                  <view :class="consultItem.status == 0 ?'unread':'haveread'" class="right">{{consultItem.statusLabel}}</view>
+                </view>
+              </view>
+              <u-loadmore :status="loadStatus[0]" bgColor="#f2f2f2"></u-loadmore>
+            </view>
+					</scroll-view>
+				</swiper-item>
+				<swiper-item class="swiper-item">
+					<scroll-view scroll-y style="height: 100%;width: 100%;" @scrolltolower="reachBottom">
+            <view class="page-box">
+              <view class="notice-container" v-for="(systemInfoItem, index) in dataList[1]" :key="index + 'systeminfo'">
+                <view class="title">{{systemInfoItem.title}}</view>
+                <view class="content">{{systemInfoItem.content}}</view>
+                <view class="footer">
+                  <view class="left">{{systemInfoItem.dateTime}}</view>
+                  <view class="right">{{systemInfoItem.status}}</view>
+                </view>
+              </view>
+              <u-loadmore :status="loadStatus[2]" bgColor="#f2f2f2"></u-loadmore>
+            </view>
+					</scroll-view>
+				</swiper-item>
+			</swiper>
+		</view>
+	</view>
+</template>
+
+<script>
+export default {
+	data() {
+		return {
+      noticeKeyword: '',
+      tabsSwiperList: [
+      	{
+      		name: '问题咨询'
+      	},
+      	{
+      		name: '系统消息'
+      	}
+      ],
+			dataList: [
+        [
+          {
+            id: 1,
+            title: '请问针对退役军人就业有哪些什么政策',
+            content: '退役军人就业政策,每个地方的规定不一样,但都会按照相关规定实行阳光安置,根据退役军人相关条件和考试成绩进行选择安置。',
+            dateTime: '发布于2021.09.23 12:31',
+            status: 1,
+            statusLabel: '已读'
+          },
+          {
+            id: 2,
+            title: '请问针对退役军人就业有哪些什么政策',
+            content: '退役军人就业政策,每个地方的规定不一样,但都会按照相关规定实行阳光安置,根据退役军人相关条件和考试成绩进行选择安置。',
+            dateTime: '发布于2021.09.23 12:31',
+            status: 0,
+            statusLabel: '未读'
+          }
+        ],
+        [
+          {
+            id: 1,
+            title: '请问针对退役军人就业有哪些什么政策',
+            content: '退役军人就业政策,每个地方的规定不一样,但都会按照相关规定实行阳光安置,根据退役军人相关条件和考试成绩进行选择安置。',
+            dateTime: '发布于2021.09.23 12:31',
+            status: 1,
+            statusLabel: '已读'
+          },
+          {
+            id: 2,
+            title: '请问针对退役军人就业有哪些什么政策',
+            content: '退役军人就业政策,每个地方的规定不一样,但都会按照相关规定实行阳光安置,根据退役军人相关条件和考试成绩进行选择安置。',
+            dateTime: '发布于2021.09.23 12:31',
+            status: 0,
+            statusLabel: '未读'
+          }
+        ]
+      ],
+			current: 0,
+			swiperCurrent: 0,
+			dx: 0,
+			loadStatus: ['loadmore','loadmore'],
+		};
+	},
+	onLoad() {
+		this.getDataList(0);
+	},
+	computed: {
+		// 价格小数
+		priceDecimal() {
+			return val => {
+				if (val !== parseInt(val)) return val.slice(-2);
+				else return '00';
+			};
+		},
+		// 价格整数
+		priceInt() {
+			return val => {
+				if (val !== parseInt(val)) return val.split('.')[0];
+				else return val;
+			};
+		}
+	},
+	methods: {
+		reachBottom() {
+      this.loadStatus.splice(this.current,1,"loading");
+      setTimeout(() => {
+      	this.getDataList(this.current);
+      }, 1200);
+		},
+		// 页面数据
+		getDataList(idx) {
+			this.loadStatus.splice(this.current,1,"nomore")
+		},
+		// 总价
+		totalPrice(item) {
+			let price = 0;
+			item.map(val => {
+				price += parseFloat(val.price);
+			});
+			return price.toFixed(2);
+		},
+		// 总件数
+		totalNum(item) {
+			let num = 0;
+			item.map(val => {
+				num += val.number;
+			});
+			return num;
+		},
+		// tab栏切换
+		tabsSwiperChange(index) {
+			this.swiperCurrent = index;
+			this.getDataList(index);
+		},
+		transition({ detail: { dx } }) {
+			this.$refs.noticeTabsSwiper.setDx(dx);
+		},
+		animationfinish({ detail: { current } }) {
+			this.$refs.noticeTabsSwiper.setFinishCurrent(current);
+			this.swiperCurrent = current;
+			this.current = current;
+		}
+	}
+};
+</script>
+
+<style lang="scss" scoped>
+.order {
+	width: 710rpx;
+	background-color: #ffffff;
+	margin: 20rpx auto;
+	border-radius: 20rpx;
+	box-sizing: border-box;
+	padding: 20rpx;
+	font-size: 28rpx;
+	.top {
+		display: flex;
+		justify-content: space-between;
+		.left {
+			display: flex;
+			align-items: center;
+			.store {
+				margin: 0 10rpx;
+				font-size: 32rpx;
+				font-weight: bold;
+			}
+		}
+		.right {
+			color: $u-type-warning-dark;
+		}
+	}
+	.item {
+		display: flex;
+		margin: 20rpx 0 0;
+		.left {
+			margin-right: 20rpx;
+			image {
+				width: 200rpx;
+				height: 200rpx;
+				border-radius: 10rpx;
+			}
+		}
+		.content {
+			.title {
+				font-size: 28rpx;
+				line-height: 50rpx;
+			}
+			.type {
+				margin: 10rpx 0;
+				font-size: 24rpx;
+				color: $u-tips-color;
+			}
+			.delivery-time {
+				color: #e5d001;
+				font-size: 24rpx;
+			}
+		}
+		.right {
+			margin-left: 10rpx;
+			padding-top: 20rpx;
+			text-align: right;
+			.decimal {
+				font-size: 24rpx;
+				margin-top: 4rpx;
+			}
+			.number {
+				color: $u-tips-color;
+				font-size: 24rpx;
+			}
+		}
+	}
+	.total {
+		margin-top: 20rpx;
+		text-align: right;
+		font-size: 24rpx;
+		.total-price {
+			font-size: 32rpx;
+		}
+	}
+	.bottom {
+		display: flex;
+		margin-top: 40rpx;
+		padding: 0 10rpx;
+		justify-content: space-between;
+		align-items: center;
+		.btn {
+			line-height: 52rpx;
+			width: 160rpx;
+			border-radius: 26rpx;
+			border: 2rpx solid $u-border-color;
+			font-size: 26rpx;
+			text-align: center;
+			color: $u-type-info-dark;
+		}
+		.evaluate {
+			color: $u-type-warning-dark;
+			border-color: $u-type-warning-dark;
+		}
+	}
+}
+.centre {
+	text-align: center;
+	margin: 200rpx auto;
+	font-size: 32rpx;
+	image {
+		width: 164rpx;
+		height: 164rpx;
+		border-radius: 50%;
+		margin-bottom: 20rpx;
+	}
+	.tips {
+		font-size: 24rpx;
+		color: #999999;
+		margin-top: 20rpx;
+	}
+	.btn {
+		margin: 80rpx auto;
+		width: 200rpx;
+		border-radius: 32rpx;
+		line-height: 64rpx;
+		color: #ffffff;
+		font-size: 26rpx;
+		background: linear-gradient(270deg, rgba(249, 116, 90, 1) 0%, rgba(255, 158, 1, 1) 100%);
+	}
+}
+
+</style>
+
+<style lang="scss"
+  scoped>
+  @import './scss/notification.scss'
+</style>

+ 98 - 0
h5_web/pages/notification/scss/notification.scss

@@ -0,0 +1,98 @@
+/* #ifndef H5 */
+page {
+	height: 100%;
+	background-color: #f2f2f2;
+}
+/* #endif */
+
+.notification{
+  .wrap {
+  	display: flex;
+  	flex-direction: column;
+  	height: calc(100vh - var(--window-top));
+  	width: 100%;
+  }
+  
+  &-tabsswiper{
+    
+  }
+  
+  .notice-search{
+    padding: 20rpx 30rpx;
+    &-btn{
+      ::v-deep .u-content{
+        // padding: 0 !important;
+        border-radius: 10rpx !important;
+      }
+    }
+  }
+  
+  .swiper-box{
+    flex: 1;
+    
+    .swiper-item{
+      height: 100%;
+      
+      .page-box{
+        padding: 0 30rpx 20rpx;
+        
+        .notice-container{
+          padding: 20rpx;
+          margin-bottom: 20rpx;
+          background-color: #FFFFFF;
+          border-radius: 10rpx;
+          
+          .title{
+            margin-bottom: 12rpx;
+            font-size: 32rpx;
+            font-family: PingFangSC-Regular, PingFang SC;
+            font-weight: 400;
+            color: #000000;
+            line-height: 45rpx;
+            letter-spacing: 1px;
+          }
+          
+          .content{
+            margin-bottom: 12rpx;
+            font-size: 24rpx;
+            font-family: PingFangSC-Regular, PingFang SC;
+            font-weight: 400;
+            color: #545454;
+            line-height: 35rpx;
+            letter-spacing: 1px;
+          }
+          
+          .footer{
+            display: flex;
+            flex-wrap: wrap;
+            justify-content: space-between;
+            
+            .left{
+              font-size: 22rpx;
+              font-family: PingFangSC-Regular, PingFang SC;
+              font-weight: 400;
+              color: #9F9F9F;
+              line-height: 30rpx;
+            }
+            
+            .right{
+              font-size: 22rpx;
+              font-family: PingFangSC-Regular, PingFang SC;
+              font-weight: 400;
+              color: #1A1A1A;
+              line-height: 30rpx;
+            }
+            
+            .unread{
+              color: #1A1A1A;
+            }
+            
+            .haveread{
+              color: #EF6622;
+            }
+          }
+        }
+      }
+    }
+  }
+}