{"remainingRequest":"D:\\jenkins\\workspace\\xypm-web-prod\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\xypm-web-prod\\src\\views\\StatisticalReport\\ContractChangeAccount.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\jenkins\\workspace\\xypm-web-prod\\src\\views\\StatisticalReport\\ContractChangeAccount.vue","mtime":1702930191777},{"path":"D:\\jenkins\\workspace\\xypm-web-prod\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"D:\\jenkins\\workspace\\xypm-web-prod\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xypm-web-prod\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":["//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\r\nimport req from '@/request.js'\r\nconst BigNumber = require('bignumber.js')\r\nexport default {\r\n name: 'contractChangeAccount',\r\n props: {\r\n pid: {\r\n type: String,\r\n default: '',\r\n },\r\n isShow: {\r\n type: Boolean,\r\n default: true,\r\n },\r\n alias: {\r\n type: String,\r\n default: '',\r\n },\r\n },\r\n data() {\r\n return {\r\n total: {\r\n projectInfo: {\r\n projectName: '合计',\r\n },\r\n changeType: '----',\r\n changeCode: '----',\r\n changePrice: 0,\r\n changeDate: '----',\r\n changeContent: '----',\r\n remarks: '----',\r\n },\r\n justShowSearch: this.isShow,\r\n url: '',\r\n size: 'medium',\r\n loading: false,\r\n searchForm: {\r\n projectName: '',\r\n changeCode: '',\r\n changeType: '',\r\n createTime: new Date().getFullYear(), //当前年份\r\n projectType: '', //项目类型\r\n changePrice: '',\r\n },\r\n optionYears: [], //顶部搜索年份选择数组\r\n details: {\r\n projectInfo: {},\r\n },\r\n data: [],\r\n pageResult: {\r\n page: 1,\r\n pageSize: 20,\r\n total: 0,\r\n },\r\n form: {},\r\n dialogVisible: false,\r\n AmountOptions: [\r\n {\r\n label: '小于20万',\r\n value: 'less,20',\r\n },\r\n {\r\n label: '50 ~ 100万',\r\n value: '50,100',\r\n },\r\n {\r\n label: '100 ~ 200万',\r\n value: '100,200',\r\n },\r\n {\r\n label: '200 ~ 400万',\r\n value: '200,400',\r\n },\r\n {\r\n label: '400万以上',\r\n value: 'great,400',\r\n },\r\n ],\r\n }\r\n },\r\n mounted() {\r\n this.getYear()\r\n if (this.isShow) {\r\n this.$refs.projectInfo.getProjectData()\r\n }\r\n },\r\n methods: {\r\n //获取顶部搜索的年份区间\r\n getYear() {\r\n const myDate = new Date()\r\n const startYear = 2006 //起始年份\r\n const endYear = myDate.getFullYear() //结束年份\r\n for (let i = endYear; i >= startYear; i--) {\r\n this.optionYears.push({\r\n label: i + '年',\r\n value: i,\r\n })\r\n }\r\n },\r\n handleReset() {\r\n this.searchForm.changePrice = ''\r\n this.searchForm.projectName = ''\r\n this.searchForm.changeCode = ''\r\n this.searchForm.changeType = ''\r\n this.searchForm.projectType = ''\r\n this.searchForm.createTime = ''\r\n this.searchForm.yearMonth = []\r\n this.$refs['searchForm'].resetFields()\r\n this.pageResult = {\r\n page: 1,\r\n pageSize: 20,\r\n total: 0,\r\n }\r\n this.$nextTick(() => {\r\n this.$refs.AtTable.load()\r\n })\r\n },\r\n //导出\r\n handleExport() {\r\n this.loading = true\r\n let query = []\r\n let search = {\r\n 'pm.PROJECT_NAME_': this.searchForm.projectName,\r\n change_code_: this.searchForm.changeCode,\r\n change_type_: this.searchForm.changeType,\r\n project_type_: this.searchForm.projectType,\r\n CREATE_TIME_: this.searchForm.createTime,\r\n year_month_: this.searchForm.yearMonth,\r\n change_price_: this.searchForm.changePrice,\r\n }\r\n if (!this.isShow) {\r\n search['pm.ID_'] = this.pid\r\n ;(search.purpose_ = this.searchForm.purpose),\r\n // search.change_price_=this.searchForm.changePrice,\r\n delete search.CREATE_TIME_\r\n }\r\n for (let i in search) {\r\n if (search[i]) {\r\n if (i == 'CREATE_TIME_') {\r\n query.push(\r\n {\r\n group: 'createTimeGroup',\r\n operation: 'BETWEEN',\r\n parentGroup: '',\r\n property: 'commencement_time_',\r\n relation: 'OR',\r\n value: [\r\n `${search[i]}-01-01 00:00:00`,\r\n `${search[i]}-12-31 23:59:59`,\r\n ],\r\n }\r\n // {\r\n // group: 'createTimeSubGroup',\r\n // operation: 'LESS_EQUAL',\r\n // parentGroup: 'createTimeGroup',\r\n // property: 'commencement_time_',\r\n // relation: 'AND',\r\n // value: `${search[i]}-12-31 23:59:59`,\r\n // },\r\n // {\r\n // group: 'createTimeSubGroup',\r\n // operation: 'LESS',\r\n // parentGroup: 'createTimeGroup',\r\n // property: 'PROJECT_STATUS_',\r\n // relation: 'AND',\r\n // value: '12',\r\n // }\r\n )\r\n } else if (i == 'pm.PROJECT_NAME_') {\r\n query.push({\r\n group: 'advance',\r\n operation: 'LIKE',\r\n property: i,\r\n relation: 'AND',\r\n value: search[i],\r\n })\r\n } else if (i == 'change_price_') {\r\n let arr = search[i].split(',')\r\n if (arr[0] == 'less') {\r\n query.push({\r\n group: 'advance',\r\n operation: 'LESS',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[1],\r\n })\r\n } else if (arr[0] == 'great') {\r\n query.push({\r\n group: 'advance',\r\n operation: 'GREAT',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[1],\r\n })\r\n } else {\r\n query.push(\r\n {\r\n group: 'advance',\r\n operation: 'GREAT_EQUAL',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[0],\r\n },\r\n {\r\n group: 'advance',\r\n operation: 'LESS_EQUAL',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[1],\r\n }\r\n )\r\n }\r\n } else if (i == 'year_month_') {\r\n if (search[i].length) {\r\n let lastDate = search[i][1]\r\n let str = lastDate.split('-')\r\n let year = parseInt(str[0])\r\n let month = parseInt(str[1])\r\n let date = new Date(year, month, 0).getDate()\r\n let arr = [`${search[i][0]}-01`, `${search[i][1]}-${date}`]\r\n query.push({\r\n group: 'createTimeGroup',\r\n operation: 'BETWEEN',\r\n parentGroup: '',\r\n property: 'change_date_',\r\n relation: 'OR',\r\n value: arr,\r\n })\r\n }\r\n } else {\r\n query.push({\r\n group: 'advance',\r\n operation: 'LIKE',\r\n property: i,\r\n relation: 'AND',\r\n value: search[i],\r\n })\r\n }\r\n }\r\n }\r\n let param = {\r\n pageBean: {\r\n page: 1,\r\n pageSize: -1,\r\n showTotal: true,\r\n },\r\n\r\n querys: query,\r\n sorter: [],\r\n }\r\n req\r\n .downloadPostCopy(\r\n '${cqxy}/biz/processManagement/changeManagement/v1/exportDataToExcel',\r\n param\r\n )\r\n .then((res) => {\r\n if (res.status == 200) {\r\n this.loading = false\r\n this.$message.success('导出成功')\r\n } else {\r\n this.loading = false\r\n this.$message.error('导出失败')\r\n }\r\n })\r\n },\r\n //查询\r\n handleSearch() {\r\n this.$refs.AtTable.load()\r\n },\r\n handleRowDBClick(data) {\r\n this.dialogVisible = true\r\n this.details = data\r\n },\r\n\r\n handleSelect(selection) {},\r\n loadData(param, cb) {\r\n let query = []\r\n let search = {\r\n 'pm.PROJECT_NAME_': this.searchForm.projectName,\r\n change_code_: this.searchForm.changeCode,\r\n change_type_: this.searchForm.changeType,\r\n project_type_: this.searchForm.projectType,\r\n CREATE_TIME_: this.searchForm.createTime,\r\n year_month_: this.searchForm.yearMonth,\r\n change_price_: this.searchForm.changePrice,\r\n }\r\n if (!this.isShow) {\r\n search['pm.ID_'] = this.pid\r\n // search.change_price_=this.searchForm.changePrice,\r\n ;(search.purpose_ = this.searchForm.purpose), delete search.CREATE_TIME_\r\n }\r\n for (let i in search) {\r\n if (search[i]) {\r\n if (i == 'CREATE_TIME_') {\r\n query.push(\r\n {\r\n group: 'createTimeGroup',\r\n operation: 'BETWEEN',\r\n parentGroup: '',\r\n property: 'commencement_time_',\r\n relation: 'OR',\r\n value: [\r\n `${search[i]}-01-01 00:00:00`,\r\n `${search[i]}-12-31 23:59:59`,\r\n ],\r\n }\r\n // {\r\n // group: 'createTimeSubGroup',\r\n // operation: 'LESS_EQUAL',\r\n // parentGroup: 'createTimeGroup',\r\n // property: 'commencement_time_',\r\n // relation: 'AND',\r\n // value: `${search[i]}-12-31 23:59:59`,\r\n // },\r\n // {\r\n // group: 'createTimeSubGroup',\r\n // operation: 'LESS',\r\n // parentGroup: 'createTimeGroup',\r\n // property: 'PROJECT_STATUS_',\r\n // relation: 'AND',\r\n // value: '12',\r\n // }\r\n )\r\n } else if (i == 'pm.PROJECT_NAME_') {\r\n query.push({\r\n group: 'advance',\r\n operation: 'LIKE',\r\n property: i,\r\n relation: 'AND',\r\n value: search[i],\r\n })\r\n } else if (i == 'change_price_') {\r\n let arr = search[i].split(',')\r\n if (arr[0] == 'less') {\r\n query.push({\r\n group: 'advance',\r\n operation: 'LESS',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[1],\r\n })\r\n } else if (arr[0] == 'great') {\r\n query.push({\r\n group: 'advance',\r\n operation: 'GREAT',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[1],\r\n })\r\n } else {\r\n query.push(\r\n {\r\n group: 'advance',\r\n operation: 'GREAT_EQUAL',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[0],\r\n },\r\n {\r\n group: 'advance',\r\n operation: 'LESS_EQUAL',\r\n property: i,\r\n relation: 'AND',\r\n value: arr[1],\r\n }\r\n )\r\n }\r\n } else if (i == 'year_month_') {\r\n if (search[i].length) {\r\n let lastDate = search[i][1]\r\n let str = lastDate.split('-')\r\n let year = parseInt(str[0])\r\n let month = parseInt(str[1])\r\n let date = new Date(year, month, 0).getDate()\r\n let arr = [`${search[i][0]}-01`, `${search[i][1]}-${date}`]\r\n query.push({\r\n group: 'createTimeGroup',\r\n operation: 'BETWEEN',\r\n parentGroup: '',\r\n property: 'change_date_',\r\n relation: 'OR',\r\n value: arr,\r\n })\r\n }\r\n } else {\r\n query.push({\r\n group: 'advance',\r\n operation: 'EQUAL',\r\n property: i,\r\n relation: 'AND',\r\n value: search[i],\r\n })\r\n }\r\n }\r\n }\r\n if (param.querys && param.querys.length) {\r\n param.querys.push(...query)\r\n } else {\r\n param.querys = query\r\n }\r\n this.$http\r\n .post('${cqxy}/biz/processManagement/changeManagement/v1/page', param)\r\n .then(\r\n (resp) => {\r\n let response = resp.data.value\r\n let data = response.rows\r\n let total = this.calculationTotal(data, 'changePrice')\r\n this.total.changePrice = total\r\n if (data.length !== 0) {\r\n data.push(this.total)\r\n }\r\n this.data = data\r\n this.pageResult = {\r\n page: response.page,\r\n pageSize: response.pageSize,\r\n total: response.total,\r\n }\r\n },\r\n (error) => {\r\n reject(error)\r\n }\r\n )\r\n .finally(() => cb())\r\n },\r\n // 计算列表合同金额合计金额\r\n calculationTotal(data, key) {\r\n let total = new BigNumber(0)\r\n if (key && data && data.length !== 0) {\r\n data.forEach((item) => {\r\n if (item[key]) {\r\n total = total.plus(item[key])\r\n } else {\r\n total = total.plus(0)\r\n }\r\n })\r\n }\r\n return this.moneyFormatter(total)\r\n },\r\n cellClassNameFn(row) {\r\n // 列表项目名称为【合计】隐藏复选框\r\n if (row.row.projectInfo.projectName === '合计') {\r\n return 'table-column-hidden'\r\n }\r\n },\r\n },\r\n}\r\n",null]}