index.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841
  1. <template>
  2. <a-card :bordered="false" style="margin-bottom: 10px" class="mb-2">
  3. <a-form ref="searchFormRef" name="advanced_search" :model="searchFormState" class="ant-advanced-search-form">
  4. <a-row :gutter="24">
  5. <a-col :span="6">
  6. <a-form-item label="订单编号" name="orderNumber">
  7. <a-input v-model:value="searchFormState.orderNumber" placeholder="订单编号查询" />
  8. </a-form-item>
  9. </a-col>
  10. <a-col :span="6">
  11. <a-form-item label="订单名称" name="orderName">
  12. <a-input v-model:value="searchFormState.orderName" placeholder="订单名称查询" />
  13. </a-form-item>
  14. </a-col>
  15. <a-col :span="6">
  16. <a-form-item label="客户名称" name="customerName">
  17. <a-input v-model:value="searchFormState.customerName" placeholder="客户名称查询" />
  18. </a-form-item>
  19. </a-col>
  20. <template v-if="advanced">
  21. <a-col :span="6">
  22. <a-form-item label="货品名称" name="goodsName">
  23. <a-input v-model:value="searchFormState.goodsName" placeholder="货品名称查询" />
  24. </a-form-item>
  25. </a-col>
  26. <a-col :span="6">
  27. <a-form-item label="订单状态" name="orderStatus">
  28. <a-select v-model:value="searchFormState.orderStatus" placeholder="订单状态查询"
  29. :options="orderStatusList"
  30. > </a-select>
  31. </a-form-item>
  32. </a-col>
  33. <!-- <a-col :span="6">
  34. <a-form-item label="订单来源" name="orderSource">
  35. <a-select v-model:value="searchFormState.orderSource" placeholder="订单状态查询"
  36. :options="orderSourceList"
  37. > </a-select>
  38. </a-form-item>
  39. </a-col>-->
  40. </template>
  41. <a-col :span="6">
  42. <a-button type="primary" @click="tableRef.refresh()">查询</a-button>
  43. <a-button style="margin: 0 8px" @click="reset">重置</a-button>
  44. <a @click="toggleAdvanced" style="margin-left: 8px">
  45. {{ advanced ? '收起' : '展开' }}
  46. <component :is="advanced ? 'up-outlined' : 'down-outlined'" />
  47. </a>
  48. </a-col>
  49. </a-row>
  50. </a-form>
  51. </a-card>
  52. <a-card :bordered="false">
  53. <s-table
  54. ref="tableRef"
  55. :columns="columns"
  56. :data="loadData"
  57. bordered
  58. :row-key="(record) => record.id"
  59. >
  60. <template #operator class="table-operator">
  61. <a-space>
  62. <a-button type="primary" @click="formRef.onOpen()" v-if="hasPerm('bizOrderAdd')">
  63. <template #icon><plus-outlined /></template>
  64. 新增
  65. </a-button>
  66. <a-button @click="exportTotal" v-if="hasPerm('bizOrderExport')">
  67. <template #icon>
  68. <export-outlined/>
  69. </template>
  70. 导出
  71. </a-button>
  72. </a-space>
  73. </template>
  74. <template #bodyCell="{ column, record }">
  75. <template v-if="column.dataIndex === 'orderType'">
  76. <a-tag
  77. :color="
  78. record.orderType === '1'
  79. ? 'orange'
  80. : record.orderType === '2'
  81. ? 'green'
  82. : 'purple'
  83. "
  84. >
  85. {{ $TOOL.dictTypeData('order_type', record.orderType) }}
  86. </a-tag>
  87. </template>
  88. <template v-if="column.dataIndex === 'orderSource'">
  89. <a-tag
  90. :color="
  91. record.orderSource === '1'
  92. ? 'orange'
  93. : record.orderSource === '2'
  94. ? 'green'
  95. : 'purple'
  96. "
  97. >
  98. {{ $TOOL.dictTypeData('order_source', record.orderSource) }}
  99. </a-tag>
  100. </template>
  101. <template v-if="column.dataIndex === 'orderStatus'">
  102. <a-tag
  103. :color="
  104. record.orderStatus === '1'
  105. ? 'blue'
  106. : record.orderStatus === '2'
  107. ? 'warning'
  108. : record.orderStatus === '3'
  109. ? 'processing'
  110. : record.orderStatus === '4'
  111. ? 'volcano'
  112. : record.orderStatus === '5'
  113. ? 'purple'
  114. : record.orderStatus === '6'
  115. ? 'error'
  116. : record.orderStatus === '7'
  117. ? 'red'
  118. : '#f50'
  119. "
  120. >
  121. {{ $TOOL.dictTypeData('order_status', record.orderStatus) }}
  122. </a-tag>
  123. </template>
  124. <template v-if="column.dataIndex === 'orderWeight'">
  125. {{record.orderWeight + '吨'}}
  126. </template>
  127. <template v-if="column.dataIndex === 'netWeight'">
  128. {{record.netWeight + '吨'}}
  129. </template>
  130. <template v-if="column.dataIndex === 'action'">
  131. <a @click="showModal(record)" v-if="record.orderStatus == '3' || record.orderStatus == '4'">二维码</a>
  132. <a-divider type="vertical" v-if="record.orderStatus == '3' || record.orderStatus == '4'"/>
  133. <a-dropdown>
  134. <a class="ant-dropdown-link">
  135. 更多
  136. <DownOutlined />
  137. </a>
  138. <template #overlay>
  139. <a-menu>
  140. <a-menu-item>
  141. <a size="small" type="link" @click="detailRef.onOpen(record)" >详情</a>
  142. </a-menu-item>
  143. <a-menu-item v-if="hasPerm('bizOrderSubmit') && record.orderStatus=='0'">
  144. <a style="color:orangered" size="small" type="link" @click="submit(record.id)">提交</a>
  145. </a-menu-item>
  146. <a-menu-item v-if="hasPerm('bizOrderEdit') && (record.orderStatus == '0')">
  147. <a style="color:blue" size="small" type="link" @click="formRef.onOpen(record)" >编辑</a>
  148. </a-menu-item>
  149. <a-menu-item v-if="hasPerm('bizOrderDelete') && (record.orderStatus == '0')">
  150. <a style="color:red" size="small" type="link" @click="deleteConfig(record)">删除</a>
  151. </a-menu-item>
  152. <!-- <a-menu-item v-if="record.orderStatus == '1'">
  153. <a style="color:orange" @click="selectCustomer(record)">绑定</a>
  154. </a-menu-item>-->
  155. <a-menu-item v-if="hasPerm('bizOrderSign') && record.orderStatus == '1'">
  156. <a style="color:orange" @click="XnSignNameRef.show(record.id)">签名</a>
  157. </a-menu-item>
  158. <a-menu-item v-if="hasPerm('bizOrderConfirm') && record.orderStatus == '2'">
  159. <a style="color:blue" @click="orderConfirm(record.id)">确认</a>
  160. </a-menu-item>
  161. <a-menu-item v-if="hasPerm('bizOrderAudit') && record.orderStatus == '5'">
  162. <a style="color:green" @click="reviewRef.showModal(record.id)">审核</a>
  163. </a-menu-item>
  164. <a-menu-item v-if="hasPerm('bizOrderFlow') && (record.orderStatus == '4' || record.orderStatus=='5' || record.orderStatus=='6' || record.orderStatus=='7')">
  165. <a style="color:deepskyblue" @click="flowRef.onOpen(record)">流水</a>
  166. </a-menu-item>
  167. <a-menu-item v-if="hasPerm('bizOrderConfig') && (record.orderStatus == '3' || record.orderStatus=='4')">
  168. <a style="color:forestgreen" @click="showMore(record)">配置</a>
  169. </a-menu-item>
  170. <a-menu-item v-if="hasPerm('bizOrderEnd') && (record.orderStatus == '3' || record.orderStatus == '4')">
  171. <a style="color:red" @click="endRef.showModal(record.id)">结束</a>
  172. </a-menu-item>
  173. </a-menu>
  174. </template>
  175. </a-dropdown>
  176. <!-- <a-space>
  177. <a @click="formRef.onOpen(record)" v-if="hasPerm('bizOrderEdit')">编辑</a>
  178. <a-divider type="vertical" v-if="hasPerm(['bizOrderEdit', 'bizOrderDelete'], 'and')" />
  179. <a-button type="link" danger size="small" v-if="hasPerm('bizOrderDelete')" @click="deleteConfig(record)">删除</a-button>
  180. </a-space>-->
  181. </template>
  182. </template>
  183. </s-table>
  184. </a-card>
  185. <Form ref="formRef" @successful="tableRef.refresh()" />
  186. <Detail ref="detailRef" @successful="tableRef.refresh()" />
  187. <Flow ref="flowRef" @successful="tableRef.refresh()" />
  188. <Review ref="reviewRef" @successful="tableRef.refresh(true)" />
  189. <End ref="endRef" @successful="tableRef.refresh(true)" />
  190. <XnSignName ref="XnSignNameRef" @successful="signSuccess" />
  191. <a-modal v-model:visible="open" title="二维码" width="600px" style="height: 700px">
  192. <div id="qrcode" style="text-align: center; margin: 15px 5px 15px 5px">
  193. <a-row>
  194. <a-col :span="13" id="colFlag">
  195. <div style="margin-top:10px;font-size:16px;">
  196. <p id="projectNameFlag">订单名称:{{nowRecord.orderName}}</p>
  197. <p id="projectCodeFlag">订单编码:{{ nowRecord.orderNumber }}</p>
  198. <p id="projectCodeFlag">客户名称:{{ nowRecord.customerName }}</p>
  199. <p id="projectCodeFlag">货品名称:{{ nowRecord.goodsName }}</p>
  200. <p id="projectCodeFlag">提货时间:{{ nowRecord.confStartTime+'~'+nowRecord.confEndTime }}</p>
  201. </div>
  202. </a-col>
  203. <a-col :span="11">
  204. <a-image width="250" height="100%" :src="qrCodeUrl.codeUrl"></a-image>
  205. </a-col>
  206. </a-row>
  207. </div>
  208. <template #footer>
  209. <a-button @click="closeQrCode">关闭</a-button>
  210. <a-button type="primary" @click="downloadFile">下载</a-button>
  211. </template>
  212. </a-modal>
  213. <xn-customer-selector
  214. ref="CustomerSelectorPlusRef"
  215. :add-show="false"
  216. :show="false"
  217. :role-global="true"
  218. @onBack="customerBack"
  219. />
  220. <a-modal
  221. v-model:visible="moreFlag"
  222. title="扫码次数配置"
  223. :footer="null"
  224. width="1100px"
  225. :body-style="{
  226. height: 'calc(100vh - 300px)',
  227. overflow: 'auto'
  228. }"
  229. @cancel="onCloseAccount"
  230. >
  231. <a-card :bordered="false">
  232. <!-- <a-button type="primary" @click="addAccount()" style="margin-bottom:10px;">
  233. <template #icon><plus-outlined /></template>
  234. 新增
  235. </a-button>-->
  236. <a-table ref="tableRef" :columns="columns1" :data-source="data1" bordered :row-key="(record) => record.id">
  237. <template #bodyCell="{ column, record }">
  238. <template v-if="column.dataIndex === 'action'">
  239. <a @click="editAccount(record)">编辑</a>
  240. <!-- <a-divider type="vertical" />
  241. <a-popconfirm title="确定要删除吗?" @confirm="removeUser(record)">
  242. <a-button type="link" danger size="small">删除</a-button>
  243. </a-popconfirm>-->
  244. </template>
  245. <template v-if="column.dataIndex === 'remain'">
  246. {{record.applyNumber-record.applyNumberAlready}}
  247. </template>
  248. </template>
  249. </a-table>
  250. </a-card>
  251. </a-modal>
  252. <a-modal
  253. v-model:visible="editAccountFlag"
  254. :title="formData.id ? '编辑扫码次数' : '添加扫码次数'"
  255. class="custom-modal"
  256. width="800px"
  257. @ok="handleOk"
  258. @cancel="onClose"
  259. >
  260. <a-form ref="formSubmitRef" :model="formData" :rules="formRules" :wrapper-col="wrapperCol" :label-col="labelCol">
  261. <a-form-item label="开始时间:" name="beginTime">
  262. <a-input v-model:value="formData.beginTime" placeholder="请输入提货开始时间" allow-clear disabled/>
  263. </a-form-item>
  264. <a-form-item label="结束时间:" name="endTime">
  265. <a-input v-model:value="formData.endTime" placeholder="请输入提货结束时间" allow-clear disabled/>
  266. </a-form-item>
  267. <a-form-item label="申请数量:" name="applyNumber">
  268. <a-input-number v-model:value="formData.applyNumber" style="width:90%" :precision="0" :min="1" :max="99999" placeholder="请输入申请数量" allow-clear /><span style="margin-left:10px;">次</span>
  269. </a-form-item>
  270. </a-form>
  271. </a-modal>
  272. </template>
  273. <script setup name="bizorder">
  274. import { cloneDeep } from 'lodash-es'
  275. import Form from './form.vue'
  276. import Detail from './detail.vue'
  277. import bizOrderApi from '@/api/biz/bizOrderApi'
  278. import {ExclamationCircleOutlined} from '@ant-design/icons-vue';
  279. import {Modal} from 'ant-design-vue';
  280. import {createVNode} from 'vue';
  281. import QRCode from 'qrcode'
  282. import html2canvas from 'html2canvas'
  283. import userApi from '@/api/sys/userApi'
  284. import downloadUtil from '@/utils/downloadUtil'
  285. import tool from '@/utils/tool'
  286. import Review from './review.vue'
  287. import Flow from './flow.vue'
  288. import bizOrderConfigApi from "@/api/biz/bizOrderConfigApi";
  289. import { required } from '@/utils/formRules'
  290. import End from './end.vue'
  291. const editAccountFlag = ref(false)
  292. const moreFlag = ref(false)
  293. const selectedRecord = ref({})
  294. const CustomerSelectorPlusRef = ref()
  295. const nowRecord = ref()
  296. const tableRef = ref()
  297. const formRef = ref()
  298. const configRef = ref()
  299. const flowRef = ref()
  300. const reviewRef = ref()
  301. const endRef = ref()
  302. const detailRef = ref()
  303. const XnSignNameRef = ref()
  304. const submitLoading = ref(false)
  305. const toolConfig = { refresh: true, height: true, columnSetting: true, striped: false }
  306. //查询数据
  307. const searchFormState = ref({})
  308. const searchFormRef = ref()
  309. const orderStatusList = tool.dictList('order_status')
  310. const orderSourceList = tool.dictList('order_source')
  311. // 查询区域显示更多控制
  312. const advanced = ref(false)
  313. const toggleAdvanced = () => {
  314. advanced.value = !advanced.value
  315. }
  316. // 表单数据
  317. const formData = ref({})
  318. const columns = [
  319. {
  320. title: '订单编号',
  321. dataIndex: 'orderNumber',
  322. align:'center',
  323. width: 130
  324. },
  325. {
  326. title: '订单名称',
  327. dataIndex: 'orderName',
  328. align:'center',
  329. width: 130
  330. },
  331. {
  332. title: '客户名称',
  333. dataIndex: 'customerName',
  334. align:'center',
  335. width: 130
  336. },
  337. {
  338. title: '货品名称',
  339. dataIndex: 'goodsName',
  340. align:'center',
  341. width: 130
  342. },
  343. /*{
  344. title: '订单类型',
  345. dataIndex: 'orderType',
  346. align:'center'
  347. },*/
  348. /*{
  349. title: '订单来源',
  350. dataIndex: 'orderSource',
  351. align:'center',
  352. width: 100
  353. },*/
  354. {
  355. title: '提货开始时间',
  356. dataIndex: 'confStartTime',
  357. align:'center',
  358. width: 130
  359. },
  360. {
  361. title: '提货结束时间',
  362. dataIndex: 'confEndTime',
  363. align:'center',
  364. width: 130
  365. },
  366. {
  367. title: '订单状态',
  368. dataIndex: 'orderStatus',
  369. align:'center',
  370. width: 80
  371. },
  372. {
  373. title: '订单重量',
  374. dataIndex: 'orderWeight',
  375. align:'center',
  376. width: 100
  377. },
  378. {
  379. title: '过磅重量',
  380. dataIndex: 'netWeight',
  381. align:'center',
  382. width: 100
  383. },
  384. ]
  385. // 操作栏通过权限判断是否显示
  386. columns.push({
  387. title: '操作',
  388. dataIndex: 'action',
  389. align: 'center',
  390. width: 150
  391. })
  392. const selectedRowKeys = ref([])
  393. // 列表选择配置
  394. const options = {
  395. // columns数字类型字段加入 needTotal: true 可以勾选自动算账
  396. alert: {
  397. show: true,
  398. clear: () => {
  399. selectedRowKeys.value = ref([])
  400. }
  401. },
  402. rowSelection: {
  403. onChange: (selectedRowKey, selectedRows) => {
  404. selectedRowKeys.value = selectedRowKey
  405. }
  406. }
  407. }
  408. const loadData = (parameter) => {
  409. const searchFormParam = cloneDeep(searchFormState.value)
  410. return bizOrderApi.bizOrderPage(Object.assign(parameter, searchFormParam)).then((data) => {
  411. return data
  412. })
  413. }
  414. // 重置
  415. const reset = () => {
  416. searchFormRef.value.resetFields()
  417. tableRef.value.refresh(true)
  418. }
  419. //确认
  420. const orderConfirm = (id) =>{
  421. Modal.confirm({
  422. title: '提示',
  423. icon: createVNode(ExclamationCircleOutlined),
  424. content: '是否确认该数据?',
  425. onOk() {
  426. submitLoading.value = true
  427. let params =
  428. {
  429. id: id
  430. }
  431. bizOrderApi
  432. .orderConfirm(params)
  433. .then(() => {
  434. tableRef.value.refresh(true)
  435. })
  436. .finally(() => {
  437. submitLoading.value = false
  438. })
  439. },
  440. onCancel() {}
  441. })
  442. }
  443. //提交
  444. const submit = (id) =>{
  445. Modal.confirm({
  446. title: '提示',
  447. icon: createVNode(ExclamationCircleOutlined),
  448. content: '是否提交该数据?',
  449. onOk() {
  450. submitLoading.value = true
  451. let params =
  452. {
  453. id: id
  454. }
  455. bizOrderApi
  456. .submit(params)
  457. .then(() => {
  458. tableRef.value.refresh(true)
  459. })
  460. .finally(() => {
  461. submitLoading.value = false
  462. })
  463. },
  464. onCancel() {}
  465. })
  466. }
  467. // 删除
  468. const deleteBizOrder = (record) => {
  469. let params = [
  470. {
  471. id: record.id
  472. }
  473. ]
  474. bizOrderApi.bizOrderDelete(params).then(() => {
  475. tableRef.value.refresh(true)
  476. })
  477. }
  478. // 删除
  479. const deleteConfig = (record) => {
  480. Modal.confirm({
  481. title: '确定删除该数据吗?',
  482. icon: createVNode(ExclamationCircleOutlined),
  483. content: '',
  484. onOk() {
  485. submitLoading.value = true
  486. let params = [
  487. {
  488. id: record.id
  489. }
  490. ]
  491. bizOrderApi
  492. .bizOrderDelete(params)
  493. .then(() => {
  494. tableRef.value.refresh(true)
  495. })
  496. .finally(() => {
  497. submitLoading.value = false
  498. })
  499. },
  500. onCancel() {}
  501. })
  502. }
  503. // 批量删除
  504. const deleteBatchBizOrder = (params) => {
  505. bizOrderApi.bizOrderDelete(params).then(() => {
  506. tableRef.value.clearRefreshSelected()
  507. })
  508. }
  509. //二维码
  510. const open = ref(false);
  511. const qrCodeUrl = ref({})
  512. const showModal = (record) => {
  513. nowRecord.value = record
  514. open.value = true;
  515. getQrCode(record)
  516. };
  517. const getQrCode = (record) => {
  518. //QRCode.toDataURL("id:"+record.id+"saleCode:"+record.saleCode, {
  519. let param = {
  520. id:record.id,
  521. orderName:record.orderName
  522. }
  523. QRCode.toDataURL(JSON.stringify(param), {
  524. errorCorrectionLevel: 'H',
  525. margin: 1,
  526. height: 206,
  527. width: 206,
  528. type: '10',
  529. scal: 177,
  530. color: {
  531. dark: '#000' // 二维码背景颜色
  532. },
  533. rendererOpts: {
  534. quality: 0.9
  535. }
  536. })
  537. .then((url) => {
  538. qrCodeUrl.value.codeUrl = url
  539. })
  540. .catch((err) => {
  541. console.error(err)
  542. })
  543. }
  544. const closeQrCode = () => {
  545. open.value = false;
  546. }
  547. // 下载二维码
  548. const downloadFile = () => {
  549. const qrcodeDiv = document.getElementById('qrcode');
  550. html2canvas(qrcodeDiv, {
  551. logging: false,
  552. allowTaint: true,
  553. scale: window.devicePixelRatio,
  554. scrollY: 0,
  555. scrollX: 0,
  556. useCORS: true,
  557. backgroundColor: '#ffffff'
  558. })
  559. .then(function (canvas) {
  560. const a = window.document.createElement('a')
  561. a.href = canvas.toDataURL('image/png')
  562. a.download = '二维码'
  563. a.click()
  564. this.$message.success('正在进行下载保存')
  565. })
  566. .catch((err) => {
  567. console.log(err)
  568. })
  569. }
  570. // 打开角色选择器
  571. const selectCustomer = (record) => {
  572. selectedRecord.value = record
  573. // 查询到已有角色,并转为ids的格式,给角色选择器
  574. CustomerSelectorPlusRef.value.showModel(record.customerId)
  575. }
  576. // 角色选择回调
  577. const customerBack = (value) => {
  578. let params = {
  579. id: selectedRecord.value.id,
  580. customerIdList: []
  581. }
  582. if (value.length > 0) {
  583. value.forEach((item) => {
  584. params.customerIdList.push(item)
  585. })
  586. }
  587. bizOrderApi.bindCustomerId(params).then(() => {
  588. tableRef.value.refresh()
  589. })
  590. }
  591. //导出
  592. const exportTotal = () => {
  593. /*const searchFormParam = cloneDeep(searchFormState.value)
  594. bizOrderApi.exportRecord(Object.assign(searchFormParam)).then((res)=>{
  595. downloadUtil.resultDownload(res)
  596. })*/
  597. Modal.confirm({
  598. title: '确定要导出记录吗?',
  599. icon: createVNode(ExclamationCircleOutlined),
  600. content: '',
  601. onOk() {
  602. submitLoading.value = true
  603. const searchFormParam = cloneDeep(searchFormState.value)
  604. bizOrderApi
  605. .exportRecord(Object.assign(searchFormParam))
  606. .then((res) => {
  607. downloadUtil.resultDownload(res)
  608. })
  609. .finally(() => {
  610. submitLoading.value = false
  611. })
  612. },
  613. onCancel() {}
  614. })
  615. }
  616. // 签名板组件回调
  617. const signSuccess = (value) => {
  618. const param = {
  619. id:value.id,
  620. orderSign: value.value
  621. }
  622. bizOrderApi.updateOrderSign(param).then(() => {
  623. tableRef.value.refresh(true)
  624. })
  625. }
  626. //结束订单
  627. const endOrder = (record) => {
  628. /*let param = {
  629. id:record.id
  630. }
  631. bizOrderApi.endOrder(param).then((res)=>{
  632. tableRef.value.refresh()
  633. })*/
  634. Modal.confirm({
  635. title: '确定结束该订单吗?',
  636. icon: createVNode(ExclamationCircleOutlined),
  637. content: '',
  638. onOk() {
  639. submitLoading.value = true
  640. let param = {
  641. id:record.id
  642. }
  643. bizOrderApi
  644. .endOrder(param)
  645. .then(() => {
  646. tableRef.value.refresh(true)
  647. })
  648. .finally(() => {
  649. submitLoading.value = false
  650. })
  651. },
  652. onCancel() {}
  653. })
  654. }
  655. const data1 = ref([])
  656. const orderId = ref()
  657. const beginTime = ref()
  658. const endTime = ref()
  659. const formSubmitRef = ref()
  660. //打开扫码次数配置页
  661. const showMore = (record) => {
  662. orderId.value = record.id
  663. beginTime.value = record.confStartTime
  664. endTime.value = record.confEndTime
  665. loadData1()
  666. moreFlag.value = true
  667. }
  668. const loadData1 = () => {
  669. let param={
  670. orderId:orderId.value
  671. }
  672. bizOrderConfigApi.bizOrderConfigPage(param).then((res)=>{
  673. data1.value = res.records
  674. })
  675. }
  676. const columns1 = [
  677. {
  678. title: '提货开始时间',
  679. dataIndex: 'beginTime',
  680. align: 'center',
  681. resizable: true,
  682. ellipsis: true,
  683. width: 130
  684. },
  685. {
  686. title: '提货结束时间',
  687. dataIndex: 'endTime',
  688. align: 'center',
  689. resizable: true,
  690. ellipsis: true,
  691. width: 130
  692. },
  693. {
  694. title: '申请数量',
  695. dataIndex: 'applyNumber',
  696. align: 'center',
  697. resizable: true,
  698. ellipsis: true,
  699. width: 100
  700. },
  701. {
  702. title: '已约数量',
  703. dataIndex: 'applyNumberAlready',
  704. align: 'center',
  705. resizable: true,
  706. ellipsis: true,
  707. width: 100
  708. },
  709. {
  710. title: '可约数量',
  711. dataIndex: 'remain',
  712. align: 'center',
  713. resizable: true,
  714. ellipsis: true,
  715. width: 100
  716. },
  717. ]
  718. columns1.push({
  719. title: '操作',
  720. dataIndex: 'action',
  721. align: 'center',
  722. fixed: 'right',
  723. width: 140,
  724. })
  725. const addAccount = () =>{
  726. formData.value = {}
  727. formData.value.orderId = orderId.value
  728. formData.value.beginTime = beginTime.value
  729. formData.value.endTime = endTime.value
  730. editAccountFlag.value = true
  731. }
  732. const formRules = {
  733. applyNumber: [required('请输入申请数量')],
  734. }
  735. //表单提交
  736. const handleOk = () => {
  737. console.log("handleOk")
  738. formSubmitRef.value.validate().then(() => {
  739. submitLoading.value = true
  740. const formDataParam = cloneDeep(formData.value)
  741. bizOrderConfigApi
  742. .bizOrderConfigSubmitForm(formDataParam, formDataParam.id)
  743. .then(() => {
  744. onClose()
  745. emit('successful')
  746. })
  747. .finally(() => {
  748. submitLoading.value = false
  749. })
  750. })
  751. }
  752. const onClose = () => {
  753. formSubmitRef.value.resetFields()
  754. formData.value = {}
  755. editAccountFlag.value = false
  756. loadData1()
  757. }
  758. const editAccount = (record) => {
  759. formData.value = record
  760. editAccountFlag.value = true
  761. }
  762. const removeUser = (record) => {
  763. let params = [
  764. {
  765. id: record.id
  766. }
  767. ]
  768. bizOrderConfigApi.bizOrderConfigDelete(params).then(() => {
  769. loadData1()
  770. })
  771. }
  772. const onCloseAccount = () => {
  773. moreFlag.value = false
  774. data1.value = []
  775. orderId.value = ''
  776. }
  777. </script>