index.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. <template>
  2. <div class="app-container">
  3. <el-form
  4. :model="queryParams"
  5. ref="queryForm"
  6. size="small"
  7. :inline="true"
  8. v-show="showSearch"
  9. label-width="68px"
  10. >
  11. <el-collapse class="searchCollapse" disabled>
  12. <el-collapse-item>
  13. <template slot="title">
  14. <el-row class="flex">
  15. <div class="titleWrapper">
  16. <el-col :span="6">
  17. <el-form-item label="客户名称" prop="customerName">
  18. <el-input
  19. v-model="queryParams.customerName"
  20. placeholder="请输入客户名称"
  21. clearable
  22. @keyup.enter.native="handleQuery"
  23. :style="{ width: '100%' }"
  24. />
  25. </el-form-item>
  26. </el-col>
  27. <el-col :span="6">
  28. <el-form-item label="客户编号" prop="customerCode">
  29. <el-input
  30. v-model="queryParams.customerCode"
  31. placeholder="请输入客户编号"
  32. clearable
  33. @keyup.enter.native="handleQuery"
  34. :style="{ width: '100%' }"
  35. />
  36. </el-form-item>
  37. </el-col>
  38. <el-col :span="6">
  39. <el-form-item label="客户状态" prop="status">
  40. <el-select
  41. v-model="queryParams.status"
  42. placeholder="全部"
  43. clearable
  44. :style="{ width: '100%' }"
  45. >
  46. <el-option
  47. v-for="dict in dict.type.CUSTOMER_STATUS"
  48. :key="dict.value"
  49. :label="dict.label"
  50. :value="dict.value"
  51. />
  52. </el-select>
  53. </el-form-item>
  54. </el-col>
  55. <el-col :span="6">
  56. <el-form-item label="登记日期" prop="createdDate">
  57. <el-date-picker
  58. v-model="queryParams.createdDate"
  59. type="date"
  60. placeholder="请选择登记日期"
  61. :style="{ width: '100%' }"
  62. >
  63. <!-- style="width: 205.4px" -->
  64. </el-date-picker>
  65. </el-form-item>
  66. </el-col>
  67. </div>
  68. </el-row>
  69. </template>
  70. <div class="infoWrapper">
  71. <el-row>
  72. <el-col :span="6">
  73. <el-form-item label="登记人" prop="createdBy">
  74. <el-input
  75. v-model="queryParams.createdBy"
  76. placeholder="请输入登记人"
  77. clearable
  78. @keyup.enter.native="handleQuery"
  79. :style="{ width: '100%' }"
  80. />
  81. </el-form-item>
  82. </el-col>
  83. <el-col :span="6">
  84. <el-form-item label="审核状态" prop="state">
  85. <el-select
  86. v-model="queryParams.state"
  87. placeholder="全部"
  88. clearable
  89. :style="{ width: '100%' }"
  90. >
  91. <el-option
  92. v-for="dict in dict.type.audit_status"
  93. :key="dict.value"
  94. :label="dict.label"
  95. :value="dict.value"
  96. />
  97. </el-select>
  98. </el-form-item>
  99. </el-col>
  100. <el-col :span="6">
  101. <el-form-item label="是否启用" prop="isOpen">
  102. <el-select
  103. v-model="queryParams.isOpen"
  104. placeholder="全部"
  105. clearable
  106. :style="{ width: '100%' }"
  107. >
  108. <el-option
  109. v-for="dict in dict.type.start_using_yes_no"
  110. :key="dict.value"
  111. :label="dict.label"
  112. :value="dict.value"
  113. />
  114. </el-select>
  115. </el-form-item>
  116. </el-col>
  117. <el-col :span="6">
  118. <el-form-item label="企业性质" prop="customerNature">
  119. <el-select
  120. v-model="queryParams.customerNature"
  121. placeholder="全部"
  122. clearable
  123. :style="{ width: '100%' }"
  124. >
  125. <el-option
  126. v-for="dict in dict.type.CUSTOMER_NATURE"
  127. :key="dict.value"
  128. :label="dict.label"
  129. :value="dict.value"
  130. />
  131. </el-select>
  132. </el-form-item>
  133. </el-col>
  134. </el-row>
  135. <el-row>
  136. <el-col :span="6">
  137. <el-form-item label="申请部门" prop="responsibleDept">
  138. <treeselect
  139. v-model="queryParams.responsibleDept"
  140. :options="deptOptions"
  141. :show-count="true"
  142. placeholder="全部"
  143. :style="{ width: '100%' }"
  144. />
  145. <!-- style="width: 489px" -->
  146. </el-form-item>
  147. </el-col>
  148. <el-col :span="6">
  149. <el-form-item label="行业" prop="trade">
  150. <el-select
  151. v-model="queryParams.trade"
  152. placeholder="全部"
  153. clearable
  154. :style="{ width: '100%' }"
  155. >
  156. <el-option
  157. v-for="dict in dict.type.CUSTOMER_TRADE"
  158. :key="dict.value"
  159. :label="dict.label"
  160. :value="dict.value"
  161. />
  162. </el-select>
  163. </el-form-item>
  164. </el-col>
  165. </el-row>
  166. </div>
  167. </el-collapse-item>
  168. </el-collapse>
  169. <el-form-item>
  170. <el-button
  171. type="primary"
  172. icon="el-icon-search"
  173. size="mini"
  174. @click="handleQuery"
  175. >搜索</el-button
  176. >
  177. <el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
  178. >重置</el-button
  179. >
  180. </el-form-item>
  181. </el-form>
  182. <el-row :gutter="10" class="mb8">
  183. <el-col :span="1.5">
  184. <el-button
  185. type="primary"
  186. plain
  187. icon="el-icon-plus"
  188. size="mini"
  189. @click="handleUserPopAdd"
  190. >新增客户</el-button
  191. >
  192. </el-col>
  193. <!-- <el-col :span="1.5">
  194. <el-button
  195. type="success"
  196. plain
  197. icon="el-icon-plus"
  198. size="mini"
  199. @click="handleApprovePopAdd"
  200. >指定审批人员</el-button
  201. >
  202. </el-col> -->
  203. </el-row>
  204. <el-table
  205. :header-cell-style="{ background: '#f8f8f9' }"
  206. v-loading="loading"
  207. :data="myTaskList"
  208. >
  209. <!-- @selection-change="handleSelectionChange" -->
  210. <el-table-column fixed type="selection" width="55" align="center" />
  211. <el-table-column
  212. fixed
  213. label="申请公司"
  214. align="center"
  215. prop="dhrmCompanyName"
  216. />
  217. <el-table-column fixed label="申请部门" align="center" prop="deptName" />
  218. <el-table-column label="客户名称" align="center" prop="customerName" />
  219. <el-table-column label="客户编码" align="center" prop="customerCode" />
  220. <el-table-column label="企业性质" align="center" prop="customerNature" />
  221. <el-table-column label="行业" align="center" prop="trade" />
  222. <el-table-column label="客户状态" align="center" prop="statusName" />
  223. <el-table-column label="成立日期" align="center" prop="registDate" />
  224. <el-table-column label="公司地址" align="center" prop="companyAddress" />
  225. <el-table-column label="申请人" align="center" prop="userName" />
  226. <el-table-column label="申请时间" align="center" prop="createdDate" />
  227. <el-table-column label="联系人" align="center" prop="contactsName" />
  228. <el-table-column label="电话" align="center" prop="phone" />
  229. <el-table-column label="登记日期" align="center" prop="createdDate" />
  230. <el-table-column label="登记人" align="center" prop="userName" />
  231. <el-table-column label="审核状态" align="center" prop="state" />
  232. <el-table-column label="是否启用" align="center" prop="isOpen" />
  233. <el-table-column label="数据来源" align="center" prop="dateFrom" />
  234. <el-table-column
  235. fixed="right"
  236. label="操作"
  237. align="center"
  238. class-name="small-padding fixed-width"
  239. >
  240. <template slot-scope="scope">
  241. <el-button
  242. size="mini"
  243. type="text"
  244. icon="el-icon-edit"
  245. @click="handleUpdate(scope.row)"
  246. v-hasPermi="['system:file:edit']"
  247. >修改</el-button
  248. >
  249. <el-button
  250. size="mini"
  251. type="text"
  252. icon="el-icon-delete"
  253. @click="handleDelete(scope.row)"
  254. v-hasPermi="['system:file:remove']"
  255. >删除</el-button
  256. >
  257. </template>
  258. </el-table-column>
  259. </el-table>
  260. <!-- 添加指定审批人员批对话框 -->
  261. <el-dialog :title="title" :visible.sync="open" width="700px" append-to-body>
  262. <el-form ref="form" :model="form" :rules="rules" label-width="100px">
  263. <el-form-item label="财务部" prop="financeDept">
  264. <el-select
  265. v-model="form.financeDept"
  266. multiple
  267. placeholder="请选择"
  268. :style="{ width: '100%' }"
  269. >
  270. <el-option
  271. v-for="item in financeDeptOptions"
  272. :key="item.value"
  273. :label="item.label"
  274. :value="item.value"
  275. >
  276. </el-option>
  277. </el-select>
  278. </el-form-item>
  279. <el-form-item label="法务部" prop="lawDept">
  280. <el-select
  281. v-model="form.lawDept"
  282. multiple
  283. placeholder="请选择"
  284. :style="{ width: '100%' }"
  285. >
  286. <el-option
  287. v-for="item in lawDeptOptions"
  288. :key="item.value"
  289. :label="item.label"
  290. :value="item.value"
  291. >
  292. </el-option>
  293. </el-select>
  294. </el-form-item>
  295. </el-form>
  296. <div slot="footer" class="dialog-footer">
  297. <el-button type="primary" @click="submitForm">确 定</el-button>
  298. <el-button @click="cancel">取 消</el-button>
  299. </div>
  300. </el-dialog>
  301. </div>
  302. </template>
  303. <script>
  304. import { deptTreeSelect } from "@/api/system/user";
  305. import Treeselect from "@riophae/vue-treeselect";
  306. import "@riophae/vue-treeselect/dist/vue-treeselect.css";
  307. export default {
  308. name: "customerInformationIndex",
  309. dicts: [
  310. "CUSTOMER_STATUS", //客户状态
  311. "audit_status", //审核状态
  312. "start_using_yes_no", //是否启用
  313. "CUSTOMER_NATURE", //企业性质
  314. "CUSTOMER_TRADE", //客户行业
  315. ],
  316. components: { Treeselect,SearchFile },
  317. data() {
  318. return {
  319. // 显示搜索条件
  320. showSearch: true,
  321. // 查询参数
  322. queryParams: {
  323. pageNum: 1,
  324. pageSize: 10,
  325. customerCode: null,
  326. customerName: null,
  327. status: null,
  328. createdDate: null,
  329. state: null,
  330. isOpen: null,
  331. customerNature: null,
  332. responsibleDept: null,
  333. trade: null,
  334. },
  335. // 部门树选项
  336. deptOptions: [],
  337. loading: false,
  338. open: false,
  339. title: "",
  340. form: {
  341. financeDept: null,
  342. lawDept: null,
  343. },
  344. rules: {},
  345. myTaskList: [],
  346. financeDeptOptions: [],
  347. lawDeptOptions: [],
  348. };
  349. },
  350. created() {
  351. // this.getList();
  352. this.getDeptTree();
  353. },
  354. mounted() {},
  355. methods: {
  356. /** 查询部门下拉树结构 */
  357. getDeptTree() {
  358. deptTreeSelect().then((response) => {
  359. this.deptOptions = response.data;
  360. });
  361. },
  362. /** 查询客户信息列表 */
  363. getList() {
  364. this.loading = true;
  365. listFile(this.queryParams).then((response) => {
  366. this.myTaskList = response.rows;
  367. this.total1 = response.total;
  368. this.loading = false;
  369. });
  370. },
  371. // 新增客户
  372. handleUserPopAdd() {
  373. this.$router.push({ name: "customerInformationAdd" });
  374. },
  375. // 指定审批人员
  376. handleApprovePopAdd() {
  377. this.reset();
  378. this.title = "指定审批人员";
  379. this.open = true;
  380. },
  381. // 取消按钮
  382. cancel() {
  383. this.open = false;
  384. this.reset();
  385. },
  386. // 指定审批人员
  387. submitForm() {
  388. this.open = false;
  389. },
  390. // 表单重置
  391. reset() {
  392. this.form = {
  393. financeDept: null,
  394. lawDept: null,
  395. };
  396. this.resetForm("form");
  397. },
  398. /** 搜索按钮操作 */
  399. handleQuery() {
  400. this.queryParams.pageNum = 1;
  401. this.getList();
  402. },
  403. /** 重置按钮操作 */
  404. resetQuery() {
  405. this.resetForm("queryForm");
  406. this.handleQuery();
  407. },
  408. // 多选框选中数据
  409. handleSelectionChange(selection) {
  410. this.ids = selection.map((item) => item.id);
  411. this.single = selection.length !== 1;
  412. this.multiple = !selection.length;
  413. },
  414. },
  415. };
  416. </script>
  417. <style lang="scss" scoped>
  418. </style>