index.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  1. <template>
  2. <div class="m-container">
  3. <h2>
  4. <div class="squrt"></div>
  5. 审核列表
  6. </h2>
  7. <div class="m-core">
  8. <!-- 搜索标题 -->
  9. <el-form :inline="true" class="searchForm" v-model.trim="searchForm">
  10. <el-form-item>
  11. <el-input
  12. v-model.trim="searchForm.search"
  13. @keyup.enter.native="search"
  14. placeholder="乐团名称/编号"
  15. ></el-input>
  16. </el-form-item>
  17. <el-form-item>
  18. <el-select
  19. class="multiple"
  20. v-model.trim="searchForm.organId"
  21. filterable
  22. clearable
  23. placeholder="请选择分部"
  24. >
  25. <el-option
  26. v-for="(item, index) in organList"
  27. :key="index"
  28. :label="item.name"
  29. :value="item.id"
  30. ></el-option>
  31. </el-select>
  32. </el-form-item>
  33. <el-form-item>
  34. <el-select
  35. class="multiple"
  36. v-model.trim="searchForm.paymentType"
  37. filterable
  38. clearable
  39. placeholder="申请类型"
  40. >
  41. <el-option
  42. v-for="(item, index) in paymentTypeList"
  43. :key="index"
  44. :label="item.label"
  45. :value="item.value"
  46. ></el-option>
  47. </el-select>
  48. </el-form-item>
  49. <el-form-item>
  50. <el-select
  51. class="multiple"
  52. v-model.trim="searchForm.status"
  53. filterable
  54. clearable
  55. placeholder="审核状态"
  56. >
  57. <el-option
  58. v-for="(item, index) in statusList"
  59. :key="index"
  60. :label="item.label"
  61. :value="item.value"
  62. ></el-option>
  63. </el-select>
  64. </el-form-item>
  65. <el-form-item>
  66. <el-button @click="getList" type="danger">搜索</el-button>
  67. </el-form-item>
  68. </el-form>
  69. <div class="tableWrap">
  70. <el-table
  71. :data="tableList"
  72. :header-cell-style="{ background: '#EDEEF0', color: '#444' }"
  73. >
  74. <!-- <el-table-column type="selection" width="55"></el-table-column> -->
  75. <el-table-column
  76. align="center"
  77. prop="organName"
  78. label="分部名称"
  79. ></el-table-column>
  80. <el-table-column
  81. align="center"
  82. prop="musicGroupName"
  83. label="乐团名称"
  84. ></el-table-column>
  85. <el-table-column
  86. align="center"
  87. width="180px"
  88. prop="musicGroupId"
  89. label="乐团编号"
  90. ></el-table-column>
  91. <el-table-column align="center" prop="paymentType" label="申请类型">
  92. <template slot-scope="scope">
  93. <div>
  94. {{ scope.row.paymentType | auditPaymentType }}
  95. </div>
  96. </template></el-table-column
  97. >
  98. <el-table-column align="center" prop="payUserType" label="订单类型">
  99. <template slot-scope="scope">
  100. <div>
  101. {{ scope.row.payUserType | payOrderType }}
  102. </div>
  103. </template>
  104. </el-table-column>
  105. <el-table-column
  106. align="center"
  107. prop="addCourseTotalTime"
  108. label="加课总时长(分钟)"
  109. ></el-table-column>
  110. <el-table-column
  111. align="center"
  112. prop="courseOriginalPrice"
  113. label="原现价(元)"
  114. >
  115. <template slot-scope="scope">
  116. <div>
  117. {{ scope.row.courseOriginalPrice | moneyFormat }}
  118. </div>
  119. </template>
  120. </el-table-column>
  121. <el-table-column
  122. align="center"
  123. prop="courseCurrentPrice"
  124. label="申请价格(元)"
  125. >
  126. <template slot-scope="scope">
  127. <div>
  128. {{ scope.row.courseCurrentPrice | moneyFormat }}
  129. </div>
  130. </template>
  131. </el-table-column>
  132. <el-table-column align="center" prop="memo" label="备注">
  133. <template slot-scope="scope">
  134. <tooltip :content="scope.row.memo" />
  135. </template>
  136. </el-table-column>
  137. <el-table-column
  138. align="center"
  139. prop="operatorName"
  140. label="申请人"
  141. ></el-table-column>
  142. <el-table-column
  143. align="center"
  144. prop="auditStatus"
  145. label="状态"
  146. width="100px"
  147. >
  148. <template slot-scope="scope">
  149. <div>
  150. {{ scope.row.auditStatus | auditType }}
  151. </div>
  152. </template>
  153. </el-table-column>
  154. <el-table-column
  155. align="center"
  156. prop="createTime"
  157. label="申请时间"
  158. width="140px"
  159. >
  160. <template slot-scope="scope">
  161. <div>
  162. {{ scope.row.createTime | dateForMinFormat }}
  163. </div>
  164. </template></el-table-column
  165. >
  166. <!-- -->
  167. <el-table-column
  168. align="center"
  169. label="操作"
  170. width="100px"
  171. fixed="right"
  172. >
  173. <template slot-scope="scope">
  174. <el-button
  175. v-permission="'helpCenterContent/modify'"
  176. @click="lookDetail(scope.row)"
  177. type="text"
  178. >查看</el-button
  179. >
  180. </template>
  181. </el-table-column>
  182. </el-table>
  183. <pagination
  184. :total="pageInfo.total"
  185. :page.sync="pageInfo.page"
  186. :limit.sync="pageInfo.limit"
  187. :page-sizes="pageInfo.page_size"
  188. @pagination="getList"
  189. />
  190. </div>
  191. </div>
  192. <el-dialog title="申请详情" width="900px" :visible.sync="typeStatus" destroy-on-close>
  193. <review :detail="detail" @close="close" />
  194. </el-dialog>
  195. </div>
  196. </template>
  197. <script>
  198. import pagination from "@/components/Pagination/index";
  199. import review from "@/views/resetTeaming/modals/review.vue";
  200. // import store from '@/store'
  201. import { getAuditList, getAuditListDetail } from "@/api/auditManager";
  202. import { getEmployeeOrgan } from "@/api/buildTeam";
  203. import Tooltip from "@/components/Tooltip/index";
  204. import { auditTypeList, auditPaymentTypeList } from "@/utils/searchArray";
  205. export default {
  206. components: { pagination, Tooltip, review },
  207. name: "helpCategory",
  208. data() {
  209. return {
  210. paymentTypeList: auditPaymentTypeList,
  211. organList: [],
  212. statusList: auditTypeList,
  213. searchForm: {
  214. search: null,
  215. paymentType: null,
  216. status: 'AUDITING',
  217. organId: null,
  218. },
  219. tableList: [],
  220. pageInfo: {
  221. // 分页规则
  222. limit: 10, // 限制显示条数
  223. page: 1, // 当前页
  224. total: 0, // 总条数
  225. page_size: [10, 20, 40, 50], // 选择限制显示条数
  226. },
  227. detail: null,
  228. typeStatus: false,
  229. };
  230. },
  231. activated() {
  232. this.getList();
  233. },
  234. mounted() {
  235. getEmployeeOrgan().then((res) => {
  236. if (res.code == 200) {
  237. this.organList = res.data;
  238. }
  239. });
  240. this.getList();
  241. },
  242. methods: {
  243. getList() {
  244. let params = {
  245. page: this.pageInfo.page,
  246. rows: this.pageInfo.limit,
  247. ...this.searchForm,
  248. };
  249. getAuditList(params).then((res) => {
  250. let result = res.data;
  251. if (res.code == 200) {
  252. this.tableList = result.rows;
  253. this.pageInfo.total = result.total;
  254. }
  255. });
  256. },
  257. lookDetail(row) {
  258. // this.detail = res.data
  259. this.detail = {
  260. id:row.musicGroupPaymentCalenderId,
  261. musicGroupId:row.musicGroupId,
  262. status:row.auditStatus
  263. }
  264. this.typeStatus = true;
  265. },
  266. close() {
  267. this.typeStatus = false;
  268. this.getList()
  269. },
  270. },
  271. watch: {
  272. typeStatus(val) {
  273. if (!val) {
  274. this.detail = null;
  275. }
  276. },
  277. },
  278. };
  279. </script>
  280. <style lang="scss" scoped>
  281. .el-button--primary {
  282. background: #14928a;
  283. border-color: #14928a;
  284. color: #fff;
  285. &:hover,
  286. &:active,
  287. &:focus {
  288. background: #14928a;
  289. border-color: #14928a;
  290. color: #fff;
  291. }
  292. }
  293. /deep/.el-date-editor.el-input {
  294. width: 100% !important;
  295. }
  296. /deep/.el-select {
  297. width: 100% !important;
  298. }
  299. /deep/.el-table .cell {
  300. display: -webkit-box;
  301. overflow: hidden;
  302. text-overflow: ellipsis;
  303. -webkit-line-clamp: 3;
  304. -webkit-box-orient: vertical;
  305. }
  306. /deep/.el-dialog__body {
  307. padding: 10px 20px;
  308. }
  309. .newBand {
  310. display: inline-block;
  311. }
  312. </style>