musicGroup.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408
  1. <template>
  2. <div>
  3. <!-- <h2>
  4. <div class="squrt"></div>
  5. 费用审核列表
  6. </h2> -->
  7. <div>
  8. <!-- 搜索标题 -->
  9. <save-form
  10. :inline="true"
  11. class="searchForm"
  12. ref="searchForm"
  13. :model.sync="searchForm"
  14. >
  15. <el-form-item>
  16. <el-input
  17. v-model.trim="searchForm.search"
  18. clearable
  19. @keyup.enter.native="
  20. (e) => {
  21. e.target.blur();
  22. $refs.searchForm.save();
  23. search();
  24. }
  25. "
  26. placeholder="乐团名称/编号"
  27. ></el-input>
  28. </el-form-item>
  29. <el-form-item>
  30. <el-select
  31. class="multiple"
  32. v-model.trim="searchForm.organId"
  33. filterable
  34. clearable
  35. placeholder="请选择分部"
  36. >
  37. <el-option
  38. v-for="(item, index) in selects.branchs"
  39. :key="index"
  40. :label="item.name"
  41. :value="item.id"
  42. ></el-option>
  43. </el-select>
  44. </el-form-item>
  45. <el-form-item>
  46. <el-select
  47. class="multiple"
  48. v-model.trim="searchForm.paymentType"
  49. filterable
  50. clearable
  51. placeholder="申请类型"
  52. >
  53. <el-option
  54. v-for="(item, index) in paymentTypeList"
  55. :key="index"
  56. :label="item.label"
  57. :value="item.value"
  58. ></el-option>
  59. </el-select>
  60. </el-form-item>
  61. <el-form-item>
  62. <el-select
  63. class="multiple"
  64. v-model.trim="searchForm.status"
  65. filterable
  66. clearable
  67. placeholder="审核状态"
  68. >
  69. <el-option
  70. v-for="(item, index) in statusList"
  71. :key="index"
  72. :label="item.label"
  73. :value="item.value"
  74. ></el-option>
  75. </el-select>
  76. </el-form-item>
  77. <el-form-item>
  78. <el-button @click="search" type="primary">搜索</el-button>
  79. <el-button @click="reset" type="danger">重置</el-button>
  80. <auth
  81. auths="musicGroupPaymentCalender/batchAuditing"
  82. style="margin-left: 10px"
  83. >
  84. <el-button
  85. @click="typesStatus = true"
  86. :disabled="!selList.length > 0"
  87. type="primary"
  88. >批量审核</el-button
  89. >
  90. </auth>
  91. </el-form-item>
  92. </save-form>
  93. <div class="tableWrap">
  94. <el-table
  95. :data="tableList"
  96. :header-cell-style="{ background: '#EDEEF0', color: '#444' }"
  97. @selection-change="handleSelectionChange"
  98. >
  99. <el-table-column
  100. fixed="left"
  101. type="selection"
  102. width="55"
  103. :selectable="selectable"
  104. ></el-table-column>
  105. <el-table-column align="center" prop="organName" label="分部名称">
  106. <template slot-scope="scope">
  107. <copy-text>{{ scope.row.organName }}</copy-text>
  108. </template>
  109. </el-table-column>
  110. <el-table-column
  111. align="center"
  112. width="200px"
  113. prop="musicGroupName"
  114. label="乐团名称"
  115. >
  116. <template slot-scope="scope">
  117. <div>
  118. <Tooltip :content="scope.row.musicGroupName" />
  119. </div>
  120. </template>
  121. </el-table-column>
  122. <el-table-column
  123. align="center"
  124. width="100px"
  125. prop="musicGroupId"
  126. label="乐团编号"
  127. >
  128. <template slot-scope="scope">
  129. <copy-text>{{ scope.row.musicGroupId }}</copy-text>
  130. </template>
  131. </el-table-column>
  132. <el-table-column align="center" prop="paymentType" label="收费模式">
  133. <template slot-scope="scope">
  134. <div>
  135. {{ scope.row.paymentType | auditPaymentType }}
  136. </div>
  137. </template>
  138. </el-table-column>
  139. <el-table-column align="center" prop="paymentType" label="申请类型">
  140. <template slot-scope="scope">
  141. <div>
  142. {{ scope.row.paymentType | auditPaymentType }}
  143. </div>
  144. </template>
  145. </el-table-column>
  146. <el-table-column align="center" prop="payUserType" label="订单类型">
  147. <template slot-scope="scope">
  148. <div>
  149. {{ scope.row.payUserType | payOrderType }}
  150. </div>
  151. </template>
  152. </el-table-column>
  153. <!-- <el-table-column
  154. align="center"
  155. prop="addCourseTotalTime"
  156. label="加课总时长(分钟)"
  157. ></el-table-column> -->
  158. <el-table-column
  159. align="center"
  160. prop="originalTotalAmount"
  161. label="总原价(元)"
  162. >
  163. </el-table-column>
  164. <el-table-column
  165. align="center"
  166. prop="currentTotalAmount"
  167. label="申请价格(元)"
  168. >
  169. </el-table-column>
  170. <el-table-column
  171. align="center"
  172. prop="memo"
  173. width="100px"
  174. label="备注"
  175. >
  176. <template slot-scope="scope">
  177. <overflow-text width="80px" :text="scope.row.memo" />
  178. </template>
  179. </el-table-column>
  180. <el-table-column
  181. align="center"
  182. prop="auditMemo"
  183. width="100px"
  184. label="审核意见"
  185. >
  186. <template slot-scope="scope">
  187. <overflow-text width="80px" :text="scope.row.auditMemo" />
  188. </template>
  189. </el-table-column>
  190. <el-table-column
  191. align="center"
  192. prop="operatorName"
  193. label="申请人"
  194. ></el-table-column>
  195. <el-table-column
  196. align="center"
  197. prop="status"
  198. label="状态"
  199. width="100px"
  200. >
  201. <template slot-scope="scope">
  202. <div>
  203. {{ scope.row.status | auditType }}
  204. </div>
  205. </template>
  206. </el-table-column>
  207. <el-table-column
  208. align="center"
  209. prop="createTime"
  210. label="申请时间"
  211. width="140px"
  212. >
  213. <template slot-scope="scope">
  214. <div>
  215. {{ scope.row.createTime | dateForMinFormat }}
  216. </div>
  217. </template>
  218. </el-table-column>
  219. <!-- -->
  220. <el-table-column align="center" label="操作" fixed="right">
  221. <template slot-scope="scope">
  222. <!-- 'musicGroupPaymentCalender/auditListDetail/update'
  223. 'musicGroupPaymentCalender/auditListDetail/look' -->
  224. <el-button
  225. @click="lookDetail(scope.row)"
  226. type="text"
  227. v-if="
  228. scope.row.status == 'AUDITING' &&
  229. $helpers.permission(
  230. 'musicGroupPaymentCalender/auditListDetail/update'
  231. )
  232. "
  233. >
  234. 审核
  235. </el-button>
  236. <el-button
  237. @click="lookDetail(scope.row)"
  238. type="text"
  239. v-if="
  240. scope.row.status != 'AUDITING' &&
  241. $helpers.permission(
  242. 'musicGroupPaymentCalender/getDetail/look'
  243. )
  244. "
  245. >
  246. 查看
  247. </el-button>
  248. </template>
  249. </el-table-column>
  250. </el-table>
  251. <pagination
  252. :total.sync="pageInfo.total"
  253. sync
  254. :page.sync="pageInfo.page"
  255. :limit.sync="pageInfo.limit"
  256. :page-sizes="pageInfo.page_size"
  257. @pagination="getList"
  258. />
  259. </div>
  260. </div>
  261. <el-dialog
  262. title="审核详情"
  263. width="900px"
  264. :visible.sync="typeStatus"
  265. v-if="typeStatus"
  266. >
  267. <review :detail="detail" @close="close" />
  268. </el-dialog>
  269. <el-dialog
  270. title="批量审核"
  271. width="700px"
  272. :visible.sync="typesStatus"
  273. v-if="typesStatus"
  274. >
  275. <audit
  276. :selList="selList"
  277. @close="typesStatus = false"
  278. @submited="submited"
  279. />
  280. </el-dialog>
  281. </div>
  282. </template>
  283. <script>
  284. import pagination from "@/components/Pagination/index";
  285. import review from "@/views/resetTeaming/modals/review.vue";
  286. import audit from "./audit.vue";
  287. // import store from '@/store'
  288. import { getAuditList, getAuditListDetail } from "@/api/auditManager";
  289. import { getEmployeeOrgan } from "@/api/buildTeam";
  290. import Tooltip from "@/components/Tooltip/index";
  291. import { auditTypeList, auditPaymentTypeList } from "@/utils/searchArray";
  292. const initSearch = {
  293. search: null,
  294. paymentType: null,
  295. status: "AUDITING",
  296. organId: null,
  297. };
  298. export default {
  299. components: { pagination, Tooltip, review, audit },
  300. name: "helpCategory",
  301. data() {
  302. return {
  303. typesStatus: false,
  304. selList: [],
  305. paymentTypeList: auditPaymentTypeList,
  306. organList: [],
  307. statusList: auditTypeList,
  308. searchForm: { ...initSearch },
  309. tableList: [],
  310. pageInfo: {
  311. // 分页规则
  312. limit: 10, // 限制显示条数
  313. page: 1, // 当前页
  314. total: 0, // 总条数
  315. page_size: [10, 20, 40, 50], // 选择限制显示条数
  316. },
  317. detail: null,
  318. typeStatus: false,
  319. };
  320. },
  321. mounted() {
  322. this.$store.dispatch("setBranchs");
  323. this.getList();
  324. },
  325. methods: {
  326. selectable(row, index) {
  327. return row.status == "AUDITING";
  328. },
  329. search() {
  330. this.pageInfo.page = 1;
  331. this.$refs.searchForm.save(this.searchForm);
  332. this.$refs.searchForm.save(this.pageInfo, "page");
  333. this.getList();
  334. },
  335. reset() {
  336. this.searchForm = { ...initSearch };
  337. this.search();
  338. },
  339. handleSelectionChange(arr) {
  340. this.selList = arr;
  341. },
  342. getList() {
  343. let params = {
  344. page: this.pageInfo.page,
  345. rows: this.pageInfo.limit,
  346. ...this.searchForm,
  347. };
  348. getAuditList(params).then((res) => {
  349. let result = res.data;
  350. if (res.code == 200) {
  351. this.tableList = result.rows;
  352. this.pageInfo.total = result.total;
  353. }
  354. });
  355. },
  356. lookDetail(row) {
  357. // this.detail = res.data
  358. this.detail = {
  359. id: row.id,
  360. musicGroupId: row.musicGroupId,
  361. status: row.status,
  362. batchNo: row.batchNo,
  363. };
  364. this.typeStatus = true;
  365. },
  366. submited() {
  367. this.pageInfo.page = 1;
  368. this.getList();
  369. },
  370. close() {
  371. this.typeStatus = false;
  372. this.getList();
  373. },
  374. },
  375. watch: {
  376. typeStatus(val) {
  377. if (!val) {
  378. this.detail = null;
  379. }
  380. },
  381. },
  382. };
  383. </script>
  384. <style lang="scss" scoped>
  385. ::v-deep .el-date-editor.el-input {
  386. width: 100% !important;
  387. }
  388. ::v-deep .el-select {
  389. width: 100% !important;
  390. }
  391. ::v-deep .el-table .cell {
  392. display: -webkit-box;
  393. overflow: hidden;
  394. text-overflow: ellipsis;
  395. -webkit-line-clamp: 3;
  396. -webkit-box-orient: vertical;
  397. }
  398. ::v-deep .el-dialog__body {
  399. padding: 10px 20px;
  400. }
  401. .newBand {
  402. display: inline-block;
  403. }
  404. </style>