salesList.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635
  1. <template>
  2. <div class="m-container">
  3. <h2>
  4. <div class="squrt"></div>
  5. 销售列表
  6. </h2>
  7. <div class="m-core">
  8. <!-- 搜索类型 -->
  9. <save-form
  10. :inline="true"
  11. class="searchForm"
  12. :model="searchForm"
  13. @submit="search"
  14. @reset="onReSet"
  15. >
  16. <el-form-item>
  17. <el-input
  18. v-model.trim="searchForm.search"
  19. placeholder="请输入流水号、订单号"
  20. clearable
  21. type="text"
  22. ></el-input>
  23. </el-form-item>
  24. <el-form-item>
  25. <el-input
  26. placeholder="学生姓名"
  27. clearable
  28. type="text"
  29. v-model.trim="searchForm.userName"
  30. ></el-input>
  31. </el-form-item>
  32. <el-form-item>
  33. <el-input
  34. v-model.trim="searchForm.goodsName"
  35. placeholder="请输入商品名称"
  36. clearable
  37. type="text"
  38. ></el-input>
  39. </el-form-item>
  40. <el-form-item>
  41. <select-all
  42. multiple
  43. collapse-tags
  44. v-model="searchForm.organIdList"
  45. clearable
  46. filterable
  47. placeholder="请选择所属分部"
  48. >
  49. <el-option
  50. v-for="(item, index) in selects.branchs"
  51. :key="index"
  52. :label="item.name"
  53. :value="item.id"
  54. ></el-option>
  55. </select-all>
  56. <!-- <el-select
  57. >
  58. </el-select> -->
  59. </el-form-item>
  60. <el-form-item>
  61. <el-select
  62. clearable
  63. filterable
  64. placeholder="请选择所属学校"
  65. v-model="searchForm.cooperationOrganId"
  66. >
  67. <el-option
  68. v-for="(item, index) in cooperations"
  69. :key="index"
  70. :label="item.name"
  71. :value="item.id"
  72. ></el-option>
  73. </el-select>
  74. </el-form-item>
  75. <!-- <el-form-item>
  76. <el-select clearable filterable placeholder="请选择销售类型" v-model="searchForm.saleType">
  77. <el-option label="1" value="1"></el-option>
  78. </el-select>
  79. </el-form-item> -->
  80. <!-- <el-form-item>
  81. <el-select clearable filterable placeholder="请选择交易方式" v-model="searchForm.paymentChannel">
  82. <el-option v-for="item in paymentChannelStatus" :key="item.value" :label="item.label" :value="item.value"></el-option>
  83. </el-select>
  84. </el-form-item> -->
  85. <el-form-item>
  86. <el-date-picker
  87. style="width: 410px"
  88. v-model.trim="searchForm.orderDate"
  89. type="daterange"
  90. value-format="yyyy-MM-dd"
  91. range-separator="至"
  92. start-placeholder="销售开始日期"
  93. end-placeholder="销售结束日期"
  94. :picker-options="{ firstDayOfWeek: 1 }"
  95. >
  96. </el-date-picker>
  97. </el-form-item>
  98. <el-form-item>
  99. <el-button native-type="submit" type="danger">搜索</el-button>
  100. <el-button native-type="reset" type="primary">重置</el-button>
  101. </el-form-item>
  102. </save-form>
  103. <div
  104. class="newBand"
  105. @click="onOrderExport"
  106. v-permission="'export/exportSellOrders'"
  107. >
  108. 报表导出
  109. </div>
  110. <!-- 列表 -->
  111. <div class="tableWrap">
  112. <el-table
  113. :data="tableList"
  114. style="width: 100%"
  115. :header-cell-style="{ background: '#EDEEF0', color: '#444' }"
  116. >
  117. <el-table-column
  118. align="center"
  119. width="150"
  120. prop="transNo"
  121. label="交易流水号"
  122. >
  123. <template slot-scope="scope">
  124. <div>
  125. <copy-text>{{ scope.row.transNo }}</copy-text>
  126. </div>
  127. </template>
  128. </el-table-column>
  129. <el-table-column
  130. align="center"
  131. prop="orderNo"
  132. label="订单号"
  133. width="180px"
  134. >
  135. <template slot-scope="scope">
  136. <div>
  137. <copy-text>{{ scope.row.orderNo }}</copy-text>
  138. </div>
  139. </template>
  140. </el-table-column>
  141. <el-table-column align="center" prop="sellTime" label="销售日期">
  142. <template slot-scope="scope">
  143. {{ scope.row.sellTime | dateForMinFormat }}
  144. </template>
  145. </el-table-column>
  146. <el-table-column align="center" prop="type" label="销售类型">
  147. <template slot-scope="scope">{{
  148. scope.row.type | saleType
  149. }}</template>
  150. </el-table-column>
  151. <el-table-column
  152. align="center"
  153. prop="goodsName"
  154. label="商品名称"
  155. width="200px"
  156. >
  157. <template slot-scope="scope">
  158. <div>
  159. <copy-text>{{ scope.row.goodsName }}</copy-text>
  160. </div>
  161. </template>
  162. </el-table-column>
  163. <el-table-column
  164. align="center"
  165. prop="num"
  166. label="数量"
  167. ></el-table-column>
  168. <el-table-column align="center" prop="expectAmount" label="订单金额">
  169. <template slot-scope="scope">
  170. <div>
  171. {{
  172. (scope.row.couponRemitAmount + scope.row.expectAmount)
  173. | moneyFormat
  174. }}
  175. </div>
  176. </template>
  177. </el-table-column>
  178. <el-table-column align="center" prop="expectAmount" label="优惠金额">
  179. <template slot-scope="scope">
  180. <div>
  181. {{ scope.row.couponRemitAmount | moneyFormat }}
  182. </div>
  183. </template>
  184. </el-table-column>
  185. <el-table-column
  186. align="center"
  187. width="100"
  188. prop="expectAmount"
  189. label="应付金额(元)"
  190. >
  191. <template slot-scope="scope">
  192. <div>
  193. {{ scope.row.expectAmount | moneyFormat }}
  194. </div>
  195. </template>
  196. </el-table-column>
  197. <el-table-column
  198. align="center"
  199. width="100"
  200. prop="balanceAmount"
  201. label="余额支付(元)"
  202. >
  203. <template slot-scope="scope">
  204. <div>
  205. {{ scope.row.balanceAmount | moneyFormat }}
  206. </div>
  207. </template>
  208. </el-table-column>
  209. <el-table-column
  210. align="center"
  211. width="100"
  212. prop="actualAmount"
  213. label="现金支付(元)"
  214. >
  215. <template slot-scope="scope">
  216. <div>
  217. {{ scope.row.actualAmount | moneyFormat }}
  218. </div>
  219. </template>
  220. </el-table-column>
  221. <el-table-column
  222. align="center"
  223. width="100"
  224. prop="sellCost"
  225. label="销售成本(元)"
  226. >
  227. <template slot-scope="scope">{{
  228. (scope.row.sellCost * scope.row.num) | moneyFormat
  229. }}</template>
  230. </el-table-column>
  231. <el-table-column align="center" prop="userName" label="学员姓名">
  232. <template slot-scope="scope">
  233. <div>
  234. <copy-text>{{ scope.row.userName }}</copy-text>
  235. </div>
  236. </template>
  237. </el-table-column>
  238. <!-- <el-table-column align='center' prop="remark" label="退费说明"></el-table-column> -->
  239. <el-table-column
  240. align="center"
  241. prop="paymentChannel"
  242. label="交易方式"
  243. >
  244. <template slot-scope="scope">{{
  245. scope.row.paymentChannel | paymentChannelStatus
  246. }}</template>
  247. </el-table-column>
  248. <el-table-column
  249. align="center"
  250. prop="merNo"
  251. label="收款账户"
  252. ></el-table-column>
  253. <el-table-column align="center" prop="accountType" label="账户类型">
  254. <template slot-scope="scope">{{
  255. scope.row.accountType | accountTypeFormat
  256. }}</template>
  257. </el-table-column>
  258. <el-table-column align="center" prop="stockType" label="扣减库存">
  259. <template slot-scope="scope">{{
  260. scope.row.stockType | stockTypeFormat
  261. }}</template>
  262. </el-table-column>
  263. <el-table-column align="center" prop="organName" label="所属分部">
  264. <template slot-scope="scope">
  265. <div>
  266. <copy-text>{{ scope.row.organName }}</copy-text>
  267. </div>
  268. </template>
  269. </el-table-column>
  270. <el-table-column align="center" prop="schoolName" label="所属学校">
  271. <template slot-scope="scope">
  272. <div>
  273. <copy-text>{{ scope.row.schoolName }}</copy-text>
  274. </div>
  275. </template>
  276. </el-table-column>
  277. <el-table-column
  278. align="center"
  279. prop="eduTeacher"
  280. label="乐团主管"
  281. ></el-table-column>
  282. <el-table-column align="center" prop="receiveStatus" label="确认收货">
  283. <template slot-scope="scope">{{
  284. scope.row.receiveStatus | receiveFormat
  285. }}</template>
  286. </el-table-column>
  287. <el-table-column align="center" prop="status" label="状态">
  288. <template slot-scope="scope">{{
  289. scope.row.status === 1 ? "已退货" : ""
  290. }}</template>
  291. </el-table-column>
  292. <el-table-column
  293. align="center"
  294. fixed="right"
  295. width="150px"
  296. label="操作"
  297. >
  298. <template slot-scope="scope">
  299. <el-button
  300. @click="onBackMoney(scope.row)"
  301. v-permission="'sellOrder/update'"
  302. type="text"
  303. >修改成本</el-button
  304. >
  305. <el-popconfirm
  306. title="退货后该销售金额将退还到学员账户余额"
  307. @confirm="() => refund({ id: scope.row.id })"
  308. v-if="scope.row.status === 0"
  309. v-permission="'sellOrder/refund'"
  310. >
  311. <el-button type="text" slot="reference">退费</el-button>
  312. </el-popconfirm>
  313. </template>
  314. </el-table-column>
  315. </el-table>
  316. <pagination
  317. sync
  318. :total.sync="pageInfo.total"
  319. :page.sync="pageInfo.page"
  320. :limit.sync="pageInfo.limit"
  321. :page-sizes="pageInfo.page_size"
  322. @pagination="getList"
  323. />
  324. </div>
  325. <el-dialog
  326. title="退费"
  327. width="400px"
  328. :visible.sync="refundVisible"
  329. @close="refundVisible = false"
  330. >
  331. <el-form :model="refundForm" :rules="refundRules" ref="refundform">
  332. <el-form-item label="退费金额" prop="money" label-width="100px">
  333. <el-input
  334. v-model="refundForm.money"
  335. type="number"
  336. placeholder="请输入退费金额"
  337. />
  338. </el-form-item>
  339. </el-form>
  340. <span slot="footer" class="dialog-footer">
  341. <el-button @click="refundVisible = false">取消</el-button>
  342. <el-button type="primary" @click="submitRefund">确认</el-button>
  343. </span>
  344. </el-dialog>
  345. <el-dialog
  346. title="修改成本"
  347. :visible.sync="backStatus"
  348. @close="onFormClose('ruleForm')"
  349. width="500px"
  350. >
  351. <el-form :model="form" :rules="rules" ref="ruleForm">
  352. <el-form-item label="交易流水号" :label-width="formLabelWidth">
  353. {{ detail.transNo }}
  354. </el-form-item>
  355. <el-form-item label="订单号" :label-width="formLabelWidth">
  356. {{ detail.orderNo }}
  357. </el-form-item>
  358. <el-form-item label="销售日期" :label-width="formLabelWidth">
  359. {{ detail.sellTime | dateForMinFormat }}
  360. </el-form-item>
  361. <el-form-item label="学员姓名" :label-width="formLabelWidth">
  362. {{ detail.userName }}
  363. </el-form-item>
  364. <el-form-item label="所属分部" :label-width="formLabelWidth">
  365. {{ detail.organName }}
  366. </el-form-item>
  367. <el-form-item label="所属学校" :label-width="formLabelWidth">
  368. {{ detail.schoolName }}
  369. </el-form-item>
  370. <el-form-item label="商品名称" :label-width="formLabelWidth">
  371. {{ detail.goodsName }}
  372. </el-form-item>
  373. <!-- <el-form-item label="商品型号" :label-width="formLabelWidth">
  374. {{ form.name }}
  375. </el-form-item> -->
  376. <el-form-item label="应付金额(元)" :label-width="formLabelWidth">
  377. {{ detail.expectAmount }}
  378. </el-form-item>
  379. <el-form-item
  380. label="单件成本(元)"
  381. prop="amount"
  382. :label-width="formLabelWidth"
  383. >
  384. <!-- <el-input autocomplete="off"></el-input> -->
  385. <el-autocomplete
  386. v-model="form.sellCost"
  387. class="inline-input"
  388. :fetch-suggestions="querySearch"
  389. placeholder="请输入成本"
  390. ></el-autocomplete>
  391. </el-form-item>
  392. <el-form-item label="乐团主管" :label-width="formLabelWidth">
  393. <remote-search
  394. :commit="'setEducations'"
  395. v-model="form.eduTeacherId"
  396. />
  397. </el-form-item>
  398. </el-form>
  399. <span slot="footer" class="dialog-footer">
  400. <el-button @click="backStatus = false">取消</el-button>
  401. <el-button
  402. type="primary"
  403. @click="onTeachingSubmit('ruleForm', 'DONE')"
  404. >确认</el-button
  405. >
  406. </span>
  407. </el-dialog>
  408. </div>
  409. </div>
  410. </template>
  411. <script>
  412. import pagination from "@/components/Pagination/index";
  413. import {
  414. getSellOrder,
  415. updateSellOrder,
  416. refundSellOrder,
  417. } from "@/api/orderManager";
  418. import {
  419. getEmployeeOrgan,
  420. getCooperation,
  421. findEducationUsers,
  422. } from "@/api/buildTeam";
  423. import { paymentChannelStatus } from "@/utils/searchArray";
  424. import { Export } from "@/utils/downLoadFile";
  425. import dayjs from "dayjs";
  426. import { getTimes } from "@/utils";
  427. import cleanDeep from "clean-deep";
  428. export default {
  429. components: { pagination },
  430. name: "backMoney",
  431. data() {
  432. return {
  433. paymentChannelStatus: paymentChannelStatus,
  434. refundVisible: false,
  435. detail: {},
  436. searchForm: {
  437. search: "",
  438. goodsName: "",
  439. cooperationOrganId: "",
  440. organIdList: [],
  441. userName: "",
  442. orderDate: [],
  443. },
  444. tableList: [],
  445. organList: [],
  446. educationList: [],
  447. pageInfo: {
  448. // 分页规则
  449. limit: 10, // 限制显示条数
  450. page: 1, // 当前页
  451. total: 0, // 总条数
  452. page_size: [10, 20, 40, 50], // 选择限制显示条数
  453. },
  454. backStatus: false,
  455. formLabelWidth: "150px",
  456. form: {
  457. id: null,
  458. sellCost: null,
  459. eduTeacherId: null,
  460. },
  461. rules: {
  462. sellCost: [{ required: true, message: "请输入金额", trigger: "input" }],
  463. },
  464. refundForm: {
  465. money: null,
  466. },
  467. refundRules: {
  468. money: [{ required: true, message: "请输入退费金额", trigger: "blur" }],
  469. },
  470. cooperations: [],
  471. restaurants: [],
  472. };
  473. },
  474. mounted() {
  475. this.$store.dispatch("setBranchs");
  476. getCooperation({ rows: 1000 }).then((res) => {
  477. if (res.code == 200) {
  478. this.cooperations = res.data.rows;
  479. }
  480. });
  481. if (this.searchForm.orderDate?.length < 1) {
  482. var now = new Date();
  483. var startDate = dayjs().format("YYYY-MM-DD");
  484. var endDate = dayjs().format("YYYY-MM-DD");
  485. this.searchForm.orderDate = [];
  486. this.searchForm.orderDate.push(startDate);
  487. this.searchForm.orderDate.push(endDate);
  488. }
  489. this.getList();
  490. },
  491. methods: {
  492. search() {
  493. this.pageInfo.page = 1;
  494. this.getList();
  495. },
  496. onTeachingSubmit(formName, status) {
  497. // 添加数据
  498. this.$refs[formName].validate((valid) => {
  499. if (valid) {
  500. updateSellOrder(this.form).then((res) => {
  501. if (res.code == 200) {
  502. this.$message.success("操作成功");
  503. this.backStatus = false;
  504. this.getList();
  505. } else {
  506. this.$message.error(res.msg);
  507. }
  508. });
  509. } else {
  510. return false;
  511. }
  512. });
  513. },
  514. getList() {
  515. let { orderDate, ...rest } = this.searchForm;
  516. let params = {
  517. ...rest,
  518. page: this.pageInfo.page,
  519. rows: this.pageInfo.limit,
  520. ...getTimes(orderDate, ["startTime", "endTime"]),
  521. };
  522. getSellOrder({
  523. ...params,
  524. organIdList: [...this.searchForm.organIdList].join(),
  525. }).then((res) => {
  526. let result = res.data;
  527. if (res.code == 200) {
  528. this.tableList = result.rows;
  529. this.pageInfo.total = result.total;
  530. }
  531. });
  532. },
  533. onReSet() {
  534. this.searchForm = {
  535. startTime: null,
  536. endTime: null,
  537. organIdList: [],
  538. search: "",
  539. goodsName: [],
  540. cooperationOrganId: "",
  541. orderDate: [dayjs().format("YYYY-MM-DD"), dayjs().format("YYYY-MM-DD")],
  542. };
  543. this.getList();
  544. },
  545. querySearch(queryString, cb) {
  546. let restaurants = [];
  547. try {
  548. const json = JSON.parse(this.detail.sellCost2);
  549. restaurants = [
  550. { value: String(json.sellCost || "") },
  551. { value: String(json.SellCost2 || "") },
  552. ].filter((item) => !!item);
  553. } catch (error) {}
  554. // this.createFilter(queryString)
  555. // let results = queryString ? restaurants.filter((restaurant) => {
  556. // return restaurant && restaurant.value && String(restaurant.value).indexOf(queryString) === 0
  557. // }) : restaurants;
  558. // 调用 callback 返回建议列表的数据
  559. cb(restaurants);
  560. },
  561. onFormClose(formName) {
  562. // 关闭弹窗重置验证
  563. this.$refs[formName].clearValidate();
  564. },
  565. refund(data) {
  566. refundSellOrder(data)
  567. .then((res) => {
  568. this.getList();
  569. this.$message.success("退费成功");
  570. })
  571. .catch((res) => {
  572. if (res.code === 100) {
  573. this.$confirm(res.msg, "提示", {
  574. confirmButtonText: "确定",
  575. cancelButtonText: "取消",
  576. type: "warning",
  577. }).then(() => {
  578. this.refund({
  579. ...data,
  580. reTry: true,
  581. });
  582. });
  583. } else {
  584. this.$message.error(res.msg);
  585. }
  586. });
  587. },
  588. openRefund(row) {
  589. this.refundVisible = true;
  590. this.detail = row;
  591. },
  592. submitRefund() {},
  593. onBackMoney(row) {
  594. // 退费
  595. this.backStatus = true;
  596. this.detail = row;
  597. this.form = {
  598. id: row.id,
  599. sellCost: String(row.sellCost),
  600. eduTeacherId: row.eduTeacherId ? row.eduTeacherId : null,
  601. };
  602. // applyRefundAudit()
  603. },
  604. onOrderExport() {
  605. let { orderDate, ...rest } = this.searchForm;
  606. let params = {
  607. ...rest,
  608. page: this.pageInfo.page,
  609. rows: this.pageInfo.limit,
  610. ...getTimes(orderDate, ["startTime", "endTime"]),
  611. };
  612. Export(
  613. this,
  614. {
  615. url: "/api-web/export/exportSellOrders",
  616. fileName: `销售列表导出.xls`,
  617. params: cleanDeep({
  618. ...params,
  619. organIdList: [...this.searchForm.organIdList].join(),
  620. }),
  621. },
  622. "是否确认导出报表?"
  623. );
  624. },
  625. },
  626. };
  627. </script>
  628. <style lang="scss">
  629. </style>