index.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. import { value, switchs, date } from "./config";
  2. import Dialog from "../../miniprogram_npm/@vant/weapp/dialog/dialog";
  3. var _value = value;
  4. Component({
  5. options: {
  6. addGlobalClass: true,//解决继承全局样式问题
  7. },
  8. lifetimes: {
  9. attached: function () { this.init(); }
  10. },
  11. properties: {
  12. type: { type: String, value: "add" },
  13. key: String
  14. },
  15. observers: {
  16. 'value': function (value) {
  17. let A = value[0][1]["value"] * 1 || 0;
  18. let B = (value[0][3]["value"] * 1 || 0) + (value[0][4]["value"] * 1 || 0) + (value[0][5]["value"] * 1 || 0) +
  19. (value[0][6]["value"] * 1 || 0) + (value[0][7]["value"] * 1 || 0);
  20. let C = value[0][8]["value"] * 1 || 0;
  21. if (A == 0 || C == 0) return false;
  22. value[0][9]["value"] = ((parseFloat(A - C + B) / parseFloat(A + B)) * 100).toFixed(2) + "%";
  23. if (this.result && this.result == value[0][9]["value"]) return false;
  24. this.result = value[0][9]["value"];
  25. this.setData({
  26. value
  27. })
  28. }
  29. },
  30. data: {
  31. value,
  32. active: '',
  33. activeObject: {},
  34. activeIndex: [],
  35. switchB: false,
  36. endDate: date(),
  37. switchs,
  38. submitLock: false,
  39. saveLock: false,
  40. btn: true,
  41. radioInputShow: false,
  42. },
  43. methods: {
  44. //组件石林进入页面接节点树执行
  45. async init () {
  46. try {
  47. // 商品请求
  48. var laompany = [];
  49. let res = await wx.$request({ method: "get", url: "/order/productDict/" });
  50. laompany = res.data.map(item => ({ key: item.id, value: item.name, month: item.month }));
  51. let { type, value, switchs } = this.data;
  52. switchs['laompany'] = laompany;
  53. switch (type) {
  54. // 已填报查看
  55. case 'watch':
  56. var resA = await wx.$request({ url: `/order/${this.data.key}/`, method: "get" });
  57. var data = resA.data.data;
  58. value = this.watchFunc(value, data, switchs);
  59. break;
  60. case 'draftsupdate':
  61. // 修改草稿
  62. var resB = await wx.$request({ url: `/order/${this.data.key}/`, method: "get" });
  63. var data = resB.data;
  64. console.log(data)
  65. value = this.draftUpdataFunc(value, data, switchs);
  66. break;
  67. case 'providedupdate':
  68. // 修改已填报
  69. var resA = await wx.$request({ url: `/order/${this.data.key}/`, method: "get" });
  70. var { data, edit_values } = resA.data;
  71. value = this.updataFunc(value, data, edit_values, switchs);
  72. default:
  73. // 新增
  74. this.data.key && laompany.forEach((item, index) => {
  75. if (item.key == this.data.key) {
  76. value[0][10]["value"] = item.key;
  77. value[0][10]["index"] = index;
  78. value[0][11]['value'] = item['month'] + '个月';
  79. }
  80. })
  81. break;
  82. }
  83. this.setData({ value, switchs })
  84. } catch (err) { wx.$err(err) }
  85. },
  86. // 查看模式
  87. watchFunc (value, data, switchs) {
  88. return value.map(itemA => itemA.map(itemB => {
  89. if (!itemB.hasOwnProperty('value')) return itemB;
  90. if (itemB.name != "maturity") { itemB['value'] = data[itemB.name] === 0 ? 0 : data[itemB.name] || ''; }
  91. itemB['disabled'] = true;
  92. switchs.hasOwnProperty(itemB.name) && switchs[itemB.name].forEach((itemC, indexC) => {
  93. if (itemC.key === itemB.value) itemB["index"] = indexC;
  94. // 申请贷款产品 申请贷款期限关联
  95. if (itemB.name == 'laompany') {
  96. value[0][11]['value'] = itemC['month'] + '个月';
  97. }
  98. // 第一借款人与申请人关系特殊处理
  99. if (itemB.name == 'mstatus' && itemB.value == 1) {
  100. value[2][2] = { ...value[2][2], disabled: true, value: 0, index: 0 }
  101. }
  102. })
  103. return itemB
  104. })
  105. )
  106. },
  107. // 修改草稿
  108. draftUpdataFunc (value, data, switchs) {
  109. console.log("打卡")
  110. return value.map(itemA => itemA.map(itemB => {
  111. if (!itemB.hasOwnProperty('value')) return itemB;
  112. if (itemB.name != "maturity") {
  113. itemB['value'] = data[itemB.name] === 0 ? 0 : data[itemB.name] || '';
  114. }
  115. switchs.hasOwnProperty(itemB.name) && switchs[itemB.name].forEach((itemC, indexC) => {
  116. if (itemC.key === itemB.value) {
  117. itemB["index"] = indexC;
  118. };
  119. // 申请贷款产品 申请贷款期限关联
  120. if (itemB.name == 'laompany') {
  121. value[0][11]['value'] = itemC['month'] + '个月';
  122. }
  123. // 第一借款人与申请人关系特殊处理
  124. if (itemB.name == 'mstatus' && itemB.value == 1) {
  125. value[2][2] = { ...value[2][2], disabled: true, value: 0, index: 0 }
  126. }
  127. })
  128. return itemB
  129. }));
  130. },
  131. // 已填报修改模式
  132. updataFunc (value, data, edit_values, switchs) {
  133. // 后台更改贷款商品key
  134. return value.map(itemA => itemA.map(itemB => {
  135. if (!itemB.hasOwnProperty('value')) return itemB;
  136. if (itemB.name != "maturity") { itemB['value'] = data[itemB.name] === 0 ? 0 : data[itemB.name] || ''; }
  137. switchs.hasOwnProperty(itemB.name) && switchs[itemB.name].forEach((itemC, indexC) => {
  138. if (itemC.key === itemB.value) itemB["index"] = indexC;
  139. // 申请贷款产品 申请贷款期限关联
  140. if (itemB.name == 'laompany') {
  141. value[0][11]['value'] = itemC['month'] + '个月';
  142. }
  143. // 第一借款人与申请人关系特殊处理
  144. if (itemB.name == 'mstatus' && itemB.value == 1) {
  145. value[2][2] = { ...value[2][2], disabled: true, value: 0, index: 0 }
  146. }
  147. })
  148. edit_values.some(itemC => {
  149. if (itemC.name == itemB.name) {
  150. itemB['err'] = itemC['reason'];
  151. }
  152. return itemC.name == itemB.name;
  153. }) ? '' : itemB['disabled'] = true;
  154. return itemB
  155. }));
  156. },
  157. // 提交
  158. async submitFunc () {
  159. try {
  160. let { value, submitLock } = this.data, megs = [], data = {}, cvalue = [], tels = [];
  161. if (submitLock) return false;
  162. this.setData({ submitLock: true });
  163. if (value[2][6]['value'] == 0) {
  164. value = [...value[0], ...value[1], ...value[2]];
  165. cvalue = [..._value[0], ..._value[1], ..._value[2]];
  166. } else {
  167. value = [...value[0], ...value[1], ...value[2], ...value[3]];
  168. cvalue = [..._value[0], ..._value[1], ..._value[2], ..._value[3]];
  169. }
  170. value.forEach((item, index) => {
  171. // 特殊格式 非必须
  172. if (!item.hasOwnProperty('value') || item.norequire) {
  173. if (item.hasOwnProperty('value')) data[item.name] = item.value;
  174. return false
  175. };
  176. // 正常流程
  177. // 判断是否为空
  178. if (!item.value) { megs.push(`${item.title}不能为空!`); return false; };
  179. // 数字类型
  180. if (item.type == 'number' && !/^\d+.?\d*$/.test(item.value)) { megs.push(`${item.title}必须是数字!`); return false; }
  181. // 正则判断
  182. if (cvalue[index].reg && !cvalue[index].reg.test(item.value)) {
  183. megs.push(`${item.title}格式不正确!`); return false;
  184. };
  185. // 号码不能相同 tel tstel ctel cttel
  186. if (item.name == 'tel' || item.name == 'tstel' || item.name == 'ctel' || item.name == 'cttel') (!tels.some(itemT => itemT == item.value) || item.vlaue == '') && tels.push(item.value)
  187. ;
  188. data[item.name] = item.value;
  189. });
  190. (tels.length !== 4 && tels.length != 0) && megs.push(`手机号码不能重复`);
  191. if (megs.length != 0) {
  192. this.setData({ errorShow: true, megs, submitLock: false });
  193. return false;
  194. };
  195. data['category'] = 1;
  196. // 申请贷款期限 不用传
  197. delete data['maturity'];
  198. await wx.$request({ method: "post", url: "/order/", data });
  199. this.setData({ submitLock: false });
  200. Dialog.alert({ message: "已提交!" }).then(res => wx.reLaunch({ url: '/pages/index/index' }))
  201. } catch (err) { wx.$err(err) }
  202. },
  203. // 新增保存
  204. async saveFunc () {
  205. try {
  206. let { value, saveLock } = this.data, data = {};
  207. if (saveLock) return false;
  208. this.setData({ saveLock: true });
  209. // 拦截
  210. var requeire = ['name', 'tel'], megs = [];
  211. value = [...value[0], ...value[1], ...value[2], ...value[3]];
  212. var cvalue = [..._value[0], ..._value[1], ..._value[2], ..._value[3]];
  213. value.forEach((item, index) => {
  214. if (!item.hasOwnProperty('value')) return false;
  215. if (requeire.some(itemB => itemB == item.name)) {
  216. if (!item.value) {
  217. megs.push(`${item.title}不能为空!`)
  218. return false
  219. };
  220. if (cvalue[index].reg && !cvalue[index].reg.test(item.value)) {
  221. megs.push(`${item.title}格式不正确!`); return false;
  222. };
  223. }
  224. data[item.name] = item.value;
  225. });
  226. data['category'] = 0;
  227. // 申请贷款期限 不用传
  228. delete data['maturity'];
  229. if (megs.length != 0) {
  230. this.setData({ errorShow: true, megs, saveLock: false });
  231. return false;
  232. };
  233. await wx.$request({ method: "post", url: "/order/", data });
  234. this.setData({ saveLock: false })
  235. Dialog.alert({ message: "已保存!" }).then(res => wx.reLaunch({ url: '/pages/index/index' }))
  236. } catch (err) {
  237. wx.$err(err)
  238. }
  239. },
  240. // 保存草稿
  241. async draftsUpdateSaveFunc () {
  242. try {
  243. let { value, saveLock, key } = this.data, data = {};
  244. if (saveLock) return false;
  245. this.setData({ saveLock: true });
  246. // 拦截
  247. var requeire = ['name', 'tel'], megs = [];
  248. value = [...value[0], ...value[1], ...value[2], ...value[3]];
  249. var cvalue = [..._value[0], ..._value[1], ..._value[2], ..._value[3]];
  250. value.forEach((item, index) => {
  251. if (!item.hasOwnProperty('value')) return false;
  252. if (requeire.some(itemB => itemB == item.name)) {
  253. if (!item.value) {
  254. megs.push(`${item.title}不能为空!`)
  255. return false
  256. };
  257. if (cvalue[index].reg && !cvalue[index].reg.test(item.value)) {
  258. megs.push(`${item.title}格式不正确!`); return false;
  259. };
  260. }
  261. data[item.name] = item.value;
  262. });
  263. data['category'] = 0;
  264. // 申请贷款期限 不用传
  265. delete data['maturity'];
  266. if (megs.length != 0) {
  267. this.setData({ errorShow: true, megs, saveLock: false });
  268. return false;
  269. };
  270. console.log(data)
  271. await wx.$request({ method: "put", url: `/order/${key}/`, data });
  272. this.setData({ saveLock: false })
  273. Dialog.alert({ message: "已保存!" }).then(res => wx.navigateBack({ delta: 1 }))
  274. } catch (err) {
  275. wx.$err(err)
  276. }
  277. },
  278. // 已填报修改上报
  279. async UpdateSaveFunc () {
  280. try {
  281. let { value, submitLock } = this.data, megs = [], data = {}, cvalue = [], tels = [];
  282. if (submitLock) return false;
  283. this.setData({ submitLock: true });
  284. if (value[2][6]['value'] == 0) {
  285. value = [...value[0], ...value[1], ...value[2]];
  286. cvalue = [..._value[0], ..._value[1], ..._value[2]];
  287. } else {
  288. value = [...value[0], ...value[1], ...value[2], ...value[3]];
  289. cvalue = [..._value[0], ..._value[1], ..._value[2], ..._value[3]];
  290. }
  291. value.forEach((item, index) => {
  292. // 特殊格式 非必须
  293. if (!item.hasOwnProperty('value') || item.norequire) {
  294. if (item.hasOwnProperty('value')) data[item.name] = item.value;
  295. return false
  296. };
  297. // 正常流程
  298. // 判断是否为空
  299. if (!item.value) { megs.push(`${item.title}不能为空!`); return false; };
  300. // 数字类型
  301. if (item.type == 'number' && !/^\d+.?\d*$/.test(item.value)) { megs.push(`${item.title}必须是数字!`); return false; }
  302. // 正则判断
  303. if (cvalue[index].reg && !cvalue[index].reg.test(item.value)) {
  304. megs.push(`${item.title}格式不正确!`); return false;
  305. };
  306. // 号码不能相同 tel tstel ctel cttel
  307. if (item.name == 'tel' || item.name == 'tstel' || item.name == 'ctel' || item.name == 'cttel') (!tels.some(item.value) || item.vlaue == '') && tels.push(item.value)
  308. ;
  309. data[item.name] = item.value;
  310. });
  311. (tels.length !== 4 && tels.length != 0) && megs.push(`手机号码不能重复`);
  312. if (megs.length != 0) {
  313. this.setData({ errorShow: true, megs, submitLock: false });
  314. return false;
  315. };
  316. data['category'] = 1;
  317. // 申请贷款期限 不用传
  318. delete data['maturity'];
  319. await wx.$request({ method: "put", url: `/order/${key}/`, data });
  320. this.setData({ submitLock: false });
  321. Dialog.alert({ message: "已提交!" }).then(res => wx.reLaunch({ url: '/pages/index/index' }))
  322. } catch (err) { wx.$err(err) }
  323. },
  324. // 输入
  325. inputFunc (e) {
  326. let { value } = this.data, { index } = e.currentTarget.dataset;
  327. value[index[0]][index[1]]['value'] = e.detail.value;
  328. this.setData({ value })
  329. },
  330. // switch
  331. switchFunc (e) {
  332. let { value, switchs } = this.data, { index } = e.currentTarget.dataset;
  333. let { name } = value[index[0]][index[1]];
  334. if (switchs.hasOwnProperty(name)) {
  335. this.setData({ switchB: true, active: name, activeIndex: index })
  336. }
  337. },
  338. // 隐藏单选框
  339. hideModal () { this.setData({ switchB: false }) },
  340. // 单选框赋值
  341. changeFunc (e) {
  342. let { activeIndex, value, switchs } = this.data;
  343. let _value = e.detail.value.split(",");
  344. value[activeIndex[0]][activeIndex[1]]['value'] = _value[0] * 1;
  345. value[activeIndex[0]][activeIndex[1]]['index'] = _value[1] * 1;
  346. // 申请贷款产品 申请贷款期限关联
  347. if (value[activeIndex[0]][activeIndex[1]]['name'] == 'laompany') {
  348. value[0][11]['value'] = switchs['laompany'][_value[1] * 1]['month'] + '个月';
  349. }
  350. // 第一借款人与申请人关系特殊处理
  351. if (value[activeIndex[0]][activeIndex[1]]['name'] == 'mstatus') {
  352. value[2][2] = {
  353. ...value[2][2], disabled: _value[0] == 1 ? true : false, value: _value[0] == 1 ? 0 : '', index: _value[0] == 1 ? 0 : ''
  354. }
  355. }
  356. if (value[activeIndex[0]][activeIndex[1]].hasOwnProperty('forlen')) {
  357. for (let i = 1; i < (value[activeIndex[0]][activeIndex[1]]['forlen'] + 1); i++) {
  358. value[activeIndex[0]][(activeIndex[1] + i)]['norequire'] = _value[0] == 0 ? false : true;
  359. }
  360. }
  361. this.setData({ value, switchB: false })
  362. },
  363. // 日期
  364. DateChange (e) {
  365. let { value } = this.data, { index } = e.currentTarget.dataset;
  366. value[index[0]][index[1]]['value'] = e.detail.value;
  367. this.setData({ value })
  368. },
  369. }
  370. })