list1.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
  4. <el-form-item label="公司名" prop="companyId">
  5. <el-select filterable style="width: 220px" v-model="queryParams.companyId" placeholder="请选择公司名" clearable size="small">
  6. <el-option
  7. v-for="item in companys"
  8. :key="item.companyId"
  9. :label="item.companyName"
  10. :value="item.companyId"
  11. />
  12. </el-select>
  13. </el-form-item>
  14. <el-form-item label="开始时间" prop="startTime">
  15. <el-date-picker v-model="dateRange" size="small" style="width: 220px" value-format="yyyy-MM-dd" type="daterange" range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期"></el-date-picker>
  16. </el-form-item>
  17. <el-form-item>
  18. <el-button type="cyan" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
  19. <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
  20. </el-form-item>
  21. </el-form>
  22. <el-row :gutter="10" class="mb8">
  23. <el-col :span="1.5">
  24. <el-button
  25. size="mini"
  26. @click="handleTransfer"
  27. v-hasPermi="['company:companyMoneyLogs:transfer']"
  28. >转账</el-button>
  29. </el-col>
  30. <el-col :span="1.5">
  31. <el-button
  32. type="warning"
  33. icon="el-icon-download"
  34. size="mini"
  35. @click="handleExport"
  36. v-hasPermi="['company:companyMoneyLogs:export']"
  37. >导出</el-button>
  38. </el-col>
  39. <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
  40. </el-row>
  41. <el-table height="500" border v-loading="loading" :data="companyMoneyLogsList" @selection-change="handleSelectionChange">
  42. <el-table-column type="selection" width="55" align="center" />
  43. <el-table-column label="ID" align="center" prop="logsId" />
  44. <el-table-column label="企业" align="center" prop="companyName" />
  45. <el-table-column label="金额" align="center" prop="money" />
  46. <el-table-column label="余额" align="center" prop="balance" />
  47. <el-table-column label="备注" align="center" prop="remark" />
  48. <el-table-column label="创建时间" align="center" prop="createTime" width="180">
  49. <template slot-scope="scope">
  50. <span>{{ parseTime(scope.row.createTime) }}</span>
  51. </template>
  52. </el-table-column>
  53. <el-table-column label="类型" align="center" prop="logsType" >
  54. <template slot-scope="scope">
  55. <el-tag prop="logsType" v-for="(item, index) in typesOptions" v-if="scope.row.logsType==item.dictValue">{{item.dictLabel}}</el-tag>
  56. </template>
  57. </el-table-column>
  58. </el-table>
  59. <pagination
  60. v-show="total>0"
  61. :total="total"
  62. :page.sync="queryParams.pageNum"
  63. :limit.sync="queryParams.pageSize"
  64. @pagination="getList"
  65. />
  66. </div>
  67. </template>
  68. <script>
  69. import { listCompanyMoneyLogs1, getCompanyMoneyLogs, delCompanyMoneyLogs, addCompanyMoneyLogs, updateCompanyMoneyLogs, exportCompanyMoneyLogs } from "@/api/company/companyMoneyLogs";
  70. import { getCompanyList } from "@/api/company/company";
  71. export default {
  72. name: "CompanyMoneyLogs",
  73. data() {
  74. return {
  75. typesOptions:[],
  76. companys:[],
  77. // 遮罩层
  78. loading: true,
  79. // 选中数组
  80. ids: [],
  81. // 非单个禁用
  82. single: true,
  83. // 非多个禁用
  84. multiple: true,
  85. // 显示搜索条件
  86. showSearch: true,
  87. // 总条数
  88. total: 0,
  89. // 企业账户记录表格数据
  90. companyMoneyLogsList: [],
  91. // 弹出层标题
  92. title: "",
  93. dateRange:[],
  94. // 是否显示弹出层
  95. open: false,
  96. // 查询参数
  97. queryParams: {
  98. pageNum: 1,
  99. pageSize: 10,
  100. companyId: null,
  101. money: null,
  102. },
  103. // 表单参数
  104. form: {},
  105. // 表单校验
  106. rules: {
  107. companyId: [
  108. { required: true, message: "企业不能为空", trigger: "blur" },
  109. ],
  110. money: [
  111. { required: true, message: "金额不能为空", trigger: "blur" },
  112. ],
  113. }
  114. };
  115. },
  116. created() {
  117. this.getDicts("company_money_logs_type").then((response) => {
  118. this.typesOptions = response.data;
  119. });
  120. getCompanyList().then(response => {
  121. this.companys = response.data;
  122. });
  123. this.getList();
  124. },
  125. methods: {
  126. /** 查询企业账户记录列表 */
  127. getList() {
  128. this.loading = true;
  129. listCompanyMoneyLogs1(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
  130. this.companyMoneyLogsList = response.rows;
  131. this.total = response.total;
  132. this.loading = false;
  133. });
  134. },
  135. // 取消按钮
  136. cancel() {
  137. this.open = false;
  138. this.reset();
  139. },
  140. // 表单重置
  141. reset() {
  142. this.form = {
  143. logsId: null,
  144. companyId: null,
  145. money: null,
  146. remark: null,
  147. createTime: null
  148. };
  149. this.resetForm("form");
  150. },
  151. /** 搜索按钮操作 */
  152. handleQuery() {
  153. this.queryParams.pageNum = 1;
  154. this.getList();
  155. },
  156. /** 重置按钮操作 */
  157. resetQuery() {
  158. this.resetForm("queryForm");
  159. this.handleQuery();
  160. },
  161. // 多选框选中数据
  162. handleSelectionChange(selection) {
  163. this.ids = selection.map(item => item.logsId)
  164. this.single = selection.length!==1
  165. this.multiple = !selection.length
  166. },
  167. handleExport() {
  168. const queryParams = this.queryParams;
  169. queryParams.logsType=1;
  170. queryParams.type=0;
  171. this.$confirm('是否确认导出所有企业账户记录数据项?', "警告", {
  172. confirmButtonText: "确定",
  173. cancelButtonText: "取消",
  174. type: "warning"
  175. }).then(function() {
  176. return exportCompanyMoneyLogs(queryParams);
  177. }).then(response => {
  178. this.download(response.msg);
  179. }).catch(function() {});
  180. },
  181. }
  182. };
  183. </script>