Browse Source

对接德邦物流

master
前端-胡立永 5 days ago
parent
commit
8276c88697
22 changed files with 1558 additions and 186 deletions
  1. BIN
      admin-pc/dist.zip
  2. +671
    -0
      admin-pc/src/views/commontOrder/CommonOrderList.vue
  3. +255
    -0
      admin-pc/src/views/commontOrder/modules/CommonOrderModal.vue
  4. +21
    -0
      delete_orders_before_july10.sql
  5. +15
    -1
      module-common/src/main/java/org/jeecg/api/controller/AppletOrderController.java
  6. +3
    -1
      module-common/src/main/java/org/jeecg/api/service/AppletOrderTeamService.java
  7. +3
    -0
      module-common/src/main/java/org/jeecg/api/service/impl/AppletIndexServiceImpl.java
  8. +26
    -5
      module-common/src/main/java/org/jeecg/api/service/impl/AppletLoginServiceImpl.java
  9. +16
    -11
      module-common/src/main/java/org/jeecg/api/service/impl/AppletMoneyLogServiceImpl.java
  10. +14
    -5
      module-common/src/main/java/org/jeecg/api/service/impl/AppletOrderServiceImpl.java
  11. +73
    -13
      module-common/src/main/java/org/jeecg/api/service/impl/AppletOrderTeamServiceImpl.java
  12. +170
    -88
      module-common/src/main/java/org/jeecg/api/service/impl/AppletPromotionServiceImpl.java
  13. +3
    -0
      module-common/src/main/java/org/jeecg/modules/commonMoneyLog/entity/CommonMoneyLog.java
  14. +15
    -1
      module-common/src/main/java/org/jeecg/modules/commonOrder/controller/CommonOrderController.java
  15. +47
    -40
      module-common/src/main/java/org/jeecg/modules/commonOrder/entity/CommonOrder.java
  16. +1
    -1
      module-common/src/main/java/org/jeecg/modules/commonOrder/mapper/CommonOrderMapper.java
  17. +2
    -1
      module-common/src/main/java/org/jeecg/modules/commonOrder/service/ICommonOrderService.java
  18. +21
    -9
      module-common/src/main/java/org/jeecg/modules/commonOrder/service/impl/CommonOrderServiceImpl.java
  19. +62
    -3
      module-common/src/main/java/org/jeecg/modules/commonOrder/vue/CommonOrderList.vue
  20. +23
    -2
      module-common/src/main/java/org/jeecg/modules/commonOrder/vue/modules/CommonOrderModal.vue
  21. +97
    -5
      module-common/src/main/java/org/jeecg/modules/commonOrder/vue3/CommonOrder.data.ts
  22. +20
    -0
      module-system/src/main/resources/application-dev.yml

BIN
admin-pc/dist.zip View File


+ 671
- 0
admin-pc/src/views/commontOrder/CommonOrderList.vue View File

