diff --git a/pages/common/index/index.vue b/pages/common/index/index.vue index 81f44fa..b09cdef 100644 --- a/pages/common/index/index.vue +++ b/pages/common/index/index.vue @@ -5,7 +5,6 @@ rightIcon="/static/images/add.png" @right-click="scan"> - 0 && arguments[0] !== undefined ? arguments[0] : '';\n if (this.loading || this.finished) return;\n this.loading = true;\n var data = {\n pageNum: this.page,\n pageSize: this.size,\n deviceType: deviceType // 使用传入的设备类型\n };\n\n (0, _index.deviceInfo)(data).then(function (res) {\n if (res.code == 200) {\n var newDevices = res.rows.map(function (device) {\n return _objectSpread(_objectSpread({}, device), {}, {\n showConfirm: false\n });\n });\n\n // 如果是第一页或切换分类,替换数据\n _this2.deviceList = _this2.page === 1 ? newDevices : [].concat((0, _toConsumableArray2.default)(_this2.deviceList), (0, _toConsumableArray2.default)(newDevices));\n _this2.total = res.total;\n // 判断是否加载完成\n if (res.rows.length < _this2.size || _this2.deviceList.length >= _this2.total) {\n _this2.finished = true;\n } else {\n _this2.page++;\n }\n }\n }).finally(function () {\n _this2.loading = false;\n });\n },\n // 滚动触底事件处理\n onScrollToLower: function onScrollToLower() {\n this.getData();\n },\n scan: function scan() {\n this.showTooltip = !this.showTooltip;\n },\n handleMenuClick: function handleMenuClick(item) {\n this.showTooltip = false; // 关闭弹窗\n switch (item.action) {\n case 'scan':\n uni.navigateTo({\n url: '/pages/common/scan/scan'\n });\n break;\n case 'bluetooth':\n uni.navigateTo({\n url: '/pages/6155/bluetooth/bluetooth'\n });\n break;\n }\n },\n // 右滑点击事件处理\n handleSwipeClick: function handleSwipeClick(e, item, index) {\n var content = e.content;\n __f__(\"log\", e, 'eeeee', \" at pages/common/index/index.vue:252\");\n switch (content.text) {\n case '删除':\n this.handleDeleteDevice(item, index);\n break;\n case '重命名':\n this.handleRenameDevice(item, index);\n break;\n }\n ;\n },\n // 删除设备\n handleDeleteDevice: function handleDeleteDevice(item, index) {\n this.deviceId = item;\n this.deleteShow = true;\n uni.hideTabBar();\n },\n // 确认删除\n handleBtn: function handleBtn() {\n var _this3 = this;\n uni.showTabBar();\n var data = {\n id: this.deviceId.id\n };\n (0, _index.deviceUnbind)(data).then(function (res) {\n if (res.code == 200) {\n uni.showToast({\n title: '删除成功',\n icon: 'none',\n duration: 1000\n });\n setTimeout(function () {\n _this3.onIntall();\n }, 500);\n _this3.deleteShow = false;\n } else {\n uni.showToast({\n title: res.msg,\n icon: 'none',\n duration: 1000\n });\n }\n });\n },\n // 重命名设备\n handleRenameDevice: function handleRenameDevice(item, index) {\n this.RenameModel = true;\n uni.hideTabBar();\n this.deviceId = item;\n },\n handleBtnName: function handleBtnName() {\n var _this4 = this;\n uni.showTabBar();\n var data = {\n id: this.deviceId.id,\n deviceName: this.deviceName\n };\n (0, _index.deviceReName)(data).then(function (res) {\n if (res.code == 200) {\n uni.showToast({\n title: res.msg,\n icon: 'none',\n duration: 1000\n });\n setTimeout(function () {\n _this4.onIntall();\n }, 500);\n _this4.RenameModel = false;\n _this4.deviceName = '';\n } else {\n uni.showToast({\n title: res.msg,\n icon: 'none',\n duration: 1000\n });\n }\n });\n },\n // 发生短信\n handleSend: function handleSend() {\n uni.navigateTo({\n url: '/pages/common/send/index'\n });\n },\n handleFile: function handleFile(item) {\n __f__(\"log\", item, 'item', \" at pages/common/index/index.vue:334\");\n // communicationMode 0是4G 1是蓝牙\n if (item.communicationMode == 0) {\n uni.navigateTo({\n url: '/pages/6170/deviceControl/index'\n });\n } else {\n uni.navigateTo({\n url: '/pages/6155/index'\n });\n }\n },\n onIntall: function onIntall() {\n this.page = 1;\n this.finished = false;\n this.deviceList = [];\n this.getData(); // 重新加载第一页数据\n }\n },\n onShow: function onShow() {\n this.getTab();\n this.onIntall();\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 19)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/common/index/index.vue"],"names":["data","navBarHeight","deviceList","tabs","activeTab","showTooltip","Options","text","style","backgroundColor","borderRadius","width","navTitle","deleteShow","RenameModel","menuItems","icon","action","page","size","total","loading","finished","deviceId","deviceName","methods","getTab","id","name","typeName","res","communicationMode","switchTab","getData","pageNum","pageSize","deviceType","device","showConfirm","onScrollToLower","scan","handleMenuClick","uni","url","handleSwipeClick","content","e","handleDeleteDevice","handleBtn","title","duration","setTimeout","handleRenameDevice","handleBtnName","handleSend","handleFile","onIntall","onShow"],"mappings":";;;;;;;;;AA6GA;AAKA;AAAA;AAAA,eACA;EACAA;IACA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;QACAC;QACAC;UACAC;UACAC;UACAC;QACA;MACA,GACA;QACAJ;QACAC;UACAC;UACAC;UACAC;QACA;MACA,EACA;;MACAC;MACAC;MACAC;MACAC;QACAR;QACAS;QACAC;MACA,GACA;QACAV;QACAS;QACAC;MACA,EACA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;MACAC;MACAC;IACA;EACA;;EACAC;IACA;IACAC;MAAA;MACA;QACA;UACA;YACAC;YACAC;YACAC;UACA,2CACAC;YAAA;cACAH;cACAC;cACAC;cACAE;YACA;UAAA,IACA;QACA;MACA;IACA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IACA;IACA;IACAC;MAAA;MAAA;MACA;MACA;MACA;QACAC;QACAC;QACAC;MACA;;MACA;QACA;UACA;YAAA,uCACAC;cACAC;YAAA;UAAA,CACA;;UAEA;UACA;UACA;UACA;UACA;YACA;UACA;YACA;UACA;QACA;MACA;QACA;MACA;IACA;IACA;IACAC;MACA;IACA;IACAC;MACA;IACA;IAEAC;MACA;MACA;QACA;UACAC;YACAC;UACA;UACA;QACA;UACAD;YACAC;UACA;UACA;MAAA;IAEA;IACA;IACAC;MACA,IACAC,UACAC,EADAD;MAEA;MACA;QACA;UACA;UACA;QACA;UACA;UACA;MAAA;MACA;IACA;IACA;IACAE;MACA;MACA;MACAL;IACA;IACA;IACAM;MAAA;MACAN;MACA;QACAf;MACA;MACA;QACA;UACAe;YACAO;YACAjC;YACAkC;UACA;UACAC;YACA;UACA;UACA;QACA;UACAT;YACAO;YACAjC;YACAkC;UACA;QACA;MACA;IACA;IACA;IACAE;MACA;MACAV;MACA;IACA;IACAW;MAAA;MACAX;MACA;QACAf;QACAH;MACA;MACA;QACA;UACAkB;YACAO;YACAjC;YACAkC;UACA;UACAC;YACA;UACA;UACA;UACA;QACA;UACAT;YACAO;YACAjC;YACAkC;UACA;QACA;MACA;IACA;IACA;IACAI;MACAZ;QACAC;MACA;IACA;IACAY;MACA;MACA;MACA;QACAb;UACAC;QACA;MACA;QACAD;UACAC;QACA;MACA;IAEA;IACAa;MACA;MACA;MACA;MACA;IACA;EACA;EACAC;IACA;IACA;EACA;AAEA;AAAA,2B","file":"49.js","sourcesContent":["<template>\r\n\t<view>\r\n\t\t<!-- 使用自定义导航栏 -->\r\n\t\t<custom-navbar :title=\"navTitle\" :showBack=\"false\" backgroundColor=\"#202020\" color=\"#FFFFFF\"\r\n\t\t\trightIcon=\"/static/images/add.png\" @right-click=\"scan\"></custom-navbar>\r\n\t\t<view class=\"device-page\" :style=\"{ paddingTop: navBarHeight + 'px' }\">\r\n\t\t\t<!-- handleSend   发送信息 -->\r\n\t\t\r\n\t\t\t<scroll-view class=\"tab-bar\" scroll-x=\"true\" scroll-with-animation>\r\n\t\t\t\t<view class=\"tab-container\">\r\n\t\t\t\t\t<view v-for=\"(tab, index) in tabs\" :key=\"index\"\r\n\t\t\t\t\t\t:class=\"['tab-item', activeTab === index ? 'active' : '']\" @click=\"switchTab(tab,index)\">\r\n\t\t\t\t\t\t{{tab.typeName}}\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\t\t\t</scroll-view>\r\n\t\t\t<view class=\"sendFlex\">\r\n\t\t\t\t<view>\r\n\t\t\t\t\t<image src=\"/static/images/gprs.png\" class=\"gprs\"></image>\r\n\t\t\t\t</view>\r\n\t\t\t\t<view class=\"callpolice\">报警</view>\r\n\t\t\t\t<view class=\"Sendmessage\" @click=\"handleSend\">发送信息</view>\r\n\t\t\t</view>\r\n\r\n\t\t\t<scroll-view class=\"device-list\" scroll-y @scrolltolower=\"onScrollToLower\" :lower-threshold=\"100\"\r\n\t\t\t\tstyle=\"height:80vh;\">\r\n\t\t\t\t<uni-swipe-action ref=\"swipeAction\">\r\n\t\t\t\t\t<block v-for=\"(item, index) in deviceList\" :key=\"index\" :ref=\"'swipeItem_' + index\">\r\n\t\t\t\t\t\t<uni-swipe-action-item :right-options=\"Options\" @click=\"handleSwipeClick($event, item, index)\"\r\n\t\t\t\t\t\t\tclass=\"device-card\">\r\n\t\t\t\t\t\t\t<!-- 设备卡片内容保持不变 -->\r\n\t\t\t\t\t\t\t<view @click.stop=\"handleFile(item)\">\r\n\t\t\t\t\t\t\t\t<view class=\"device-header\">\r\n\t\t\t\t\t\t\t\t\t<view class=\"deviceIMG\">\r\n\t\t\t\t\t\t\t\t\t\t<image :src=\"item.devicePic\" class=\"IMG\"></image>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t<view class=\"device-name\">\r\n\t\t\t\t\t\t\t\t\t\t<view>设备:{{item.deviceName}}</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"ID\" v-if=\"item.communicationMode==0\">ID:{{item.deviceImei}}</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"ID\" v-else>ID:{{item.deviceMac}}</view>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<!-- <view class=\"device-status online\">已连接</view> -->\r\n\t\t\t\t\t\t\t\t<view class=\"device-status unline\">未连接</view>\r\n\t\t\t\t\t\t\t\t<view class=\"device-info\" v-if=\"item.communicationMode==0\">\r\n\t\t\t\t\t\t\t\t\t<text class=\"onlines\">在线</text>\r\n\t\t\t\t\t\t\t\t\t<text class=\"line\"></text>\r\n\t\t\t\t\t\t\t\t\t<text>电量：90%</text>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<image src=\"/static/images/cires.png\" class=\"circle\"></image>\r\n\t\t\t\t\t\t</uni-swipe-action-item>\r\n\t\t\t\t\t</block>\r\n\t\t\t\t</uni-swipe-action>\r\n\t\t\t\t<!-- 加载状态提示 -->\r\n\t\t\t\t<view class=\"loading-status\">\r\n\t\t\t\t\t<text v-if=\"loading\">加载中...</text>\r\n\t\t\t\t\t<text v-if=\"finished\">没有更多数据了</text>\r\n\t\t\t\t</view>\r\n\t\t\t</scroll-view>\r\n\t\t</view>\r\n\t\t<!-- 删除弹框 -->\r\n\t\t<view class=\"agreement-mask\" v-if=\"deleteShow\">\r\n\t\t\t<view class=\"agreement-popupC\">\r\n\t\t\t\t<view class=\"popup-content\">\r\n\t\t\t\t\t<image src=\"/static/images/dell.png\" mode=\"\" class=\"svg\"></image>\r\n\t\t\t\t\t<uni-icon class=\"trash\"></uni-icon>\r\n\t\t\t\t\t<view>\r\n\t\t\t\t\t\t<view class=\"popup-Title\">确定删除所选设备！</view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\t\t\t\t<!-- 按钮组 -->\r\n\t\t\t\t<view class=\"popup-buttons\">\r\n\t\t\t\t\t<button class=\"btn agreeBtn\" @click=\"handleBtn\">确定</button>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</view>\r\n\t\t<!-- =========重命名============== -->\r\n\t\t<view class=\"agreement-mask\" v-if=\"RenameModel\">\r\n\t\t\t<view class=\"agreement-popupD\">\r\n\t\t\t\t<view class=\"popup-content\">\r\n\t\t\t\t\t<view>\r\n\t\t\t\t\t\t<view class=\"popup-flex\">\r\n\t\t\t\t\t\t\t<text>设备名称</text>\r\n\t\t\t\t\t\t\t<input type=\"text\" v-model=\"deviceName\" placeholder=\"请输入设备名称\" class=\"popup-input\" />\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\t\t\t\t<!-- 按钮组 -->\r\n\t\t\t\t<view class=\"popup-buttons\" style=\"margin-top:50rpx;\">\r\n\t\t\t\t\t<button class=\"btn agreeBtn4\" @click=\"handleBtnName\">确定</button>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</view>\r\n\t\t<!-- 小提示框 -->\r\n\t\t<view class=\"tooltip-box\" v-if=\"showTooltip\">\r\n\t\t\t<view class=\"tooltip-arrow\"></view>\r\n\t\t\t<view class=\"tooltip-content\">\r\n\t\t\t\t<view class=\"tooltip-item\" v-for=\"(item, index) in menuItems\" :key=\"index\"\r\n\t\t\t\t\t@click=\"handleMenuClick(item)\">\r\n\t\t\t\t\t<image :src=\"item.icon\" class=\"item-icon\" />\r\n\t\t\t\t\t<text>{{ item.text }}</text>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</view>\r\n\t</view>\r\n</template>\r\n\r\n<script>\r\n\timport {\r\n\t\tdeviceTypeList,\r\n\t\tdeviceInfo,\r\n\t\tdeviceUnbind, //删除设备\r\n\t\tdeviceReName\r\n\t} from '@/api/common/index.js'\r\n\texport default {\r\n\t\tdata() {\r\n\t\t\treturn {\r\n\t\t\t\tnavBarHeight: 70 + uni.getSystemInfoSync().statusBarHeight,\r\n\t\t\t\tdeviceList: [],\r\n\t\t\t\ttabs: [],\r\n\t\t\t\tactiveTab: 0,\r\n\t\t\t\tshowTooltip: false,\r\n\t\t\t\tOptions: [{\r\n\t\t\t\t\t\ttext: '重命名',\r\n\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\tbackgroundColor: '#E09319',\r\n\t\t\t\t\t\t\tborderRadius: '16px',\r\n\t\t\t\t\t\t\twidth: '240rpx', // 初始宽度\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttext: '删除',\r\n\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\tbackgroundColor: 'rgb(240, 60, 60)',\r\n\t\t\t\t\t\t\tborderRadius: '16px',\r\n\t\t\t\t\t\t\twidth: '240rpx', // 初始宽度\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t],\r\n\t\t\t\tnavTitle: \"我的设备\",\r\n\t\t\t\tdeleteShow: false,\r\n\t\t\t\tRenameModel: false,\r\n\t\t\t\tmenuItems: [{\r\n\t\t\t\t\t\ttext: '扫一扫添加',\r\n\t\t\t\t\t\ticon: '/static/images/scane.png',\r\n\t\t\t\t\t\taction: 'scan'\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttext: '蓝牙添加',\r\n\t\t\t\t\t\ticon: '/static/images/bluetooth.png',\r\n\t\t\t\t\t\taction: 'bluetooth'\r\n\t\t\t\t\t}\r\n\t\t\t\t],\r\n\t\t\t\tpage: 1, // 当前页码\r\n\t\t\t\tsize:10, // 每页条数\r\n\t\t\t\ttotal: 0, // 总数据量\r\n\t\t\t\tloading: false,\r\n\t\t\t\tfinished: false,\r\n\t\t\t\tdeviceId: '',\r\n\t\t\t\tdeviceName: \"\" //重命名\r\n\t\t\t}\r\n\t\t},\r\n\t\tmethods: {\r\n\t\t\t// tab导航切换栏\r\n\t\t\tgetTab() {\r\n\t\t\t\tdeviceTypeList({}).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tthis.tabs = [{\r\n\t\t\t\t\t\t\t\tid: '',\r\n\t\t\t\t\t\t\t\tname: '全部设备',\r\n\t\t\t\t\t\t\t\ttypeName: '全部设备'\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t...res.data.map(item => ({\r\n\t\t\t\t\t\t\t\tid: item.id,\r\n\t\t\t\t\t\t\t\tname: item.typeName,\r\n\t\t\t\t\t\t\t\ttypeName: item.typeName,\r\n\t\t\t\t\t\t\t\tcommunicationMode: item.communicationMode\r\n\t\t\t\t\t\t\t}))\r\n\t\t\t\t\t\t];\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\t// tab切换页\r\n\t\t\tswitchTab(tab, index) {\r\n\t\t\t\tthis.deviceList = [];\r\n\t\t\t\tthis.activeTab = index;\r\n\t\t\t\tthis.page = 1; // 重置页码\r\n\t\t\t\tthis.finished = false; // 重\r\n\t\t\t\t// 明确传递参数，空字符串改为null或undefined\r\n\t\t\t\tconst deviceType = tab.id === '' ? undefined : tab.id;\r\n\t\t\t\tthis.getData(deviceType);\r\n\t\t\t},\r\n\t\t\t// 获取设备列表\r\n\t\t\tgetData(deviceType = '') {\r\n\t\t\t\tif (this.loading || this.finished) return;\r\n\t\t\t\tthis.loading = true;\r\n\t\t\t\tlet data = {\r\n\t\t\t\t\tpageNum: this.page,\r\n\t\t\t\t\tpageSize: this.size,\r\n\t\t\t\t\tdeviceType: deviceType // 使用传入的设备类型\r\n\t\t\t\t}\r\n\t\t\t\tdeviceInfo(data).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tconst newDevices = res.rows.map(device => ({\r\n\t\t\t\t\t\t\t...device,\r\n\t\t\t\t\t\t\tshowConfirm: false\r\n\t\t\t\t\t\t}));\r\n\r\n\t\t\t\t\t\t// 如果是第一页或切换分类，替换数据\r\n\t\t\t\t\t\tthis.deviceList = this.page === 1 ? newDevices : [...this.deviceList, ...newDevices];\r\n\t\t\t\t\t\tthis.total = res.total;\r\n\t\t\t\t\t\t// 判断是否加载完成\r\n\t\t\t\t\t\tif (res.rows.length < this.size || this.deviceList.length >= this.total) {\r\n\t\t\t\t\t\t\tthis.finished = true;\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\tthis.page++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}).finally(() => {\r\n\t\t\t\t\tthis.loading = false;\r\n\t\t\t\t});\r\n\t\t\t},\r\n\t\t\t// 滚动触底事件处理\r\n\t\t\tonScrollToLower() {\r\n\t\t\t\tthis.getData();\r\n\t\t\t},\r\n\t\t\tscan() {\r\n\t\t\t\tthis.showTooltip = !this.showTooltip;\r\n\t\t\t},\r\n\r\n\t\t\thandleMenuClick(item) {\r\n\t\t\t\tthis.showTooltip = false; // 关闭弹窗\r\n\t\t\t\tswitch (item.action) {\r\n\t\t\t\t\tcase 'scan':\r\n\t\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\t\turl: '/pages/common/scan/scan'\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase 'bluetooth':\r\n\t\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\t\turl: '/pages/6155/bluetooth/bluetooth'\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t// 右滑点击事件处理\r\n\t\t\thandleSwipeClick(e, item, index) {\r\n\t\t\t\tconst {\r\n\t\t\t\t\tcontent\r\n\t\t\t\t} = e\r\n\t\t\t\tconsole.log(e, 'eeeee');\r\n\t\t\t\tswitch (content.text) {\r\n\t\t\t\t\tcase '删除':\r\n\t\t\t\t\t\tthis.handleDeleteDevice(item, index)\r\n\t\t\t\t\t\tbreak\r\n\t\t\t\t\tcase '重命名':\r\n\t\t\t\t\t\tthis.handleRenameDevice(item, index)\r\n\t\t\t\t\t\tbreak\r\n\t\t\t\t};\r\n\t\t\t},\r\n\t\t\t// 删除设备\r\n\t\t\thandleDeleteDevice(item, index) {\r\n\t\t\t\tthis.deviceId = item\r\n\t\t\t\tthis.deleteShow = true\r\n\t\t\t\tuni.hideTabBar()\r\n\t\t\t},\r\n\t\t\t// 确认删除\r\n\t\t\thandleBtn() {\r\n\t\t\t\tuni.showTabBar()\r\n\t\t\t\tlet data = {\r\n\t\t\t\t\tid: this.deviceId.id\r\n\t\t\t\t}\r\n\t\t\t\tdeviceUnbind(data).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: '删除成功',\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tthis.onIntall();\r\n\t\t\t\t\t\t}, 500);\r\n\t\t\t\t\t\tthis.deleteShow = false\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: res.msg,\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\t// 重命名设备\r\n\t\t\thandleRenameDevice(item, index) {\r\n\t\t\t\tthis.RenameModel = true\r\n\t\t\t\tuni.hideTabBar()\r\n\t\t\t\tthis.deviceId = item\r\n\t\t\t},\r\n\t\t\thandleBtnName() {\r\n\t\t\t\tuni.showTabBar()\r\n\t\t\t\tlet data = {\r\n\t\t\t\t\tid: this.deviceId.id,\r\n\t\t\t\t\tdeviceName: this.deviceName\r\n\t\t\t\t}\r\n\t\t\t\tdeviceReName(data).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: res.msg,\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tthis.onIntall();\r\n\t\t\t\t\t\t}, 500);\r\n\t\t\t\t\t\tthis.RenameModel = false\r\n\t\t\t\t\t\tthis.deviceName = ''\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: res.msg,\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\t// 发生短信\r\n\t\t\thandleSend() {\r\n\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\turl: '/pages/common/send/index'\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\thandleFile(item) {\r\n\t\t\t\tconsole.log(item, 'item');\r\n\t\t\t\t// communicationMode 0是4G 1是蓝牙\r\n\t\t\t\tif (item.communicationMode == 0) {\r\n\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\turl: '/pages/6170/deviceControl/index'\r\n\t\t\t\t\t})\r\n\t\t\t\t} else {\r\n\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\turl: '/pages/6155/index'\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\r\n\t\t\t},\r\n\t\t\tonIntall() {\r\n\t\t\t\tthis.page = 1;\r\n\t\t\t\tthis.finished = false;\r\n\t\t\t\tthis.deviceList = [];\r\n\t\t\t\tthis.getData(); // 重新加载第一页数据\r\n\t\t\t}\r\n\t\t},\r\n\t\tonShow() {\r\n\t\t\tthis.getTab()\r\n\t\t\tthis.onIntall()\r\n\t\t}\r\n\r\n\t}\r\n</script>\r\n\r\n<style>\r\n\t/* 页面整体样式 */\r\n\t.device-page {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: column;\r\n\t\tmin-height: 100vh;\r\n\t\tbackground-color: rgb(18, 18, 18);\r\n\t\tpadding: 30rpx;\r\n\t}\r\n\r\n\t.tab-bar {\r\n\t\twidth: 100%;\r\n\t\tcolor: rgb(255, 255, 255);\r\n\t\twhite-space: nowrap;\r\n\t\t/* 禁止换行 */\r\n\t\toverflow: hidden;\r\n\r\n\t}\r\n\r\n\t.tab-container {\r\n\t\tdisplay: flex;\r\n\t\t/* justify-content: space-around; */\r\n\t\tcursor: pointer;\r\n\t\tmargin-bottom: 40rpx;\r\n\t/* \tmin-width: 100%; */\r\n\t\t/* 最小宽度 */\r\n\t}\r\n\r\n\t.tab-item {\r\n\t\tfont-size: 28rpx;\r\n\t/* \tmin-width: 120rpx; */\r\n\t\tpadding: 0 30rpx; /* 左右内边距 */\r\n\t\t  text-align: center; /* 文字居中 */\r\n\t\t/* 设置最小宽度 */\r\n\t}\r\n\r\n\t.active {\r\n\t\tcolor: rgba(187, 230, 0, 1);\r\n\t\tborder-bottom: 6rpx solid rgba(187, 230, 0, 1);\r\n\t\theight: 60rpx;\r\n\t}\r\n\r\n\t.sendFlex {\r\n\t\tdisplay: flex;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\tjustify-content: flex-end;\r\n\t\tcursor: pointer;\r\n\t\tmargin-bottom: 30rpx;\r\n\t\tfont-size: 28rpx;\r\n\t}\r\n\t.gprs{\r\n\t\twidth:20rpx;\r\n\t\theight:26rpx;\r\n\t\tposition: absolute;\r\n\t\tleft:50rpx\r\n\t}\r\n\r\n\t.Sendmessage {\r\n\t\tmargin-left: 50rpx;\r\n\t\tborder: 1px solid rgba(187, 230, 0, 0.4);\r\n\t\tborder-radius: 20px;\r\n\t\tpadding: 7rpx 20rpx;\r\n\t\tcolor: rgba(187, 230, 0, 1);\r\n\t}\r\n\t.callpolice{\r\n\t\tborder: 1px solid rgba(224, 52, 52, 0.4);\r\n\t\tborder-radius: 20px;\r\n\t\tcolor: rgba(224, 52, 52, 1);\r\n\t\twidth: 150rpx;\r\n\t\ttext-align: center;\r\n\t\tpadding: 5rpx 10rpx;\r\n\t}\r\n\r\n\t/* 设备卡片 */\r\n\t.device-card {\r\n\t\tbackground-color: rgb(26, 26, 26);\r\n\t\tborder-radius: 16rpx;\r\n\t\t/* padding: 30rpx; */\r\n\t\tmargin-bottom: 20rpx;\r\n\t\t/* \t\tbox-shadow: 0 2rpx 10rpx rgba(0, 0, 0, 0.05); */\r\n\t\tbox-sizing: border-box;\r\n\t\tposition: relative;\r\n\t}\r\n\r\n\t.device-header {\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t\tmargin-bottom: 15rpx;\r\n\t\tpadding: 30rpx 0 10rpx 30rpx;\r\n\t}\r\n\r\n\t.device-name {\r\n\t\tfont-size: 28rpx;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\tmargin-left: 24rpx;\r\n\t\tline-height: 50rpx;\r\n\t}\r\n\r\n\t.ID {\r\n\t\tcolor: rgba(255, 255, 255, 0.6);\r\n\t\tfont-size: 24rpx;\r\n\t}\r\n\r\n\t.device-status {\r\n\t\twidth: 122rpx;\r\n\t\theight: 52rpx;\r\n\t\tfont-size: 26rpx;\r\n\t\tborder-radius: 0px 8px 0px 8px;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tposition: absolute;\r\n\t\ttop: 0rpx;\r\n\t\tright: 0rpx;\r\n\t\ttext-align: center;\r\n\t\tline-height: 52rpx;\r\n\t}\r\n\r\n\t.circle {\r\n\t\twidth: 8rpx;\r\n\t\theight: 40rpx;\r\n\t\tposition: absolute;\r\n\t\tright: 40rpx;\r\n\t\ttop: 80rpx;\r\n\t}\r\n\r\n\t.online {\r\n\t\tcolor: rgb(187, 230, 0);\r\n\t}\r\n\r\n\t.unline {\r\n\t\tcolor: rgba(255, 255, 255, 0.4);\r\n\t}\r\n\r\n\t.device-id {\r\n\t\tfont-size: 26rpx;\r\n\t\tcolor: #999;\r\n\t\tmargin-bottom: 20rpx;\r\n\t\tdisplay: block;\r\n\t}\r\n\r\n\t.device-info {\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: space-evenly;\r\n\t\tfont-size: 28rpx;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\tposition: relative;\r\n\t\tpadding: 0rpx 0rpx 30rpx 30rpx;\r\n\t}\r\n\r\n\t.deviceIMG {\r\n\t\twidth: 100rpx;\r\n\t\theight: 100rpx;\r\n\t\tborder-radius: 16rpx;\r\n\t\tposition: relative;\r\n\t\tbackground-color: rgba(42, 42, 42, 0.6);\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t}\r\n\r\n\t.IMG {\r\n\t\twidth: 68rpx;\r\n\t\theight: 50rpx;\r\n\t\tmargin-left: 17%;\r\n\t}\r\n\r\n\t.onlines::before {\r\n\t\tcontent: '';\r\n\t\tposition: absolute;\r\n\t\twidth: 15rpx;\r\n\t\theight: 15rpx;\r\n\t\tbackground: rgb(0, 171, 103);\r\n\t\tborder-radius: 50%;\r\n\t\tleft: 120rpx;\r\n\t\ttop: 15rpx\r\n\t}\r\n\r\n\t.line {\r\n\t\twidth: 2rpx;\r\n\t\theight: 24rpx;\r\n\t\tbackground: linear-gradient(90deg,\r\n\t\t\t\trgba(0, 0, 0, 0) 0%,\r\n\t\t\t\trgb(255, 255, 255) 50%,\r\n\t\t\t\trgba(255, 255, 255, 0) 100%);\r\n\t\tmargin-top: 12rpx;\r\n\t}\r\n\r\n\t.loading-status {\r\n\t\ttext-align: center;\r\n\t\tcolor: rgba(255, 255, 255, 0.6);\r\n\t\tpadding: 20rpx;\r\n\t\tfont-size: 22rpx;\r\n\t}\r\n\r\n\t.device-uplod {\r\n\t\tbackground-color: rgb(26, 26, 26);\r\n\t\tborder-radius: 16rpx;\r\n\t\talign-items: center;\r\n\t\ttext-align: center;\r\n\t\theight: 202rpx;\r\n\t\tline-height: 200rpx;\r\n\t}\r\n\r\n\t.uni-swipe-action-item__options {\r\n\t\ttransition: width 0.3s ease;\r\n\t}\r\n\r\n\t/* 遮罩层 */\r\n\t.agreement-mask {\r\n\t\tposition: fixed;\r\n\t\ttop: 0;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\tbottom: 0;\r\n\t\tbackground-color: rgba(0, 0, 0, 0.5);\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: center;\r\n\t\talign-items: center;\r\n\t\tz-index: 9999;\r\n\t}\r\n\r\n\t.popup-Title {\r\n\t\tcolor: rgba(255, 255, 255, 0.86);\r\n\t\ttext-align: center;\r\n\t\tpadding: 30rpx 0rpx;\r\n\t}\r\n\r\n\t.popup-buttons {\r\n\t\tdisplay: flex;\r\n\t\ttext-align: center;\r\n\t}\r\n\r\n\t/* 弹窗主体 */\r\n\t.agreement-popup {\r\n\t\twidth: 100%;\r\n\t\theight: 50%;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tborder-radius: 60rpx 60rpx 0rpx 0rpx;\r\n\t\tpadding: 40rpx;\r\n\t\tbox-sizing: border-box;\r\n\t\tposition: absolute;\r\n\t\tbottom: 0rpx;\r\n\t}\r\n\r\n\t.agreement-popupC {\r\n\t\twidth: 60%;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tborder-radius: 40rpx;\r\n\t\tpadding: 30rpx;\r\n\t\ttext-align: center;\r\n\t\tborder: 1px solid rgba(255, 200, 78, 0.3);\r\n\t}\r\n\r\n\t.agreement-popupD {\r\n\t\twidth: 70%;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tborder-radius: 40rpx;\r\n\t\tpadding: 40rpx;\r\n\t\ttext-align: center;\r\n\t\tborder: 1px solid rgba(187, 230, 0, 0.3);\r\n\t}\r\n\r\n\t.popup-flex {\r\n\t\tdisplay: flex;\r\n\t\twhite-space: nowrap;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\theight: 50rpx;\r\n\t\tpadding: 30rpx;\r\n\t}\r\n\r\n\t.popup-input {\r\n\t\tborder: 1px solid rgba(255, 255, 255, 0.4);\r\n\t\tborder-radius: 12rpx;\r\n\t\tmargin-left: 15rpx;\r\n\t\tpadding: 10rpx 0rpx;\r\n\t\tfont-size: 28rpx;\r\n\t}\r\n\r\n\t.svg {\r\n\t\twidth: 58rpx;\r\n\t\theight: 62rpx;\r\n\t}\r\n\r\n\t/* 通用按钮样式 */\r\n\t.btn {\r\n\t\theight: 60rpx;\r\n\t\tline-height: 60rpx;\r\n\t\tborder-radius: 40rpx;\r\n\t\tfont-size: 24rpx;\r\n\t\tmargin: 10rpx auto;\r\n\t\ttext-align: center;\r\n\r\n\t}\r\n\r\n\t/* 同意按钮 */\r\n\t.agreeBtn {\r\n\t\tbackground: #FFC84E;\r\n\t\tcolor: #232323;\r\n\t\tborder: none;\r\n\t\twidth: 170rpx !important;\r\n\t}\r\n\r\n\t.agreeBtn4 {\r\n\t\tbackground: rgba(187, 230, 0, 1);\r\n\t\tcolor: #232323;\r\n\t\tborder: none;\r\n\t\twidth: 170rpx !important;\r\n\t}\r\n\r\n\t.closeBtn {\r\n\t\tborder: 1px solid rgba(255, 255, 255, 0.2);\r\n\t\tbackground-color: rgba(35, 35, 35, 0.87);\r\n\t\tcolor: rgba(255, 255, 255, 1);\r\n\t}\r\n\r\n\t/* 提示框样式 */\r\n\t.tooltip-box {\r\n\t\tposition: fixed;\r\n\t\tright: 18rpx;\r\n\t\ttop: 140rpx;\r\n\t\t/* 根据导航栏高度调整 */\r\n\t\tz-index: 9999;\r\n\t}\r\n\r\n\t.tooltip-arrow {\r\n\t\twidth: 0;\r\n\t\theight: 0;\r\n\t\tborder-left: 8px solid transparent;\r\n\t\tborder-right: 8px solid transparent;\r\n\t\tborder-bottom: 8px solid #333;\r\n\t\tposition: absolute;\r\n\t\tright: 12px;\r\n\t\ttop: -8px;\r\n\t}\r\n\r\n\t.tooltip-content {\r\n\t\tborder-radius: 8rpx;\r\n\t\tbackdrop-filter: blur(14px);\r\n\t\tbackground: rgba(58, 58, 58, 1);\r\n\t\tpadding: 10px 0;\r\n\t\tmin-width: 120px;\r\n\t}\r\n\r\n\t.tooltip-item {\r\n\t\tpadding: 8px 16px;\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t\tcolor: #fff;\r\n\t}\r\n\r\n\t.tooltip-item text {\r\n\t\tmargin-left: 8px;\r\n\t\tfont-size: 14px;\r\n\t}\r\n\r\n\t.item-icon {\r\n\t\twidth: 16px;\r\n\t\theight: 16px;\r\n\t}\r\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///49\n"); +eval("/* WEBPACK VAR INJECTION */(function(__f__) {\n\nvar _interopRequireDefault = __webpack_require__(/*! @babel/runtime/helpers/interopRequireDefault */ 1);\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\nvar _defineProperty2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/defineProperty */ 2));\nvar _toConsumableArray2 = _interopRequireDefault(__webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ 50));\nvar _index = __webpack_require__(/*! @/api/common/index.js */ 56);\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nvar _default = {\n data: function data() {\n return {\n navBarHeight: 70 + uni.getSystemInfoSync().statusBarHeight,\n deviceList: [],\n tabs: [],\n activeTab: 0,\n showTooltip: false,\n Options: [{\n text: '重命名',\n style: {\n backgroundColor: '#E09319',\n borderRadius: '16px',\n width: '240rpx' // 初始宽度\n }\n }, {\n text: '删除',\n style: {\n backgroundColor: 'rgb(240, 60, 60)',\n borderRadius: '16px',\n width: '240rpx' // 初始宽度\n }\n }],\n\n navTitle: \"我的设备\",\n deleteShow: false,\n RenameModel: false,\n menuItems: [{\n text: '扫一扫添加',\n icon: '/static/images/scane.png',\n action: 'scan'\n }, {\n text: '蓝牙添加',\n icon: '/static/images/bluetooth.png',\n action: 'bluetooth'\n }],\n page: 1,\n // 当前页码\n size: 10,\n // 每页条数\n total: 0,\n // 总数据量\n loading: false,\n finished: false,\n deviceId: '',\n deviceName: \"\" //重命名\n };\n },\n\n methods: {\n // tab导航切换栏\n getTab: function getTab() {\n var _this = this;\n (0, _index.deviceTypeList)({}).then(function (res) {\n if (res.code == 200) {\n _this.tabs = [{\n id: '',\n name: '全部设备',\n typeName: '全部设备'\n }].concat((0, _toConsumableArray2.default)(res.data.map(function (item) {\n return {\n id: item.id,\n name: item.typeName,\n typeName: item.typeName,\n communicationMode: item.communicationMode\n };\n })));\n }\n });\n },\n // tab切换页\n switchTab: function switchTab(tab, index) {\n this.deviceList = [];\n this.activeTab = index;\n this.page = 1; // 重置页码\n this.finished = false; // 重\n // 明确传递参数,空字符串改为null或undefined\n var deviceType = tab.id === '' ? undefined : tab.id;\n this.getData(deviceType);\n },\n // 获取设备列表\n getData: function getData() {\n var _this2 = this;\n var deviceType = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n if (this.loading || this.finished) return;\n this.loading = true;\n var data = {\n pageNum: this.page,\n pageSize: this.size,\n deviceType: deviceType // 使用传入的设备类型\n };\n\n (0, _index.deviceInfo)(data).then(function (res) {\n if (res.code == 200) {\n var newDevices = res.rows.map(function (device) {\n return _objectSpread(_objectSpread({}, device), {}, {\n showConfirm: false\n });\n });\n\n // 如果是第一页或切换分类,替换数据\n _this2.deviceList = _this2.page === 1 ? newDevices : [].concat((0, _toConsumableArray2.default)(_this2.deviceList), (0, _toConsumableArray2.default)(newDevices));\n _this2.total = res.total;\n // 判断是否加载完成\n if (res.rows.length < _this2.size || _this2.deviceList.length >= _this2.total) {\n _this2.finished = true;\n } else {\n _this2.page++;\n }\n }\n }).finally(function () {\n _this2.loading = false;\n });\n },\n // 滚动触底事件处理\n onScrollToLower: function onScrollToLower() {\n this.getData();\n },\n scan: function scan() {\n this.showTooltip = !this.showTooltip;\n },\n handleMenuClick: function handleMenuClick(item) {\n this.showTooltip = false; // 关闭弹窗\n switch (item.action) {\n case 'scan':\n uni.navigateTo({\n url: '/pages/common/scan/scan'\n });\n break;\n case 'bluetooth':\n uni.navigateTo({\n url: '/pages/6155/bluetooth/bluetooth'\n });\n break;\n }\n },\n // 右滑点击事件处理\n handleSwipeClick: function handleSwipeClick(e, item, index) {\n var content = e.content;\n __f__(\"log\", e, 'eeeee', \" at pages/common/index/index.vue:251\");\n switch (content.text) {\n case '删除':\n this.handleDeleteDevice(item, index);\n break;\n case '重命名':\n this.handleRenameDevice(item, index);\n break;\n }\n ;\n },\n // 删除设备\n handleDeleteDevice: function handleDeleteDevice(item, index) {\n this.deviceId = item;\n this.deleteShow = true;\n uni.hideTabBar();\n },\n // 确认删除\n handleBtn: function handleBtn() {\n var _this3 = this;\n uni.showTabBar();\n var data = {\n id: this.deviceId.id\n };\n (0, _index.deviceUnbind)(data).then(function (res) {\n if (res.code == 200) {\n uni.showToast({\n title: '删除成功',\n icon: 'none',\n duration: 1000\n });\n setTimeout(function () {\n _this3.onIntall();\n }, 500);\n _this3.deleteShow = false;\n } else {\n uni.showToast({\n title: res.msg,\n icon: 'none',\n duration: 1000\n });\n }\n });\n },\n // 重命名设备\n handleRenameDevice: function handleRenameDevice(item, index) {\n this.RenameModel = true;\n uni.hideTabBar();\n this.deviceId = item;\n },\n handleBtnName: function handleBtnName() {\n var _this4 = this;\n uni.showTabBar();\n var data = {\n id: this.deviceId.id,\n deviceName: this.deviceName\n };\n (0, _index.deviceReName)(data).then(function (res) {\n if (res.code == 200) {\n uni.showToast({\n title: res.msg,\n icon: 'none',\n duration: 1000\n });\n setTimeout(function () {\n _this4.onIntall();\n }, 500);\n _this4.RenameModel = false;\n _this4.deviceName = '';\n } else {\n uni.showToast({\n title: res.msg,\n icon: 'none',\n duration: 1000\n });\n }\n });\n },\n // 发生短信\n handleSend: function handleSend() {\n uni.navigateTo({\n url: '/pages/common/send/index'\n });\n },\n handleFile: function handleFile(item) {\n __f__(\"log\", item, 'item', \" at pages/common/index/index.vue:333\");\n // communicationMode 0是4G 1是蓝牙\n if (item.communicationMode == 0) {\n uni.navigateTo({\n url: '/pages/6170/deviceControl/index'\n });\n } else {\n uni.navigateTo({\n url: '/pages/6155/index'\n });\n }\n },\n onIntall: function onIntall() {\n this.page = 1;\n this.finished = false;\n this.getData(); // 重新加载第一页数据\n }\n },\n onShow: function onShow() {\n this.getTab();\n this.onIntall();\n }\n};\nexports.default = _default;\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./node_modules/@dcloudio/vue-cli-plugin-uni/lib/format-log.js */ 19)[\"default\"]))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["uni-app:///pages/common/index/index.vue"],"names":["data","navBarHeight","deviceList","tabs","activeTab","showTooltip","Options","text","style","backgroundColor","borderRadius","width","navTitle","deleteShow","RenameModel","menuItems","icon","action","page","size","total","loading","finished","deviceId","deviceName","methods","getTab","id","name","typeName","res","communicationMode","switchTab","getData","pageNum","pageSize","deviceType","device","showConfirm","onScrollToLower","scan","handleMenuClick","uni","url","handleSwipeClick","content","e","handleDeleteDevice","handleBtn","title","duration","setTimeout","handleRenameDevice","handleBtnName","handleSend","handleFile","onIntall","onShow"],"mappings":";;;;;;;;;AA4GA;AAKA;AAAA;AAAA,eACA;EACAA;IACA;MACAC;MACAC;MACAC;MACAC;MACAC;MACAC;QACAC;QACAC;UACAC;UACAC;UACAC;QACA;MACA,GACA;QACAJ;QACAC;UACAC;UACAC;UACAC;QACA;MACA,EACA;;MACAC;MACAC;MACAC;MACAC;QACAR;QACAS;QACAC;MACA,GACA;QACAV;QACAS;QACAC;MACA,EACA;MACAC;MAAA;MACAC;MAAA;MACAC;MAAA;MACAC;MACAC;MACAC;MACAC;IACA;EACA;;EACAC;IACA;IACAC;MAAA;MACA;QACA;UACA;YACAC;YACAC;YACAC;UACA,2CACAC;YAAA;cACAH;cACAC;cACAC;cACAE;YACA;UAAA,IACA;QACA;MACA;IACA;IACA;IACAC;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IACA;IACA;IACAC;MAAA;MAAA;MACA;MACA;MACA;QACAC;QACAC;QACAC;MACA;;MACA;QACA;UACA;YAAA,uCACAC;cACAC;YAAA;UAAA,CACA;;UAEA;UACA;UACA;UACA;UACA;YACA;UACA;YACA;UACA;QACA;MACA;QACA;MACA;IACA;IACA;IACAC;MACA;IACA;IACAC;MACA;IACA;IAEAC;MACA;MACA;QACA;UACAC;YACAC;UACA;UACA;QACA;UACAD;YACAC;UACA;UACA;MAAA;IAEA;IACA;IACAC;MACA,IACAC,UACAC,EADAD;MAEA;MACA;QACA;UACA;UACA;QACA;UACA;UACA;MAAA;MACA;IACA;IACA;IACAE;MACA;MACA;MACAL;IACA;IACA;IACAM;MAAA;MACAN;MACA;QACAf;MACA;MACA;QACA;UACAe;YACAO;YACAjC;YACAkC;UACA;UACAC;YACA;UACA;UACA;QACA;UACAT;YACAO;YACAjC;YACAkC;UACA;QACA;MACA;IACA;IACA;IACAE;MACA;MACAV;MACA;IACA;IACAW;MAAA;MACAX;MACA;QACAf;QACAH;MACA;MACA;QACA;UACAkB;YACAO;YACAjC;YACAkC;UACA;UACAC;YACA;UACA;UACA;UACA;QACA;UACAT;YACAO;YACAjC;YACAkC;UACA;QACA;MACA;IACA;IACA;IACAI;MACAZ;QACAC;MACA;IACA;IACAY;MACA;MACA;MACA;QACAb;UACAC;QACA;MACA;QACAD;UACAC;QACA;MACA;IAEA;IACAa;MACA;MACA;MAEA;IACA;EACA;EACAC;IACA;IACA;EACA;AAEA;AAAA,2B","file":"49.js","sourcesContent":["<template>\r\n\t<view>\r\n\t\t<!-- 使用自定义导航栏 -->\r\n\t\t<custom-navbar :title=\"navTitle\" :showBack=\"false\" backgroundColor=\"#202020\" color=\"#FFFFFF\"\r\n\t\t\trightIcon=\"/static/images/add.png\" @right-click=\"scan\"></custom-navbar>\r\n\t\t<view class=\"device-page\" :style=\"{ paddingTop: navBarHeight + 'px' }\">\r\n\t\t\t<!-- handleSend   发送信息 -->\r\n\t\t\t<scroll-view class=\"tab-bar\" scroll-x=\"true\" scroll-with-animation>\r\n\t\t\t\t<view class=\"tab-container\">\r\n\t\t\t\t\t<view v-for=\"(tab, index) in tabs\" :key=\"index\"\r\n\t\t\t\t\t\t:class=\"['tab-item', activeTab === index ? 'active' : '']\" @click=\"switchTab(tab,index)\">\r\n\t\t\t\t\t\t{{tab.typeName}}\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\t\t\t</scroll-view>\r\n\t\t\t<view class=\"sendFlex\">\r\n\t\t\t\t<view>\r\n\t\t\t\t\t<image src=\"/static/images/gprs.png\" class=\"gprs\"></image>\r\n\t\t\t\t</view>\r\n\t\t\t\t<view class=\"callpolice\">报警</view>\r\n\t\t\t\t<view class=\"Sendmessage\" @click=\"handleSend\">发送信息</view>\r\n\t\t\t</view>\r\n\r\n\t\t\t<scroll-view class=\"device-list\" scroll-y @scrolltolower=\"onScrollToLower\" :lower-threshold=\"100\"\r\n\t\t\t\tstyle=\"height:80vh;\">\r\n\t\t\t\t<uni-swipe-action ref=\"swipeAction\">\r\n\t\t\t\t\t<block v-for=\"(item, index) in deviceList\" :key=\"index\" :ref=\"'swipeItem_' + index\">\r\n\t\t\t\t\t\t<uni-swipe-action-item :right-options=\"Options\" @click=\"handleSwipeClick($event, item, index)\"\r\n\t\t\t\t\t\t\tclass=\"device-card\">\r\n\t\t\t\t\t\t\t<!-- 设备卡片内容保持不变 -->\r\n\t\t\t\t\t\t\t<view @click.stop=\"handleFile(item)\">\r\n\t\t\t\t\t\t\t\t<view class=\"device-header\">\r\n\t\t\t\t\t\t\t\t\t<view class=\"deviceIMG\">\r\n\t\t\t\t\t\t\t\t\t\t<image :src=\"item.devicePic\" class=\"IMG\"></image>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t\t<view class=\"device-name\">\r\n\t\t\t\t\t\t\t\t\t\t<view>设备:{{item.deviceName}}</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"ID\" v-if=\"item.communicationMode==0\">ID:{{item.deviceImei}}</view>\r\n\t\t\t\t\t\t\t\t\t\t<view class=\"ID\" v-else>ID:{{item.deviceMac}}</view>\r\n\t\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t\t<!-- <view class=\"device-status online\">已连接</view> -->\r\n\t\t\t\t\t\t\t\t<view class=\"device-status unline\">未连接</view>\r\n\t\t\t\t\t\t\t\t<view class=\"device-info\" v-if=\"item.communicationMode==0\">\r\n\t\t\t\t\t\t\t\t\t<text class=\"onlines\">在线</text>\r\n\t\t\t\t\t\t\t\t\t<text class=\"line\"></text>\r\n\t\t\t\t\t\t\t\t\t<text>电量：90%</text>\r\n\t\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t</view>\r\n\t\t\t\t\t\t\t<image src=\"/static/images/cires.png\" class=\"circle\"></image>\r\n\t\t\t\t\t\t</uni-swipe-action-item>\r\n\t\t\t\t\t</block>\r\n\t\t\t\t</uni-swipe-action>\r\n\t\t\t\t<!-- 加载状态提示 -->\r\n\t\t\t\t<view class=\"loading-status\">\r\n\t\t\t\t\t<text v-if=\"loading\">加载中...</text>\r\n\t\t\t\t\t<text v-if=\"finished\">没有更多数据了</text>\r\n\t\t\t\t</view>\r\n\t\t\t</scroll-view>\r\n\t\t</view>\r\n\t\t<!-- 删除弹框 -->\r\n\t\t<view class=\"agreement-mask\" v-if=\"deleteShow\">\r\n\t\t\t<view class=\"agreement-popupC\">\r\n\t\t\t\t<view class=\"popup-content\">\r\n\t\t\t\t\t<image src=\"/static/images/dell.png\" mode=\"\" class=\"svg\"></image>\r\n\t\t\t\t\t<uni-icon class=\"trash\"></uni-icon>\r\n\t\t\t\t\t<view>\r\n\t\t\t\t\t\t<view class=\"popup-Title\">确定删除所选设备！</view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\t\t\t\t<!-- 按钮组 -->\r\n\t\t\t\t<view class=\"popup-buttons\">\r\n\t\t\t\t\t<button class=\"btn agreeBtn\" @click=\"handleBtn\">确定</button>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</view>\r\n\t\t<!-- =========重命名============== -->\r\n\t\t<view class=\"agreement-mask\" v-if=\"RenameModel\">\r\n\t\t\t<view class=\"agreement-popupD\">\r\n\t\t\t\t<view class=\"popup-content\">\r\n\t\t\t\t\t<view>\r\n\t\t\t\t\t\t<view class=\"popup-flex\">\r\n\t\t\t\t\t\t\t<text>设备名称</text>\r\n\t\t\t\t\t\t\t<input type=\"text\" v-model=\"deviceName\" placeholder=\"请输入设备名称\" class=\"popup-input\" />\r\n\t\t\t\t\t\t</view>\r\n\t\t\t\t\t</view>\r\n\t\t\t\t</view>\r\n\t\t\t\t<!-- 按钮组 -->\r\n\t\t\t\t<view class=\"popup-buttons\" style=\"margin-top:50rpx;\">\r\n\t\t\t\t\t<button class=\"btn agreeBtn4\" @click=\"handleBtnName\">确定</button>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</view>\r\n\t\t<!-- 小提示框 -->\r\n\t\t<view class=\"tooltip-box\" v-if=\"showTooltip\">\r\n\t\t\t<view class=\"tooltip-arrow\"></view>\r\n\t\t\t<view class=\"tooltip-content\">\r\n\t\t\t\t<view class=\"tooltip-item\" v-for=\"(item, index) in menuItems\" :key=\"index\"\r\n\t\t\t\t\t@click=\"handleMenuClick(item)\">\r\n\t\t\t\t\t<image :src=\"item.icon\" class=\"item-icon\" />\r\n\t\t\t\t\t<text>{{ item.text }}</text>\r\n\t\t\t\t</view>\r\n\t\t\t</view>\r\n\t\t</view>\r\n\t</view>\r\n</template>\r\n\r\n<script>\r\n\timport {\r\n\t\tdeviceTypeList,\r\n\t\tdeviceInfo,\r\n\t\tdeviceUnbind, //删除设备\r\n\t\tdeviceReName\r\n\t} from '@/api/common/index.js'\r\n\texport default {\r\n\t\tdata() {\r\n\t\t\treturn {\r\n\t\t\t\tnavBarHeight: 70 + uni.getSystemInfoSync().statusBarHeight,\r\n\t\t\t\tdeviceList: [],\r\n\t\t\t\ttabs: [],\r\n\t\t\t\tactiveTab: 0,\r\n\t\t\t\tshowTooltip: false,\r\n\t\t\t\tOptions: [{\r\n\t\t\t\t\t\ttext: '重命名',\r\n\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\tbackgroundColor: '#E09319',\r\n\t\t\t\t\t\t\tborderRadius: '16px',\r\n\t\t\t\t\t\t\twidth: '240rpx', // 初始宽度\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttext: '删除',\r\n\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\tbackgroundColor: 'rgb(240, 60, 60)',\r\n\t\t\t\t\t\t\tborderRadius: '16px',\r\n\t\t\t\t\t\t\twidth: '240rpx', // 初始宽度\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t},\r\n\t\t\t\t],\r\n\t\t\t\tnavTitle: \"我的设备\",\r\n\t\t\t\tdeleteShow: false,\r\n\t\t\t\tRenameModel: false,\r\n\t\t\t\tmenuItems: [{\r\n\t\t\t\t\t\ttext: '扫一扫添加',\r\n\t\t\t\t\t\ticon: '/static/images/scane.png',\r\n\t\t\t\t\t\taction: 'scan'\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttext: '蓝牙添加',\r\n\t\t\t\t\t\ticon: '/static/images/bluetooth.png',\r\n\t\t\t\t\t\taction: 'bluetooth'\r\n\t\t\t\t\t}\r\n\t\t\t\t],\r\n\t\t\t\tpage: 1, // 当前页码\r\n\t\t\t\tsize:10, // 每页条数\r\n\t\t\t\ttotal: 0, // 总数据量\r\n\t\t\t\tloading: false,\r\n\t\t\t\tfinished: false,\r\n\t\t\t\tdeviceId: '',\r\n\t\t\t\tdeviceName: \"\" //重命名\r\n\t\t\t}\r\n\t\t},\r\n\t\tmethods: {\r\n\t\t\t// tab导航切换栏\r\n\t\t\tgetTab() {\r\n\t\t\t\tdeviceTypeList({}).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tthis.tabs = [{\r\n\t\t\t\t\t\t\t\tid: '',\r\n\t\t\t\t\t\t\t\tname: '全部设备',\r\n\t\t\t\t\t\t\t\ttypeName: '全部设备'\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t...res.data.map(item => ({\r\n\t\t\t\t\t\t\t\tid: item.id,\r\n\t\t\t\t\t\t\t\tname: item.typeName,\r\n\t\t\t\t\t\t\t\ttypeName: item.typeName,\r\n\t\t\t\t\t\t\t\tcommunicationMode: item.communicationMode\r\n\t\t\t\t\t\t\t}))\r\n\t\t\t\t\t\t];\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\t// tab切换页\r\n\t\t\tswitchTab(tab, index) {\r\n\t\t\t\tthis.deviceList = [];\r\n\t\t\t\tthis.activeTab = index;\r\n\t\t\t\tthis.page = 1; // 重置页码\r\n\t\t\t\tthis.finished = false; // 重\r\n\t\t\t\t// 明确传递参数，空字符串改为null或undefined\r\n\t\t\t\tconst deviceType = tab.id === '' ? undefined : tab.id;\r\n\t\t\t\tthis.getData(deviceType);\r\n\t\t\t},\r\n\t\t\t// 获取设备列表\r\n\t\t\tgetData(deviceType = '') {\r\n\t\t\t\tif (this.loading || this.finished) return;\r\n\t\t\t\tthis.loading = true;\r\n\t\t\t\tlet data = {\r\n\t\t\t\t\tpageNum: this.page,\r\n\t\t\t\t\tpageSize: this.size,\r\n\t\t\t\t\tdeviceType: deviceType // 使用传入的设备类型\r\n\t\t\t\t}\r\n\t\t\t\tdeviceInfo(data).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tconst newDevices = res.rows.map(device => ({\r\n\t\t\t\t\t\t\t...device,\r\n\t\t\t\t\t\t\tshowConfirm: false\r\n\t\t\t\t\t\t}));\r\n\r\n\t\t\t\t\t\t// 如果是第一页或切换分类，替换数据\r\n\t\t\t\t\t\tthis.deviceList = this.page === 1 ? newDevices : [...this.deviceList, ...newDevices];\r\n\t\t\t\t\t\tthis.total = res.total;\r\n\t\t\t\t\t\t// 判断是否加载完成\r\n\t\t\t\t\t\tif (res.rows.length < this.size || this.deviceList.length >= this.total) {\r\n\t\t\t\t\t\t\tthis.finished = true;\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\tthis.page++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}).finally(() => {\r\n\t\t\t\t\tthis.loading = false;\r\n\t\t\t\t});\r\n\t\t\t},\r\n\t\t\t// 滚动触底事件处理\r\n\t\t\tonScrollToLower() {\r\n\t\t\t\tthis.getData();\r\n\t\t\t},\r\n\t\t\tscan() {\r\n\t\t\t\tthis.showTooltip = !this.showTooltip;\r\n\t\t\t},\r\n\r\n\t\t\thandleMenuClick(item) {\r\n\t\t\t\tthis.showTooltip = false; // 关闭弹窗\r\n\t\t\t\tswitch (item.action) {\r\n\t\t\t\t\tcase 'scan':\r\n\t\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\t\turl: '/pages/common/scan/scan'\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\tcase 'bluetooth':\r\n\t\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\t\turl: '/pages/6155/bluetooth/bluetooth'\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t// 右滑点击事件处理\r\n\t\t\thandleSwipeClick(e, item, index) {\r\n\t\t\t\tconst {\r\n\t\t\t\t\tcontent\r\n\t\t\t\t} = e\r\n\t\t\t\tconsole.log(e, 'eeeee');\r\n\t\t\t\tswitch (content.text) {\r\n\t\t\t\t\tcase '删除':\r\n\t\t\t\t\t\tthis.handleDeleteDevice(item, index)\r\n\t\t\t\t\t\tbreak\r\n\t\t\t\t\tcase '重命名':\r\n\t\t\t\t\t\tthis.handleRenameDevice(item, index)\r\n\t\t\t\t\t\tbreak\r\n\t\t\t\t};\r\n\t\t\t},\r\n\t\t\t// 删除设备\r\n\t\t\thandleDeleteDevice(item, index) {\r\n\t\t\t\tthis.deviceId = item\r\n\t\t\t\tthis.deleteShow = true\r\n\t\t\t\tuni.hideTabBar()\r\n\t\t\t},\r\n\t\t\t// 确认删除\r\n\t\t\thandleBtn() {\r\n\t\t\t\tuni.showTabBar()\r\n\t\t\t\tlet data = {\r\n\t\t\t\t\tid: this.deviceId.id\r\n\t\t\t\t}\r\n\t\t\t\tdeviceUnbind(data).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: '删除成功',\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tthis.onIntall();\r\n\t\t\t\t\t\t}, 500);\r\n\t\t\t\t\t\tthis.deleteShow = false\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: res.msg,\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\t// 重命名设备\r\n\t\t\thandleRenameDevice(item, index) {\r\n\t\t\t\tthis.RenameModel = true\r\n\t\t\t\tuni.hideTabBar()\r\n\t\t\t\tthis.deviceId = item\r\n\t\t\t},\r\n\t\t\thandleBtnName() {\r\n\t\t\t\tuni.showTabBar()\r\n\t\t\t\tlet data = {\r\n\t\t\t\t\tid: this.deviceId.id,\r\n\t\t\t\t\tdeviceName: this.deviceName\r\n\t\t\t\t}\r\n\t\t\t\tdeviceReName(data).then((res) => {\r\n\t\t\t\t\tif (res.code == 200) {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: res.msg,\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tsetTimeout(() => {\r\n\t\t\t\t\t\t\tthis.onIntall();\r\n\t\t\t\t\t\t}, 500);\r\n\t\t\t\t\t\tthis.RenameModel = false\r\n\t\t\t\t\t\tthis.deviceName = ''\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tuni.showToast({\r\n\t\t\t\t\t\t\ttitle: res.msg,\r\n\t\t\t\t\t\t\ticon: 'none',\r\n\t\t\t\t\t\t\tduration: 1000\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\t// 发生短信\r\n\t\t\thandleSend() {\r\n\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\turl: '/pages/common/send/index'\r\n\t\t\t\t})\r\n\t\t\t},\r\n\t\t\thandleFile(item) {\r\n\t\t\t\tconsole.log(item, 'item');\r\n\t\t\t\t// communicationMode 0是4G 1是蓝牙\r\n\t\t\t\tif (item.communicationMode == 0) {\r\n\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\turl: '/pages/6170/deviceControl/index'\r\n\t\t\t\t\t})\r\n\t\t\t\t} else {\r\n\t\t\t\t\tuni.navigateTo({\r\n\t\t\t\t\t\turl: '/pages/6155/index'\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\r\n\t\t\t},\r\n\t\t\tonIntall() {\r\n\t\t\t\tthis.page = 1;\r\n\t\t\t\tthis.finished = false;\r\n\t\t\t\t\r\n\t\t\t\tthis.getData(); // 重新加载第一页数据\r\n\t\t\t}\r\n\t\t},\r\n\t\tonShow() {\r\n\t\t\tthis.getTab()\r\n\t\t\tthis.onIntall()\r\n\t\t}\r\n\r\n\t}\r\n</script>\r\n\r\n<style>\r\n\t/* 页面整体样式 */\r\n\t.device-page {\r\n\t\tdisplay: flex;\r\n\t\tflex-direction: column;\r\n\t\tmin-height: 100vh;\r\n\t\tbackground-color: rgb(18, 18, 18);\r\n\t\tpadding: 30rpx;\r\n\t}\r\n\r\n\t.tab-bar {\r\n\t\twidth: 100%;\r\n\t\tcolor: rgb(255, 255, 255);\r\n\t\twhite-space: nowrap;\r\n\t\t/* 禁止换行 */\r\n\t\toverflow: hidden;\r\n\r\n\t}\r\n\r\n\t.tab-container {\r\n\t\tdisplay: flex;\r\n\t\t/* justify-content: space-around; */\r\n\t\tcursor: pointer;\r\n\t\tmargin-bottom: 40rpx;\r\n\t/* \tmin-width: 100%; */\r\n\t\t/* 最小宽度 */\r\n\t}\r\n\r\n\t.tab-item {\r\n\t\tfont-size: 28rpx;\r\n\t/* \tmin-width: 120rpx; */\r\n\t\tpadding: 0 30rpx; /* 左右内边距 */\r\n\t\t  text-align: center; /* 文字居中 */\r\n\t\t/* 设置最小宽度 */\r\n\t}\r\n\r\n\t.active {\r\n\t\tcolor: rgba(187, 230, 0, 1);\r\n\t\tborder-bottom: 6rpx solid rgba(187, 230, 0, 1);\r\n\t\theight: 60rpx;\r\n\t}\r\n\r\n\t.sendFlex {\r\n\t\tdisplay: flex;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\tjustify-content: flex-end;\r\n\t\tcursor: pointer;\r\n\t\tmargin-bottom: 30rpx;\r\n\t\tfont-size: 28rpx;\r\n\t}\r\n\t.gprs{\r\n\t\twidth:28rpx;\r\n\t\theight:35rpx;\r\n\t\tposition: absolute;\r\n\t\tleft:50rpx\r\n\t}\r\n\r\n\t.Sendmessage {\r\n\t\tmargin-left: 50rpx;\r\n\t\tborder: 1px solid rgba(187, 230, 0, 0.4);\r\n\t\tborder-radius: 20px;\r\n\t\tpadding: 7rpx 20rpx;\r\n\t\tcolor: rgba(187, 230, 0, 1);\r\n\t}\r\n\t.callpolice{\r\n\t\tborder: 1px solid rgba(224, 52, 52, 0.4);\r\n\t\tborder-radius: 20px;\r\n\t\tcolor: rgba(224, 52, 52, 1);\r\n\t\twidth: 150rpx;\r\n\t\ttext-align: center;\r\n\t\tpadding: 5rpx 10rpx;\r\n\t}\r\n\r\n\t/* 设备卡片 */\r\n\t.device-card {\r\n\t\tbackground-color: rgb(26, 26, 26);\r\n\t\tborder-radius: 16rpx;\r\n\t\t/* padding: 30rpx; */\r\n\t\tmargin-bottom: 20rpx;\r\n\t\t/* \t\tbox-shadow: 0 2rpx 10rpx rgba(0, 0, 0, 0.05); */\r\n\t\tbox-sizing: border-box;\r\n\t\tposition: relative;\r\n\t}\r\n\r\n\t.device-header {\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t\tmargin-bottom: 15rpx;\r\n\t\tpadding: 30rpx 0 10rpx 30rpx;\r\n\t}\r\n\r\n\t.device-name {\r\n\t\tfont-size: 28rpx;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\tmargin-left: 24rpx;\r\n\t\tline-height: 50rpx;\r\n\t}\r\n\r\n\t.ID {\r\n\t\tcolor: rgba(255, 255, 255, 0.6);\r\n\t\tfont-size: 24rpx;\r\n\t}\r\n\r\n\t.device-status {\r\n\t\twidth: 122rpx;\r\n\t\theight: 52rpx;\r\n\t\tfont-size: 26rpx;\r\n\t\tborder-radius: 0px 8px 0px 8px;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tposition: absolute;\r\n\t\ttop: 0rpx;\r\n\t\tright: 0rpx;\r\n\t\ttext-align: center;\r\n\t\tline-height: 52rpx;\r\n\t}\r\n\r\n\t.circle {\r\n\t\twidth: 8rpx;\r\n\t\theight: 40rpx;\r\n\t\tposition: absolute;\r\n\t\tright: 40rpx;\r\n\t\ttop: 80rpx;\r\n\t}\r\n\r\n\t.online {\r\n\t\tcolor: rgb(187, 230, 0);\r\n\t}\r\n\r\n\t.unline {\r\n\t\tcolor: rgba(255, 255, 255, 0.4);\r\n\t}\r\n\r\n\t.device-id {\r\n\t\tfont-size: 26rpx;\r\n\t\tcolor: #999;\r\n\t\tmargin-bottom: 20rpx;\r\n\t\tdisplay: block;\r\n\t}\r\n\r\n\t.device-info {\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: space-evenly;\r\n\t\tfont-size: 28rpx;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\tposition: relative;\r\n\t\tpadding: 0rpx 0rpx 30rpx 30rpx;\r\n\t}\r\n\r\n\t.deviceIMG {\r\n\t\twidth: 100rpx;\r\n\t\theight: 100rpx;\r\n\t\tborder-radius: 16rpx;\r\n\t\tposition: relative;\r\n\t\tbackground-color: rgba(42, 42, 42, 0.6);\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t}\r\n\r\n\t.IMG {\r\n\t\twidth: 68rpx;\r\n\t\theight: 50rpx;\r\n\t\tmargin-left: 17%;\r\n\t}\r\n\r\n\t.onlines::before {\r\n\t\tcontent: '';\r\n\t\tposition: absolute;\r\n\t\twidth: 15rpx;\r\n\t\theight: 15rpx;\r\n\t\tbackground: rgb(0, 171, 103);\r\n\t\tborder-radius: 50%;\r\n\t\tleft: 120rpx;\r\n\t\ttop: 15rpx\r\n\t}\r\n\r\n\t.line {\r\n\t\twidth: 2rpx;\r\n\t\theight: 24rpx;\r\n\t\tbackground: linear-gradient(90deg,\r\n\t\t\t\trgba(0, 0, 0, 0) 0%,\r\n\t\t\t\trgb(255, 255, 255) 50%,\r\n\t\t\t\trgba(255, 255, 255, 0) 100%);\r\n\t\tmargin-top: 12rpx;\r\n\t}\r\n\r\n\t.loading-status {\r\n\t\ttext-align: center;\r\n\t\tcolor: rgba(255, 255, 255, 0.6);\r\n\t\tpadding: 20rpx;\r\n\t\tfont-size: 22rpx;\r\n\t}\r\n\r\n\t.device-uplod {\r\n\t\tbackground-color: rgb(26, 26, 26);\r\n\t\tborder-radius: 16rpx;\r\n\t\talign-items: center;\r\n\t\ttext-align: center;\r\n\t\theight: 202rpx;\r\n\t\tline-height: 200rpx;\r\n\t}\r\n\r\n\t.uni-swipe-action-item__options {\r\n\t\ttransition: width 0.3s ease;\r\n\t}\r\n\r\n\t/* 遮罩层 */\r\n\t.agreement-mask {\r\n\t\tposition: fixed;\r\n\t\ttop: 0;\r\n\t\tleft: 0;\r\n\t\tright: 0;\r\n\t\tbottom: 0;\r\n\t\tbackground-color: rgba(0, 0, 0, 0.5);\r\n\t\tdisplay: flex;\r\n\t\tjustify-content: center;\r\n\t\talign-items: center;\r\n\t\tz-index: 9999;\r\n\t}\r\n\r\n\t.popup-Title {\r\n\t\tcolor: rgba(255, 255, 255, 0.86);\r\n\t\ttext-align: center;\r\n\t\tpadding: 30rpx 0rpx;\r\n\t}\r\n\r\n\t.popup-buttons {\r\n\t\tdisplay: flex;\r\n\t\ttext-align: center;\r\n\t}\r\n\r\n\t/* 弹窗主体 */\r\n\t.agreement-popup {\r\n\t\twidth: 100%;\r\n\t\theight: 50%;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tborder-radius: 60rpx 60rpx 0rpx 0rpx;\r\n\t\tpadding: 40rpx;\r\n\t\tbox-sizing: border-box;\r\n\t\tposition: absolute;\r\n\t\tbottom: 0rpx;\r\n\t}\r\n\r\n\t.agreement-popupC {\r\n\t\twidth: 60%;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tborder-radius: 40rpx;\r\n\t\tpadding: 30rpx;\r\n\t\ttext-align: center;\r\n\t\tborder: 1px solid rgba(255, 200, 78, 0.3);\r\n\t}\r\n\r\n\t.agreement-popupD {\r\n\t\twidth: 70%;\r\n\t\tbackground-color: rgb(42, 42, 42);\r\n\t\tborder-radius: 40rpx;\r\n\t\tpadding: 40rpx;\r\n\t\ttext-align: center;\r\n\t\tborder: 1px solid rgba(187, 230, 0, 0.3);\r\n\t}\r\n\r\n\t.popup-flex {\r\n\t\tdisplay: flex;\r\n\t\twhite-space: nowrap;\r\n\t\tcolor: rgba(255, 255, 255, 0.87);\r\n\t\theight: 50rpx;\r\n\t\tpadding: 30rpx;\r\n\t}\r\n\r\n\t.popup-input {\r\n\t\tborder: 1px solid rgba(255, 255, 255, 0.4);\r\n\t\tborder-radius: 12rpx;\r\n\t\tmargin-left: 15rpx;\r\n\t\tpadding: 10rpx 0rpx;\r\n\t\tfont-size: 28rpx;\r\n\t}\r\n\r\n\t.svg {\r\n\t\twidth: 58rpx;\r\n\t\theight: 62rpx;\r\n\t}\r\n\r\n\t/* 通用按钮样式 */\r\n\t.btn {\r\n\t\theight: 60rpx;\r\n\t\tline-height: 60rpx;\r\n\t\tborder-radius: 40rpx;\r\n\t\tfont-size: 24rpx;\r\n\t\tmargin: 10rpx auto;\r\n\t\ttext-align: center;\r\n\r\n\t}\r\n\r\n\t/* 同意按钮 */\r\n\t.agreeBtn {\r\n\t\tbackground: #FFC84E;\r\n\t\tcolor: #232323;\r\n\t\tborder: none;\r\n\t\twidth: 170rpx !important;\r\n\t}\r\n\r\n\t.agreeBtn4 {\r\n\t\tbackground: rgba(187, 230, 0, 1);\r\n\t\tcolor: #232323;\r\n\t\tborder: none;\r\n\t\twidth: 170rpx !important;\r\n\t}\r\n\r\n\t.closeBtn {\r\n\t\tborder: 1px solid rgba(255, 255, 255, 0.2);\r\n\t\tbackground-color: rgba(35, 35, 35, 0.87);\r\n\t\tcolor: rgba(255, 255, 255, 1);\r\n\t}\r\n\r\n\t/* 提示框样式 */\r\n\t.tooltip-box {\r\n\t\tposition: fixed;\r\n\t\tright: 18rpx;\r\n\t\ttop: 140rpx;\r\n\t\t/* 根据导航栏高度调整 */\r\n\t\tz-index: 9999;\r\n\t}\r\n\r\n\t.tooltip-arrow {\r\n\t\twidth: 0;\r\n\t\theight: 0;\r\n\t\tborder-left: 8px solid transparent;\r\n\t\tborder-right: 8px solid transparent;\r\n\t\tborder-bottom: 8px solid #333;\r\n\t\tposition: absolute;\r\n\t\tright: 12px;\r\n\t\ttop: -8px;\r\n\t}\r\n\r\n\t.tooltip-content {\r\n\t\tborder-radius: 8rpx;\r\n\t\tbackdrop-filter: blur(14px);\r\n\t\tbackground: rgba(58, 58, 58, 1);\r\n\t\tpadding: 10px 0;\r\n\t\tmin-width: 120px;\r\n\t}\r\n\r\n\t.tooltip-item {\r\n\t\tpadding: 8px 16px;\r\n\t\tdisplay: flex;\r\n\t\talign-items: center;\r\n\t\tcolor: #fff;\r\n\t}\r\n\r\n\t.tooltip-item text {\r\n\t\tmargin-left: 8px;\r\n\t\tfont-size: 14px;\r\n\t}\r\n\r\n\t.item-icon {\r\n\t\twidth: 16px;\r\n\t\theight: 16px;\r\n\t}\r\n</style>"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///49\n"); /***/ }), /* 50 */ diff --git a/unpackage/dist/dev/app-plus/app-view.js b/unpackage/dist/dev/app-plus/app-view.js index 5db2e05..fcc4fe3 100644 --- a/unpackage/dist/dev/app-plus/app-view.js +++ b/unpackage/dist/dev/app-plus/app-view.js @@ -3617,7 +3617,7 @@ if(false) {} var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../du/HBuilderX.4.64.2025042916/HBuilderX/plugins/uniapp-cli/node_modules/css-loader/dist/runtime/api.js */ 13); exports = ___CSS_LOADER_API_IMPORT___(false); // Module -exports.push([module.i, "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* 页面整体样式 */\n.device-page {\n\tdisplay: flex;\n\tflex-direction: column;\n\tmin-height: 100vh;\n\tbackground-color: rgb(18, 18, 18);\n\tpadding: 30rpx;\n}\n.tab-bar {\n\twidth: 100%;\n\tcolor: rgb(255, 255, 255);\n\twhite-space: nowrap;\n\t/* 禁止换行 */\n\toverflow: hidden;\n}\n.tab-container {\n\tdisplay: flex;\n\t/* justify-content: space-around; */\n\tcursor: pointer;\n\tmargin-bottom: 40rpx;\n/* \tmin-width: 100%; */\n\t/* 最小宽度 */\n}\n.tab-item {\n\tfont-size: 28rpx;\n/* \tmin-width: 120rpx; */\n\tpadding: 0 30rpx; /* 左右内边距 */\n\t text-align: center; /* 文字居中 */\n\t/* 设置最小宽度 */\n}\n.active {\n\tcolor: rgba(187, 230, 0, 1);\n\tborder-bottom: 6rpx solid rgba(187, 230, 0, 1);\n\theight: 60rpx;\n}\n.sendFlex {\n\tdisplay: flex;\n\tcolor: rgba(255, 255, 255, 0.87);\n\tjustify-content: flex-end;\n\tcursor: pointer;\n\tmargin-bottom: 30rpx;\n\tfont-size: 28rpx;\n}\n.gprs{\n\twidth:28rpx;\n\theight:35rpx;\n\tposition: absolute;\n\tleft:50rpx\n}\n.Sendmessage {\n\tmargin-left: 50rpx;\n\tborder: 1px solid rgba(187, 230, 0, 0.4);\n\tborder-radius: 20px;\n\tpadding: 7rpx 20rpx;\n\tcolor: rgba(187, 230, 0, 1);\n}\n.callpolice{\n\tborder: 1px solid rgba(224, 52, 52, 0.4);\n\tborder-radius: 20px;\n\tcolor: rgba(224, 52, 52, 1);\n\twidth: 150rpx;\n\ttext-align: center;\n\tpadding: 5rpx 10rpx;\n}\n/* 设备卡片 */\n.device-card {\n\tbackground-color: rgb(26, 26, 26);\n\tborder-radius: 16rpx;\n\t/* padding: 30rpx; */\n\tmargin-bottom: 20rpx;\n\t/* \t\tbox-shadow: 0 2rpx 10rpx rgba(0, 0, 0, 0.05); */\n\tbox-sizing: border-box;\n\tposition: relative;\n}\n.device-header {\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-bottom: 15rpx;\n\tpadding: 30rpx 0 10rpx 30rpx;\n}\n.device-name {\n\tfont-size: 28rpx;\n\tcolor: rgba(255, 255, 255, 0.87);\n\tmargin-left: 24rpx;\n\tline-height: 50rpx;\n}\n.ID {\n\tcolor: rgba(255, 255, 255, 0.6);\n\tfont-size: 24rpx;\n}\n.device-status {\n\twidth: 122rpx;\n\theight: 52rpx;\n\tfont-size: 26rpx;\n\tborder-radius: 0px 8px 0px 8px;\n\tbackground-color: rgb(42, 42, 42);\n\tposition: absolute;\n\ttop: 0rpx;\n\tright: 0rpx;\n\ttext-align: center;\n\tline-height: 52rpx;\n}\n.circle {\n\twidth: 8rpx;\n\theight: 40rpx;\n\tposition: absolute;\n\tright: 40rpx;\n\ttop: 80rpx;\n}\n.online {\n\tcolor: rgb(187, 230, 0);\n}\n.unline {\n\tcolor: rgba(255, 255, 255, 0.4);\n}\n.device-id {\n\tfont-size: 26rpx;\n\tcolor: #999;\n\tmargin-bottom: 20rpx;\n\tdisplay: block;\n}\n.device-info {\n\tdisplay: flex;\n\tjustify-content: space-evenly;\n\tfont-size: 28rpx;\n\tcolor: rgba(255, 255, 255, 0.87);\n\tposition: relative;\n\tpadding: 0rpx 0rpx 30rpx 30rpx;\n}\n.deviceIMG {\n\twidth: 100rpx;\n\theight: 100rpx;\n\tborder-radius: 16rpx;\n\tposition: relative;\n\tbackground-color: rgba(42, 42, 42, 0.6);\n\tdisplay: flex;\n\talign-items: center;\n}\n.IMG {\n\twidth: 68rpx;\n\theight: 50rpx;\n\tmargin-left: 17%;\n}\n.onlines::before {\n\tcontent: '';\n\tposition: absolute;\n\twidth: 15rpx;\n\theight: 15rpx;\n\tbackground: rgb(0, 171, 103);\n\tborder-radius: 50%;\n\tleft: 120rpx;\n\ttop: 15rpx\n}\n.line {\n\twidth: 2rpx;\n\theight: 24rpx;\n\tbackground: linear-gradient(90deg,\n\t\t\trgba(0, 0, 0, 0) 0%,\n\t\t\trgb(255, 255, 255) 50%,\n\t\t\trgba(255, 255, 255, 0) 100%);\n\tmargin-top: 12rpx;\n}\n.loading-status {\n\ttext-align: center;\n\tcolor: rgba(255, 255, 255, 0.6);\n\tpadding: 20rpx;\n\tfont-size: 22rpx;\n}\n.device-uplod {\n\tbackground-color: rgb(26, 26, 26);\n\tborder-radius: 16rpx;\n\talign-items: center;\n\ttext-align: center;\n\theight: 202rpx;\n\tline-height: 200rpx;\n}\n.uni-swipe-action-item__options {\n\ttransition: width 0.3s ease;\n}\n/* 遮罩层 */\n.agreement-mask {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground-color: rgba(0, 0, 0, 0.5);\n\tdisplay: flex;\n\tjustify-content: center;\n\talign-items: center;\n\tz-index: 9999;\n}\n.popup-Title {\n\tcolor: rgba(255, 255, 255, 0.86);\n\ttext-align: center;\n\tpadding: 30rpx 0rpx;\n}\n.popup-buttons {\n\tdisplay: flex;\n\ttext-align: center;\n}\n/* 弹窗主体 */\n.agreement-popup {\n\twidth: 100%;\n\theight: 50%;\n\tbackground-color: rgb(42, 42, 42);\n\tborder-radius: 60rpx 60rpx 0rpx 0rpx;\n\tpadding: 40rpx;\n\tbox-sizing: border-box;\n\tposition: absolute;\n\tbottom: 0rpx;\n}\n.agreement-popupC {\n\twidth: 60%;\n\tbackground-color: rgb(42, 42, 42);\n\tborder-radius: 40rpx;\n\tpadding: 30rpx;\n\ttext-align: center;\n\tborder: 1px solid rgba(255, 200, 78, 0.3);\n}\n.agreement-popupD {\n\twidth: 70%;\n\tbackground-color: rgb(42, 42, 42);\n\tborder-radius: 40rpx;\n\tpadding: 40rpx;\n\ttext-align: center;\n\tborder: 1px solid rgba(187, 230, 0, 0.3);\n}\n.popup-flex {\n\tdisplay: flex;\n\twhite-space: nowrap;\n\tcolor: rgba(255, 255, 255, 0.87);\n\theight: 50rpx;\n\tpadding: 30rpx;\n}\n.popup-input {\n\tborder: 1px solid rgba(255, 255, 255, 0.4);\n\tborder-radius: 12rpx;\n\tmargin-left: 15rpx;\n\tpadding: 10rpx 0rpx;\n\tfont-size: 28rpx;\n}\n.svg {\n\twidth: 58rpx;\n\theight: 62rpx;\n}\n/* 通用按钮样式 */\n.btn {\n\theight: 60rpx;\n\tline-height: 60rpx;\n\tborder-radius: 40rpx;\n\tfont-size: 24rpx;\n\tmargin: 10rpx auto;\n\ttext-align: center;\n}\n/* 同意按钮 */\n.agreeBtn {\n\tbackground: #FFC84E;\n\tcolor: #232323;\n\tborder: none;\n\twidth: 170rpx !important;\n}\n.agreeBtn4 {\n\tbackground: rgba(187, 230, 0, 1);\n\tcolor: #232323;\n\tborder: none;\n\twidth: 170rpx !important;\n}\n.closeBtn {\n\tborder: 1px solid rgba(255, 255, 255, 0.2);\n\tbackground-color: rgba(35, 35, 35, 0.87);\n\tcolor: rgba(255, 255, 255, 1);\n}\n/* 提示框样式 */\n.tooltip-box {\n\tposition: fixed;\n\tright: 18rpx;\n\ttop: 140rpx;\n\t/* 根据导航栏高度调整 */\n\tz-index: 9999;\n}\n.tooltip-arrow {\n\twidth: 0;\n\theight: 0;\n\tborder-left: 8px solid transparent;\n\tborder-right: 8px solid transparent;\n\tborder-bottom: 8px solid #333;\n\tposition: absolute;\n\tright: 12px;\n\ttop: -8px;\n}\n.tooltip-content {\n\tborder-radius: 8rpx;\n\t-webkit-backdrop-filter: blur(14px);\n\t backdrop-filter: blur(14px);\n\tbackground: rgba(58, 58, 58, 1);\n\tpadding: 10px 0;\n\tmin-width: 120px;\n}\n.tooltip-item {\n\tpadding: 8px 16px;\n\tdisplay: flex;\n\talign-items: center;\n\tcolor: #fff;\n}\n.tooltip-item uni-text {\n\tmargin-left: 8px;\n\tfont-size: 14px;\n}\n.item-icon {\n\twidth: 16px;\n\theight: 16px;\n}\n", ""]); +exports.push([module.i, "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/* 页面整体样式 */\n.device-page {\n\tdisplay: flex;\n\tflex-direction: column;\n\tmin-height: 100vh;\n\tbackground-color: rgb(18, 18, 18);\n\tpadding: 30rpx;\n}\n.tab-bar {\n\twidth: 100%;\n\tcolor: rgb(255, 255, 255);\n\twhite-space: nowrap;\n\t/* 禁止换行 */\n\toverflow: hidden;\n}\n.tab-container {\n\tdisplay: flex;\n\t/* justify-content: space-around; */\n\tcursor: pointer;\n\tmargin-bottom: 40rpx;\n/* \tmin-width: 100%; */\n\t/* 最小宽度 */\n}\n.tab-item {\n\tfont-size: 28rpx;\n/* \tmin-width: 120rpx; */\n\tpadding: 0 30rpx; /* 左右内边距 */\n\t text-align: center; /* 文字居中 */\n\t/* 设置最小宽度 */\n}\n.active {\n\tcolor: rgba(187, 230, 0, 1);\n\tborder-bottom: 6rpx solid rgba(187, 230, 0, 1);\n\theight: 60rpx;\n}\n.sendFlex {\n\tdisplay: flex;\n\tcolor: rgba(255, 255, 255, 0.87);\n\tjustify-content: flex-end;\n\tcursor: pointer;\n\tmargin-bottom: 30rpx;\n\tfont-size: 28rpx;\n}\n.gprs{\n\twidth:28rpx;\n\theight:35rpx;\n\tposition: absolute;\n\tleft:50rpx\n}\n.Sendmessage {\n\tmargin-left: 50rpx;\n\tborder: 1px solid rgba(187, 230, 0, 0.4);\n\tborder-radius: 20px;\n\tpadding: 7rpx 20rpx;\n\tcolor: rgba(187, 230, 0, 1);\n}\n.callpolice{\n\tborder: 1px solid rgba(224, 52, 52, 0.4);\n\tborder-radius: 20px;\n\tcolor: rgba(224, 52, 52, 1);\n\twidth: 150rpx;\n\ttext-align: center;\n\tpadding: 5rpx 10rpx;\n}\n/* 设备卡片 */\n.device-card {\n\tbackground-color: rgb(26, 26, 26);\n\tborder-radius: 16rpx;\n\t/* padding: 30rpx; */\n\tmargin-bottom: 20rpx;\n\t/* \t\tbox-shadow: 0 2rpx 10rpx rgba(0, 0, 0, 0.05); */\n\tbox-sizing: border-box;\n\tposition: relative;\n}\n.device-header {\n\tdisplay: flex;\n\talign-items: center;\n\tmargin-bottom: 15rpx;\n\tpadding: 30rpx 0 10rpx 30rpx;\n}\n.device-name {\n\tfont-size: 28rpx;\n\tcolor: rgba(255, 255, 255, 0.87);\n\tmargin-left: 24rpx;\n\tline-height: 50rpx;\n}\n.ID {\n\tcolor: rgba(255, 255, 255, 0.6);\n\tfont-size: 24rpx;\n}\n.device-status {\n\twidth: 122rpx;\n\theight: 52rpx;\n\tfont-size: 26rpx;\n\tborder-radius: 0px 8px 0px 8px;\n\tbackground-color: rgb(42, 42, 42);\n\tposition: absolute;\n\ttop: 0rpx;\n\tright: 0rpx;\n\ttext-align: center;\n\tline-height: 52rpx;\n}\n.circle {\n\twidth: 8rpx;\n\theight: 40rpx;\n\tposition: absolute;\n\tright: 40rpx;\n\ttop: 80rpx;\n}\n.online {\n\tcolor: rgb(187, 230, 0);\n}\n.unline {\n\tcolor: rgba(255, 255, 255, 0.4);\n}\n.device-id {\n\tfont-size: 26rpx;\n\tcolor: #999;\n\tmargin-bottom: 20rpx;\n\tdisplay: block;\n}\n.device-info {\n\tdisplay: flex;\n\tjustify-content: space-evenly;\n\tfont-size: 28rpx;\n\tcolor: rgba(255, 255, 255, 0.87);\n\tposition: relative;\n\tpadding: 0rpx 0rpx 30rpx 30rpx;\n}\n.deviceIMG {\n\twidth: 100rpx;\n\theight: 100rpx;\n\tborder-radius: 16rpx;\n\tposition: relative;\n\tbackground-color: rgba(42, 42, 42, 0.6);\n\tdisplay: flex;\n\talign-items: center;\n}\n.IMG {\n\twidth: 68rpx;\n\theight: 50rpx;\n\tmargin-left: 17%;\n}\n.onlines::before {\n\tcontent: '';\n\tposition: absolute;\n\twidth: 15rpx;\n\theight: 15rpx;\n\tbackground: rgb(0, 171, 103);\n\tborder-radius: 50%;\n\tleft: 120rpx;\n\ttop: 15rpx\n}\n.line {\n\twidth: 2rpx;\n\theight: 24rpx;\n\tbackground: linear-gradient(90deg,\n\t\t\trgba(0, 0, 0, 0) 0%,\n\t\t\trgb(255, 255, 255) 50%,\n\t\t\trgba(255, 255, 255, 0) 100%);\n\tmargin-top: 12rpx;\n}\n.loading-status {\n\ttext-align: center;\n\tcolor: rgba(255, 255, 255, 0.6);\n\tpadding: 20rpx;\n\tfont-size: 22rpx;\n}\n.device-uplod {\n\tbackground-color: rgb(26, 26, 26);\n\tborder-radius: 16rpx;\n\talign-items: center;\n\ttext-align: center;\n\theight: 202rpx;\n\tline-height: 200rpx;\n}\n.uni-swipe-action-item__options {\n\ttransition: width 0.3s ease;\n}\n/* 遮罩层 */\n.agreement-mask {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground-color: rgba(0, 0, 0, 0.5);\n\tdisplay: flex;\n\tjustify-content: center;\n\talign-items: center;\n\tz-index: 9999;\n}\n.popup-Title {\n\tcolor: rgba(255, 255, 255, 0.86);\n\ttext-align: center;\n\tpadding: 30rpx 0rpx;\n}\n.popup-buttons {\n\tdisplay: flex;\n\ttext-align: center;\n}\n/* 弹窗主体 */\n.agreement-popup {\n\twidth: 100%;\n\theight: 50%;\n\tbackground-color: rgb(42, 42, 42);\n\tborder-radius: 60rpx 60rpx 0rpx 0rpx;\n\tpadding: 40rpx;\n\tbox-sizing: border-box;\n\tposition: absolute;\n\tbottom: 0rpx;\n}\n.agreement-popupC {\n\twidth: 60%;\n\tbackground-color: rgb(42, 42, 42);\n\tborder-radius: 40rpx;\n\tpadding: 30rpx;\n\ttext-align: center;\n\tborder: 1px solid rgba(255, 200, 78, 0.3);\n}\n.agreement-popupD {\n\twidth: 70%;\n\tbackground-color: rgb(42, 42, 42);\n\tborder-radius: 40rpx;\n\tpadding: 40rpx;\n\ttext-align: center;\n\tborder: 1px solid rgba(187, 230, 0, 0.3);\n}\n.popup-flex {\n\tdisplay: flex;\n\twhite-space: nowrap;\n\tcolor: rgba(255, 255, 255, 0.87);\n\theight: 50rpx;\n\tpadding: 30rpx;\n}\n.popup-input {\n\tborder: 1px solid rgba(255, 255, 255, 0.4);\n\tborder-radius: 12rpx;\n\tmargin-left: 15rpx;\n\tpadding: 10rpx 0rpx;\n\tfont-size: 28rpx;\n}\n.svg {\n\twidth: 58rpx;\n\theight: 62rpx;\n}\n/* 通用按钮样式 */\n.btn {\n\theight: 60rpx;\n\tline-height: 60rpx;\n\tborder-radius: 40rpx;\n\tfont-size: 24rpx;\n\tmargin: 10rpx auto;\n\ttext-align: center;\n}\n/* 同意按钮 */\n.agreeBtn {\n\tbackground: #FFC84E;\n\tcolor: #232323;\n\tborder: none;\n\twidth: 170rpx !important;\n}\n.agreeBtn4 {\n\tbackground: rgba(187, 230, 0, 1);\n\tcolor: #232323;\n\tborder: none;\n\twidth: 170rpx !important;\n}\n.closeBtn {\n\tborder: 1px solid rgba(255, 255, 255, 0.2);\n\tbackground-color: rgba(35, 35, 35, 0.87);\n\tcolor: rgba(255, 255, 255, 1);\n}\n/* 提示框样式 */\n.tooltip-box {\n\tposition: fixed;\n\tright: 18rpx;\n\ttop: 140rpx;\n\t/* 根据导航栏高度调整 */\n\tz-index: 9999;\n}\n.tooltip-arrow {\n\twidth: 0;\n\theight: 0;\n\tborder-left: 8px solid transparent;\n\tborder-right: 8px solid transparent;\n\tborder-bottom: 8px solid #333;\n\tposition: absolute;\n\tright: 12px;\n\ttop: -8px;\n}\n.tooltip-content {\n\tborder-radius: 8rpx;\n\t-webkit-backdrop-filter: blur(14px);\n\t backdrop-filter: blur(14px);\n\tbackground: rgba(58, 58, 58, 1);\n\tpadding: 10px 0;\n\tmin-width: 120px;\n}\n.tooltip-item {\n\tpadding: 8px 16px;\n\tdisplay: flex;\n\talign-items: center;\n\tcolor: #fff;\n}\n.tooltip-item uni-text {\n\tmargin-left: 8px;\n\tfont-size: 14px;\n}\n.item-icon {\n\twidth: 16px;\n\theight: 16px;\n}\n", ""]); // Exports module.exports = exports;