index.vue 24 KB

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