@ -0,0 +1,671 @@
<template>
<a-card :bordered="false">
<!-- 查询区域 -->
<div class="table-page-search-wrapper">
<a-form layout="inline" @keyup.enter.native="searchQuery">
<a-row :gutter="24">
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="订单状态">
<j-dict-select-tag placeholder="请选择订单状态" v-model="queryParam.state" dictCode="order_type"/>
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="流程状态">
<j-dict-select-tag placeholder="请选择流程状态" v-model="queryParam.status" dictCode="order_state"/>
</a-form-item>
</a-col>
<template v-if="toggleSearchStatus">
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="下单用户">
<j-search-select-tag placeholder="请选择下单用户" v-model="queryParam.userId" dict="han_hai_member,nick_name,id"/>
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="联系电话">
<a-input placeholder="请输入联系电话" v-model="queryParam.phone"></a-input>
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="物流编码">
<a-input placeholder="请输入物流编码" v-model="queryParam.wliuNo"></a-input>
</a-form-item>
</a-col>
</template>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
<a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
<a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
<a @click="handleToggleSearch" style="margin-left: 8px">
{{ toggleSearchStatus ? '收起' : '展开' }}
<a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>
</a>
</span>
</a-col>
</a-row>
</a-form>
</div>
<!-- 查询区域-END -->
<!-- 操作按钮区域 -->
<!-- <div class="table-operator">-->
<!-- <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>-->
<!-- <a-button type="primary" icon="download" @click="handleExportXls('订单信息表')">导出</a-button>-->
<!-- <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">-->
<!-- <a-button type="primary" icon="import">导入</a-button>-->
<!-- </a-upload>-->
<!-- &lt;!&ndash; 高级查询区域 &ndash;&gt;-->
<!-- <j-super-query :fieldList="superFieldList" ref="superQueryModal" @handleSuperQuery="handleSuperQuery"></j-super-query>-->
<!-- <a-dropdown v-if="selectedRowKeys.length > 0">-->
<!-- <a-menu slot="overlay">-->
<!-- <a-menu-item key="1" @click="batchDel"><a-icon type="delete"/>删除</a-menu-item>-->
<!-- </a-menu>-->
<!-- <a-button style="margin-left: 8px"> 批量操作 <a-icon type="down" /></a-button>-->
<!-- </a-dropdown>-->
<!-- </div>-->
<!-- table区域-begin -->
<div>
<div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
<i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{ selectedRowKeys.length }}</a>
<a style="margin-left: 24px" @click="onClearSelected">清空</a>
</div>
<a-table
ref="table"
size="middle"
rowKey="id"
class="j-table-force-nowrap"
:scroll="{x:true}"
:columns="columns"
:dataSource="dataSource"
:pagination="ipagination"
:loading="loading"
:expandedRowKeys="expandedRowKeys"
@change="handleTableChange"
@expand="handleExpand"
v-bind="tableProps">
<template slot="imgSlot" slot-scope="text,record">
<span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
<img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt="" style="max-width:80px;font-size: 12px;font-style: italic;"/>
</template>
<template slot="fileSlot" slot-scope="text">
<span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
<a-button
v-else
:ghost="true"
type="primary"
icon="download"
size="small"
@click="downloadFile(text)">
下载
</a-button>
</template>
<span slot="action" slot-scope="text, record">
<a @click="handleEdit(record)">编辑</a>
<a-divider type="vertical" />
<a @click="handleRefund(record)"
v-if="record.state == 2 && record.status == 3 && isWithin48Hours(record.testingTime)">退货退款</a>
<a-divider type="vertical" />
<a-dropdown>
<a class="ant-dropdown-link">更多 <a-icon type="down" /></a>
<a-menu slot="overlay">
<!-- <a-menu-item>-->
<!-- <a @click="handleAddChild(record)">添加下级</a>-->
<!-- </a-menu-item>-->
<a-menu-item>
<a-popconfirm title="确定删除吗?" @confirm="() => handleDeleteNode(record.id)" placement="topLeft">
<a>删除</a>
</a-popconfirm>
</a-menu-item>
</a-menu>
</a-dropdown>
</span>
</a-table>
</div>
<commonOrder-modal ref="modalForm" @ok="modalFormOk"></commonOrder-modal>
</a-card>
</template>
<script>
import { getAction, deleteAction, postAction } from '@/api/manage'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import CommonOrderModal from './modules/CommonOrderModal'
import {filterMultiDictText} from '@/components/dict/JDictSelectUtil'
import { filterObj } from '@/utils/util';
export default {
name: "CommonOrderList",
mixins:[JeecgListMixin],
components: {
CommonOrderModal
},
data () {
return {
description: '订单信息表管理页面',
//
columns: [
{
title:'创建日期',
align:"left",
dataIndex: 'createTime'
},
{
title:'订单编号',
align:"left",
dataIndex: 'ordeNo'
},
{
title:'订单状态',
align:"left",
dataIndex: 'state_dictText'
},
{
title:'流程状态',
align:"left",
dataIndex: 'status_dictText'
},
{
title:'下单用户',
align:"left",
dataIndex: 'userId_dictText'
},
{
title:'订单图片',
align:"left",
dataIndex: 'image',
scopedSlots: {customRender: 'imgSlot'}
},
{
title:'订单标题',
align:"left",
dataIndex: 'title'
},
{
title:'客户姓名',
align:"left",
dataIndex: 'name'
},
{
title:'联系电话',
align:"left",
dataIndex: 'phone'
},
{
title:'订单价格',
align:"left",
dataIndex: 'price'
},
{
title:'取件地址',
align:"left",
dataIndex: 'address'
},
{
title:'取件地址明细',
align:"left",
dataIndex: 'addressDetail'
},
{
title:'直推佣金',
align:"left",
dataIndex: 'oneMoney'
},
{
title:'间推佣金',
align:"left",
dataIndex: 'twoMoney'
},
{
title:'上门时间',
align:"left",
dataIndex: 'goTime'
},
{
title:'物流公司',
align:"left",
dataIndex: 'wliu'
},
{
title:'单价',
align:"left",
dataIndex: 'onePrice'
},
{
title:'单位',
align:"left",
dataIndex: 'unit'
},
{
title:'数量',
align:"left",
dataIndex: 'num'
},
{
title:'简介',
align:"left",
dataIndex: 'details'
},
{
title:'最近回收',
align:"left",
dataIndex: 'izShow',
customRender: (text) => (!text ? "" : (text == "Y" ? "是" : "否"))
},
{
title:'物流编码',
align:"left",
dataIndex: 'wliuNo'
},
{
title:'商品标识',
align:"left",
dataIndex: 'shopId'
},
{
title:'地址标识',
align:"left",
dataIndex: 'addressId'
},
{
title:'检测状态',
align:"left",
dataIndex: 'testingStatus_dictText'
},
{
title:'检测说明',
align:"left",
dataIndex: 'testingInstructions'
},
{
title:'检测时间',
align:"left",
dataIndex: 'testingTime'
},
{
title:'检测报告',
align:"left",
dataIndex: 'testingImages',
scopedSlots: {customRender: 'imgSlot'}
},
{
title:'是否包邮',
align:"left",
dataIndex: 'isBy',
customRender: (text) => (!text ? "" : (text == "Y" ? "是" : "否"))
},
{
title:'质检员',
align:"left",
dataIndex: 'isUserId_dictText'
},
{
title:'品牌',
align:"left",
dataIndex: 'pinId'
},
{
title:'合格数量',
align:"left",
dataIndex: 'qualifiedNum'
},
{
title:'不合格数量',
align:"left",
dataIndex: 'noQualifiedNum'
},
{
title:'不可回收数量',
align:"left",
dataIndex: 'unrecyclable'
},
{
title:'分类',
align:"left",
dataIndex: 'shopClass'
},
{
title:'预估价格',
align:"left",
dataIndex: 'estimatedPrice'
},
{
title:'快递员电话',
align:"left",
dataIndex: 'deliveryPhone'
},
{
title: '操作',
dataIndex: 'action',
align:"center",
fixed:"right",
width:147,
scopedSlots: { customRender: 'action' },
}
],
url: {
list: "/commonOrder/commonOrder/rootList",
childList: "/commonOrder/commonOrder/childList",
getChildListBatch: "/commonOrder/commonOrder/getChildListBatch",
delete: "/commonOrder/commonOrder/delete",
deleteBatch: "/commonOrder/commonOrder/deleteBatch",
exportXlsUrl: "/commonOrder/commonOrder/exportXls",
importExcelUrl: "commonOrder/commonOrder/importExcel",
},
expandedRowKeys:[],
hasChildrenField:"hasChild",
pidField:"pid",
dictOptions: {},
loadParent: false,
superFieldList:[],
}
},
created() {
this.getSuperFieldList();
},
computed: {
importExcelUrl(){
return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
},
tableProps() {
let _this = this
return {
//
rowSelection: {
selectedRowKeys: _this.selectedRowKeys,
onChange: (selectedRowKeys) => _this.selectedRowKeys = selectedRowKeys
}
}
}
},
methods: {
loadData(arg){
if(arg==1){
this.ipagination.current=1
}
this.loading = true
let params = this.getQueryParams()
// params.hasQuery = 'true'
getAction(this.url.list,params).then(res=>{
if(res.success){
let result = res.result
if(Number(result.total)>0){
this.ipagination.total = Number(result.total)
this.dataSource = this.getDataByResult(res.result.records)
return this.loadDataByExpandedRows(this.dataSource)
}else{
this.ipagination.total=0
this.dataSource=[]
}
}else{
this.$message.warning(res.message)
}
}).finally(()=>{
this.loading = false
})
},
//
loadDataByExpandedRows(dataList) {
if (this.expandedRowKeys.length > 0) {
return getAction(this.url.getChildListBatch,{ parentIds: this.expandedRowKeys.join(',') }).then(res=>{
if (res.success && res.result.records.length>0) {
//
let records = res.result.records
const listMap = new Map();
for (let item of records) {
let pid = item[this.pidField];
if (this.expandedRowKeys.join(',').includes(pid)) {
let mapList = listMap.get(pid);
if (mapList == null) {
mapList = [];
}
mapList.push(item);
listMap.set(pid, mapList);
}
}
let childrenMap = listMap;
let fn = (list) => {
if(list) {
list.forEach(data => {
if (this.expandedRowKeys.includes(data.id)) {
data.children = this.getDataByResult(childrenMap.get(data.id))
fn(data.children)
}
})
}
}
fn(dataList)
}
})
} else {
return Promise.resolve()
}
},
getQueryParams(arg) {
//
let sqp = {}
let param = {}
if(this.superQueryParams){
sqp['superQueryParams']=encodeURI(this.superQueryParams)
sqp['superQueryMatchType'] = this.superQueryMatchType
}
if(arg){
param = Object.assign(sqp, this.isorter ,this.filters);
}else{
param = Object.assign(sqp, this.queryParam, this.isorter ,this.filters);
}
if(JSON.stringify(this.queryParam) === "{}" || arg){
param.hasQuery = 'false'
}else{
param.hasQuery = 'true'
}
param.field = this.getQueryField();
param.pageNo = this.ipagination.current;
param.pageSize = this.ipagination.pageSize;
return filterObj(param);
},
searchReset() {
//
this.expandedRowKeys = []
this.queryParam = {}
this.loadData(1);
},
getDataByResult(result){
if(result){
return result.map(item=>{
//
if(item[this.hasChildrenField]=='1'){
let loadChild = { id: item.id+'_loadChild', name: 'loading...', isLoading: true }
item.children = [loadChild]
}
return item
})
}
},
handleExpand(expanded, record){
//
if (expanded) {
this.expandedRowKeys.push(record.id)
if (record.children.length>0 && record.children[0].isLoading === true) {
let params = this.getQueryParams(1);//
params[this.pidField] = record.id
params.hasQuery = 'false'
params.superQueryParams=""
getAction(this.url.childList,params).then((res)=>{
if(res.success){
if(res.result.records){
record.children = this.getDataByResult(res.result.records)
this.dataSource = [...this.dataSource]
}else{
record.children=''
record.hasChildrenField='0'
}
}else{
this.$message.warning(res.message)
}
})
}
}else{
let keyIndex = this.expandedRowKeys.indexOf(record.id)
if(keyIndex>=0){
this.expandedRowKeys.splice(keyIndex, 1);
}
}
},
handleAddChild(record){
this.loadParent = true
let obj = {}
obj[this.pidField] = record['id']
this.$refs.modalForm.add(obj);
},
handleDeleteNode(id) {
if(!this.url.delete){
this.$message.error("请设置url.delete属性!")
return
}
var that = this;
deleteAction(that.url.delete, {id: id}).then((res) => {
if (res.success) {
that.loadData(1)
} else {
that.$message.warning(res.message);
}
});
},
batchDel(){
if(this.selectedRowKeys.length<=0){
this.$message.warning('请选择一条记录!');
return false;
}else{
let ids = "";
let that = this;
that.selectedRowKeys.forEach(function(val) {
ids+=val+",";
});
that.$confirm({
title:"确认删除",
content:"是否删除选中数据?",
onOk: function(){
that.handleDeleteNode(ids)
that.onClearSelected();
}
});
}
},
// 48
isWithin48Hours(testingTime) {
if (!testingTime) {
return false;
}
const testingDate = new Date(testingTime);
const currentDate = new Date();
const timeDiff = currentDate.getTime() - testingDate.getTime();
const hoursDiff = timeDiff / (1000 * 60 * 60);
return hoursDiff <= 48;
},
// 退退
handleRefund(record) {
if (!this.isWithin48Hours(record.testingTime)) {
this.$message.warning('检测时间已超过48小时,无法进行退货退款操作');
return;
}
this.$confirm({
title: '确认退货退款',
content: `确定要对订单 ${record.ordeNo} 进行退货退款操作吗?`,
onOk: () => {
this.processRefund(record);
}
});
},
// 退退
processRefund(record) {
// API退退
// 退退
const params = {
id: record.id,
};
// 退退API
getAction('/commonOrder/commonOrder/refund', params).then(res => {
if (res.success) {
console.log(res.result);
if (res.result && res.result.money < 0) {
this.$confirm({
title: '余额不足提醒',
content: '退货退款完成,请注意:该用户余额不足退款,已成负数,请及时通知用户',
okText: '确定',
type: 'warning'
});
}else{
this.$message.success('退货退款成功');
}
this.loadData(1); //
} else {
this.$message.error(res.message || '退货退款申请失败');
}
}).catch(err => {
this.$message.error('操作失败,请稍后重试');
});
// 使API
// this.$message.success('退退');
// console.log('退退', params);
},
getSuperFieldList(){
let fieldList=[];
fieldList.push({type:'datetime',value:'createTime',text:'创建日期'})
fieldList.push({type:'string',value:'ordeNo',text:'订单编号',dictCode:''})
fieldList.push({type:'int',value:'state',text:'订单状态',dictCode:'order_type'})
fieldList.push({type:'int',value:'status',text:'流程状态',dictCode:'order_state'})
fieldList.push({type:'sel_search',value:'userId',text:'下单用户',dictTable:"han_hai_member", dictText:'nick_name', dictCode:'id'})
fieldList.push({type:'Text',value:'image',text:'订单图片',dictCode:''})
fieldList.push({type:'string',value:'title',text:'订单标题',dictCode:''})
fieldList.push({type:'string',value:'name',text:'客户姓名',dictCode:''})
fieldList.push({type:'string',value:'phone',text:'联系电话',dictCode:''})
fieldList.push({type:'BigDecimal',value:'price',text:'订单价格',dictCode:''})
fieldList.push({type:'Text',value:'address',text:'取件地址',dictCode:''})
fieldList.push({type:'Text',value:'addressDetail',text:'取件地址明细',dictCode:''})
fieldList.push({type:'BigDecimal',value:'oneMoney',text:'直推佣金',dictCode:''})
fieldList.push({type:'BigDecimal',value:'twoMoney',text:'间推佣金',dictCode:''})
fieldList.push({type:'string',value:'pid',text:'父级节点',dictCode:''})
fieldList.push({type:'string',value:'goTime',text:'上门时间',dictCode:''})
fieldList.push({type:'string',value:'wliu',text:'物流公司',dictCode:''})
fieldList.push({type:'BigDecimal',value:'onePrice',text:'单价',dictCode:''})
fieldList.push({type:'string',value:'unit',text:'单位',dictCode:''})
fieldList.push({type:'int',value:'num',text:'数量',dictCode:''})
fieldList.push({type:'string',value:'details',text:'简介',dictCode:''})
fieldList.push({type:'switch',value:'izShow',text:'最近回收'})
fieldList.push({type:'string',value:'wliuNo',text:'物流编码',dictCode:''})
fieldList.push({type:'string',value:'shopId',text:'商品标识',dictCode:''})
fieldList.push({type:'string',value:'addressId',text:'地址标识',dictCode:''})
fieldList.push({type:'int',value:'testingStatus',text:'检测状态',dictCode:'test_status'})
fieldList.push({type:'string',value:'testingInstructions',text:'检测说明',dictCode:''})
fieldList.push({type:'datetime',value:'testingTime',text:'检测时间'})
fieldList.push({type:'Text',value:'testingImages',text:'检测报告',dictCode:''})
fieldList.push({type:'switch',value:'isBy',text:'是否包邮'})
fieldList.push({type:'sel_search',value:'isUserId',text:'质检员',dictTable:"han_hai_member", dictText:'name', dictCode:'id'})
fieldList.push({type:'string',value:'pinId',text:'品牌',dictCode:''})
fieldList.push({type:'int',value:'qualifiedNum',text:'合格数量',dictCode:''})
fieldList.push({type:'int',value:'noQualifiedNum',text:'不合格数量',dictCode:''})
fieldList.push({type:'int',value:'unrecyclable',text:'不可回收数量',dictCode:''})
fieldList.push({type:'string',value:'shopClass',text:'分类',dictCode:''})
fieldList.push({type:'string',value:'estimatedPrice',text:'预估价格',dictCode:''})
fieldList.push({type:'string',value:'deliveryPhone',text:'快递员电话',dictCode:''})
this.superFieldList = fieldList
}
}
}
</script>
<style scoped>
@import '~@assets/less/common.less';
</style>

