common.js 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. import api from '@/api'
  2. import router from '../router'
  3. import { Message } from 'element-ui'
  4. import Permission from '@/utils/permissions'
  5. import showPermissionDialog from "@/utils/model/noPermission/index";
  6. export default {
  7. /**
  8. * 防抖
  9. * @param {Function} func
  10. * @param {Number} duration
  11. * @returns
  12. */
  13. debounce(func, duration = 500) {
  14. let timer;
  15. return () => {
  16. clearTimeout(timer)
  17. timer = setTimeout(func, duration)
  18. }
  19. },
  20. /**
  21. * 节流
  22. * @param {Function} func
  23. * @param {Number} delay
  24. * @returns
  25. */
  26. throttle(func, delay = 2000) {
  27. let flag = true
  28. return () => {
  29. if (!flag) return;
  30. flag = false;
  31. setTimeout(() => {
  32. func()
  33. flag = true
  34. }, delay)
  35. }
  36. },
  37. //对象转数组
  38. objectToArray(val){
  39. var data = []
  40. if (Object.keys(val).length > 0) {
  41. Object.keys(val).forEach(item => {
  42. if(val[item]){
  43. data.push(
  44. {
  45. key: item,
  46. value: val[item]
  47. }
  48. )
  49. }
  50. })
  51. } else {
  52. return []
  53. }
  54. return data
  55. },
  56. //转简单数组
  57. ArrayToArray(data){
  58. var arr = []
  59. data.forEach(item => {
  60. if (item.type == 3) {
  61. arr.push({
  62. key:item.value,
  63. value:item.searchValue.map(itemValue => {
  64. return itemValue.value
  65. })
  66. })
  67. } else {
  68. arr.push({
  69. key:item.value,
  70. value:item.searchValue.label
  71. })
  72. }
  73. })
  74. return arr
  75. },
  76. //object转字符串
  77. objectToString(val) {
  78. var data = []
  79. if (val.constructor == Object) {
  80. if (Object.keys(val).length > 0) {
  81. Object.keys(val).forEach(item => {
  82. data.push(
  83. {
  84. key: item,
  85. value: val[item]
  86. }
  87. )
  88. })
  89. } else {
  90. return ''
  91. }
  92. } else if (val.constructor == Array) {
  93. if (val.length > 0) {
  94. data = val
  95. } else {
  96. return ''
  97. }
  98. } else {
  99. return val
  100. }
  101. // 生成字符串
  102. var str = ''
  103. data.forEach(item => {
  104. var value = ''
  105. if (Array.isArray(item.value)) {
  106. value = '(' + item.value.join(' OR ') + ')'
  107. } else {
  108. if (item.value) {
  109. value = item.value
  110. } else {
  111. return
  112. }
  113. }
  114. if (str) {
  115. str = str + ' AND ' + item.key + '=' + value
  116. } else {
  117. str = str + item.key + '=' + value
  118. }
  119. })
  120. return str
  121. },
  122. /**
  123. * 获取字段列表
  124. * @param {Array} array
  125. * @param {Function} fun
  126. * @param {Object} props
  127. * @returns
  128. */
  129. getField(array, fun, props) {
  130. var type = {
  131. 'Array': '3',
  132. 'DateTime': '2',
  133. 'String': '1'
  134. }
  135. //获取规范数据
  136. var keys = []
  137. var arr = []
  138. if (props) {
  139. keys = Object.keys(props)
  140. }
  141. //获取所需要的数据
  142. var newArray = array.filter(item => {
  143. return fun(item)
  144. })
  145. if (keys.length > 0) {
  146. newArray.forEach(item => {
  147. var obj = {}
  148. keys.forEach(key => {
  149. if (key == 'type') {
  150. obj[key] = type[item[props[key]]] || item[props[key]]
  151. }else if(key == 'value' && props.value == 'value'){
  152. obj[key] = item.field
  153. }else{
  154. obj[key] = item[props[key]]
  155. }
  156. })
  157. // 过滤不需要的数据
  158. if (['id'].includes(obj.value) == false) {
  159. arr.push(obj)
  160. }
  161. })
  162. return arr;
  163. }
  164. return newArray
  165. },
  166. /**
  167. * 获取表格数据
  168. * @author zhuliu
  169. * @param {object} row 当前行数据
  170. * @param {object} field 对应的栏位
  171. * @param {String} prop 数据类型为数组对象时所需要使用的字段
  172. * @param {object} data 需要获取对应label值时的字典对象(包含数据以及配置及{data,prop})
  173. * @param {object} data.prop
  174. * @return {String} 返回值
  175. * @example
  176. * getColumnData({value:1},{type:'String',value:'value'}) //返回字符串1
  177. */
  178. getColumnData(row, field, prop, data) {
  179. if (field.type == 'Array') {
  180. if (row[field.value] && row[field.value].length > 0) {
  181. if (prop) {
  182. return row[field.value].map(item => {
  183. return item[prop]
  184. }).join('、')
  185. }
  186. return row[field.value].join('、')
  187. } else {
  188. return '--'
  189. }
  190. } else if (field.type == 'Object') {
  191. if (!row[field.value]) {
  192. return '--'
  193. }
  194. if (prop) {
  195. return row[field.value][prop]
  196. }
  197. return row[field.value].name
  198. }
  199. else {
  200. if (data) {
  201. if (data.data.constructor == Array) {
  202. var dataProp = data.prop || {
  203. label: 'label',
  204. value: 'value'
  205. }
  206. var obj = data.data.find(item => {
  207. return item[dataProp.value] == row[field.value]
  208. })
  209. if (obj) {
  210. return obj[dataProp.label]
  211. } else {
  212. return '--'
  213. }
  214. } else {
  215. return data.data[row[field.value]]
  216. }
  217. }
  218. if (row[field.value] == '0') {
  219. return '0'
  220. }
  221. return row[field.value] || '--'
  222. }
  223. },
  224. //查看图片
  225. checkViewer(guid) {
  226. if(!guid){
  227. return ''
  228. }
  229. return `/api/fileManager/downloadFile?fileId=${guid}`
  230. },
  231. //查看专利详情
  232. checkPatentDetails(patentNo,projectId) {
  233. router.push(
  234. {
  235. path: '/patentDetails/' + patentNo,
  236. query: {
  237. projectId: projectId,
  238. }
  239. }
  240. )
  241. },
  242. //查看显示栏位管理
  243. async getCustomField(type, patentObj = {}) {
  244. var params = {
  245. tableName: type,
  246. ...patentObj,
  247. }
  248. let apiItem = Object.keys(patentObj).length > 0 ? 'getTableColumns':'getCustomField'
  249. var a = []
  250. await api[apiItem](params).then((response) => {
  251. if (response.code == 200) {
  252. a = response.data.data
  253. }
  254. }).catch(error => {
  255. return []
  256. });
  257. return a
  258. },
  259. /**
  260. * 获取排序字段(sortProp:{order})
  261. * @param {Object} param0 {sort,column, prop, order,sortProp,defaultValue,multiple}
  262. * @returns
  263. */
  264. getSortData({ sort, column, prop, order, sortProp, defaultValue, multiple }) {
  265. var sortProp1 = sortProp || {
  266. "orderBy": "orderBy",
  267. "orderType": 'orderType'
  268. }
  269. if (multiple) {
  270. var sortData = sort
  271. } else {
  272. var sortData = []
  273. }
  274. if (order == null) {
  275. if (defaultValue) {
  276. this.sort = [defaultValue]
  277. }
  278. this.sort = [
  279. {
  280. "orderBy": "createTime",
  281. "orderType": 1
  282. }
  283. ]
  284. } else {
  285. var orderType = {
  286. ascending: 0,
  287. descending: 1
  288. }
  289. var params = sortData.find(item => {
  290. return item[sortProp1.orderBy] == prop
  291. })
  292. if (params) {
  293. params[sortProp1.orderType] = orderType[order]
  294. } else {
  295. params = {}
  296. params[sortProp1.orderBy] = prop
  297. params[sortProp1.orderType] = orderType[order]
  298. sortData.push(params)
  299. }
  300. }
  301. return sortData
  302. },
  303. //显示表头数据
  304. renderHeaderMethods(h, { column }, message) {
  305. var message = '点击升序'
  306. switch (column.order) {
  307. case "":
  308. message = '点击升序'
  309. break;
  310. case "ascending":
  311. message = '点击降序'
  312. break;
  313. case 'descending':
  314. message = '点击取消排序'
  315. break
  316. }
  317. return [
  318. ,
  319. h(
  320. 'el-tooltip',
  321. {
  322. props: {
  323. content: message, // 鼠标悬停时要展示的文字提示
  324. placement: 'top' // 悬停内容展示的位置
  325. }
  326. },
  327. [h('span', column.label)] // 图标
  328. )
  329. ]
  330. },
  331. /**
  332. * 跳转到导入专利界面
  333. * @param {Object} data 参数
  334. * @param {*} type 导入类型
  335. */
  336. toImportParent(data, type) {
  337. if(!(Permission.FunPermissions('xiaoshi/patentImport'))){
  338. showPermissionDialog()
  339. return false
  340. }
  341. var types = {
  342. 1: '/import',
  343. 2: '/PatentNoImport',
  344. 4: '/conditionImport'
  345. }
  346. router.push(
  347. {
  348. path: types[type],
  349. query: {
  350. ...data
  351. }
  352. }
  353. )
  354. },
  355. // 校验文件是否全部上传并处理文件的guid
  356. allUploadFile(form) {
  357. var arr =[]
  358. let allUpload = this.validFile(form.systemFileList,arr)
  359. if (allUpload) {
  360. Message.warning('文件未全部上传,请耐心等待')
  361. return false
  362. }
  363. if(form.systemFileList && form.systemFileList.length>0){
  364. form.fileGuids = form.systemFileList.map(item => {
  365. return item.guid
  366. })
  367. }else{
  368. form.fileGuids = []
  369. }
  370. },
  371. //校验文件是否全部上传
  372. validFile(data,arr) {
  373. if (data && data.length > 0) {
  374. for(var i =0;i<data.length;i++){
  375. if(data[i] && data[i].guid){
  376. arr.push(data[i].guid)
  377. }else{
  378. return true
  379. }
  380. }
  381. return false
  382. } else {
  383. return false
  384. }
  385. },
  386. //校验是否全部上传
  387. checkUploadFile(data) {
  388. if(!data){
  389. return []
  390. }
  391. var arr = []
  392. let allUpload = this.validFile(data,arr)
  393. if (allUpload) {
  394. Message.warning('文件未全部上传,请耐心等待')
  395. return false
  396. }
  397. return arr
  398. },
  399. }