1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504 |
- <template>
- <a-card :bordered="false" style="overflow: hidden;">
- <!-- 查询区域 -->
- <div class="table-page-search-wrapper">
- <a-form layout="inline" @keyup.enter.native="searchQuery">
- <a-row :gutter="24">
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="任务名称">
- <a-input placeholder="请输入任务名称" v-model="queryParam.taskname"></a-input>
- </a-form-item>
- </a-col>
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="任务号">
- <a-input placeholder="请输入任务号" v-model="queryParam.taskno"></a-input>
- </a-form-item>
- </a-col>
- <template v-if="toggleSearchStatus">
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="型号">
- <a-input placeholder="请输入型号" v-model="queryParam.xhname"></a-input>
- </a-form-item>
- </a-col>
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="阶段">
- <a-input placeholder="请输入阶段" v-model="queryParam.yzjdname"></a-input>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="计划完成时间">
- <j-date placeholder="请选择计划完成时间" v-model="queryParam.jhwcsj"></j-date>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="任务类型">
- <a-input placeholder="请输入任务类型" v-model="queryParam.tasktype"></a-input>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="审计审价">
- <a-input placeholder="请输入审计审价" v-model="queryParam.auditprice"></a-input>
- </a-form-item>
- </a-col>
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="任务状态">
- <a-input placeholder="请输入任务状态" v-model="queryParam.iflag"></a-input>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="项目进度">
- <a-input placeholder="请输入项目进度" v-model="queryParam.processpercent"></a-input>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="成本进度">
- <a-input placeholder="请输入成本进度" v-model="queryParam.costPercent"></a-input>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="业务员">
- <a-input placeholder="请输入业务员" v-model="queryParam.businessman"></a-input>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="下达部门id">
- <a-input placeholder="请输入下达部门id" v-model="queryParam.jycsid"></a-input>
- </a-form-item>
- </a-col> -->
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="项目进度">
- <a-input placeholder="请输入项目进度" v-model="queryParam.processpercent"></a-input>
- </a-form-item>
- </a-col>
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="下达部门">
- <a-input placeholder="请输入下达部门" v-model="queryParam.jycs"></a-input>
- </a-form-item>
- </a-col>
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="责任部门">
- <a-input placeholder="请输入责任部门" v-model="queryParam.zrbm"></a-input>
- </a-form-item>
- </a-col>
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="批产任务号">
- <a-input placeholder="请输入批产任务号" v-model="queryParam.pccode"></a-input>
- </a-form-item>
- </a-col> -->
- <!-- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="备产任务号">
- <a-input placeholder="请输入备产任务号" v-model="queryParam.bccode"></a-input>
- </a-form-item>
- </a-col>
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <a-form-item label="备料任务号">
- <a-input placeholder="请输入备料任务号" v-model="queryParam.blcode"></a-input>
- </a-form-item>
- </a-col> -->
- </template>
- <a-col :xl="6" :lg="7" :md="8" :sm="24">
- <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
- <a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
- <a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
- <a @click="handleToggleSearch" style="margin-left: 8px">
- {{ toggleSearchStatus ? '收起' : '展开' }}
- <a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>
- </a>
- </span>
- </a-col>
- </a-row>
- </a-form>
- </div>
- <!-- 查询区域-END -->
- <!-- 操作按钮区域 -->
- <div class="table-operator">
- <!-- <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button> -->
- <a-button @click="handleExpand" type="primary" icon="column-height">折叠/展开</a-button>
- <a-button @click="handleAdd" type="primary" icon="plus">导入</a-button>
- <a-button @click="handleComputed" type="primary" icon="reconciliation">计算</a-button>
- <a-button type="primary" icon="download" @click="handleExportXls()">导出</a-button>
- <!-- <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
- <a-button type="primary" icon="import">导入</a-button>
- </a-upload> -->
- <!-- 高级查询区域 -->
- <j-super-query :fieldList="superFieldList" ref="superQueryModal" @handleSuperQuery="handleSuperQuery"></j-super-query>
- <a-button @click="batchDuiBi" :disabled="chooseStatus"><a-icon type="shrink" />比对</a-button>
- <!-- <a-dropdown v-if="selectedRowKeys.length > 0"> -->
- <!-- <a-menu slot="overlay"> -->
- <!-- <a-menu-item key="1" @click="batchDel"><a-icon type="delete"/>比对</a-menu-item> -->
- <!-- <a-menu-item key="1" @click="batchDuiBi"><a-icon type="shrink" />比对</a-menu-item>
- </a-menu>
- <a-button style="margin-left: 8px"> 批量操作 <a-icon type="down" /></a-button> -->
- <!-- </a-dropdown> -->
- </div>
- <!-- table区域-begin -->
- <div>
- <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
- <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
- <a style="margin-left: 24px" @click="onClearSelected">清空</a>
- <span style="margin-left: 40px; color: #b5b5b5;">*红色表示亏损;绿色表示加入至产品价格库;灰色表示解组批后;*</span>
- <span style="float:right;">
- <a @click="loadData()"><a-icon type="sync" />刷新</a>
- <a-divider type="vertical" />
- <a-popover title="自定义列" trigger="click" placement="leftBottom">
- <template slot="content">
- <a-checkbox-group @change="onColSettingsChange" v-model="settingColumns" :defaultValue="settingColumns">
- <a-row style="width: 400px">
- <template v-for="(item, index) in defColumns">
- <template v-if="item.key!='rowIndex'&& item.dataIndex!='action'">
- <a-col :span="12" :key="index">
- <a-checkbox :value="item.dataIndex" :disabled="!!item.fixed" :checked="!!item.fixed">
- {{ item.title }}</a-checkbox>
- </a-col>
- </template>
- </template>
- </a-row>
- </a-checkbox-group>
- </template>
- <a><a-icon type="setting" />自定义列</a>
- </a-popover>
- </span>
- </div>
-
- <a-table
- ref="table"
- size="middle"
- :scroll="{x:true,}"
- bordered
- rowKey="id"
- :columns="columns"
- :dataSource="dataSource"
- :pagination="ipagination"
- :loading="loading"
- class="j-table-force-nowrap"
- :expandedRowKeys="expandedRowKeys"
- @expand="onExpand"
- @mousedown.native="mouseDownHandler"
- @mouseup.native="mouseUpHandler"
- @mousemove.native="mouseMoveHandler"
- :rowClassName="setRowClassName"
- :rowSelection="{
- selectedRowKeys: selectedRowKeys,
- onChange: onSelectChange,
- onSelect: onSelect,
- getCheckboxProps: (record) => ({
- props: {
- //disabled: record.id == 'amount', // 禁选的条件为:合计行不可选
- disabled: record.id == 'amount' ||
- (record.ji== '1' && chooseRowType == 'huiji') ||
- (record.ji== '2' && chooseRowType == 'chengben')
- },
- }),}"
- @change="handleTableChange"
- :indentSize="12">
- <template slot="htmlSlot" slot-scope="text">
- <div v-html="text"></div>
- </template>
- <template slot="imgSlot" slot-scope="text,record">
- <span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
- <img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt="" style="max-width:80px;font-size: 12px;font-style: italic;"/>
- </template>
- <template slot="fileSlot" slot-scope="text">
- <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
- <a-button
- v-else
- :ghost="true"
- type="primary"
- icon="download"
- size="small"
- @click="downloadFile(text)">
- 下载
- </a-button>
- </template>
- <div slot="filterDropdown">
- <a-card>
- <a-checkbox-group @change="onColSettingsChange" v-model="settingColumns" :defaultValue="settingColumns">
- <a-row style="width: 400px">
- <template v-for="(item, index) in defColumns">
- <template v-if="item.key!='rowIndex'&& item.dataIndex!='action'">
- <a-col :span="12" :key="index"><a-checkbox :value="item.dataIndex">{{ item.title }}</a-checkbox></a-col>
- </template>
- </template>
- </a-row>
- </a-checkbox-group>
- </a-card>
- </div>
- <a-icon slot="filterIcon" type='setting' :style="{ fontSize:'16px',color: '#108ee9' }" />
- <!-- <span slot="contractfpe" slot-scope="text, record">
- <a-button type="link" @click.native="detailClick(text,record,'contractfpe','合同额')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{(Number(text)/10000).toFixed(2)}}</a-button>
- </span> -->
- <!-- <span slot="taskmoney" slot-scope="text, record">
- <a-button type="link" @click="detailClick(text,record,'taskmoney','已收款')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{(Number(text)/10000).toFixed(2)}}</a-button>
- </span> -->
- <!-- <span slot="clf" slot-scope="text, record">
- <a-button type="link" @click="detailClick(text,record,'clf','材料费')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{(Number(text)/10000).toFixed(2)}}</a-button>
- </span> -->
- <!-- <span slot="zyf" slot-scope="text, record">
- <a-button type="link" @click="detailClick(text,record,'zyf','专用费')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{(Number(text)/10000).toFixed(2)}}</a-button>
- </span> -->
- <!-- <span slot="swf" slot-scope="text, record">
- <a-button type="link" @click="detailClick(text,record,'swf','事务费')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{(Number(text)/10000).toFixed(2)}}</a-button>
- </span> -->
- <!-- <span slot="wxf" slot-scope="text, record">
- <a-button type="link" @click.native="detailClick(text,record,'wxf','外协费')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{(Number(text)/10000).toFixed(2)}}</a-button>
- </span>
- <span slot="zjcb" slot-scope="text, record">
- <a-button type="link" @click="detailClick(text,record,'zjcb','装机成本')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{(Number(text)/10000).toFixed(2)}}</a-button>
- </span>
- <span slot="workhour" slot-scope="text, record">
- <a-button type="link" @click="detailClick(text,record,'workhour','工时')" :style="{color: (record.children || record.id === 'amount') ? 'rgba(0,0,0,.65)' : ''}">{{text}}</a-button>
- </span> -->
-
- <span slot="action" slot-scope="text, record">
- <!-- <a @click="handleEdit(record)">编辑</a> -->
- <!-- <a-tooltip v-if="record.id !== 'amount' && record.ji === 1">
- <template slot="title">
- 汇集层无预算执行
- </template>
- <span style="color: rgba(0,0,0,.25);">预算执行</span>
- </a-tooltip> -->
- <a @click="handleXushi(record)" v-if="record.id !== 'amount'">预算执行</a>
- <!-- <a @click="handleXushi(record)" v-if="record.id !== 'amount'" :disabled="record.ji === 1">预算执行</a> -->
- <a-divider v-if="record.id !== 'amount' && record.ji === 1" type="vertical" />
- <a @click="handleAddProjectModel(record)" v-if="record.id !== 'amount' && record.ji === 1" :disabled="record.hjstatus === '4'">加入产品</a>
- <!-- <a-dropdown>
- <a class="ant-dropdown-link">更多 <a-icon type="down" /></a>
- <a-menu slot="overlay">
- <a-menu-item>
- <a @click="handleDetail(record)">详情</a>
- </a-menu-item>
- <a-menu-item>
- <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
- <a>删除</a>
- </a-popconfirm>
- </a-menu-item>
- </a-menu>
- </a-dropdown> -->
- </span>
- </a-table>
- </div>
- <project-detail-modal ref="proCostDetail"></project-detail-modal>
- <j-modal
- :width="1200"
- :visible="duiBi"
- switchFullscreen
- @cancel="handleGb">
- <a-tabs default-active-key="1">
- <a-tab-pane key="1" tab="总体比对">
- <all-list :duibiIds="duibiIds" :chooseRowType="chooseRowType"></all-list>
- <!-- <all-list :duibiList="duibiList"></all-list> -->
- </a-tab-pane>
- <a-tab-pane key="2" tab="材料费比对" force-render>
- <wuliao-list :chooseRowType="chooseRowType" :duibiTasknos="duibiTasknos" ></wuliao-list>
- <!-- <wuliao-list :duibiclList="duibiclList"></wuliao-list> -->
- </a-tab-pane>
- </a-tabs>
- <template slot="footer">
- <a-button @click="handleGb">关闭</a-button>
- </template>
- </j-modal>
- <!-- 虚实成本比对(堆叠图) -->
- <contrast-modal ref="xushi"></contrast-modal>
- <!-- 导入弹框 -->
- <project-import-list-modal ref="modalForm" @ok="modalFormOk" :isAllShow="false"></project-import-list-modal>
- </a-card>
- </template>
- <script>
- import Vue from 'vue';
- // import VueDraggableResizable from 'vue-draggable-resizable';
- // Vue.component('vue-draggable-resizable', VueDraggableResizable);
- import { columnsSelect, columnsEdit, proCostYSKdetail, proCostContractdetail, getDbList, getHjList, getDbClList, insertIntoProject, visibleClientStart } from '@/api/kzksApi.js'
- import '@/assets/less/TableExpand.less'
- import { mixinDevice } from '@/utils/mixin'
- import { JeecgListMixin } from '@/mixins/JeecgListMixin'
- import ProjectDetailModal from './modulesDetail/ProjectDetailModal'
- import AllList from '../projectContrastList/allList.vue'
- import WuliaoList from '../projectContrastList/wuliaoList.vue'
- import { getAction, downFile } from '@/api/manage'
- import ContrastModal from '../projectXushiContrast/contrastModal.vue'
- import ProjectImportListModal from '../projectImportList/modules/ProjectImportListModal.vue'
- import { number } from 'echarts';
- export default {
- name: 'ProjectCostList',
- mixins:[JeecgListMixin, mixinDevice],
- components: {
- AllList,
- WuliaoList,
- ProjectDetailModal,
- ContrastModal,
- ProjectImportListModal,
- },
- data () {
- return {
- scrollHeight: 700,
- /* 分页参数 */
- ipagination:{
- current: 1,
- pageSize: 11, // 设置a-table调用时加上筛选行
- pageSizeOptions: ['11', '21', '31'],
- showTotal: (total, range) => {
- // console.log(total, range, this.ipagination.current)
- var current = this.ipagination.current
- if(this.showListTotal){
- return (range[0] - current + 1) + "-" + (range[1] - current) + " 共" + this.showListTotal + "条"
- } else {
- return range[0] + "-" + range[1] + " 共" + total + "条"
- }
- },
- showQuickJumper: true,
- showSizeChanger: true,
- total: 0,
- // 显示时减去筛选行
- buildOptionText: (size) => {
- return new Number(size.value) - 1 + '条/页'
- }
- },
- // 用来前端显示出去筛选行的total
- showListTotal: 0,
- description: '项目成本管理页面',
- // 一键折叠/展开
- expandedRowKeys: [],
- // 是否全部展开
- isExpanded: false,
- // 获取比对级
- chooseRowType: undefined,
- // 比对状态
- chooseStatus: true,
- // 获取到的比对数据
- duibiList: {},
- // 获取到的材料费比对数据
- duibiclList: [],
- // 比对弹框是否显示
- duiBi: false,
- // 表头:当前显示的列,初始为全部
- columns: [],
- //列设置:多选弹窗显示的
- settingColumns:[],
- //列定义:所有列
- defColumns: [
- // {
- // title: '#',
- // dataIndex: '',
- // key:'rowIndex',
- // width:60,
- // align:"center",
- // customRender:function (t,r,index) {
- // return parseInt(index)+1;
- // }
- // },
- {
- title:'任务号',
- fixed:"left",
- dataIndex: 'taskno',
- width: 120,
- customHeaderCell:() => ({
- style: {
- textAlign: 'center', // 表头居中
- }
- })
- },
- {
- title:'任务名称',
- align:"center",
- fixed:"left",
- width: 120,
- dataIndex: 'taskname',
- ellipsis: true,
- },
- {
- title:'型号',
- align:"center",
- width: 120,
- dataIndex: 'xhname',
- },
- {
- title:'计划完成时间',
- align:"center",
- width: 120,
- dataIndex: 'jhwcsj',
- customRender:function (text) {
- return !text?"":(text.length>10?text.substr(0,10):text)
- }
- },
- {
- title:'阶段',
- align:"center",
- width: 80,
- dataIndex: 'yzjdname'
- },
- {
- title:'项目进度',
- align:"center",
- width: 80,
- dataIndex: 'processpercent',
- customRender: (text, record) => {
- return record.id === 'amount'?null:parseInt(text)+ '%'
- },
- },
- {
- title:'成本进度',
- align:"center",
- width: 80,
- dataIndex: 'costPercent',
- customRender: (text, record) => {
- return record.id === 'amount'?null:(Number(text) * 100).toFixed(0) + '%'
- },
- },
- {
- title:'已收款',
- align:"center",
- width: 80,
- dataIndex: 'taskmoney',
- // scopedSlots: {
- // customRender: 'taskmoney',
- // },
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'taskmoney', '已收款')}
- },
- {
- title:'合同额',
- align:"center",
- width: 80,
- dataIndex: 'contractfpe',
- // scopedSlots: {
- // customRender: 'contractfpe',
- // },
- // customCell: this.getClickColumn,
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'contractfpe', '合同额')}
- },
- {
- title:'预估价',
- align:"center",
- width: 80,
- dataIndex: 'estimationcoat',
- customRender: (text, record) => {
- return record.contractfpe ? '-' : Number(text).toFixed(2)
- },
- },
- {
- title:'总成本',
- align:"center",
- width: 80,
- dataIndex: 'zcb',
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- },
- {
- title:'利润额',
- align:"center",
- width: 80,
- dataIndex: 'lre',
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- },
- {
- title:'利润率',
- align:"center",
- width: 80,
- dataIndex: 'lrl',
- customRender: (text) => {
- return (Number(text) * 100).toFixed(1) + '%'
- },
- },
- {
- title:'研制数量',
- align:"center",
- width: 80,
- dataIndex: 'yzsl'
- },
- {
- title:'单台利润',
- align:"center",
- width: 80,
- dataIndex: 'oneProfit',
- customRender: (text, record) => {
- return record.id === 'amount'?null:(Number(text)/10000).toFixed(2)
- },
- },
- {
- title:'单台收入',
- align:"center",
- width: 80,
- dataIndex: 'oneIncome',
- customRender: (text, record) => {
- return record.id === 'amount'?null:(Number(text)/10000).toFixed(2)
- },
- },
- {
- title:'单台成本',
- align:"center",
- width: 80,
- dataIndex: 'oneCost',
- customRender: (text, record) => {
- return record.id === 'amount'?null:(Number(text)/10000).toFixed(2)
- },
- },
- {
- title:'材料预算',
- align:"center",
- width: 80,
- dataIndex: 'clys',
- customRender: (text) => {
- return Number(text).toFixed(2)
- },
- },
- {
- title:'材料费',
- align:"center",
- width: 80,
- dataIndex: 'clf',
- // scopedSlots: {
- // customRender: 'clf',
- // },
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'clf', '材料费')}
- },
- {
- title:'专用预算',
- align:"center",
- width: 80,
- dataIndex: 'zyys',
- customRender: (text) => {
- return Number(text).toFixed(2)
- },
- },
- {
- title:'专用费',
- align:"center",
- width: 80,
- dataIndex: 'zyf',
- // scopedSlots: {
- // customRender: 'zyf',
- // },
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'zyf', '专用费')}
- },
- {
- title:'事务预算',
- align:"center",
- width: 80,
- dataIndex: 'swys',
- customRender: (text) => {
- return Number(text).toFixed(2)
- },
- },
- {
- title:'事务费',
- align:"center",
- width: 80,
- dataIndex: 'swf',
- // scopedSlots: {
- // customRender: 'swf',
- // },
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'swf', '事务费')}
- },
- {
- title:'外协预算',
- align:"center",
- width: 80,
- dataIndex: 'wxys',
- customRender: (text) => {
- return Number(text).toFixed(2)
- },
- },
- {
- title:'外协费',
- align:"center",
- width: 80,
- dataIndex: 'wxf',
- // scopedSlots: {
- // customRender: 'wxf',
- // },
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'wxf', '外协费')}
- },
- {
- title:'间接预算',
- align:"center",
- width: 80,
- dataIndex: 'jjys',
- customRender: (text) => {
- return Number(text).toFixed(2)
- },
- },
- {
- title:'燃动费',
- align:"center",
- width: 80,
- dataIndex: 'rldlf',
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'rldlf', '燃动费')}
- },
- {
- title:'固资费',
- align:"center",
- width: 80,
- dataIndex: 'gdzczj',
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'gdzczj', '固资费')}
- },
- {
- title:'人工费',
- align:"center",
- width: 80,
- dataIndex: 'gzjlwf',
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'gzjlwf', '人工费')}
- },
- {
- title:'管理费',
- align:"center",
- width: 80,
- dataIndex: 'glf',
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'glf', '管理费')}
- },
- {
- title:'筛选费',
- align:"center",
- width: 80,
- dataIndex: 'sxf',
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'sxf', '筛选费')}
- },
- {
- title:'装机成本',
- align:"center",
- width: 80,
- dataIndex: 'zjcb',
- // scopedSlots: {
- // customRender: 'zjcb',
- // },
- customRender: (text) => {
- return (Number(text)/10000).toFixed(2)
- },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'zjcb', '装机成本')}
- },
- {
- title:'内部试验',
- align:"center",
- width: 80,
- dataIndex: 'lbsy',
- ellipsis: true,
- },
- {
- title:'工时(h)',
- align:"center",
- width: 80,
- dataIndex: 'workhour',
- // scopedSlots: {
- // customRender: 'workhour',
- // },
- customCell: (record, index)=>{ return this.customCellDetail(record, index, 'workhour', '工时')}
- },
- {
- title:'责任部门',
- align:"center",
- width: 120,
- dataIndex: 'zrbm',
- ellipsis: true,
- },
- // {
- // title:'下达部门id',
- // align:"center",
- // dataIndex: 'jycsid'
- // },
- {
- title:'下达部门',
- align:"center",
- width: 120,
- dataIndex: 'jycs',
- ellipsis: true,
- },
- // {
- // title:'1:横向 2:纵向',
- // align:"center",
- // dataIndex: 'hxzxid'
- // },
- {
- title:'横向纵向',
- align:"center",
- width: 80,
- dataIndex: 'hxzxname'
- },
- {
- title:'任务类型',
- align:"center",
- width: 80,
- dataIndex: 'tasktype'
- },
- {
- title:'审计审价',
- align:"center",
- width: 80,
- dataIndex: 'auditprice'
- },
- {
- title:'任务状态',
- align:"center",
- width: 80,
- dataIndex: 'iflag'
- },
- {
- title:'提出单位简称',
- align:"center",
- width: 120,
- dataIndex: 'brief'
- },
- {
- title:'父级任务',
- align:"center",
- width: 80,
- dataIndex: 'reftaskno'
- },
- {
- title:'批产任务号',
- align:"center",
- width: 80,
- dataIndex: 'pccode'
- },
- {
- title:'备产任务号',
- align:"center",
- width: 80,
- dataIndex: 'bccode'
- },
- {
- title:'备料任务号',
- align:"center",
- width: 80,
- dataIndex: 'blcode'
- },
- {
- title:'业务员',
- align:"center",
- width: 80,
- dataIndex: 'businessManName',
- ellipsis: true,
- },
- {
- title:'主管设计师',
- align:"center",
- width: 100,
- dataIndex: 'ywfzrname',
- ellipsis: true,
- },
- {
- title:'科研任务负责人',
- align:"center",
- width: 120,
- dataIndex: 'xhzzrname',
- ellipsis: true,
- },
- {
- title:'设计工时',
- align:"center",
- width: 80,
- dataIndex: 'sjgs'
- },
- {
- title:'生产工时',
- align:"center",
- width: 80,
- dataIndex: 'scgs'
- },
- // {
- // title:'级别',
- // align:"center",
- // dataIndex: 'ji',
- // customCell: this.getClickColumn,
- // },
- {
- title: '操作',
- dataIndex: 'action',
- align:"center",
- fixed:"right",
- width: 150,
- scopedSlots: {
- // filterDropdown: 'filterDropdown',
- // filterIcon: 'filterIcon',
- customRender: 'action',
- }
- }
- ],
- url: {
- list: "/projectCostHuiji/projectCostHuiji/list",
- // delete: "/projectCost/projectCost/delete",
- // deleteBatch: "/projectCost/projectCost/deleteBatch",
- exportXlsUrl: "/projectCostHuiji/projectCostHuiji/exportXlsProjectCost",
- importExcelUrl: "projectCost/projectCost/importExcel",
- },
- dictOptions:{},
- superFieldList:[],
- // 拖拽
- handlerFirstTime: null,
- isClick: false,
- mouseFlag: false,
- mouseOffset: null,
- // 比对
- duibiIds: '',
- duibiTasknos: '',
- }
- },
- created() {
- this.loadData()
- this.initColumns();
- this.getSuperFieldList();
- },
- mounted() {
- console.log(window.innerHeight, this.$refs.table)
- this.$nextTick(() => {
- this.scrollHeight = window.innerHeight - 60 - 25 - 55 - 25
- // this.scrollHeight = window.innerHeight - this.$refs.table.$el.offsetTop - 60 - 52 - 50 - 56 - 60 - 34
- })
- },
- computed: {
- importExcelUrl: function(){
- return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
- },
- },
- methods: {
- // 按下鼠标记录鼠标位置
- mouseDownHandler(e) {
- this.mouseOffset = e.clientX;
- this.handlerFirstTime = new Date().getTime()
- this.mouseFlag = true;
- console.log(this.mouseOffset)
- },
- mouseUpHandler(e) {
- var lastTime = new Date().getTime();
- this.mouseFlag = false;
- if( (lastTime - this.handlerFirstTime) < 100){
- this.isClick = true
- } else {
- this.isClick = false
- }
- },
- mouseMoveHandler(e) {
- // 这里面需要注意,通过ref需要那个那个包含table元素的父元素
- let v=document.getElementsByClassName("ant-table-body")[0]
- v.style.cursor = 'move'
- v.style['user-select'] = 'none'
- if (this.mouseFlag) {
- // 设置水平方向的元素的位置
- v.scrollLeft -= (- this.mouseOffset + (this.mouseOffset = e.clientX));
- }
- },
- loadData(arg) {
- console.log(111)
- if(!this.url.list){
- this.$message.error("请设置url.list属性!")
- return
- }
- //加载数据 若传入参数1则加载第一页的内容
- if (arg === 1) {
- this.ipagination.current = 1;
- }
- var params = this.getQueryParams();//查询条件
- console.log(params)
- // 查询时减去筛选行
- params.pageSize = (Number(params.pageSize) - 1).toString()
- this.loading = true;
- getAction(this.url.list, params).then((res) => {
- console.log(res)
- if (res.success) {
- //update-begin---author:zhangyafei Date:20201118 for:适配不分页的数据列表------------
- this.dataSource = res.result.pageList.records||res.result.pageList;
- var amount = res.result.projectCostHuiji
- amount.taskno = '筛选合计:'
- amount.id = 'amount'
- // amount.id = 'amount'+res.result.pageList.current
- this.dataSource.unshift(amount)
- if(res.result.pageList.total)
- {
- // 解决页数显示不对的问题:因为a-table当前默认是加上筛选行的,合计时几页就加上几
- // 例如:当前total后端返回32,一页10个应该是4页,但是a-table调用的是一页11个,所以32/11 会显示3页
- this.ipagination.total = res.result.pageList.total + res.result.pageList.pages;
- // 设置显示的total数
- this.showListTotal = res.result.pageList.total
- }else{
- this.ipagination.total = 0;
- }
- console.log(this.dataSource)
- //update-end---author:zhangyafei Date:20201118 for:适配不分页的数据列表------------
- }else{
- this.$message.warning(res.message)
- }
- }).finally(() => {
- this.loading = false
- })
- },
- initDictConfig(){
- },
- initColumns(){
- //权限过滤(列权限控制时打开,修改第二个参数为授权码前缀)
- // this.defColumns = colAuthFilter(this.defColumns,'testdemo:');
- columnsSelect().then(res => {
- let colSettings = res
- if(colSettings==null||colSettings==undefined || colSettings.length === 0){
- let allSettingColumns = [];
- this.defColumns.forEach(function (item,i,array ) {
- allSettingColumns.push(item.dataIndex);
- })
- this.settingColumns = allSettingColumns;
- this.columns = this.defColumns;
- }else{
- this.settingColumns = colSettings;
- const cols = this.defColumns.filter(item => {
- if(item.key =='rowIndex'|| item.dataIndex=='action'){
- return true;
- }
- if (colSettings.includes(item.dataIndex)) {
- return true;
- }
- return false;
- })
- this.columns = cols;
- }
- })
- // 储存浏览器方式
- // var key = this.$route.name+":colsettings";
- // let colSettings= Vue.ls.get(key);
- },
- // 行颜色设置
- setRowClassName(record, index){
- // console.log(record)
- if(record.lrl < 0){
- // 亏损标红
- return 'table-kuisun-color'
- }
- if(record.status === '1'){
- // 汇集计算之后的数据标浅灰
- return 'table-zupi-color'
- }
- if(record.hjstatus === '4'){
- // 加入产品价格库的
- return 'table-chanpin-model-color'
- }
- },
- //列设置更改事件
- onColSettingsChange (checkedValues) {
- console.log(checkedValues)
- // 获取浏览器方式
- // var key = this.$route.name+":colsettings";
- // Vue.ls.set(key, checkedValues, 7 * 24 * 60 * 60 * 1000)
- this.settingColumns = checkedValues;
- const cols = this.defColumns.filter(item => {
- if(item.key =='rowIndex'|| item.dataIndex=='action'){
- return true
- }
- if (this.settingColumns.includes(item.dataIndex)) {
- return true
- }
- return false
- })
- this.columns = cols;
- columnsEdit({checkedValues: checkedValues})
- },
- customCellDetail(record, index, columnValue, columnTitle){
- if(record.children || record.id === 'amount'){
- return false
- }
- console.log(record, index, columnValue, columnTitle)
- return {
- style: {
- 'color': "#1890ff !important",
- 'cursor': "pointer",
- },
- on: {
- // 点击事件
- click: (event) => {
-
- },
- dblclick: (event) => {
- // 没有值不弹窗--也弹窗
- // if(!event.target.textContent){
- // return
- // }
- this.$refs.proCostDetail.taskno = record.taskno
- if(record.status === '1' && columnValue === 'clf'){
- // 批产参数
- this.$refs.proCostDetail.pichanInfo = {
- pccode: record.pccode,
- proportion: record.proportion,
- columnValue: columnValue,
- }
- console.log(columnValue)
- this.$refs.proCostDetail.columnValue = 'pichanTask'
- this.$refs.proCostDetail.title = columnTitle + '批产明细'
- } else {
- this.$refs.proCostDetail.columnValue = columnValue
- this.$refs.proCostDetail.title = columnTitle + '明细'
- }
- this.$refs.proCostDetail.show()
- },
- contextmenu: (event) => {},
- mouseenter: (event) => {}, // 鼠标移入行
- mouseleave: (event) => {}
- },
- };
- },
- detailClick(text, record, columnValue, columnTitle){
- if(!this.isClick){
- return
- }
- // console.log(text, record, columnValue, columnTitle)
- // 去掉没有值不弹窗判断 !text ||
- if(record.children || record.id === 'amount'){
- return
- }
- this.$refs.proCostDetail.taskno = record.taskno
- if(record.status === '1' && columnValue === 'clf'){
- // 批产参数
- this.$refs.proCostDetail.pichanInfo = {
- pccode: record.pccode,
- proportion: record.proportion,
- columnValue: columnValue,
- }
- console.log(columnValue)
- this.$refs.proCostDetail.columnValue = 'pichanTask'
- this.$refs.proCostDetail.title = columnTitle + '批产明细'
- } else {
- this.$refs.proCostDetail.columnValue = columnValue
- this.$refs.proCostDetail.title = columnTitle + '明细'
- }
- this.$refs.proCostDetail.show()
- },
- getClickColumn(record, index){
- if(record.children || record.id === 'amount'){
- return false
- }
- return {
- style: {
- 'color': '#1890ff',
- 'cursor': 'pointer',
- },
- on: {
- click: (event)=> {
- // 没有值不弹窗
- if(!event.target.textContent){
- return
- }
- // console.log(record, index, event, event.target.cellIndex)
- // console.log(this.columns[event.target.cellIndex - 1])
- var clickColumn = this.columns[event.target.cellIndex - 1].dataIndex
- var title = this.columns[event.target.cellIndex - 1].title
- this.$refs.proCostDetail.taskno = record.taskno
- if(record.status === '1'){
- // 批产参数
- this.$refs.proCostDetail.pichanInfo = {
- pccode: record.pccode,
- proportion: record.proportion,
- columnValue: clickColumn,
- }
- this.$refs.proCostDetail.columnValue = 'pichanTask'
- this.$refs.proCostDetail.title = title + '批产明细'
- } else {
- this.$refs.proCostDetail.columnValue = clickColumn
- this.$refs.proCostDetail.title = title + '明细'
- }
- // console.log(this.$refs.proCostDetail.columnValue)
- this.$refs.proCostDetail.show()
- },
- }
- }
- },
- // 费用导入后执行一次计算程序
- handleComputed(){
- this.loading = true
- visibleClientStart().then(response => {
- console.log(response)
- this.loadData()
- })
- },
- // 比对
- batchDuiBi(){
- // console.log(this.selectedRowKeys,this.selectionRows)
- // console.log(JSON.stringify(this.selectedRowKeys))
- var selectTasknos = this.selectionRows.map( res => {
- console.log(res.status)
- var value = res.status === '1' ? res.taskno+'_-_pc' : res.taskno
- return value
- })
- console.log(selectTasknos)
- this.duibiTasknos = selectTasknos.toString()
- this.duibiIds = this.selectedRowKeys.toString()
- this.duiBi = true
- // if (this.chooseRowType == 1) {
- // var a = this.selectedRowKeys
- // var ids = a.toString()
- // getHjList({ids: ids}).then((res) => {
- // console.log(res)
- // this.duibiList = res
- // this.duibiclList = []
- // })
- // var selectTasknos = this.selectionRows.map( res => {
- // return res.taskno
- // })
- // var tasknos = selectTasknos.toString()
- // console.log(tasknos)
- // getDbClList({tasknos: tasknos}).then((res) => {
- // console.log(res)
- // this.duibiclList = res.result.resultVOList
- // this.duiBi = true
- // })
- // } else {
- // var a = this.selectedRowKeys
- // var ids = a.toString()
- // getDbList({ids: ids}).then((res) => {
- // console.log(res)
- // this.duibiList = res
- // })
- // var selectTasknos = this.selectionRows.map( res => {
- // return res.taskno
- // })
- // var tasknos = selectTasknos.toString()
- // console.log(tasknos)
- // getDbClList({tasknos: tasknos}).then((res) => {
- // console.log(res)
- // this.duibiclList = res.result.resultVOList
- // this.duiBi = true
- // })
- // }
- // var a = this.selectedRowKeys
- // var ids = a.toString()
- // getDbList({ids: ids}).then((res) => {
- // console.log(res)
- // this.duibiList = res
- // })
- // var selectTasknos = this.selectionRows.map( res => {
- // return res.taskno
- // })
- // var tasknos = selectTasknos.toString()
- // console.log(tasknos)
- // getDbClList({tasknos: tasknos}).then((res) => {
- // console.log(res)
- // this.duibiclList = res
- // this.duiBi = true
- // })
- },
- // 关闭比对弹框
- handleGb(){
- this.duiBi = false
- this.duibiList = {}
- this.duibiclList = []
- },
- // 一键折叠展开
- handleExpand(){
- console.log(this.isExpanded)
- if(this.isExpanded){
- // 当前为展开,全部折叠
- this.expandedRowKeys = []
- } else {
- // 当前为折叠,全部展开
- this.expandedRowKeys = this.dataSource.map(res => res.id)
- }
- this.isExpanded = !this.isExpanded
- },
- onExpand (expanded, record) {
- if (expanded) {
- console.log(record.id)
- // 设置展开窗Key,代表展开操作
- this.expandedRowKeys.push(record.id)
- } else {
- // 代表折叠操作
- if (this.expandedRowKeys.length) {
- this.expandedRowKeys = this.expandedRowKeys.filter(v => {
- return v !== record.id
- })
- }
- }
- },
- // 虚实比对(堆叠图)
- handleXushi(record){
- console.log(record)
- this.$refs.xushi.open(record)
- },
- // 加入产品模型
- handleAddProjectModel(record){
- console.log(record)
- var arr = []
- arr.push(record)
- insertIntoProject(arr).then(response => {
- console.log(response)
- this.loadData()
- })
- },
- // 比对禁选判断
- onSelectChange(selectedRowKeys, selectionRows) {
- console.log(selectedRowKeys, selectionRows)
- // this.selectedRowKeys = selectedRowKeys;
- // this.selectionRows = selectionRows;
- // 解决分页后selectionRows只获取本页面勾选的问题
- for (let val of selectionRows) {
- if (!this.selectionRows.find((item) => item.id === val.id)) {
- this.selectionRows.push(val);
- }
- }
- this.selectedRowKeys = selectedRowKeys;
- this.selectionRows = this.selectionRows.filter((item) =>
- this.selectedRowKeys.includes(item.id)
- );
- },
- onSelect(record, selected, selectedRows, nativeEvent){
- console.log(record, selected, selectedRows, nativeEvent)
- console.log(this.selectionRows)
- if(selected) {
- if (this.selectionRows.length == 1) {
- this.chooseRowType = record.ji
- this.chooseStatus = true
- } else {
- console.log(this.chooseRowType,record.ji)
- if (this.chooseRowType != record.ji) {
- this.chooseRowType = this.chooseRowType
- this.chooseStatus = true
- this.$message.error("请选择同级项进行比对");
- } else{
- // this.chooseStatus = false
- for (let i = 0; i < this.selectionRows.length; i++) {
- const element = this.selectionRows[i].ji;
- console.log(888,this.chooseRowType,element)
- if (this.chooseRowType != element) {
- this.chooseStatus = true
- } else {
- this.chooseStatus = false
- }
- }
- }
- }
- } else{
- if (this.selectionRows.length == 1) {
- console.log(777,this.selectionRows[0].ji)
- this.chooseRowType = this.selectionRows[0].ji
- this.chooseStatus = true
- } else {
- for (let i = 0; i < this.selectionRows.length; i++) {
- const element = this.selectionRows[i].ji;
- console.log(888,this.chooseRowType,element)
- if (this.chooseRowType != element) {
- this.chooseStatus = true
- this.$message.error("请选择同级项进行比对");
- } else {
- this.chooseStatus = false
- }
- }
- // 第一版
- // if (this.chooseRowType != record.ji) {
- // this.chooseRowType = this.chooseRowType
- // this.chooseStatus = true
- // this.$message.error("请选择同级项进行比对");
- // }else{
- // // this.chooseStatus = false
- // for (let i = 0; i < selectedRows.length; i++) {
- // const element = selectedRows[i].ji;
- // console.log(888,this.chooseRowType,element)
- // if (this.chooseRowType != element) {
- // this.chooseStatus = true
- // } else {
- // this.chooseStatus = false
- // }
- // }
- // }
- }
- }
- // console.log(record.ji)
- // if (record.ji == '2') {
- // // 选中二级,一级禁选
- // this.chooseRowType == 'chengben'
- // } else {
- // // 选中一级,二级禁选
- // this.chooseRowType == 'huiji'
- // }
- },
- export(value, fileName){
- // if(!fileName || typeof fileName != "string"){
- // fileName = "导出文件"
- // }
- // let param = this.getQueryParams();
- // if(this.selectedRowKeys && this.selectedRowKeys.length>0){
- // param['selections'] = this.selectedRowKeys.join(",")
- // }
- // console.log("导出参数",param)
- var param = {isFolding: value}
- downFile(this.url.exportXlsUrl,param).then((data)=>{
- console.log(data)
- if (!data) {
- this.$message.warning("文件下载失败")
- return
- }
- if (typeof window.navigator.msSaveBlob !== 'undefined') {
- window.navigator.msSaveBlob(new Blob([data],{type: 'application/vnd.ms-excel'}), fileName+'.xls')
- }else{
- let url = window.URL.createObjectURL(new Blob([data],{type: 'application/vnd.ms-excel'}))
- let link = document.createElement('a')
- link.style.display = 'none'
- link.href = url
- link.setAttribute('download', fileName+'.xls')
- document.body.appendChild(link)
- link.click()
- document.body.removeChild(link); //下载完成移除元素
- window.URL.revokeObjectURL(url); //释放掉blob对象
- }
- })
- },
- // 导出
- handleExportXls(){
- var isFolding
- var fileName = "项目成本"
- var _this = this
- const modal = this.$confirm({
- title: '请选择导出数据类型',
- content: '*全部数据=汇集层+子级',
- okText: '全部数据',
- // okType: 'danger',
- cancelText: '汇集数据',
- closable: true, // 显示右上角关闭按钮
- onOk() {
- isFolding = 1
- fileName = '项目成本-全部数据'
- _this.export(isFolding, fileName)
- },
- onCancel(e) {
- // console.log(e)
- // 如果是右上角关闭触发,则不导出,只关闭
- if(e.triggerCancel) return
- isFolding = 0
- fileName = '项目成本-汇集数据'
- _this.export(isFolding, fileName)
- modal.destroy();
- },
- });
- },
- getSuperFieldList(){
- let fieldList=[];
- fieldList.push({type:'string',value:'taskno',text:'任务号',dictCode:''})
- fieldList.push({type:'string',value:'taskname',text:'任务名称',dictCode:''})
- fieldList.push({type:'string',value:'xhname',text:'型号',dictCode:''})
- // fieldList.push({type:'date',value:'jhwcsj',text:'计划完成时间'})
- fieldList.push({type:'string',value:'yzjdname',text:'阶段',dictCode:''})
- fieldList.push({type:'string',value:'processpercent',text:'项目进度',dictCode:''})
- fieldList.push({type:'string',value:'costPercent',text:'成本进度',dictCode:''})
- // fieldList.push({type:'int',value:'yzsl',text:'研制数量',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'oneIncome',text:'单台收入',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'oneCost',text:'单台成本',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'oneProfit',text:'单台利润',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'lre',text:'利润额',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'lrl',text:'利润率',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'estimationcoat',text:'预估价',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'contractfpe',text:'合同额',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'taskmoney',text:'已收款',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'zcb',text:'总成本',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'clf',text:'材料费',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'zyf',text:'专用费',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'swf',text:'事务费',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'wxf',text:'外协费',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'rldlf',text:'燃料动力费',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'gdzczj',text:'固定资产折旧',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'gzjlwf',text:'工资及劳务费',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'glf',text:'管理费',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'zjcb',text:'装机成本',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'lbsy',text:'内部试验',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'workhour',text:'工时(h)',dictCode:''})
- fieldList.push({type:'string',value:'zrbm',text:'责任部门',dictCode:''})
- // fieldList.push({type:'int',value:'jycsid',text:'下达部门id',dictCode:''})
- fieldList.push({type:'string',value:'jycs',text:'下达部门',dictCode:''})
- // fieldList.push({type:'int',value:'hxzxid',text:'1:横向 2:纵向/来自科研任务',dictCode:''})
- fieldList.push({type:'string',value:'hxzxname',text:'横向纵向',dictCode:''})
- fieldList.push({type:'string',value:'tasktype',text:'任务类型',dictCode:''})
- // fieldList.push({type:'string',value:'auditprice',text:'审计审价',dictCode:''})
- fieldList.push({type:'string',value:'iflag',text:'任务状态',dictCode:''})
- fieldList.push({type:'string',value:'brief',text:'提出单位简称',dictCode:''})
- fieldList.push({type:'int',value:'reftaskno',text:'父级任务',dictCode:''})
- fieldList.push({type:'int',value:'pccode',text:'批产任务号',dictCode:''})
- // fieldList.push({type:'int',value:'bccode',text:'备产任务号',dictCode:''})
- // fieldList.push({type:'int',value:'blcode',text:'备料任务号',dictCode:''})
- fieldList.push({type:'string',value:'businessman',text:'业务员',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'sjgs',text:'设计工时',dictCode:''})
- // fieldList.push({type:'BigDecimal',value:'scgs',text:'生产工时',dictCode:''})
- this.superFieldList = fieldList
- },
- }
- }
- </script>
- <style scoped>
- @import '~@assets/less/common.less';
- </style>
- <style scoped>
- .table-kuisun-color{
- color: red !important;
- /* user-select: 'none'; */
- }
- .table-zupi-color{
- color: #b3b2b2 !important;
- /* user-select: 'none'; */
- }
- .table-chanpin-model-color{
- color: #29d59f !important;
- /* color: #438bf7 !important; */
- }
- /*表格thead*/
- ::v-deep .ant-table-thead > tr > th {
- font-size: 14px;
- /* color: #000; */
- }
- /*表格tbody*/
- ::v-deep .ant-table-tbody > tr > td {
- font-size: 13px;
- padding: 6px 4px !important;
- }
- </style>
|