开发原因:
在开发销售订单时,一个页面要显示主单,在点击主单一行时,显示对应的明细信息。搜索时,还要根据销售时间段、支付类型、营业员、销售类型、是否挂单、价格、销售数量等进行主单查询,同时还要根据销售明细的产品名称、产品编号、助记码等进行查询,如何将这些复杂的需求在同一页面展示出来,就需要进行合理的设计,下面我来一一讲述
页面展示效果图:
1、构件搜索栏
为每一项绑定getDataList()事件,用于在设置了搜索条件时立即触动搜索功能
<el-form :inline="true" :model="dataForm" ref="dataFormRef" @keyup.enter.native="getDataList()">
<el-form-item>
销售日期:
<el-date-picker v-model="dataForm.queryDates" type="daterange" value-format="yyyy-MM-dd" range-separator="至"
start-placeholder="开始日期" end-placeholder="结束日期" size="mini" @blur="getDataList()" clearable>
</el-date-picker>
</el-form-item>
<el-form-item>
支付类型:
<el-select size="mini" v-model="dataForm.payType" clearable placeholder="请选择" @change="getDataList()"
@clear="getDataList()">
<el-option value="1" label="现金"></el-option>
<el-option value="2" label="支付宝"></el-option>
<el-option value="3" label="微信"></el-option>
<el-option value="4" label="社保卡"></el-option>
<el-option value="5" label="银联"></el-option>
<el-option value="6" label="其它"></el-option>
</el-select>
</el-form-item>
<el-form-item>
营业员:
<el-select size="mini" @focus="getUsers()" @change='getDataList()' v-model="dataForm.saleUser" clearable placeholder="请选择"
@clear="getDataList()">
<el-option v-for="item in users" :key="item.userId" :label="item.username" :value="item.username">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
选择过滤:
<el-select size="mini" v-model="dataForm.selectField" clearable placeholder="请选择" @change="getDataList(1)"
@clear="getDataList(1)">
<el-option v-for="item in selectFields" :key="item.value" :label="item.label" :value="item.value">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-select size="mini" v-model="dataForm.selectValue" clearable placeholder="请选择" @change="getDataList(1)"
@clear="getDataList(1)">
<el-option label="是" value="1"></el-option>
<el-option label="否" value="0"></el-option>
</el-select>
</el-form-item>
<el-form-item>
数量/价格/金额:
<el-select size="mini" v-model="dataForm.priceField" clearable placeholder="请选择" @change="getDataList(1)"
@clear="getDataList(1)">
<el-option v-for="item in priceFields" :key="item.value" :label="item.label" :value="item.value">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-select size="mini" v-model="dataForm.priceFormula" clearable placeholder="请选择" @change="getDataList(1)"
@clear="getDataList(1)">
<el-option v-for="item in priceFormulas" :key="item.value" :label="item.label" :value="item.value">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-input size="mini" v-model="dataForm.priceValue" clearable type="number" placeholder="库存/价格/毛利"
@blur="getDataList(1)" @clear="getDataList(1)"></el-input>
</el-form-item>
<el-form-item>
主单条件查询:
<el-select size="mini" v-model="dataForm.queryField" clearable placeholder="请选择" @change="getDataList()"
@clear="getDataList()">
<el-option v-for="item in queryFields" :key="item.value" :label="item.label" :value="item.value">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-input size="mini" v-model="dataForm.key" placeholder="参数名" clearable @blur="getDataList()"
@clear="getDataList()"></el-input>
</el-form-item>
<el-form-item>
明细条件查询:
<el-select size="mini" v-model="dataForm.queryItemField" clearable placeholder="请选择" @change="getDataList()"
@clear="getDataList()">
<el-option v-for="item in queryItemFields" :key="item.value" :label="item.label" :value="item.value">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-input size="mini" v-model="dataForm.itemKey" placeholder="参数名" clearable @blur="getDataList()"
@clear="getDataList()"></el-input>
</el-form-item>
<el-form-item>
<el-button size="mini" type="success" @click="getDataList()" icon="el-icon-search">查询</el-button>
<el-button @click="resetForm" size="mini" type="warning" icon="el-icon-refresh-left">重置</el-button>
</el-form-item>
</el-form>
2、主表单内容
<el-table :data="dataList" size="mini" v-loading="dataListLoading" @selection-change="selectionChangeHandle"
style="width: 100%;" @cell-click="tableDbEdit" @cell-dblclick="tableDbEdit"
:header-cell-style="{ background: '#fcfcfc', color: '#606266', height:'36px'}" height="320">
<el-table-column type="selection" header-align="center" align="center" width="50">
</el-table-column>
<el-table-column prop="saleNo" header-align="center" align="center" label="销售编号" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="saleType" header-align="center" align="center" label="销售类型">
<template slot-scope="scope">
<el-tag v-if="scope.row.saleType==0" type="danger">退货</el-tag>
<el-tag v-else type="success">销售</el-tag>
</template>
</el-table-column>
<el-table-column prop="saleDate" header-align="center" align="center" label="销售日期" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="backDate" header-align="center" align="center" label="退货日期" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="memberName" header-align="center" align="center" label="会员名称">
</el-table-column>
<el-table-column prop="memberNo" header-align="center" align="center" label="会员编号" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="isPending" header-align="center" align="center" label="是否挂单">
<template slot-scope="scope">
<el-tag v-if="scope.row.isPending==1" type="warning">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="pendingRemark" header-align="center" align="center" label="挂单备注" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="totalSaleNum" header-align="center" align="center" label="共购买">
</el-table-column>
<el-table-column prop="totalPrediscountFee" header-align="center" align="center" label="折前总额">
</el-table-column>
<el-table-column prop="totalMemberFee" header-align="center" align="center" label="会员总额">
</el-table-column>
<el-table-column prop="totalDiscountFee" header-align="center" align="center" label="折后总额">
</el-table-column>
<el-table-column prop="fundPaySumamt" header-align="center" align="center" label="医保基金">
</el-table-column>
<el-table-column prop="toalOtherFee" header-align="center" align="center" label="其它费用">
</el-table-column>
<el-table-column prop="paymentFee" header-align="center" align="center" label="实付金额">
</el-table-column>
<el-table-column prop="receiveFee" header-align="center" align="center" label="实收金额">
</el-table-column>
<el-table-column prop="giveChangeFee" header-align="center" align="center" label="找零金额">
</el-table-column>
<el-table-column prop="totalReduceFee" header-align="center" align="center" label="共优惠(元)" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="totalGiveNum" header-align="center" align="center" label="共赠送数量" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="isPayed" header-align="center" align="center" label="是否支付">
<template slot-scope="scope">
<el-tag v-if="scope.row.isPayed==1" type="success">是</el-tag>
<el-tag v-else type="warning">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="payType" header-align="center" align="center" label="支付类型">
<template slot-scope="scope">
<el-tag v-if="scope.row.isPayed==1" type="success">现金</el-tag>
<el-tag v-else-if="scope.row.isPayed==2" type="primary">支付宝</el-tag>
<el-tag v-else-if="scope.row.isPayed==3" type="warning">微信</el-tag>
<el-tag v-else-if="scope.row.isPayed==4" type="danger">社保卡</el-tag>
<el-tag v-else-if="scope.row.isPayed==5" type="info">银联</el-tag>
<el-tag v-else type="warning">其它</el-tag>
</template>
</el-table-column>
<el-table-column prop="saleUser" header-align="center" align="center" label="营业员">
<template slot-scope="scope">
<el-input size="mini" v-model="scope.row.saleUser" v-if="showInput == `saleUser${scope.row.Id}`"
@blur='blurInput(scope.row, "saleUser", scope.row.saleUser)' v-focus>
</el-input>
<span v-else class="active-input">{{scope.row.saleUser}}</span>
</template>
</el-table-column>
<el-table-column prop="buyerName" header-align="center" align="center" label="购买人">
<template slot-scope="scope">
<el-input size="mini" v-model="scope.row.buyerName" v-if="showInput == `buyerName${scope.row.Id}`"
@blur='blurInput(scope.row, "buyerName", scope.row.buyerName)' v-focus>
</el-input>
<span v-else class="active-input">{{scope.row.buyerName}}</span>
</template>
</el-table-column>
<el-table-column prop="buyerCardId" header-align="center" align="center" label="购买人身份证" width="140" show-overflow-tooltip>
<template slot-scope="scope">
<el-input size="mini" v-model="scope.row.buyerCardId" v-if="showInput == `buyerCardId${scope.row.Id}`"
@blur='blurInput(scope.row, "buyerCardId", scope.row.buyerCardId)' v-focus>
</el-input>
<span v-else class="active-input">{{scope.row.buyerCardId}}</span>
</template>
</el-table-column>
<el-table-column prop="buyerMobile" header-align="center" align="center" label="购买人手机" width="140" show-overflow-tooltip>
<template slot-scope="scope">
<el-input size="mini" v-model="scope.row.buyerMobile" v-if="showInput == `buyerMobile${scope.row.Id}`"
@blur='blurInput(scope.row, "buyerMobile", scope.row.buyerMobile)' v-focus>
</el-input>
<span v-else class="active-input">{{scope.row.buyerMobile}}</span>
</template>
</el-table-column>
<el-table-column prop="singleFee" header-align="center" align="center" label="单张金额">
</el-table-column>
<el-table-column prop="backType" header-align="center" align="center" label="退货状态">
<template slot-scope="scope">
<el-tag v-if="scope.row.backType==1" type="danger">部分退货</el-tag>
<el-tag v-else-if="scope.row.backType==3" type="warning">完全退货</el-tag>
<el-tag v-else type="warning">无退货</el-tag>
</template>
</el-table-column>
<el-table-column prop="orderSource" header-align="center" align="center" label="订单来源">
<template slot-scope="scope">
<el-tag v-if="scope.row.orderSource==1" type="primary">POS</el-tag>
<el-tag v-else type="success">小程序</el-tag>
</template>
</el-table-column>
<el-table-column prop="isOnlinePay" header-align="center" align="center" label="线上支付">
<template slot-scope="scope">
<el-tag v-if="scope.row.isOnlinePay==1" type="primary">线上</el-tag>
<el-tag v-else type="success">线下</el-tag>
</template>
</el-table-column>
<el-table-column prop="storeName" header-align="center" align="center" label="门店名称">
</el-table-column>
<el-table-column prop="storeCode" header-align="center" align="center" label="门店编码">
</el-table-column>
<el-table-column prop="updateTime" header-align="center" align="center" label="修改时间">
</el-table-column>
<el-table-column prop="updateUsername" header-align="center" align="center" label="修改人">
</el-table-column>
<el-table-column prop="remark" header-align="center" align="center" label="备注">
<template slot-scope="scope">
<span v-html="scope.row.remark"></span>
</template>
</el-table-column>
</el-table>
3、子表单
<el-table :data="itemDataList" size="mini" v-loading="dataListLoading" @selection-change="selectionChangeHandle"
style="width: 100%;" @cell-click="tableDbEdit" @cell-dblclick="tableDbEdit" class="item-table" height="250"
:header-cell-style="{ background: '#fcfcfc', color: '#606266', height:'36px'}">
<el-table-column type="selection" header-align="center" align="center" width="50">
</el-table-column>
<el-table-column prop="inboundNo" header-align="center" align="center" label="入库单编号" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="productCode" header-align="center" align="center" label="产品编号">
</el-table-column>
<el-table-column prop="isDrugPiece" header-align="center" align="center" label="中药饮片">
</el-table-column>
<el-table-column prop="gspType" header-align="center" align="center" label="GSP类型">
<template slot-scope="scope">
<el-input size="mini" v-model="scope.row.gspType" v-if="showInput == `gspType${scope.row.Id}`"
@blur='blurInput(scope.row, "gspType", scope.row.gspType)' v-focus>
</el-input>
<span v-else class="active-input">{{scope.row.gspType}}</span>
</template>
</el-table-column>
<el-table-column prop="pinyin" header-align="center" align="center" label="拼音">
</el-table-column>
<el-table-column prop="barCode" header-align="center" align="center" label="条形码">
</el-table-column>
<el-table-column prop="productName" header-align="center" align="center" label="产品名称" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="genericName" header-align="center" align="center" label="通用名称" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="producingArea" header-align="center" align="center" label="产地" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="standard" header-align="center" align="center" label="规格" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="unit" header-align="center" align="center" label="单位">
</el-table-column>
<el-table-column prop="approvalNo" header-align="center" align="center" label="批号">
</el-table-column>
<el-table-column prop="produceFactory" header-align="center" align="center" label="生产单位" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="dosageForm" header-align="center" align="center" label="剂型" width="140" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="expiryDate" header-align="center" align="center" label="有效期" width="110" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="produceDate" header-align="center" align="center" label="生产日期" width="110" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="batchNo" header-align="center" align="center" label="批号" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="lotNo" header-align="center" align="center" label="批次号" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="isRxDrug" header-align="center" align="center" label="是否处方">
<template slot-scope="scope">
<el-tag v-if="scope.row.isRxDrug==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="isEphedrine" header-align="center" align="center" label="含麻黄碱">
<template slot-scope="scope">
<el-tag v-if="scope.row.isEphedrine==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="isGmp" header-align="center" align="center" label="是否GMP">
<template slot-scope="scope">
<el-tag v-if="scope.row.isGmp==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="isSplit" header-align="center" align="center" label="是否拆零药" width="110" >
<template slot-scope="scope">
<el-tag v-if="scope.row.isSplit==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="isYiBao" header-align="center" align="center" label="是否医保">
<template slot-scope="scope">
<el-tag v-if="scope.row.isYiBao==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="stockNum" header-align="center" align="center" label="库存">
</el-table-column>
<el-table-column prop="saleNum" header-align="center" align="center" label="销售数量">
</el-table-column>
<el-table-column prop="costPrice" header-align="center" align="center" label="成本价">
</el-table-column>
<el-table-column prop="costFee" header-align="center" align="center" label="成本金额">
</el-table-column>
<el-table-column prop="originalPrice" header-align="center" align="center"label="原价">
</el-table-column>
<el-table-column prop="originalFee" header-align="center" align="center" label="原价金额">
</el-table-column>
<el-table-column prop="salePrice" header-align="center" align="center" label="出售价">
</el-table-column>
<el-table-column prop="saleFee" header-align="center" align="center" label="出售金额">
</el-table-column>
<el-table-column prop="retailPrice" header-align="center" align="center" label="指导价">
</el-table-column>
<el-table-column prop="retailFee" header-align="center" align="center" label="指导金额">
</el-table-column>
<el-table-column prop="tradePrice" header-align="center" align="center" label="批发价">
</el-table-column>
<el-table-column prop="tradeFee" header-align="center" align="center" label="批发额">
</el-table-column>
<el-table-column prop="memberPrice" header-align="center" align="center" label="会员价">
</el-table-column>
<el-table-column prop="memberFee" header-align="center" align="center" label="会员金额">
</el-table-column>
<el-table-column prop="discount" header-align="center" align="center" label="折扣">
</el-table-column>
<el-table-column prop="discountFee" header-align="center" align="center" label="折扣金额">
</el-table-column>
<el-table-column prop="isOnlinePay" header-align="center" align="center" label="线上支付">
<template slot-scope="scope">
<el-tag v-if="scope.row.isOnlinePay==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="saleType" header-align="center" align="center" label="订单类型">
</el-table-column>
<el-table-column prop="hasPromotion" header-align="center" align="center" label="是否促销">
<template slot-scope="scope">
<el-tag v-if="scope.row.hasPromotion==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="promotionReduceFee" header-align="center" align="center" label="促销减少额" width="120">
</el-table-column>
<el-table-column prop="promotionName" header-align="center" align="center" label="促销名称">
</el-table-column>
<el-table-column prop="promotionGiveNum" header-align="center" align="center" label="促销赠送数" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="promotionGiveFee" header-align="center" align="center" label="赠品总成本" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="promotionGiveProductNames" header-align="center" align="center" label="促销赠品名称" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="isPausePromotion" header-align="center" align="center" label="暂停促销">
<template slot-scope="scope">
<el-tag v-if="scope.row.isPausePromotion==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="saleUser" header-align="center" align="center" label="营业员">
</el-table-column>
<el-table-column prop="isGiveProduct" header-align="center" align="center" label="是否赠品">
</el-table-column>
<el-table-column prop="giveProdcutParentCode" header-align="center" align="center" label="赠品对应产品" width="130" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="isCommission" header-align="center" align="center" label="是否提成">
</el-table-column>
<el-table-column prop="commissionRadio" header-align="center" align="center" label="提成比例">
</el-table-column>
<el-table-column prop="commissionFee" header-align="center" align="center" label="提成金额">
</el-table-column>
<el-table-column prop="couponInfo" header-align="center" align="center" label="优惠券">
</el-table-column>
<el-table-column prop="isReward" header-align="center" align="center" label="是否奖励">
<template slot-scope="scope">
<el-tag v-if="scope.row.isReward==1" type="primary">是</el-tag>
<el-tag v-else type="info">否</el-tag>
</template>
</el-table-column>
<el-table-column prop="rewardState" header-align="center" align="center" label="奖励发放状态" width="120" show-overflow-tooltip>
<template slot-scope="scope">
<el-tag v-if="scope.row.rewardState==1" type="primary">已发放</el-tag>
<el-tag v-else type="info">未发放</el-tag>
</template>
</el-table-column>
<el-table-column prop="rewardFee" header-align="center" align="center" label="奖励金额">
</el-table-column>
<el-table-column prop="rewardDate" header-align="center" align="center" label="奖励发放时间" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="updateTime" header-align="center" align="center" label="修改时间" width="120" show-overflow-tooltip>
</el-table-column>
<el-table-column prop="updateUsername" header-align="center" align="center" label="修改人">
</el-table-column>
<el-table-column prop="remark" header-align="center" align="center" label="备注">
<template slot-scope="scope">
<span v-html="scope.row.remark"></span>
</template>
</el-table-column>
</el-table>
<el-pagination @size-change="sizeChangeHandle" @current-change="currentChangeHandle" :current-page="pageIndex"
:page-sizes="[10, 20, 50, 100]" :page-size="pageSize" :total="totalPage"
layout="total, sizes, prev, pager, next, jumper">
</el-pagination>
4、JS模块定义data数据
data() {
return {
dataForm: {
queryDates:[], //保存日期信息
key: null, //主表搜索
queryField: null, //查询字段
itemKey: null, //明细查询内容
queryItemField: null, //明细查询字段
payType: null, //支付方式 类型
saleUserId: null,
saleUser: null, //营业员
selectField: null, //选择查询字段
selectValue: null, //选择查询值
priceField: null, //价格自段
priceFormula: null, //运算符号
priceValue: null, //价格值
},
users: [], //保存用户信息
selectFields: [],
priceFields: [],
priceFormulas: [],
units: [],
queryFields: [],
queryItemFields: [],
dataList: [], //主表数据
itemDataList: [], //字表数据
pageIndex: 1,
pageSize: 10,
totalPage: 0,
dataListLoading: false,
dataListSelections: [],
addOrUpdateVisible: false
}
},
5、JS模块初始化data信息
activated() {
this.getDataList()
this.initQueryParams()
},
methods: {
// 获取数据列表
async getDataList() {
this.dataListLoading = true
let newDataForm = _.cloneDeep(this.dataForm)
let queryDates = newDataForm.queryDates || [];
newDataForm.queryDates = queryDates.join(",")
const res = await this.$http({
url: `/sale/saleorder/page`,
method: 'get',
params: this.$http.adornParams({
'page': this.pageIndex,
'limit': this.pageSize,
'dataForm': newDataForm
})
})
let data = res.data
if (data && data.code === 0) {
this.dataList = data.page.list
this.totalPage = data.page.totalCount
this.dataList.forEach(item => {
item.status = item.status == 1 ? true : false
})
if (this.dataList.length > 0) {
this.getItemDataList(this.dataList[0].saleId)
}else{
this.itemDataList = []
}
} else {
this.dataList = []
this.totalPage = 0
}
this.dataListLoading = false
},
async getItemDataList(saleId) {
const res = await this.$http({
url: `/sale/saleorderdetail/listByOrderId`,
method: 'get',
params: this.$http.adornParams({
saleId
})
})
let data = res.data
if (data && data.code === 0) {
this.itemDataList = data.list
} else {
this.itemDataList = []
}
},
// 每页数
sizeChangeHandle(val) {
this.pageSize = val
this.pageIndex = 1
this.getDataList()
},
// 当前页
currentChangeHandle(val) {
this.pageIndex = val
this.getDataList()
},
// 多选
selectionChangeHandle(val) {
this.dataListSelections = val
},
resetForm() {
this.$nextTick(() => {
this.dataForm = this.$options.data().dataForm
this.getDataList()
})
},
async getUsers() {
const res = await this.$http({
url: `/sys/user/listUsers`,
method: 'get',
params: this.$http.adornParams()
})
let data = res.data
if (data && data.code === 0) {
this.users = data.data
}
},
initQueryParams() {
let selectFields = [{
value: 'sale_type',
label: '是否退货'
}, {
value: 'is_pending',
label: '是否挂单'
}, {
value: 'is_payed',
label: '是否支付'
}, {
value: 'is_online_pay',
label: '是否线上支付'
}];
let priceFields = [{
value: 'total_sale_num',
label: '销售总数量'
}, {
value: 'total_prediscount_fee',
label: '折前总金额'
}, {
value: 'total_member_fee',
label: '会员价总金额'
}, {
value: 'fund_pay_sumamt',
label: '医保基金'
},{
value: 'toal_other_fee',
label: '其它费用总额'
}, {
value: 'payment_fee',
label: '实付金额'
}, {
value: 'receive_fee',
label: '实收金额'
}, {
value: 'give_change_fee',
label: '找零金额'
}, {
value: 'total_reduce_fee',
label: '优惠金额'
}, {
value: 'total_give_num',
label: '赠送数量'
}];
let priceFormulas = [{
value: 'GE',
label: '大于等于'
}, {
value: 'EQ',
label: '等于'
}, {
value: 'GT',
label: '大于'
}, {
value: 'LE',
label: '小于等于'
}, {
value: 'LT',
label: '小于'
}, {
value: 'NE',
label: '不等于'
}, ]
let queryFields = [{
value: 'sale_no',
label: '销售编码'
}, {
value: 'member_mame',
label: '会员名称'
}, {
value: 'member_no',
label: '会员编号'
}, {
value: 'sale_user',
label: '营业员名称'
}, {
value: 'audit_username',
label: '审核人'
}]
let queryItemFields = [{
value: 'product_code',
label: '编码'
}, {
value: 'bar_code',
label: '条形码'
}, {
value: 'product_name',
label: '产品名称'
}, {
label: '通用名'
}, {
value: 'producing_area',
label: '产地'
}, {
value: 'produce_factory',
label: '厂家'
}, {
value: 'dosage_form',
label: '剂型'
}, {
value: 'standard',
label: '规格'
}, {
value: 'approval_no',
label: '批准文号'
}]
this.selectFields = selectFields;
this.priceFields = priceFields;
this.priceFormulas = priceFormulas;
this.queryFields = queryFields;
this.queryItemFields = queryItemFields;
}
},
6、后台查询实现
6.1、控制层
@ApiOperation("获取分页列表")
@GetMapping("/page")
@RequiresPermissions("sale:saleorder:list")
public R page(@RequestParam Map<String, Object> params) {
PageUtils page = saleOrderService.queryPage(params);
return R.ok().put("page", page);
}
6.2、实现层
@Override
public PageUtils queryPage(Map<String, Object> params) {
QueryWrapper<SaleOrderEntity> wrapper = new QueryWrapper<>();
List<Long> ids = new ArrayList<>();
boolean isItemQuery = false;
Object dataForm = params.get("dataForm");
if (dataForm != null) {
SaleQueryVo queryVo = JSON.parseObject(dataForm + "", SaleQueryVo.class);
String queryDates = queryVo.getQueryDates();
String itemKey = queryVo.getItemKey();
String queryItemField = queryVo.getQueryItemField();
if (queryVo != null) {
//子查询,获取明细ID
if (MyStrUtil.isNotEmpty(itemKey) && MyStrUtil.isNotEmpty(queryItemField)) {
isItemQuery = true;
QueryWrapper<SaleOrderDetailEntity> itemWrapper = new QueryWrapper<>();
itemWrapper.like(queryItemField, itemKey);
List<SaleOrderDetailEntity> list = saleOrderDetailService.list(itemWrapper);
if (CollectionUtils.isNotEmpty(list)) {
for (SaleOrderDetailEntity detailEntity : list) {
ids.add(detailEntity.getSaleId());
}
}
}
if (MyStrUtil.isNotEmpty(queryDates)) {
String[] queryDateArr = queryDates.split(",");
String startDate = queryDateArr[0];
String endDate = queryDateArr[1];
wrapper.ge(MyStrUtil.isNotEmpty(startDate), "sale_date", startDate);
wrapper.le(MyStrUtil.isNotEmpty(endDate), "sale_date", endDate);
}
WrapperUtil.initSaleQueryWrapper(params, wrapper);
}
}
IPage<SaleOrderEntity> page = new Query<SaleOrderEntity>().getPage(params);
if (isItemQuery) {
if (CollectionUtils.isNotEmpty(ids)) {
page = baseMapper.listPage(page, wrapper, ids);
}
} else {
page = baseMapper.selectPage(page, wrapper);
}
return new PageUtils(page);
}
6.3、封装查询参数实体类
@Data
public class SaleQueryVo {
@ApiModelProperty(value = "查询日期")
private String queryDates;
@ApiModelProperty(value = "审批状态")
private Integer auditStatus;
@ApiModelProperty(value = "支付类型")
private Integer payType;
@ApiModelProperty(value = "营业员id")
private String saleUserId;
@ApiModelProperty(value = "营业员名称")
private String saleUser;
@ApiModelProperty(value = "查询关键字")
private String key;
@ApiModelProperty(value = "是否判断字段")
private String selectField;
@ApiModelProperty(value = "是否判断值")
private Integer selectValue;
@ApiModelProperty(value = "数量价格字段")
private String priceField;
@ApiModelProperty(value = "数量价格符号")
private String priceFormula;
@ApiModelProperty(value = "数量价格值")
private BigDecimal priceValue;
@ApiModelProperty(value = "查询字段")
private String queryField;
@ApiModelProperty(value = "明细查询关键字")
private String itemKey;
@ApiModelProperty(value = "明细查询字段")
private String queryItemField;
}
6.4、数据接口Dao层
@Mapper
public interface SaleOrderDao extends BaseMapper<SaleOrderEntity> {
IPage<SaleOrderEntity> listPage(@Param("page") IPage<SaleOrderEntity> page, @Param(Constants.WRAPPER) QueryWrapper<SaleOrderEntity> wrapper, @Param("ids") List<Long> ids);
}
6.5、数据实现层
<select id="listPage" resultType="com.koo.modules.sale.entity.SaleOrderEntity">
SELECT * FROM sale_order
<if test="ew != null and ew.customSqlSegment != null and ew.customSqlSegment != ''">
${ew.customSqlSegment}
<if test="ids !=null and ids.size()>0">
AND sale_id IN
<foreach item="item" index="index" collection="ids" open="(" close=")" separator=",">
#{item}
</foreach>
</if>
</if>
<if test="ew == null || ew.customSqlSegment == null || ew.customSqlSegment == ''">
<if test="ids !=null and ids.size()>0">
WHERE sale_id IN
<foreach item="item" index="index" collection="ids" open="(" close=")" separator=",">
#{item}
</foreach>
</if>
</if>
</select>
7、根据主单id查询明细
@ApiOperation("获取全部列表")
@RequestMapping("/listByOrderId")
@RequiresPermissions("sale:saleorderdetail:list")
public R listByOrderId(String saleId){
List<SaleOrderDetailEntity> list = saleOrderDetailService.listByOrderId(saleId);
return R.ok().put("list", list);
}
@Override
public List<SaleOrderDetailEntity> listByOrderId(String saleId) {
LambdaQueryWrapper<SaleOrderDetailEntity> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(MyStrUtil.isNotEmpty(saleId), SaleOrderDetailEntity::getSaleId, saleId);
return this.list(wrapper);
}