123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749 |
- <template>
- <basic-container>
- <div class="h-100p">
- <el-tabs
- v-model="activeType"
- :before-leave="beforeLeave"
- >
- <el-tab-pane
- label="项目基本信息"
- name="1"
- :disabled="btnLoad"
- >
- <div>
- <el-form
- :model="projectForm"
- :rules="projectRules"
- ref="projectForm"
- label-width="120px"
- >
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="项目名称"
- prop="projectName"
- >
- <el-input v-model="projectForm.projectName"></el-input>
- </el-form-item>
- <el-form-item
- label="项目别名"
- prop="projectAlias"
- >
- <el-input v-model="projectForm.projectAlias"></el-input>
- </el-form-item>
- <el-form-item
- label="项目编号"
- prop="projectNumber"
- >
- <el-input v-model="projectForm.projectNumber"></el-input>
- </el-form-item>
- <el-form-item
- label="公路等级"
- prop="projectGrade"
- >
- <el-select
- v-model="projectForm.projectGrade"
- placeholder="请选择"
- class="w-100p"
- >
- <el-option
- v-for="item in highwayGradeList"
- :key="item.id"
- :label="item.dictValue"
- :value="item.dictKey"
- ></el-option>
- </el-select>
- </el-form-item>
- <el-form-item
- label="计划开工日期"
- prop="planStartTime"
- >
- <el-date-picker
- v-model="projectForm.planStartTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- <el-form-item
- label="实际开工日期"
- prop="actualStartTime"
- >
- <el-date-picker
- v-model="projectForm.actualStartTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- <el-form-item
- label="项目预算投资"
- prop="estimatedAmount"
- >
- <el-input v-model="projectForm.estimatedAmount">
- <template slot="append">万元</template>
- </el-input>
- </el-form-item>
- <el-form-item
- label="电签类别"
- prop="remarkType"
- >
- <el-radio-group v-model="projectForm.remarkType">
- <el-radio :label="1">安心签</el-radio>
- <el-radio :label="2">东方中讯</el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item
- label="电签方式"
- prop="approvalType"
- >
- <el-radio-group v-model="projectForm.approvalType">
- <el-radio :label="1">流程审批</el-radio>
- <el-radio :label="2">平行审批</el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item
- label="系统计量单元"
- prop="projectGrade"
- >
- <el-select
- v-model="projectForm.meterTemplateId"
- placeholder="请选择"
- class="w-100p"
- >
- <el-option
- v-for="item in meterTemplateOption"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="项目概况"
- prop="projectGist"
- >
- <el-input
- v-model="projectForm.projectGist"
- type="textarea"
- :rows="7"
- ></el-input>
- </el-form-item>
- <el-form-item
- label="内置里程"
- prop="projectAllMileage"
- >
- <el-radio-group v-model="radioType">
- <el-radio-button label="总里程"></el-radio-button>
- <el-radio-button label="路面"></el-radio-button>
- <el-radio-button label="路基"></el-radio-button>
- </el-radio-group>
- <el-input-number
- v-model="projectForm.projectAllMileage"
- v-show="radioType == '总里程'"
- :min="0"
- label="总里程"
- ></el-input-number>
- <el-input-number
- v-model="projectForm.projectPavement"
- v-show="radioType == '路面'"
- :min="0"
- label="路面"
- ></el-input-number>
- <el-input-number
- v-model="projectForm.projectSubgrade"
- v-show="radioType == '路基'"
- :min="0"
- label="路基"
- ></el-input-number>
- <span>公里(KM)</span>
- </el-form-item>
- <el-form-item
- label="计划完工日期"
- prop="planEndTime"
- >
- <el-date-picker
- v-model="projectForm.planEndTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- <el-form-item
- label="实际完工日期"
- prop="actualEndTime"
- >
- <el-date-picker
- v-model="projectForm.actualEndTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- <el-form-item
- label="开启随机数"
- prop="isOpenRandomNumber"
- >
- <el-radio-group v-model="projectForm.isOpenRandomNumber">
- <el-radio :label="0">不开启</el-radio>
- <el-radio :label="1">开启</el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item v-if="false"
- label="是否为省级模板"
- prop="isOpenRandomNumber"
- >
- <el-radio-group v-model="projectForm.isOpenRandomNumber" >
- <el-radio :label="1">是</el-radio>
- <el-radio :label="0">否</el-radio>
- </el-radio-group>
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- </div>
- </el-tab-pane>
- <el-tab-pane
- label="分配WBS模版"
- name="2"
- :disabled="btnLoad"
- >
- <div>
- <div class="text-align-c">
- <el-radio-group
- v-model="templateType"
- @change="templateTypeChange"
-
- >
- <el-radio :label="2">试验</el-radio>
- <el-radio :label="1">质检</el-radio>
- <el-radio :label="5">征拆</el-radio>
- <el-radio :label="6">计量</el-radio>
-
- </el-radio-group>
- </div>
- <div class="text-align-c mg-t-20" >
- <span class="mg-r-20">选择WBS</span>
- <el-select
- v-model="wbsId"
- @change='wbsChange'
- :disabled="iswbsselected"
- placeholder="请选择WBS"
- style="width:500px;"
- >
- <el-option-group
- v-for="group in treeList"
- :key="group.label"
- :label="group.label"
- >
- <el-option
- v-for="(item,index) in group.options"
- :key="index"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-option-group>
- </el-select>
- </div>
- <tree-tree
- :left-tree-data="leftTreeData"
- scrollbarStyle="height:calc(100vh - 500px)"
- ref="treetotree"
- :show-all-check="true"
- @onAddTree="treeChang"
- @onDelTree="treeChang"
- @onCheckAll="treeChang"
- :leftloading="leftloading"
- :rightloading="rightloading"
-
- ></tree-tree>
- </div>
- </el-tab-pane>
- <el-tab-pane
- label="分配日志WBS"
- name="3"
- :disabled="btnLoad"
- >
- <div>
- <div class="text-align-c mg-t-20">
- <span class="mg-r-20">选择WBS</span>
- <el-select
- v-model="logWbsId"
- @change="logWbsChange"
- :disabled="selected"
- placeholder="请选择WBS"
- style="width:500px;"
- >
- <el-option-group
- v-for="group in logTreeList"
- :key="group.label"
- :label="group.label"
- >
- <el-option
- v-for="(item,index) in group.options"
- :key="index"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-option-group>
- </el-select>
- </div>
- <tree-tree
- :left-tree-data="logLeftTreeData"
- ref="treetotree2"
- :show-all-check="true"
- @onAddTree="treeChang3"
- @onDelTree="treeChang3"
- @onCheckAll="treeChang3"
- :leftloading="logleftloading"
- :rightloading="logrightloading"
- scrollbarStyle="height:calc(100vh - 500px)"
- ></tree-tree>
- </div>
- </el-tab-pane>
- <el-tab-pane
- label="分配系统维护人员"
- name="4"
- :disabled="btnLoad"
- >
- <div>
- <div class="flex jc-al-c">
- <span class="mg-r-10">项目名称</span>
- <el-input
- v-model="projectForm.projectName"
- disabled
- style="width:300px;margin-right:30px;"
- ></el-input>
- <span class="mg-r-10">合同段名称</span>
- <el-select
- v-model="cId"
- placeholder="请选择"
- @change="getUserByCondition"
- >
- <el-option
- label="全部"
- value=""
- ></el-option>
- <el-option
- v-for="item in contractList"
- :key="item.id"
- :label="item.contractName"
- :value="item.id"
- ></el-option>
- </el-select>
- </div>
- <el-divider></el-divider>
- <div class="flex jc-al-c mg-b-10">
- <span>维护人员角色</span>
- <avue-input-tree
- class="marleft10"
- :check-strictly="true"
- v-model="rId"
- placeholder="请选择"
- type="tree"
- :dic="roleList"
- :props="treeProps"
- @change="getUserByCondition"
- ></avue-input-tree>
- <!-- <el-select v-model="rId" clearable placeholder="请选择" @change="getUserByCondition">
- <el-option v-for="item in roleList" :key="item.id" :label="item.title" :value="item.id"></el-option>
- </el-select> -->
- </div>
- <div>
- <el-table
- :data="contractUserList"
- border
- height="420"
- style="width: 100%"
- >
- <el-table-column
- prop="name"
- label="姓名"
- align="center"
- ></el-table-column>
- <el-table-column
- prop="contractName"
- label="合同段名称"
- align="center"
- ></el-table-column>
- <el-table-column
- prop="postName"
- label="岗位"
- align="center"
- ></el-table-column>
- <el-table-column
- prop="phone"
- label="电话"
- align="center"
- ></el-table-column>
- <el-table-column
- label="操作"
- align="center"
- >
- <template slot-scope="scope">
- <el-button
- size="mini"
- type="danger"
- @click="handleDelete(scope.$index, scope.row)"
- >删除</el-button>
- </template>
- </el-table-column>
- </el-table>
- </div>
- <div class="martop10 flexEnd">
- <el-pagination
- background
- @size-change="handleSizeChange"
- @current-change="handleCurrentChange"
- :current-page.sync="pageindx"
- :page-size="pagesize"
- layout="total, prev, pager, next"
- :total="total"
- >
- </el-pagination>
- </div>
- <div class="flex jc-al-c mg-t-20">
- <span>添加系统内部人员</span>
- <el-select
- class="marleft10"
- v-model="userId"
- filterable
- placeholder="请输入搜索"
- >
- <el-option
- v-for="item in userList"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- ></el-option>
- </el-select>
- <el-button
- type="success"
- class="marleft10"
- @click="addUserToProject"
- >添加</el-button>
- <el-button
- type="primary"
- @click="rputerPush()"
- >创建新用户</el-button>
- <el-button
- type="danger"
- @click="handleDeletes"
- >全部删除</el-button>
- </div>
- <el-divider></el-divider>
- </div>
- </el-tab-pane>
- </el-tabs>
- <div class="flexEnd">
- <el-button
- :type="activeType != 4?'info':'success'"
- size="medium"
- :disabled="saveBtnDisabled
- || leftloading || logleftloading
- || rightloading || logrightloading"
- :loading="saveBtnLoad"
- @click="saveQuit"
- >保存并退出</el-button>
- <el-button
- type="info"
- size="medium"
- :disabled="saveBtnBackDisabled
- || leftloading || logleftloading
- || rightloading || logrightloading"
- :loading="saveBtnBackLoad"
- v-if="activeType != 1"
- @click="saveNext('p')"
- >保存并返回上一步</el-button>
- <el-button
- type="success"
- size="medium"
- :disabled="saveBtnNextDisabled
- || leftloading || logleftloading
- || rightloading || logrightloading"
- :loading="saveBtnNextLoad"
- v-if="activeType != 4"
- @click="saveNext('n')"
- >保存并进入下一步</el-button>
- </div>
- </div>
- </basic-container>
- </template>
- <script>
- import {
- submitProject, getProjectDeatil, findWbsTreeList, findProjectTree,
- submitWbsTreeInProject, getProjectDeatilWbsId, findLogWbsTreeList, submitLogWbsTreeInProject
- } from "@/api/manager/projectinfo";
- import {
- findContractByProjectId, saveUserInfoByProject, findUserListByCondition,
- findUserByName, removeUsersByIds
- } from "@/api/manager/contractinfo";
- import { getRoleTree } from "@/api/system/role";
- import { getAlltree } from "@/api/manager/wbstree";
- import { getDictionary } from "@/api/system/dict";
- import { mapGetters } from "vuex";
- import treeTree from "@/components/tree-tree/main"
- import { findUserList } from "@/api/manager/contractinfo";
- import { queryBusinessUserOpinionList } from "@/api/measure/template.js";
- export default {
- components: {
- treeTree
- },
- data () {
- var checkDate = (rule, value, callback) => {
- if (value && this.projectForm.planStartTime) {
- if (Date.parse(value) < Date.parse(this.projectForm.planStartTime)) {
- callback(new Error('计划完工日期不能小于开工日期'));
- }
- }
- callback();
- };
- var checkDate2 = (rule, value, callback) => {
- if (value && this.projectForm.actualStartTime) {
- if (Date.parse(value) < Date.parse(this.projectForm.actualStartTime)) {
- callback(new Error('实际完工日期不能小于开工日期'));
- }
- }
- callback();
- };
- var checkIsNumber = (rule, value, callback) => {
- if (value != Number(value)) {
- callback(new Error('金额必须是数字'));
- }
- if (value && 999999999999999999 < Number(value)) {
- callback(new Error('数字过大'));
- }
- callback();
- };
- var checkMileage = (rule, value, callback) => {
- if (this.projectForm.projectPavement || this.projectForm.projectSubgrade) {
- if (this.projectForm.projectPavement) {
- if (this.projectForm.projectPavement > value) {
- callback(new Error('总里程必须是最大的'));
- }
- } else if (this.projectForm.projectSubgrade) {
- if (this.projectForm.projectSubgrade > value) {
- callback(new Error('总里程必须是最大的'));
- }
- }
- if (this.projectForm.projectPavement && this.projectForm.projectSubgrade) {
- if ((this.projectForm.projectPavement + this.projectForm.projectSubgrade) > value) {
- callback(new Error('总里程必须大于两项总和'));
- }
- }
- }
- callback();
- };
- return {
- //#region
- pageindx: 1,
- pagesize: 10,
- total: 0,
- //#endregion
- activeType: '1',
- typeChang: {
- 1: false,
- 2: false,
- 3: false,
- 4: false,
- },
- btnLoad: false,
- saveBtnLoad: false,
- saveBtnDisabled: false,
- saveBtnBackLoad: false,
- saveBtnBackDisabled: false,
- saveBtnNextLoad: false,
- saveBtnNextDisabled: false,
- id: '',
- highwayGradeList: [],
- meterTemplateOption:[],//计量单元列表
- radioType: '总里程',
- projectForm: {
- estimatedAmount: 0,
- isOpenRandomNumber:1,
- approvalType:2
- },
- projectRules: {
- projectName: [
- { required: true, message: '请输入项目名称', trigger: 'blur' },
- ],
- projectAlias: [
- { required: true, message: '请输入项目别名', trigger: 'blur' },
- ],
- planStartTime: [{ required: true, message: '请选择计划开工日期', trigger: 'blur' },],
- planEndTime: [
- { validator: checkDate, trigger: 'blur' }
- ],
- actualEndTime: [
- { validator: checkDate2, trigger: 'blur' }
- ],
- estimatedAmount: [
- { validator: checkIsNumber, trigger: 'blur' }
- ],
- projectAllMileage: [
- { validator: checkMileage, trigger: 'blur' }
- ],
- remarkType: [
- { required: true, message: '请选择电签类别', trigger: 'blur' },
- ]
- },
- contractList: [],
- cId: '',
- rId: '',
- roleList: [],
- userId: '',
- userList: [],
- contractUserList: [],
- treeProps: {
- label: "dictValue",
- value: "id"
- },
- templateType: 1,
- treeList: [],
- logTreeList: [],
- wbsId: '',
- iswbsselected:true,//右边有数据禁用下拉框选择
- logWbsId: '',
- selected: false,
- leftTreeData: [],
- logLeftTreeData: [],
- leftloading:false,
- rightloading:false,
- logleftloading:false,
- logrightloading:false,
- selectData:{},
- isFirst:false,
- rightTreeData:[],//存储右边的试验树数据
- rightTreeData1:[],//存储右边的质检树数据
- rightTreeData2:[],//存储征拆数据
-
- rightObj:[
-
- ],
- rightObj1:[
-
- ],
- rightObj2:[
-
- ],
- nowref:{},
- finalWbsid:'',
- finalIds:''
-
- }
- },
- computed: {
- ...mapGetters(["userInfo"]),
- },
- watch: {
- projectForm: {
- immediate:false,
- handler: function () { // 此处注意,handler函数不能为箭头函数,this会取上下文,而不是组件里的this,此外,深度监听,必须为handler函数名,否则会无效果
- // this.typeChang['1'] = true;
- if(this.isFirst===false){
- this.typeChang['1'] = true;
- }
- },
- deep: true
- },
- activeType: function (newValue) {
-
- if (newValue == '4') {
- this.getContractList();
- this.getRoleList();
- this.getUserByCondition();
- this.getUserByName();
- } else if (newValue == '2') {
- this.treeInit();
-
- } else if (newValue == '3') {
- this.treeLogInit();
- }
- }
- },
- created () {
- this.init();
- //console.log(this.userInfo)
- },
- mounted () {
- this.$nextTick(() => {
- this.typeChang = {
- 1: false,
- 2: false,
- 3: false,
- 4: false,
- }
- })
- },
- methods: {
- //#region //后加分页
- handleSizeChange (val) {
- this.pagesize = val
- this.getUserByCondition();
- },
- handleCurrentChange (val) {
- this.pageindx = val
- this.getUserByCondition();
- },
- rputerPush () {
- this.$router.push({
- path: '/system/user',
- query: { tankai: true }
- })
- },
- //#endregion
- init () {
- this.getHighwayGradeList();
- this.getMeterTemplateOption()
- this.id = this.$route.query.id;
- if (this.id) {
- this.getProjectDeatil();
- }
- },
- beforeLeave (activeName, oldActiveName) {
- return new Promise((resolve, reject) => {
- if (oldActiveName == '1' && !this.projectForm.id) {
- this.$message({
- type: "warning",
- message: "请先保存项目后,再进行项目的分配"
- });
- // reject();
- }
- if (this.typeChang[oldActiveName]) {
- this.$confirm('检测到新编辑内容, 是否保存?', '提示', {
- confirmButtonText: '确定',
- cancelButtonText: '不用',
- type: 'warning'
- }).then(() => {
- switch (oldActiveName) {
- case '1':
- this.saveProject().then((res) => {
- this.projectForm.id = res.data.data.id;
- this.typeChang[oldActiveName] = false;
- resolve();
- this.$message({
- type: "success",
- message: "保存成功!"
- });
- });
- break;
- case '2':
- this.saveWbsTree().then(() => {
- this.typeChang[oldActiveName] = false;
- resolve();
- this.$message({
- type: "success",
- message: "保存成功!"
- });
- }).catch(() => {
- console.log("beforeLeave catch getRightTree")
- this.getRightTree();
- reject();
- })
- break;
- }
- }).catch(() => {
- this.typeChang[oldActiveName] = false;
- resolve();
- })
- } else {
- resolve();
- }
- })
- },
- getProjectDeatil () {
- getProjectDeatil(this.id).then((res) => {
- const data = res.data.data
- console.log(data)
- this.projectForm = data;
- this.isFirst=true;
- setTimeout(() => {
- this.isFirst=false;
- }, 1000);
- console.log(data,'data项目详情');
- this.selectData={
- referenceWbsTemplateId:data.referenceWbsTemplateId,//质检
- referenceWbsTemplateIdLar:data.referenceWbsTemplateIdLar,//征拆
- referenceWbsTemplateIdTrial:data.referenceWbsTemplateIdTrial===-1?'':data.referenceWbsTemplateIdTrial//试验
- }
- if (Number(this.projectForm.estimatedAmount) < 0) {
- this.projectForm.estimatedAmount = 0
- }
- this.$nextTick(() => {
- this.typeChang['1'] = false;
- })
- let templateType = 'public';
- if (this.projectForm.referenceWbsTemplateType) {
- templateType = this.projectForm.referenceWbsTemplateType;
- }
- getProjectDeatilWbsId(this.id, this.projectForm.referenceWbsTemplateId, templateType).then((res) => {
- this.projectForm.wbsType = res.data.data.wbsType;
- })
- })
- },
- async saveQuit () {
- console.log('保存2',this.selectData);
- this.btnLoad = true;
- this.saveBtnLoad = true;
- this.saveBtnBackDisabled = true
- this.saveBtnNextDisabled = true
- try {
- if (this.activeType == '1') {
- await this.saveProject();
- } else if (this.activeType == '2') {
- await this.saveWbsTree();
- } else if (this.activeType == '3'){
- await this.saveLogWbsTree();
- }
- } catch (error) {
- this.btnLoad = false;
- this.saveBtnLoad = false;
- this.saveBtnBackDisabled = false
- this.saveBtnNextDisabled = false
- if(this.activeType == '2'){
- console.log("saveQuit getRightTree")
- this.getRightTree();
- }
- return;
- }
- this.$message({
- type: "success",
- message: "保存成功!"
- });
- this.btnLoad = false;
- this.saveBtnLoad = false;
- this.saveBtnBackDisabled = false
- this.saveBtnNextDisabled = false
- this.$router.go(-1);
- },
- async saveNext (type) {
- console.log('保存',this.activeType,this.selectData);
- this.btnLoad = true;
- if (type == 'n') {
- this.saveBtnNextLoad = true;
- this.saveBtnBackDisabled = true
- this.saveBtnDisabled = true
- } else if (type == 'p') {
- this.saveBtnBackLoad = true;
- this.saveBtnNextDisabled = true
- this.saveBtnDisabled = true
-
- }
- try {
- if (this.activeType == '1') {
- let res = await this.saveProject();
- this.projectForm.id = res.data.data.id;
- } else if (this.activeType == '2') {
-
- await this.saveWbsTree();
- } else if (this.activeType == '3'){
- await this.saveLogWbsTree();
- if(type == 'p'){
- console.log(this.wbsId,'wbsis');
- }
-
- }
- } catch (error) {
- this.btnLoad = false;
- if (type == 'n') {
- this.saveBtnNextLoad = false;
- this.saveBtnBackDisabled = false
- this.saveBtnDisabled = false
- } else if (type == 'p') {
- this.saveBtnBackLoad = false;
- this.saveBtnNextDisabled = false
- this.saveBtnDisabled = false
- }
- if(this.activeType == '2'){
- console.log("saveNext getRightTree")
- this.getRightTree();
- // this.templateType=1
- }
- return;
- }
- this.$message({
- type: "success",
- message: "保存成功!"
- });
- this.typeChang[this.activeType] = false;
- let num = Number(this.activeType);
- if (type == 'n') {
- num++;
- } else if (type == 'p') {
- num--;
- }
- this.activeType = num.toString();
- this.btnLoad = false;
- if (type == 'n') {
- this.saveBtnNextLoad = false;
- this.saveBtnBackDisabled = false
- this.saveBtnDisabled = false
- } else if (type == 'p') {
- this.saveBtnBackLoad = false;
- this.saveBtnNextDisabled = false
- this.saveBtnDisabled = false
- }
- },
- saveProject () {
- console.log('保存3',this.selectData);
- return new Promise((resolve, reject) => {
- this.$refs['projectForm'].validate((valid) => {
- if (valid) {
- resolve(submitProject(this.projectForm))
- } else {
- reject('验证失败')
- }
- })
- })
- },
- saveLogWbsTree() {
- let ids = this.$refs.treetotree2.getTreeAllId('rightTree');
- let obj = {
- wbsId: this.logWbsId,
- projectId: this.projectForm.id,
- wbsType: "4",
- wbsTreeIds: ids
- };
- return submitLogWbsTreeInProject(obj);
- },
- saveWbsTree () {
- let obj = {};
- let ids = this.$refs.treetotree.getTreeAllId('rightTree');
- // if(this.finalWbsid.length>0){
- // this.wbsId=this.finalWbsid
- // }
- console.log(this.finalIds,'finalIds');
- obj = {
- wbsId: this.wbsId,
- projectId: this.projectForm.id,
- wbsType: this.templateType,
- wbsTreeIds: ids
- }
-
-
- console.log(this.wbsId,'this.wbsId最终');
- console.log(this.projectForm,'projectForm');
- if (this.wbsId.toString().indexOf(',') >= 0) {
- //私有库
- obj.referenceType = "private";
- let ids = this.wbsId.toString().split(',');
- // obj.wbsId = this.finalWbsid;
- obj.wbsId = ids[0];
- obj.referencePrivateWbsProjectId = ids[1];
- obj.primaryKeyId = this.leftTreeData[0].primaryKeyId;
- } else {
- //公有库
- obj.referenceType = "public";
- obj.wbsId = this.wbsId;
- // obj.wbsId = this.finalWbsid;
- }
- return submitWbsTreeInProject(obj);
- },
- addUserToProject () {
- if (!this.userId) {
- this.$message({
- type: "warning",
- message: "请先选择用户再进行添加"
- });
- return;
- }
- if (!this.rId) {
- this.$message({
- type: "warning",
- message: "请先选择维护人员角色再进行添加"
- });
- return;
- }
- let list = [{
- projectId: this.projectForm.id,
- contractId: this.cId ? this.cId : undefined,
- userId: this.userId,
- roleId: this.rId
- }];
- saveUserInfoByProject(list).then(() => {
- this.getUserByCondition();
- })
- },
- getUserByCondition () {
- findUserListByCondition({
- cId: this.cId,
- pId: this.projectForm.id,
- postId: '',
- rId: this.rId,
- size: this.pagesize,
- current: this.pageindx
- }).then((res) => {
- this.contractUserList = res.data.data.records;
- this.total = res.data.data.total
- })
- },
- getUserByName () {
- findUserList('').then((res) => {
- this.userList = res.data.data;
- })
- },
- handleDelete (index, row) {
- this.$confirm('是否将该用户移除出合同段', '提示', {
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- type: 'warning'
- }).then(() => {
- removeUsersByIds(row.id).then(() => {
- this.contractUserList.splice(index, 1);
- this.$message({
- type: "success",
- message: "删除成功!"
- });
- })
- })
- },
- handleDeletes () {
- this.$confirm('是否将所有用户移除出合同段', '提示', {
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- type: 'warning'
- }).then(() => {
- let ids = [];
- this.contractUserList.forEach((element) => {
- ids.push(element.id);
- })
- removeUsersByIds(ids.join(',')).then(() => {
- this.contractUserList = [];
- this.$message({
- type: "success",
- message: "删除成功!"
- });
- })
- })
- },
- getHighwayGradeList () {
- if (this.highwayGradeList.length > 1) {
- return;
- }
- getDictionary({
- code: 'highway_grade'
- }).then((res) => {
- // res.data.data.forEach(element => {
- // element.dictKey = Number(element.dictKey)
- // });
- this.highwayGradeList = res.data.data;
- })
- },
- getMeterTemplateOption(){
- queryBusinessUserOpinionList().then((res)=>{
- this.meterTemplateOption=res.data.data
- })
- },
- getContractList () {
- if (this.contractList.length < 1) {
- findContractByProjectId(this.projectForm.id).then((res) => {
- this.contractList = res.data.data;
- })
- }
- },
- getRoleList () {
- if (this.roleList.length > 1) {
- return;
- }
- getRoleTree().then((res) => {
- this.roleList = res.data.data
- })
- },
- logWbsChange(value){
- //公有库
- this.logleftloading = true;
- getAlltree(this.userInfo.tenant_id, '1', value).then((res) => {
- if (Array.isArray(res.data.data)) {
- this.logLeftTreeData = res.data.data;
- } else {
- this.logLeftTreeData = [];
- }
- this.logleftloading = false;
- })
- },
- wbsChange (value, flag) {
- console.log(value, 'WBS节点更换测试 value')
- this.iswbsselected=false
- if(this.templateType==1){
- this.selectData.referenceWbsTemplateId=value
- }else if(this.templateType==5){
- // this.selectData.referenceWbsTemplateId=value
- this.selectData.referenceWbsTemplateIdLar=value
- }
- else{
- this.selectData.referenceWbsTemplateIdTrial=value
- }
- this.leftloading = true;
- if (value&&value.toString().indexOf(',') >= 0) {
- console.log('私有库');
- //私有库
- if(this.templateType==1){
- this.projectForm.referenceWbsTemplateType='private'
- }else if(this.templateType==5){
- this.projectForm.referenceWbsTemplateTypeLar='private'
- }
- else{
- this.projectForm.referenceWbsTemplateTypeTrial='private'
- }
- let ids = value.toString().split(',');
- console.log(ids,'ids');
- findProjectTree(ids[1], ids[0]).then((res) => {
- if (Array.isArray(res.data.data)) {
- this.leftTreeData = res.data.data;
- } else {
- this.leftTreeData = [];
- }
- this.leftloading = false;
- })
- this.getRightTree()
- } else {
- console.log('公有库');
- //公有库
- if(value&&value.length>0){
- if(this.templateType==1){
- this.projectForm.referenceWbsTemplateType='public'
- }
- else if(this.templateType==5){
- this.projectForm.referenceWbsTemplateTypeLar='public'
- }else{
- this.projectForm.referenceWbsTemplateTypeTrial='public'
- }
- }
- getAlltree(this.userInfo.tenant_id, '1', value).then((res) => {
- if (Array.isArray(res.data.data)) {
- this.leftTreeData = res.data.data;
- console.log("this.leftTreeData", this.leftTreeData)
- } else {
- this.leftTreeData = [];
- }
- this.leftloading = false;
- })
- this.getRightTree()
- }
- if (flag === undefined) { /* 下拉框切换的时候调用 */
- this.getRightTree();
- }
-
- },
- getLogTreeList(){
- return new Promise((resolve) => {
- if (this.logTreeList.length) {
- resolve();
- }
- findLogWbsTreeList().then((res) => {
- let arr = [{
- label: '公有库',
- options: [],
- }];
- let data = res.data.data;
- if (data && data.length) {
- data.forEach((element) => {
- element.label = element.wbsName;
- element.value = element.id;
- })
- arr[0].options = data;
- }
- this.logTreeList = arr;
- }).finally(() => {
- resolve();
- })
- })
- },
- getTreeList () {
- console.log('getTreeList');
- return new Promise((resolve) => {
- if (this.treeList.length) {
- resolve();
- }
- findWbsTreeList(this.templateType).then((res) => {
- let arr = [{
- label: '公有库',
- options: [],
- },
- {
- label: '私有库',
- options: [],
- }];
- let data = res.data.data;
- if (data.wbsInfos && data.wbsInfos.length) {
- data.wbsInfos.forEach((element) => {
- element.label = element.wbsName;
- element.value = element.id;
- })
- arr[0].options = data.wbsInfos;
- }
- if (data.wbsTreePrivates && data.wbsTreePrivates.length) {
- data.wbsTreePrivates.forEach((element) => {
- element.label = element.projectName;
- element.value = element.wbsId + ',' + element.projectId;
- })
- arr[1].options = data.wbsTreePrivates;
- }
- this.treeList = arr;
- // this.wbsChange(this.wbsId, true)
- }).finally(() => {
- resolve();
- })
- })
- },
- //格式化wbsid
- formatWbsId(orid){
- let refId = orid;
- let WbsId=''
- if ((this.templateType == 1 && this.projectForm.referenceWbsTemplateType === 'private')
- || (this.templateType == 2 && this.projectForm.referenceWbsTemplateTypeTrial === 'private')
- || (this.templateType == 5 && this.projectForm.referenceWbsTemplateTypeLar === 'private')
-
- && refId != null && refId.toString().length > 0) {
- console.log(refId,'refId');
- // 私有库右边树形数据是通过 pkeyId 查询的
- let ids = refId.toString().split(",");
- console.log(ids,'ids');
- if (ids.length > 1) {
- refId = ids[0]
- console.log(refId,'refId');
- console.log(this.treeList,'treeList');
- let list = this.treeList[1].options;
- refId = list.filter(e => e.projectId == ids[1])[0].pkeyId;
- WbsId=refId
- }
- }else{
- console.log(3333333);
- WbsId=refId
- }
- return WbsId
-
- },
- treeChang () {
- let recordid= this.formatWbsId(this.wbsId)
- console.log(recordid,'recordid');
- if (this.templateType===2) {
- this.rightTreeData=this.$refs.treetotree.rightTreeData;
- // this.rightObj.push({
- // wbsid:this.wbsId,objdata: this.rightTreeData
- // })
- this.rightObj.wbsId=recordid
- this.rightObj.objdata=this.rightTreeData
- }else if(this.templateType===5){
- this.rightTreeData2=this.$refs.treetotree.rightTreeData
- this.rightObj2.wbsId=recordid
- this.rightObj2.objdata=this.rightTreeData2
- }
- else{
- this.rightTreeData1=this.$refs.treetotree.rightTreeData
- // this.rightObj1.push({
- // wbsid:this.wbsId,objdata: this.rightTreeData
- // })
- this.rightObj1.wbsId=recordid
- this.rightObj1.objdata=this.rightTreeData1
-
- }
-
- this.typeChang[2] = true;
- },
- treeChang3 () {
- this.typeChang[3] = true;
- },
- templateTypeChange () {
- findWbsTreeList(this.templateType).then((res) => {
- let arr = [
- {label: '公有库', options: []},
- {label: '私有库', options: []}
- ];
- let data = res.data.data;
- if (data.wbsInfos && data.wbsInfos.length) {
- data.wbsInfos.forEach((element) => {
- element.label = element.wbsName;
- element.value = element.id;
- })
- arr[0].options = data.wbsInfos;
- }
- if (data.wbsTreePrivates && data.wbsTreePrivates.length) {
- data.wbsTreePrivates.forEach((element) => {
- element.label = element.projectName;
- element.value = element.wbsId + ',' + element.projectId;
- })
- arr[1].options = data.wbsTreePrivates;
- }
- this.treeList = arr;
- this.wbsId = this.templateType == 1 ? this.selectData.referenceWbsTemplateId : this.selectData.referenceWbsTemplateIdTrial
- if(this.templateType===5){
- console.log('征拆选择');
- this.wbsId =this.selectData.referenceWbsTemplateIdLar
-
- }
- console.log(this.wbsId===-1);
- if(this.wbsId===-1){
- this.wbsId=''
- }
- this.wbsChange(this.wbsId, true)
- // if(this.treeList[0].options.length > 0){
- // this.wbsId = this.treeList[0].options[0].value;
- // this.wbsChange(this.wbsId)
- // }else if(this.treeList[1].options.length > 0){
- // this.wbsId = this.treeList[1].options[0].value;
- // this.wbsChange(this.wbsId)
- // }else{
- // this.wbsId = '';
- // this.leftTreeData = [];
- // }
- })
- },
- async treeLogInit(){
- let refId = this.projectForm.referenceLogWbsTemplateId;
- if(refId && refId > 0 && Number(this.projectForm.wbsType) > 0){
- await this.getLogTreeList();
- this.logWbsId = refId;
- this.logleftloading = true;
- let leftData = await getAlltree(this.userInfo.tenant_id, '1', refId);
- if (Array.isArray(leftData.data.data)) {
- this.logLeftTreeData = leftData.data.data;
- } else {
- this.logLeftTreeData = [];
- }
- this.logleftloading = false;
- this.logrightloading = true;
- let projectTree = await findProjectTree(this.projectForm.id, refId);
-
- this.$refs.treetotree2.setRightTree(Array.isArray(projectTree.data.data)?projectTree.data.data:[]);
- this.logrightloading = false;
- } else {
- await this.getLogTreeList();
- }
- },
- //初始化质量
- async treeInit () {
- console.log('------------------- treeInit ------------------------');
- let refId = this.selectData.referenceWbsTemplateId;
- console.log(refId, '------------------- treeInit.refId ------------------------');
-
- if (this.projectForm.referenceWbsTemplateType === 'private' && refId != null && refId.toString().length > 0) {
- // 私有库右边树形数据是通过 pkeyId 查询的
- let ids = refId.toString().split(",");
- if (ids.length > 1) {
- refId = ids[0]
- let list = this.treeList[1].options;
- refId = list.filter(e => e.projectId == ids[1])[0].pkeyId;
- }
- }
- //引用被删会出现 wbsType -1
- if (refId && refId > 0 && Number(this.projectForm.wbsType) > 0) {
- console.log('------------------- treeInit if------------------------');
- //有引用id,回显
- //this.selected = true;
- // this.templateType = this.projectForm.wbsType;
- await this.getTreeList();
- let priv = {};
- if (this.projectForm.referenceWbsTemplateType == 'private') {
- //私有
- let list = this.treeList[1].options;
- for (let i = 0; i < list.length; i++) {
- if (list[i].pkeyId == refId) {
- this.wbsId = list[i].wbsId + ',' + list[i].projectId;
- priv.wbsId = list[i].wbsId;
- priv.projectId = list[i].projectId;
- priv.value= list[i].value
- priv.pkeyId= list[i].pkeyId
- break;
- }
- }
- } else {
- //公有
- this.wbsId = refId;
- }
- if(this.templateType == 1){
- this.selectData.referenceWbsTemplateId =this.wbsId
- }else if(this.templateType==5){
- this.selectData.referenceWbsTemplateIdLar =this.wbsId
-
- }
- else{
- this.selectData.referenceWbsTemplateIdTrial=this.wbsId
- }
- this.nowref={
- value:priv.value,
- id: priv.pkeyId
- }
- let projectTree = await findProjectTree(this.projectForm.id, refId) //查询的右边的数据
- if (projectTree&&projectTree.data&&projectTree.data.data&&projectTree.data.data.length>0) {
- this.iswbsselected=true
- }else{
- this.iswbsselected=false
- }
- if (Array.isArray(projectTree.data.data)) {
- this.leftloading = true;
- this.rightloading = true;
- if (this.projectForm.referenceWbsTemplateType == 'private') {
- //私有
- let leftData = await findProjectTree(priv.projectId, priv.wbsId)
- if (Array.isArray(leftData.data.data)) {
- this.leftTreeData = leftData.data.data;
- } else {
- this.leftTreeData = [];
- }
- this.leftloading = false;
- } else {
- //公有
- let leftData = await getAlltree(this.userInfo.tenant_id, '1', refId)
- if (Array.isArray(leftData.data.data)) {
- this.leftTreeData = leftData.data.data;
- } else {
- this.leftTreeData = [];
- }
- this.leftloading = false;
- }
- this.$refs.treetotree.setRightTree(projectTree.data.data);
- console.log(projectTree.data.data,'projectTree.data.data');
-
- this.rightloading = false;
- }else{
- this.wbsId = '';
- }
- }
- else {
- console.log('------------------- treeInit else------------------------');
- this.getTreeList();
- this.iswbsselected=false
- }
- console.log(this.wbsId,'this.wbsId33333');
- this.treeInitTrial()
- this.treeInitLar()
- },
- //初始化征拆
- async treeInitLar () {
- let refId = this.selectData.referenceWbsTemplateIdLar;
- console.log(refId,'refId');
- //引用被删会出现 wbsType -1
- if (refId && refId > 0 && Number(this.projectForm.wbsType) > 0) {
- //有引用id,回显
- //this.selected = true;
- findWbsTreeList(5).then((res) => {
- let arr = [{
- label: '公有库',
- options: [],
- },
- {
- label: '私有库',
- options: [],
- }];
- let data = res.data.data;
- if (data.wbsInfos && data.wbsInfos.length) {
- data.wbsInfos.forEach((element) => {
- element.label = element.wbsName;
- element.value = element.id;
- })
- arr[0].options = data.wbsInfos;
- }
- if (data.wbsTreePrivates && data.wbsTreePrivates.length) {
- data.wbsTreePrivates.forEach((element) => {
- element.label = element.projectName;
- element.value = element.wbsId + ',' + element.projectId;
- })
- arr[1].options = data.wbsTreePrivates;
- }
- let WbsId = 0;
- if (this.projectForm.referenceWbsTemplateTypeLar == 'private') {
- //私有
- let list = arr[1].options;
- console.log(list,'list');
- for (let i = 0; i < list.length; i++) {
- if (list[i].pkeyId == refId) {
- WbsId = list[i].wbsId + ',' + list[i].projectId;
- break;
- }
- }
- } else {
- console.log('共有',refId);
- //公有
- WbsId = refId;
- }
- this.selectData.referenceWbsTemplateIdLar = WbsId
- console.log("征拆", this.selectData)
- })
- } else {
- this.getTreeList();
- }
- },
- //初始化试验
- async treeInitTrial () {
- console.log(this.wbsId,'wbsidshiyan');
- let refId = this.selectData.referenceWbsTemplateIdTrial;
- console.log(refId,'wbsidshiyan');
- //引用被删会出现 wbsType -1
- if (refId && refId > 0 && Number(this.projectForm.wbsType) > 0) {
- //有引用id,回显
- //this.selected = true;
- findWbsTreeList(2).then((res) => {
- let arr = [{
- label: '公有库',
- options: [],
- },
- {
- label: '私有库',
- options: [],
- }];
- let data = res.data.data;
- if (data.wbsInfos && data.wbsInfos.length) {
- data.wbsInfos.forEach((element) => {
- element.label = element.wbsName;
- element.value = element.id;
- })
- arr[0].options = data.wbsInfos;
- }
- if (data.wbsTreePrivates && data.wbsTreePrivates.length) {
- data.wbsTreePrivates.forEach((element) => {
- element.label = element.projectName;
- element.value = element.wbsId + ',' + element.projectId;
- })
- arr[1].options = data.wbsTreePrivates;
- }
- let WbsId = 0;
- if (this.projectForm.referenceWbsTemplateTypeTrial == 'private') {
- //私有
- let list = arr[1].options;
- for (let i = 0; i < list.length; i++) {
- if (list[i].pkeyId == refId) {
- WbsId = list[i].wbsId + ',' + list[i].projectId;
- break;
- }
- }
- } else {
- //公有
- WbsId = refId;
- }
- this.selectData.referenceWbsTemplateIdTrial = WbsId
- console.log("treeInitTrial", this.selectData)
- })
- } else {
- this.getTreeList();
- }
- },
- getRightTree() {
- this.rightloading = true;
- this.iswbsselected=true
- console.log(this.nowref,'nowrefId');
- let refId = this.templateType === 1? this.selectData.referenceWbsTemplateId : this.selectData.referenceWbsTemplateIdTrial;
- if(this.templateType===5){
- console.log(this.selectData.referenceWbsTemplateIdLar,1111111111);
- refId=this.selectData.referenceWbsTemplateIdLar;
- // this.$refs.treetotree.setRightTree([]);
- }
-
- console.log(refId,'refId');
- if(!refId){
- console.log('不存在refId');
- this.$refs.treetotree.setRightTree([]);
- this.iswbsselected=false
- }else{
- let WbsId=''
- if (this.projectForm.referenceWbsTemplateType === 'private' && refId != null && refId.toString().length > 0&&this.templateType===1) {
- // 私有库右边树形数据是通过 pkeyId 查询的
- let ids = refId.toString().split(",");
- console.log(ids,'ids111111');
- this.finalIds=ids
- if (ids.length > 1) {
- refId = ids[0]
- let list = this.treeList[1].options;
- refId = list.filter(e => e.projectId == ids[1])[0].pkeyId;
- console.log(refId,'refId');
-
- }
- }
- if (this.projectForm.referenceWbsTemplateTypeTrial === 'private' && refId != null && refId.toString().length > 0&&this.templateType===2) {
- // 私有库右边树形数据是通过 pkeyId 查询的
- let ids = refId.toString().split(",");
- console.log(ids,'试验');
- this.finalIds=ids
- if (ids.length > 1) {
- refId = ids[0]
- let list = this.treeList[1].options;
- refId = list.filter(e => e.projectId == ids[1])[0].pkeyId;
- console.log(refId,'refId');
-
- }
- }
- if (
- this.projectForm.referenceWbsTemplateTypeLar === 'private' && refId != null && refId.toString().length > 0 &&this.templateType===5) {
- // 私有库右边树形数据是通过 pkeyId 查询的
- let ids = refId.toString().split(",");
- console.log(ids,'征拆');
- this.finalIds=ids
- if (ids.length > 1) {
- refId = ids[0]
- let list = this.treeList[1].options;
- refId = list.filter(e => e.projectId == ids[1])[0].pkeyId;
- console.log(refId,'refId');
-
- }
- }
- //引用被删会出现 wbsType -1
- if (refId && refId > 0) {
- let priv = {};
- if (this.projectForm.referenceWbsTemplateType == 'private'&&this.templateType===1
- ||this.projectForm.referenceWbsTemplateTypeLar === 'private' &&this.templateType===5
- ||this.projectForm.referenceWbsTemplateTypeTrial === 'private'&&this.templateType===2) {
- //私有
- let list = this.treeList[1].options;
- for (let i = 0; i < list.length; i++) {
- if (list[i].pkeyId == refId) {
- refId = list[i].wbsId + ',' + list[i].projectId;
- priv.wbsId = list[i].wbsId;
- priv.projectId = list[i].projectId;
- priv.value= list[i].value
- priv.pkeyId= list[i].pkeyId
-
- break;
- }
- }
- } else {
- //公有
- WbsId = refId;
- }
- if(this.nowref.value===refId){
- console.log(11111111111);
- WbsId=this.nowref.id
- }else{
- if (this.projectForm.referenceWbsTemplateType == 'private'&& refId != null && refId.toString().length > 0 &&this.templateType==1) {
- WbsId = priv.pkeyId
- }
- else if (this.projectForm.referenceWbsTemplateTypeTrial == 'private'&& refId != null && refId.toString().length > 0 &&this.templateType==2) {
- WbsId =priv.pkeyId
- }
- else if (this.projectForm.referenceWbsTemplateTypeLar === 'private'&& refId != null && refId.toString().length > 0&&this.templateType==5) {
- WbsId = priv.pkeyId
- }
- else {//公有
- WbsId=this.templateType === 1 ?this.selectData.referenceWbsTemplateId: this.selectData.referenceWbsTemplateIdTrial
- if(this.templateType===5){
- WbsId=this.selectData.referenceWbsTemplateIdLar
- }
- }
- }
-
- this.finalWbsid=WbsId
- console.log(WbsId,'WbsId');
- console.log( this.finalWbsid,' this.finalWbsid=');
- // this.selectData.referenceWbsTemplateIdLar=WbsId
- console.log(this.selectData.referenceWbsTemplateIdLar,'this.selectData.referenceWbsTemplateIdLar');
- // findProjectTree(this.projectForm.id, this.templateType === 1 ? WbsId : this.selectData.referenceWbsTemplateIdTrial).then((res) => {
- findProjectTree(this.projectForm.id, WbsId).then((res) => {
- if (this.rightTreeData.length>0&&this.templateType===2&&this.rightObj.wbsId==WbsId) {
- this.$refs.treetotree.setRightTree(this.rightTreeData);
- }else if(this.rightTreeData1.length>0&&this.templateType===1&&this.rightObj1.wbsId==WbsId){
- this.$refs.treetotree.setRightTree(this.rightTreeData1);
- }else if(this.rightTreeData2.length>0&&this.templateType===5&&this.rightObj2.wbsId==WbsId){
- this.$refs.treetotree.setRightTree(this.rightTreeData2);
- }
- else{
- if (Array.isArray(res.data.data)) {
- if(res.data.data.length>0){
- this.iswbsselected=true
- }else{
- this.iswbsselected=false
- }
- console.log(11111111111);
- this.$refs.treetotree.setRightTree(res.data.data);
- } else {
- this.$refs.treetotree.setRightTree([]);
- this.iswbsselected=false
- }
- }
-
-
- })
-
-
- }
- }
- this.rightloading = false;
- },
- }
- };
- </script>
- <style scoped lang="scss">
- </style>
|