+ 255
- 0
admin-pc/src/views/commontOrder/modules/CommonOrderModal.vue View File

@ -0,0 +1,255 @@
<template>
<j-modal
:title="title"
:width="width"
:visible="visible"
:confirmLoading="confirmLoading"
switchFullscreen
@ok="handleOk"
@cancel="handleCancel"
cancelText="关闭">
<a-spin :spinning="confirmLoading">
<a-form-model ref="form" :model="model" :rules="validatorRules">
<a-form-model-item label="订单状态" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="state">
<j-dict-select-tag type="list" v-model="model.state" dictCode="order_type" placeholder="请选择订单状态" />
</a-form-model-item>
<a-form-model-item label="流程状态" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="status">
<j-dict-select-tag type="list" v-model="model.status" dictCode="order_state" placeholder="请选择流程状态" />
</a-form-model-item>
<a-form-model-item label="下单用户" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="userId">
<j-search-select-tag v-model="model.userId" dict="han_hai_member,nick_name,id" />
</a-form-model-item>
<a-form-model-item label="订单图片" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="image">
<j-image-upload isMultiple v-model="model.image" ></j-image-upload>
</a-form-model-item>
<a-form-model-item label="订单标题" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="title">
<a-input v-model="model.title" placeholder="请输入订单标题" ></a-input>
</a-form-model-item>
<a-form-model-item label="客户姓名" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="name">
<a-input v-model="model.name" placeholder="请输入客户姓名" ></a-input>
</a-form-model-item>
<a-form-model-item label="联系电话" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="phone">
<a-input v-model="model.phone" placeholder="请输入联系电话" ></a-input>
</a-form-model-item>
<a-form-model-item label="订单价格" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="price">
<a-input-number v-model="model.price" placeholder="请输入订单价格" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="取件地址" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="address">
<a-input v-model="model.address" placeholder="请输入取件地址" ></a-input>
</a-form-model-item>
<a-form-model-item label="取件地址明细" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="addressDetail">
<a-input v-model="model.addressDetail" placeholder="请输入取件地址明细" ></a-input>
</a-form-model-item>
<a-form-model-item label="直推佣金" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="oneMoney">
<a-input-number v-model="model.oneMoney" placeholder="请输入直推佣金" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="间推佣金" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="twoMoney">
<a-input-number v-model="model.twoMoney" placeholder="请输入间推佣金" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="父级节点" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="pid">
<j-tree-select
ref="treeSelect"
placeholder="请选择父级节点"
v-model="model.pid"
dict="common_order,title,name,phone,price,id"
pidField="pid"
pidValue="0"
hasChildField="has_child"
>
</j-tree-select>
</a-form-model-item>
<a-form-model-item label="上门时间" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="goTime">
<a-input v-model="model.goTime" placeholder="请输入上门时间" ></a-input>
</a-form-model-item>
<a-form-model-item label="物流公司" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="wliu">
<a-input v-model="model.wliu" placeholder="请输入物流公司" ></a-input>
</a-form-model-item>
<a-form-model-item label="单价" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="onePrice">
<a-input-number v-model="model.onePrice" placeholder="请输入单价" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="单位" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="unit">
<a-input v-model="model.unit" placeholder="请输入单位" ></a-input>
</a-form-model-item>
<a-form-model-item label="数量" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="num">
<a-input-number v-model="model.num" placeholder="请输入数量" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="简介" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="details">
<a-input v-model="model.details" placeholder="请输入简介" ></a-input>
</a-form-model-item>
<a-form-model-item label="最近回收" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="izShow">
<j-switch v-model="model.izShow" ></j-switch>
</a-form-model-item>
<a-form-model-item label="物流编码" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="wliuNo">
<a-input v-model="model.wliuNo" placeholder="请输入物流编码" ></a-input>
</a-form-model-item>
<a-form-model-item label="商品标识" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="shopId">
<a-input v-model="model.shopId" placeholder="请输入商品标识" ></a-input>
</a-form-model-item>
<a-form-model-item label="地址标识" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="addressId">
<a-input v-model="model.addressId" placeholder="请输入地址标识" ></a-input>
</a-form-model-item>
<a-form-model-item label="检测状态" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="testingStatus">
<j-dict-select-tag type="list" v-model="model.testingStatus" dictCode="test_status" placeholder="请选择检测状态" />
</a-form-model-item>
<a-form-model-item label="检测说明" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="testingInstructions">
<a-input v-model="model.testingInstructions" placeholder="请输入检测说明" ></a-input>
</a-form-model-item>
<a-form-model-item label="检测时间" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="testingTime">
<j-date placeholder="请选择检测时间" v-model="model.testingTime" :show-time="true" date-format="YYYY-MM-DD HH:mm:ss" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="检测报告" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="testingImages">
<j-image-upload isMultiple v-model="model.testingImages" ></j-image-upload>
</a-form-model-item>
<a-form-model-item label="是否包邮" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="isBy">
<j-switch v-model="model.isBy" ></j-switch>
</a-form-model-item>
<a-form-model-item label="质检员" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="isUserId">
<j-search-select-tag v-model="model.isUserId" dict="han_hai_member,name,id" />
</a-form-model-item>
<a-form-model-item label="品牌" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="pinId">
<a-input v-model="model.pinId" placeholder="请输入品牌" ></a-input>
</a-form-model-item>
<a-form-model-item label="合格数量" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="qualifiedNum">
<a-input-number v-model="model.qualifiedNum" placeholder="请输入合格数量" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="不合格数量" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="noQualifiedNum">
<a-input-number v-model="model.noQualifiedNum" placeholder="请输入不合格数量" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="不可回收数量" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="unrecyclable">
<a-input-number v-model="model.unrecyclable" placeholder="请输入不可回收数量" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="分类" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="shopClass">
<a-input v-model="model.shopClass" placeholder="请输入分类" ></a-input>
</a-form-model-item>
<a-form-model-item label="预估价格" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="estimatedPrice">
<a-input v-model="model.estimatedPrice" placeholder="请输入预估价格" ></a-input>
</a-form-model-item>
<a-form-model-item label="快递员电话" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="deliveryPhone">
<a-input v-model="model.deliveryPhone" placeholder="请输入快递员电话" ></a-input>
</a-form-model-item>
</a-form-model>
</a-spin>
</j-modal>
</template>
<script>
import { httpAction } from '@/api/manage'
import { validateDuplicateValue } from '@/utils/util'
export default {
name: "CommonOrderModal",
components: {
},
data () {
return {
title:"操作",
width:800,
visible: false,
model:{
},
labelCol: {
xs: { span: 24 },
sm: { span: 5 },
},
wrapperCol: {
xs: { span: 24 },
sm: { span: 16 },
},
confirmLoading: false,
validatorRules: {
},
url: {
add: "/commonOrder/commonOrder/add",
edit: "/commonOrder/commonOrder/edit",
},
expandedRowKeys:[],
pidField:"pid"
}
},
created () {
//model
this.modelDefault = JSON.parse(JSON.stringify(this.model));
},
methods: {
add (obj) {
this.modelDefault.pid=''
this.edit(Object.assign(this.modelDefault , obj));
},
edit (record) {
this.model = Object.assign({}, record);
this.visible = true;
},
close () {
this.$emit('close');
this.visible = false;
this.$refs.form.clearValidate()
},
handleOk () {
const that = this;
//
this.$refs.form.validate(valid => {
if (valid) {
that.confirmLoading = true;
let httpurl = '';
let method = '';
if(!this.model.id){
httpurl+=this.url.add;
method = 'post';
}else{
httpurl+=this.url.edit;
method = 'put';
}
if(this.model.id && this.model.id === this.model[this.pidField]){
that.$message.warning("父级节点不能选择自己");
that.confirmLoading = false;
return;
}
httpAction(httpurl,this.model,method).then((res)=>{
if(res.success){
that.$message.success(res.message);
this.$emit('ok');
}else{
that.$message.warning(res.message);
}
}).finally(() => {
that.confirmLoading = false;
that.close();
})
}else{
return false
}
})
},
handleCancel () {
this.close()
},
submitSuccess(formData,flag){
if(!formData.id){
let treeData = this.$refs.treeSelect.getCurrTreeData()
this.expandedRowKeys=[]
this.getExpandKeysByPid(formData[this.pidField],treeData,treeData)
this.$emit('ok',formData,this.expandedRowKeys.reverse());
}else{
this.$emit('ok',formData,flag);
}
},
getExpandKeysByPid(pid,arr,all){
if(pid && arr && arr.length>0){
for(let i=0;i<arr.length;i++){
if(arr[i].key==pid){
this.expandedRowKeys.push(arr[i].key)
this.getExpandKeysByPid(arr[i]['parentId'],all,all)
}else{
this.getExpandKeysByPid(pid,arr[i].children,all)
}
}
}
}
}
}
</script>

