meLaboratory.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531
  1. <!-- 我的实验室 -->
  2. <template>
  3. <view id="meLaboratory">
  4. <view class="top-picker-max-box">
  5. <view class="top-picker-box">
  6. <picker @change="facultyChange" :value="facultyIndex" :range="facultyArray">
  7. <view class="picker-view">
  8. <view>{{!facultyIndex?'学院':facultyArray[facultyIndex]}}</view>
  9. <img class="picker-img" src="@/images/basicsModules/icon_06.png" alt="">
  10. </view>
  11. </picker>
  12. </view>
  13. <view class="top-picker-box">
  14. <picker @change="subjectChange" :value="subjectIndex" :range="subjectArray">
  15. <view class="picker-view">
  16. <view>{{!subjectIndex?'分类':subjectArray[subjectIndex]}}</view>
  17. <img class="picker-img" src="@/images/basicsModules/icon_06.png" alt="">
  18. </view>
  19. </picker>
  20. </view>
  21. <view class="top-picker-box">
  22. <picker @change="levelChange" :value="levelIndex" :range="levelArray">
  23. <view class="picker-view">
  24. <view>{{!levelIndex?'分级':levelArray[levelIndex]}}</view>
  25. <img class="picker-img" src="@/images/basicsModules/icon_06.png" alt="">
  26. </view>
  27. </picker>
  28. </view>
  29. </view>
  30. <view class="for-max-box">
  31. <img class="null-img" v-if="!dataList[0]" src="@/images/basicsModules/null-data-1.png">
  32. <view class="for-box" v-for="(item,index) in dataList" :key="index" @click="laboratoryInfo(item)">
  33. <view class="title-box">
  34. <view :style="'border:1rpx solid '+item.fiedColor+';background:#fff;color:'+item.fiedColor+';'">{{item.levelName}}</view>
  35. <view>{{item.name}}</view>
  36. <img src="@/images/basicsModules/icon_04.png">
  37. </view>
  38. <view class="address-box"><span>{{item.typeName}}</span>{{item.deptName}}</view>
  39. <view class="address-box-two">
  40. <img src="@/images/basicsModules/icon_14.png">
  41. <view>{{item.subAddrrStr}}</view>
  42. </view>
  43. <view class="text-box" v-if="item.sensorFunctionList[0]">
  44. <view class="min-box" v-for="(minItem,index2) in item.sensorFunctionList" :key="index2">
  45. <view class="min-min-box">
  46. <img v-show="minItem.hasWarn" src="@/images/basicsModules/icon_15.png">
  47. <view :class="{'colorA':minItem.hasWarn}">{{minItem.funcName}}:{{minItem.formatVal?minItem.formatVal:'-'}}</view>
  48. </view>
  49. </view>
  50. </view>
  51. </view>
  52. </view>
  53. </view>
  54. </template>
  55. <script>
  56. import $mqtt from '@/utils/mqtt.min.js';
  57. import { config } from '@/api/request/config.js'
  58. import { laboratoryList,subject_class,listDepartments,mangerControl,laboratoryInfo } from '@/api/apiDemo/index.js'
  59. import { systemAppletSubjectList } from '@/api/basicsModules/index.js'
  60. export default {
  61. data() {
  62. return {
  63. dataList:[],
  64. subject_classData:[],
  65. //MQTT请求参数-传感器
  66. client:{},
  67. mqttIdList:[],
  68. //院系选择器数据
  69. facultyList:[],
  70. facultyArray:[],
  71. facultyIndex:"",
  72. //学科选择器数据
  73. subjectList:[],
  74. subjectArray:[],
  75. subjectIndex:"",
  76. //级别选择器数据
  77. levelList:[
  78. {dictLabel:"全部级别", dictValue:""},
  79. {dictLabel:"一级", dictValue:"1"},
  80. {dictLabel:"二级", dictValue:"2"},
  81. {dictLabel:"三级", dictValue:"3"},
  82. {dictLabel:"四级", dictValue:"4"},
  83. ],
  84. levelArray:['全部级别','一级','二级','三级','四级'],
  85. levelIndex:"",
  86. }
  87. },
  88. onLoad() {
  89. },
  90. onShow(){
  91. this.listDepartments();
  92. this.subject_class();
  93. // mqtt订阅因为返回数据频率问题 暂时取消列表的MQTT刷新
  94. //监听传感器信息
  95. // getApp().watch(this.getMqttSensorData,'mqttSensorData')
  96. },
  97. methods: {
  98. //监听传感器信息
  99. getMqttSensorData(val){
  100. let self = this;
  101. // console.log('页面获取的-传感器信息',val)
  102. if(val.subId){
  103. for(let i=0;i<self.dataList.length;i++){
  104. if(self.dataList[i].id == val.subId){
  105. self.$set(self.dataList[i],'sensorFunctionList',val.functionStatuses);
  106. }
  107. }
  108. }
  109. },
  110. async laboratoryInfo(item){
  111. const {data} = await laboratoryInfo(item.id);
  112. if(data.code == 200){
  113. let obj = data.data[0];
  114. obj.subClassVO = item.subClassVO;
  115. obj.name = item.name;
  116. obj.subTypeLable = item.subTypeLable;
  117. obj.deptName = item.deptName;
  118. obj.subAddrrStr = item.subAddrrStr;
  119. obj.sensorFunctionList = item.sensorFunctionList;
  120. uni.navigateTo({
  121. url: '/pages_manage/laboratory/laboratoryInfo?item='+encodeURIComponent(JSON.stringify(obj))+'&deptId='+item.deptId
  122. });
  123. }
  124. },
  125. //滚动选择器
  126. facultyChange: function(e) {
  127. if(this.facultyArray[0]){
  128. this.facultyIndex = parseInt(e.target.value);
  129. this.systemAppletSubjectList();
  130. }
  131. },
  132. subjectChange: function(e) {
  133. if(this.subjectArray[0]){
  134. this.subjectIndex = parseInt(e.target.value);
  135. this.systemAppletSubjectList();
  136. }
  137. },
  138. levelChange: function(e) {
  139. if(this.levelArray[0]){
  140. this.levelIndex = parseInt(e.target.value);
  141. this.systemAppletSubjectList();
  142. }
  143. },
  144. //设备开关按钮
  145. hardwareButton(minItem,command){
  146. let self = this;
  147. let text = '';
  148. if(command == 'close'){
  149. text = '关闭';
  150. }else if(command == 'open'){
  151. text = '开启';
  152. }
  153. uni.showModal({
  154. content: '确认要'+text+'吗?',
  155. cancelColor:"#999",
  156. confirmColor:"#0183FA",
  157. success: function (res) {
  158. if (res.confirm) {
  159. self.mangerControl(minItem,command);
  160. console.log('用户点击确定');
  161. } else if (res.cancel) {
  162. console.log('用户点击取消');
  163. }
  164. }
  165. });
  166. },
  167. //设备开关
  168. async mangerControl(minItem,command){
  169. let obj = {
  170. id:minItem.id,
  171. command:command,
  172. };
  173. const {data} = await mangerControl(obj);
  174. if(data.code == 200){
  175. if(command == 'open'){
  176. minItem.type = 3;
  177. }else if(command == 'close'){
  178. minItem.type = 4;
  179. }
  180. uni.showToast({
  181. title: '操作成功',
  182. icon:"none",
  183. mask:true,
  184. duration: 2000
  185. });
  186. }
  187. },
  188. //获取院系
  189. async listDepartments(){
  190. const {data} = await listDepartments();
  191. if(data.code == 200){
  192. let list = [];
  193. for(let i=0;i<data.data.length;i++){
  194. list.push(data.data[i].deptName)
  195. }
  196. this.facultyArray = list;
  197. list.unshift('全部院系');
  198. this.facultyList = data.data;
  199. this.facultyList.unshift({deptName:"全部院系", deptId:""})
  200. }
  201. },
  202. //获取学科字典
  203. async subject_class(){
  204. const {data} = await subject_class();
  205. if(data.code == 200){
  206. this.subject_classData = data.data;
  207. let list = [];
  208. for(let i=0;i<data.data.length;i++){
  209. list.push(data.data[i].dictLabel)
  210. }
  211. this.subjectArray = list;
  212. list.unshift('全部分类');
  213. this.subjectList = data.data;
  214. this.subjectList.unshift({dictLabel:"全部分类", dictValue:""})
  215. this.systemAppletSubjectList()
  216. }
  217. },
  218. //获取实验室列表
  219. async systemAppletSubjectList(){
  220. let self = this;
  221. let obj = {
  222. deptId:this.facultyIndex?this.facultyList[this.facultyIndex].deptId:'',
  223. subDept:this.subjectIndex?this.subjectList[this.subjectIndex].dictValue:'',
  224. level:this.levelIndex?this.levelList[this.levelIndex].dictValue:'',
  225. };
  226. const {data} = await systemAppletSubjectList(obj);
  227. if(data.code == 200){
  228. for(let o=0;o<data.data.length;o++){
  229. if(data.data[o].labHardwareVOList){
  230. data.data[o].hardwareList = [];
  231. for(let i=0;i<data.data[o].labHardwareVOList.length;i++){
  232. if(data.data[o].labHardwareVOList[i].hardwareTypeEnum.code == 4 &&data.data[o].labHardwareVOList[i].hardwareNUM){
  233. if(data.data[o].hardwareNUM){
  234. data.data[o].hardwareNUM = data.data[o].hardwareNUM + ',' + data.data[o].labHardwareVOList[i].hardwareNUM
  235. }else{
  236. data.data[o].hardwareNUM = data.data[o].labHardwareVOList[i].hardwareNUM
  237. }
  238. }else{
  239. let obj = {
  240. name:"",
  241. type:"",
  242. };
  243. obj.name = data.data[o].labHardwareVOList[i].hardwareTypeEnum.hardwareTypeName
  244. obj.type = data.data[o].labHardwareVOList[i].state.code;
  245. obj.id = data.data[o].labHardwareVOList[i].id;
  246. data.data[o].hardwareList.push(obj);
  247. }
  248. }
  249. }
  250. }
  251. this.dataList = data.data;
  252. let list = [];
  253. let obj = {
  254. type:"lab/function/data",
  255. idList:[],
  256. }
  257. let objOne = {
  258. type:"lab/hardware/data",
  259. idList:[],
  260. }
  261. for(let i=0;i<self.dataList.length;i++){
  262. let num = 0;
  263. for(let o=0;o<obj.idList.length;o++){
  264. if(obj.idList[o] == self.dataList[i].id){
  265. num++
  266. }
  267. }
  268. if(num == 0){
  269. obj.idList.push(self.dataList[i].id)
  270. objOne.idList.push(self.dataList[i].id)
  271. }
  272. }
  273. list.push(obj);
  274. list.push(objOne);
  275. this.$set(self,'mqttIdList',list);
  276. // mqtt订阅因为返回数据频率问题 暂时取消列表的MQTT刷新
  277. // getApp().appMqttOn(1,list);
  278. }
  279. },
  280. },
  281. onHide(){
  282. // this.offMQTT();
  283. // //删除传感器监听
  284. // getApp().appMqttOn(2);
  285. getApp().deleteSensorWatch();
  286. console.log("onHide",this.mtopic);
  287. },
  288. beforeDestroy(){
  289. // this.offMQTT();
  290. // //删除传感器监听
  291. getApp().offMQTT();
  292. getApp().deleteSensorWatch();
  293. console.log("beforeDestroy",this.mtopic);
  294. }
  295. }
  296. </script>
  297. <style lang="stylus" scoped>
  298. #meLaboratory{
  299. height:100%;
  300. display flex
  301. flex-direction column
  302. .top-picker-max-box{
  303. display:flex;
  304. padding:0 20rpx;
  305. background #fff
  306. border-bottom:1rpx solid #E0E0E0;
  307. .top-picker-box{
  308. line-height:80rpx;
  309. height:80rpx;
  310. .picker-view{
  311. display flex
  312. view{
  313. display:block;
  314. overflow:hidden;
  315. text-overflow:ellipsis;
  316. white-space:nowrap;
  317. font-size:28rpx;
  318. }
  319. .picker-img{
  320. width:24rpx;
  321. height:13rpx;
  322. margin-top:36rpx;
  323. margin-left:13rpx;
  324. }
  325. }
  326. }
  327. .top-picker-box:nth-child(1){
  328. text-align left
  329. width:320rpx;
  330. .picker-view{
  331. view{
  332. max-width:260rpx;
  333. }
  334. }
  335. }
  336. .top-picker-box:nth-child(2){
  337. text-align left
  338. width:215rpx;
  339. .picker-view{
  340. view{
  341. max-width:156rpx;
  342. }
  343. }
  344. }
  345. .top-picker-box:nth-child(3){
  346. text-align right
  347. width:195rpx;
  348. .picker-view{
  349. view{
  350. flex:1;
  351. }
  352. }
  353. }
  354. }
  355. .for-max-box{
  356. flex:1;
  357. overflow-y scroll
  358. .null-img{
  359. display block
  360. width:276rpx;
  361. height:321rpx;
  362. position absolute
  363. top:200rpx;
  364. left:274rpx;
  365. }
  366. .for-box{
  367. overflow hidden
  368. background #ffffff
  369. margin-bottom:20rpx;
  370. .title-box{
  371. margin:20rpx 20rpx 0;
  372. display flex
  373. view:nth-child(1){
  374. height:40rpx;
  375. line-height:40rpx;
  376. font-size:20rpx;
  377. border-radius:10rpx;
  378. padding:0 20rpx;
  379. color:#fff;
  380. margin-right:20rpx;
  381. }
  382. view:nth-child(2){
  383. line-height:42rpx;
  384. font-size:30rpx;
  385. color:#333;
  386. max-width:600rpx;
  387. flex:1;
  388. }
  389. img{
  390. width:12rpx;
  391. height:20rpx;
  392. margin-top:11rpx;
  393. }
  394. .colorA{
  395. background:#aa2315;
  396. }
  397. .colorB{
  398. background:#ff9b09;
  399. }
  400. .colorC{
  401. background:#3ea3e9;
  402. }
  403. .colorD{
  404. background:#3ea34c;
  405. }
  406. }
  407. .address-box{
  408. margin:20rpx 20rpx;
  409. font-size:26rpx;
  410. color:#999999;
  411. span{
  412. margin-right:60rpx;
  413. }
  414. }
  415. .address-box-two{
  416. display flex
  417. margin:0 20rpx 20rpx 20rpx;
  418. img{
  419. width:28rpx;
  420. height:30rpx;
  421. margin-right:18rpx;
  422. }
  423. view{
  424. line-height:30rpx;
  425. font-size:24rpx;
  426. color:#999999;
  427. }
  428. }
  429. .text-box{
  430. /*border-top:1rpx dashed #e0e0e0;*/
  431. border-top:1rpx solid #E0E0E0;
  432. padding:20rpx 20rpx;
  433. /*
  434. overflow-x:scroll;
  435. overflow-y:hidden;
  436. white-space: nowrap;
  437. */
  438. .min-box{
  439. display inline-block
  440. /*padding:0 30rpx 0 10rpx;*/
  441. width:335rpx;
  442. .min-min-box{
  443. display: flex
  444. img{
  445. width:30rpx;
  446. height:27rpx;
  447. margin-top:24rpx;
  448. margin-right:10rpx;
  449. }
  450. view{
  451. line-height:74rpx;
  452. text-align center
  453. font-size:28rpx;
  454. color:#333;
  455. }
  456. .colorA{
  457. color:#EE3A3A;
  458. }
  459. }
  460. }
  461. }
  462. .sensor-max-box{
  463. margin:0 20rpx;
  464. border-top:1rpx solid #e0e0e0;
  465. border-bottom:1rpx solid #e0e0e0;
  466. display flex
  467. .for-sensor-box{
  468. flex:1;
  469. display flex
  470. font-size:28rpx;
  471. line-height:94rpx;
  472. view{
  473. margin-left:20rpx;
  474. font-size:25rpx;
  475. line-height:94rpx;
  476. color:#0183FA;
  477. }
  478. }
  479. }
  480. .button-max-box{
  481. .button-box{
  482. display flex
  483. view:nth-child(1){
  484. flex:1;
  485. line-height:90rpx;
  486. color:#333333;
  487. margin-left:30rpx;
  488. font-size:28rpx;
  489. }
  490. view:nth-child(2){
  491. width:142rpx;
  492. line-height:42rpx;
  493. border:4rpx solid #0183FA;
  494. border-radius:25rpx;
  495. color: #0183FA;
  496. font-size: 30rpx;
  497. text-align center;
  498. margin:20rpx 20rpx 20rpx 0;
  499. }
  500. }
  501. .for-button-box{
  502. display flex
  503. view{
  504. flex:1;
  505. line-height:90rpx;
  506. color:#333333;
  507. margin-left:30rpx;
  508. font-size:28rpx;
  509. }
  510. img{
  511. height:50rpx;
  512. width:100rpx;
  513. margin:20rpx 20rpx 20rpx 0;
  514. }
  515. view:nth-child(2){
  516. text-align right
  517. color:#999;
  518. margin-right:30rpx;
  519. }
  520. }
  521. }
  522. }
  523. }
  524. }
  525. </style>