index.vue 26 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055
  1. <template>
  2. <view>
  3. <view class="textbox">
  4. <view class="inputs">
  5. <u-search placeholder="请输入设备名称/编号" v-model="device_id" placeholder-color="#909696" :show-action="false"
  6. search-icon-color="#909696" @input="searchinput">
  7. </u-search>
  8. </view>
  9. <view class="tab">
  10. <view class="tab-content">
  11. <view class="tab-box tab-box-top">
  12. <view v-for="(item,index) in menuList" :key="index" @click="change(index,item)"
  13. v-if="isShow(item)"
  14. :class="['tab-item',current==index?'active':'']">
  15. <image class="img-icon" :src="item.app_menu_icon" mode=""></image>
  16. <view class="text">{{ getSlice(item.purview_name) }}</view>
  17. </view>
  18. </view>
  19. <u-empty v-if="!menuList.length && !loading" :image-size="100" text="暂无设备权限,请联系工作人员添加"></u-empty>
  20. </view>
  21. </view>
  22. <view class="listbox" v-if="menuList.length">
  23. <view class="second-tab">
  24. <view class="tab-box">
  25. <view
  26. v-for="(item,index) in list"
  27. :key="index"
  28. @click="changeDevice(item,index)"
  29. v-show="!item.url"
  30. :class="['tab-item',currents == index?'active':'']"
  31. >
  32. <text>{{item.purview_name}}</text>
  33. </view>
  34. </view>
  35. </view>
  36. <view class="third-tab">
  37. <view
  38. class="third-tab-item"
  39. @click="changeStatus('')"
  40. :class="{'active-tab' : device_status == ''}"
  41. >总计{{ counts }}</view>
  42. <view
  43. class="third-tab-item"
  44. @click="changeStatus('1')"
  45. :class="{'active-tab' : device_status == '1'}"
  46. >在线{{ online_counts }}</view>
  47. <view
  48. class="third-tab-item"
  49. @click="changeStatus('0')"
  50. :class="{'active-tab' : device_status == '0'}"
  51. >离线{{ offline_counts }}</view>
  52. </view>
  53. <scroll-view
  54. :scroll-top="0"
  55. :scroll-y="true"
  56. class="list scroll-Y"
  57. @scrolltoupper="upper"
  58. @scrolltolower="lower"
  59. @scroll="scroll"
  60. >
  61. <view class="list_item" v-for="(item, index) in eqlistdata" :key="index" @click="historys(item)">
  62. <view class="list_item_top">
  63. <p class="p1">
  64. <span class="title">{{ (item.name || '--' )}}</span>
  65. <span class="sub-title" @click.stop="modification(item)">信息修改</span>
  66. </p>
  67. <p class="online-status"
  68. v-if="item.status == 1 || item.is_online" >
  69. <image
  70. :src="$imageURL+'/bigdata_app/newImg/home/online1.png'"
  71. mode=""
  72. ></image>
  73. <text class="status-text-online">在线</text>
  74. </p>
  75. <p
  76. v-else
  77. class="online-status"
  78. >
  79. <image
  80. :src="$imageURL+'/bigdata_app/newImg/home/offline.png'"
  81. mode=""
  82. ></image>
  83. <text class="status-text-offline">离线</text>
  84. </p>
  85. </view>
  86. <view class="list_item_text">
  87. <p v-if="item.imei">
  88. <span class="label">IMEI</span>{{ (item.dui || item.imei) }}
  89. </p>
  90. <p>
  91. <span class="label">设备ID</span>{{ item.only_for_show || item.id || item.device_id }}
  92. </p>
  93. <p>
  94. <span class="label">上报时间</span>{{ (item.report || item.uptime) | timeFormat() }}
  95. </p>
  96. <p style="display:flex;align-items: center;">
  97. <span class="label">设备位置</span>
  98. <span class="nav-label">{{ (item.address|| '无') }}</span>
  99. </p>
  100. </view>
  101. </view>
  102. </scroll-view>
  103. </view>
  104. </view>
  105. <view class="loading" v-if="loadingtf">
  106. <image src="../../static/images/ajax-loader.gif" mode="" class="img"></image>
  107. </view>
  108. <view class="top" v-if="isTop" @click="top">
  109. <image
  110. :src="
  111. $imageURL+'/bigdata_app' +
  112. '/image/6209a98f0cb3b5086f2ca36152c9269.png'
  113. " mode=""></image>
  114. </view>
  115. </view>
  116. </template>
  117. <script>
  118. import {
  119. Debounce,
  120. Throttle
  121. } from '../../util/anitthro.js';
  122. export default {
  123. data() {
  124. return {
  125. list: [],
  126. pur_id: '',
  127. loading: false,
  128. currentPur_id:'',
  129. device_status: '',
  130. counts:0,
  131. online_counts:0,
  132. offline_counts:0,
  133. accessToken: '',
  134. current: 0,
  135. currents: 0,
  136. total: 0,
  137. refreshData:'',
  138. page: 1,
  139. size: 10,
  140. eqlistdata: [],
  141. isTop: false,
  142. device_model: '',
  143. infoalter: false, // 权限设置,
  144. type_id: 0, //设备类型,
  145. imgpath: [],
  146. loadingtf: false,
  147. width: 0, //顶部搜索栏宽度
  148. device_id: '', //搜索设备ID
  149. menuList: []
  150. };
  151. },
  152. methods: {
  153. isShow(item){
  154. return item.pur_id != 422
  155. },
  156. getSlice(name){
  157. return name.slice(0,4)
  158. },
  159. modification(item) {
  160. uni.navigateTo({
  161. url:
  162. './seabox/modification?data=' +
  163. JSON.stringify(item) +
  164. '&id=' +
  165. this.type_id,
  166. });
  167. },
  168. changeStatus(status){
  169. this.device_status = status;
  170. Debounce(() => {
  171. this.page = 1;
  172. this.eqlist();
  173. }, 500)();
  174. },
  175. async getUserlogin() {
  176. this.list = [];
  177. this.loading = true;
  178. const res = await this.$myRequest({
  179. url: '/api/api_gateway?method=user.login.user_login_info',
  180. method: 'POST',
  181. data: {
  182. is_app: 1,
  183. },
  184. });
  185. this.loading = false;
  186. res.forEach(item=>{
  187. item.icon = '/bigdata_app/newImg/home/sqjd.png'
  188. })
  189. const menulist = res || [];
  190. const menuItem = menulist.find(item => item.purview_name == '智慧物联')
  191. this.menuList = menuItem.children || [];
  192. if(this.menuList.length == 0){
  193. //提示暂无分配权限
  194. uni.showToast({
  195. title: '暂无分配权限,请联系工作人员',
  196. icon: 'none',
  197. });
  198. return
  199. }
  200. if(!this.pur_id){
  201. this.list = this.menuList[0].children || []
  202. this.pur_id = this.menuList[0].pur_id || '';
  203. this.current = 0;
  204. }else{
  205. this.list = this.menuList.find(item => item.pur_id == this.pur_id)?.children || []
  206. this.pur_id = this.menuList.find(item => item.pur_id == this.pur_id)?.pur_id || '';
  207. this.current = this.menuList.findIndex(item => item.pur_id == this.pur_id);
  208. }
  209. if(this.list.length > 1){
  210. if(this.list[0].purview_name != '全部'){
  211. this.list.unshift({
  212. device_type_id: '',
  213. purview_name: '全部'
  214. })
  215. }
  216. }
  217. const firstChild = this.list[0];
  218. this.type_id = firstChild.device_type_id;
  219. if(firstChild.device_type_id !== ''){
  220. this.device_model = firstChild?.device_model || '';
  221. }else{
  222. this.device_model = '';
  223. }
  224. this.initPage();
  225. },
  226. async eqlist(tf) {
  227. this.counts = 0;
  228. this.online_counts = 0;
  229. this.offline_counts = 0;
  230. this.loadingtf = true;
  231. let data = {
  232. device_type_id: this.type_id,
  233. page_num: this.page,
  234. page_size: this.size,
  235. pur_id: this.pur_id,
  236. device_status: this.device_status,
  237. device_id: this.device_id,
  238. device_model: this.device_model
  239. }
  240. const res = await this.$myRequest({
  241. url: '/api/api_gateway?method=device.app_device.app_device_list',
  242. data: data,
  243. });
  244. this.loadingtf = false;
  245. const status = res?.status || {};
  246. this.online_counts = status.online || 0;
  247. this.offline_counts = status.offline || 0;
  248. this.counts = (status.online || 0) + (status.offline || 0);
  249. this.total = res.total || 0;
  250. if (tf) {
  251. this.eqlistdata = this.eqlistdata.concat(res.data);
  252. } else {
  253. this.eqlistdata = res.data;
  254. }
  255. },
  256. change(index,itemData) {
  257. this.list = this.menuList[index].children || []
  258. const list = [];
  259. this.list.forEach(item=>{
  260. if(item.url){
  261. list.push(item)
  262. }
  263. })
  264. // if(list.length > 1){
  265. // if(this.list[0].purview_name != '全部'){
  266. // this.list.unshift({
  267. // device_type_id: '',
  268. // purview_name: '全部'
  269. // })
  270. // }
  271. // }
  272. this.current = index;
  273. const item = this.list[0];
  274. this.pur_id = itemData.pur_id || '';
  275. // this.changeDevice(item,0);
  276. },
  277. changeDevice(item,index){
  278. this.currents = index;
  279. this.currentPur_id = item.pur_id || '';
  280. const name = item.menu;
  281. if (name === 'cbd4') {
  282. this.device_model = 11;
  283. } else if(name === 'cbd1'){
  284. this.device_model = 12;
  285. } else if(name === 'cbd3'){
  286. this.device_model = '';
  287. } else if(name === 'cbd5'){
  288. this.device_model = 13;
  289. } else if(name === 'cbd6'){
  290. this.device_model = 14;
  291. }else if(name === 'gkcbd1'){
  292. this.device_model = 15;
  293. } else if(name === 'zhiCbd'){
  294. this.device_model = 16;
  295. } else {
  296. this.device_model = item.device_model || '';
  297. }
  298. this.page = 1;
  299. this.eqlistdata = [];
  300. this.type_id = item.device_type_id;
  301. Debounce(() => {
  302. this.eqlist();
  303. }, 500)();
  304. },
  305. top() {
  306. uni.pageScrollTo({
  307. scrollTop: 0,
  308. duration: 500,
  309. });
  310. },
  311. initPage(){
  312. this.eqlistdata = [];
  313. this.currents = 0;
  314. this.page = 1;
  315. Debounce(() => {
  316. this.eqlist();
  317. }, 500)();
  318. this.width = 0;
  319. },
  320. historys(item) {
  321. const type_id = item.type_id;
  322. this.accessToken = uni.getStorageSync('session_key')
  323. switch (type_id) {
  324. // 水肥新设备
  325. case 22:
  326. var obj = {};
  327. obj.d_id = item.d_id;
  328. obj.device_id = item.id;
  329. obj.is_online = item.status;
  330. obj.lat = item.lat;
  331. obj.lng = item.lng;
  332. obj.equip_name = item.name;
  333. obj.uptime = item.uptime;
  334. uni.navigateTo({
  335. url: '../waterandfernew/details?shebei=' + JSON.stringify(obj),
  336. });
  337. break;
  338. // 病虫害可视监测
  339. case 14:
  340. item.addtime = item.uptime;
  341. uni.navigateTo({
  342. url: '../cb/sy/detail?detail=' + JSON.stringify(item),
  343. });
  344. break;
  345. case 2:
  346. item.addtime = item.uptime;
  347. if(item.device_model == 102){
  348. uni.navigateTo({
  349. url: '../scd/detail?info=' + JSON.stringify(item),
  350. });
  351. }else{
  352. uni.navigateTo({
  353. url: '../prevention/equipmentdetails?shebei=' + JSON.stringify(item),
  354. });
  355. }
  356. break;
  357. case 38:
  358. uni.navigateTo({
  359. url: `../deviceDetails/weatherStation1/index?devBid=${item.id}&devName=${item.name}&devStatus=${item.status}&address=${item.address}&uptime=${item.uptime}&d_id=${item.d_id}&deviceType=46`,
  360. });
  361. break;
  362. // var obj = {};
  363. // obj.d_id = item.d_id;
  364. // obj.equip_id = item.id;
  365. // obj.is_online = item.status;
  366. // obj.lat = item.lat;
  367. // obj.lng = item.lng;
  368. // obj.equip_name = item.name;
  369. // obj.uptime = item.uptime;
  370. // uni.navigateTo({
  371. // url: '../environment/equipment-new?shebei=' + JSON.stringify(obj),
  372. // });
  373. break;
  374. case 5:
  375. var obj = {};
  376. obj.d_id = item.d_id;
  377. obj.equip_id = item.id;
  378. obj.is_online = item.status;
  379. obj.lat = item.lat;
  380. obj.lng = item.lng;
  381. obj.equip_name = item.name;
  382. obj.uptime = item.uptime;
  383. uni.navigateTo({
  384. url: '../environment/equipment?shebei=' + JSON.stringify(obj),
  385. });
  386. break;
  387. case 6:
  388. uni.navigateTo({
  389. url: '/pages/webview/webview?device_id=' +
  390. item.id +
  391. '&accessToken=' +
  392. this.accessToken,
  393. });
  394. break;
  395. case 44:
  396. uni.navigateTo({
  397. url:
  398. '/pages/webviewdgp/webviewdgp?device_id=' +
  399. item.id +
  400. '&accessToken=' +
  401. uni.getStorageSync('session_key') +
  402. '&type=dgp',
  403. });
  404. break;
  405. case 3:
  406. item.addtime = item.uptime;
  407. item.type = item.type_id;
  408. uni.navigateTo({
  409. url: '../cbd/detail?info=' + JSON.stringify(item),
  410. });
  411. break;
  412. case 28:
  413. item.addtime = item.uptime;
  414. item.type = item.type_id;
  415. uni.navigateTo({
  416. url: '../cb/smallPest/smallPest?info=' + JSON.stringify(item),
  417. });
  418. break;
  419. case 4:
  420. item.addtime = item.uptime;
  421. item.type = item.type_id;
  422. uni.navigateTo({
  423. url: '../cb/equip-detail/equip-detail?info=' + JSON.stringify(item),
  424. });
  425. break;
  426. case 32:
  427. case 35:
  428. item.addtime = item.uptime;
  429. item.type = item.type_id;
  430. uni.navigateTo({
  431. url: '../cb/equip-detail/equip-detail-new?info=' +
  432. JSON.stringify(item),
  433. });
  434. break;
  435. case 33:
  436. case 34:
  437. item.addtime = item.uptime;
  438. item.type = item.type_id;
  439. let cmd = ''
  440. if(type_id == 34){
  441. cmd = 'sy1'
  442. }else if(type_id == 33){
  443. cmd = 'sy2'
  444. }
  445. uni.navigateTo({
  446. url: '../sy/detail?info=' +
  447. JSON.stringify(item) + '&cmd=' + cmd,
  448. });
  449. break;
  450. case 7:
  451. item.addtime = item.uptime;
  452. item.type = item.type_id;
  453. // uni.navigateTo({
  454. // url: '../bzy/detail?info=' + JSON.stringify(item),
  455. // });
  456. if(item.pur_id == 458){
  457. uni.navigateTo({
  458. url: '../bzy/detail?info=' + JSON.stringify(item),
  459. });
  460. }else{
  461. uni.navigateTo({
  462. url: '../cb/equip-detail/equip-detail?info=' + JSON.stringify(item),
  463. });
  464. }
  465. break;
  466. case 8:
  467. uni.navigateTo({
  468. url: '../cb/thxydetail/thxydetail?imei=' + item.id,
  469. });
  470. break;
  471. case 29:
  472. uni.navigateTo({
  473. url: `../cb/nlNewXy/nlNewXy?imei=${item.id}&showId=${item.d_id}`,
  474. });
  475. break;
  476. case 24:
  477. uni.navigateTo({
  478. url: '../cb/zjxydetail/thxydetail?imei=' + item.id,
  479. });
  480. break;
  481. case 12:
  482. item.addtime = item.uptime;
  483. uni.navigateTo({
  484. url: '../cb/xctdetail/xctdetail?info=' + JSON.stringify(item),
  485. });
  486. break;
  487. case 13:
  488. var obj = {};
  489. obj.d_id = item.d_id;
  490. obj.device_id = item.id;
  491. obj.is_online = item.status;
  492. obj.lat = item.lat;
  493. obj.lng = item.lng;
  494. obj.equip_name = item.name;
  495. obj.uptime = item.uptime;
  496. uni.navigateTo({
  497. url: '../waterandfer/datails?shebei=' + JSON.stringify(obj),
  498. });
  499. break;
  500. case 15:
  501. var obj = {};
  502. obj.d_id = item.d_id;
  503. obj.device_id = item.id;
  504. obj.is_online = item.status;
  505. obj.lat = item.lat;
  506. obj.lng = item.lng;
  507. obj.equip_name = item.name;
  508. obj.uptime = item.uptime;
  509. obj.address = item.address || '无';
  510. uni.navigateTo({
  511. url: '../environment/gsequipment?shebei=' + JSON.stringify(obj),
  512. });
  513. break;
  514. case 17:
  515. break;
  516. case 18:
  517. var obj = {};
  518. obj.device_id = item.id;
  519. obj.is_online = item.status;
  520. uni.navigateTo({
  521. url: '../cb/shuifeiL/shuifeiL?detail=' + JSON.stringify(obj),
  522. });
  523. break;
  524. case 43:
  525. uni.navigateTo({
  526. url: "/pages/fmSys/details?info=" + JSON.stringify(item)
  527. })
  528. break;
  529. // case 44:
  530. // uni.navigateTo({
  531. // url: "/pages/webviewdgp/webview?device_id=" + item.id + "&accessToken=" + this.accessToken || uni
  532. // .getStorageSync('session_key') +
  533. // '&type=dgp'
  534. // })
  535. // break;
  536. case 11:
  537. var obj = {};
  538. obj.d_id = item.d_id;
  539. obj.device_id = item.id;
  540. obj.is_online = item.status;
  541. obj.lat = item.lat;
  542. obj.lng = item.lng;
  543. obj.equip_name = item.name;
  544. obj.uptime = item.uptime;
  545. obj.location = item.address;
  546. obj.type = 11;
  547. uni.navigateTo({
  548. url: '../disease/cmb?shebei=' + JSON.stringify(obj),
  549. });
  550. break;
  551. case 19:
  552. var obj = {};
  553. obj.d_id = item.d_id;
  554. obj.device_id = item.id;
  555. obj.is_online = item.status;
  556. obj.lat = item.lat;
  557. obj.lng = item.lng;
  558. obj.equip_name = item.name;
  559. obj.uptime = item.uptime;
  560. obj.location = item.address;
  561. obj.type = 19;
  562. uni.navigateTo({
  563. url: '../disease/cmb?shebei=' + JSON.stringify(obj),
  564. });
  565. break;
  566. case 20:
  567. var obj = {};
  568. obj.d_id = item.d_id;
  569. obj.device_id = item.id;
  570. obj.is_online = item.status;
  571. obj.lat = item.lat;
  572. obj.lng = item.lng;
  573. obj.equip_name = item.name;
  574. obj.uptime = item.uptime;
  575. obj.location = item.address;
  576. obj.type = 20;
  577. uni.navigateTo({
  578. url: '../disease/cmb?shebei=' + JSON.stringify(obj),
  579. });
  580. break;
  581. case 21:
  582. var obj = {};
  583. obj.d_id = item.d_id;
  584. obj.device_id = item.id;
  585. obj.is_online = item.status;
  586. obj.lat = item.lat;
  587. obj.lng = item.lng;
  588. obj.equip_name = item.name;
  589. obj.uptime = item.uptime;
  590. obj.location = item.address;
  591. obj.type = 21;
  592. uni.navigateTo({
  593. url: '../disease/cmb?shebei=' + JSON.stringify(obj),
  594. });
  595. break;
  596. case 26:
  597. var obj = {};
  598. obj.d_id = item.d_id;
  599. obj.device_id = item.id;
  600. obj.is_online = item.status;
  601. obj.lat = item.lat;
  602. obj.lng = item.lng;
  603. obj.equip_name = item.name;
  604. obj.uptime = item.uptime;
  605. obj.location = item.address;
  606. obj.type = 26;
  607. uni.navigateTo({
  608. url: '../disease/cmb?shebei=' + JSON.stringify(obj),
  609. });
  610. break;
  611. case 27:
  612. var obj = {};
  613. obj.d_id = item.d_id;
  614. obj.device_id = item.id;
  615. obj.is_online = item.status;
  616. obj.lat = item.lat;
  617. obj.lng = item.lng;
  618. obj.equip_name = item.name;
  619. obj.uptime = item.uptime;
  620. obj.location = item.address;
  621. obj.type = 26;
  622. uni.navigateTo({
  623. url: '../disease/mls/mls?shebei=' + JSON.stringify(obj),
  624. });
  625. break;
  626. case 25:
  627. item.addtime = item.uptime;
  628. uni.navigateTo({
  629. url: '../cb/xylps/detail/detail?detail=' + JSON.stringify(item),
  630. });
  631. break;
  632. case 40:
  633. item.addtime = item.uptime;
  634. uni.navigateTo({
  635. url: `../cb/shuifeizs/shuifeizs?devBid=${item.d_id}&devName=${item.name}&devStatus=${item.status}`,
  636. });
  637. break;
  638. case 42:
  639. item.addtime = item.uptime;
  640. uni.navigateTo({
  641. url: `../cb/wenshizs/wenshizs?devBid=${item.d_id}&devName=${item.name}&devStatus=${item.status}`,
  642. });
  643. break;
  644. case 45:
  645. item.addtime = item.uptime;
  646. uni.navigateTo({
  647. url: `../cb/shuifeizsFirst/shuifeizs?devBid=${item.d_id}&devName=${item.name}&devStatus=${item.status}`,
  648. });
  649. break;
  650. case 46:
  651. uni.navigateTo({
  652. url: `../deviceDetails/weatherStation/index?devBid=${item.id}&devName=${item.name}&devStatus=${item.status}&address=${item.address}&uptime=${item.uptime}&d_id=${item.d_id}&deviceType=46`,
  653. });
  654. break;
  655. case 47:
  656. uni.navigateTo({
  657. url: `../cb/zhamenFirst/zhamenzs?devBid=${item.d_id}&devName=${item.name}&devStatus=${item.status}`,
  658. });
  659. break;
  660. default:
  661. item.addtime = item.uptime;
  662. item.type = this.type_id;
  663. uni.navigateTo({
  664. url: '../cb/xy2.0/particulars?info=' + JSON.stringify(item),
  665. });
  666. break;
  667. }
  668. },
  669. searchinput() {
  670. Debounce(() => {
  671. this.eqlistdata = [];
  672. this.page = 1;
  673. this.eqlist();
  674. }, 1000)();
  675. },
  676. scrollTop(e) {},
  677. upper() {},
  678. lower() {
  679. if(this.eqlistdata.length >= this.total){
  680. return;
  681. }
  682. Debounce(() => {
  683. this.page++;
  684. this.eqlist(true);
  685. }, 500)();
  686. },
  687. scroll() {},
  688. },
  689. watch:{
  690. pur_id(){
  691. setTimeout(() => {
  692. this.getUserlogin();
  693. }, 100);
  694. },
  695. },
  696. onLoad() {
  697. const that = this;
  698. uni.$on('purId', (item) => {
  699. that.pur_id = item.purId;
  700. that.menu = item.menu;
  701. that.device_model = item.device_model;
  702. });
  703. uni.$on('refreshData', (refreshData) => {
  704. this.eqlist();
  705. });
  706. this.getUserlogin();
  707. },
  708. onShow() {
  709. // 监听刷新数据事件
  710. const refreshData = uni.getStorageSync('refreshData');
  711. if(!this.refreshData){
  712. this.refreshData = refreshData;
  713. // 如果发生改变,刷新数据
  714. if(refreshData){
  715. Debounce(() => {
  716. this.getUserlogin();
  717. }, 500)();
  718. }
  719. }else if(this.refreshData != refreshData){
  720. this.refreshData = refreshData;
  721. Debounce(() => {
  722. this.getUserlogin();
  723. }, 500)();
  724. }
  725. },
  726. onTabItemTap(e) {
  727. },
  728. onReachBottom() {
  729. if(this.eqlistdata.length >= this.total){
  730. return;
  731. }
  732. Debounce(() => {
  733. this.page++;
  734. this.eqlist(true);
  735. }, 500)();
  736. },
  737. onPageScroll(e) {
  738. //nvue暂不支持滚动监听,可用bindingx代替
  739. if (e.scrollTop > 200) {
  740. //距离大于200时显示
  741. this.isTop = true;
  742. } else {
  743. //距离小于200时隐藏
  744. this.isTop = false;
  745. }
  746. },
  747. };
  748. </script>
  749. <style lang="scss">
  750. page {
  751. background: linear-gradient(180deg, #ffffff00 0%, #F5F6FA 23.64%, #F5F6FA 100%), linear-gradient(102deg, #BFEADD 6.77%, #B8F1E7 40.15%, #B9EEF5 84.02%);
  752. }
  753. /deep/.uni-icons {
  754. font-size: 40rpx !important;
  755. }
  756. input{
  757. background: transparent !important;
  758. }
  759. .textbox {
  760. width: 100%;
  761. height: calc(100vh - 82rpx);
  762. padding-top: 82rpx;
  763. box-sizing: border-box;
  764. }
  765. .inputs {
  766. width: 65%;
  767. margin-left: 12rpx;
  768. /deep/.u-content {
  769. background-color: #fff !important;
  770. }
  771. /deep/.uni-input-wrapper {
  772. background-color: #fff !important;
  773. }
  774. }
  775. .utabs_box {
  776. width: 100%;
  777. position: fixed;
  778. top: 88px;
  779. background-color: #ffffff;
  780. z-index: 100;
  781. .utabs {
  782. width: 95%;
  783. margin: 0 auto;
  784. }
  785. }
  786. .loading {
  787. position: fixed;
  788. top: 440px;
  789. width: 95%;
  790. left: 2.5%;
  791. text-align: center;
  792. .img {
  793. width: 300rpx;
  794. height: 40rpx;
  795. }
  796. }
  797. .active-tab{
  798. border-radius: 8rpx;
  799. background: linear-gradient(0deg, #0bbc580f 0%, #0bbc580f 100%), #00000005;
  800. }
  801. .tab-box {
  802. font-size: 30rpx;
  803. box-sizing: border-box;
  804. width: 100%;
  805. height: 100%;
  806. overflow-y: hidden;
  807. overflow-x: auto;
  808. white-space: nowrap;
  809. // 去掉滚动条
  810. -ms-overflow-style: none;
  811. scrollbar-width: none;
  812. .tab-item {
  813. cursor: pointer;
  814. position: relative;
  815. text-align: center;
  816. display: inline-block;
  817. padding: 16rpx 24rpx;
  818. box-sizing: border-box;
  819. span {
  820. display: inline-block;
  821. }
  822. }
  823. }
  824. .tab-box-top{
  825. .tab-item {
  826. width: 140rpx;
  827. text-align: center;
  828. }
  829. }
  830. .tab {
  831. // background-color: #0BBC58;
  832. margin-top: 42rpx;
  833. margin-bottom: 38rpx;
  834. padding: 0 32rpx;
  835. .img-icon {
  836. width: 80rpx;
  837. height: 80rpx;
  838. margin-bottom: 12rpx;
  839. }
  840. .text {
  841. color: #303133;
  842. font-size: 24rpx;
  843. }
  844. .tab-content {
  845. width: 100%;
  846. height: 162rpx;
  847. }
  848. .tab-item.active {
  849. border-radius: 24rpx;
  850. background: linear-gradient(0deg, #0bbc580f 0%, #0bbc580f 100%), #00000005;
  851. }
  852. }
  853. .second-tab {
  854. height: 80rpx;
  855. .tab-item{
  856. font-size: 28rpx;
  857. color: #999999;
  858. }
  859. .tab-item.active {
  860. color: #303133;
  861. font-weight: 700;
  862. }
  863. .tab-item.active::after {
  864. content: '';
  865. position: absolute;
  866. bottom: 0;
  867. left: 50%;
  868. transform: translateX(-50%);
  869. width: 18px; /* 比文字略宽 */
  870. height: 18px;
  871. border: 3px solid #0BBC58;
  872. border-radius: 50%;
  873. border-color: transparent; /* 隐藏其他部分 */
  874. border-bottom-color: #0BBC58; /* 组合成45度角 */
  875. // transform: rotate(0deg); /* 调整角度 */
  876. }
  877. }
  878. .third-tab {
  879. margin: 8rpx 0;
  880. height: 64rpx;
  881. line-height: 64rpx;
  882. display: flex;
  883. justify-content: space-between;
  884. .third-tab-item {
  885. flex: 1;
  886. text-align: center;
  887. }
  888. }
  889. .list {
  890. width: 100%;
  891. background-color: #F5F6FA;
  892. // margin-bottom: 100rpx;
  893. overflow-y: auto;
  894. padding: 0 32rpx;
  895. box-sizing: border-box;
  896. .list_item {
  897. width: 100%;
  898. margin: 0 auto 24rpx;
  899. padding: 32rpx;
  900. box-sizing: border-box;
  901. position: relative;
  902. background-color: #ffffff;
  903. border-radius: 16rpx;
  904. .list_item_top {
  905. .p1 {
  906. width: 86%;
  907. font-size: 28rpx;
  908. overflow: hidden;
  909. display: flex;
  910. align-items: center;
  911. .title{
  912. max-width: 75%;
  913. color: #333333;
  914. font-size: 28rpx;
  915. font-weight: 700;
  916. margin-right: 8rpx;
  917. overflow: hidden;
  918. text-overflow: ellipsis;
  919. white-space: nowrap;
  920. }
  921. .sub-title{
  922. border-radius: 32rpx;
  923. border:2rpx solid #0bbc58;
  924. padding: 4rpx 12rpx;
  925. font-size: 22rpx;
  926. font-weight: 400;
  927. overflow: hidden;
  928. text-overflow: ellipsis;
  929. white-space: nowrap;
  930. color:#0bbc58;
  931. margin-left: 20rpx;
  932. }
  933. }
  934. }
  935. .online-status{
  936. font-size: 28rpx;
  937. position: absolute;
  938. top:0rpx;
  939. text-align: center;
  940. right: 8rpx;
  941. top: 2rpx;
  942. width: 76px;
  943. height: 28px;
  944. // line-height: 28px;
  945. // border-radius: 0px 0px 0px 26px;
  946. // border: 1px solid #ffffff;
  947. image{
  948. width: 140rpx;
  949. height: 56rpx;
  950. }
  951. .status-text-online{
  952. color: #0BBC58;
  953. position: absolute;
  954. top: 0rpx;
  955. right: 0rpx;
  956. width: 120rpx;
  957. height: 56rpx;
  958. line-height: 56rpx;
  959. font-size: 26rpx;
  960. }
  961. .status-text-offline{
  962. color: #FB4E52;
  963. position: absolute;
  964. top: 0rpx;
  965. right: 0rpx;
  966. width: 120rpx;
  967. height: 56rpx;
  968. line-height: 56rpx;
  969. font-size: 26rpx;
  970. }
  971. }
  972. // .p2 {
  973. // color: #0BBC58;
  974. // background: #0bbc581a;
  975. // }
  976. // .p_out {
  977. // color: #FB4E52;
  978. // background: #fb4e521a;
  979. // }
  980. .list_item_text {
  981. margin-top: 20rpx;
  982. p {
  983. font-size: 24rpx;
  984. color: #303133;
  985. margin-top: 10rpx;
  986. word-break: break-all;
  987. }
  988. .label{
  989. color: #999999;
  990. text-align: left;
  991. margin-right: 32rpx;
  992. font-size: 24rpx;
  993. min-width: 90rpx;
  994. display: inline-block;
  995. }
  996. .nav-label{
  997. //超出隐藏
  998. display: inline-block;
  999. width: 70%;
  1000. overflow: hidden;
  1001. text-overflow: ellipsis;
  1002. white-space: nowrap;
  1003. }
  1004. }
  1005. .list_item_btn {
  1006. width: 126rpx;
  1007. color: #42b983;
  1008. height: 40rpx;
  1009. text-align: center;
  1010. border: 1rpx solid #42b983;
  1011. border-radius: 25rpx;
  1012. font-size: 24rpx;
  1013. line-height: 35rpx;
  1014. position: absolute;
  1015. bottom: 15rpx;
  1016. right: 20rpx;
  1017. }
  1018. }
  1019. }
  1020. .top {
  1021. position: fixed;
  1022. right: 30px;
  1023. bottom: 100px;
  1024. z-index: 100;
  1025. image {
  1026. width: 100rpx;
  1027. height: 100rpx;
  1028. }
  1029. }
  1030. </style>