+ 21
- 0
delete_orders_before_july10.sql View File

@ -0,0 +1,21 @@
-- 删除7月10号之前的订单数据
-- 注意:执行前请先备份数据,此操作不可逆
-- 删除主订单(pid = '0')中7月10号之前的数据
DELETE FROM common_order
WHERE create_time < '2024-07-10 00:00:00'
AND pid = '0';
-- 删除所有子订单中7月10号之前的数据
DELETE FROM common_order
WHERE create_time < '2024-07-10 00:00:00'
AND pid != '0';
-- 或者使用一条SQL删除所有7月10号之前的数据(包括主订单和子订单)
-- DELETE FROM common_order WHERE create_time < '2024-07-10 00:00:00';
-- 查询删除前的数据量(用于确认)
-- SELECT COUNT(*) as total_count FROM common_order WHERE create_time < '2024-07-10 00:00:00';
-- 查询删除后的数据量(用于验证)
-- SELECT COUNT(*) as remaining_count FROM common_order;

+ 15
- 1
module-common/src/main/java/org/jeecg/api/controller/AppletOrderController.java View File

@ -1,14 +1,18 @@
package org.jeecg.api.controller;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.jeecg.api.bean.PageBean;
import org.jeecg.api.service.AppletOrderService;
import org.jeecg.api.service.impl.LogisticsUtil;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.dblogistics.dto.LogisticsTrackPushRequest;
import org.jeecg.common.dblogistics.service.DBLogisticsService;
import org.jeecg.modules.commonOrder.entity.CommonOrder;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
@ -22,6 +26,10 @@ public class AppletOrderController {
@Resource
private AppletOrderService appletOrderService;
@Autowired
private DBLogisticsService logisticsService;
// 联系客服问题相关列表数据带分页
@ApiOperation(value="联系客服问题相关列表数据带分页", notes="联系客服问题相关列表数据带分页")
@GetMapping(value = "/getQuestionList")
@ -64,7 +72,6 @@ public class AppletOrderController {
}
//获取预约时间断
@ApiOperation(value="获取预约时间断", notes="获取预约时间断")
@GetMapping(value = "/getOrderTime")
@ -100,5 +107,12 @@ public class AppletOrderController {
return appletOrderService.wuliuStatus(params);
}
@ApiOperation(value="通过运单号获取物流轨迹", notes="通过运单号获取物流轨迹")
@GetMapping(value = "/queryTrace")
public Object queryTrace(String wuliuNo){
return Result.ok(JSONObject.parseObject(logisticsService.queryTrace(wuliuNo)));
}
}

+ 3
- 1
module-common/src/main/java/org/jeecg/api/service/AppletOrderTeamService.java View File

@ -35,5 +35,7 @@ public interface AppletOrderTeamService {
Result<?> adminOrderBrowseRecord(String token, String orderIds);
Result<?> getOrderIdBywliuNo(String token, String wliuNo);
Result<?> getOrderIdBywliuNo(String token, String wliuNo);//根据订单id查询运单号
Result<?> refund(String id);//退货退款
}

+ 3
- 0
module-common/src/main/java/org/jeecg/api/service/impl/AppletIndexServiceImpl.java View File

@ -80,6 +80,9 @@ public class AppletIndexServiceImpl implements AppletIndexService {
.lambdaQuery()
.orderByDesc(CommonGet::getCreateTime)
.page(new Page<CommonGet>(1, 6));
return Result.OK("最近回收商品", page.getRecords());
}


+ 26
- 5
module-common/src/main/java/org/jeecg/api/service/impl/AppletLoginServiceImpl.java View File

