123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728 |
- <template>
- <div class="app-container">
- <el-collapse v-model="activeName" @change="handleChange">
- <el-collapse-item>
- <template slot="title">
- <span style="font-size:20px; margin-left:20px;letter-spacing:2px;color:red">
- <i class="el-icon-warning"></i>
- <span> 当前节点:{{ currentNode == null ? '???' : currentNode.nodeName }}</span>
- <!-- <span v-if = "currentNode.tasks.length>0" style="margin-left:30px">任务:</span> -->
- <!-- <span v-for="( t,index) in currentNode.tasks" :key=index >{{t.info}}</span> -->
- <!-- <span style="margin-left:30px" v-if="statementNo || reportNo">该流程已取:<el-tag type="success" v-if="statementNo">{{statementNo}}</el-tag> <el-tag type="danger" v-if="reportNo">{{reportNo}}</el-tag></span> -->
- </span>
- <span style="font-size:15px; margin-left:15px;letter-spacing:2px; color:RGB(168,168,168)">
- 点击展开查看实时流程图
- </span>
- </template>
- <WorkflowBoard ref='board' @workflowCommitVerify="workflowCommitVerify" :nodeBusinessInfo="nodeBusinessInfo"
- @getPreviousNode="getPreviousNode" />
- </el-collapse-item>
- </el-collapse>
- <div class="button-area">
- <el-button v-if="nodeBusinessInfo.currentNodePermission.commit" class="y-save" type="success" round
- @click="commit('PASS')" :disabled="!nodeBusinessInfo.doWorkflow">提交</el-button>
- <el-button v-if="nodeBusinessInfo.currentNodePermission.reversible" class="y-save" type="warning" round
- @click="commit('REVERSE')" :disabled="!nodeBusinessInfo.doWorkflow">退回</el-button>
- <el-button v-if="nodeBusinessInfo.currentNodePermission.skippable" class="y-save" type="warning" round
- @click="commit('SKIP')" :disabled="!nodeBusinessInfo.doWorkflow">跳过</el-button>
- <el-button v-if="nodeBusinessInfo.currentNodePermission.terminable" class="y-save" type="danger" round
- @click="commit('TERMINATE')" :disabled="!nodeBusinessInfo.doWorkflow">终止</el-button>
- <el-button v-if="nodeBusinessInfo.currentNodePermission.restartable" class="y-save" type="danger" round
- @click="commit('RESTART')" :disabled="!nodeBusinessInfo.doWorkflow">重置</el-button>
- <el-button class="y-save" round type="info" @click="goBack">返回</el-button>
- </div>
- <el-tabs v-model="activeTagName" @tab-click="handleClick" type="border-card">
- <el-tab-pane name="baseInfo" class="pane-class" :lazy=true>
- <span slot="label"><i class="el-icon-document"></i>基本信息</span>
- <y-detail-page-layout ref="addAssetsOrder" name="assets" :editStatus="editStatus">
- <el-form ref="assetsForm" :model="assetsForm" :rules="assetsFormRules" :disabled="disabledStatus">
- <div class="createMajor-main-container">
- <div class="postInfo-container">
- <div>
- <el-divider content-position="left">
- <h3 class="title">
- <div class="avatar-wrapper icon-title">订单</div>
- <div class="icon-info">资产订单</div>
- </h3>
- </el-divider>
- </div>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="客户经理:" prop="clientManager" label-width="120px" class="postInfo-container-item">
- <el-input :value="assetsForm.clientManagerName" class="filter-item" readonly disabled
- style=" width: 225px" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="4" :span="6">
- <el-form-item label="接单部门:" prop="departmentId" label-width="120px" class="postInfo-container-item">
- <el-select v-model="assetsForm.departmentId">
- <el-option v-for="(d, id) in allotDepartment" :label="d.name" :value="d.id"
- :key="d.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item prop="name" label-width="120px" class="postInfo-container-item" label="项目名称:">
- <el-input v-model="assetsForm.name" class="filter-item" />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="业务类型:" prop="assetsBusinessGener" label-width="120px"
- class="postInfo-container-item">
- <el-select v-model="assetsForm.assetsBusinessGener" filterable placeholder="业务类型">
- <el-option v-for="(s, index) in assetsBusinessGeners" :label="s.label" :value="s.value"
- :key="s.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="客户再次委托:" prop="entrustAgain" label-width="140px" class="postInfo-container-item">
- <el-radio v-model="assetsForm.entrustAgain" :label="false" border size="medium">否</el-radio>
- <el-radio v-model="assetsForm.entrustAgain" :label="true" border size="medium">是</el-radio>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="客户类型:" prop="clienteleType" label-width="120px" class="postInfo-container-item">
- <el-select v-model="assetsForm.clienteleType" placeholder="请选择"
- @change="changeCustomerType(assetsForm.clienteleType)">
- <el-option label="企业" value="企业"></el-option>
- <el-option label="个人" value="个人"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="客户名称:" prop="clienteleId" label-width="120px" class="postInfo-container-item"
- v-if="itemHideStatus">
- <el-select v-model="assetsForm.clienteleId" placeholder="请选择(可搜索)" @change="findSubClientele(0)"
- clearable filterable>
- <el-option v-for="(c, id) in customerCompany" :label="c.name" :value="c.id"
- :key="c.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="业务来源:" prop="clienteleSubId" label-width="120px" class="postInfo-container-item"
- v-if="itemHideStatus">
- <el-select v-model="assetsForm.clienteleSubId" placeholder="请选择(可搜索)" @change="getCustomerContract"
- clearable filterable>
- <el-option v-for="(s, id) in subCustomerCompany" :label="s.name" :value="s.id"
- :key="s.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="客户联系人:" prop="clienteleContactId" label-width="120px"
- class="postInfo-container-item">
- <div>
- <el-select v-model="assetsForm.clienteleContactId" placeholder="请选择(可搜索)" clearable filterable
- @change="" style="width:60%">
- <el-option v-for="(c, id) in customerContract" :label="c.name" :value="c.id"
- :key="c.id"></el-option>
- </el-select>
- <!-- <el-tooltip class="item" effect="dark" content="没有联系人?点击新增" placement="top-end">
- <span style="margin-left:5%;color:RGB(64,158,255);cursor:pointer"
- @click="createLinkman(false)">新增</span>
- </el-tooltip> -->
- </div>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="联系人电话:" prop="mobile" label-width="120px" class="postInfo-container-item">
- <el-input :value="assetsForm.linkmanMobile" class="filter-item" readonly disabled
- style=" width: 225px" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="联系人部门:" prop="department" label-width="120px" class="postInfo-container-item">
- <el-input :value="assetsForm.linkmanDepartment" class="filter-item" readonly disabled
- style=" width: 225px" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="联系人职务:" prop="duty" label-width="120px" class="postInfo-container-item">
- <el-input :value="assetsForm.linkmanDuty" class="filter-item" readonly disabled
- style=" width: 225px" />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="是否证券项目:" prop="security" label-width="140px" class="postInfo-container-item">
- <el-radio v-model="assetsForm.security" :label="false" border size="medium">否</el-radio>
- <el-radio v-model="assetsForm.security" :label="true" border size="medium">是</el-radio>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="是否资产重组项目:" prop="significantAssetsReorganization" label-width="200px"
- class="postInfo-container-item">
- <el-radio v-model="assetsForm.significantAssetsReorganization" :label="false" border
- size="medium">否</el-radio>
- <el-radio v-model="assetsForm.significantAssetsReorganization" :label="true" border
- size="medium">是</el-radio>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label=" 是否国资项目:" prop="stateAssets" label-width="140px" class="postInfo-container-item">
- <el-radio v-model="assetsForm.stateAssets" :label="false" border size="medium">否</el-radio>
- <el-radio v-model="assetsForm.stateAssets" :label="true" border size="medium">是</el-radio>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="是否涉及境外资产:" prop="foreignAssetsInvolved" label-width="200px"
- class="postInfo-container-item">
- <el-radio v-model="assetsForm.foreignAssetsInvolved" :label="false" border
- size="medium">否</el-radio>
- <el-radio v-model="assetsForm.foreignAssetsInvolved" :label="true" border size="medium">是</el-radio>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="是否分配产值:" prop="dispenseBenefit" label-width="140px"
- class="postInfo-container-item">
- <el-radio v-model="assetsForm.dispenseBenefit" :label="false" border size="medium">否</el-radio>
- <el-radio v-model="assetsForm.dispenseBenefit" :label="true" border size="medium">是</el-radio>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="委托人:" prop="bailor" label-width="120px" class="postInfo-container-item">
- <el-input v-model="assetsForm.bailor" class="filter-item" style=" width: 225px" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="委托联系人:" prop="bailorContactName" label-width="120px"
- class="postInfo-container-item">
- <el-input v-model="assetsForm.bailorContactName" class="filter-item" style=" width: 225px" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="委托人联系人电话:" prop="bailorContactTel" label-width="160px"
- class="postInfo-container-item">
- <el-input v-model="assetsForm.bailorContactTel" class="filter-item" style=" width: 225px" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="委托人地址:" prop="bailorAddress" label-width="120px" class="postInfo-container-item">
- <el-input v-model="assetsForm.bailorAddress" class="filter-item" style=" width: 225px" />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="终端客户类型:" prop="terminalClienteleType" label-width="140px"
- class="postInfo-container-item">
- <el-select v-model="assetsForm.terminalClienteleType" placeholder="请选择" style="width:205px">
- <el-option label="企业" value="企业"></el-option>
- <el-option label="个人" value="个人"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6" v-if="assetsForm.terminalClienteleType === '企业'">
- <el-form-item label="终端客户名称:" prop="terminalClienteleId" label-width="140px"
- class="postInfo-container-item">
- <div v-if="couldEdit">
- <el-select v-model="assetsForm.terminalClienteleId" placeholder="请选择(可搜索)"
- @change="findSubClientele(1)" clearable filterable style="width:80%">
- <el-option v-for="(c, id) in tCustomerCompany" :label="c.name" :value="c.id"
- :key="c.id"></el-option>
- </el-select>
- <!-- <el-tooltip class="item" effect="dark" content="没有终端客户?点击新增" placement="top-end">
- <span style="margin-left:5%;color:RGB(64,158,255);cursor:pointer"
- @click="createTerminalClient()">新增</span>
- </el-tooltip> -->
- </div>
- <el-input :value="assetsForm.tterminalClienteleName" class="filter-item" style=" width: 225px"
- v-else />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6" v-if="assetsForm.terminalClienteleType === '个人'">
- <el-form-item label="终端联系人:" prop="terminalClienteleContactId" label-width="120px"
- class="postInfo-container-item">
- <div v-if="couldEdit">
- <el-select v-model="assetsForm.terminalClienteleContactId" placeholder="请选择(可搜索)" clearable
- filterable @change="" style="width:80%">
- <el-option v-for="(c, id) in tCustomerContract" :label="c.name" :value="c.id"
- :key="c.id"></el-option>
- </el-select>
- <!-- <el-tooltip class="item" effect="dark" content="没有联系人?点击新增" placement="top-end">
- <span style="margin-left:5%;color:RGB(64,158,255);cursor:pointer"
- @click="createTlinkman()">新增</span>
- </el-tooltip> -->
- </div>
- <el-input :value="assetsForm.tterminalClienteleContactName" class="filter-item"
- style=" width: 225px" v-else />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="终端联系电话:" prop="clienteleType" label-width="150px"
- class="postInfo-container-item">
- <el-input :value="assetsForm.tlinkmanMobile" class="filter-item" readonly disabled
- style=" width: 215px" />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="23" :span="12">
- <el-form-item label="备注:" prop="remark" label-width="120px" class="postInfo-container-item">
- <el-input v-model="assetsForm.remark" :autosize="{ minRows: 4, maxRows: 4 }" class="filter-item"
- type="textarea" />
- </el-form-item>
- </el-col>
- </el-row>
- </div>
- </div>
- </el-form>
- </y-detail-page-layout>
- </el-tab-pane>
- <el-tab-pane name="members" class="pane-class" :lazy=true>
- <span slot="label"><i class="el-icon-document"></i>项目人员</span>
- <y-detail-page-layout @save="updatePrincipalAndMembers" ref="addAssetsOrder" name="assets"
- :editStatus="currentNode.nodeCode === 'DEPARTMENT_ALLOCATION'">
- <el-form ref="assetsForm" :model="assetsForm" :rules="assetsFormRules"
- :disabled="currentNode.nodeCode !== 'DEPARTMENT_ALLOCATION'">
- <div class="createMajor-main-container">
- <div class="postInfo-container">
- <div style="margin-top: 35px;">
- <el-divider content-position="left">
- <h3 class="title">
- <div class="avatar-wrapper icon-title">成员</div>
- <div class="icon-info">项目成员</div>
- </h3>
- </el-divider>
- </div>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="项目负责人:" prop="principalId" label-width="120px"
- :class="['postInfo-container-item', currentNode.nodeCode === 'DEPARTMENT_ALLOCATION' ? 'task-class' : '']"
- :rules="{ required: true, message: '项目负责人不能为空', trigger: 'blur' }">
- <el-select v-model="assetsForm.principalId" placeholder="请选择"
- :filterable="currentNode.nodeCode === 'DEPARTMENT_ALLOCATION'"
- :clearable="currentNode.nodeCode === 'DEPARTMENT_ALLOCATION'"
- :readonly="currentNode.nodeCode != 'DEPARTMENT_ALLOCATION'"
- :disabled="currentNode.nodeCode != 'DEPARTMENT_ALLOCATION'">
- <el-option v-for="(p, id) in principals" :label="p.name" :value="p.id" :key="p.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="3" :span="6">
- <el-form-item label="项目成员:" prop="members" label-width="120px"
- :class="['postInfo-container-item', currentNode.nodeCode === 'DEPARTMENT_ALLOCATION' ? 'task-class' : '']"
- :rules="{ required: true, message: '项目成员不能为空', trigger: 'blur' }">
- <el-select v-model="assetsForm.members" placeholder="请选择" multiple style=" width: 686px"
- :filterable="currentNode.nodeCode === 'DEPARTMENT_ALLOCATION'"
- :clearable="currentNode.nodeCode === 'DEPARTMENT_ALLOCATION'"
- :readonly="currentNode.nodeCode != 'DEPARTMENT_ALLOCATION'"
- :disabled="currentNode.nodeCode != 'DEPARTMENT_ALLOCATION'">
- <el-option v-for="(u, id) in allUsers" :label="u.name" :value="u.id" :key="u.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- </div>
- </div>
- </el-form>
- </y-detail-page-layout>
- </el-tab-pane>
- <el-tab-pane name="target" class="pane-class" :lazy=true>
- <span @click="getAETargetListByAssetsId()" slot="label"><i class="el-icon-document"></i>资产评估对象</span>
- <div class="createMajor-main-container">
- <div class="postInfo-container">
- <div style="margin-top: 35px;">
- <el-divider content-position="left">
- <h3 class="title">
- <div class="avatar-wrapper icon-title">评估</div>
- <div class="icon-info">资产评估对象</div>
- </h3>
- </el-divider>
- </div>
- <el-row>
- <el-col :span="2">
- <div>
- <el-statistic group-separator="," :precision="4" :value="totalEvaluateValue" title="估价对象总价(万)">
- <template slot="prefix">
- <i class="el-icon-coin"></i>
- </template>
- </el-statistic>
- </div>
- </el-col>
- <el-col :span="2">
- <el-button v-if="currentNode.nodeCode === 'SPOT_RECONNAISSANCE'" type="danger"
- @click="openTargetDialog(), changeStatus('add')" round>添加评估对象</el-button>
- </el-col>
- </el-row>
- <el-table ref="multipleTable" :data="assetsEvaluationTarget" stripe :header-row-style="{ color: '#333333' }"
- border takeNumberItems style="width: 100%; margin-top:20px">
- <el-table-column type="index" label="序号" width="80" align="center">
- </el-table-column>
- <el-table-column prop="purposeName" label="评估目的" align="center" show-overflow-tooltip>
- </el-table-column>
- <el-table-column label="评估对象" align="center" show-overflow-tooltip>
- <template slot-scope="{row}">
- <span>{{ row.targetTypename }}</span>
- <span>--</span>
- <span>{{ row.secTargetTypaName }}</span>
- </template>
- </el-table-column>
- <el-table-column prop="theHolder" label="产权持有人" align="center" show-overflow-tooltip>
- </el-table-column>
- <el-table-column prop="valueTypeName" label="价值类型" align="center" show-overflow-tooltip>
- </el-table-column>
- <el-table-column prop="totalAssetCarryingAmount" label="总资产账面值(万)" align="center" show-overflow-tooltip>
- </el-table-column>
- <el-table-column prop="totalLiabilitiesCarryingAmount" label="总负债账面值(万)" align="center"
- show-overflow-tooltip>
- </el-table-column>
- <el-table-column prop="carryingAmountOfNetAssets" label="净资产账面值(万)" align="center" show-overflow-tooltip>
- </el-table-column>
- <el-table-column prop="estimatedValue" label="评估价格(万)" align="center" show-overflow-tooltip>
- </el-table-column>
- <el-table-column prop="checkValue" label="审核价格(万)" align="center" show-overflow-tooltip>
- </el-table-column>
- <el-table-column label="操作" align="center" width="100" fixed="right">
- <template slot-scope="scope">
- <el-button type="text" size="small"
- @click="getAssetsTargetDetail(scope.row.id), changeStatus('detail')">
- 查看
- </el-button>
- <el-button v-if="currentNode.nodeCode === 'SPOT_RECONNAISSANCE'" type="text" size="small"
- @click="getAssetsTargetDetail(scope.row.id), changeStatus('edit')">
- 编辑
- </el-button>
- <el-button type="text" size="small" @click="assetsTargetDelete(scope.row.id)">删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- </div>
- </div>
- </el-tab-pane>
- <el-tab-pane name="finance" class="pane-class" :lazy=true>
- <span slot="label" @click="getOrderFundInvoiceById()"><i class="el-icon-document"></i>款项信息</span>
- <div class="createMajor-main-container">
- <div class="postInfo-container">
- <div style="margin-top: 35px;">
- <el-divider content-position="left">
- <h3 class="title">
- <div class="avatar-wrapper icon-title">款项</div>
- <div class="icon-info">资产款项信息</div>
- </h3>
- </el-divider>
- </div>
- </div>
- <el-form ref="invoiceData" :model="invoiceData" :disabled="true">
- <el-row>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="应收金额(元):" prop="shouldAmount" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.shouldAmount" class="filter-item" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="实收金额(元):" prop="realAmount" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.realAmount" class="filter-item" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="剩余金额(元):" prop="leftAmount" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.leftAmount" class="filter-item" />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="开票类型:" prop="type" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.type" class="filter-item" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="发票抬头:" prop="title" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.title" class="filter-item" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="税号:" prop="taxNo" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.taxNo" class="filter-item" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="开户银行:" prop="bankName" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.bankName" class="filter-item" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="银行地址:" prop="bankAddress" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.bankAddress" class="filter-item" />
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="6" :span="6">
- <el-form-item label="联系电话:" prop="bankTel" label-width="120px" class="postInfo-container-item">
- <el-input v-model="invoiceData.bankTel" class="filter-item" />
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- </div>
- </el-tab-pane>
- </el-tabs>
- <el-dialog :visible.sync="targetDialogVisible" @open="clear()" @close="resettargetForm"
- custom-class="doWarehouseClass">
- <div>
- <el-form ref="targetForm" :model="targetForm" style="margin-top:20px" :rules="targetFormRules"
- :disabled="targetDisabledStatus">
- <el-divider content-position="left">【资产】评估对象</el-divider>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="评估目的:" prop="evaluationPurposeId" label-width="120px" class="postInfo-container-item">
- <el-select v-model="targetForm.evaluationPurposeId">
- <el-option v-for="(p, id) in assetsEvaluationTargetPurpose" :label="p.purposeName"
- :value="p.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6" style="width: 350px;">
- <el-form-item label="评估对象:" prop="evaluationTypeId" label-width="120px" class="postInfo-container-item">
- <el-select v-model="targetForm.evaluationTypeId" @change="getTypeList(targetForm.evaluationTypeId, 2)">
- <el-option v-for="(t, id) in assetsEvaluationTargetType" :label="t.typeName" :value="t.id"
- :key="t.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :xs="4" :sm="12" :lg="12" :span="6">
- <el-form-item prop="evaluationTypeSecId" label-width="10px" class="postInfo-container-item">
- <el-select v-model="targetForm.evaluationTypeSecId">
- <el-option v-for="(t, id) in assetsSecEvaluationTargetType" :label="t.typeName" :value="t.id"
- :key="t.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6" style="width: 345px;">
- <el-form-item label="产权持有人:" prop="theHolder" label-width="120px" class="postInfo-container-item">
- <el-input v-model="targetForm.theHolder" class="filter-item" />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="价值类型:" prop="assetsValueId" label-width="120px" class="postInfo-container-item">
- <el-select v-model="targetForm.assetsValueId">
- <el-option v-for="(t, id) in assetsValueType" :label="t.typeName" :value="t.id" :key="t.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6" style="width: 400px;">
- <el-form-item label="项目负责人:" label-width="120px" class="postInfo-container-item">
- <el-select v-model="targetForm.principalId" placeholder="请选择" readonly disabled>
- <el-option v-for="(u, id) in allUsers" :label="u.name" :value="u.id" :key="u.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="实勘人:" prop="siteIds" label-width="120px" class="postInfo-container-item">
- <el-select v-model="targetForm.siteIds" placeholder="请选择" readonly disabled multiple>
- <el-option v-for="(u, id) in allUsers" :label="u.name" :value="u.id" :key="u.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="7" :span="6">
- <el-form-item prop="valuationBasisDate" label-width="120px" label="估价基准日:" class="postInfo-container-item">
- <el-date-picker v-model="targetForm.valuationBasisDate" type="date" placeholder="选择日期" style="width:100%">
- </el-date-picker>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="评估方法:" prop="evaluationMethodId" label-width="120px" class="postInfo-container-item">
- <el-select v-model="targetForm.evaluationMethodId">
- <el-option v-for="(m, id) in assetsEvaluationMethod" :label="m.methodName" :value="m.id"
- :key="m.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="最终选择的评估方法:" prop="choiceEvaluationMethodId" label-width="200px"
- class="postInfo-container-item">
- <el-select v-model="targetForm.choiceEvaluationMethodId">
- <el-option v-for="(m, id) in assetsEvaluationMethod" :label="m.methodName" :value="m.id"
- :key="m.id"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="总资产账面值:" prop="totalAssetCarryingAmount" label-width="140px"
- class="postInfo-container-item">
- <el-input-number v-model="targetForm.totalAssetCarryingAmount" controls-position="right" :precision="2"
- :step="0.1"></el-input-number>
- <span>(万)</span>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="总负债账面值:" prop="totalLiabilitiesCarryingAmount" label-width="140px"
- class="postInfo-container-item">
- <el-input-number v-model="targetForm.totalLiabilitiesCarryingAmount" controls-position="right"
- :precision="2" :step="0.1"></el-input-number>
- <span>(万)</span>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="净资产账面值:" prop="carryingAmountOfNetAssets" label-width="140px"
- class="postInfo-container-item">
- <el-input-number v-model="targetForm.carryingAmountOfNetAssets" controls-position="right" :precision="2"
- :step="0.1"></el-input-number>
- <span>(万)</span>
- </el-form-item>
- </el-col>
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="评估结论对应的评估值:" prop="estimatedValue" label-width="200px" class="postInfo-container-item">
- <el-input-number v-model="targetForm.estimatedValue" controls-position="right" :precision="2"
- :step="0.1"></el-input-number>
- <span>(万)</span>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style" v-if="currentNode.nodeCode === 'REVIEW_QUOTATION'">
- <el-col :xs="24" :sm="12" :lg="12" :span="6">
- <el-form-item label="审核定价:" prop="checkValue" label-width="200px" class="postInfo-container-item">
- <el-input-number v-model="targetForm.checkValue" controls-position="right" :precision="2"
- :step="0.1"></el-input-number>
- <span>(万)</span>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="18" :span="6">
- <el-form-item prop="filePath" label="资料附件:" label-width="120px" class="postInfo-container-item">
- <el-upload action="/api/upload" :limit="3" :on-success="changeres" :on-exceed="handleExceed"
- :on-preview="handleAttachmentPreview" :before-remove="beforeRemove" :file-list="fileList">
- <el-button plain type="info" round style="width: 100%">上传附件<i
- class="el-icon-upload el-icon--right"></i></el-button>
- </el-upload>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-col :xs="24" :sm="12" :lg="23" :span="12">
- <el-form-item label="备注:" prop="remark" label-width="120px" class="postInfo-container-item">
- <el-input v-model="targetForm.remark" :autosize="{ minRows: 4, maxRows: 4 }" class="filter-item"
- type="textarea" />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row class="row-style">
- <el-button v-if="saveButtonStatus" @click="assetsTargetSave" style="width:100%;">保存</el-button>
- <el-button v-if="updateButtonStatus" @click="assetsTargetUpdate" style="width:100%;">更新</el-button>
- </el-row>
- </el-form>
- </div>
- </el-dialog>
- </div>
- </template>
- <script>
- import YDetailPageLayout from '@/components/YDetailPageLayout/index_detail'
- import WorkflowBoard from '@/components/workflowBoard'
- import { isNumber, phoneNumber, postiveInteger, isIdNumber } from '@/utils/validate'
- import { calculateTargetPrice, validateParams } from '@/utils/personalUtil'
- export default {
- name: 'assetsDetail',
- components: {
- YDetailPageLayout,
- WorkflowBoard
- },
- data() {
- return {
- editStatus: false,
- // 资产业务表单禁用状态
- disabledStatus: true,
- // 评估对象表单禁用状态
- targetDisabledStatus: true,
- // 评估对象表单保存按钮显示状态
- saveButtonStatus: true,
- // 评估对象表单更新按钮显示状态
- updateButtonStatus: true,
- couldEdit: null,
- couldBack: null,
- // 表单项目隐藏字段
- itemHideStatus: false,
- createLinkmanVisible: false,
- // 文件上传数组
- fileList: [],
- // 资产业务下单表单校验规则
- assetsFormRules: {
- clientManager: [
- { required: true, message: '客户经理不能为空', trigger: 'blur' }
- ],
- departmentId: [
- { required: true, message: '请选择接单部门', trigger: 'change' }
- ],
- name: [
- { required: true, message: '项目名称不能为空', trigger: 'blur' }
- ],
- assetsBusinessGener: [
- { required: true, message: '请选择业务类型', trigger: 'change' }
- ],
- entrustAgain: [
- { required: true, message: '请选择客户是否再次委托', trigger: 'change' }
- ],
- clienteleType: [
- { required: true, message: '请选择客户类型', trigger: 'change' }
- ],
- clienteleId: [
- { required: true, message: '请选择客户名称', trigger: 'change' }
- ],
- clienteleSubId: [
- { required: true, message: '请选择业务来源', trigger: 'change' }
- ],
- clienteleContactId: [
- { required: true, message: '请选择客户联系人', trigger: 'change' }
- ],
- security: [
- { required: true, message: '请选择是否证券项目', trigger: 'change' }
- ],
- significantAssetsReorganization: [
- { required: true, message: '请选择是否资产重组项目', trigger: 'change' }
- ],
- stateAssets: [
- { required: true, message: '请选择是否是否国资项目', trigger: 'change' }
- ],
- foreignAssetsInvolved: [
- { required: true, message: '请选择是否 是否涉及境外资产', trigger: 'change' }
- ],
- dispenseBenefit: [
- { required: true, message: '请选择是否是否分配产值', trigger: 'change' }
- ],
- terminalClienteleType: [
- { required: true, message: '请选择终端客户类型', trigger: 'change' }
- ],
- terminalClienteleId: [
- { required: true, message: '终端客户名称不能为空', trigger: 'blur' }
- ],
- terminalClienteleContactId: [
- { required: true, message: '终端联系人不能为空', trigger: 'blur' }
- ]
- },
- workflowLogs: [],
- activeName: 'workflowInfo',
- activeTagName: "baseInfo",
- nodeBusinessInfo: {
- currentNodePermission: {
- commit: true,
- reversible: true,
- restartable: true,
- terminable: true,
- skippable: true,
- },
- mainBusiness: "ASSET_BUSINESS",
- doWorkflow: true,
- businessId: null,
- currentNodeInstanceId: null,
- currentNodeInstanceCode: null,
- production: [],
- businessSubId: null,
- ifFeedback: null
- },
- currentNode: {
- flowId: null,
- pnodeId: null,
- nodeId: null,
- flowCode: null,
- nodeName: "",
- nodeCode: null,
- state: "",
- instanceId: null,
- sequence: null,
- restartable: null,
- reversible: null,
- skippable: null,
- terminable: null,
- tasks: []
- },
- assetsForm: {
- // 项目名
- name: null,
- // 客户经理id
- clientManagerId: this.$store.getters.userInfo.id,
- // 客户经理
- clientManagerName: this.$store.getters.userInfo.name,
- // 接单部门id
- departmentId: null,
- // 资产业务类型
- assetsBusinessGener: null,
- // 客户再次委托
- entrustAgain: null,
- // 客户类型(企业,个人)
- clienteleType: null,
- // 客户id
- clienteleId: null,
- // 业务来源(下级客户id)
- clienteleSubId: null,
- // 客户联系人id
- clienteleContactId: null,
- // 是否证券项目
- security: null,
- // 是否资产重组项目
- significantAssetsReorganization: null,
- // 是否国资项目
- stateAssets: null,
- // 是否涉及境外资产
- foreignAssetsInvolved: null,
- // 是否分配产值
- dispenseBenefit: null,
- // 委托人
- bailor: null,
- // 委托人地址
- bailorAddress: null,
- // 委托联系人姓名
- bailorContactName: null,
- // 委托人联系人电话
- bailorContactTel: null,
- // 终端客户id
- terminalClienteleId: null,
- // 终端客户类型
- terminalClienteleType: null,
- // 终端联系人id
- terminalClienteleContactId: null,
- // 备注
- remark: null,
- // 终端联系电话
- tmobile: null,
- // 分单类型
- allotType: "指派",
- // 项目成员
- members: null,
- },
- // 客户联系人信息
- linkmanInfo: {
- },
- //
- pageParams: {
- },
- // 业务类型下拉列表
- assetsBusinessGeners: [
- {
- value: '单项资产',
- label: '单项资产'
- }, {
- value: '整体资产',
- label: '整体资产'
- }, {
- value: '无形资产',
- label: '无形资产'
- }, {
- value: '债权',
- label: '债权'
- }, {
- value: '其他',
- label: '其他'
- }
- ],
- // 接单部门
- allotDepartment: [],
- // 客户信息
- customerCompany: [],
- // 业务信息(二级客户)
- subCustomerCompany: [],
- // 客户联系人下拉列表
- customerContract: [],
- // 终端客户下拉列表
- tCustomerCompany: [],
- // 终端联系人下拉列表
- tCustomerContract: [],
- // 项目负责人下拉列表
- principals: [],
- // 用户下拉列表
- allUsers: [],
- // 资产评估对象信息
- assetsEvaluationTarget: [],
- // 估计对象总价
- totalEvaluateValue: 0.00,
- // 评估对象表单
- targetForm: {
- // 资产评估目的id
- evaluationPurposeId: null,
- // 资产评估对象类型一级id
- evaluationTypeId: null,
- // 资产评估对象类型二级id
- evaluationTypeSecId: null,
- // 产权持有人
- theHolder: null,
- // 资产价值类型id
- assetsValueId: null,
- // 项目负责人id
- principalId: null,
- // 实勘人id (json 可多个)
- siteIds: [],
- // 估价基准日
- valuationBasisDate: null,
- // 评估方法id
- evaluationMethodId: null,
- // 最终选择的评估方法id
- choiceEvaluationMethodId: null,
- // 总资产账面值(万)
- totalAssetCarryingAmount: null,
- // 总负债账面值(万)
- totalLiabilitiesCarryingAmount: null,
- // 净资产账面值(万)
- carryingAmountOfNetAssets: null,
- // 评估结论对应的评估值(万)
- estimatedValue: null,
- // 审核价格
- checkValue: null,
- // 资料路由信息
- filePath: [],
- // 资产业务id
- assetsId: null
- },
- targetFormBack: {
- evaluationPurposeId: null,
- evaluationTypeId: null,
- evaluationTypeSecId: null,
- theHolder: null,
- assetsValueId: null,
- principalId: null,
- siteIds: [],
- valuationBasisDate: null,
- evaluationMethodId: null,
- choiceEvaluationMethodId: null,
- totalAssetCarryingAmount: null,
- totalLiabilitiesCarryingAmount: null,
- carryingAmountOfNetAssets: null,
- estimatedValue: null,
- checkValue: null,
- filePath: [],
- assetsId: null
- },
- // 资产评估对象评估目的
- assetsEvaluationTargetPurpose: [],
- // 资产评估方法
- assetsEvaluationMethod: [],
- // 资产价值类型
- assetsValueType: [],
- // 资产评估对象类型
- assetsEvaluationTargetType: [],
- // 二级资产评估对象类型
- assetsSecEvaluationTargetType: [],
- // 评估对象弹窗可视状态
- targetDialogVisible: false,
- // 添加评估对象表单校验规则
- targetFormRules: {
- evaluationPurposeId: [
- { required: true, message: '请选择评估目的', trigger: 'change' }
- ],
- evaluationTypeId: [
- { required: true, message: '请选择评估对象', trigger: 'change' }
- ],
- evaluationTypeSecId: [
- { required: true, message: '请选择评估对象', trigger: 'change' }
- ],
- theHolder: [
- { required: true, message: '请填写产权持有人', trigger: 'blur' }
- ],
- assetsValueId: [
- { required: true, message: '请选择价值类型', trigger: 'change' }
- ],
- principalId: [
- { required: true, message: '请选择项目负责人', trigger: 'change' }
- ],
- siteIds: [
- { required: true, message: '请选择实勘人', trigger: 'change' }
- ],
- valuationBasisDate: [
- { required: true, message: '请选择价格基准日', trigger: 'change' }
- ],
- evaluationMethodId: [
- { required: true, message: '请选择评估方法', trigger: 'change' }
- ],
- choiceEvaluationMethodId: [
- { required: true, message: '请选择最终选择的评估方法', trigger: 'change' }
- ],
- totalAssetCarryingAmount: [
- { required: true, message: '请填写总资产账面值', trigger: 'blur' }
- ],
- totalLiabilitiesCarryingAmount: [
- { required: true, message: '请填写总负债账面值', trigger: 'blur' }
- ],
- carryingAmountOfNetAssets: [
- { required: true, message: '请填写净资产账面值', trigger: 'blur' }
- ],
- estimatedValue: [
- { required: true, message: '请填写评估结论对应的评估值', trigger: 'blur' }
- ],
- filePath: [
- { required: true, message: '请上传附件资料', trigger: 'change' }
- ]
- },
- // 款项信息
- invoiceData: {
- businessId: null,
- shouldAmount: null,
- realAmount: null,
- leftAmount: null,
- title: null,
- type: null,
- taxNo: null,
- bankName: null,
- bankAddress: null,
- bankTel: null
- },
- // 节点任务提交dto
- taskRecordDTO: {
- recordId: null,
- taskData: {}
- }
- }
- },
- watch: {
- },
- created() {
- this.couldEdit = true;
- this.couldBack = true;
- // 获取页面参数
- this.pageParams = this.$route.query;
- this.getCurrentNodeInfo();
- this.getAllotDepartment();
- this.getCustomerCompany(0);
- this.getCustomerCompany(1);
- this.getAssetsDetailById(this.pageParams.id);
- },
- methods: {
- // 根据业务id获取资产业务详情
- getAssetsDetailById(id) {
- this.$api.assets.getAssetsDetailById(id).then(res => {
- if (res.code === 200) {
- this.assetsForm = res.data;
- this.assetsForm.members = JSON.parse(res.data.members);
- this.initCustomerSelect(this.assetsForm.clienteleType);
- this.getPrincipalByAllotDepartment();
- this.getAllUser();
- this.$refs.board.getInstanceQueue();
- }
- })
- },
- handleChange() {
- },
- workflowCommitVerify(val, callback) {
- let commit = val.commit;
- let verify = new Object();
- verify.state = true;
- verify.cleanReport = false;
- verify.nextHandlerId = this.secondCheckUserId;
- if (commit.state === 'PASS') {
- let nodeCode = this.currentNode.nodeCode;
- this.getProductions(this.majorId, (this.reportNo == null ? this.statementNo : this.reportNo));
- switch (nodeCode) {
- case 'WRITE_STATEMENT':
- let notTakeNumberTargets = this.evaluateLandData.filter(function (e) {
- return e.statementNo == null;
- })
- if (notTakeNumberTargets.length > 0) {
- this.$notify({
- title: '提示',
- message: '还有价值意见书号未取的估价对象,请先完成取号操作。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- if (typeof (commit.businessSubId) == 'undefined' || commit.businessSubId == null || commit.ifCheckTask == null) {
- this.$notify({
- title: '提示',
- message: '请选择一个产品后,再进行流程提交。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- let selected = this.productions.filter(function (e) {
- return e.reportNo === commit.businessSubId
- })
- if (!selected[0].name) {
- this.$notify({
- title: '提示',
- message: '请完成所选产品的基本信息后,再进行流程提交。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- break;
- case 'WRITE_REPORT':
- let notTakeReportNoTargets = this.evaluateLandData.filter(function (e) {
- return e.reportNo == null;
- })
- if (notTakeReportNoTargets.length > 0) {
- this.$notify({
- title: '提示',
- message: '还有报告号未取的估价对象,请先完成取号操作。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- if (typeof (commit.businessMinId) == 'undefined' || commit.businessMinId == null || commit.ifCheckTask == null) {
- this.$notify({
- title: '提示',
- message: '请选择一个产品后,再进行流程提交。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- let selected1 = this.productions.filter(function (e) {
- return e.reportNo === commit.businessMinId
- })
- if (!selected1[0].name) {
- this.$notify({
- title: '提示',
- message: '请完成所选产品的基本信息后,再进行流程提交。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- break;
- case 'WRITE_LETTER':
- let notTakeLetterNumberTargets = this.evaluateLandData.filter(function (e) {
- return e.letterNo == null;
- })
- if (notTakeLetterNumberTargets.length > 0) {
- this.$notify({
- title: '提示',
- message: '还有复评函号未取的估价对象,请先完成取号操作。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- if (typeof (commit.businessMinId) == 'undefined' || commit.businessMinId == null || commit.ifCheckTask == null) {
- this.$notify({
- title: '提示',
- message: '请选择一个产品后,再进行流程提交。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- let selected2 = this.productions.filter(function (e) {
- return e.reportNo === commit.businessMinId
- })
- if (!selected2[0].name) {
- this.$notify({
- title: '提示',
- message: '请完成所选产品的基本信息后,再进行流程提交。',
- type: 'error',
- duration: 3000
- });
- verify.state = false;
- callback(verify);
- return;
- }
- break;
- case "CHECK_STATEMENT":
- case "CHECK_REPORT":
- case "CHECK_LETTER":
- if (!verify.nextHandlerId) {
- verify.state = false;
- callback(verify);
- this.chooseSecondCheckerDialog = true
- this.$api.dictData.remark("MAJOR_SECOND_CHECK_USERS").then(res => {
- if (res.code === 200) {
- this.secondCheckUsers = res.data;
- //默认复审人
- this.secondCheckUserId = res.data[0].remark;
- }
- })
- return;
- }
- }
- callback(verify);
- }
- let specialNodesForReverse = ["WRITE_STATEMENT", "WRITE_REPORT", "WRITE_LETTER"];
- if (commit.state === 'REVERSE' && specialNodesForReverse.includes(this.currentNode.nodeCode)) {
- this.$refs.board.getPreviousNode();
- let reportNos = this.evaluateLandData.map(item => item.reportNo);
- //取了子号不能退回节点
- if (this.pNode.nodeCode === "QUOTATION_FEEDBACK" && reportNos[0].includes("-")) {
- this.$notify({
- title: '提示',
- message: '该订单已取了其他子号,不能退回节点。',
- type: 'info',
- duration: 3000
- });
- verify.state = false;
- verify.cleanReport = false;
- callback(verify);
- }
- if (this.pNode.nodeCode === "QUOTATION_FEEDBACK" && !reportNos[0].includes("-")) {
- verify.cleanReport = true;
- callback(verify);
- }
- callback(verify);
- }
- },
- goBack() {
- const back = this.$route.query.back
- if (back) {
- this.$router.push(back)
- }
- },
- handleClick(tab) {
- },
- // 改变客户类型时进行值重置的操作
- changeCustomerType(val) {
- // 清空联系人下拉列表
- this.assetsForm.clienteleContactId = null;
- this.assetsForm.clienteleSubId = null;
- this.customerContract = [];
- if (val === "企业") {
- this.getCustomerCompany(0);
- this.itemHideStatus = true;
- } else {
- this.getCustomerContract(1);
- this.itemHideStatus = false;
- }
- },
- initCustomerSelect(val) {
- if (val === "企业") {
- this.getCustomerCompany(0);
- this.getCustomerContract();
- this.itemHideStatus = true;
- } else {
- this.getCustomerContract(1);
- this.itemHideStatus = false;
- }
- },
- // 获取部门下拉列表
- getAllotDepartment() {
- this.$api.department.allot().then(res => {
- if (res.code === 200) {
- this.allotDepartment = res.data;
- }
- })
- },
- // 获取客户信息
- getCustomerCompany(val) {
- if (val === 0) {
- let simpleAll = new Object();
- simpleAll.terminal = val;
- this.$api.customerCompany.simpleAll(simpleAll).then(res => {
- if (res.code === 200) {
- this.customerCompany = res.data;
- this.findSubClientele(0);
- }
- })
- } else {
- let simpleAll = new Object();
- simpleAll.terminal = val;
- this.$api.customerCompany.simpleAll(simpleAll).then(res => {
- if (res.code === 200) {
- this.tCustomerCompany = res.data;
- }
- })
- }
- },
- // 打开新建客户联系人弹窗
- createLinkman(val) {
- // 打开前判断是否已经选择客户信息
- if (this.targetFassetsFormorm.clienteleType === "个人" || this.assetsForm.clienteleType != null && this.assetsForm.clienteleId != null && this.assetsForm.clienteleSubId != null) {
- this.createLinkmanVisible = true;
- this.linkmanFrom.terminal = val;
- this.linkmanFrom.clienteleType = this.assetsForm.clienteleType;
- this.linkmanFrom.clienteleId = this.assetsForm.clienteleId;
- this.linkmanFrom.clienteleSubId = this.assetsForm.clienteleSubId;
- if (this.assetsForm.clienteleType === '企业') {
- this.linkmanFrom.ccId = this.assetsForm.clienteleSubId
- } else {
- this.assetsForm.clienteleSubId = 1;
- this.linkmanFrom.ccId = this.assetsForm.clienteleSubId;
- }
- } else {
- this.$notify({
- title: '警告',
- message: '请先选择客户!',
- type: 'warning',
- duration: 2000
- });
- }
- },
- // 获取客户联系人列表
- getCustomerContract(val) {
- // if (this.assetsForm.clienteleSubId) {
- let simpleAll = new Object();
- simpleAll.terminal = 0;
- if (val === 1) {
- simpleAll.ccId = val;
- } else {
- simpleAll.ccId = this.assetsForm.clienteleSubId;
- }
- this.$api.customerLinkman.simpleAll(simpleAll).then(res => {
- if (res.code === 200) {
- this.customerContract = res.data;
- }
- })
- // }
- },
- // 获取二级客户信息(业务来源)
- findSubClientele(val) {
- if (val === 0) {
- if (this.assetsForm.clienteleId) {
- let simpleAll = new Object();
- simpleAll.terminal = val;
- simpleAll.parentId = this.assetsForm.clienteleId;
- this.$api.customerCompany.simpleAll(simpleAll).then(res => {
- if (res.code === 200) {
- this.subCustomerCompany = res.data;
- }
- })
- }
- } else {
- if (this.assetsForm.terminalClienteleId) {
- let simpleAll = new Object();
- simpleAll.terminal = val;
- simpleAll.ccId = this.assetsForm.terminalClienteleId;
- this.$api.customerCompany.detail(this.assetsForm.terminalClienteleId).then(res => {
- if (res.code === 200) {
- this.assetsForm.tmobile = res.data.phone;
- }
- })
- }
- }
- },
- // 打开新增终端客户弹窗
- createTerminalClient() {
- this.createTerminalClientVisible = true;
- },
- // 根据部门id获取项目负责人列表
- getPrincipalByAllotDepartment() {
- let departmentId = this.assetsForm.departmentId;
- if (departmentId) {
- this.$api.user.usersByDepartmentId(departmentId).then(res => {
- if (res.code === 200) {
- this.principals = res.data;
- }
- })
- }
- },
- // 获取用户下拉列表
- getAllUser() {
- this.$api.user.simpleAll().then(res => {
- if (res.code === 200) {
- this.allUsers = res.data;
- }
- })
- },
- // 获取流程节点信息
- getCurrentNodeInfo() {
- if (this.pageParams.id) {
- this.$api.workNodeInstance.currentNode({ "mainBusiness": "ASSET_BUSINESS", "businessId": this.pageParams.id, "businessSubId": this.pageParams.businessSubId, "businessMinId": this.pageParams.businessMinId }).then(res => {
- if (res.code === 200) {
- if (res.data) {
- this.currentNode = res.data;
- this.nodeBusinessInfo.currentInstanceNodeId = res.data.instanceId;
- this.nodeBusinessInfo.currentNodeInstanceCode = res.data.nodeCode;
- this.nodeBusinessInfo.currentNodePermission.restartable = res.data.restartable;
- this.nodeBusinessInfo.currentNodePermission.reversible = res.data.reversible;
- this.nodeBusinessInfo.currentNodePermission.skippable = res.data.skippable;
- this.nodeBusinessInfo.currentNodePermission.terminable = res.data.terminable;
- this.nodeBusinessInfo.businessId = this.pageParams.id;
- }
- }
- })
- }
- },
- // 修改项目负责人与项目成员信息
- updatePrincipalAndMembers() {
- let assetsPrincipalMembers = new Object();
- assetsPrincipalMembers.id = this.assetsForm.id;
- assetsPrincipalMembers.principalId = this.assetsForm.principalId;
- assetsPrincipalMembers.members = JSON.stringify(this.assetsForm.members);
- this.taskRecordDTO.recordId = this.currentNode.tasks[0].recordId;
- this.taskRecordDTO.taskData = assetsPrincipalMembers;
- this.$api.assets.updatePrincipalAndMembers(this.taskRecordDTO).then(res => {
- if (res.code === 200 && res.data) {
- this.$notify({
- title: '成功',
- message: '保存成功,请提交节点继续流程。',
- type: 'success',
- duration: 2000
- });
- }
- })
- },
- // 根据节点返回不同的操作按钮信息
- hanlderType() {
- if (this.currentNode) {
- if (this.currentNode.nodeCode === 'SPOT_RECONNAISSANCE') {
- return "编辑";
- }
- if (this.currentNode.nodeCode === 'INITIAL_PRICE') {
- return "定价";
- }
- if (this.currentNode.nodeCode === 'REVIEW_QUOTATION') {
- return "审核定价";
- }
- return "查看";
- }
- },
- // 根据资产业务id获取资产业务评估对象集合
- getAETargetListByAssetsId() {
- this.$api.assets.getAETargetListByAssetsId(this.assetsForm.id).then(res => {
- if (res.code === 200) {
- this.assetsEvaluationTarget = res.data;
- }
- })
- },
- // 获取所有资产评估目的集合
- getPurpose() {
- this.$api.assets.getPurpose().then(res => {
- if (res.code === 200) {
- this.assetsEvaluationTargetPurpose = res.data;
- }
- })
- },
- // 获取所有评估方法集合
- getAssetsEvaluationMethod() {
- this.$api.assets.getAssetsEvaluationMethod().then(res => {
- if (res.code === 200) {
- this.assetsEvaluationMethod = res.data;
- }
- })
- },
- // 获取所有资产价值类型
- getAssetsValueType() {
- this.$api.assets.getAssetsValueType().then(res => {
- if (res.code === 200) {
- this.assetsValueType = res.data;
- }
- })
- },
- // 根据父级id获取资产评估对象类型(id可为空)
- getTypeList(val, level) {
- let parentId = val;
- // 每次进入方法清空二级下拉选择
- // this.targetForm.evaluationTypeSecId = null;
- this.assetsSecEvaluationTargetType = [];
- this.$api.assets.getTypeList(parentId).then(res => {
- if (res.code === 200) {
- if (level == 1) {
- // 等级为1赋值给assetsEvaluationTargetType
- this.assetsEvaluationTargetType = res.data;
- } else {
- // 其他赋值给assetsEvaluationTargetType
- this.assetsSecEvaluationTargetType = res.data;
- }
- }
- })
- },
- // 打开新增评估对象弹窗表单
- openTargetDialog() {
- // 可视状态为true
- this.targetDialogVisible = true;
- // 初始表单所需信息
- this.targetForm.principalId = this.assetsForm.principalId;
- this.targetForm.siteIds = this.assetsForm.members;
- if (this.assetsEvaluationTargetPurpose.length == 0 || this.assetsEvaluationMethod.length == 0 || this.assetsValueType.length == 0 || this.assetsEvaluationTargetType.length == 0) {
- this.getPurpose();
- this.getAssetsEvaluationMethod();
- this.getAssetsValueType();
- this.getTypeList(0, 1);
- }
- },
- // 文件选择改变触发事件
- changeres(res, file, fileList) {
- // 上传成功向表单附件信息数组添加信息
- if (res.code === 200) {
- this.targetForm.filePath.push({ name: file.name, url: res.data.url });
- } else {
- this.$notify({
- title: '错误',
- message: '电子文档上传失败',
- type: 'error',
- duration: 2000
- });
- }
- },
- // 文件上传数量限制
- handleExceed() {
- this.$message.warning(`当前限制选择 3个文件!`);
- },
- // 打开Windows文件选择器
- handleAttachmentPreview(file) {
- window.open(file.url)
- },
- // 移除文件
- beforeRemove(file, fileList) {
- fileList = fileList.filter((o) => {
- return o.name !== file.name
- });
- this.targetForm.filePath = this.targetForm.filePath.filter((o) => {
- return o.name !== file.name
- });
- },
- resettargetForm() {
- this.targetForm = this.targetFormBack;
- this.fileList = [];
- },
- clear() {
- if (this.$refs.targetForm !== undefined) {
- this.$refs.targetForm.clearValidate();
- }
- },
- // 保存新增资产业务评估对象
- assetsTargetSave() {
- this.$refs.targetForm.validate(valid => {
- if (valid) {
- this.targetForm.assetsId = this.targetForm.id;
- this.targetForm.siteIds = JSON.stringify(this.targetForm.siteIds);
- this.targetForm.filePath = JSON.stringify(this.targetForm.filePath);
- this.$api.assets.assetsTargetSave(this.targetForm).then(res => {
- if (res.code === 200) {
- this.$notify({
- title: '成功',
- message: '添加资产业务评估对象成功!',
- type: 'success',
- duration: 2000
- });
- setTimeout(() => {
- this.targetDialogVisible = false;
- //获取评估对象列表
- this.getAETargetListByAssetsId();
- }, 2000);
- }
- })
- }
- })
- },
- // 根据id获取资产评估对象详情
- getAssetsTargetDetail(id) {
- this.$api.assets.getAssetsTargetDetail(id).then(res => {
- if (res.code === 200) {
- this.targetForm = res.data;
- this.targetForm.siteIds = JSON.parse(res.data.siteIds);
- this.targetForm.filePath = JSON.parse(res.data.filePath);
- this.fileList = this.targetForm.filePath
- this.getTypeList(this.targetForm.evaluationTypeId, 2);
- this.openTargetDialog();
- }
- })
- },
- // 更新资产评估对象
- assetsTargetUpdate() {
- this.$refs.targetForm.validate(valid => {
- if (valid) {
- this.targetForm.assetsId = this.targetForm.id;
- this.targetForm.siteIds = JSON.stringify(this.targetForm.siteIds);
- this.targetForm.filePath = JSON.stringify(this.targetForm.filePath);
- this.$api.assets.assetsTargetUpdate(this.targetForm).then(res => {
- if (res.code === 200) {
- this.$notify({
- title: '成功',
- message: '更新资产业务评估对象成功!',
- type: 'success',
- duration: 2000
- });
- setTimeout(() => {
- this.targetDialogVisible = false;
- //获取评估对象列表
- this.getAETargetListByAssetsId();
- }, 2000);
- }
- })
- }
- })
- },
- // 删除资产评估对象
- assetsTargetDelete(id) {
- this.$api.assets.assetsTargetDelete(id).then(res => {
- if (res.code === 200) {
- this.$notify({
- title: '成功',
- message: '删除资产业务评估对象成功!',
- type: 'success',
- duration: 2000
- });
- this.getAETargetListByAssetsId();
- }
- })
- },
- // 根据不同情况打开的评估对象表单可编辑状态不同
- changeStatus(val) {
- if (val == "edit") {
- this.targetDisabledStatus = false;
- this.updateButtonStatus = true;
- this.saveButtonStatus = false;
- } else if (val == "add") {
- this.targetDisabledStatus = false;
- this.saveButtonStatus = true;
- this.updateButtonStatus = false;
- } else if (val == "detail") {
- this.targetDisabledStatus = true;
- this.saveButtonStatus = false;
- this.updateButtonStatus = false;
- }
- },
- // 根据业务id获取资产业务款项信息
- getOrderFundInvoiceById() {
- this.$api.assets.getOrderFundInvoiceById(this.assetsForm.id).then(res => {
- if (res.code === 200) {
- if (res.data != null) {
- this.invoiceData = res.data;
- this.invoiceData.leftAmount = this.invoiceData.shouldAmount - this.invoiceData.realAmount;
- }
- }
- })
- },
- // 提交节点
- commit(state) {
- this.$refs.board.commit(state);
- },
- getPreviousNode(pNode) {
- this.pNode = pNode;
- }
- }
- }
- </script>
- <style lang="scss" scoped>
- .row-style {
- margin-left: 40px;
- margin-right: 1%;
- }
- .major-radio {
- width: 92px
- }
- .task-class {
- /deep/ .el-form-item__label {
- color: red;
- }
- }
- .evaluate-table {
- margin-left: 40px;
- margin-top: 35px;
- }
- .pane-class {
- height: 800px;
- width: 100%;
- overflow-y: scroll;
- }
- /deep/ .cell-class {
- font-size: 13px;
- color: black;
- }
- .table {
- /deep/ thead {
- .el-table-column--selection {
- .cell {
- display: none;
- }
- }
- }
- }
- /deep/.doWarehouseClass {
- border-radius: 10px;
- }
- .button-area {
- position: absolute;
- top: 20px;
- right: 50px;
- }
- .error-type {
- margin-right: 5px;
- }
- .error-type:hover {
- cursor: pointer;
- }
- .box-card {
- margin-top: 40px
- }
- .time {
- font-size: 13px;
- color: #999;
- float: right;
- margin-top: 5px;
- }
- .bottom {
- margin-top: 13px;
- line-height: 12px;
- }
- .button {
- float: left;
- }
- .image {
- width: 100%;
- padding: 0%;
- display: block;
- }
- .control {
- z-index: 999;
- position: relative;
- top: 10px;
- }
- </style>
|