index.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515
  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="carNumber">
  7. <a-input v-model:value="searchFormState.carNumber" placeholder="请输入车次编码" />
  8. </a-form-item>
  9. </a-col>
  10. <a-col :span="6">
  11. <a-form-item label="车牌号码" name="licensePlate">
  12. <a-input v-model:value="searchFormState.licensePlate" placeholder="请输入车牌号码" />
  13. </a-form-item>
  14. </a-col>
  15. <a-col :span="6">
  16. <a-form-item label="过毛时间" name="grossTime">
  17. <a-range-picker
  18. v-model:value="searchFormState.grossTime"
  19. value-format="YYYY-MM-DD"
  20. />
  21. </a-form-item>
  22. </a-col>
  23. <template v-if="advanced">
  24. <a-col :span="6">
  25. <a-form-item label="过皮时间" name="tareTime">
  26. <a-range-picker
  27. v-model:value="searchFormState.tareTime"
  28. value-format="YYYY-MM-DD"
  29. />
  30. </a-form-item>
  31. </a-col>
  32. <a-col :span="6" v-show="advanced">
  33. <a-form-item label="司机姓名" name="driverName">
  34. <a-input v-model:value="searchFormState.driverName" placeholder="请输入司机姓名" />
  35. </a-form-item>
  36. </a-col>
  37. <a-col :span="6" v-show="advanced">
  38. <a-form-item label="司机电话" name="driverMobile">
  39. <a-input v-model:value="searchFormState.driverMobile" placeholder="请输入司机电话" />
  40. </a-form-item>
  41. </a-col>
  42. <a-col :span="6" v-show="advanced">
  43. <a-form-item label="货品名称" name="goodsName">
  44. <a-input v-model:value="searchFormState.goodsName" placeholder="请输入货品名称" />
  45. </a-form-item>
  46. </a-col>
  47. <a-col :span="6" v-show="advanced">
  48. <a-form-item label="规格型号" name="goodsModel">
  49. <a-input v-model:value="searchFormState.goodsModel" placeholder="请输入规格型号" />
  50. </a-form-item>
  51. </a-col>
  52. <!-- <a-col :span="6" v-show="advanced">
  53. <a-form-item label="收货单位" name="receiptCompany">
  54. <a-input v-model:value="searchFormState.receiptCompany" placeholder="请输入收货单位" />
  55. </a-form-item>
  56. </a-col>
  57. <a-col :span="6" v-show="advanced">
  58. <a-form-item label="发货单位" name="shippingCompany">
  59. <a-input v-model:value="searchFormState.shippingCompany" placeholder="请输入发货单位" />
  60. </a-form-item>
  61. </a-col>
  62. <a-col :span="6" v-show="advanced">
  63. <a-form-item label="运输单位" name="transportCompany">
  64. <a-input v-model:value="searchFormState.transportCompany" placeholder="请输入运输单位" />
  65. </a-form-item>
  66. </a-col>-->
  67. <a-col :span="6" v-show="advanced">
  68. <a-form-item label="订单编号" name="orderNumber">
  69. <a-input v-model:value="searchFormState.orderNumber" placeholder="请输入订单编号" />
  70. </a-form-item>
  71. </a-col>
  72. <!-- <a-col :span="6" v-show="advanced">
  73. <a-form-item label="订单名称" name="orderName">
  74. <a-input v-model:value="searchFormState.orderName" placeholder="请输入订单名称" />
  75. </a-form-item>
  76. </a-col>-->
  77. <a-col :span="6" v-show="advanced">
  78. <a-form-item label="客户名称" name="customerName">
  79. <a-input v-model:value="searchFormState.customerName" placeholder="请输入客户名称" />
  80. </a-form-item>
  81. </a-col>
  82. <a-col :span="6" v-show="advanced">
  83. <a-form-item label="供应商名称" name="supplierName">
  84. <a-input v-model:value="searchFormState.supplierName" placeholder="请输入供应商名称" />
  85. </a-form-item>
  86. </a-col>
  87. </template>
  88. <a-col :span="6">
  89. <a-button type="primary" @click="tableRef.refresh()">查询</a-button>
  90. <a-button style="margin: 0 8px" @click="reset">重置</a-button>
  91. <a @click="toggleAdvanced" style="margin-left: 8px">
  92. {{ advanced ? '收起' : '展开' }}
  93. <component :is="advanced ? 'up-outlined' : 'down-outlined'" />
  94. </a>
  95. </a-col>
  96. </a-row>
  97. </a-form>
  98. </a-card>
  99. <a-card :bordered="false">
  100. <s-table
  101. ref="tableRef"
  102. :columns="columns"
  103. :data="loadData"
  104. bordered
  105. :row-key="(record) => record.id"
  106. >
  107. <template #operator class="table-operator">
  108. <a-space>
  109. <a-button type="dashed" class="snowy-buttom-left" @click="exportData()" v-if="hasPerm('bizRecordBatchExport')"
  110. ><export-outlined />记录导出</a-button
  111. >
  112. </a-space>
  113. </template>
  114. <template #bodyCell="{ column, record }">
  115. <template v-if="column.dataIndex === 'licensePlate'">
  116. <span v-if="record.plateColor === '蓝色'" class="blue-background">{{ record.licensePlate }}</span>
  117. <span v-else-if="record.plateColor === '黄色'" class="yellow-background">{{ record.licensePlate }}</span>
  118. <span v-else-if="record.plateColor === '绿色'" class="green-background">{{ record.licensePlate }}</span>
  119. <span v-else-if="record.plateColor === '白色'" class="white-background">{{ record.licensePlate }}</span>
  120. <span v-else-if="record.plateColor === '黑色'" class="black-background">{{ record.licensePlate }}</span>
  121. <span v-else class="blue-background">{{ record.licensePlate }}</span>
  122. </template>
  123. <template v-if="column.dataIndex === 'enterTime'">
  124. <div class="time-list">
  125. <p>
  126. <span class="blueTag">过毛</span>
  127. <span style="font-weight: normal">{{ record.grossTime }}</span>
  128. </p>
  129. <p style="margin-bottom: 0">
  130. <span class="orangeTag">过皮</span>
  131. <span style="font-weight: normal">{{ record.tareTime }}</span>
  132. </p>
  133. </div>
  134. </template>
  135. <template v-if="column.dataIndex === 'weight'">
  136. <div class="time-list">
  137. <p>
  138. <span class="blueTag">毛重</span>
  139. <span class="showNum">{{ record.grossWeight }} </span>
  140. </p>
  141. <p>
  142. <span class="orangeTag">皮重</span>
  143. <span class="showNum">{{ record.tareWeight }}</span>
  144. </p>
  145. <p>
  146. <span class="greenTag">净重</span>
  147. <span class="showNum">{{ record.netWeight }}</span>
  148. </p>
  149. </div>
  150. </template>
  151. <template v-if="column.dataIndex === 'company'">
  152. <div class="company-list">
  153. <p>收货:{{ record.receiptCompany }}</p>
  154. <p>发货:{{ record.shippingCompany }}</p>
  155. <p style="margin-bottom: 0">运输:{{ record.transportCompany }}</p>
  156. </div>
  157. </template>
  158. <template v-if="column.dataIndex === 'goods'">
  159. <div class="time-list">
  160. <p>名称:{{ record.goodsName }}</p>
  161. <p style="margin-bottom: 0">编码:{{ record.goodsModel }}</p>
  162. </div>
  163. </template>
  164. <template v-if="column.dataIndex === 'driver'">
  165. <div class="time-list">
  166. <p>姓名:{{ record.driverName }}</p>
  167. <p style="margin-bottom: 0">电话:{{ record.driverMobile }}</p>
  168. </div>
  169. </template>
  170. <template v-if="column.dataIndex === 'orderInfo'">
  171. <div class="time-list">
  172. <p>名称:{{ record.orderName }}</p>
  173. <p style="margin-bottom: 0">编号:{{ record.orderNumber }}</p>
  174. </div>
  175. </template>
  176. <template v-if="column.dataIndex === 'action'">
  177. <a-space>
  178. <a @click="detailRef.onOpen(record)">详情</a>
  179. <a-divider type="vertical" v-if="hasPerm('bizRecordDriverConfirm')" />
  180. <!-- <a @click="XnSignNameRef.show(record.id)" v-if="hasPerm('bizRecordDriverConfirm') && record.status == '8'">司机确认</a>-->
  181. <XnSignName ref="XnSignNameRef" :image="searchFormState.driverSign" @successful="signSuccess" />
  182. <a-divider type="vertical" v-if="hasPerm(['bizGoodsEdit', 'bizGoodsDelete'], 'and')" />
  183. <a-popconfirm title="确定要删除吗?" @confirm="cancellationBizRecord(record)">
  184. <a-button type="link" danger size="small" v-if="hasPerm('bizRecordCancel')">删除</a-button>
  185. </a-popconfirm>
  186. </a-space>
  187. </template>
  188. </template>
  189. </s-table>
  190. </a-card>
  191. <Form ref="formRef" @successful="tableRef.refresh()" />
  192. <Detail ref="detailRef" />
  193. </template>
  194. <script setup name="record">
  195. import { message, Modal } from 'ant-design-vue'
  196. import { cloneDeep } from 'lodash-es'
  197. import Form from './form.vue'
  198. import Detail from './detail.vue'
  199. import bizRecordApi from '@/api/biz/bizRecordApi'
  200. import downloadUtil from '@/utils/downloadUtil'
  201. const searchFormState = ref({})
  202. const searchFormRef = ref()
  203. const tableRef = ref()
  204. const formRef = ref()
  205. const detailRef = ref()
  206. const XnSignNameRef = ref()
  207. const toolConfig = { refresh: true, height: true, columnSetting: true, striped: false }
  208. // 查询区域显示更多控制
  209. const advanced = ref(false)
  210. const toggleAdvanced = () => {
  211. advanced.value = !advanced.value
  212. }
  213. const columns = [
  214. {
  215. title: '车次编码',
  216. dataIndex: 'carNumber',
  217. width: 120,
  218. align: 'center'
  219. },
  220. {
  221. title: '车牌号码',
  222. dataIndex: 'licensePlate',
  223. width: '130px',
  224. align: 'center'
  225. },
  226. {
  227. title: '过车时间',
  228. dataIndex: 'enterTime',
  229. width: '130px'
  230. },
  231. {
  232. title: '重量(吨)',
  233. dataIndex: 'weight',
  234. align: 'center'
  235. },
  236. /*{
  237. title: '订单信息',
  238. dataIndex: 'orderInfo'
  239. },*/
  240. {
  241. title: '订单编号',
  242. dataIndex: 'orderNumber',
  243. align:'center'
  244. },
  245. {
  246. title: '客户名称',
  247. dataIndex: 'customerName',
  248. align:'center'
  249. },
  250. {
  251. title: '货品',
  252. dataIndex: 'goods'
  253. },
  254. {
  255. title: '司机信息',
  256. dataIndex: 'driver',
  257. width: '150px'
  258. },
  259. {
  260. title: '供应商',
  261. dataIndex: 'supplierName',
  262. width: '150px'
  263. }
  264. ]
  265. // 操作栏通过权限判断是否显示
  266. columns.push({
  267. title: '操作',
  268. dataIndex: 'action',
  269. align: 'center',
  270. width: 150
  271. })
  272. const loadData = (parameter) => {
  273. const searchFormParam = cloneDeep(searchFormState.value)
  274. // grossTime范围查询条件重载
  275. if (searchFormParam.grossTime) {
  276. searchFormParam.startGrossTime = searchFormParam.grossTime[0]
  277. searchFormParam.endGrossTime = searchFormParam.grossTime[1]
  278. delete searchFormParam.grossTime
  279. }
  280. // tareTime范围查询条件重载
  281. if (searchFormParam.tareTime) {
  282. searchFormParam.startTareTime = searchFormParam.tareTime[0]
  283. searchFormParam.endTareTime = searchFormParam.tareTime[1]
  284. delete searchFormParam.tareTime
  285. }
  286. return bizRecordApi.bizRecordPage(Object.assign(parameter, searchFormParam)).then((data) => {
  287. return data
  288. })
  289. }
  290. const dateRangeOnChange = (date, dateString) => {
  291. searchFormState.startGrossTime = dateString[0]
  292. searchFormState.endGrossTime = dateString[1]
  293. }
  294. const dateRangeOnChangeTare = (date, dateString) => {
  295. searchFormState.startTareTime = dateString[0]
  296. searchFormState.endTareTime = dateString[1]
  297. }
  298. // 重置
  299. const reset = () => {
  300. searchFormRef.value.resetFields()
  301. searchFormState.startGrossTime = null
  302. searchFormState.endGrossTime = null
  303. searchFormState.startTareTime = null
  304. searchFormState.endTareTime = null
  305. tableRef.value.refresh(true)
  306. }
  307. const exportData = () => {
  308. /*const paramData = {
  309. licensePlate: searchFormState.value.licensePlate,
  310. carNumber: searchFormState.value.carNumber,
  311. goodsName: searchFormState.value.goodsName,
  312. goodsModel: searchFormState.value.goodsModel,
  313. receiptCompany: searchFormState.value.receiptCompany,
  314. shippingCompany: searchFormState.value.shippingCompany,
  315. transportCompany: searchFormState.value.transportCompany,
  316. driverName: searchFormState.value.driverName,
  317. driverMobile: searchFormState.value.driverMobile,
  318. startGrossTime: searchFormState.value.startGrossTime,
  319. endGrossTime: searchFormState.value.endGrossTime,
  320. startTareTime: searchFormState.value.startTareTime,
  321. endTareTime: searchFormState.value.endTareTime
  322. }*/
  323. const searchFormParam = cloneDeep(searchFormState.value)
  324. // grossTime范围查询条件重载
  325. if (searchFormParam.grossTime) {
  326. searchFormParam.startGrossTime = searchFormParam.grossTime[0]
  327. searchFormParam.endGrossTime = searchFormParam.grossTime[1]
  328. delete searchFormParam.grossTime
  329. }
  330. // tareTime范围查询条件重载
  331. if (searchFormParam.tareTime) {
  332. searchFormParam.startTareTime = searchFormParam.tareTime[0]
  333. searchFormParam.endTareTime = searchFormParam.tareTime[1]
  334. delete searchFormParam.tareTime
  335. }
  336. Modal.confirm({
  337. title: '提示',
  338. content: '确定要导出过磅记录?',
  339. maskClosable: true,
  340. onOk: () => {
  341. bizRecordApi.bizRecordExport(searchFormParam).then((res) => {
  342. downloadUtil.resultDownload(res)
  343. tableRef.value.clearSelected()
  344. })
  345. }
  346. })
  347. }
  348. // 签名板组件回调
  349. const signSuccess = (value) => {
  350. const param = {
  351. id:value.id,
  352. driverSign: value.value
  353. }
  354. bizRecordApi.updateDriverSign(param).then(() => {
  355. tableRef.value.refresh(true)
  356. })
  357. }
  358. </script>
  359. <style lang="less" scoped>
  360. /** 表头居中 */
  361. :deep .ant-table-thead > tr > th {
  362. text-align: center;
  363. }
  364. .time-list {
  365. -webkit-text-size-adjust: none;
  366. font-size: 13px;
  367. display: flex;
  368. flex-direction: column;
  369. p {
  370. white-space: nowrap;
  371. span {
  372. display: inline-block;
  373. font-weight: 600;
  374. height: 16px;
  375. line-height: 16px;
  376. border-radius: 5px;
  377. text-align: center;
  378. margin-right: 2px;
  379. padding: 0 5px;
  380. }
  381. .blueTag {
  382. color: #1890ff;
  383. background: rgba(24, 144, 255, 0.1);
  384. }
  385. .orangeTag {
  386. color: #ff7c18;
  387. background: rgba(24, 144, 255, 0.1);
  388. }
  389. .greenTag {
  390. color: rgb(82, 196, 26);
  391. background: rgba(82, 196, 26, 0.1);
  392. }
  393. .purpleTag {
  394. color: rgb(77, 26, 196);
  395. background: rgba(82, 196, 26, 0.1);
  396. }
  397. .showNum {
  398. display: inline-block;
  399. height: 16px;
  400. line-height: 16px;
  401. width: 45px;
  402. border-radius: 5px;
  403. text-align: center;
  404. margin-right: 2px;
  405. text-align: right;
  406. }
  407. }
  408. }
  409. .order-list,
  410. .company-list {
  411. -webkit-text-size-adjust: none;
  412. font-size: 13px;
  413. display: flex;
  414. flex-direction: column;
  415. p {
  416. white-space: nowrap;
  417. margin-bottom: 5px;
  418. .weightSpan,
  419. .company {
  420. display: inline-block;
  421. width: 17px;
  422. height: 17px;
  423. line-height: 16px;
  424. border-radius: 50%;
  425. color: #fff;
  426. text-align: center;
  427. }
  428. .company {
  429. margin-right: 5px;
  430. }
  431. .weight,
  432. .receiptCompany {
  433. background-color: #1890ff;
  434. }
  435. .tare {
  436. background-color: #2f54eb;
  437. }
  438. .netWeight,
  439. .shippingCompany {
  440. background-color: #52c41a;
  441. }
  442. .transportCompany {
  443. background-color: #c61263;
  444. }
  445. .showNum {
  446. display: inline-block;
  447. height: 16px;
  448. line-height: 16px;
  449. width: 45px;
  450. border-radius: 5px;
  451. text-align: center;
  452. margin-right: 2px;
  453. text-align: right;
  454. }
  455. em {
  456. font-style: normal;
  457. }
  458. }
  459. }
  460. .blue-background {
  461. background-color: #0d84ff;
  462. border-radius: 5px; /* 你可以根据需要调整圆角的大小 */
  463. padding: 5px; /* 可选:添加一些内边距 */
  464. color: white; /* 可选:设置文字颜色 */
  465. font-size: large;
  466. }
  467. .yellow-background {
  468. background-color: yellow;
  469. border-radius: 5px;
  470. padding: 5px;
  471. color: black;
  472. font-size: large;
  473. }
  474. .green-background {
  475. background: linear-gradient(to bottom, white, #39b54a);
  476. border-radius: 5px;
  477. padding: 5px;
  478. color: black; /* 文字颜色改为黑色以便在渐变背景上更清晰 */
  479. font-size: large;
  480. border: 1px solid #ccc; /* 增加边框 */
  481. box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* 增加阴影 */
  482. }
  483. .white-background {
  484. background-color: white;
  485. border-radius: 5px;
  486. padding: 5px;
  487. color: black;
  488. font-size: large;
  489. border: 1px solid #ccc; /* 增加边框 */
  490. box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); /* 增加阴影 */
  491. }
  492. .black-background {
  493. background-color: black;
  494. border-radius: 5px;
  495. padding: 5px;
  496. color: white;
  497. font-size: large;
  498. }
  499. </style>