123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155 |
- <template>
- <basic-container>
- <div>
- <el-tabs
- v-model="activeType"
- :before-leave="beforeLeave"
- >
- <el-tab-pane
- label="合同段信息"
- name="1"
- >
- <div>
- <el-form
- :model="contractForm"
- :rules="contractRules"
- ref="contractForm"
- label-width="120px"
- >
- <el-form-item label="项目名称">
- <el-input
- v-model="projectInfo.projectName"
- disabled
- ></el-input>
- </el-form-item>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="合同段类型"
- prop="contractType"
- >
- <el-select
- v-model="contractForm.contractType"
- placeholder="请选择"
- class="w-100p"
- >
- <el-option
- v-for="item in contractTypeList"
- :key="item.id"
- :label="item.dictValue"
- :value="item.dictKey"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="合同段编号"
- prop="contractNumber"
- >
- <el-input v-model="contractForm.contractNumber"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="合同段名称"
- prop="contractName"
- >
- <el-input v-model="contractForm.contractName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="参与方进场日期"
- prop="contractorJoinTime"
- >
- <el-date-picker
- v-model="contractForm.contractorJoinTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="计划开工日期"
- prop="planStartTime"
- >
- <el-date-picker
- v-model="contractForm.planStartTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="计划完工日期"
- prop="planEndTime"
- >
- <el-date-picker
- v-model="contractForm.planEndTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="实际开工日期"
- prop="actualStartTime"
- >
- <el-date-picker
- v-model="contractForm.actualStartTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="实际完工日期"
- prop="actualEndTime"
- >
- <el-date-picker
- v-model="contractForm.actualEndTime"
- type="date"
- format="yyyy 年 MM 月 dd 日"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期"
- ></el-date-picker>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="业主单位名称"
- prop="contractorUnitName"
- >
- <el-input v-model="contractForm.contractorUnitName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="合同金额"
- prop="contractAmount"
- >
- <el-input v-model="contractForm.contractAmount">
- <template slot="append">万元</template>
- </el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="施工单位名称"
- prop="constructionUnitName"
- >
- <el-input v-model="contractForm.constructionUnitName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="上传开工令"
- prop="startFileUrl"
- >
- <template v-if="isBackShow">
- <el-link
- type="primary"
- @click="downloadFile"
- >开工令</el-link>
- <el-button
- @click="delFile"
- class="mg-l-10"
- style="color:red"
- type="text"
- icon="el-icon-circle-close"
- ></el-button>
- </template>
- <template v-else>
- <el-upload
- action="/api/blade-resource/oss/endpoint/put-file-attach"
- :on-remove="handleRemove"
- :limit="1"
- :headers=headers
- :on-exceed="handleExceed"
- :on-success="handleSuccess"
- :file-list="fileList"
- >
- <el-button
- size="small"
- type="primary"
- >点击上传</el-button>
- </el-upload>
- </template>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="监理单位名称"
- prop="supervisionUnitName"
- >
- <el-input v-model="contractForm.supervisionUnitName"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="试验室名称"
- prop="laboratoryName"
- >
- <el-input v-model="contractForm.laboratoryName"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- <el-divider></el-divider>
- <el-row :gutter="20">
- <el-col :span="12">
- <div class="head-font">组卷归档默认信息</div>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="立卷人"
- prop="filer"
- >
- <el-input v-model="contractForm.filer"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="保管期限"
- prop="storagePeriod"
- >
- <el-select
- v-model="contractForm.storagePeriod"
- placeholder="请选择"
- class="w-100p"
- >
- <el-option
- v-for="item in storagePeriodList"
- :key="item.id"
- :label="item.dictValue"
- :value="item.dictKey"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="审核人"
- prop="reviewer"
- >
- <el-input v-model="contractForm.reviewer"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item
- label="保管密级"
- prop="securityLevel"
- >
- <el-select
- v-model="contractForm.securityLevel"
- placeholder="请选择"
- class="w-100p"
- >
- <el-option
- v-for="item in securityLevelList"
- :key="item.id"
- :label="item.dictValue"
- :value="item.dictKey"
- ></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="档案前缀"
- prop="prefix"
- >
- <el-input v-model="contractForm.prefix"></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- </el-col>
- </el-row>
- </el-col>
- <el-col :span="12">
- <div class="head-font">附加信息</div>
- <el-form-item
- label="项目地址"
- prop="projectPlace"
- >
- <!-- <el-input v-model="contractForm.projectPlace" placeholder="点击后面地图选取地址">
- <el-button slot="append" icon="el-icon-map-location" @click="mapDialogVisible = true"></el-button>
- </el-input> -->
- <avue-input-map
- :params="params"
- placeholder="请选择地图"
- v-model="flageData"
- @change="mapChange"
- ></avue-input-map>
- </el-form-item>
- <el-form-item
- label="起始桩号"
- prop="startStation"
- >
- <el-input v-model="contractForm.startStation"></el-input>
- </el-form-item>
- <el-form-item
- label="结束桩号"
- prop="endStation"
- >
- <el-input v-model="contractForm.endStation"></el-input>
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- </div>
- </el-tab-pane>
- <el-tab-pane
- label="分配WBS"
- name="2"
- >
- <div>
- <div
- v-if="!wbsId"
- class="text-align-c"
- >项目暂未分配wbs树</div>
- <tree-tree
- :left-tree-data="leftTreeData"
- ref="treetotree"
- @onAddTree="treeChang"
- @onDelTree="treeChang"
- ></tree-tree>
- </div>
- </el-tab-pane>
- <el-tab-pane
- label="分配项目人员"
- name="3"
- >
- <div>
- <div class="flex jc-al-c">
- <span class="mg-r-10">项目名称</span>
- <el-input
- v-model="projectInfo.projectName"
- disabled
- style="width:300px;margin-right:30px;"
- ></el-input>
- <span class="mg-r-10">合同段名称</span>
- <el-input
- v-model="contractForm.contractName"
- disabled
- style="width:300px;"
- ></el-input>
- </div>
- <el-divider></el-divider>
- <div class="flex jc-al-c mg-b-10">
- <div>
- <span class="mg-r-10">角色方</span>
- <el-radio-group v-model="rId">
- <el-radio-button
- v-for="(item,key) in roleList"
- :label="item.id"
- :key="key"
- >{{item.roleName}}</el-radio-button>
- </el-radio-group>
- </div>
- <div>
- <span class="mg-r-10 mg-l-20">请选择岗位</span>
- <el-select
- v-model="postId"
- filterable
- placeholder="请输入搜索"
- >
- <el-option
- v-for="item in postList"
- :key="item.id"
- :label="item.roleName"
- :value="item.id"
- ></el-option>
- </el-select>
- </div>
- </div>
- <!-- table表 -->
- <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="account"
- label="登录账号"
- align="center"
- ></el-table-column>
- <el-table-column
- prop="password"
- label="密码"
- align="center"
- ></el-table-column>
- <el-table-column
- label="操作"
- align="center"
- >
- <template slot-scope="scope">
- <el-link
- class="mg-r-20"
- type="primary"
- @click="copyAccPas(scope.row)"
- >复制</el-link>
- <el-link
- class="mg-r-20"
- type="primary"
- @click="resetPassword(scope.row)"
- >重置密码</el-link>
- <el-link
- type="danger"
- @click="handleDelete(scope.$index, scope.row)"
- >删除</el-link>
- </template>
- </el-table-column>
- </el-table>
- <el-input
- v-model="copyText"
- ref="copyInput"
- type="textarea"
- style='opacity: 0;position: absolute;height:1px;overflow:hidden;'
- ></el-input>
- </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
- class="marleft10"
- type="success"
- @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 marbottom20">
- <el-button
- type="success"
- size="medium"
- :loading="btnLoad"
- @click="saveQuit"
- >保存并退出</el-button>
- <el-button
- type="info"
- size="medium"
- :loading="btnLoad"
- v-if="activeType != 1"
- @click="saveNext('p')"
- >保存并返回上一步</el-button>
- <el-button
- type="info"
- size="medium"
- :loading="btnLoad"
- v-if="activeType != 3"
- @click="saveNext('n')"
- >保存并进入下一步</el-button>
- </div>
- </div>
- </basic-container>
- </template>
- <script>
- import { getProjectDeatil, findProjectTree } from "@/api/manager/projectinfo";
- import {
- submitContractInfo, getContractInfo, delFileFromUrl, searchRole, findAllUserByCondition, findUserByName,
- saveUserInfoByProjectTow, removeUsersByIds, resetPasswordByUserId,
- submitWbsTreeInContract, getContractInfoTree
- } from "@/api/manager/contractinfo";
- import { getDictionary } from "@/api/system/dict";
- import { getDictionary as getDictbiz } from "@/api/system/dictbiz";
- import { remove as removeFile } from "@/api/resource/attach";
- import website from '@/config/website';
- import { Base64 } from 'js-base64';
- import { getToken } from '@/util/auth';
- import { mapGetters } from "vuex";
- import treeTree from "@/components/tree-tree/main"
- export default {
- components: {
- treeTree
- },
- data () {
- var checkPlace = (rule, value, callback) => {
- if (this.flageData && this.flageData.length > 2 && this.flageData[2]) {
- callback();
- } else {
- callback(new Error('请选取项目地址'));
- }
- }
- var checkDate = (rule, value, callback) => {
- if (value && this.contractForm.planStartTime) {
- if (Date.parse(value) < Date.parse(this.contractForm.planStartTime)) {
- callback(new Error('计划完工日期不能小于开工日期'));
- }
- }
- callback();
- };
- var checkDate2 = (rule, value, callback) => {
- if (value && this.contractForm.actualStartTime) {
- if (Date.parse(value) < Date.parse(this.contractForm.actualStartTime)) {
- callback(new Error('实际完工日期不能小于开工日期'));
- }
- }
- callback();
- };
- var checkIsNumber = (rule, value, callback) => {
- if (value != Number(value)) {
- callback(new Error('金额必须是数字'));
- }
- callback();
- };
- return {
- //#region
- pageindx: 1,
- pagesize: 10,
- total: 0,
- //#endregion
- activeType: '1',
- typeChang: {
- 1: false,
- 2: false,
- 3: false,
- },
- btnLoad: false,
- pid: '',
- cid: '',
- projectInfo: {},
- contractTypeList: [],
- storagePeriodList: [],//保管期限
- securityLevelList: [],//保管密级
- fileList: [],
- headers: {},
- isBackShow: false,
- contractForm: {
- contractAmount: 0
- },
- contractRules: {
- contractName: [
- { required: true, message: '请输入合同段名称', trigger: 'blur' },
- ],
- contractType: [
- { required: true, message: '请选择合同段类型', trigger: 'change' }
- ],
- contractNumber: [
- { required: true, message: '请输入合同段编号', trigger: 'blur' },
- ],
- contractorUnitName: [
- { required: true, message: '请输入业主单位名称', trigger: 'blur' },
- ],
- constructionUnitName: [
- { required: true, message: '请输入施工单位名称', trigger: 'blur' },
- ],
- supervisionUnitName: [
- { required: true, message: '请输入监理单位名称', trigger: 'blur' },
- ],
- laboratoryName: [
- { required: true, message: '请输入实验室名称', trigger: 'blur' },
- ],
- startStation: [
- { required: true, message: '请输入起始桩号', trigger: 'blur' },
- ],
- endStation: [
- { required: true, message: '请输入结束桩号', trigger: 'blur' },
- ],
- projectPlace: [
- { required: true, validator: checkPlace, trigger: 'blur' },
- ],
- planEndTime: [
- { validator: checkDate, trigger: 'blur' },
- ],
- actualEndTime: [
- { validator: checkDate2, trigger: 'blur' },
- ],
- contractAmount: [
- { validator: checkIsNumber, trigger: 'blur' }
- ]
- },
- mapDialogVisible: false,
- params: {
- zoom: 10,
- // zoomEnable: false,
- // dragEnable: false,
- },
- flageData: [],
- rId: '',
- roleList: [],
- postId: '',
- postList: [],
- contractUserList: [],
- userId: '',
- userList: [],
- copyText: '',
- wbsId: '',
- leftTreeData: [],
- }
- },
- computed: {
- ...mapGetters(["userInfo"]),
- },
- watch: {
- contractForm: {
- handler: function () { // 此处注意,handler函数不能为箭头函数,this会取上下文,而不是组件里的this,此外,深度监听,必须为handler函数名,否则会无效果
- this.typeChang['1'] = true;
- },
- deep: true
- },
- activeType: async function (newValue) {
- if (newValue == '3') {
- this.getUserByName();
- this.searchRole()
- } else if (newValue == '2') {
- await this.getLeftTree();
- this.getRightTree();
- }
- },
- rId: function (newValue) {
- this.postId = ''
- this.roleList.forEach(val => {
- if (val.id === this.rId) {
- if (val.children) {
- this.postList = val.children
- } else {
- this.postList = []
- }
- } else {
- this.findAllUserByCondition(this.rId)
- }
- })
- },
- postId: function (newValue) {
- if (newValue) {
- this.findAllUserByCondition();
- } else {
- this.contractUserList = [];
- }
- }
- },
- created () {
- this.init();
- //console.log(this.userInfo)
- },
- mounted () {
- this.$nextTick(() => {
- this.typeChang = {
- 1: false,
- 2: false,
- 3: false,
- }
- })
- },
- methods: {
- //#region //后加分页
- handleSizeChange (val) {
- this.pagesize = val
- this.findAllUserByCondition()
- },
- handleCurrentChange (val) {
- this.pageindx = val
- this.findAllUserByCondition()
- },
- rputerPush () {
- this.$router.push({
- path: '/system/user',
- query: { tankai: true }
- })
- },
- //#endregion
- //#region 甘云杰
- async searchRole () {
- const { data: res } = await searchRole()
- console.log(res);
- if (res.code === 200) {
- this.roleList = res.data
- }
- },
- async init () {
- this.pid = this.$route.query.pid;
- this.cid = this.$route.query.cid;
- if (!this.cid) {
- this.contractForm.pid = this.pid;
- } else {
- await this.getContractInfo();
- }
- await this.getProjectDeatil();
- if (this.$route.query.type) {
- this.activeType = this.$route.query.type;
- }
- this.getContractTypeList();
- this.getStoragePeriodList();
- this.getSecurityLevelList();
- this.setHeaders();
- },
- beforeLeave (activeName, oldActiveName) {
- return new Promise((resolve, reject) => {
- if (oldActiveName == '1' && !this.contractForm.id) {
- this.$message({
- type: "warning",
- message: "请先保存合同段后,再进行合同段的分配"
- });
- reject();
- }
- if (this.typeChang[oldActiveName]) {
- this.$confirm('检测到新编辑内容, 是否保存?', '提示', {
- confirmButtonText: '确定',
- cancelButtonText: '不用',
- type: 'warning'
- }).then(() => {
- switch (oldActiveName) {
- case '1':
- this.savecontract().then((res) => {
- this.contractForm.id = res.data.data.id;
- resolve();
- this.$message({
- type: "success",
- message: "保存成功!"
- });
- });
- break;
- case '2':
- this.saveWbsTree().then(() => {
- resolve();
- this.$message({
- type: "success",
- message: "保存成功!"
- });
- })
- break;
- }
- }).catch(() => {
- this.typeChang[oldActiveName] = false;
- resolve();
- })
- } else {
- resolve();
- }
- })
- },
- getProjectDeatil () {
- return new Promise((resolve) => {
- getProjectDeatil(this.pid).then((res) => {
- this.projectInfo = res.data.data;
- this.wbsId = this.projectInfo.referenceWbsTemplateId;
- resolve();
- }).finally(() => {
- resolve();
- })
- })
- },
- getContractInfo () {
- return new Promise((resolve) => {
- getContractInfo(this.cid).then((res) => {
- this.contractForm = res.data.data;
- if (this.contractForm.startFileUrl) {
- this.isBackShow = true;
- }
- if (this.contractForm.projectPlace) {
- this.flageData = ['', '', this.contractForm.projectPlace]
- }
- if (Number(this.contractForm.contractAmount) < 0) {
- this.contractForm.contractAmount = 0;
- }
- this.$nextTick(() => {
- this.typeChang['1'] = false;
- })
- }).finally(() => {
- resolve();
- })
- })
- },
- async saveQuit () {
- this.btnLoad = true;
- try {
- if (this.activeType == '1') {
- await this.savecontract();
- } else if (this.activeType == '2') {
- await this.saveWbsTree();
- }
- } catch (error) {
- this.btnLoad = false;
- return;
- }
- this.$message({
- type: "success",
- message: "保存成功!"
- });
- this.btnLoad = false;
- this.$router.go(-1);
- },
- async saveNext (type) {
- this.btnLoad = true;
- try {
- if (this.activeType == '1') {
- let res = await this.savecontract();
- this.contractForm.id = res.data.data.id;
- } else if (this.activeType == '2') {
- await this.saveWbsTree();
- }
- } catch (error) {
- this.btnLoad = false;
- 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;
- },
- savecontract () {
- return new Promise((resolve, reject) => {
- this.$refs['contractForm'].validate((valid) => {
- if (valid) {
- if (this.flageData.length == 3) {
- this.contractForm.projectPlace = this.flageData[2];
- }
- resolve(submitContractInfo(this.contractForm))
- } else {
- reject('验证失败')
- }
- })
- })
- },
- handleRemove (file) {
- //console.log(file, fileList);
- removeFile(file.response.data.attachId).then(() => {
- this.contractForm.startFileUrl = '';
- })
- },
- handleExceed () {
- this.$message.warning(`当前限制选择 1 个文件,请先移除后,再次上传`);
- },
- handleSuccess (res) {
- this.contractForm.startFileUrl = res.data.link;
- },
- setHeaders () {
- this.headers['Authorization'] = `Basic ${Base64.encode(`${website.clientId}:${website.clientSecret}`)}`;
- this.headers[website.tokenHeader] = 'bearer ' + getToken()
- },
- downloadFile () {
- window.open(this.contractForm.startFileUrl);
- },
- delFile () {
- this.$confirm('是否删除该文件?', '删除开工令', {
- distinguishCancelAndClose: true,
- confirmButtonText: '删除',
- cancelButtonText: '取消'
- }).then(() => {
- delFileFromUrl(this.contractForm.startFileUrl).then(() => {
- this.isBackShow = false;
- this.contractForm.startFileUrl = '';
- })
- })
- },
- addUserToProject () {
- if (!this.userId) {
- this.$message({
- type: "warning",
- message: "请先选择用户再进行添加"
- });
- return;
- }
- if (!this.postId) {
- this.$message({
- type: "warning",
- message: "请先选择岗位再进行添加"
- });
- return;
- }
- let list = [{
- projectId: this.pid,
- contractId: this.contractForm.id,
- userId: this.userId,
- roleId: this.postId,
- }];
- saveUserInfoByProjectTow(list).then(() => {
- // this.findAllUserByCondition();
- })
- },
- findAllUserByCondition (val) {
- let rId
- if (this.postId) {
- rId = this.postId
- } else {
- rId = val
- }
- findAllUserByCondition({
- cId: this.contractForm.id,
- pId: this.pid,
- // "postId": this.postId,
- rId: rId,
- },
- this.pagesize,
- this.pageindx,
- ).then((res) => {
- this.contractUserList = res.data.data.records;
- this.total = res.data.data.total
- })
- },
- 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: "删除成功!"
- });
- })
- })
- },
- copyAccPas (row) {
- this.copyText = `姓名:${row.name}
- 账号:${row.account}
- 密码:${row.password}`;
- this.$nextTick(() => {
- this.$refs.copyInput.select()
- document.execCommand('copy')
- this.$message({
- type: "success",
- message: "成功复制在剪贴板!"
- });
- })
- },
- resetPassword (row) {
- this.$confirm('是否将用户【' + row.name + '】密码重置为123456', '提示', {
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- type: 'warning'
- }).then(() => {
- resetPasswordByUserId(row.uid).then(() => {
- row.password = '123456';
- this.$message({
- type: "success",
- message: "重置成功!"
- });
- })
- })
- },
- getContractTypeList () {
- if (this.contractTypeList.length > 1) {
- return;
- }
- getDictionary({
- code: 'contract_type'
- }).then((res) => {
- res.data.data.forEach(element => {
- element.dictKey = Number(element.dictKey)
- });
- this.contractTypeList = res.data.data;
- })
- },
- getUserByName () {
- findUserByName('').then((res) => {
- this.userList = res.data.data;
- })
- },
- getLeftTree () {
- return new Promise((resolve) => {
- if (!this.leftTreeData.length) {
- findProjectTree(this.projectInfo.id, this.wbsId).then((res) => {
- if (Array.isArray(res.data.data)) {
- this.leftTreeData = res.data.data;
- } else {
- this.leftTreeData = [];
- }
- resolve();
- }).finally(() => {
- resolve();
- })
- }
- resolve();
- })
- },
- getRightTree () {
- getContractInfoTree(this.wbsId, this.projectInfo.id, this.contractForm.id).then((res) => {
- if (Array.isArray(res.data.data)) {
- this.$refs.treetotree.setRightTree(res.data.data);
- }
- })
- },
- saveWbsTree () {
- let obj = {};
- let ids = this.$refs.treetotree.getTreeAllId('rightTree');
- obj = {
- wbsId: this.wbsId,
- projectId: this.projectInfo.id,
- contractId: this.contractForm.id,
- wbsTreeIds: ids
- }
- return submitWbsTreeInContract(obj);
- },
- treeChang () {
- this.typeChang[2] = true;
- },
- mapChange () {
- this.$refs['contractForm'].validateField('projectPlace');
- },
- getStoragePeriodList () {
- if (this.storagePeriodList.length > 1) {
- return;
- }
- getDictbiz({
- code: 'storage_period'
- }).then((res) => {
- res.data.data.forEach(element => {
- element.dictKey = Number(element.dictKey)
- });
- this.storagePeriodList = res.data.data;
- })
- },
- getSecurityLevelList () {
- if (this.securityLevelList.length > 1) {
- return;
- }
- getDictbiz({
- code: 'security_level'
- }).then((res) => {
- res.data.data.forEach(element => {
- element.dictKey = Number(element.dictKey)
- });
- this.securityLevelList = res.data.data;
- })
- },
- //#endregion
- }
- };
- </script>
- <style scoped lang="scss">
- .bm-view {
- width: 100%;
- height: 300px;
- }
- .head-font {
- font-size: 20px;
- font-weight: bold;
- }
- </style>
|