@ -34,6 +34,7 @@ import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.StandardCharsets;
import java.util.*;
import java.util.stream.Collectors;
@Slf4j
@Service
@ -90,8 +91,7 @@ public class AppletLoginServiceImpl implements AppletLoginService {
if (StringUtils.isBlank(wxOpenid)) {
throw new JeecgBootException("未获取到openid");
}
Random random = new Random();
int randomNumber = 100000 + random.nextInt(900000);
HanHaiMember member = memberService.lambdaQuery().eq(HanHaiMember::getAppletOpenid,wxOpenid).one();
if (member == null) {
@ -149,7 +149,7 @@ public class AppletLoginServiceImpl implements AppletLoginService {
// 生成token返回给小程序端
String token = JwtUtil.sign(member.getAppletOpenid(), wxOpenid);
member.setIntentioCode(String.valueOf(randomNumber));
member.setIntentioCode(randomInt());
memberService.save(member);
redisUtil.set(CommonConstant.PREFIX_USER_TOKEN + token, token);
// 设置超时时间
@ -175,6 +175,25 @@ public class AppletLoginServiceImpl implements AppletLoginService {
return result;
}
//生成一个唯一的邀请码
private String randomInt(){
Random random = new Random();
List<String> collect = memberService.lambdaQuery()
.select(HanHaiMember::getIntentioCode)
.list().stream().map(n -> n.getIntentioCode())
.collect(Collectors.toList());
String randomNumber = String.valueOf(10000000 + random.nextInt(90000000));
while (collect.contains(randomNumber)){
randomNumber = String.valueOf(10000000 + random.nextInt(90000000));
}
return randomNumber;
}
private static final String TOKEN_URL = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s";
public String getAccessToken() throws Exception {
@ -255,8 +274,10 @@ public class AppletLoginServiceImpl implements AppletLoginService {
if ("Y".equals(hanHaiMember.getIsUser()) && StringUtils.isNotBlank(hanHaiMember.getIsTuiType())){
CommonDistributionRatio ratio = commonDistributionRatioService.getById(hanHaiMember.getIsTuiType());
hanHaiMember.setIsTuiTypeTitle(ratio.getTitle());
hanHaiMember.setIsTuiType(ratio.getSort().toString());
if (ratio != null){
hanHaiMember.setIsTuiTypeTitle(ratio.getTitle());
hanHaiMember.setIsTuiType(ratio.getSort().toString());
}
}
//查询我的所有的提现记录


+ 16
- 11
module-common/src/main/java/org/jeecg/api/service/impl/AppletMoneyLogServiceImpl.java View File

@ -9,6 +9,7 @@ import org.apache.commons.lang3.StringUtils;
import org.jeecg.api.bean.PageBean;
import org.jeecg.api.service.AppletMoneyLogService;
import org.jeecg.api.transfer.TransferToUser;
import org.jeecg.api.transfer.WXPayUtility;
import org.jeecg.common.api.vo.Result;
import org.jeecg.config.shiro.ShiroRealm;
import org.jeecg.modules.commonBook.entity.CommonBook;
@ -88,23 +89,18 @@ public class AppletMoneyLogServiceImpl implements AppletMoneyLogService {
BigDecimal balance = member.getMoney();//用户余额
//金额不能为空
if(null == commonMoneyLog.getMoney()){
log.info("金额为空,请填写大于0的整数金额");
return Result.error("金额小于0,请填写大于0的整数金额");
log.info("金额为空,请填写大于0.3的整数金额");
return Result.error("最低提现0.3元");
}
if(commonMoneyLog.getMoney().compareTo(balance)>0){
//提现金额大于推广佣金
log.info("用户余额不足,当前用户余额:{}", balance);
return Result.error("用户余额不足");
}
//提现金额要为整数
if(commonMoneyLog.getMoney().scale()>0){
log.info("请填写大于0的整数金额,当前输入金额:{}", commonMoneyLog.getMoney());
return Result.error("请填写大于0的整数金额");
}
//提现金额大于0的整数
if(commonMoneyLog.getMoney().compareTo(new BigDecimal(0))<=0){
log.info("请填写大于0的整数金额,当前输入金额:{}", commonMoneyLog.getMoney());
return Result.error("请填写大于0的整数金额");
if(commonMoneyLog.getMoney().compareTo(new BigDecimal(0.3))<=0){
log.info("请填写大于0.3的整数金额,当前输入金额:{}", commonMoneyLog.getMoney());
return Result.error("最低提现0.3元");
}
if(org.apache.commons.lang.StringUtils.isEmpty(commonMoneyLog.getUserName())){
log.info("用户姓名未填写");
@ -149,7 +145,16 @@ public class AppletMoneyLogServiceImpl implements AppletMoneyLogService {
}
//3执行提现
TransferToUser.TransferToUserResponse response = client.run(request, map);
TransferToUser.TransferToUserResponse response = null;
try {
response = client.run(request, map);
}catch (WXPayUtility.ApiException e){
if (e.statusCode == 400){
return Result.error("请输入您的真实姓名");
}
return Result.error("提现失败");
}
log.info("提现发起成功,outBillNo:"+response.outBillNo + ",transferBillNo:" +response.transferBillNo + ",state:" +response.state+ ",packageInfo:" + response.packageInfo);
switch (response.state){
case ACCEPTED:


+ 14
- 5
module-common/src/main/java/org/jeecg/api/service/impl/AppletOrderServiceImpl.java View File

@ -164,6 +164,11 @@ public class AppletOrderServiceImpl implements AppletOrderService {
.one();
if (commonOrder == null){
return Result.error("订单不存在");
}
commonOrder.setCommonOrderList(getCommonOrderList(orderId, 0));
commonOrder.setOrderCheckList(getCommonOrderList(orderId, 1));
@ -343,6 +348,7 @@ public class AppletOrderServiceImpl implements AppletOrderService {
//创建主订单
CommonOrder cityOrder = new CommonOrder();
cityOrder.setId(orderId);
cityOrder.setOrdeNo(orderId);
cityOrder.setUserId(hanHaiMember.getId());
cityOrder.setShopId(null);
cityOrder.setNum(totalNum);
@ -416,15 +422,15 @@ public class AppletOrderServiceImpl implements AppletOrderService {
@Override
public Result<?> getCeckoutReasons(String token, String classId, String type) {
if (StringUtils.isBlank(classId)){
return Result.error("classId分类ID不能为空");
}
// if (StringUtils.isBlank(classId)){
// return Result.error("classId分类ID不能为空");
// }
if (StringUtils.isBlank(type)){
return Result.error("type类型不能为空");
}
return Result.ok(commonReasonsService.lambdaQuery()
.in(CommonReasons::getClassId, classId)
.like(StringUtils.isNotBlank(classId), CommonReasons::getClassId, classId)
.eq(CommonReasons::getType, type)
.list()
);
@ -465,11 +471,14 @@ public class AppletOrderServiceImpl implements AppletOrderService {
// 根据物流状态更新订单状态
if (LogisticsTrackStatusConstants.GOT.equals(traceInfo.getStatus())) {
// 签收状态更新订单为 已取件+快递上门
updateOrderStatusByTrackingNumber(trackInfo.getTracking_number(), 1, 1);
} else if (LogisticsTrackStatusConstants.SIGNED.equals(traceInfo.getStatus()) ||
LogisticsTrackStatusConstants.BACK_SIGNED.equals(traceInfo.getStatus()) ||
LogisticsTrackStatusConstants.STA_SIGN.equals(traceInfo.getStatus())) {
// 签收状态更新订单为已 已取件+透明质检
updateOrderStatusByTrackingNumber(trackInfo.getTracking_number(), 1, 2);
@ -643,7 +652,7 @@ public class AppletOrderServiceImpl implements AppletOrderService {
for (CommonOrder order : orders) {
if (state != 1 && status != 1){
if (state == 1 && status == 2){
// 删除其他用户的浏览记录
commonAdminOrderBrowseRecordService
.remove(Wrappers.<CommonAdminOrderBrowseRecord>lambdaQuery()


+ 73
- 13
module-common/src/main/java/org/jeecg/api/service/impl/AppletOrderTeamServiceImpl.java View File

@ -135,15 +135,35 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
.eq(CommonOrder::getPid,"0")
.page(page);
if (pageList.getRecords().size() == 0){
return Result.OK("订单列表",pageList);
}
List<String> ids = pageList.getRecords().stream().map(n -> n.getId())
.collect(Collectors.toList());
//查询阅读记录
List<String> orderIds = commonAdminOrderBrowseRecordService
.lambdaQuery()
.eq(CommonAdminOrderBrowseRecord::getUserId, hanHaiMember.getId())
.in(ids.size() > 0, CommonAdminOrderBrowseRecord::getOrderId, ids)
.select(CommonAdminOrderBrowseRecord::getOrderId)
.list()
.stream().map(n -> n.getOrderId())
.collect(Collectors.toList());
//得到集合数据
for (CommonOrder commonOrder : pageList.getRecords()) {
//查询下级
List<CommonOrder> children = commonOrderService
.lambdaQuery()
.eq(CommonOrder::getPid, commonOrder.getId())
.list();
commonOrder.setCommonOrderList(children);
// //查询下级
// List<CommonOrder> children = commonOrderService
// .lambdaQuery()
// .eq(CommonOrder::getPid, commonOrder.getId())
// .list();
//是否已读
commonOrder.setReadFlag(orderIds.contains(commonOrder.getId()));
// commonOrder.setCommonOrderList(children);
}
@ -155,6 +175,10 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
HanHaiMember hanHaiMember = shiroRealm.checkUserTokenIsEffectHanHaiOpenId(token);
CommonOrder commonOrder = commonOrderService.getById(orderId);
if (commonOrder == null){
return Result.error("订单不存在");
}
commonOrder.setCommonOrderList(getCommonOrderList(orderId, 0));
commonOrder.setOrderCheckList(getCommonOrderList(orderId, 1));
@ -501,11 +525,6 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
orderReq.setHasChild("1");
orderReq.setType(1);
int testingStatus = 0;
if (orderReq.getCommonOrderList().size() > 0){
testingStatus = orderReq.getCommonOrderList().get(0).getTestingStatus();
}
//设置商品
if (StringUtils.isNotBlank(orderReq.getShopId())){
CommonShop shop = commonShopService.getById(orderReq.getShopId());
@ -515,7 +534,7 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
orderReq.setDetails(shop.getService());
orderReq.setShopClass(shop.getShopClass());
orderReq.setCreateTime(new Date());
}if (testingStatus == 1){
}else if (orderReq.getTestingStatus() == 1){
//质量问题
orderReq.setTitle("质量问题");
}else {
@ -685,6 +704,7 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
userLog.setState(1); // 立即到账状态
userLog.setUserId(member.getId());
userLog.setOldMoney(member.getMoney()); // 记录原始余额
userLog.setOrderId(order.getId());
commonMoneyLogService.save(userLog);
//累计回收金额
@ -712,6 +732,7 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
log.setType(0);
log.setIsBrokerage("Y");
log.setState(0); // 待打款状态48小时后由定时任务自动打款
log.setOrderId(order.getId());
commonMoneyLogService.save(log);
}
}
@ -722,7 +743,7 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
HanHaiMember member2 = hanHaiMemberService.getById(member.getVid());
if (member2 != null && "Y".equals(member2.getIsUser()) && StringUtils.isNotBlank(member2.getIsTuiType())){
CommonDistributionRatio byId = commonDistributionRatioService.getById(member2.getIsTuiType());
if (byId != null && byId.getIndirect() != null){
if (byId != null && byId.getIndirect() != null && !byId.getIndirect().equals(BigDecimal.ZERO)){
CommonMoneyLog log = new CommonMoneyLog();
log.setMoney(order.getPrice().multiply(byId.getIndirect()).divide(new BigDecimal(100)));
@ -732,9 +753,48 @@ public class AppletOrderTeamServiceImpl implements AppletOrderTeamService {
log.setIsBrokerage("Y");
log.setFormUserId(member.getId());//来源
log.setState(0); // 待打款状态48小时后由定时任务自动打款
log.setOrderId(order.getId());
commonMoneyLogService.save(log);
}
}
}
}
@Override
public Result<?> refund(String id) {//退货退款
CommonOrder order = commonOrderService.getById(id);
if(order == null){
return Result.error("订单不存在");
}
if(order.getStatus() != 3 || order.getState() != 2){
return Result.error("订单还未结算或已退回");
}
HanHaiMember member = hanHaiMemberService.getById(order.getUserId());
if (member != null){
BigDecimal money = member.getMoney() == null ? BigDecimal.ZERO : member.getMoney();
member.setMoney(money.subtract(order.getPrice()));
hanHaiMemberService.updateById(member);
}
List<CommonMoneyLog> list = commonMoneyLogService.lambdaQuery()
.eq(CommonMoneyLog::getOrderId, id)
.list();
for (CommonMoneyLog log : list) {
log.setState(2);//取消状态
}
commonMoneyLogService.updateBatchById(list);
order.setState(5);
commonOrderService.updateById(order);
return Result.ok(member);
}
}

+ 170
- 88
module-common/src/main/java/org/jeecg/api/service/impl/AppletPromotionServiceImpl.java View File

@ -12,6 +12,7 @@ import org.jeecg.api.service.AppletPromotionService;
import org.jeecg.api.wxUtils.HttpClientUtil;
import org.jeecg.api.wxUtils.WxHttpUtils;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.exception.JeecgBootException;
import org.jeecg.config.shiro.ShiroRealm;
import org.jeecg.modules.commonConfig.entity.CommonConfig;
import org.jeecg.modules.commonConfig.service.ICommonConfigService;
@ -37,6 +38,8 @@ import org.springframework.web.client.RestTemplate;
import javax.annotation.Resource;
import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.font.FontRenderContext;
import java.awt.geom.AffineTransform;
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.File;
@ -109,58 +112,51 @@ public class AppletPromotionServiceImpl implements AppletPromotionService {
//获取推广二维码 2
@Override
public byte[] getInviteCode2(String token){
HanHaiMember member = shiroRealm.checkUserTokenIsEffectHanHaiOpenId(token);
// 获取环境配置
CommonConfig vsion = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "v_sion")
.one();
Integer vsionStr = Integer.parseInt(vsion.getKeyContent());
String trial = "release";
if(vsionStr == 0){
trial= "release";
}else if(vsionStr == 1){
trial= "trial";
}else{
trial= "develop";
}
// 获取必要的配置信息
CommonConfig xcxSharePage = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "xcxSharePage")
.one();
CommonConfig oneImage = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "codeImg")
.one();
CommonConfig qr_code = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "qr_code")
.one();
CommonConfig image_go_url = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "image_go_url")
.one();
String backgroundImageUrl = qr_code.getKeyContent();
try {
// 1. 验证token和用户
if (StringUtils.isBlank(token)) {
throw new JeecgBootException("token不能为空");
}
HanHaiMember member = shiroRealm.checkUserTokenIsEffectHanHaiOpenId(token);
if (member == null) {
throw new JeecgBootException("用户不存在或token无效");
}
// 尝试从缓存获取二维码
String cacheKey = "CodeImage::" + trial + member.getId();
WxQrCodeVo wxCodeVo = new WxQrCodeVo();
// 2. 获取环境配置增加容错处理
String trial = "release";
try {
CommonConfig vsion = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "v_sion")
.one();
if (vsion != null && StringUtils.isNotBlank(vsion.getKeyContent())) {
Integer vsionStr = Integer.parseInt(vsion.getKeyContent());
if (vsionStr == 1) {
trial = "trial";
} else if (vsionStr == 2) {
trial = "develop";
}
}
} catch (Exception e) {
// 配置获取失败使用默认值
trial = "release";
}
wxCodeVo.setName("爱回收欢迎您");
// 3. 获取必要的配置信息增加容错处理
CommonConfig xcxSharePage = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "xcxSharePage")
.one();
if (xcxSharePage == null || StringUtils.isBlank(xcxSharePage.getKeyContent())) {
throw new JeecgBootException("小程序分享页面配置不存在");
}
// 如果启用了Redis缓存可以取消下面注释
// String cachedQrCode = (String) redisUtil.get(cacheKey);
// if(cachedQrCode != null){
// String combinedImageUrl = this.generateAndCombineImagesFromUrl(cachedQrCode, backgroundImageUrl, "combined_image_code");
// wxCodeVo.setUrl(combinedImageUrl);
// return Result.OK(wxCodeVo);
// }
CommonConfig qr_code = commonConfigService.lambdaQuery()
.eq(CommonConfig::getKeyName, "qr_code")
.one();
try {
String backgroundImageUrl = qr_code.getKeyContent();
// 准备微信API请求参数
// 4. 准备微信API请求参数
String key = "shareId=" + member.getId();
Map<String, Object> param = new HashMap<>();
param.put("path", xcxSharePage.getKeyContent() + "?" + key);
@ -169,62 +165,121 @@ public class AppletPromotionServiceImpl implements AppletPromotionService {
param.put("auto_color", false);
param.put("env_version", trial);
// Map<String, Object> line_color = new HashMap<>();
// line_color.put("r", 0);
// line_color.put("g", 0);
// line_color.put("b", 0);
// param.put("line_color", line_color);
// param.put("is_hyaline", true);//透明
// 获取微信小程序码
String accessToken = wxHttpUtils.getAccessToken();
String url = "https://api.weixin.qq.com/wxa/getwxacode?access_token=" + accessToken;
// 请求微信API获取二维码图片数据
RestTemplate rest = new RestTemplate();
MultiValueMap<String, String> headers = new LinkedMultiValueMap<>();
org.springframework.http.HttpEntity requestEntity = new org.springframework.http.HttpEntity(JSON.toJSONString(param), headers);
ResponseEntity<byte[]> entity = rest.exchange(url, HttpMethod.POST, requestEntity, byte[].class, new Object[0]);
byte[] qrCodeBytes = entity.getBody();
// 直接将二维码图片转为MultipartFile避免写入临时文件
// MultipartFile qrCodeFile = createMultipartFile(qrCodeBytes, "qrcode.jpg");
// 上传二维码到阿里云并获取URL
// String qrCodeImageUrl = image_go_url.getKeyContent() + this.uploadAliYunOss(qrCodeFile);
// 合并图片并上传
// String combinedImageUrl = this.generateAndCombineImagesFromUrl2(qrCodeBytes, backgroundImageUrl);
// 设置返回数据
// 如果启用了Redis缓存可以取消下面注释
//redisUtil.set(cacheKey, qrCodeImageUrl, 3600); // 缓存一小时
// 5. 获取微信小程序码增加重试机制
byte[] qrCodeBytes = null;
int retryCount = 0;
int maxRetries = 3;
while (retryCount < maxRetries && qrCodeBytes == null) {
try {
String accessToken = wxHttpUtils.getAccessToken();
if (StringUtils.isBlank(accessToken)) {
throw new JeecgBootException("获取微信access_token失败");
}
String url = "https://api.weixin.qq.com/wxa/getwxacode?access_token=" + accessToken;
// 请求微信API获取二维码图片数据
RestTemplate rest = new RestTemplate();
MultiValueMap<String, String> headers = new LinkedMultiValueMap<>();
headers.add("Content-Type", "application/json");
org.springframework.http.HttpEntity<String> requestEntity =
new org.springframework.http.HttpEntity<>(JSON.toJSONString(param), headers);
ResponseEntity<byte[]> entity = rest.exchange(url, HttpMethod.POST, requestEntity, byte[].class);
if (entity.getStatusCode().is2xxSuccessful() && entity.getBody() != null) {
qrCodeBytes = entity.getBody();
// 验证返回的数据是否为图片
if (qrCodeBytes.length < 100) {
// 可能是错误信息重新尝试
qrCodeBytes = null;
throw new JeecgBootException("微信API返回数据异常");
}
} else {
throw new JeecgBootException("微信API请求失败");
}
} catch (Exception e) {
retryCount++;
if (retryCount >= maxRetries) {
throw new JeecgBootException("获取微信小程序码失败,已重试" + maxRetries + "次: " + e.getMessage());
}
// 等待一段时间后重试
try {
Thread.sleep(1000 * retryCount);
} catch (InterruptedException ie) {
Thread.currentThread().interrupt();
throw new JeecgBootException("线程被中断");
}
}
}
// return qrCodeBytes;
if (qrCodeBytes == null) {
throw new JeecgBootException("无法获取微信小程序码");
}
// 6. 合并图片并返回
return this.generateAndCombineImagesFromUrl2(qrCodeBytes, backgroundImageUrl);
} catch (Exception e) {
e.printStackTrace();
return null;
throw new JeecgBootException(e.getMessage());
}
}
public byte[] generateAndCombineImagesFromUrl2(byte[] qrCodeImageByte, String backgroundUrl) {
File file = null;
try {
// 验证输入参数
if (qrCodeImageByte == null || qrCodeImageByte.length == 0) {
throw new JeecgBootException("二维码图片数据为空");
}
if (StringUtils.isBlank(backgroundUrl)) {
return qrCodeImageByte;
}
// 从字节数组加载小程序码图像
BufferedImage qrCodeImage = ImageIO.read(new ByteArrayInputStream(qrCodeImageByte));
if (qrCodeImage == null) {
throw new RuntimeException("无法解析二维码图片数据");
}
// 从URL加载背景图像
URL backgroundImageUrl = new URL(backgroundUrl);
BufferedImage backgroundImage = ImageIO.read(backgroundImageUrl);
// 从URL加载背景图像增加重试机制
BufferedImage backgroundImage = null;
int retryCount = 0;
int maxRetries = 3;
while (retryCount < maxRetries && backgroundImage == null) {
try {
URL backgroundImageUrl = new URL(backgroundUrl);
backgroundImage = ImageIO.read(backgroundImageUrl);
if (backgroundImage == null) {
throw new RuntimeException("无法加载背景图片");
}
} catch (Exception e) {
retryCount++;
if (retryCount >= maxRetries) {
// 如果背景图片加载失败创建一个默认背景
backgroundImage = createDefaultBackground();
} else {
try {
Thread.sleep(1000);
} catch (InterruptedException ie) {
Thread.currentThread().interrupt();
break;
}
}
}
}
// 创建一个新的BufferedImage来保存合并后的图像
Graphics2D g2d = backgroundImage.createGraphics();
// 设置抗锯齿
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
g2d.setRenderingHint(RenderingHints.KEY_RENDERING, RenderingHints.VALUE_RENDER_QUALITY);
int wh = backgroundImage.getWidth() / 3;
@ -244,8 +299,9 @@ public class AppletPromotionServiceImpl implements AppletPromotionService {
return Files.readAllBytes(file.toPath());
} catch (Exception e) {
throw new RuntimeException("生成合并图片失败", e);
e.printStackTrace();
// 如果合并失败返回原始二维码图片
return qrCodeImageByte;
} finally {
// 删除临时文件
if (file != null && file.exists()) {
@ -254,6 +310,32 @@ public class AppletPromotionServiceImpl implements AppletPromotionService {
}
}
/**
* 创建默认背景图片
*/
private BufferedImage createDefaultBackground() {
int width = 600;
int height = 800;
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
Graphics2D g2d = image.createGraphics();
// 设置渐变背景
GradientPaint gradient = new GradientPaint(0, 0, new Color(255, 255, 255),
0, height, new Color(240, 240, 240));
g2d.setPaint(gradient);
g2d.fillRect(0, 0, width, height);
// 添加一些装饰元素
g2d.setColor(new Color(200, 200, 200));
g2d.setStroke(new BasicStroke(1));
for (int i = 0; i < 5; i++) {
g2d.drawOval(50 + i * 100, 50, 80, 80);
}
g2d.dispose();
return image;
}
@Override
public Result<?> getHanHaiMemberUser(String token,Integer state,PageBean pageBean){


+ 3
- 0
module-common/src/main/java/org/jeecg/modules/commonMoneyLog/entity/CommonMoneyLog.java View File

@ -102,6 +102,9 @@ public class CommonMoneyLog implements Serializable {
@Excel(name = "参数", width = 15, dictTable = "han_hai_member", dicText = "nick_name", dicCode = "id")
@ApiModelProperty(value = "参数")
private java.lang.String packageInfo;
/**参数*/
@ApiModelProperty(value = "订单ID")
private java.lang.String orderId;
/**佣金来源用户*/
@TableField(exist = false)


+ 15
- 1
module-common/src/main/java/org/jeecg/modules/commonOrder/controller/CommonOrderController.java View File

@ -9,6 +9,8 @@ import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.jeecg.api.service.AppletOrderTeamService;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.system.query.QueryGenerator;
import org.jeecg.common.util.oConvertUtils;
@ -39,7 +41,7 @@ import org.jeecg.common.aspect.annotation.AutoLog;
/**
* @Description: 订单信息表
* @Author: jeecg-boot
* @Date: 2025-05-21
* @Date: 2025-07-16
* @Version: V1.0
*/
@Api(tags="订单信息表")
@ -49,6 +51,8 @@ import org.jeecg.common.aspect.annotation.AutoLog;
public class CommonOrderController extends JeecgController<CommonOrder, ICommonOrderService>{
@Autowired
private ICommonOrderService commonOrderService;
@Autowired
private AppletOrderTeamService appletOrderTeamService;
/**
* 分页列表查询
@ -226,4 +230,14 @@ public class CommonOrderController extends JeecgController<CommonOrder, ICommonO
return super.importExcel(request, response, CommonOrder.class);
}
/**
* 退货退款
*
* @return
*/
@RequestMapping(value = "/refund", method = RequestMethod.GET)
public Result<?> refund(@RequestParam(name="id") String id) {
return appletOrderTeamService.refund(id);
}
}

+ 47
- 40
module-common/src/main/java/org/jeecg/modules/commonOrder/entity/CommonOrder.java View File

@ -21,7 +21,7 @@ import java.util.List;
/**
* @Description: 订单信息表
* @Author: jeecg-boot
* @Date: 2025-05-21
* @Date: 2025-07-16
* @Version: V1.0
*/
@Data
@ -46,6 +46,10 @@ public class CommonOrder implements Serializable {
/**更新日期*/
@ApiModelProperty(value = "更新日期")
private java.util.Date updateTime;
/**订单编号*/
@Excel(name = "订单编号", width = 15)
@ApiModelProperty(value = "订单编号")
private java.lang.String ordeNo;
/**订单状态*/
@Excel(name = "订单状态", width = 15, dicCode = "order_type")
@Dict(dicCode = "order_type")
@ -56,6 +60,7 @@ public class CommonOrder implements Serializable {
已完成 2
已取消 3
驳回 4
退货退款 5
*/
private java.lang.Integer state;
/**流程状态*/
@ -79,16 +84,12 @@ public class CommonOrder implements Serializable {
private java.lang.String userId;
/**订单图片*/
@Excel(name = "订单图片", width = 15)
@ApiModelProperty(value = "商品订单图片")
@ApiModelProperty(value = "订单图片")
private java.lang.String image;
/**商品分类*/
@Excel(name = "商品分类", width = 15)
@ApiModelProperty(value = "商品分类")
private java.lang.String shopClass;
/**订单标题*/
@Excel(name = "订单标题", width = 15)
@ApiModelProperty(value = "订单标题")
private java.lang.String title;//商品名称
private java.lang.String title;
/**客户姓名*/
@Excel(name = "客户姓名", width = 15)
@ApiModelProperty(value = "客户姓名")
@ -150,10 +151,10 @@ public class CommonOrder implements Serializable {
@Excel(name = "简介", width = 15)
@ApiModelProperty(value = "简介")
private java.lang.String details;
/**订单编号*/
@Excel(name = "订单编号", width = 15)
@ApiModelProperty(value = "订单编号")
private java.lang.String ordeNo;
/**最近回收*/
@Excel(name = "最近回收", width = 15)
@ApiModelProperty(value = "最近回收")
private java.lang.String izShow;
/**物流编码*/
@Excel(name = "物流编码", width = 15)
@ApiModelProperty(value = "物流编码")
@ -181,7 +182,7 @@ public class CommonOrder implements Serializable {
private java.util.Date testingTime;
/**检测报告*/
@Excel(name = "检测报告", width = 15)
@ApiModelProperty(value = "检测图片")
@ApiModelProperty(value = "检测报告")
private java.lang.String testingImages;
/**是否包邮*/
@Excel(name = "是否包邮", width = 15)
@ -192,39 +193,42 @@ public class CommonOrder implements Serializable {
@Dict(dictTable = "han_hai_member", dicText = "name", dicCode = "id")
@ApiModelProperty(value = "质检员")
private java.lang.String isUserId;
/**品牌标识*/
@Excel(name = "品牌标识", width = 15)
@ApiModelProperty(value = "品牌标识")
@Dict(dictTable = "common_vip", dicCode = "id", dicText = "name")
private java.lang.String pinId;
@Excel(name = "快递员电话", width = 15)
@ApiModelProperty(value = "快递员电话")
private String deliveryPhone;
/**品牌*/
@Excel(name = "品牌", width = 15)
@ApiModelProperty(value = "品牌")
private java.lang.String pinId;
/**合格数量*/
@Excel(name = "合格数量", width = 15)
@ApiModelProperty(value = "合格数量")
private Integer qualifiedNum;
@ApiModelProperty(value = "合格数量")
private java.lang.Integer qualifiedNum;
/**不合格数量*/
@Excel(name = "不合格数量", width = 15)
@ApiModelProperty(value = "不合格数量")
private Integer noQualifiedNum;
@ApiModelProperty(value = "不合格数量")
private java.lang.Integer noQualifiedNum;
/**不可回收数量*/
@Excel(name = "不可回收数量", width = 15)
@ApiModelProperty(value = "不可回收数量")
private Integer unrecyclable;
@ApiModelProperty(value = "不可回收数量")
private java.lang.Integer unrecyclable;
/**分类*/
@Excel(name = "分类", width = 15)
@ApiModelProperty(value = "分类")
private java.lang.String shopClass;
/**预估价格*/
@Excel(name = "预估价格", width = 15)
@ApiModelProperty(value = "预估价格")
private String estimatedPrice;//预估价格
@Excel(name = "子订单类型(0用户订单,1质检订单)", width = 15)
@ApiModelProperty(value = "子订单类型(0用户订单,1质检订单)")
private Integer type;//子订单类型
@ApiModelProperty(value = "预估价格")
private java.lang.String estimatedPrice;
/**子订单类型(0用户创建的订单,1质检结算的订单)*/
@Excel(name = "子订单类型(0用户创建的订单,1质检结算的订单)", width = 15)
@ApiModelProperty(value = "子订单类型(0用户创建的订单,1质检结算的订单)")
private java.lang.Integer type;
/**渠道单号*/
@Excel(name = "渠道单号", width = 15)
@ApiModelProperty(value = "渠道单号")
private String logisticId;//渠道单号
@ApiModelProperty(value = "渠道单号")
private java.lang.String logisticId;
/**快递员电话*/
@Excel(name = "快递员电话", width = 15)
@ApiModelProperty(value = "快递员电话")
private java.lang.String deliveryPhone;
@TableField (exist=false)
@ -245,4 +249,7 @@ public class CommonOrder implements Serializable {
@TableField(exist = false)
private String logisticsTrajectoryText;//物流状态描述
@TableField(exist = false)
private boolean readFlag;//是否已读
}

+ 1
- 1
module-common/src/main/java/org/jeecg/modules/commonOrder/mapper/CommonOrderMapper.java View File

@ -7,7 +7,7 @@ import com.baomidou.mybatisplus.core.mapper.BaseMapper;
/**
* @Description: 订单信息表
* @Author: jeecg-boot
* @Date: 2025-05-21
* @Date: 2025-07-16
* @Version: V1.0
*/
public interface CommonOrderMapper extends BaseMapper<CommonOrder> {


+ 2
- 1
module-common/src/main/java/org/jeecg/modules/commonOrder/service/ICommonOrderService.java View File

@ -1,5 +1,6 @@
package org.jeecg.modules.commonOrder.service;
import org.jeecg.common.api.vo.Result;
import org.jeecg.modules.commonOrder.entity.CommonOrder;
import com.baomidou.mybatisplus.extension.service.IService;
import org.jeecg.common.exception.JeecgBootException;
@ -9,7 +10,7 @@ import java.util.List;
/**
* @Description: 订单信息表
* @Author: jeecg-boot
* @Date: 2025-05-21
* @Date: 2025-07-16
* @Version: V1.0
*/
public interface ICommonOrderService extends IService<CommonOrder> {


+ 21
- 9
module-common/src/main/java/org/jeecg/modules/commonOrder/service/impl/CommonOrderServiceImpl.java View File

@ -1,13 +1,19 @@
package org.jeecg.modules.commonOrder.service.impl;
import org.jeecg.common.api.vo.Result;
import org.jeecg.common.exception.JeecgBootException;
import org.jeecg.common.util.oConvertUtils;
import org.jeecg.modules.commonOrder.entity.CommonOrder;
import org.jeecg.modules.commonOrder.mapper.CommonOrderMapper;
import org.jeecg.modules.commonOrder.service.ICommonOrderService;
import org.jeecg.modules.hanHaiMember.entity.HanHaiMember;
import org.jeecg.modules.hanHaiMember.service.IHanHaiMemberService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import org.springframework.transaction.annotation.Transactional;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
@ -17,12 +23,16 @@ import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
/**
* @Description: 订单信息表
* @Author: jeecg-boot
* @Date: 2025-05-21
* @Date: 2025-07-16
* @Version: V1.0
*/
@Service
public class CommonOrderServiceImpl extends ServiceImpl<CommonOrderMapper, CommonOrder> implements ICommonOrderService {
@Autowired
private IHanHaiMemberService memberService;
@Override
public void addCommonOrder(CommonOrder commonOrder) {
//新增时设置hasChild为0
@ -118,18 +128,20 @@ public class CommonOrderServiceImpl extends ServiceImpl<CommonOrderMapper, Commo
}
return mapList;
}
/**
/**
* 根据所传pid查询旧的父级节点的子节点并修改相应状态值
* @param pid
*/
private void updateOldParentNode(String pid) {
// if(!ICommonOrderService.ROOT_PID_VALUE.equals(pid)) {
// Integer count = baseMapper.selectCount(new QueryWrapper<CommonOrder>().eq("pid", pid));
// if(count==null || count<=1) {
// baseMapper.updateTreeNodeStatus(pid, ICommonOrderService.NOCHILD);
// }
// }
if(!ICommonOrderService.ROOT_PID_VALUE.equals(pid)) {
Long count = baseMapper.selectCount(new QueryWrapper<CommonOrder>().eq("pid", pid));
if(count==null || count<=1) {
baseMapper.updateTreeNodeStatus(pid, ICommonOrderService.NOCHILD);
}
}
}
/**


+ 62
- 3
module-common/src/main/java/org/jeecg/modules/commonOrder/vue/CommonOrderList.vue View File

@ -19,6 +19,16 @@
<a-form-item label="下单用户">
<j-search-select-tag placeholder="请选择下单用户" v-model="queryParam.userId" dict="han_hai_member,nick_name,id"/>
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="联系电话">
<a-input placeholder="请输入联系电话" v-model="queryParam.phone"></a-input>
</a-form-item>
</a-col>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
<a-form-item label="物流编码">
<a-input placeholder="请输入物流编码" v-model="queryParam.wliuNo"></a-input>
</a-form-item>
</a-col>
</template>
<a-col :xl="6" :lg="7" :md="8" :sm="24">
@ -142,6 +152,11 @@
align:"left",
dataIndex: 'createTime'
},
{
title:'订单编号',
align:"left",
dataIndex: 'ordeNo'
},
{
title:'订单状态',
align:"left",
@ -234,9 +249,10 @@
dataIndex: 'details'
},
{
title:'订单编号',
title:'最近回收',
align:"left",
dataIndex: 'ordeNo'
dataIndex: 'izShow',
customRender: (text) => (!text ? "" : (text == "Y" ? "是" : "否"))
},
{
title:'物流编码',
@ -285,6 +301,41 @@
align:"left",
dataIndex: 'isUserId_dictText'
},
{
title:'品牌',
align:"left",
dataIndex: 'pinId'
},
{
title:'合格数量',
align:"left",
dataIndex: 'qualifiedNum'
},
{
title:'不合格数量',
align:"left",
dataIndex: 'noQualifiedNum'
},
{
title:'不可回收数量',
align:"left",
dataIndex: 'unrecyclable'
},
{
title:'分类',
align:"left",
dataIndex: 'shopClass'
},
{
title:'预估价格',
align:"left",
dataIndex: 'estimatedPrice'
},
{
title:'快递员电话',
align:"left",
dataIndex: 'deliveryPhone'
},
{
title: '操作',
dataIndex: 'action',
@ -506,6 +557,7 @@
getSuperFieldList(){
let fieldList=[];
fieldList.push({type:'datetime',value:'createTime',text:'创建日期'})
fieldList.push({type:'string',value:'ordeNo',text:'订单编号',dictCode:''})
fieldList.push({type:'int',value:'state',text:'订单状态',dictCode:'order_type'})
fieldList.push({type:'int',value:'status',text:'流程状态',dictCode:'order_state'})
fieldList.push({type:'sel_search',value:'userId',text:'下单用户',dictTable:"han_hai_member", dictText:'nick_name', dictCode:'id'})
@ -525,7 +577,7 @@
fieldList.push({type:'string',value:'unit',text:'单位',dictCode:''})
fieldList.push({type:'int',value:'num',text:'数量',dictCode:''})
fieldList.push({type:'string',value:'details',text:'简介',dictCode:''})
fieldList.push({type:'string',value:'ordeNo',text:'订单编号',dictCode:''})
fieldList.push({type:'switch',value:'izShow',text:'最近回收'})
fieldList.push({type:'string',value:'wliuNo',text:'物流编码',dictCode:''})
fieldList.push({type:'string',value:'shopId',text:'商品标识',dictCode:''})
fieldList.push({type:'string',value:'addressId',text:'地址标识',dictCode:''})
@ -535,6 +587,13 @@
fieldList.push({type:'Text',value:'testingImages',text:'检测报告',dictCode:''})
fieldList.push({type:'switch',value:'isBy',text:'是否包邮'})
fieldList.push({type:'sel_search',value:'isUserId',text:'质检员',dictTable:"han_hai_member", dictText:'name', dictCode:'id'})
fieldList.push({type:'string',value:'pinId',text:'品牌',dictCode:''})
fieldList.push({type:'int',value:'qualifiedNum',text:'合格数量',dictCode:''})
fieldList.push({type:'int',value:'noQualifiedNum',text:'不合格数量',dictCode:''})
fieldList.push({type:'int',value:'unrecyclable',text:'不可回收数量',dictCode:''})
fieldList.push({type:'string',value:'shopClass',text:'分类',dictCode:''})
fieldList.push({type:'string',value:'estimatedPrice',text:'预估价格',dictCode:''})
fieldList.push({type:'string',value:'deliveryPhone',text:'快递员电话',dictCode:''})
this.superFieldList = fieldList
}
}


+ 23
- 2
module-common/src/main/java/org/jeecg/modules/commonOrder/vue/modules/CommonOrderModal.vue View File

@ -76,8 +76,8 @@
<a-form-model-item label="简介" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="details">
<a-input v-model="model.details" placeholder="请输入简介" ></a-input>
</a-form-model-item>
<a-form-model-item label="订单编号" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="ordeNo">
<a-input v-model="model.ordeNo" placeholder="请输入订单编号" ></a-input>
<a-form-model-item label="最近回收" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="izShow">
<j-switch v-model="model.izShow" ></j-switch>
</a-form-model-item>
<a-form-model-item label="物流编码" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="wliuNo">
<a-input v-model="model.wliuNo" placeholder="请输入物流编码" ></a-input>
@ -106,6 +106,27 @@
<a-form-model-item label="质检员" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="isUserId">
<j-search-select-tag v-model="model.isUserId" dict="han_hai_member,name,id" />
</a-form-model-item>
<a-form-model-item label="品牌" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="pinId">
<a-input v-model="model.pinId" placeholder="请输入品牌" ></a-input>
</a-form-model-item>
<a-form-model-item label="合格数量" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="qualifiedNum">
<a-input-number v-model="model.qualifiedNum" placeholder="请输入合格数量" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="不合格数量" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="noQualifiedNum">
<a-input-number v-model="model.noQualifiedNum" placeholder="请输入不合格数量" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="不可回收数量" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="unrecyclable">
<a-input-number v-model="model.unrecyclable" placeholder="请输入不可回收数量" style="width: 100%" />
</a-form-model-item>
<a-form-model-item label="分类" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="shopClass">
<a-input v-model="model.shopClass" placeholder="请输入分类" ></a-input>
</a-form-model-item>
<a-form-model-item label="预估价格" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="estimatedPrice">
<a-input v-model="model.estimatedPrice" placeholder="请输入预估价格" ></a-input>
</a-form-model-item>
<a-form-model-item label="快递员电话" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="deliveryPhone">
<a-input v-model="model.deliveryPhone" placeholder="请输入快递员电话" ></a-input>
</a-form-model-item>
</a-form-model>
</a-spin>


+ 97
- 5
module-common/src/main/java/org/jeecg/modules/commonOrder/vue3/CommonOrder.data.ts View File

@ -9,6 +9,11 @@ export const columns: BasicColumn[] = [
align:"center",
dataIndex: 'createTime'
},
{
title: '订单编号',
align:"center",
dataIndex: 'ordeNo'
},
{
title: '订单状态',
align:"center",
@ -101,9 +106,12 @@ export const columns: BasicColumn[] = [
dataIndex: 'details'
},
{
title: '订单编号',
title: '最近回收',
align:"center",
dataIndex: 'ordeNo'
dataIndex: 'izShow',
customRender:({text}) => {
return render.renderSwitch(text, [{text:'是',value:'Y'},{text:'否',value:'N'}])
},
},
{
title: '物流编码',
@ -154,6 +162,41 @@ export const columns: BasicColumn[] = [
align:"center",
dataIndex: 'isUserId_dictText'
},
{
title: '品牌',
align:"center",
dataIndex: 'pinId'
},
{
title: '合格数量',
align:"center",
dataIndex: 'qualifiedNum'
},
{
title: '不合格数量',
align:"center",
dataIndex: 'noQualifiedNum'
},
{
title: '不可回收数量',
align:"center",
dataIndex: 'unrecyclable'
},
{
title: '分类',
align:"center",
dataIndex: 'shopClass'
},
{
title: '预估价格',
align:"center",
dataIndex: 'estimatedPrice'
},
{
title: '快递员电话',
align:"center",
dataIndex: 'deliveryPhone'
},
];
//查询数据
export const searchFormSchema: FormSchema[] = [
@ -184,6 +227,18 @@ export const searchFormSchema: FormSchema[] = [
},
colProps: {span: 6},
},
{
label: "联系电话",
field: "phone",
component: 'Input',
colProps: {span: 6},
},
{
label: "物流编码",
field: "wliuNo",
component: 'Input',
colProps: {span: 6},
},
];
//表单数据
export const formSchema: FormSchema[] = [
@ -294,9 +349,11 @@ export const formSchema: FormSchema[] = [
component: 'Input',
},
{
label: '订单编号',
field: 'ordeNo',
component: 'Input',
label: '最近回收',
field: 'izShow',
component: 'JSwitch',
componentProps:{
},
},
{
label: '物流编码',
@ -353,4 +410,39 @@ export const formSchema: FormSchema[] = [
dict:"han_hai_member,name,id"
},
},
{
label: '品牌',
field: 'pinId',
component: 'Input',
},
{
label: '合格数量',
field: 'qualifiedNum',
component: 'InputNumber',
},
{
label: '不合格数量',
field: 'noQualifiedNum',
component: 'InputNumber',
},
{
label: '不可回收数量',
field: 'unrecyclable',
component: 'InputNumber',
},
{
label: '分类',
field: 'shopClass',
component: 'Input',
},
{
label: '预估价格',
field: 'estimatedPrice',
component: 'Input',
},
{
label: '快递员电话',
field: 'deliveryPhone',
component: 'Input',
},
];

+ 20
- 0
module-system/src/main/resources/application-dev.yml View File

@ -345,8 +345,28 @@ wechat:
refundNotifyUrl: # 退款通知地址(正式环境)
#正式环境
#dblogistics:
# companyCode: EWBXZDDMXX
# appKey: eb4cd9c454e93a2b76a9d9c5c1f8542a
# sign: ZRNR
# customerCode: 1102311359
# api:
# # 创建订单接口
# createOrder: http://gwapi.deppon.com/dop-interface-async/standard-order/createOrderNotify.action
# # 轨迹查询接口0
# queryTrace: http://dpapi.deppon.com/dop-interface-sync/standard-query/newTraceQuery.action
# # 修改订单接口
# updateOrder: http://gwapi.deppon.com/dop-interface-async/standard-order/updateOrder.action
# # 撤销订单接口
# cancelOrder: http://gwapi.deppon.com/dop-interface-async/standard-order/cancelOrder.action
# # 查询订单接口
# queryOrder: http://dpapi.deppon.com/dop-interface-sync/standard-query/queryOrder.action
# # 轨迹订阅接口
# subscribeTrace: http://dpapi.deppon.com/dop-interface-sync/dop-nonstandard-extension/standTraceSubscribe.action
#测试环境
dblogistics:
companyCode: EWBXZDDMXX
appKey: eb4cd9c454e93a2b76a9d9c5c1f8542a


Loading…
Cancel
Save