From 17d991dc11f5d00a07e5f14515cc6b950c6c2df0 Mon Sep 17 00:00:00 2001 From: whycq <123456> Date: 星期四, 12 五月 2022 12:34:12 +0800 Subject: [PATCH] # --- pages/basics/sale.vue | 372 +++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 315 insertions(+), 57 deletions(-) diff --git a/pages/basics/sale.vue b/pages/basics/sale.vue index b04ad91..653efe9 100644 --- a/pages/basics/sale.vue +++ b/pages/basics/sale.vue @@ -1,46 +1,50 @@ <template> <view> - <!-- 鎼滅储鏍� --> - <view> - <view class="cu-bar bg-white search"> - <view class="search-form radius"> - <text class="cuIcon-search"></text> - <input :adjust-position="false" type="text" placeholder="鎵爜 / 杈撳叆 (鍗曟嵁缂栧彿)" confirm-type="search"></input> - <text class="cuIcon-close"></text> + <scroll-view scroll-y> + <view> + <view class="search-box"> + <view class="search-area"> + <view class="search-icon"><uni-icons type="search" size="25" color="#a5a5a5"></uni-icons></view> + <input type="text" v-model="orderNo" placeholder="鎵爜 / 杈撳叆(璁㈠崟缂栧彿)" @input="search()"/> + <view class="close-icon" @click="reset()"><uni-icons type="closeempty" size="25" color="#a5a5a5"></uni-icons></view> + </view> </view> - <view class="action"> - <button class="cu-btn bg-yellow" style="color: #fff;">鎼� 绱�</button> - </view> - </view> - </view> - <view class="margin-top"> - <uni-table border stripe type="selection" emptyText="娌℃湁鏇村鏁版嵁"> - <!-- 琛ㄥご --> - <uni-tr > - <uni-th align="center" width="200">璁㈠崟</uni-th> - <uni-th align="center">搴斿叆搴撻噺</uni-th> - <uni-th align="center">宸插叆搴撻噺</uni-th> - <uni-th align="center" width="200">鍟嗗搧缂栫爜</uni-th> - <uni-th align="center">鍟嗗搧鍚嶇О</uni-th> - <uni-th align="center">璁㈠崟鐘舵��</uni-th> - <uni-th align="center"width="200">鎿嶄綔</uni-th> - </uni-tr> - <!-- 琛ㄤ綋 --> - <uni-tr v-for="(item, index) in tabData" :key="index"> - <uni-td align="center">{{item.orderNo}}</uni-td> - <uni-td align="center">{{item.anfme}}</uni-td> - <uni-td align="center">{{item.inQty}}</uni-td> - <uni-td align="center">{{item.matnr}}</uni-td> - <uni-td align="center">{{item.maktx}}</uni-td> - <uni-td align="center">{{item.state$}}</uni-td> - <uni-td> - <view class="flex justify-around"> - <button class="cu-btn bg-orange sm">涓� 鏋�</button> - <button class="cu-btn bg-red sm">鎾ら攢涓婃灦</button> + <checkbox-group @change="checkbox"> + <label v-for="(item,index) in data" :key="index" class="demo-list bg-false" :class="'bg-'+item.checked" > + <view class="demo-list-left"> + <checkbox :value="item.id+''" :checked="item.checked" style="display: block;" /> </view> - </uni-td> - </uni-tr> - </uni-table> + <view class="demo-list-right"> + <!-- <view><text style="font-weight: bold;">搴忓彿锛歿{index+1}}</text></view> --> + <view class="order-ditel"><text class="index">No.{{index+1}}</text><text class="orderNo">{{item.orderNo}}</text></view> + <view><text style="width: 400rpx;">鍟嗗搧缂栫爜锛歿{item.matnr}}</text></view> + <view> + <text>搴斿叆鏁伴噺锛歿{item.anfme}}</text> + <text>鍟嗗搧鍚嶇О锛歿{item.maktx}}</text> + </view> + <view> + <text>宸插叆鏁伴噺锛歿{item.inQty}}</text> + <text style="width: auto;">璁㈠崟鐘舵�侊細</text><text :class="state$"> {{item.state$}}</text> + </view> + </view> + </label> + </checkbox-group> + </view> + </scroll-view> + <view class="footer flex justify-around"> + <label class="label-btn" style="width: 150rpx;"> + <checkbox :checked="check" @click="allChecked()">{{checkText}}</checkbox> + </label> + <label class="label-btn" style="width: 100rpx;"> + <text @click="reChecked()">鍙嶉��</text> + </label> + + <label class="label-btn" style="width: 170rpx;"> + <button class="cu-btn bg-red ">鎾ら攢涓婃灦</button> + </label> + <label class="label-btn"> + <button class="cu-btn bg-blue " @click="shangjia()">涓婃灦</button> + </label> </view> </view> </template> @@ -49,35 +53,289 @@ export default { data() { return { - tabData:[], + data: [], + orderNo:'', + needData:{}, + check:false, + checkText:'鍏ㄩ��', + checkedData:[], + state$:'', } }, - mounted(){ + mounted() { const UIP = uni.getStorageSync('UIP'); this.baseIP = UIP; const UPORT = uni.getStorageSync('UPORT'); this.basePORT = UPORT; - let that = this; - uni.request({ - url: that.baseHttp + that.baseIP + ':' +that.basePORT + that.baseUrl + "/receiveDetl/list/auth", - header:{'token':uni.getStorageSync('token')}, - success(res) { - var res = res.data - if (res.code === 200) { - that.tabData = res.data.records - console.log(that.tabData) - } - } - }) - }, - onLoad() { - + this.render() }, methods: { - + // 鎼滅储 + search() { + let that = this; + // that.tabData.forEach(function(e){ + // that.searchData = e.orderNo + // }) + this.render(that.orderNo) + }, + // 閲嶇疆 + reset() { + let that = this; + if (that.orderNo == '') { + uni.vibrateShort(); + } else { + uni.vibrateLong(); + } + that.orderNo = ''; + that.needData['order_no'] = ''; + that.getData(); + + + }, + // 琛ㄦ牸鍔犺浇 + render(param) { + let that = this; + if(param) { + that.needData['order_no'] = param; + that.getData(); + } else { + that.getData(); + } + }, + getData() { + let that = this + uni.request({ + url: that.baseHttp + that.baseIP + ':' +that.basePORT + that.baseUrl + "/receiveDetl/list/auth", + header:{'token':uni.getStorageSync('token')}, + data: that.needData, + success(res) { + var res = res.data + if (res.code === 200) { + that.data = res.data.records + } + for (var i = 0; i < that.data.length; i++) { + if (that.data[i].state$ == "鏈叆搴�") { + that.state$ = 'color-red' + } else { + console.log(2) + } + + } + } + }) + }, + checkbox: function (e) { + var items = this.data, + values = e.detail.value; + for (var i = 0, lenI = items.length; i < lenI; ++i) { + const item = items[i] + item.id = item.id + '' + if(values.indexOf(item.id) >= 0){ + this.$set(item,'checked',true) + }else{ + this.$set(item,'checked',false) + } + } + if (values.length == items.length) { + this.check = true + this.checkText = "鍙栨秷鍏ㄩ��" + } else { + this.check = false + this.checkText = "鍏ㄩ��" + } + uni.vibrateShort(); + }, + reChecked() { // 鍙嶉�� + var checkArr = [] + for (var i = 0; i < this.data.length;i++) { + if (this.data[i].checked == true) { + this.$set(this.data[i],'checked',false) + }else{ + this.$set(this.data[i],'checked',true) + } + if (this.data[i].checked == true) { + checkArr.push(this.data[i].checked) + } + } + if (checkArr.length == this.data.length) { + this.check = true + this.checkText = "鍙栨秷鍏ㄩ��" + } else { + this.check = false + this.checkText = "鍏ㄩ��" + } + uni.vibrateShort(); + }, + allChecked(e){ // 鍏ㄩ�� + if (this.check == true) { + for (var i = 0; i < this.data.length;i++) { + this.$set(this.data[i],'checked',false) + } + this.check = false + this.checkText = "鍏ㄩ��" + } else { + for (var i = 0; i < this.data.length;i++) { + this.$set(this.data[i],'checked',true) + } + this.check = true + this.checkText = "鍙栨秷鍏ㄩ��" + } + uni.vibrateShort(); + }, + shangjia() { + this.checkedData = [] + for (var i = 0; i < this.data.length; i++) { + if (this.data[i].checked == true) { + this.checkedData.push(this.data[i]) + } + } + uni.vibrateShort(); + console.log(this.checkedData) + } } } </script> <style> + .search-box { + position: fixed; + left: 0; + top: 0; + width: 100%; + height: 100rpx; + background-color: #FFF; + border-bottom: 1px solid #d8d8d8; + border-radius: 0 0 20rpx 20rpx; + z-index: 1; + } + /*#ifdef H5 */ + .search-box { + position: fixed; + left: 0; + top: 60rpx; + width: 100%; + height: 100rpx; + background-color: #ffffff; + border-bottom: 1px solid #d8d8d8; + border-radius: 0 0 20rpx 20rpx; + z-index: 1; + } + /* #endif */ + .search-area { + background-color: #F1F1F1; + width: 96%; + height: 70%; + margin: 15rpx; + border-radius: 15rpx; + } + .search-area input { + display: inline-block; + height: 70rpx; + width: 70%; + line-height: 70rpx; + font-size: 25rpx; + font-weight: 400; + } + .search-icon { + display: inline-block; + float: left; + width: 70rpx; + height: 70rpx; + text-align: center; + line-height: 70rpx; + + } + .close-icon { + display: inline-block; + float: right; + width: 70rpx; + height: 70rpx; + text-align: center; + line-height: 70rpx; + } + .bg-false { + background-color: #FFFFFF; + } + .bg-true { + background-color: #ebebeb; + } + + .demo-list { + border-bottom: 1px solid #d8d8d8; + height: 180rpx; + margin: 15rpx; + border-radius: 20rpx; + } + .demo-list:first-child { + margin-top: 120rpx; + } + .demo-list:last-child { + margin-bottom: 120rpx; + } + label { + display: block; + } + .demo-list-left { + display: inline-block; + float: left; + text-align: center; + width: 100rpx; + height: 180rpx; + line-height: 180rpx; + } + .demo-list-right { + display: inline-block; + float: left; + height: 180rpx; + color: #828282; + } + .order-ditel { + height: 60rpx; + width: 600rpx; + line-height: 60rpx; + } + + .demo-list-right .index { + width: 120rpx; + height: 25rpx; + line-height: 25rpx; + font-size: 40rpx; + border-right: 4rpx solid #6f6f6f; + padding-left: 0px; + padding-right: 10rpx; + color: #3b3b3b; + /* background-color: #007AFF; */ + } + .demo-list-right .orderNo { + padding-left: 30rpx; + font-size: 35rpx; + width: 400rpx; + color: #3b3b3b; + /* background-color: #0A98D5; */ + } + .demo-list-right .vertical-bar { // 绔栨潬 + /* background-color: #6739B6; */ + width: 50rpx; + font-size: 30rpx; + text-align: center; + } + .demo-list-right text { + display: inline-block; + width: 250rpx; + font-size: 25rpx; + } + .color-red { + width: auto; + font-weight: 700; + color: #e74f4f; + } + + + .label-btn { + width: 150rpx; + } + checkbox { + /* transform:scale(0.7) */ + } + </style> -- Gitblit v1.9.1