index.vue 24 KB

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