12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253 |
- <template>
- <!-- 风机风门-->
- <div class="l_Dialog bou tablebk">
- <div class="common-layout" style="margin: 0">
- <el-aside
- width="2.125rem"
- class="L_aside L_aside1 asideg asidegbg leftbgimg1"
- >
- <div class="demo-collapse">
- <el-collapse v-model="coolactiveName1">
- <el-collapse-item name="1" class="imgneon">
- <template #title>
- <el-icon class="iconimg Frame3" fit="contain"></el-icon>
- 风机<el-icon class="header-icon"> </el-icon>
- </template>
- <div class="asides_content">
- <div class="jc_content tablecolor">
- <div class="jc_padding font12">
- <div class="xian btncolor tablefocus bmar">
- <el-table
- :data="fjtableData"
- style="width: 100%"
- :max-height="tableHeight"
- :highlight-current-row="currentrow"
- :row-class-name="tableRowClassName"
- @row-click="handlerow($event)"
- :header-cell-style="{ background: 'rgba(13, 22, 57, 0) ' }"
- >
- <template v-slot:empty>
- <p>暂无数据</p>
- </template>
- <el-table-column prop="fanname" label="风机名称" />
- <el-table-column prop="pname" label="选择巷道" />
- <!-- <el-table-column prop="site" label="相对位置" /> -->
- <el-table-column property="siteremark" label="位置"/>
- <el-table-column prop="pa" >
- <template v-slot:header>
- <span >增压</span><br>
- <span >(kpa)</span>
- </template>
- </el-table-column>
- <el-table-column prop="onoff" label="开启状态">
- <template #default="scope">
- {{
- scope.row.onoff == "0"
- ? "否"
- : scope.row.onoff == "1"
- ? "是"
- : "是"
- }}
- </template>
- </el-table-column>
- </el-table>
- <div class="asdis_btn">
- <div class="flex_a" >
- <div
- class="btns"
- @click="fjloadclick();sdialog.fjloaddialog = true;"
- >
- <span class="spantext">加载</span>
- </div>
- </div>
- <div class="flex_a" >
- <div
- class="btns"
- @click="fjclick();sdialog.fjdialog = true;"
- >
- <span class="spantext">添加</span>
- </div>
- </div>
- <div class="flex_a" >
- <div class="btns" @click="xiugaiclick()">
- <span class="spantext">修改</span>
- </div>
- </div>
- <div class="flex_a">
- <div class="btns" @click="delonclock('风机')" >
- <span class="spantext">删除</span>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </el-collapse-item>
- </el-collapse>
- <el-collapse v-model="coolactiveName1" style="margin-top: 10px;">
- <el-collapse-item name="2" class="imgneon">
- <template #title>
- <el-icon class="iconimg Frame3" fit="contain"></el-icon>
- 风门<el-icon class="header-icon"> </el-icon>
- </template>
- <div class="asides_content">
- <div class="jc_content tablecolor">
- <div class="jc_padding font12">
- <div class="xian btncolor tablefocus bmar">
- <el-table
- :data="fmtableData"
- style="width: 100%"
- :max-height="tableHeight"
- :highlight-current-row="currentrow"
- :row-class-name="tableRowClassName"
- @row-click="handlerow2($event)"
- :header-cell-style="{ background: 'rgba(13, 22, 57, 0) ' }"
- >
- <template v-slot:empty>
- <p>暂无数据</p>
- </template>
- <el-table-column prop="doorname" label="风门名称" />
- <el-table-column prop="pname" label="选择巷道" />
- <!-- <el-table-column prop="site" label="相对位置" /> -->
- <el-table-column property="siteremark" label="位置"/>
- <el-table-column prop="dragcoe" label="阻力系数" />
- <el-table-column prop="onoff" label="开启状态">
- <template #default="scope">
- {{
- scope.row.onoff == 0
- ? "否"
- : scope.row.onoff == 1
- ? "是"
- : "是"
- }}
- </template>
- </el-table-column>
- </el-table>
- <div class="asdis_btn">
- <div class="flex_a" >
- <div
- class="btns" @click="fmload();sdialog.fmloaddialog=true"
- >
- <span class="spantext">加载</span>
- </div>
- </div>
- <div class="flex_a" >
- <div
- class="btns" @click="fmadd();sdialog.fmdialog=true"
- >
- <span class="spantext">添加</span>
- </div>
- </div>
- <div class="flex_a" >
- <div class="btns" @click="fmxiugai()">
- <span class="spantext">修改</span>
- </div>
- </div>
- <div class="flex_a">
- <div class="btns" @click="fmdel('风门')" >
- <span class="spantext">删除</span>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </el-collapse-item>
- </el-collapse>
- </div>
- </el-aside>
- </div>
- <!-- 风机的加载 -->
- <el-dialog
- v-model="sdialog.fjloaddialog"
- width="400"
- align-center
- :modal="false"
- :append-to-body="true"
- :z-index='1000'
- :close-on-click-modal="false"
- :fullscreen="false"
- :modal-append-to-body="false"
- modal-class="summary-dlg"
- class="dialog_class bgcolor tianjia"
- draggable
- >
- <template #header="{ titleId, titleClass }">
- <div class="my-header">
- <el-image :src="icon" fit="contain"></el-image>
- <h4 :id="titleId" :class="titleClass">加载</h4>
- </div>
- </template>
- <div class="demo-input-suffix firsttitle leftbgimg2">
- <el-table
- :row-class-name="tableRowClassName"
- :max-height="tableHeight"
- ref="tabledatafjjzref"
- type="selection"
- :data="tableDatafjjz"
- style="width: 100%"
-
- :header-cell-style="{ background: 'rgba(13, 22, 57, 0) ' }"
- >
- <template v-slot:empty>
- <p>暂无数据</p>
- </template>
- <el-table-column type="selection" width="55" />
- <!-- <el-table-column property="snId" label="开始节点" />
- <el-table-column property="enId" label="结束节点" /> -->
- <el-table-column type="index" label="编号" width="70" />
- <el-table-column property="fanname" label="风机名称" />
- <el-table-column property="pname" label="巷道名称" />
- <!-- <el-table-column property="site" label="相对位置" /> -->
- <el-table-column property="siteremark" label="位置"/>
- <el-table-column prop="pa" >
- <template v-slot:header>
- <span >增压</span><br>
- <span >(kpa)</span>
- </template>
- </el-table-column>
- <el-table-column prop="onoff" label="开启状态">
- <template #default="scope">
- {{
- scope.row.onoff == "0"
- ? "否"
- : scope.row.onoff == "1"
- ? "是"
- : "是"
- }}
- </template>
- </el-table-column>
- </el-table>
- <div class="dialog-footer footer_div l_btn">
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button @click="sdialog.fjloaddialog = false">取消</el-button>
- </div>
- </div>
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button
- @click="
- fjloadsave();
- sdialog.fjloaddialog = false;
- "
- >
- 确定
- </el-button>
- </div>
- </div>
- </div>
- </div>
- </el-dialog>
- <!-- 风机的添加 -->
- <el-dialog
- v-model="sdialog.fjdialog"
- width="400"
- align-center
- :modal="false"
- :append-to-body="true"
- :z-index='1000'
- :close-on-click-modal="false"
- :fullscreen="false"
- :modal-append-to-body="false"
- modal-class="summary-dlg"
- class="dialog_class bgcolor tianjia"
- draggable
- @close='closeDialog'
- >
- <template #header="{ titleId, titleClass }">
- <div class="my-header">
- <el-image :src="icon" fit="contain"></el-image>
- <h4 :id="titleId" :class="titleClass">{{ zhtext }}</h4>
- </div>
- </template>
- <el-form >
- <el-form-item label="编码" :label-width="formLabelWidth6">
- <el-input v-model="fjobj.fancode" maxlength="18" @input="fjobj.fancode = fjobj.fancode.replace(/[\u4e00-\u9fa5\s]/g, '')" class="w-50 m-2" placeholder="请输入" />
- </el-form-item>
- <el-form-item label="风机名称" :label-width="formLabelWidth6">
- <el-input v-model="fjobj.fanname" maxlength="18" oninput ="value=value.replace(/[^\a-\z\A-\Z0-9\u4E00-\u9FA5]/g,'')" class="w-50 m-2" placeholder="请输入" />
- </el-form-item>
- <div class="demo-input-suffix firsttitle magintop">
- <el-form-item label="巷道名称" :label-width="formLabelWidth6">
- <el-input
- v-model="source.selectstr"
- disabled
- class="w-50 m-2"
- placeholder="巷道名称"
- />
- </el-form-item>
- <div class="btn2">
- <el-button
- type="primary"
- @click="
- fireclick('fj');
- sdialog.dialogVisiblenode = true;
- "
- >选择巷道</el-button
- >
- </div>
- <div class="btn2" style="padding-left: 10px">
- <el-button type="primary" @click="Dclick('fj')">3D巷道选择</el-button>
- </div>
- </div>
- <!-- <div class="input">
- <el-form-item label="相对位置" :label-width="formLabelWidth6">
- <el-input-number
- v-model="source.site"
- :min="0"
- :max="1"
- :precision="2"
- :step="0.1"
- controls-position="right"
- class="w-50 m-2"
- placeholder="相对位置"
- @change="inputnuberChange"
- />
- </el-form-item>
- </div> -->
- <el-form-item label="位置" :label-width="formLabelWidth6">
- <el-input
- v-model="fjobj.siteremark"
- class="w-50 m-2"
- placeholder="请输入位置说明"
- />
- </el-form-item>
- <div style="display: flex;" >
- <span class="switchppm">开启状态</span>
- <el-switch
- v-model="fjobj.onoff"
- inline-prompt
- active-text="是"
- inactive-text="否"
- :active-value="1"
- :inactive-value="0"
- @change="handleSwitchChange"
- />
- </div>
- <el-form-item label="增压(kpa)" :label-width="formLabelWidth6">
- <el-input v-model="fjobj.pa" maxlength="10" oninput ="value=value.replace(/[^0-9.]/g,'')" class="w-50 m-2" placeholder="请输入" />
- </el-form-item>
- </el-form>
- <div class="dialog-footer footer_div l_btn">
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button @click="closeDialog(); sdialog.fjdialog=false">取消</el-button>
- </div>
- </div>
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button
- :disabled="isSubmitting"
- @click="addrequest(); "
- >
- 确定
- </el-button>
- </div>
- </div>
- </div>
- </el-dialog>
- <!-- 风门的加载 -->
- <el-dialog
- v-model="sdialog.fmloaddialog"
- width="400"
- align-center
- :modal="false"
- :append-to-body="true"
- :z-index='1000'
- :close-on-click-modal="false"
- :fullscreen="false"
- :modal-append-to-body="false"
- modal-class="summary-dlg"
- class="dialog_class bgcolor tianjia"
- draggable
- >
- <template #header="{ titleId, titleClass }">
- <div class="my-header">
- <el-image :src="icon" fit="contain"></el-image>
- <h4 :id="titleId" :class="titleClass">加载</h4>
- </div>
- </template>
- <div class="demo-input-suffix firsttitle leftbgimg2">
- <el-table
- :row-class-name="tableRowClassName"
- :max-height="tableHeight"
- ref="tabledatafmjzref"
- type="selection"
- :data="tableDatafmjz"
- style="width: 100%"
-
- :header-cell-style="{ background: 'rgba(13, 22, 57, 0) ' }"
- >
- <template v-slot:empty>
- <p>暂无数据</p>
- </template>
- <el-table-column type="selection" width="55" />
- <!-- <el-table-column property="snId" label="开始节点" />
- <el-table-column property="enId" label="结束节点" /> -->
- <el-table-column type="index" label="编号" width="70" />
- <el-table-column property="doorname" label="风门名称" />
- <el-table-column property="pname" label="巷道名称" />
- <!-- <el-table-column property="site" label="相对位置" /> -->
- <el-table-column property="siteremark" label="位置"/>
- <el-table-column prop="dragcoe" label="阻力系数" />
- <el-table-column prop="onoff" label="开启状态">
- <template #default="scope">
- {{
- scope.row.onoff == "0"
- ? "否"
- : scope.row.onoff == "1"
- ? "是"
- : "是"
- }}
- </template>
- </el-table-column>
- </el-table>
- <div class="dialog-footer footer_div l_btn">
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button @click="sdialog.fmloaddialog = false">取消</el-button>
- </div>
- </div>
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button
- @click="
- fmloadsave();
- sdialog.fmloaddialog = false;
- "
- >
- 确定
- </el-button>
- </div>
- </div>
- </div>
- </div>
- </el-dialog>
- <!-- 风门的添加 -->
- <el-dialog
- v-model="sdialog.fmdialog"
- width="400"
- align-center
- :modal="false"
- :append-to-body="true"
- :z-index='1000'
- :close-on-click-modal="false"
- :fullscreen="false"
- :modal-append-to-body="false"
- modal-class="summary-dlg"
- class="dialog_class bgcolor tianjia"
- draggable
- @close='closeDialog'
- >
- <template #header="{ titleId, titleClass }">
- <div class="my-header">
- <el-image :src="icon" fit="contain"></el-image>
- <h4 :id="titleId" :class="titleClass">{{ zhtext }}</h4>
- </div>
- </template>
- <el-form >
- <!-- 只能输入引文oninput ="value=value.replace(/[^a-zA-Z]/g, '');" -->
- <el-form-item label="编码" :label-width="formLabelWidth6">
- <el-input v-model="fmobj.doorcode" maxlength="18" @input="fmobj.doorcode = fmobj.doorcode.replace(/[\u4e00-\u9fa5\s]/g, '')" class="w-50 m-2" placeholder="请输入" />
- </el-form-item>
- <el-form-item label="风门名称" :label-width="formLabelWidth6">
- <el-input v-model="fmobj.doorname" maxlength="18" oninput ="value=value.replace(/[^\a-\z\A-\Z0-9\u4E00-\u9FA5]/g,'')" class="w-50 m-2" placeholder="请输入" />
- </el-form-item>
- <div class="demo-input-suffix firsttitle magintop">
- <el-form-item label="巷道名称" :label-width="formLabelWidth6">
- <el-input
- v-model="source.selectstr"
- disabled
- class="w-50 m-2"
- placeholder="巷道名称"
- />
- </el-form-item>
- <div class="btn2">
- <el-button
- type="primary"
- @click="
- fireclick('fm');
- sdialog.dialogVisiblenode = true;
- "
- >选择巷道</el-button
- >
- </div>
- <div class="btn2" style="padding-left: 10px">
- <el-button type="primary" @click="Dclick('fm')">3D巷道选择</el-button>
- </div>
- </div>
- <!-- <div class="input">
- <el-form-item label="相对位置" :label-width="formLabelWidth6">
- <el-input-number
- v-model="source.site"
- :min="0"
- :max="1"
- :precision="2"
- :step="0.1"
- controls-position="right"
- class="w-50 m-2"
- placeholder="相对位置"
- @change="inputnuberChange1"
- />
- </el-form-item>
- </div> -->
- <el-form-item label="位置" :label-width="formLabelWidth6">
- <el-input
- v-model="fmobj.siteremark"
- class="w-50 m-2"
- placeholder="请输入位置说明"
- />
- </el-form-item>
- <div style="display: flex;" >
- <span class="switchppm">开启状态</span>
- <el-switch
- v-model="fmobj.onoff"
- inline-prompt
- active-text="是"
- inactive-text="否"
- :active-value="1"
- :inactive-value="0"
- @change="handleSwitchChange"
- />
- </div>
- <el-form-item label="阻力系数" :label-width="formLabelWidth6">
- <el-input v-model="fmobj.dragcoe" maxlength="10" oninput ="value=value.replace(/[^0-9.]/g,'')" class="w-50 m-2" placeholder="请输入" />
- </el-form-item>
- </el-form>
- <div class="dialog-footer footer_div l_btn">
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button @click="closeDialog(); sdialog.fmdialog=false">取消</el-button>
- </div>
- </div>
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button
- :disabled="isSubmitting"
- @click="addxiufm(); "
- >
- 确定
- </el-button>
- </div>
- </div>
- </div>
- </el-dialog>
- <!-- 选择巷道 -->
- <pipelines ref="pipeline" :selectstr="source.selectstr" @pipelineapi="pipelineapi" />
-
- <!-- 删除 -->
- <el-dialog
- v-model="sdialog.dialogsgdelect"
- width="400"
- class="dialog_class bgcolor tianjia"
- >
- <template #header="{ titleId, titleClass }">
- <div class="my-header">
- <el-image :src="icon" fit="contain"></el-image>
- <h4 :id="titleId" :class="titleClass">删除框</h4>
- </div>
- </template>
- <h4 class="delecttitle">
- 是否确认删除 <span class="spanclad">{{ zqname }}</span>
- </h4>
- <div class="dialog-footer footer_div l_btn">
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button @click="sdialog.dialogsgdelect=false">取消</el-button>
- </div>
- </div>
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button
- @click="deletefun(); "
- >
- 确定
- </el-button>
- </div>
- </div>
- </div>
- <!-- <div class="dialog-footer footer_div l_btn">
- <div class="footerbtn flex1">
- <div class="borderimg">
- <el-button @click="sdialog.dialogsgdelect=false">取消</el-button>
- <el-button @click="deletefun()">确定</el-button>
- </div>
- </div>
-
- </div> -->
- </el-dialog>
- <selfdialogs ref="dialogtrue" :site="dsite" @Dtext="Dtext"></selfdialogs>
- </div>
- </template>
- <script setup>
- import { computed, ref, onMounted, reactive } from "vue";
- import { request, uploadFile } from "@/utils/request";
- import icon from "@/assets/img/icon.png";
- import closeimg from "@/assets/img/colse.png";
- import { ElMessage, ElButton, ElDialog,ElConfigProvider } from "element-plus";
- import { message } from '@/utils/message';
- import zhCn from 'element-plus/es/locale/lang/zh-cn'
- import { Calendar, Search } from "@element-plus/icons-vue";
- // import selfdialogs from "./SetNode.vue";
- import selfdialogs from "./SetPipe.vue";
- import pipelines from "./PipeIine.vue"
- import { vtkmodel } from "@/control/vtkModel.js";
- let zqname=ref();
- let tableHeight=ref(200);
- let dsite=ref();
- let currentrow=ref();
- let pipeline = ref();
- let dialogtrue = ref();
- let isSubmitting = false;
- let sdialog=ref({
- dialogsgdelect:false,
- dialogVisiblenode:false,
- fjdialog:false,
- fjloaddialog:false,
- fmdialog:false,
- fmloaddialog:false
- })
- let delte=ref();
- let state=ref();
- let formLabelWidth6=ref(120)
- let source = ref({
- selectstr: '',
- site:null
- })
- // let selectstr=ref();
- // let firepid=ref();
- let aid=ref()//事故id
- let pid=ref();// 巷道id
- let site=ref();
- let fjobj=ref({
- fanid:null,
- fanname:"",
- fancode:'',
- pa:null,
- onoff:0
- })
- let handobj=ref({});
- let fmobj=ref({
- doorid:null,
- doorname:"",
- dragcoe:null,
- doorcode:'',
- onoff:0
- })
- let handobjfm=ref({});
- const props = defineProps({
- aid: {
- type: String,
- },
- });
- let zhtext=ref('');
- let tishi=ref('');
- let fjtableData=ref([]);
- let tableDatafjjz=ref([]);
- let tabledatafjjzref = ref();
- let fmtableData=ref([]);
- let tableDatafmjz=ref([]);
- let tabledatafmjzref = ref();
- let opendialogname = '';//用于区分风机风门打开的弹窗
- const handlerow = (val) => {
- vtkmodel.delfan();
- currentrow.value=true;
- handobj.value=val;
- console.log(val);
- vtkmodel.delAll();
- vtkmodel.addfan(val.pid,val.site);
- };
- const handlerow2 = (val) => {
- vtkmodel.deldoor();
- currentrow.value=true;
- handobjfm.value=val;
- vtkmodel.delAll();
- vtkmodel.adddoor(val.pid,val.site);
- };
- let coolactiveName1 = ref(["1", "2"]);
- let coolactiveName2 = ref( "2");
- // 表格变色
- const tableRowClassName = ({ row, rowIndex }) => {
- if (rowIndex % 2 != 0) {
- return "evenRow";
- }
- return "oddRow";
- };
- //
- const initisshow=()=>{
- sdialog.value.dialogsgdelect=false;
- sdialog.value.dialogVisiblenode=false;
- sdialog.value.fjdialog=false;
- sdialog.value.fjloaddialog=false;
- sdialog.value.fmdialog=false;
- dialogtrue.value.dialoglog = false;
- pipeline.value.dialogVisiblenode = false;
- closeDialog();
- }
- // 3D弹屏
- const Dclick = (val) => {
- opendialogname = val;
- dialogtrue.value.dialoglog = true;
- vtkmodel.clearJgAddMode();
- vtkmodel.clearpipfan();
- vtkmodel.clearpipdoor();
-
- vtkmodel.selectPipes();
- dialogtrue.value.jgSelect();
- console.log(dialogtrue.value.dialoglog);
- };
- // 选择巷道
- const fireclick = (val) => {
- opendialogname = val;
- pipeline.value.searchtaggd='';
- pipeline.value.dialogVisiblenode = true;
- pipeline.value.pipelinedata('');
-
- }
- const closeDialog=()=>{
- state.value=sessionStorage.getItem("state");
- if(state.value=='1'){
- vtkmodel.clearModeAddJg();
- }
- //节点图形
- vtkmodel.clearpipfan();//清除选择巷道的位置
- vtkmodel.clearpipdoor();
- vtkmodel.selectNoting();
- dialogtrue.value.timintclaer();
- sdialog.value.fjdialog=false
- }
- //点击确定
- const pipelineapi = (row) => {
- console.log(row);
- pid.value = row.id;
- source.value.selectstr = row.name;
- vtkmodel.selectByPipeId(row.id);
- if(opendialogname === "fj"){
- vtkmodel.addpipfan(row.id, source.value.site|| 0.0);
- }else {
- vtkmodel.addpipdoor(row.id, source.value.site|| 0.0);
- }
-
- }
- //风机加载
- const fjloadclick = () => {
- console.log("目标:",fjtableData.value)
- tableDatafjjz.value = [];
- let temptable = [];
-
- fjtableData.value.forEach(row => {
- if (row.fanbaseid !== 0) {
- temptable.push(row);
- }
- });
- const params = {
- transCode: "D50007",
- // aid: aid.value,
- };
- request(params)
- .then((res) => {
- // 使用 concat() 将新数据添加到现有数据后面
- res.rows.forEach(newRow => {
- const exists = temptable.some(existingRow => existingRow.fanbaseid === newRow.fanbaseid);
- if (!exists) {
- temptable.push(newRow); // 只有在不存在时才追加
- }
- });
- tableDatafjjz.value = temptable;
- nextTick(() => {
- fjtableData.value.forEach(row => {
- if (row.fanbaseid !== 0) { // 确保只选中符合条件的行
- // 在 tableData3 中查找与 tableDatpump 中对应的行
- const rowIndex = tableDatafjjz.value.findIndex(item => item.fanbaseid === row.fanbaseid);
- if (rowIndex !== -1) {
- // 找到对应的行后,选中该行
- tabledatafjjzref.value.toggleRowSelection(tableDatafjjz.value[rowIndex], true); // 选中该行
- console.log("选中的行:", tableDatafjjz.value[rowIndex]);
- }
- }
- });
- });
- })
- .catch((err) => {
- message.error(err.returnMsg);
- });
- }
- //风机加载保存
- const fjloadsave = () => {
- let values = [];
- const selectedRows = tabledatafjjzref.value.getSelectionRows();
- console.log( '选中行:',selectedRows);
- if (selectedRows.length === 0) {
- return;
- }
- selectedRows.forEach(row => {
- // 获取每一行的 fanbaseid
- if (row.fanbaseid) {
- values.push(row.fanbaseid);
- }
- });
- const params = {
- transCode: "D50014",
- aid: aid.value,
- fanbaseids:values.join(',')
- };
- request(params)
- .then((res) => {
- message.success({
- message: "加载成功"
- });
- getrequest();
- })
- .catch((err) => {
- message.error(err.returnMsg);
- });
- }
- //风机的添加
- const fjclick=()=>{
- zhtext.value='添加';
- currentrow.value=false;
- tishi.value= zhtext.value;
- handobj.value={};
- fjobj.value.fanid='';
- fjobj.value.fancode='';
- fjobj.value.fanname='';
- fjobj.value.onoff='';
- fjobj.value.pa='';
- fjobj.value.siteremark='';
- source.value.site='';
- source.value.selectstr='';
- pid.value='';
- source.value.site=='';
- vtkmodel.clearJgAddMode();
- vtkmodel.delAll();
- }
- // 风机的修改
- const xiugaiclick=()=>{
- zhtext.value='修改';
- if (JSON.stringify(handobj.value) == "{}"|| currentrow.value==false) {
- message.error("你还没有选中修改的项目");
- } else {
- sdialog.value.fjdialog = true;
- aid.value=handobj.value.aid;
- fjobj.value.fanid=handobj.value.fanid;
- fjobj.value.fancode=handobj.value.fancode;
- fjobj.value.fanname=handobj.value.fanname;
- fjobj.value.onoff=handobj.value.onoff;
- fjobj.value.pa=handobj.value.pa;
- fjobj.value.siteremark=handobj.value.siteremark;
- source.value.selectstr=handobj.value.pname;
- source.value.site=handobj.value.site;
- pid.value=handobj.value.pid;
- source.value.site==handobj.value.site;
- vtkmodel.clearJgAddMode();
- vtkmodel.delAll();
- vtkmodel.selectByPipeId(pid.value);
- vtkmodel.addpipfan(pid.value, source.value.site|| 0.0);
- }
- }
- //风机删除
- const delonclock=(val)=>{
- if (JSON.stringify(handobj.value) == "{}"|| currentrow.value==false) {
- message.error("你还没有选中删除的项目");
- } else {
- delte.value=val;
- sdialog.value.dialogsgdelect=true;
- zqname.value=handobj.value.pname;
- }
- }
- const deletefun=()=>{
- console.log(delte.value);
- if(delte.value=="风机"){
- const params = {
- transCode: "D20009",
- fanid: handobj.value.fanid,
- };
- request(params)
- .then((res) => {
- message.success({
- message:"删除风机成功",
- });
- sdialog.value.dialogsgdelect = false;
- getrequest();
- })
- .catch((err) => {
- message.error('删除风机失败');
- });
- }else if(delte.value=="风门"){
- const params = {
- transCode: "D20012",
- doorid:handobjfm.value.doorid,
- };
- request(params)
- .then((res) => {
- message.success({
- message:"删除风门成功",
- });
- sdialog.value.dialogsgdelect = false;
- fmrequest();
- })
- .catch((err) => {
- message.error('删除风门失败');
- });
- }else{
-
- }
- }
- const inputnuberChange = (number) => {
- source.value.site=number;
- dsite.value=number;
- dialogtrue.value.jgSelenum();
-
- vtkmodel.addpipfan(pid.value,number)
-
- }
- const inputnuberChange1 = (number) => {
- source.value.site=number;
- dsite.value=number;
- dialogtrue.value.jgSelenum();
-
- vtkmodel.addpipdoor(pid.value,number)
- }
- const handleSwitchChange=(value)=> {
- fjobj.value.onoff=value;
- }
- //初始化
- const getquery=(id)=>{
- aid.value=id;
- getrequest();
- fmrequest();
- }
- // 风机查询
- const getrequest=()=>{
- const params = {
- transCode: "D20007",
- aid: aid.value,
- };
- request(params)
- .then((res) => {
- console.log(res)
- vtkmodel.delfan();
- fjtableData.value=res.rows;
- currentrow.value=false;
- console.log( currentrow.value);
- })
- .catch((err) => {
- message.error(err.returnMsg);
- });
- }
- // 确定添加
- const addrequest=()=>{
- if (isSubmitting) return;
- if(fjobj.value.fancode==null||fjobj.value.fancode==''){
- message.error("风机编码不能为空")
- return
- }
- if(fjobj.value.fanname==null||fjobj.value.fanname==''){
- message.error("风机名称不能为空")
- return
- }
- if(pid.value==null||pid.value==""){
- message.error("巷道不能为空")
- }else{
- isSubmitting = true; // 开始提交
- const params = {
- transCode: "D20008",
- fanid:fjobj.value.fanid,
- fancode:fjobj.value.fancode,
- pid:pid.value,
- fanname:fjobj.value.fanname,
- site:source.value.site,
- pa:parseFloat(fjobj.value.pa),
- onoff:fjobj.value.onoff,
- aid:aid.value,
- siteremark: fjobj.value.siteremark || ""
- };
- request(params)
- .then((res) => {
- message.success({
- message: zhtext.value+"风机成功",
- });
- sdialog.value.fjdialog = false;
- getrequest();
- // getrequest();
- fun3D();
- })
- .catch((err) => {
- const regex = /字段\d*/g;
- let Msg=err.returnMsg.replace(regex, '');
- message.error(Msg)
- })
- .finally(() => {
- isSubmitting = false; // 提交结束
- });
- }
- }
- //风门查询
- const fmrequest=()=>{
- console.log(aid.value)
- const params = {
- transCode: "D20010",
- aid: aid.value,
- };
- request(params)
- .then((res) => {
- vtkmodel.deldoor();
- fmtableData.value=res.rows;
- currentrow.value=false;
- })
- .catch((err) => {
- message.error(err.returnMsg);
- });
- }
- //风门加载
- const fmload = () => {
- console.log("目标:",fmtableData.value)
- tableDatafmjz.value = [];
- let temptable = [];
-
- fmtableData.value.forEach(row => {
- if (row.doorbaseid !== 0) {
- temptable.push(row);
- }
- });
- const params = {
- transCode: "D50010",
- // aid: aid.value,
- };
- request(params)
- .then((res) => {
- // 使用 concat() 将新数据添加到现有数据后面
- res.rows.forEach(newRow => {
- const exists = temptable.some(existingRow => existingRow.doorbaseid === newRow.doorbaseid);
- if (!exists) {
- temptable.push(newRow); // 只有在不存在时才追加
- }
- });
- tableDatafmjz.value = temptable;
- nextTick(() => {
- fmtableData.value.forEach(row => {
- if (row.doorbaseid !== 0) { // 确保只选中符合条件的行
- // 在 tableData3 中查找与 tableDatpump 中对应的行
- const rowIndex = tableDatafmjz.value.findIndex(item => item.doorbaseid === row.doorbaseid);
- if (rowIndex !== -1) {
- // 找到对应的行后,选中该行
- tabledatafmjzref.value.toggleRowSelection(tableDatafmjz.value[rowIndex], true); // 选中该行
- console.log("选中的行:", tableDatafmjz.value[rowIndex]);
- }
- }
- });
- });
- })
- .catch((err) => {
- message.error(err.returnMsg);
- });
- }
- const fmloadsave = () => {
- let values = [];
- const selectedRows = tabledatafmjzref.value.getSelectionRows();
- console.log( '选中行:',selectedRows);
- if (selectedRows.length === 0) {
- return;
- }
- selectedRows.forEach(row => {
- // 获取每一行的 doorbaseid
- if (row.doorbaseid) {
- values.push(row.doorbaseid);
- }
- });
- const params = {
- transCode: "D50015",
- aid: aid.value,
- doorbaseids:values.join(',')
- };
- request(params)
- .then((res) => {
- message.success({
- message: "加载成功"
- });
- fmrequest();
- })
- .catch((err) => {
- message.error(err.returnMsg);
- });
- }
- //风门的添加
- const fmadd=()=>{
- zhtext.value='添加';
- currentrow.value=false;
- tishi.value= zhtext.value;
- handobj.value={};
- fmobj.value.doorid=null;
- fmobj.value.doorcode='';
- fmobj.value.doorname='';
- fmobj.value.onoff=0;
- fmobj.value.dragcoe=null;
- source.value.site=null;
- source.value.selectstr='';
- pid.value=null;
- vtkmodel.clearJgAddMode();
- vtkmodel.delAll();
- }
- //风门的修改
- const fmxiugai=()=>{
- zhtext.value='修改';
- if (JSON.stringify(handobjfm.value) == "{}"|| currentrow.value==false) {
- message.error("你还没有选中修改的项目");
- } else {
- sdialog.value.fmdialog = true;
- aid.value=handobjfm.value.aid;
- fmobj.value.doorid=handobjfm.value.doorid;
- fmobj.value.doorcode=handobjfm.value.doorcode;
- fmobj.value.doorname=handobjfm.value.doorname;
- fmobj.value.onoff=handobjfm.value.onoff;
- fmobj.value.dragcoe=handobjfm.value.dragcoe;
- fmobj.value.siteremark=handobjfm.value.siteremark;
- source.value.selectstr=handobjfm.value.pname;
- source.value.site=handobjfm.value.site;
- pid.value=handobjfm.value.pid;
- source.value.site==handobjfm.value.site;
- vtkmodel.clearJgAddMode();
- vtkmodel.delAll();
- vtkmodel.selectByPipeId(pid.value);
- vtkmodel.addpipdoor(pid.value, source.value.site|| 0.0);
- }
- }
- // 删除
-
- const fmdel=(val)=>{
- if (JSON.stringify(handobjfm.value) == "{}"|| currentrow.value==false) {
- message.error("你还没有选中删除的项目");
- } else {
- delte.value=val;
- sdialog.value.dialogsgdelect=true;
- zqname.value=handobjfm.value.pname;
- }
- }
- //添加接口
-
- const addxiufm = () => {
- if (isSubmitting) return; // 如果正在提交,则不再继续
- if (fmobj.value.doorcode == null || fmobj.value.doorcode == "") {
- message.error("风门编码不能为空");
- return;
- }
- if (fmobj.value.doorname == null || fmobj.value.doorname == "") {
- message.error("风门名称不能为空");
- return;
- }
- if (pid.value == null || pid.value == "") {
- message.error("巷道不能为空");
- return;
- }
- isSubmitting = true; // 开始提交
- const params = {
- transCode: "D20011",
- doorid: fmobj.value.doorid,
- doorcode: fmobj.value.doorcode,
- pid: pid.value,
- doorname: fmobj.value.doorname,
- site: source.value.site,
- dragcoe: parseFloat(fmobj.value.dragcoe),
- onoff: fmobj.value.onoff,
- aid: aid.value,
- siteremark: fmobj.value.siteremark || ""
- };
- request(params)
- .then((res) => {
- message.success({
- message: zhtext.value + "风门成功"
- });
- sdialog.value.fmdialog = false;
- fmrequest();
- fun3D();
- })
- .catch((err) => {
- const regex = /字段\d*/g;
- let Msg = err.returnMsg.replace(regex, "");
- message.error(Msg);
- })
- .finally(() => {
- isSubmitting = false; // 提交结束
- });
- };
-
- // 3D关闭弹窗
- const fun3D = () => {
- state.value=sessionStorage.getItem("state");
- //console.log(state.value);
- if(state.value=='1'){
- vtkmodel.clearModeAddJg();
- }else{
- vtkmodel.selectNoting();
- }
- dialogtrue.value.timintclaer();
- vtkmodel.clearpipdoor();//清除选择巷道的位置
- vtkmodel.clearpipfan();
- }
- const Dtext=(val)=>{
- console.log('dayin',val);
- console.log('opendialogname',opendialogname);
- source.value.selectstr=val.name;
- pid.value=val.id;
- if(opendialogname === "fj"){
- vtkmodel.addpipfan(pid.value, source.value.site|| 0.0);
- }else {
- vtkmodel.addpipdoor(pid.value, source.value.site|| 0.0);
- }
- }
- defineExpose({getquery,initisshow});
- </script>
|