12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514 |
- <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-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"
- :disabled="selected"
- >
- <el-radio :label="2">试验</el-radio>
- <el-radio :label="1">质检</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="selected"
- 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";
- 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: [],
- radioType: '总里程',
- projectForm: {
- estimatedAmount: 0,
- isOpenRandomNumber:1
- },
- 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: '',
- logWbsId: '',
- selected: false,
- leftTreeData: [],
- logLeftTreeData: [],
- leftloading:false,
- rightloading:false,
- logleftloading:false,
- logrightloading:false,
- selectData:{},
- isFirst:false,
- rightTreeData:[],//存储右边的试验树数据
- rightTreeData1:[],//存储右边的质检树数据
-
- rightObj:[
-
- ],
- rightObj1:[
-
- ],
- nowref:{}
-
- }
- },
- 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.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,//质检
- 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();
- }
- } 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();
- }
- 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');
- obj = {
- wbsId: this.wbsId,
- projectId: this.projectForm.id,
- wbsType: this.templateType,
- wbsTreeIds: ids
- }
- if (this.wbsId.toString().indexOf(',') >= 0) {
- //私有库
- obj.referenceType = "private";
- let ids = this.wbsId.toString().split(',');
- obj.wbsId = ids[0];
- obj.referencePrivateWbsProjectId = ids[1];
- obj.primaryKeyId = this.leftTreeData[0].primaryKeyId;
- } else {
- //公有库
- obj.referenceType = "public";
- }
- 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;
- })
- },
- 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')
- if(this.templateType==1){
- this.selectData.referenceWbsTemplateId=value
- }else{
- this.selectData.referenceWbsTemplateIdTrial=value
- }
- this.leftloading = true;
- if (value&&value.toString().indexOf(',') >= 0) {
- //私有库
- if(this.templateType==1){
- this.projectForm.referenceWbsTemplateType='private'
- }else{
- this.projectForm.referenceWbsTemplateTypeTrial='private'
- }
- let ids = value.toString().split(',');
- 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 {
- //公有库
- if(value&&value.length>0){
- if(this.templateType==1){
- this.projectForm.referenceWbsTemplateType='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')
- && refId != null && refId.toString().length > 0) {
-
- console.log(1111111111111);
- 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{
- 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
- 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{
- this.selectData.referenceWbsTemplateIdTrial=this.wbsId
- }
- this.nowref={
- value:priv.value,
- id: priv.pkeyId
- }
- let projectTree = await findProjectTree(this.projectForm.id, refId) //查询的右边的数据
- 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);
- this.rightloading = false;
- }else{
- this.wbsId = '';
- }
- }
- else {
- console.log('------------------- treeInit else------------------------');
- this.getTreeList();
- }
- this.treeInitTrial()
- },
- //初始化试验
- async treeInitTrial () {
- let refId = this.selectData.referenceWbsTemplateIdTrial;
- //引用被删会出现 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;
- console.log(this.nowref,'nowrefId');
- let refId = this.templateType === 1 ? this.selectData.referenceWbsTemplateId : this.selectData.referenceWbsTemplateIdTrial;
- console.log(refId,'refId');
- if(!refId){
- console.log('不存在refId');
- this.$refs.treetotree.setRightTree([]);
- }else{
- let WbsId=''
- 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;
- console.log(refId,'refId');
-
- }
- }
- //引用被删会出现 wbsType -1
- if (refId && refId > 0) {
- 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) {
- 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){
- WbsId=this.nowref.id
- }else{
- if (this.projectForm.referenceWbsTemplateType == 'private' && refId != null && refId.toString().length > 0) {
- WbsId = priv.pkeyId||this.selectData.referenceWbsTemplateIdTrial
- }
- else {//公有
- WbsId=this.templateType === 1 ?this.selectData.referenceWbsTemplateId: this.selectData.referenceWbsTemplateIdTrial
- }
- }
-
-
- console.log(WbsId,'WbsId');
- // 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 (Array.isArray(res.data.data)) {
- this.$refs.treetotree.setRightTree(res.data.data);
- } else {
- this.$refs.treetotree.setRightTree([]);
- }
- }
-
-
- })
-
-
- }
- }
- this.rightloading = false;
- },
- }
- };
- </script>
- <style scoped lang="scss">
- </style>
|