diff --git a/api/pointManagement.js b/api/pointManagement.js
new file mode 100644
index 0000000..467bc29
--- /dev/null
+++ b/api/pointManagement.js
@@ -0,0 +1,41 @@
+var fly = require('../utils/request.js')
+/**
+ * @param userId 用户ID
+ * @param operationType 积分操作类型 0-减积分,1-加积分
+ * @param points 操作积分值
+ */
+// 积分核销接口
+export function pointSverification(params) {
+ return fly.post('work/pointsverification/pointsverification', params)
+}
+/**
+ * @param typeKey 网格:grid_party
+ */
+// 根据机构类型获取机构信息
+export function getDeptInfo(typeKey) {
+ return fly.get(`work/pointsverification/getdeptinfo/${typeKey}`)
+}
+/**
+ * 工作端积分核销记录接口
+ * @param pageIndex Number 页码
+ * @param pageSize Number 页容量
+ * @param startTime 开始时间
+ * @param endTime 结束时间
+ * @param deptId 部门ID
+ */
+
+export function getVerificationLogs({
+ pageIndex,
+ pageSize,
+ startTime,
+ endTime,
+ deptId,
+}) {
+ return fly.get("work/pointsverification/verificationlogs", {
+ pageIndex,
+ pageSize,
+ startTime,
+ endTime,
+ deptId,
+ })
+}
\ No newline at end of file
diff --git a/subpages/pointManagement/images/point-back.png b/subpages/pointManagement/images/point-back.png
new file mode 100644
index 0000000..ac4161a
Binary files /dev/null and b/subpages/pointManagement/images/point-back.png differ
diff --git a/subpages/pointManagement/pages/pointClear/pointClear.js b/subpages/pointManagement/pages/pointClear/pointClear.js
new file mode 100644
index 0000000..cdc4f8b
--- /dev/null
+++ b/subpages/pointManagement/pages/pointClear/pointClear.js
@@ -0,0 +1,99 @@
+import {
+ pointSverification
+} from '../../../../api/pointManagement.js'
+let util = require('../../../../utils/util.js')
+Page({
+ data: {
+ peopleNum: 0,
+ faceImg: '', //用户头像
+ points: 0, //用户积分
+ realName: '', //用户真实姓名
+ userId: "", //用户ID
+ operationType: 0,
+ remark: "",
+ isFlag: true, //按钮防点击
+ },
+ onLoad: function (options) {
+ this.setData({
+ faceImg: options.faceImg, //用户头像
+ points: options.points, //用户积分
+ realName: options.realName, //用户真实姓名
+ userId: options.userId, //用户ID
+ })
+ },
+ onChange(e) {
+ this.setData({
+ peopleNum: e.detail.value,
+ })
+ },
+ pointSverification() {
+ if (!this.data.isFlag) return
+
+ if (this.data.peopleNum == 0) {
+ wx.showToast({
+ icon: 'none',
+ title: '操作积分值必须大于0',
+ duration: 1000,
+ })
+ return
+ }
+ if (this.data.peopleNum > parseInt(this.data.points)) {
+ wx.showToast({
+ icon: 'none',
+ title: '用户积分不足',
+ duration: 2000,
+ })
+ return
+ }
+ if (this.data.remark == '') {
+ wx.showToast({
+ icon: 'none',
+ title: '请输入核销说明',
+ duration: 1000,
+ })
+ return
+ }
+ this.setData({
+ isFlag: false
+ })
+ /**
+ * @param userId 用户ID
+ * @param operationType 积分操作类型 0-减积分,1-加积分
+ * @param points 操作积分值
+ */
+ let para = {
+ userId: this.data.userId,
+ operationType: this.data.operationType,
+ points: this.data.peopleNum,
+ remark: this.data.remark
+ }
+ pointSverification(para).then((res) => {
+ wx.showModal({
+ title: '',
+ content: '操作成功',
+ showCancel: false,
+ success: (res) => {
+ if (res.confirm) {
+ this.setData({
+ isFlag: true
+ })
+ wx.navigateBack({
+ delta: 1
+ })
+ }
+ }
+ })
+
+ }).catch((err) => {
+ this.setData({
+ isFlag: true
+ })
+ })
+ },
+ // 双向绑定 内容输入框
+ bindTextareaInput(e) {
+ this.setData({
+ remark: e.detail.value.trim()
+ })
+ },
+})
\ No newline at end of file
diff --git a/subpages/pointManagement/pages/pointClear/pointClear.json b/subpages/pointManagement/pages/pointClear/pointClear.json
new file mode 100644
index 0000000..cc1a520
--- /dev/null
+++ b/subpages/pointManagement/pages/pointClear/pointClear.json
@@ -0,0 +1,7 @@
+{
+ "usingComponents": {
+ "wux-cell": "../../../../dist/cell/index",
+ "wux-input-number": "../../../../dist/input-number/index"
+ },
+ "navigationBarTitleText": "积分核销"
+}
\ No newline at end of file
diff --git a/subpages/pointManagement/pages/pointClear/pointClear.wxml b/subpages/pointManagement/pages/pointClear/pointClear.wxml
new file mode 100644
index 0000000..c40843f
--- /dev/null
+++ b/subpages/pointManagement/pages/pointClear/pointClear.wxml
@@ -0,0 +1,33 @@
+
+
+
+
+ 本次核销积分
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/subpages/pointManagement/pages/pointClear/pointClear.wxss b/subpages/pointManagement/pages/pointClear/pointClear.wxss
new file mode 100644
index 0000000..d0c29f0
--- /dev/null
+++ b/subpages/pointManagement/pages/pointClear/pointClear.wxss
@@ -0,0 +1,125 @@
+.point-clear {
+ width: 100%;
+ box-sizing: border-box;
+}
+
+
+.clear-header {
+ width: 100%;
+ height: 294rpx;
+ position: relative;
+}
+
+.clear-header .clear-header-bac {
+ width: 754rpx;
+ height: 294rpx;
+}
+
+.info {
+ box-sizing: border-box;
+ width: 100%;
+ position: absolute;
+ left: 0;
+ top: 50%;
+ transform: translate(0%, -50%);
+ padding: 86rpx 70rpx;
+ font-size: 34rpx;
+ font-weight: bold;
+ color: #fff;
+ display: flex;
+}
+
+.info-left {
+ display: flex;
+ align-items: center;
+}
+
+.info-left image {
+ width: 110rpx;
+ height: 110rpx;
+ border-radius: 55rpx;
+ vertical-align: middle;
+}
+
+.info-left text {
+ margin-left: 10rpx;
+}
+
+.info-right {
+ display: flex;
+ flex-direction: column;
+ margin-left: 280rpx;
+ vertical-align: middle;
+ margin-top: 20rpx;
+}
+
+.info-right-text {
+ font-size: 28rpx;
+ font-weight: normal;
+}
+
+.cleaar-num {
+ box-sizing: border-box;
+ width: 100%;
+ /* border: 1rpx solid red; */
+ display: flex;
+ justify-content: space-between;
+ padding-left: 24rpx;
+ padding-right: 24rpx;
+}
+
+.button-footer {
+ width: 100%;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ position: fixed;
+ bottom: 300rpx;
+ z-index: 3;
+}
+
+.footer {
+ width: 530rpx;
+ height: 80rpx;
+ background: url() no-repeat center;
+ text-align: center;
+ line-height: 84rpx;
+ border-radius: 50rpx;
+ font-size: 32rpx;
+ font-weight: bold;
+ color: rgba(255, 255, 255, 1);
+}
+
+
+/* 核销说明样式 */
+
+
+.clear-content-textarea {
+ width: 90%;
+ /* height: 730rpx; */
+ border-radius: 16rpx;
+ background: #fff;
+ box-sizing: border-box;
+ padding: 30rpx 20rpx 45rpx;
+ margin: 30rpx auto;
+}
+
+.clear-content-textarea textarea {
+ width: 100%;
+ height: 298rpx;
+ box-sizing: border-box;
+ padding-bottom: 20rpx;
+ font-size: 34rpx;
+ color: #333;
+ line-height: 50rpx;
+ position: relative;
+}
+
+.clear-content-textarea textarea .textarea-placeholder {
+ font-size: 32rpx;
+ color: #999;
+ line-height: 50rpx;
+ position: absolute;
+ left: 0;
+ top: 0;
+}
\ No newline at end of file
diff --git a/subpages/pointManagement/pages/pointList/pointList.js b/subpages/pointManagement/pages/pointList/pointList.js
new file mode 100644
index 0000000..6d3cf80
--- /dev/null
+++ b/subpages/pointManagement/pages/pointList/pointList.js
@@ -0,0 +1,240 @@
+import {
+ $wuxSelect
+} from '../../../../dist/index'
+import {
+ getDeptInfo,
+ getVerificationLogs
+} from '../../../../api/pointManagement.js'
+let util = require('../../../../utils/util.js')
+Page({
+ data: {
+ visibleTimeLeft: false,
+ visibleTimeRight: false,
+ /****时间选择器 *****/
+ value1: [],
+ value2: [],
+ value3: "",
+ displayValue1: '请选择开始时间',
+ displayValue2: '请选择截至时间',
+ displayValue3: '请选择所属网格',
+ optionsGrid: [],
+ valueRight: [],
+ lang: 'zh_CN',
+ typeKey: "grid_party",
+ pageIndex: 1,
+ pageSize: 15,
+ startTime: "",
+ endTime: "",
+ deptId: '',
+ pointList: [],
+ loadMoreVisible: false, //false
+ loadMoreType: "none",
+ nodata: false,
+ pointsTotal: 0,
+ optionsGridOrgin: [],
+ },
+ onLoad: function (options) {
+ this.getDeptInfo()
+ this.getVerificationLogs()
+ console.log('当天时间', util.getData())
+ this.setData({
+ value1: util.getData().split('-'),
+ value2: util.getData().split('-'),
+ })
+ },
+ selectTapLeft() {
+ this.setData({
+ visibleTimeLeft: true,
+ });
+ },
+ selectTapRight() {
+ this.setData({
+ visibleTimeRight: true,
+ });
+ },
+ selectTapGrid() {
+ wx.showLoading({
+ duration: 2000
+ })
+ $wuxSelect('#wux-select1').open({
+ options: this.data.optionsGrid,
+ onConfirm: (value, index, options) => {
+ console.log('onConfirm', value, index, options)
+ if (index !== -1) {
+ this.setData({
+ value3: value,
+ displayValue3: options[index],
+ })
+ }
+ this.setData({
+ deptId: this.data.optionsGridOrgin[index].id,
+ pointList: [],
+ pageIndex: 1
+ })
+ this.getVerificationLogs()
+ },
+ })
+ },
+ setValue(values, key) {
+ this.setData({
+ [`value${key}`]: values.value,
+ [`displayValue${key}`]: values.label,
+ // [`displayValue${key}`]: values.displayValue.join(' '),
+ })
+ },
+ onConfirmLeft(e) {
+ const {
+ mode
+ } = e.currentTarget.dataset
+ this.setValue(e.detail, mode)
+ this.setData({
+ pageIndex: 1,
+ visibleTimeLeft: false,
+ pointList: [],
+ startTime: this.data.displayValue1
+ })
+ this.getVerificationLogs()
+ },
+ onConfirmRight(e) {
+ const {
+ mode
+ } = e.currentTarget.dataset
+ this.setValue(e.detail, mode)
+ this.setData({
+ pageIndex: 1,
+ visibleTimeRight: false,
+ pointList: [],
+ endTime: this.data.displayValue2
+ })
+ this.getVerificationLogs()
+ },
+ cancelTimeLeft() {
+ this.setData({
+ visibleTimeLeft: false,
+ })
+ },
+ cancelTimeRight() {
+ this.setData({
+ visibleTimeRight: false,
+ })
+ },
+ clearValue1() {
+ this.setData({
+ startTime: '',
+ displayValue1: "请选择开始时间",
+ pointList: [],
+ value1: util.getData().split('-'),
+ })
+ this.getVerificationLogs()
+ },
+ clearValue2() {
+ this.setData({
+ endTime: '',
+ displayValue2: "请选择截至时间",
+ pointList: [],
+ value2: util.getData().split('-'),
+ })
+ this.getVerificationLogs()
+ },
+ clearValue3() {
+ this.setData({
+ deptId: '',
+ displayValue3: '请选择所属网格',
+ pointList: [],
+ })
+ this.getVerificationLogs()
+ },
+ // 所属网格
+ getDeptInfo() {
+ getDeptInfo(this.data.typeKey).then((res) => {
+ console.log('所属网格', res)
+ let optionsGrid = []
+ res.data.forEach((item) => {
+ optionsGrid.push(item.name)
+ })
+ this.setData({
+ optionsGrid,
+ optionsGridOrgin: res.data
+ })
+ }).catch((err) => {})
+ },
+ // 工作端积分核销记录接口
+ // 获取居民兑换记录接口
+ getVerificationLogs() {
+ // 判断时间问题
+ // let startTime = 0
+ // let endTime = 0
+ // this.data.value1.forEach((item) => {
+ // startTime += Number(item)
+ // })
+ // this.data.value2.forEach((item) => {
+ // endTime += Number(item)
+ // })
+ // if (startTime > endTime) {
+ // wx.showToast({
+ // icon: 'none',
+ // title: '开始时间不能晚于截止时间',
+ // duration: 1500,
+ // })
+ // return
+ // } else if (startTime < endTime) {
+ // this.setData({
+ // pointList: [],
+ // })
+ // }
+ /**
+ * 工作端积分核销记录接口
+ * @param pageIndex Number 页码
+ * @param pageSize Number 页容量
+ * @param startTime 开始时间
+ * @param endTime 结束时间
+ * @param deptId 部门ID
+ */
+ let para = {
+ pageIndex: this.data.pageIndex,
+ pageSize: this.data.pageSize,
+ startTime: this.data.startTime,
+ endTime: this.data.endTime,
+ deptId: this.data.deptId
+ }
+ this.setData({
+ loadMoreVisible: true,
+ nodata: false,
+ loadMoreType: "loading",
+ })
+ getVerificationLogs(para).then((res) => {
+ this.setData({
+ // loadMoreVisible: false,
+ loadMoreType: res.data.verificationLogs.length === this.data.pageSize ? 'loading' : 'none',
+ pointList: this.data.pointList.concat(res.data.verificationLogs),
+ pointsTotal: res.data.pointsTotal
+ })
+ if (this.data.pointList.length == 0) {
+ this.setData({
+ loadMoreVisible: false,
+ nodata: true
+ })
+ }
+ }).catch(() => {
+ this.setData({
+ loadMoreVisible: false,
+ nodata: true,
+ })
+ })
+ },
+ /**
+ * 页面上拉触底事件的处理函数
+ */
+ onReachBottom: function () {
+ console.log('下拉了')
+ if (this.data.loadMoreType === 'loading') {
+ this.setData({
+ loadMoreVisible: true,
+ })
+ this.data.pageIndex += 1
+ this.getVerificationLogs()
+ }
+ },
+
+
+})
\ No newline at end of file
diff --git a/subpages/pointManagement/pages/pointList/pointList.json b/subpages/pointManagement/pages/pointList/pointList.json
new file mode 100644
index 0000000..ebbee35
--- /dev/null
+++ b/subpages/pointManagement/pages/pointList/pointList.json
@@ -0,0 +1,9 @@
+{
+ "usingComponents": {
+ "wux-date-picker": "../../../../dist/date-picker/index",
+ "wux-select": "../../../../dist/select/index",
+ "load-more": "../../../../components/loadMore/loadMore",
+ "no-data": "../../../../components/nodata/nodata"
+ },
+ "navigationBarTitleText": "核销记录"
+}
\ No newline at end of file
diff --git a/subpages/pointManagement/pages/pointList/pointList.wxml b/subpages/pointManagement/pages/pointList/pointList.wxml
new file mode 100644
index 0000000..bd794ea
--- /dev/null
+++ b/subpages/pointManagement/pages/pointList/pointList.wxml
@@ -0,0 +1,59 @@
+
+
+ 时间
+
+
+ {{displayValue1}}
+
+
+
+ 至
+
+
+ {{displayValue2}}
+
+
+
+
+
+
+
+
+
+ 所属网格
+
+
+ {{displayValue3}}
+
+
+
+
+
+
+
+ 用户
+ 兑换时间
+ 核销说明
+ 积分
+
+
+
+
+ {{item.realName}}
+ {{item.operationTime}}
+
+ {{item.operationType==='1'? '+':'-'}}{{item.points}}
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/subpages/pointManagement/pages/pointList/pointList.wxss b/subpages/pointManagement/pages/pointList/pointList.wxss
new file mode 100644
index 0000000..fc9bea6
--- /dev/null
+++ b/subpages/pointManagement/pages/pointList/pointList.wxss
@@ -0,0 +1,202 @@
+page {
+ background: #fff;
+}
+
+.point-list-box {
+ box-sizing: border-box;
+ height: auto;
+ width: 100%;
+}
+
+.select-time {
+ box-sizing: border-box;
+ height: 100rpx;
+ width: 100%;
+ background: #fff;
+ display: flex;
+ align-items: center;
+ padding: 20rpx;
+}
+
+.select-time1 {
+ color: #333;
+ font-size: 32rpx;
+}
+
+.seleted {
+ width: 100%;
+ height: 194rpx;
+ box-sizing: border-box;
+ background: #fff;
+ /* overflow: hidden; */
+}
+
+.select_box {
+ background: #fff;
+ width: 280rpx;
+ height: 64rpx;
+ margin: 0 auto;
+}
+
+.select {
+ box-sizing: border-box;
+ width: 100%;
+ height: 58rpx;
+ border: 1px solid #efefef;
+ border-radius: 8rpx;
+ display: flex;
+ align-items: center;
+ padding: 0 15rpx;
+ background: #F4F4F4;
+}
+
+.select_text {
+ font-size: 24rpx;
+ flex: 1;
+ color: #BABABA;
+}
+
+.select_img {
+ width: 40rpx;
+ height: 40rpx;
+ display: block;
+ transition: transform 0.3s;
+}
+
+.select_img_rotate {
+ transform: rotate(180deg);
+}
+
+.option_box {
+ position: absolute;
+ top: 58rpx;
+ left: 20rpx;
+ width: 661rpx;
+ /* border: 1px solid #efefef; */
+ box-sizing: border-box;
+ height: 0;
+ overflow-y: auto;
+ border-top: 0;
+ background: #fff;
+ transition: height 0.3s;
+ z-index: 999;
+}
+
+.option {
+ display: block;
+ line-height: 40rpx;
+ font-size: 30rpx;
+ border-bottom: 1px solid #efefef;
+ padding: 10rpx;
+ margin-left: 10rpx;
+ color: #BABABA;
+}
+
+.image {
+ width: 28rpx;
+ height: 28rpx;
+}
+
+.select-and {
+ color: #666;
+ font-size: 30rpx;
+}
+
+/* 下来框样式结束 */
+.point-content {
+ box-sizing: border-box;
+ width: 100%;
+ height: auto;
+ background: #fff;
+ /* margin-top: 20rpx; */
+ padding: 20rpx;
+}
+
+.content-grid {
+ display: flex;
+ font-size: 32rpx;
+ color: #333;
+}
+
+.exchange-time .time-title {
+ box-sizing: border-box;
+ width: 100%;
+ font-weight: bold;
+ font-size: 26rpx;
+ color: #151515;
+ margin-top: 30rpx;
+ /* display: flex;
+ justify-content: space-between; */
+}
+
+.exchange-time .time-item-box .time-item {
+ box-sizing: border-box;
+ width: 100%;
+ display: flex;
+ /* justify-content: space-between; */
+ font-size: 26rpx;
+ margin-top: 50rpx;
+}
+
+
+
+.exchange-time .time-item-box .time-item .time-item-name {
+ width: 20%;
+ color: #151515;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ margin-right: 20rpx;
+}
+
+.exchange-time .time-item-box .time-item .time-item-time {
+ color: #151515;
+ margin-right: 20rpx;
+}
+
+.exchange-time .time-item-box .time-item .time-item-remark {
+ width: 25%;
+ color: #151515;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ margin-right: 10rpx;
+}
+
+.exchange-time .time-item-box .time-item .time-item-num {
+ width: 10%;
+ color: #D60000;
+ text-align: center;
+}
+
+.point-footer {
+ box-sizing: border-box;
+ width: 100%;
+ display: flex;
+ /* justify-content: right; */
+ justify-content: flex-end;
+ align-items: center;
+ position: fixed;
+ bottom: 0rpx;
+ z-index: 3;
+ padding: 20rpx;
+ border-radius: 10rpx;
+ background: #f6f6f6;
+}
+
+.point-footer-text {
+ font-weight: bold;
+ color: #333;
+ font-size: 32rpx;
+}
+
+.point-footer-num {
+ font-weight: bold;
+ color: #D60000;
+ font-size: 34rpx;
+}
+
+.load-more-exchange {
+ background: #fff !important;
+ margin-bottom: 100rpx !important;
+}
\ No newline at end of file