tool.js 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247
  1. import moment from 'moment'
  2. import { getToken } from './request'
  3. import { GlobalConstant } from '@/constant'
  4. import DictCache from '@/utils/dict'
  5. import {
  6. message
  7. } from 'ant-design-vue'
  8. const BaseTool = {}
  9. BaseTool.Constant = {
  10. labelCol: {
  11. xs: { span: 24 },
  12. sm: { span: 8 } // 2的倍数
  13. },
  14. labelCol2: {
  15. xs: { span: 4 },
  16. sm: { span: 4 } // 2的倍数
  17. },
  18. labelCol3: {
  19. xs: { span: 6 },
  20. sm: { span: 6 } // 2的倍数
  21. },
  22. wrapperCol: {
  23. xs: { span: 24 },
  24. sm: { span: 13 }
  25. },
  26. wrapperCol2: {
  27. xs: { span: 18 },
  28. sm: { span: 18 }
  29. },
  30. wrapperCol3: {
  31. xs: { span: 24 },
  32. sm: { span: 15 }
  33. },
  34. row: {
  35. gutter: 16
  36. },
  37. INVEST: 'INVEST',
  38. FINANCE: 'FINANCE',
  39. FINANCING: 'FINANCING',
  40. FILE_URL: '',
  41. HOST: window.location.protocol + '//' + window.location.host,
  42. scrollY: document.documentElement.clientHeight < 680 ? document.documentElement.clientHeight * 0.4 : document.documentElement.clientHeight * 0.5
  43. }
  44. // 时间对象
  45. BaseTool.Moment = moment
  46. BaseTool.Date = {
  47. PICKER_NORM_YEAR: 'YYYY',
  48. PICKER_NORM_MONTH: 'MM',
  49. PICKER_NORM_MONTH_ONE: 'M',
  50. PICKER_NORM_DAY: 'DD',
  51. PICKER_NORM_DAY_ONE: 'D',
  52. PICKER_NORM_YEAR_MONTH: 'YYYY-MM',
  53. PICKER_NORM_DATE_PATTERN: 'YYYY-MM-DD',
  54. PICKER_NORM_DATE_PATTERN_CHINESE: 'YYYY年MM月DD日',
  55. PICKER_NORM_TIME_PATTERN: 'HH:mm:ss',
  56. PICKER_NORM_DATETIME_PATTERN: 'YYYY-MM-DD HH:mm:ss',
  57. PICKER_NORM_DATETIME_PATTERN2: 'YYYY-MM-DD HH:mm',
  58. PICKER_NORM_DATETIME_PATTERN_CHINESE: 'YYYY年MM月DD日 HH:mm:ss',
  59. /**
  60. * 将字符串日期格式化
  61. * @param date
  62. * @param pattern
  63. * @returns {string}
  64. */
  65. formatter (date, pattern) {
  66. if (BaseTool.Object.isBlank(date)) {
  67. return ''
  68. } else {
  69. return BaseTool.Moment(date, BaseTool.Date.PICKER_NORM_DATETIME_PATTERN).format(pattern)
  70. }
  71. },
  72. getCountBetween (date1, date2, type = 1) {
  73. const startTime = new Date(date1) // 开始时间
  74. const endTime = new Date(date2) // 结束时间
  75. const usedTime = endTime - startTime // 相差的毫秒数
  76. const days = Math.floor(usedTime / (24 * 3600 * 1000)) // 计算出天数
  77. const leavel = usedTime % (24 * 3600 * 1000) // 计算天数后剩余的时间
  78. const hours = Math.floor(leavel / (3600 * 1000)) // 计算剩余的小时数
  79. const leavel2 = leavel % (3600 * 1000) // 计算剩余小时后剩余的毫秒数
  80. const minutes = Math.floor(leavel2 / (60 * 1000)) // 计算剩余的分钟数
  81. if (type === 1) {
  82. return days
  83. }
  84. if (type === 2) {
  85. return hours
  86. }
  87. if (type === 3) {
  88. return minutes
  89. }
  90. }
  91. }
  92. BaseTool.String = {
  93. isBlank (text) {
  94. return text === null || text === undefined || text === 'undefined' || text === ''
  95. },
  96. isNotBlank (text) {
  97. return !this.isBlank(text)
  98. },
  99. uuid () {
  100. const s = []
  101. const hexDigits = '0123456789abcdef'
  102. for (let i = 0; i < 36; i++) {
  103. s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1)
  104. }
  105. s[14] = '4' // bits 12-15 of the time_hi_and_version field to 0010
  106. s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1) // bits 6-7 of the clock_seq_hi_and_reserved to 01
  107. // s[8] = s[13] = s[18] = s[23] = '-'
  108. s[8] = s[13] = s[18] = s[23] = ''
  109. const uuid = s.join('')
  110. return uuid
  111. }
  112. }
  113. BaseTool.Object = {
  114. isBlank (text) {
  115. if (typeof text === 'string') {
  116. return BaseTool.String.isBlank(text)
  117. }
  118. return text === null || text === undefined
  119. },
  120. isNotBlank (text) {
  121. return !this.isBlank(text)
  122. },
  123. /**
  124. * 获取对象属性
  125. * @param obj
  126. * @param field
  127. * @returns {*}
  128. */
  129. getField (obj, field) {
  130. if (BaseTool.String.isBlank(obj) || BaseTool.String.isBlank(field)) {
  131. return ''
  132. }
  133. return obj[field]
  134. },
  135. /**
  136. * 深克隆
  137. * @param data
  138. * @returns {{}|any}
  139. */
  140. copy: function (data) {
  141. if (BaseTool.Object.isBlank(data)) {
  142. return {}
  143. }
  144. return JSON.parse(JSON.stringify(data))
  145. }
  146. }
  147. BaseTool.Table = {
  148. defaultOptions (that) {
  149. return {
  150. alert: { show: true, clear: () => { that.selectedRowKeys = [] } },
  151. rowSelection: {
  152. selectedRowKeys: that.selectedRowKeys,
  153. onChange: that.onSelectChange
  154. }
  155. }
  156. },
  157. tableOption (that) {
  158. if (!that.optionAlertShow) {
  159. that.options = {
  160. alert: { show: true, clear: () => { that.selectedRowKeys = [] } },
  161. rowSelection: {
  162. selectedRowKeys: that.selectedRowKeys,
  163. onChange: that.onSelectChange,
  164. getCheckboxProps: record => ({
  165. props: {
  166. disabled: false,
  167. name: record.id
  168. }
  169. })
  170. }
  171. }
  172. that.optionAlertShow = true
  173. } else {
  174. that.options = {
  175. alert: false,
  176. rowSelection: null
  177. }
  178. that.optionAlertShow = false
  179. }
  180. },
  181. getMapText (obj, field) {
  182. if (BaseTool.String.isBlank(obj) || BaseTool.String.isBlank(field)) {
  183. return ''
  184. }
  185. return obj[field]
  186. },
  187. getMapTextForMoneyType (obj, field) {
  188. if (BaseTool.String.isBlank(obj) || BaseTool.String.isBlank(field)) {
  189. return ''
  190. }
  191. return '(币种:' + obj[field] + ')'
  192. },
  193. colSpan (value, col) {
  194. return {
  195. children: value,
  196. attrs: {
  197. colSpan: col
  198. }
  199. }
  200. },
  201. rowSpan (value, row) {
  202. return {
  203. children: value,
  204. attrs: {
  205. rowSpan: row
  206. }
  207. }
  208. },
  209. rowSpanDiv (value, row) {
  210. return {
  211. children: BaseTool.Amount.formatter(BaseTool.Number.div(value, 10000, 4)),
  212. attrs: {
  213. rowSpan: row
  214. }
  215. }
  216. },
  217. allSpan (value, col, row) {
  218. return {
  219. children: value,
  220. attrs: {
  221. colSpan: col,
  222. rowSpan: row
  223. }
  224. }
  225. },
  226. statusCustomRender (vm, text, record, type) {
  227. if (BaseTool.Object.isBlank(text)) {
  228. return ''
  229. }
  230. const label = DictCache.getLabelByValue(DictCache.TYPE[type], text)
  231. const status1 = DictCache.COLOR[type][text]
  232. const myProps = { status: status1, text: label }
  233. return vm.$createElement('Badge', { ...{ props: { ...myProps } } })
  234. },
  235. statusCustomRenderWhether (vm, text) {
  236. if (BaseTool.Object.isBlank(text)) {
  237. return vm.$createElement('Badge', { ...{ props: { status: 'error', text: '否' } } })
  238. }
  239. const label = text ? '是' : '否'
  240. const status1 = text ? 'success' : 'error'
  241. const myProps = { status: status1, text: label }
  242. return vm.$createElement('Badge', { ...{ props: { ...myProps } } })
  243. },
  244. statusCustomRenderDict (vm, text, record, colorMap, dictMap) {
  245. if (BaseTool.Object.isBlank(text)) {
  246. return ''
  247. }
  248. const label = dictMap[text]
  249. const status1 = colorMap[text]
  250. const myProps = { status: status1, text: label }
  251. return vm.$createElement('Badge', { ...{ props: { ...myProps } } })
  252. },
  253. statusCustomRenderTypeDict (vm, text, record, type, dictMap) {
  254. if (BaseTool.Object.isBlank(text)) {
  255. return ''
  256. }
  257. const label = dictMap[text]
  258. const status1 = DictCache.COLOR[type][text]
  259. const myProps = { status: status1, text: label }
  260. return vm.$createElement('Badge', { ...{ props: { ...myProps } } })
  261. },
  262. statusCustomRenderFun (vm, fun) {
  263. const myProps = fun()
  264. return vm.$createElement('Badge', { ...{ props: { ...myProps } } })
  265. },
  266. customRenderWidth: (vm, text, width) => {
  267. const content = {
  268. content: props => vm.$createElement('div', text)
  269. }
  270. const textDom = vm.$createElement('div', {
  271. style: {
  272. maxWidth: width + ' !important',
  273. overflow: 'hidden',
  274. whiteSpace: 'nowrap',
  275. textOverflow: 'ellipsis',
  276. cursor: 'pointer'
  277. }
  278. }, text)
  279. return vm.$createElement('a-popover', { scopedSlots: content, attrs: { placement: 'top' } }, [textDom])
  280. },
  281. customRenderWidthDefault: (vm, text) => {
  282. return BaseTool.Table.customRenderWidth(vm, text, '150px')
  283. },
  284. customCellWidth: (text, width) => {
  285. return {
  286. attrs: {
  287. title: text
  288. },
  289. style: {
  290. maxWidth: width + ' !important',
  291. overflow: 'hidden',
  292. whiteSpace: 'nowrap',
  293. textOverflow: 'ellipsis',
  294. cursor: 'pointer'
  295. }
  296. }
  297. },
  298. customCellDefault: (text) => {
  299. return BaseTool.Table.customCellWidth(text, '150px')
  300. },
  301. customRenderDictValue (vm, text, record, dictMap) {
  302. if (BaseTool.Object.isBlank(text)) {
  303. return ''
  304. }
  305. return dictMap[text]
  306. },
  307. customRenderMultiDictValue (vm, text, record, dictMap) {
  308. if (BaseTool.Object.isBlank(text)) {
  309. return ''
  310. }
  311. const values = text.split(',')
  312. const texts = new Array()
  313. values.forEach((item, index, array) => {
  314. texts.push(dictMap[item])
  315. })
  316. return texts.join(',')
  317. }
  318. }
  319. BaseTool.ListForm = {
  320. clearOneList: (vm) => {
  321. vm.$store.dispatch('setOneListAdd', [])
  322. vm.$store.dispatch('setOneListUpdate', [])
  323. vm.$store.dispatch('setOneListDelete', [])
  324. },
  325. setOneListValues: (vm, values) => {
  326. values.updateList = vm.$store.getters.oneListUpdate
  327. values.deleteList = vm.$store.getters.oneListDelete
  328. values.addList = vm.$store.getters.oneListAdd
  329. console.log(values.addList)
  330. },
  331. setTwoListValues: (vm, values, id) => {
  332. values.updateList = vm.$store.getters.twoListUpdate[id]
  333. values.deleteList = vm.$store.getters.twoListDelete[id]
  334. values.addList = vm.$store.getters.twoListAdd[id]
  335. // values.addList = addList
  336. // // 将删除表里面排除 删除后又添加进来的 适用于同一个明细的 比如采购申请 采购单 合同登
  337. // const addListMap = {}
  338. // if (addList) {
  339. // addList.forEach((item) => {
  340. // addListMap[item.id] = item
  341. // })
  342. // }
  343. // const result = []
  344. // if (deleteList) {
  345. // deleteList.forEach((item) => {
  346. // const elem = addListMap[item.id]
  347. // if (!elem) {
  348. // result.push(item)
  349. // }
  350. // })
  351. // }
  352. // values.deleteList = result
  353. },
  354. pushOneListAdd: (vm, item) => {
  355. if (!item.exist) {
  356. const oneListAdd = vm.$store.getters.oneListAdd
  357. oneListAdd.push(item)
  358. vm.$store.dispatch('setOneListAdd', oneListAdd)
  359. }
  360. },
  361. pushOneListAddMore: (vm, items) => {
  362. const oneListAdd = vm.$store.getters.oneListAdd
  363. const addListMap = {}
  364. oneListAdd.forEach((item) => {
  365. addListMap[item.id] = item
  366. })
  367. items.forEach((item) => {
  368. if (!item.exist) {
  369. const elem = addListMap[item.id]
  370. if (!elem) {
  371. oneListAdd.push(item)
  372. }
  373. }
  374. })
  375. vm.$store.dispatch('setOneListAdd', oneListAdd)
  376. },
  377. pushOneListAddMoreForEdit: (vm, items, id) => {
  378. const oneListAdd = vm.$store.getters.oneListAdd
  379. const addListMap = {}
  380. oneListAdd.forEach((item) => {
  381. addListMap[item[id]] = item
  382. })
  383. items.forEach((item) => {
  384. if (!item.exist) {
  385. const elem = addListMap[item[id]]
  386. if (!elem) {
  387. oneListAdd.push(item)
  388. }
  389. }
  390. })
  391. console.log(oneListAdd)
  392. vm.$store.dispatch('setOneListAdd', oneListAdd)
  393. },
  394. pushTwoListAddMore: (vm, items, id) => {
  395. const twoListAddMap = vm.$store.getters.twoListAdd
  396. let twoListAdd = twoListAddMap[id]
  397. const addListMap = {}
  398. if (twoListAdd) {
  399. twoListAdd.forEach((item) => {
  400. addListMap[item.id] = item
  401. })
  402. } else {
  403. twoListAdd = []
  404. }
  405. items.forEach((item) => {
  406. if (!item.exist) {
  407. const elem = addListMap[item.id]
  408. if (!elem) {
  409. twoListAdd.push(item)
  410. }
  411. }
  412. })
  413. twoListAddMap[id] = twoListAdd
  414. vm.$store.dispatch('setTwoListAdd', twoListAddMap)
  415. },
  416. pushOneListUpdate: (vm, item) => {
  417. const oneListAdd = vm.$store.getters.oneListAdd
  418. let flag = true
  419. for (let i = 0; i < oneListAdd.length; i++) {
  420. const value = oneListAdd[i]
  421. if (item.id === value.id) {
  422. oneListAdd[i] = item
  423. flag = false
  424. }
  425. }
  426. if (!flag) {
  427. vm.$store.dispatch('setOneListAdd', oneListAdd)
  428. } else {
  429. const oneListUpdate = vm.$store.getters.oneListUpdate
  430. const updateListMap = {}
  431. oneListUpdate.forEach((item) => {
  432. updateListMap[item.id] = item
  433. })
  434. const elem = updateListMap[item.id]
  435. if (!elem) {
  436. oneListUpdate.push(item)
  437. } else {
  438. for (let i = 0; i < oneListUpdate.length; i++) {
  439. const one = oneListUpdate[i]
  440. if (one.id === item.id) {
  441. oneListUpdate[i] = item
  442. break
  443. }
  444. }
  445. }
  446. vm.$store.dispatch('setOneListUpdate', oneListUpdate)
  447. }
  448. },
  449. pushOneListDelete: (vm, items) => {
  450. const oneListDelete = vm.$store.getters.oneListDelete
  451. const oneListDeleteMap = {}
  452. items.forEach((item) => {
  453. oneListDelete.push(item)
  454. oneListDeleteMap[item.id] = item
  455. })
  456. vm.$store.dispatch('setOneListDelete', oneListDelete)
  457. const oneListAdd = vm.$store.getters.oneListAdd
  458. const result = []
  459. oneListAdd.forEach((item) => {
  460. const elem = oneListDeleteMap[item.id]
  461. if (!elem) {
  462. result.push(item)
  463. }
  464. })
  465. vm.$store.dispatch('setOneListAdd', result)
  466. },
  467. clearTwoList: (vm) => {
  468. vm.$store.dispatch('setTwoListAdd', {})
  469. vm.$store.dispatch('setTwoListUpdate', {})
  470. vm.$store.dispatch('setTwoListDelete', {})
  471. },
  472. initTwoList: (vm, id) => {
  473. console.log(id)
  474. const twoListAddMap = vm.$store.getters.twoListAdd
  475. const twoListAdd = twoListAddMap[id]
  476. if (!twoListAdd) {
  477. twoListAddMap[id] = []
  478. }
  479. vm.$store.dispatch('setTwoListAdd', twoListAddMap)
  480. const twoListUpdateMap = vm.$store.getters.twoListUpdate
  481. const twoListUpdate = twoListUpdateMap[id]
  482. if (!twoListUpdate) {
  483. twoListUpdateMap[id] = []
  484. }
  485. vm.$store.dispatch('setTwoListUpdate', twoListUpdateMap)
  486. const twoListDeleteMap = vm.$store.getters.twoListDelete
  487. const twoListDelete = twoListDeleteMap[id]
  488. if (!twoListDelete) {
  489. twoListDeleteMap[id] = []
  490. }
  491. vm.$store.dispatch('setTwoListDelete', twoListDeleteMap)
  492. },
  493. pushTwoListAdd: (vm, item, id) => {
  494. const twoListAddMap = vm.$store.getters.twoListAdd
  495. const twoListAdd = twoListAddMap[id]
  496. twoListAdd.push(item)
  497. twoListAddMap[id] = twoListAdd
  498. vm.$store.dispatch('setTwoListAdd', twoListAddMap)
  499. },
  500. pushTwoListUpdate: (vm, item, id) => {
  501. const twoListAddMap = vm.$store.getters.twoListAdd
  502. const twoListAdd = twoListAddMap[id]
  503. let flag = true
  504. for (let i = 0; i < twoListAdd.length; i++) {
  505. const value = twoListAdd[i]
  506. if (item.id === value.id) {
  507. twoListAdd[i] = item
  508. flag = false
  509. }
  510. }
  511. if (!flag) {
  512. twoListAddMap[id] = twoListAdd
  513. vm.$store.dispatch('setTwoListAdd', twoListAddMap)
  514. } else {
  515. const twoListUpdateMap = vm.$store.getters.twoListUpdate
  516. const twoListUpdate = twoListUpdateMap[id]
  517. const updateListMap = {}
  518. twoListUpdate.forEach((item) => {
  519. updateListMap[item.id] = item
  520. })
  521. const elem = updateListMap[item.id]
  522. if (!elem) {
  523. twoListUpdate.push(item)
  524. twoListUpdateMap[id] = twoListUpdate
  525. vm.$store.dispatch('setTwoListUpdate', twoListUpdateMap)
  526. }
  527. }
  528. },
  529. pushTwoListDelete: (vm, items, id) => {
  530. const twoListDeleteMap = vm.$store.getters.twoListDelete
  531. let twoListDelete = twoListDeleteMap[id]
  532. if (!twoListDelete) {
  533. twoListDelete = []
  534. }
  535. const listDeleteMap = {}
  536. items.forEach((item) => {
  537. twoListDelete.push(item)
  538. listDeleteMap[item.id] = item
  539. })
  540. twoListDeleteMap[id] = twoListDelete
  541. vm.$store.dispatch('setTwoListDelete', twoListDeleteMap)
  542. const twoListAddMap = vm.$store.getters.twoListAdd
  543. const twoListAdd = twoListAddMap[id]
  544. const result = []
  545. if (twoListAdd) {
  546. twoListAdd.forEach((item) => {
  547. const elem = listDeleteMap[item.id]
  548. if (!elem) {
  549. result.push(item)
  550. }
  551. })
  552. }
  553. twoListAddMap[id] = result
  554. vm.$store.dispatch('setTwoListAdd', twoListAddMap)
  555. },
  556. getOneListHandledRows: (vm, rows) => {
  557. const oneListAdd = vm.$store.getters.oneListAdd
  558. const oneListUpdate = vm.$store.getters.oneListUpdate
  559. const oneListUpdateMap = {}
  560. oneListUpdate.forEach((item) => {
  561. oneListUpdateMap[item.id] = item
  562. })
  563. const oneListDelete = vm.$store.getters.oneListDelete
  564. const oneListDeleteMap = {}
  565. oneListDelete.forEach((item) => {
  566. oneListDeleteMap[item.id] = item
  567. })
  568. const result = []
  569. rows.forEach((item) => {
  570. item.exist = 1
  571. const id = item.id
  572. let elem = oneListDeleteMap[id]
  573. if (!elem) {
  574. elem = oneListUpdateMap[id]
  575. if (elem) {
  576. result.push(elem)
  577. } else {
  578. result.push(item)
  579. }
  580. }
  581. })
  582. const resultMap = {}
  583. result.forEach((item) => {
  584. resultMap[item.id] = item
  585. })
  586. oneListAdd.forEach((item) => {
  587. const elem = resultMap[item.id]
  588. if (!elem) {
  589. result.splice(0, 0, item)
  590. }
  591. })
  592. return result
  593. },
  594. getOneListHandledRowsForEdit: (vm, rows, id) => {
  595. const oneListDelete = vm.$store.getters.oneListDelete
  596. const oneListDeleteMap = {}
  597. oneListDelete.forEach((item) => {
  598. oneListDeleteMap[item[id]] = item
  599. })
  600. const result = []
  601. const resultMap = {}
  602. rows.forEach((item) => {
  603. const i = item[id]
  604. const elem = oneListDeleteMap[i]
  605. if (!elem) {
  606. resultMap[i] = item
  607. result.push(item)
  608. }
  609. })
  610. const oneListAdd = vm.$store.getters.oneListAdd
  611. oneListAdd.forEach((item) => {
  612. const elem = resultMap[item[id]]
  613. if (!elem) {
  614. result.splice(0, 0, item)
  615. resultMap[item[id]] = item
  616. }
  617. })
  618. // rows.forEach((item) => {
  619. // const elem = resultMap[item[id]]
  620. // if (!elem) {
  621. // result.push(item)
  622. // }
  623. // })
  624. return result
  625. },
  626. getTwoListHandledRows: (vm, rows, id) => {
  627. const twoListAdd = vm.$store.getters.twoListAdd[id]
  628. const twoListUpdate = vm.$store.getters.twoListUpdate[id]
  629. const twoListUpdateMap = {}
  630. if (twoListUpdate) {
  631. twoListUpdate.forEach((item) => {
  632. twoListUpdateMap[item.id] = item
  633. })
  634. }
  635. const twoListDelete = vm.$store.getters.twoListDelete[id]
  636. const twoListDeleteMap = {}
  637. if (twoListDelete) {
  638. twoListDelete.forEach((item) => {
  639. twoListDeleteMap[item.id] = item
  640. })
  641. }
  642. const result = []
  643. rows.forEach((item) => {
  644. item.exist = 1
  645. const id = item.id
  646. let elem = twoListDeleteMap[id]
  647. if (!elem) {
  648. elem = twoListUpdateMap[id]
  649. if (elem) {
  650. result.push(elem)
  651. } else {
  652. result.push(item)
  653. }
  654. }
  655. })
  656. const resultMap = {}
  657. result.forEach((item) => {
  658. resultMap[item.id] = item
  659. })
  660. if (twoListAdd) {
  661. twoListAdd.forEach((item) => {
  662. const elem = resultMap[item.id]
  663. if (!elem) {
  664. result.splice(0, 0, item)
  665. }
  666. })
  667. }
  668. return result
  669. }
  670. }
  671. BaseTool.Amount = {
  672. /**
  673. * 元换算为万元
  674. * @param num :
  675. * @returns {number} :
  676. */
  677. divTenThousand (num) {
  678. if (num == null) {
  679. return 0
  680. }
  681. return BaseTool.Number.div(num, 10000, 3)
  682. // return num
  683. },
  684. /**
  685. * 元换算为万元,并格式化
  686. * @param num :
  687. * @returns {string} :
  688. */
  689. divTenThousandFormatter (num) {
  690. if (BaseTool.String.isBlank(num)) {
  691. return num
  692. }
  693. return this.formatter(this.divTenThousand(num))
  694. },
  695. /**
  696. * 格式化金额
  697. * @param value
  698. * @returns {string}
  699. */
  700. formatter: value => {
  701. if (BaseTool.String.isBlank(value)) {
  702. return value
  703. }
  704. return `${value}`.replace(/\B(?=(\d{3})+(?!\d))/g, ',')
  705. },
  706. /**
  707. * 格式化利率
  708. * @param value
  709. * @returns {string|*}
  710. */
  711. formatterRate: value => {
  712. if (BaseTool.String.isBlank(value)) {
  713. return value
  714. }
  715. return value + '%'
  716. },
  717. /**
  718. * 去掉格式化金额
  719. * @param value
  720. * @returns {*}
  721. */
  722. parser: value => value.replace(/\$\s?|(,*)/g, ''),
  723. /**
  724. * 万元换算为元
  725. * @param num
  726. * @returns {*}
  727. */
  728. mulTenThousand (num) {
  729. if (BaseTool.String.isBlank(num)) {
  730. return 0
  731. }
  732. return BaseTool.Number.mul(num, 10000, 6)
  733. // return num
  734. },
  735. /**
  736. * 元换算为万元,并格式化
  737. * @param num :
  738. * @returns {string} :
  739. */
  740. default (value) {
  741. if (BaseTool.String.isBlank(value) || value === 0) {
  742. return '0.00'
  743. }
  744. return value
  745. },
  746. /**
  747. * 元换算为万元,并格式化
  748. * @param num :
  749. * @returns {string} :
  750. */
  751. defaultDivTenThousandFormatter (num) {
  752. if (BaseTool.String.isBlank(num) || num === 0) {
  753. return '0.00'
  754. }
  755. return this.formatter(this.divTenThousand(num))
  756. }
  757. }
  758. BaseTool.Number = {
  759. /**
  760. * 校验费率最大值是否大于100 与 小于0
  761. * 由于校验框架对值校验需要用a-input-number组件,否则是按照字符串校验
  762. * @param rule
  763. * @param value
  764. * @param callback
  765. * @param max
  766. * @param min
  767. */
  768. rateValidatorMax: (rule, value, callback) => {
  769. if (BaseTool.Object.isBlank(rule.min)) {
  770. rule.min = 0
  771. }
  772. if (BaseTool.Object.isBlank(rule.max)) {
  773. rule.max = 100
  774. }
  775. const myValue = parseFloat(value)
  776. if (myValue > rule.max) {
  777. callback(new Error(rule.messageBefore + '不能大于' + rule.max))
  778. } else if (myValue < rule.min) {
  779. callback(new Error(rule.messageBefore + '不能小于' + rule.min))
  780. } else {
  781. callback()
  782. }
  783. },
  784. numberValidatorMax: (rule, value, callback) => {
  785. const myValue = parseFloat(value)
  786. if (!BaseTool.Object.isBlank(rule.max) && myValue > rule.max) {
  787. callback(new Error(rule.messageBefore + '不能大于' + rule.max))
  788. } else if (!BaseTool.Object.isBlank(rule.min) && myValue < rule.min) {
  789. callback(new Error(rule.messageBefore + '不能小于' + rule.min))
  790. } else {
  791. callback()
  792. }
  793. },
  794. add (arg1, arg2) {
  795. if (BaseTool.String.isBlank(arg1)) {
  796. arg1 = 0
  797. }
  798. if (BaseTool.String.isBlank(arg2)) {
  799. arg2 = 0
  800. }
  801. let r1, r2
  802. try {
  803. r1 = arg1.toString().split('.')[1].length
  804. } catch (e) {
  805. r1 = 0
  806. }
  807. try {
  808. r2 = arg2.toString().split('.')[1].length
  809. } catch (e) {
  810. r2 = 0
  811. }
  812. const m = Math.pow(10, Math.max(r1, r2))
  813. const n = (r1 >= r2) ? r1 : r2
  814. return ((arg1 * m + arg2 * m) / m).toFixed(n)
  815. },
  816. sub (arg1, arg2) {
  817. if (BaseTool.String.isBlank(arg1)) {
  818. arg1 = 0
  819. }
  820. if (BaseTool.String.isBlank(arg2)) {
  821. arg2 = 0
  822. }
  823. let re1, re2
  824. try {
  825. re1 = arg1.toString().split('.')[1].length
  826. } catch (e) {
  827. re1 = 0
  828. }
  829. try {
  830. re2 = arg2.toString().split('.')[1].length
  831. } catch (e) {
  832. re2 = 0
  833. }
  834. const m = Math.pow(10, Math.max(re1, re2))
  835. const n = (re1 >= re2) ? re1 : re2
  836. return ((arg1 * m - arg2 * m) / m).toFixed(n)
  837. },
  838. mul (arg1, arg2) {
  839. if (BaseTool.String.isBlank(arg1)) {
  840. arg1 = 0
  841. }
  842. if (BaseTool.String.isBlank(arg2)) {
  843. arg2 = 0
  844. }
  845. let m = 0
  846. const s1 = arg1.toString()
  847. const s2 = arg2.toString()
  848. try {
  849. m += s1.split('.')[1].length
  850. } catch (e) {}
  851. try {
  852. m += s2.split('.')[1].length
  853. } catch (e) {}
  854. return Number(s1.replace('.', '')) * Number(s2.replace('.', '')) / Math.pow(10, m)
  855. },
  856. /**
  857. * 除法 注意如果整除了 小数点将无效
  858. * @param arg1 : 被除数
  859. * @param arg2 : 除数
  860. * @param digit :精确位数
  861. * @returns {number}
  862. */
  863. div (arg1, arg2, digit) {
  864. if (BaseTool.String.isBlank(arg1)) {
  865. arg1 = 0
  866. }
  867. if (BaseTool.String.isBlank(arg2)) {
  868. arg2 = 1
  869. }
  870. let t1 = 0
  871. let t2 = 0
  872. try { t1 = arg1.toString().split('.')[1].length } catch (e) {}
  873. try { t2 = arg2.toString().split('.')[1].length } catch (e) {}
  874. const r1 = Number(arg1.toString().replace('.', ''))
  875. const r2 = Number(arg2.toString().replace('.', ''))
  876. // 获取小数点后的计算值
  877. const result = ((r1 / r2) * Math.pow(10, t2 - t1)).toString()
  878. let result2 = result.split('.')[1]
  879. if (result2 !== undefined) {
  880. result2 = result2.substring(0, digit > result2.length ? result2.length : digit)
  881. } else {
  882. result2 = ''
  883. }
  884. while (result2.length < digit) {
  885. result2 = result2 + '0'
  886. }
  887. if (digit === 0) {
  888. return Number(result.split('.')[0])
  889. }
  890. return Number(result.split('.')[0] + '.' + result2)
  891. },
  892. /**
  893. * 除法 注意如果整除了 小数点将无效
  894. * @param arg1 : 被除数
  895. * @param arg2 : 除数
  896. * @param digit :精确位数
  897. * @returns {number}
  898. */
  899. divForDollar (arg1, arg2, digit) {
  900. return '(' + BaseTool.Amount.formatter(BaseTool.Number.div(arg1, arg2, digit)) + '美元)'
  901. }
  902. }
  903. BaseTool.UPLOAD = {
  904. /**
  905. * 上传文件校验是否为文件
  906. * @param file
  907. * @param successBack
  908. * @param errorFun
  909. * @returns {Promise<boolean>|boolean}
  910. */
  911. isFileUpload (file, successBack, errorFun) {
  912. const reg = /\.(doc|docx|pdf|zip|xls|xlsx)(\?.*)?$/
  913. if (reg.test(file.name)) {
  914. if (!BaseTool.Object.isBlank(successBack)) {
  915. successBack(file)
  916. }
  917. return true
  918. } else {
  919. if (!BaseTool.Object.isBlank(errorFun)) {
  920. errorFun()
  921. } else {
  922. message.error(`请上传正确的word、pdf、docx、zip、xls、xlsx文件`)
  923. }
  924. // reject(new Error('请上传正确的word文件或pdf文件'))
  925. return new Promise((resolve, reject) => {
  926. reject(new Error('请上传正确的word、pdf、docx、zip、xls、xlsx文件'))
  927. return false
  928. })
  929. }
  930. },
  931. /**
  932. * 上传文件校验是否为图片
  933. * @param file
  934. * @param successBack
  935. * @param errorFun
  936. * @returns {Promise<boolean>|boolean}
  937. */
  938. isImageUpload (file, successBack, errorFun) {
  939. const reg = /\.(jpeg|jpg|png|gif)(\?.*)?$/
  940. if (reg.test(file.name)) {
  941. if (!BaseTool.Object.isBlank(successBack)) {
  942. successBack(file)
  943. }
  944. return true
  945. } else {
  946. if (!BaseTool.Object.isBlank(errorFun)) {
  947. errorFun()
  948. } else {
  949. message.error(`请上传正确的图片`)
  950. }
  951. // reject(new Error('请上传正确的word文件或pdf文件'))
  952. return new Promise((resolve, reject) => {
  953. reject(new Error('请上传正确的图片'))
  954. return false
  955. })
  956. }
  957. },
  958. downLoadExportExcel (data) {
  959. const contentDistribution = data.headers['content-disposition']
  960. // attachment;filename=%E6%8A%95%E8%B5%84%E9%A1%B9%E7%9B%AE%E4%BF%A1%E6%81%AF20200202162009965.xls
  961. const fileName = decodeURI(contentDistribution.replace('attachment;filename=', ''))
  962. if (window.navigator.msSaveOrOpenBlob) {
  963. navigator.msSaveBlob(data, fileName)
  964. }
  965. const blob = new Blob([data.data])
  966. const elink = document.createElement('a')
  967. elink.download = fileName
  968. elink.style.display = 'none'
  969. elink.href = URL.createObjectURL(blob)
  970. document.body.appendChild(elink)
  971. elink.click()
  972. URL.revokeObjectURL(elink.href)// 释放 URL 对象
  973. document.body.removeChild(elink)
  974. },
  975. transImg (imgArr = []) {
  976. const temp = []
  977. if (BaseTool.Object.isBlank(imgArr)) {
  978. return temp
  979. }
  980. imgArr.forEach((item) => {
  981. if (BaseTool.String.isNotBlank(item.url)) {
  982. temp.push({
  983. url: GlobalConstant.BaseImageUrl + item.url,
  984. uid: item.id ? item.id : item.url,
  985. name: item.name,
  986. value: item
  987. })
  988. }
  989. })
  990. return temp
  991. },
  992. transImg2 (imgArr = []) {
  993. const temp = []
  994. if (BaseTool.Object.isBlank(imgArr)) {
  995. return temp
  996. }
  997. imgArr.forEach((item) => {
  998. if (BaseTool.String.isNotBlank(item.url)) {
  999. temp.push({
  1000. url: GlobalConstant.BaseImageUrl + item.url,
  1001. uid: item.id ? item.id : item.uid,
  1002. name: item.name,
  1003. value: item
  1004. })
  1005. }
  1006. })
  1007. return temp
  1008. },
  1009. filePreview (file) {
  1010. if (file.url == null) {
  1011. return
  1012. }
  1013. window.open(process.env.VUE_APP_PREVIEW_URL + BaseTool.Constant.HOST + BaseTool.Constant.FILE_URL + file.url)
  1014. },
  1015. getUploadFileDTO (fileList = [], type = Number) {
  1016. // 添加图片
  1017. const length = fileList.length
  1018. const temp = []
  1019. if (length >= 1) {
  1020. for (let i = 0; i < length; i++) {
  1021. let data = {}
  1022. if (fileList[i].response) {
  1023. data = fileList[i].response.data
  1024. } else {
  1025. data = fileList[i].value
  1026. }
  1027. const fileDTO = {}
  1028. fileDTO.type = type
  1029. fileDTO.name = data.name
  1030. fileDTO.fileName = data.fileName
  1031. fileDTO.fileFormat = data.fileFormat
  1032. fileDTO.url = data.url
  1033. // fileDTO.id = data.id || fileList[i].uid
  1034. temp.push(fileDTO)
  1035. }
  1036. }
  1037. return temp
  1038. },
  1039. getUploadOneFileDTO (file, type = Number) {
  1040. // 添加图片
  1041. const temp = []
  1042. if (file != null) {
  1043. let data = {}
  1044. if (file.response) {
  1045. data = file.response.data
  1046. } else {
  1047. data = file
  1048. }
  1049. const fileDTO = {}
  1050. fileDTO.type = type
  1051. fileDTO.name = data.name
  1052. fileDTO.fileName = data.fileName
  1053. fileDTO.fileFormat = data.fileFormat
  1054. fileDTO.url = data.url
  1055. temp.push(fileDTO)
  1056. }
  1057. return temp
  1058. },
  1059. handleFileChange ({ file, fileList }) {
  1060. const result = {}
  1061. result.defaultFileList = fileList
  1062. result.success = false
  1063. if (file.status === 'done') {
  1064. result.fileList = BaseTool.UPLOAD.getUploadFileDTO(fileList, GlobalConstant.FileTypeFile)
  1065. result.success = true
  1066. } else if (file.status === 'removed') {
  1067. result.fileList = BaseTool.UPLOAD.getUploadFileDTO(fileList, GlobalConstant.FileTypeFile)
  1068. result.success = true
  1069. } else if (file.status === 'error') {
  1070. message.error('上传失败')
  1071. }
  1072. return result
  1073. },
  1074. handleImageChange ({ file, fileList }) {
  1075. const result = {}
  1076. result.defaultImageList = fileList
  1077. result.success = false
  1078. if (file.status === 'done') {
  1079. result.imageList = BaseTool.UPLOAD.getUploadFileDTO(fileList, GlobalConstant.FileTypeImg)
  1080. result.success = true
  1081. } else if (file.status === 'removed') {
  1082. result.imageList = BaseTool.UPLOAD.getUploadFileDTO(fileList, GlobalConstant.FileTypeImg)
  1083. result.success = true
  1084. } else if (file.status === 'error') {
  1085. message.error('上传失败')
  1086. } else {
  1087. }
  1088. return result
  1089. }
  1090. }
  1091. BaseTool.Util = {
  1092. getUUID() {
  1093. var d = new Date().getTime();
  1094. var uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
  1095. var r = (d + Math.random()*16)%16 | 0;
  1096. d = Math.floor(d/16);
  1097. return (c=='x' ? r : (r&0x3|0x8)).toString(16);
  1098. });
  1099. return uuid;
  1100. },
  1101. _isMobile () {
  1102. const flag = navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)
  1103. return flag
  1104. },
  1105. getToken (url) {
  1106. return getToken(url)
  1107. },
  1108. /**
  1109. * 页面合并单元格
  1110. * @param mergeMap :合并信息对象
  1111. * @param keys :获取的key
  1112. * @returns {{}|number} :
  1113. */
  1114. getSpan (mergeMap = {}, ...keys) {
  1115. if (mergeMap == null) {
  1116. return 1
  1117. }
  1118. let map = mergeMap
  1119. for (let i = 0; i < keys.length; i++) {
  1120. if (map[keys[i]] == null) {
  1121. return 1
  1122. }
  1123. map = map[keys[i]]
  1124. }
  1125. return map
  1126. },
  1127. /**
  1128. * 根据不同类型获取行数据
  1129. * @param record :
  1130. * @param key :
  1131. * @returns {string|*}
  1132. */
  1133. getRecordText (record, key) {
  1134. let result = ''
  1135. if (record.data == null) {
  1136. return ''
  1137. }
  1138. if (record.type === 1) {
  1139. result = record.data[key]
  1140. } else {
  1141. if (record.data[key] == null) {
  1142. return ''
  1143. }
  1144. result = record.data[key]['data']
  1145. }
  1146. return result
  1147. },
  1148. /**
  1149. * 获取携带合并单元格的行数据
  1150. * @param record :
  1151. * @param key :
  1152. * @returns {{children: null, attrs: {rowSpan: ({}|number), colSpan: ({}|number)}}}
  1153. */
  1154. getCustomRender (record, key) {
  1155. const obj = {
  1156. children: null,
  1157. attrs: {
  1158. rowSpan: this.getSpan(record['mergeMap'], key, 'rowSpan'),
  1159. colSpan: this.getSpan(record['mergeMap'], key, 'cellSpan')
  1160. }
  1161. }
  1162. obj.children = this.getRecordText(record, key)
  1163. return obj
  1164. },
  1165. /**
  1166. * 获取携带合并单元格的行数据 ,并对类型进行格式化
  1167. * @param record :
  1168. * @param key :
  1169. * @param type: 1表示string 2表示格式化金额 3表示万元之后格式金额
  1170. * @returns {{children: null, attrs: {rowSpan: ({}|number), colSpan: ({}|number)}}}
  1171. */
  1172. getCustomRenderFormat (record, key, type) {
  1173. const obj = {
  1174. children: null,
  1175. attrs: {
  1176. rowSpan: this.getSpan(record['mergeMap'], key, 'rowSpan'),
  1177. colSpan: this.getSpan(record['mergeMap'], key, 'cellSpan')
  1178. }
  1179. }
  1180. let result = this.getRecordText(record, key)
  1181. if (type === 2) {
  1182. result = BaseTool.Amount.formatter(result)
  1183. }
  1184. if (type === 3) {
  1185. result = BaseTool.Amount.divTenThousandFormatter(result)
  1186. }
  1187. obj.children = result
  1188. return obj
  1189. },
  1190. getCustomRenderMultiDictValue (text, dictMap) {
  1191. if (BaseTool.Object.isBlank(text)) {
  1192. return ''
  1193. }
  1194. const values = text.split(',')
  1195. const texts = new Array()
  1196. values.forEach((item, index, array) => {
  1197. texts.push(dictMap[item])
  1198. })
  1199. return texts.join(',')
  1200. },
  1201. getCustomRenderDictValue (text, dictMap) {
  1202. if (BaseTool.Object.isBlank(text)) {
  1203. return ''
  1204. }
  1205. return dictMap[text]
  1206. }
  1207. }
  1208. BaseTool.TREE = {
  1209. treeFilter (list = [], f = (item) => { return item }) {
  1210. const r = []
  1211. list.forEach(item => {
  1212. if (item.children && item.children.length > 0) {
  1213. item.children = this.treeFilter(item.children, f)
  1214. }
  1215. const i = f(item)
  1216. if (i) {
  1217. if (!i.delete) {
  1218. r.push(i)
  1219. }
  1220. } else {
  1221. r.push(item)
  1222. }
  1223. })
  1224. return r
  1225. }
  1226. }
  1227. BaseTool.ANTD = {
  1228. selectFilterOption (input, option) {
  1229. return option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0
  1230. }
  1231. }
  1232. export default BaseTool