addOrder.vue 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761
  1. <template>
  2. <div class="app-container">
  3. <!-- 添加一个加载状态,在获取createOrderType之前显示 -->
  4. <div v-if="!formReady" style="text-align: center; padding: 50px;">
  5. <i class="el-icon-loading"></i> 正在加载...
  6. </div>
  7. <!-- 只有在formReady为true时才显示表单 -->
  8. <el-form v-if="formReady" ref="form" :model="form" :rules="rules" label-width="120px">
  9. <el-form-item label="会员信息" prop="userId">
  10. <el-row>
  11. <el-col>
  12. <el-input placeholder="请输入会员手机号" style="width:240px;cursor:pointer" v-model="phone">
  13. </el-input>
  14. <el-button plain style="margin-left:10px;" @click="searchUser()">查询</el-button>
  15. <el-button plain style="margin-left:10px;" icon="el-icon-plus" type="primary" @click="handleAddUser()">添加会员</el-button>
  16. </el-col>
  17. </el-row>
  18. <el-table border style="margin-top:5px;" v-loading="userloading" :data="users">
  19. <el-table-column label="ID" align="center" prop="userId" />
  20. <el-table-column label="会员头像" align="center" width="80">
  21. <template slot-scope="scope">
  22. <el-popover placement="right" title="" trigger="hover">
  23. <img slot="reference" :src="scope.row.avatar" width="50">
  24. <img :src="scope.row.avatar" style="max-width: 120px;">
  25. </el-popover>
  26. </template>
  27. </el-table-column>
  28. <el-table-column label="昵称" align="center" prop="nickname" />
  29. <el-table-column label="手机号" align="center" prop="phone" />
  30. <el-table-column label="状态" align="center" prop="status">
  31. <template slot-scope="scope">
  32. <el-tag prop="status" v-for="(item, index) in userStatusOptions" v-if="scope.row.status==item.dictValue">{{item.dictLabel}}</el-tag>
  33. </template>
  34. </el-table-column>
  35. </el-table>
  36. </el-form-item>
  37. <el-form-item label="收货信息" prop="addressId">
  38. <el-row>
  39. <el-col>
  40. <el-button plain type="primary" icon="el-icon-plus" @click="handleAddUserAddress()">添加收货地址</el-button>
  41. </el-col>
  42. </el-row>
  43. <el-radio-group v-model="form.addressId" style="width:100%">
  44. <el-table border style="margin-top:5px;" v-loading="addressloading" :data="address">
  45. <el-table-column label="ID" align="center" >
  46. <template slot-scope="scope">
  47. <el-radio :label="scope.row.addressId"></el-radio>
  48. </template>
  49. </el-table-column>
  50. <el-table-column label="收货人姓名" align="center" prop="realName" />
  51. <el-table-column label="收货人电话" align="center" prop="phone" />
  52. <el-table-column label="地址" align="center" prop="detail">
  53. <template slot-scope="scope">
  54. {{scope.row.province}} {{scope.row.city}} {{scope.row.district}} {{scope.row.detail}}
  55. </template>
  56. </el-table-column>
  57. </el-table>
  58. </el-radio-group>
  59. </el-form-item>
  60. <el-form-item label="商品列表">
  61. <el-row>
  62. <el-col>
  63. <el-button plain type="primary" icon="el-icon-plus" @click="handleAddProduct">添加商品</el-button>
  64. </el-col>
  65. </el-row>
  66. <el-table border :key="tablekey" width="100%" style="margin-top:5px;" :data="products">
  67. <el-table-column label="商品编号" align="center" prop="barCode" />
  68. <el-table-column label="商品图片" align="center" width="100">
  69. <template slot-scope="scope">
  70. <el-popover placement="right" title="" trigger="hover">
  71. <img slot="reference" :src="scope.row.image" width="50">
  72. <img :src="scope.row.image" style="max-width: 50px;">
  73. </el-popover>
  74. </template>
  75. </el-table-column>
  76. <el-table-column label="商品名称" show-overflow-tooltip align="center" prop="productName" />
  77. <el-table-column label="商品规格" align="center" prop="sku" />
  78. <el-table-column label="库存" align="center" prop="stock" />
  79. <el-table-column label="单价" align="center" prop="price" width="200px" v-if="createOrderType == 1">
  80. <template slot-scope="scope">
  81. <el-input-number v-model="scope.row.price" @change="handleProductCountChange(scope.row)" size="mini" :min="0.01"></el-input-number>
  82. </template>
  83. </el-table-column>
  84. <el-table-column label="单价" align="center" prop="price" v-if="createOrderType == 2"/>
  85. <el-table-column label="数量" align="center" prop="count" width="200px" :key="tablekey">
  86. <template slot-scope="scope">
  87. <div>
  88. <el-input-number v-model="scope.row.count" @change="handleProductCountChange(scope.row)" size="mini" :min="1" :max="scope.row.stock"></el-input-number>
  89. </div>
  90. </template>
  91. </el-table-column>
  92. <el-table-column label="小计" align="center" prop="money" />
  93. <el-table-column label="操作" align="center" width="100px">
  94. <template slot-scope="scope">
  95. <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)">删除</el-button>
  96. </template>
  97. </el-table-column>
  98. </el-table>
  99. <el-row>
  100. <el-col>
  101. <span>商品合计:{{products.length}}</span><span style="margin-left:10px;">商品总价:{{totalMoney.toFixed(2)}}</span>
  102. </el-col>
  103. </el-row>
  104. </el-form-item>
  105. <el-form-item label="订单类型" prop="orderType">
  106. <el-select v-model="form.orderType" placeholder="请选择订单类型" clearable size="small">
  107. <el-option v-for="item in orderTypeOptions" :key="item.dictValue" :label="item.dictLabel" :value="item.dictValue" />
  108. </el-select>
  109. </el-form-item>
  110. <el-form-item label="媒体来源" prop="orderMedium" v-if="orderMediumOptions.length>0">
  111. <el-select v-model="form.orderMedium" placeholder="请选择媒体来源" clearable size="small">
  112. <el-option v-for="item in orderMediumOptions" :key="item.dictValue" :label="item.dictLabel" :value="item.dictValue" />
  113. </el-select>
  114. </el-form-item>
  115. <el-form-item label="支付方式" prop="payType">
  116. <el-select v-model="form.payType" placeholder="请选择支付方式" clearable size="small">
  117. <el-option v-for="item in payTypeOptions" :key="item.dictValue" :label="item.dictLabel" :value="item.dictValue" />
  118. </el-select>
  119. </el-form-item>
  120. <el-form-item label="改价" prop="payPrice" v-if="createOrderType == 2">
  121. <el-input-number v-model="form.payPrice" placeholder="修改商品总价" size="medium" :precision="2" :min="0.01" :step="0.1" />
  122. </el-form-item>
  123. <el-form-item label="物流代收" prop="amount" v-if="form.payType == '3'">
  124. <el-input-number v-model="form.amount" placeholder="平台支付价格" size="medium" :precision="2" :min="0.01" :step="0.1" />
  125. </el-form-item>
  126. <el-form-item label="订单备注" prop="mark">
  127. <el-input type="textarea" rows="2" v-model="form.mark" placeholder="" />
  128. </el-form-item>
  129. </el-form>
  130. <div v-if="formReady" slot="footer" class="dialog-footer" style="float: right; margin-bottom: 20px;">
  131. <el-button type="primary" @click="submitForm">确 定</el-button>
  132. <el-button @click="cancel">取 消</el-button>
  133. </div>
  134. <!-- 对话框部分保持不变 -->
  135. <el-dialog :title="product.title" v-if="product.open" :visible.sync="product.open" width="1000px" append-to-body>
  136. <product-select @selectProduct="selectProduct" />
  137. </el-dialog>
  138. <el-dialog :title="user.title" v-if="user.open" :visible.sync="user.open" width="500px" append-to-body>
  139. <add-user @addUser="addUser" />
  140. </el-dialog>
  141. <el-dialog :title="userAddress.title" v-if="userAddress.open" :visible.sync="userAddress.open" width="800px" append-to-body>
  142. <add-user-address ref="addUserAddress" @addUserAddress="addUserAddress" />
  143. </el-dialog>
  144. <el-dialog :title="payQr.title" v-if="payQr.open" :visible.sync="payQr.open" width="240px" append-to-body>
  145. <div style="padding-bottom:15px;">
  146. <div class="qrcode" ref="qrCodeUrl"></div>
  147. </div>
  148. </el-dialog>
  149. </div>
  150. </template>
  151. <script>
  152. import {exportStoreOrderItems, createUserOrder,listStoreOrder, getStoreOrder, delStoreOrder, addStoreOrder, updateStoreOrder, exportStoreOrder,getCreateOrderType } from "@/api/hisStore/storeOrder";
  153. import { getUserList } from "@/api/users/user";
  154. import { getAddressList } from "@/api/users/userAddress";
  155. import { getTcmScheduleList } from "@/api/company/tcmScheduleReport";
  156. import productOrder from "@/views/hisStore/components/productOrder";
  157. import productSelect from "@/views/hisStore/components/productSelect";
  158. import addUser from "@/views/hisStore/components/addUser";
  159. import addUserAddress from "@/views/hisStore/components/addUserAddress";
  160. import config from "@/utils/config";
  161. import QRCode from 'qrcodejs2'
  162. import { treeselect } from "@/api/company/companyDept";
  163. import Treeselect from "@riophae/vue-treeselect";
  164. import "@riophae/vue-treeselect/dist/vue-treeselect.css";
  165. export default {
  166. components: { Treeselect,productOrder,productSelect,addUser,addUserAddress },
  167. name: "StoreOrder",
  168. props: {
  169. customerId: {
  170. type: Number,
  171. required: false
  172. },
  173. userId: {
  174. type: Number,
  175. required: false
  176. }
  177. },
  178. data() {
  179. return {
  180. // 添加表单准备状态
  181. formReady: false,
  182. createOrderType: null,
  183. // 部门树选项
  184. deptOptions: undefined,
  185. // 部门名称
  186. deptName: undefined,
  187. defaultProps: {
  188. children: "children",
  189. label: "label",
  190. },
  191. deliveryPayStatusOptions:[],
  192. deliveryStatusOptions:[],
  193. dateRange: [],
  194. orderTypeOptions:[],
  195. orderMediumOptions:[],
  196. payTypeOptions:[],
  197. payQr:{
  198. open:false,
  199. title:"付款二维码"
  200. },
  201. user:{
  202. open:false,
  203. title:"创建会员"
  204. },
  205. userAddress:{
  206. open:false,
  207. title:"创建收货地址"
  208. },
  209. tablekey:false,
  210. totalMoney:0.00,
  211. products:[],
  212. product:{
  213. open:false,
  214. title:"商品选择"
  215. },
  216. phone:null,
  217. address:[],
  218. addressloading: false,
  219. userloading: false,
  220. users:[],
  221. userStatusOptions:[],
  222. show:{
  223. open:false,
  224. title:"订单详情"
  225. },
  226. activeName:"00",
  227. statusOptions:[],
  228. // 遮罩层
  229. loading: true,
  230. // 选中数组
  231. ids: [],
  232. // 非单个禁用
  233. single: true,
  234. // 非多个禁用
  235. multiple: true,
  236. // 显示搜索条件
  237. showSearch: true,
  238. // 总条数
  239. total: 0,
  240. // 订单表格数据
  241. storeOrderList: [],
  242. // 弹出层标题
  243. title: "",
  244. // 是否显示弹出层
  245. open: false,
  246. createTimeRange:[],
  247. payTimeRange:[],
  248. deliveryImportTimeRange:[],
  249. scheduleOptions:[],
  250. // 查询参数
  251. queryParams: {
  252. pageNum: 1,
  253. pageSize: 10,
  254. orderCode: null,
  255. extendOrderId: null,
  256. userId: null,
  257. realName: null,
  258. userPhone: null,
  259. userAddress: null,
  260. cartId: null,
  261. freightPrice: null,
  262. totalNum: null,
  263. totalPrice: null,
  264. totalPostage: null,
  265. payPrice: null,
  266. payPostage: null,
  267. deductionPrice: null,
  268. couponId: null,
  269. couponPrice: null,
  270. paid: null,
  271. payTime: null,
  272. payType: null,
  273. status: null,
  274. refundStatus: null,
  275. refundReasonWapImg: null,
  276. refundReasonWapExplain: null,
  277. refundReasonTime: null,
  278. refundReasonWap: null,
  279. refundReason: null,
  280. refundPrice: null,
  281. deliverySn: null,
  282. deliveryName: null,
  283. deliveryType: null,
  284. deliveryId: null,
  285. gainIntegral: null,
  286. useIntegral: null,
  287. payIntegral: null,
  288. backIntegral: null,
  289. mark: null,
  290. isDel: null,
  291. cost: null,
  292. verifyCode: null,
  293. storeId: null,
  294. shippingType: null,
  295. isChannel: null,
  296. isRemind: null,
  297. isSysDel: null
  298. },
  299. // 表单参数
  300. form: {
  301. addressId:null,
  302. userId:null,
  303. products:[],
  304. },
  305. // 表单校验
  306. rules: {
  307. userId: [
  308. { required: true, message: "会员信息不能为空", trigger: "submit" }
  309. ],
  310. addressId: [
  311. { required: true, message: "收货信息不能为空", trigger: "submit" }
  312. ],
  313. products: [
  314. { required: true, message: "商品不能为空", trigger: "submit" }
  315. ],
  316. }
  317. };
  318. },
  319. watch: {
  320. // 根据名称筛选部门树
  321. deptName(val) {
  322. this.$refs.tree.filter(val);
  323. },
  324. },
  325. created() {
  326. // 先获取createOrderType,然后再初始化其他数据
  327. this.initializeForm();
  328. },
  329. methods: {
  330. // 初始化表单的方法
  331. async initializeForm() {
  332. try {
  333. // 1. 首先获取createOrderType
  334. const response = await getCreateOrderType();
  335. this.createOrderType = response.createSalesOrderType;
  336. // 2. 然后并行加载其他数据
  337. await Promise.all([
  338. this.loadDictionaries(),
  339. this.loadOtherData(),
  340. this.initUser()
  341. ]);
  342. // 3. 所有数据加载完成后,设置表单为准备状态
  343. this.formReady = true;
  344. console.log('Form is ready to display');
  345. } catch (error) {
  346. console.error('Error initializing form:', error);
  347. this.$message.error('表单初始化失败');
  348. }
  349. },
  350. // 加载字典数据
  351. async loadDictionaries() {
  352. const dictPromises = [
  353. this.getDicts("crm_customer_source").then((response) => {
  354. this.orderMediumOptions = response.data;
  355. }),
  356. this.getDicts("store_order_type").then((response) => {
  357. this.orderTypeOptions = response.data;
  358. }),
  359. this.getDicts("store_pay_type").then((response) => {
  360. this.payTypeOptions = response.data;
  361. }),
  362. this.getDicts("user_status").then((response) => {
  363. this.userStatusOptions = response.data;
  364. }),
  365. this.getDicts("store_order_status").then((response) => {
  366. this.statusOptions = response.data;
  367. }),
  368. this.getDicts("store_order_delivery_status").then((response) => {
  369. this.deliveryStatusOptions = response.data;
  370. }),
  371. this.getDicts("store_delivery_pay_status").then((response) => {
  372. this.deliveryPayStatusOptions = response.data;
  373. })
  374. ];
  375. await Promise.all(dictPromises);
  376. },
  377. // 加载其他数据
  378. async loadOtherData() {
  379. await Promise.all([
  380. this.getTreeselect(),
  381. getTcmScheduleList().then(response => {
  382. this.scheduleOptions = response.data;
  383. })
  384. ]);
  385. },
  386. initUser(){
  387. return new Promise((resolve) => {
  388. if(this.userId != null){
  389. var data={userId:this.userId}
  390. this.userloading = true;
  391. this.users=[];
  392. this.address=[];
  393. getUserList(data).then(response => {
  394. this.users = response.data;
  395. this.userloading = false;
  396. if(this.users!=null&&this.users.length==1){
  397. this.form.userId=this.users[0].userId;
  398. this.getAddressList(this.form.userId).then(() => {
  399. resolve();
  400. });
  401. } else {
  402. resolve();
  403. }
  404. }).catch(() => {
  405. resolve();
  406. });
  407. } else {
  408. resolve();
  409. }
  410. });
  411. },
  412. /** 查询部门下拉树结构 */
  413. getTreeselect() {
  414. return treeselect().then((response) => {
  415. this.deptOptions = response.data;
  416. });
  417. },
  418. // 修改getAddressList方法,返回Promise
  419. getAddressList(userId){
  420. var data={userId:userId}
  421. this.addressloading = true;
  422. this.address=[];
  423. return getAddressList(data).then(response => {
  424. this.address = response.data;
  425. this.addressloading = false;
  426. });
  427. },
  428. // 其他方法保持不变...
  429. // 筛选节点
  430. filterNode(value, data) {
  431. if (!value) return true;
  432. return data.label.indexOf(value) !== -1;
  433. },
  434. // 节点单击事件
  435. handleNodeClick(data) {
  436. this.queryParams.deptId = data.id;
  437. this.getList();
  438. },
  439. handleGenPayUrl(row){
  440. this.payQr.open=true;
  441. setTimeout(() => {
  442. var qrcode = new QRCode(this.$refs.qrCodeUrl, {
  443. text: config.payQRUrl+row.id,
  444. width: 200,
  445. height: 200,
  446. colorDark: '#000000',
  447. colorLight: '#ffffff',
  448. correctLevel: QRCode.CorrectLevel.H
  449. })
  450. }, 200);
  451. },
  452. handleAddUser(){
  453. this.user.open=true;
  454. },
  455. handleAddUserAddress(){
  456. if(this.form.userId==null){
  457. this.msgError("请选择会员");
  458. return;
  459. }
  460. this.userAddress.open=true;
  461. setTimeout(() => {
  462. this.$refs.addUserAddress.init(this.form.userId);
  463. }, 500);
  464. },
  465. addUserAddress(){
  466. this.userAddress.open=false;
  467. //获取地址
  468. this.getAddressList(this.form.userId);
  469. },
  470. addUser(){
  471. this.user.open=false;
  472. },
  473. compute(){
  474. this.totalMoney=0;
  475. var that=this;
  476. this.products.forEach (function (value) {
  477. that.totalMoney += value.money;
  478. });
  479. },
  480. handleProductCountChange(row){
  481. this.tablekey = !this.tablekey
  482. row.money=row.count*row.price;
  483. this.$forceUpdate();
  484. this.compute();
  485. },
  486. selectProduct(row){
  487. for(var i=0;i<this.products.length;i++){
  488. if(this.products[i].id==row.id){
  489. return;
  490. }
  491. }
  492. row.count=1;
  493. row.money=row.count*row.price;
  494. this.products.push(row);
  495. this.$message.success("商品"+ row.productName + "添加成功")
  496. this.compute();
  497. },
  498. handleAddProduct(){
  499. this.product.open=true;
  500. },
  501. searchUser(){
  502. if(this.phone==null||this.phone==""){
  503. return;
  504. }
  505. var data={phone:this.phone}
  506. this.userloading = true;
  507. this.users=[];
  508. this.address=[];
  509. getUserList(data).then(response => {
  510. this.users = response.data;
  511. this.userloading = false;
  512. if(this.users!=null&&this.users.length==1){
  513. this.form.userId=this.users[0].userId;
  514. this.getAddressList(this.form.userId)
  515. }
  516. });
  517. },
  518. handleDetails(row){
  519. this.show.open=true;
  520. const orderId = row.id ;
  521. setTimeout(() => {
  522. this.$refs.order.getOrder(orderId);
  523. }, 500);
  524. },
  525. handleClick(tab, event) {
  526. if(tab.name=="all"){
  527. this.queryParams.status==null;
  528. }
  529. else{
  530. this.queryParams.status=tab.name;
  531. }
  532. this.getList();
  533. },
  534. /** 查询订单列表 */
  535. getList() {
  536. if(this.queryParams.status=='00'){
  537. this.queryParams.status=null;
  538. }
  539. if(this.createTimeRange!=null&&this.createTimeRange.length==2){
  540. this.queryParams.createTimeRange=this.createTimeRange[0]+"--"+this.createTimeRange[1]
  541. }
  542. else{
  543. this.queryParams.createTimeRange=null;
  544. }
  545. if(this.payTimeRange!=null&&this.payTimeRange.length==2){
  546. this.queryParams.payTimeRange=this.payTimeRange[0]+"--"+this.payTimeRange[1]
  547. }
  548. else{
  549. this.queryParams.payTimeRange=null;
  550. }
  551. if(this.deliveryImportTimeRange!=null&&this.deliveryImportTimeRange.length==2){
  552. this.queryParams.deliveryImportTimeRange=this.deliveryImportTimeRange[0]+"--"+this.deliveryImportTimeRange[1]
  553. }
  554. else{
  555. this.queryParams.deliveryImportTimeRange=null;
  556. }
  557. this.loading = true;
  558. listStoreOrder(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
  559. this.storeOrderList = response.rows;
  560. this.total = response.total;
  561. this.loading = false;
  562. });
  563. },
  564. // 取消按钮
  565. cancel() {
  566. this.open = false;
  567. this.reset();
  568. this.$emit("closePackage")
  569. },
  570. // 表单重置
  571. reset() {
  572. this.form = {
  573. addressId:null,
  574. userId:null,
  575. products:null,
  576. };
  577. this.resetForm("form");
  578. },
  579. /** 搜索按钮操作 */
  580. handleQuery() {
  581. this.queryParams.pageNum = 1;
  582. this.getList();
  583. },
  584. /** 重置按钮操作 */
  585. resetQuery() {
  586. this.resetForm("queryForm");
  587. this.handleQuery();
  588. },
  589. /** 新增按钮操作 */
  590. handleAdd() {
  591. this.reset();
  592. this.open = true;
  593. this.title = "创建订单";
  594. },
  595. /** 修改按钮操作 */
  596. handleUpdate(row) {
  597. this.reset();
  598. const id = row.id || this.ids
  599. getStoreOrder(id).then(response => {
  600. this.form = response.data;
  601. this.open = true;
  602. this.title = "修改订单";
  603. });
  604. },
  605. /** 提交按钮 */
  606. submitForm() {
  607. this.$refs["form"].validate(valid => {
  608. if(this.products.length==0){
  609. this.msgError("请选择商品");
  610. return;
  611. }
  612. this.form.products=this.products;
  613. if (valid) {
  614. this.form.customerId = this.customerId;
  615. createUserOrder(this.form).then(response => {
  616. if (response.code === 200) {
  617. this.msgSuccess("创建成功");
  618. this.$emit("closePackage")
  619. }
  620. });
  621. }
  622. });
  623. },
  624. /** 删除按钮操作 */
  625. handleDelete(row) {
  626. this.products.splice(this.products.findIndex(item => item.id === row.id), 1)
  627. this.compute();
  628. },
  629. /** 导出按钮操作 */
  630. handleExport() {
  631. if(this.queryParams.status=='00'){
  632. this.queryParams.status=null;
  633. }
  634. if(this.createTimeRange!=null&&this.createTimeRange.length==2){
  635. this.queryParams.createTimeRange=this.createTimeRange[0]+"--"+this.createTimeRange[1]
  636. }
  637. else{
  638. this.queryParams.createTimeRange=null;
  639. }
  640. if(this.payTimeRange!=null&&this.payTimeRange.length==2){
  641. this.queryParams.payTimeRange=this.payTimeRange[0]+"--"+this.payTimeRange[1]
  642. }
  643. else{
  644. this.queryParams.payTimeRange=null;
  645. }
  646. if(this.deliveryImportTimeRange!=null&&this.deliveryImportTimeRange.length==2){
  647. this.queryParams.deliveryImportTimeRange=this.deliveryImportTimeRange[0]+"--"+this.deliveryImportTimeRange[1]
  648. }
  649. else{
  650. this.queryParams.deliveryImportTimeRange=null;
  651. }
  652. const queryParams = this.addDateRange(this.queryParams, this.dateRange);
  653. this.$confirm('是否确认导出所有订单数据项?', "警告", {
  654. confirmButtonText: "确定",
  655. cancelButtonText: "取消",
  656. type: "warning"
  657. }).then(function() {
  658. return exportStoreOrder(queryParams);
  659. }).then(response => {
  660. this.download(response.msg);
  661. }).catch(function() {});
  662. },
  663. handleExportItems() {
  664. if(this.queryParams.status=='00'){
  665. this.queryParams.status=null;
  666. }
  667. if(this.createTimeRange!=null&&this.createTimeRange.length==2){
  668. this.queryParams.createTimeRange=this.createTimeRange[0]+"--"+this.createTimeRange[1]
  669. }
  670. else{
  671. this.queryParams.createTimeRange=null;
  672. }
  673. if(this.payTimeRange!=null&&this.payTimeRange.length==2){
  674. this.queryParams.payTimeRange=this.payTimeRange[0]+"--"+this.payTimeRange[1]
  675. }
  676. else{
  677. this.queryParams.payTimeRange=null;
  678. }
  679. if(this.deliveryImportTimeRange!=null&&this.deliveryImportTimeRange.length==2){
  680. this.queryParams.deliveryImportTimeRange=this.deliveryImportTimeRange[0]+"--"+this.deliveryImportTimeRange[1]
  681. }
  682. else{
  683. this.queryParams.deliveryImportTimeRange=null;
  684. }
  685. const queryParams = this.addDateRange(this.queryParams, this.dateRange);
  686. this.$confirm('是否确认导出所有订单明细数据项?', "警告", {
  687. confirmButtonText: "确定",
  688. cancelButtonText: "取消",
  689. type: "warning"
  690. }).then(function() {
  691. return exportStoreOrderItems(queryParams);
  692. }).then(response => {
  693. this.download(response.msg);
  694. }).catch(function() {});
  695. }
  696. }
  697. };
  698. </script>
  699. <style scoped lang="scss">
  700. .items{
  701. margin: 5px 0px;
  702. display: flex;
  703. flex-direction: row;
  704. align-items: center;
  705. justify-content: flex-start;
  706. .pic{
  707. width:60px;
  708. height:60px;
  709. }
  710. .goods-content{
  711. margin-left: 10px;
  712. max-width: 200px;
  713. text-align: left;
  714. .goods-title{
  715. overflow:hidden;
  716. white-space: nowrap;
  717. text-overflow: ellipsis;
  718. -o-text-overflow:ellipsis;
  719. }
  720. }
  721. }
  722. .el-message-box__message p{
  723. max-height: 400px;
  724. overflow:scroll;
  725. }
  726. .import-msg{
  727. height: 500px;
  728. overflow: auto;
  729. }
  730. </style>
  731. <style>
  732. .el-descriptions-item__label.is-bordered-label{
  733. font-weight: normal;
  734. }
  735. </style>