detailsPageEdit.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814
  1. <template>
  2. <div class="borderless">
  3. <div class="customer-head">
  4. <div class="customer-back">
  5. <!-- <i class="back-icon el-icon-arrow-left"></i><i style="font-style:normal">返回管理列表</i>-->
  6. <el-button
  7. type="danger"
  8. style="border: none;background: none;color: red"
  9. icon="el-icon-arrow-left"
  10. @click="backToList"
  11. >返回列表
  12. </el-button>
  13. </div>
  14. <div class="add-customer-btn">
  15. <el-button type="primary" @click="openFlow" size="small"
  16. >审 核
  17. </el-button>
  18. <el-button
  19. type="primary"
  20. :disabled="disabled"
  21. @click="editCustomer"
  22. size="small"
  23. >{{ form.id ? "确认修改" : "确认新增" }}
  24. </el-button>
  25. </div>
  26. </div>
  27. <div class="customer-main">
  28. <el-form
  29. :model="form"
  30. ref="form"
  31. label-width="100px"
  32. class="demo-ruleForm"
  33. >
  34. <containerTitle title="基础资料"></containerTitle>
  35. <basic-container>
  36. <el-row>
  37. <el-col
  38. v-for="(item, index) in basicData.column"
  39. :key="index"
  40. :span="item.span ? item.span : 8"
  41. >
  42. <el-form-item
  43. :label="item.label"
  44. :prop="item.prop"
  45. :rules="item.rules"
  46. >
  47. <avue-input-tree
  48. v-if="item.prop === 'corpsTypeId'"
  49. leaf-only
  50. multiple
  51. style="width: 100%;"
  52. size="small"
  53. :props="{ label: 'title' }"
  54. v-model="form[item.prop]"
  55. placeholder=" "
  56. type="tree"
  57. :dic="dic"
  58. ></avue-input-tree>
  59. <avue-input-tree
  60. v-else-if="item.prop === 'belongtoarea'"
  61. leaf-only
  62. multiple
  63. style="width: 100%;"
  64. size="small"
  65. :props="{ label: 'name', value: 'name' }"
  66. v-model="form[item.prop]"
  67. placeholder=" "
  68. type="tree"
  69. :dic="dicArea"
  70. ></avue-input-tree>
  71. <el-select
  72. v-else-if="item.prop === 'adminProfiles'"
  73. size="small"
  74. style="width: 100%;"
  75. v-model="form[item.prop]"
  76. multiple
  77. placeholder=""
  78. >
  79. <el-option
  80. v-for="item in userList"
  81. :key="item.id"
  82. :label="item.name"
  83. :value="item.id"
  84. >
  85. </el-option>
  86. </el-select>
  87. <el-input
  88. type="age"
  89. v-else
  90. v-model="form[item.prop]"
  91. size="small"
  92. autocomplete="off"
  93. ></el-input>
  94. </el-form-item>
  95. </el-col>
  96. </el-row>
  97. </basic-container>
  98. <containerTitle title="联系方式"></containerTitle>
  99. <basic-container>
  100. <el-row>
  101. <el-col
  102. v-for="(item, index) in contactInformation.column"
  103. :key="index"
  104. :span="item.span ? item.span : 8"
  105. >
  106. <el-form-item
  107. :label="item.label"
  108. :prop="item.prop"
  109. :rules="item.rules"
  110. >
  111. <el-input
  112. type="age"
  113. v-model="form[item.prop]"
  114. size="small"
  115. autocomplete="off"
  116. ></el-input>
  117. </el-form-item>
  118. </el-col>
  119. </el-row>
  120. </basic-container>
  121. <containerTitle title="财务资料"></containerTitle>
  122. <basic-container>
  123. <el-row>
  124. <el-col
  125. v-for="(item, index) in financialInformation.column"
  126. :key="index"
  127. :span="item.span ? item.span : 8"
  128. >
  129. <el-form-item
  130. :label="item.label"
  131. :prop="item.prop"
  132. :rules="item.rules"
  133. >
  134. <el-switch
  135. v-if="item.prop === 'creditstatus'"
  136. v-model="form[item.prop]"
  137. active-value="0"
  138. inactive-value="1"
  139. active-text="开启"
  140. inactive-text="关闭"
  141. >
  142. </el-switch>
  143. <el-select
  144. v-else-if="item.prop === 'paymentType'"
  145. v-model="form[item.prop]"
  146. clearable
  147. filterable
  148. size="small"
  149. style="width: 100%;"
  150. >
  151. <el-option
  152. v-for="(item, index) in paymentOption"
  153. :key="index"
  154. :label="item.dictValue"
  155. :value="item.dictValue"
  156. ></el-option>
  157. </el-select>
  158. <el-input
  159. v-else
  160. type="age"
  161. v-model="form[item.prop]"
  162. size="small"
  163. autocomplete="off"
  164. ></el-input>
  165. </el-form-item>
  166. </el-col>
  167. </el-row>
  168. </basic-container>
  169. <containerTitle title="客户联系人"></containerTitle>
  170. <basic-container>
  171. <avue-crud
  172. :option="customerContact"
  173. v-model="contactsForm"
  174. :data="contactsData"
  175. @row-save="rowSave"
  176. @row-update="rowUpdate"
  177. @row-del="rowDel"
  178. ></avue-crud>
  179. </basic-container>
  180. <!-- <containerTitle title="客户优势项目"></containerTitle>
  181. <basic-container style="margin-bottom: 10px">
  182. <avue-crud
  183. :option="advantageProject"
  184. v-model="advantageProjectForm"
  185. :data="advantageProjectData"
  186. @row-save="rowSaveProject"
  187. @row-update="rowUpdateProject"
  188. @row-del="rowDelProject"
  189. ></avue-crud>
  190. </basic-container> -->
  191. <containerTitle title="客户开户行"></containerTitle>
  192. <basic-container>
  193. <avue-crud
  194. :option="bankOfDeposit"
  195. v-model="bankOfDepositForm"
  196. :data="bankOfDepositData"
  197. @row-save="rowSaveBankOfDeposit"
  198. @row-update="rowUpdateBankOfDeposit"
  199. @row-del="rowDelBankOfDeposit"
  200. ></avue-crud>
  201. </basic-container>
  202. <containerTitle title="收发货地址"></containerTitle>
  203. <basic-container>
  204. <avue-crud
  205. :option="addressOption"
  206. v-model="addressForm"
  207. :data="addressData"
  208. @row-save="rowSaveAddress"
  209. @row-update="rowUpdateAddress"
  210. @row-del="rowDelAddress"
  211. ></avue-crud>
  212. </basic-container>
  213. </el-form>
  214. </div>
  215. <flow-dialog :switchDialog="switchDialog" @onClose="onClose()">
  216. <template slot="content"> </template>
  217. </flow-dialog>
  218. </div>
  219. </template>
  220. <script>
  221. import {
  222. customerList,
  223. typeSave,
  224. detail,
  225. deleteDetails,
  226. corpstypeTree,
  227. corpsattn,
  228. corpsbank,
  229. corpsfiles,
  230. corpsitem,
  231. areaTypeTree,
  232. corpsAddrDelete,
  233. } from "@/api/basicData/customerInformation";
  234. import customerContact from "./configuration/customerContact.json";
  235. import advantageProject from "./configuration/advantageProject.json";
  236. import bankOfDeposit from "./configuration/bankOfDeposit.json";
  237. import flowDialog from "@/components/flow-dialog/main";
  238. import { supplierParameter } from "@/enums/management-type";
  239. import { gainUser } from "@/api/basicData/customerInquiry";
  240. import addressOption from "./configuration/addressOption.json";
  241. export default {
  242. name: "detailsPage",
  243. data() {
  244. return {
  245. switchDialog: false,
  246. form: {},
  247. disabled: false,
  248. contactsForm: {},
  249. advantageProjectForm: {},
  250. bankOfDepositForm: {},
  251. contactsData: [],
  252. advantageProjectData: [],
  253. bankOfDepositData: [],
  254. dic: [],
  255. dicArea: [],
  256. customerContact: customerContact,
  257. advantageProject: advantageProject,
  258. bankOfDeposit: bankOfDeposit,
  259. contactInformation: {
  260. column: [
  261. {
  262. label: "联系人",
  263. prop: "attn",
  264. rules: [
  265. {
  266. required: false,
  267. message: "请输入联系人",
  268. trigger: "blur"
  269. }
  270. ]
  271. },
  272. {
  273. label: "联系电话",
  274. prop: "tel",
  275. rules: [
  276. {
  277. required: false,
  278. message: "请输入联系电话",
  279. trigger: "blur"
  280. }
  281. ]
  282. },
  283. {
  284. label: "职位",
  285. prop: "position",
  286. rules: [
  287. {
  288. required: false,
  289. message: "请输入联系电话",
  290. trigger: "blur"
  291. }
  292. ]
  293. },
  294. {
  295. label: "单位地址",
  296. prop: "addr",
  297. rules: [
  298. {
  299. required: false,
  300. message: "请输入单位地址",
  301. trigger: "blur"
  302. }
  303. ]
  304. },
  305. {
  306. label: "仓库地址",
  307. prop: "storageAddr",
  308. rules: [
  309. {
  310. required: false,
  311. message: "请输入仓库地址",
  312. trigger: "blur"
  313. }
  314. ]
  315. },
  316. {
  317. label: "分仓地址",
  318. prop: "subStorageAddr",
  319. rules: [
  320. {
  321. required: false,
  322. message: "请输入分仓地址",
  323. trigger: "blur"
  324. }
  325. ]
  326. }
  327. ]
  328. },
  329. financialInformation: {
  330. column: [
  331. {
  332. label: "账户名称",
  333. prop: "accountName",
  334. rules: [
  335. {
  336. required: false,
  337. message: " ",
  338. trigger: "blur"
  339. }
  340. ]
  341. },
  342. {
  343. label: "开户银行",
  344. prop: "accountBank",
  345. rules: [
  346. {
  347. required: false,
  348. message: " ",
  349. trigger: "blur"
  350. }
  351. ]
  352. },
  353. {
  354. label: "银行帐号",
  355. prop: "accountNo",
  356. rules: [
  357. {
  358. required: false,
  359. message: " ",
  360. trigger: "blur"
  361. }
  362. ]
  363. },
  364. {
  365. label: "外币账户名称",
  366. prop: "accountNameFcy",
  367. rules: [
  368. {
  369. required: false,
  370. message: " ",
  371. trigger: "blur"
  372. }
  373. ]
  374. },
  375. {
  376. label: "外币开户银行",
  377. prop: "accountBankFcy",
  378. rules: [
  379. {
  380. required: false,
  381. message: " ",
  382. trigger: "blur"
  383. }
  384. ]
  385. },
  386. {
  387. label: "外币银行账号",
  388. prop: "accountNoFcy",
  389. rules: [
  390. {
  391. required: false,
  392. message: " ",
  393. trigger: "blur"
  394. }
  395. ]
  396. },
  397. {
  398. label: "授信状态",
  399. prop: "creditstatus",
  400. rules: [
  401. {
  402. required: false,
  403. message: " ",
  404. trigger: "blur"
  405. }
  406. ]
  407. },
  408. {
  409. label: "授信等级",
  410. prop: "creditLevel",
  411. rules: [
  412. {
  413. required: false,
  414. message: " ",
  415. trigger: "blur"
  416. }
  417. ]
  418. },
  419. {
  420. label: "授信额度",
  421. prop: "creditGrant",
  422. rules: [
  423. {
  424. required: false,
  425. message: " ",
  426. trigger: "blur"
  427. }
  428. ]
  429. },
  430. {
  431. label: "授信天数",
  432. prop: "creditDay",
  433. rules: [
  434. {
  435. required: false,
  436. message: " ",
  437. trigger: "blur"
  438. }
  439. ]
  440. },
  441. {
  442. label: "授信利率",
  443. prop: "creditRate",
  444. rules: [
  445. {
  446. required: false,
  447. message: " ",
  448. trigger: "blur"
  449. }
  450. ]
  451. },
  452. {
  453. label: "FOB系数",
  454. prop: "coefficient"
  455. },
  456. {
  457. label: "付款方式",
  458. prop: "paymentType"
  459. }
  460. ]
  461. },
  462. basicData: {
  463. column: [
  464. {
  465. label: "编码",
  466. prop: "code",
  467. rules: [
  468. {
  469. required: true,
  470. message: " ",
  471. trigger: "blur"
  472. }
  473. ]
  474. },
  475. {
  476. label: "名称",
  477. prop: "cname",
  478. rules: [
  479. {
  480. required: true,
  481. message: " ",
  482. trigger: "blur"
  483. }
  484. ]
  485. },
  486. {
  487. label: "类别",
  488. prop: "corpsTypeId",
  489. rules: [
  490. {
  491. required: true,
  492. message: " ",
  493. trigger: "blur"
  494. }
  495. ]
  496. },
  497. {
  498. label: "企业类型",
  499. prop: "companytype",
  500. rules: [
  501. {
  502. required: false,
  503. message: " ",
  504. trigger: "blur"
  505. }
  506. ]
  507. },
  508. {
  509. label: "代理品牌",
  510. prop: "goodtypes",
  511. rules: [
  512. {
  513. required: false,
  514. message: " ",
  515. trigger: "blur"
  516. }
  517. ]
  518. },
  519. {
  520. label: "所属公司",
  521. prop: "belongtocompany",
  522. rules: [
  523. {
  524. required: false,
  525. message: " ",
  526. trigger: "blur"
  527. }
  528. ]
  529. },
  530. {
  531. label: "分管员",
  532. prop: "adminProfiles",
  533. span: 8
  534. },
  535. {
  536. label: "代理区域",
  537. prop: "belongtoarea",
  538. span: 16,
  539. mock: {
  540. type: "county"
  541. }
  542. },
  543. {
  544. label: "备注",
  545. prop: "remarks",
  546. span: 24,
  547. mock: {
  548. type: "county"
  549. }
  550. }
  551. ]
  552. },
  553. paymentOption: [],
  554. addressOption: addressOption,
  555. addressForm: {},
  556. addressData: []
  557. };
  558. },
  559. components: {
  560. flowDialog
  561. },
  562. created() {
  563. corpstypeTree({ corpType: supplierParameter.code }).then(res => {
  564. this.dic = res.data.data;
  565. });
  566. areaTypeTree().then(res => {
  567. this.dicArea = res.data.data;
  568. });
  569. this.getWorkDicts("payment_term").then(res => {
  570. this.paymentOption = res.data.data;
  571. });
  572. if (this.$route.query.id) {
  573. let id = this.$route.query.id.replace(/\"/g, "");
  574. // let id = parseInt(this.$route.query.id)
  575. detail(id).then(res => {
  576. if (res.data.data.adminProfiles) {
  577. res.data.data.adminProfiles = res.data.data.adminProfiles.split(",");
  578. }
  579. this.form = res.data.data;
  580. this.contactsData = this.form.corpsAttnList;
  581. this.bankOfDepositData = this.form.corpsBankList;
  582. this.advantageProjectData = this.form.corpsItems;
  583. this.addressData = this.form.corpsAddrList.length > 0?this.form.corpsAddrList: [];
  584. delete this.form.corpsAttnList;
  585. delete this.form.corpsBankList;
  586. delete this.form.corpsItems;
  587. delete this.form.corpsAddrList;
  588. });
  589. } else {
  590. //新增时根据左侧选中树结构给客户类别赋值
  591. this.$set(this.form, "corpsTypeId", this.$route.query.treeDeptId);
  592. }
  593. gainUser().then(res => {
  594. this.userList = res.data.data;
  595. });
  596. },
  597. watch: {
  598. $route(to, from) {
  599. console.log(to, from);
  600. if (this.$route.query.id) {
  601. let id = JSON.parse(this.$route.query.id).replace(/\"/g, "");
  602. detail(id).then(res => {
  603. console.log(res.data.data);
  604. this.form = res.data.data;
  605. });
  606. } else {
  607. this.form = {};
  608. }
  609. }
  610. },
  611. methods: {
  612. //新增客户联系人保存触发
  613. rowSave(row, done, loading) {
  614. console.log(row, done, loading);
  615. this.contactsData.push(row);
  616. done();
  617. },
  618. //修改客户联系人触发
  619. rowUpdate(row, index, done, loading) {
  620. done(row);
  621. },
  622. //删除客户联系人触发
  623. rowDel(row, index, donerowDel) {
  624. this.$confirm("确定将选择数据删除?", {
  625. confirmButtonText: "确定",
  626. cancelButtonText: "取消",
  627. type: "warning"
  628. }).then(() => {
  629. // 数据回调进行刷新
  630. if (row.id) {
  631. corpsattn(row.id).then(res => {
  632. this.$message({
  633. type: "success",
  634. message: "操作成功!"
  635. });
  636. this.contactsData.splice(index, 1);
  637. });
  638. } else {
  639. this.$message({
  640. type: "success",
  641. message: "操作成功!"
  642. });
  643. this.contactsData.splice(index, 1);
  644. }
  645. });
  646. },
  647. //新增客户优势项目保存触发
  648. rowSaveProject(row, done, loading) {
  649. console.log(row, done, loading);
  650. this.advantageProjectData.push(row);
  651. done();
  652. },
  653. //修改客户优势项目触发
  654. rowUpdateProject(row, index, done, loading) {
  655. done(row);
  656. },
  657. //删除客户优势项目触发
  658. rowDelProject(row, index, donerowDel) {
  659. this.$confirm("确定将选择数据删除?", {
  660. confirmButtonText: "确定",
  661. cancelButtonText: "取消",
  662. type: "warning"
  663. }).then(() => {
  664. if (row.id) {
  665. corpsitem(row.id).then(res => {
  666. this.$message({
  667. type: "success",
  668. message: "操作成功!"
  669. });
  670. this.advantageProjectData.splice(index, 1);
  671. });
  672. } else {
  673. this.$message({
  674. type: "success",
  675. message: "操作成功!"
  676. });
  677. this.advantageProjectData.splice(index, 1);
  678. }
  679. });
  680. },
  681. //新增客户优势项目保存触发
  682. rowSaveBankOfDeposit(row, done, loading) {
  683. console.log(row, done, loading);
  684. this.bankOfDepositData.push(row);
  685. done();
  686. },
  687. //修改客户优势项目触发
  688. rowUpdateBankOfDeposit(row, index, done, loading) {
  689. done(row);
  690. },
  691. //删除客户优势项目触发
  692. rowDelBankOfDeposit(row, index, donerowDel) {
  693. this.$confirm("确定将选择数据删除?", {
  694. confirmButtonText: "确定",
  695. cancelButtonText: "取消",
  696. type: "warning"
  697. }).then(() => {
  698. if (row.id) {
  699. corpsbank(row.id).then(res => {
  700. this.$message({
  701. type: "success",
  702. message: "操作成功!"
  703. });
  704. this.bankOfDepositData.splice(index, 1);
  705. });
  706. } else {
  707. this.$message({
  708. type: "success",
  709. message: "操作成功!"
  710. });
  711. this.bankOfDepositData.splice(index, 1);
  712. }
  713. });
  714. },
  715. //修改提交触发
  716. editCustomer() {
  717. this.$refs["form"].validate(valid => {
  718. if (valid) {
  719. this.form.corpsAttnList = this.contactsData;
  720. this.form.corpsBankList = this.bankOfDepositData;
  721. this.form.corpsItems = this.advantageProjectData;
  722. this.form.corpsAddrList = this.addressData;
  723. if (typeof this.form.corpsTypeId == "object") {
  724. this.form.corpsTypeId = this.form.corpsTypeId.join(",");
  725. }
  726. this.disabled = true;
  727. if (this.form.belongtoarea) {
  728. this.form.belongtoarea = this.form.belongtoarea.toString();
  729. }
  730. if (this.form.adminProfiles) {
  731. this.form.adminProfiles = this.form.adminProfiles.join(",");
  732. }
  733. this.form.corpType = supplierParameter.code;
  734. typeSave(this.form).then(res => {
  735. if (res.data.data === "error") {
  736. this.disabled = false;
  737. this.$message({
  738. showClose: true,
  739. message: res.data.msg,
  740. type: "error"
  741. });
  742. } else {
  743. this.$message({
  744. type: "success",
  745. message: this.form.id ? "修改成功!" : "新增成功!"
  746. });
  747. this.$router.$avueRouter.closeTag();
  748. this.$router.push({
  749. path: "/basicData/customerManagement/supplierMaterial/index",
  750. query: {}
  751. });
  752. }
  753. });
  754. } else {
  755. return false;
  756. }
  757. });
  758. },
  759. backToList() {
  760. this.$router.$avueRouter.closeTag();
  761. this.$router.push({
  762. path: "/basicData/customerManagement/supplierMaterial/index",
  763. query: {}
  764. });
  765. },
  766. openFlow() {
  767. this.switchDialog = !this.switchDialog;
  768. },
  769. onClose(val) {
  770. this.switchDialog = val;
  771. },
  772. //新增收发货地址保存触发
  773. rowSaveAddress(row, done, loading) {
  774. this.addressData.push(row);
  775. done();
  776. },
  777. //修改收发货地址优势项目触发
  778. rowUpdateAddress(row, index, done, loading) {
  779. done(row);
  780. },
  781. //删除收发货地址优势项目触发
  782. rowDelAddress(row, index, donerowDel) {
  783. this.$confirm("确定将选择数据删除?", {
  784. confirmButtonText: "确定",
  785. cancelButtonText: "取消",
  786. type: "warning"
  787. }).then(() => {
  788. if (row.id) {
  789. corpsAddrDelete(row.id).then(res => {
  790. this.$message({
  791. type: "success",
  792. message: "操作成功!"
  793. });
  794. this.addressData.splice(index, 1);
  795. });
  796. } else {
  797. this.$message({
  798. type: "success",
  799. message: "操作成功!"
  800. });
  801. this.addressData.splice(index, 1);
  802. }
  803. });
  804. },
  805. }
  806. };
  807. </script>
  808. <style lang="scss" scoped>
  809. ::v-deep .el-form-item {
  810. margin-bottom: 0;
  811. }
  812. </style>