Index.vue 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <template>
  2. <div style="display: flex; flex-direction:column;height: 100vh;">
  3. <!-- 店铺名称 -->
  4. <div style="padding: 10px 16px 10px 16px;">
  5. <div style="display: flex;
  6. justify-content:space-between;
  7. align-items:center;">
  8. <div style="display: flex; align-items: flex-end;">
  9. <div style="font-size: 20px; font-weight: bold;">
  10. <span>设备</span>
  11. </div>
  12. <div style="font-size: 0.9rem; margin-left: 5px;">
  13. <span>共{{ page.total }}台</span>
  14. </div>
  15. </div>
  16. <div style="background-color: #eee; border-radius: 2.5rem; width: 0px; flex-grow: 1; margin: 0px 5px;">
  17. <van-field style="padding: 6px 16px;" v-model="keyWord" size="normal" clearable />
  18. </div>
  19. <div style="line-height: 0px;" @click="onRefresh">
  20. <van-icon name="static/images/icon-search-black.png" size="1.7rem" />
  21. </div>
  22. </div>
  23. </div>
  24. <div class="container" style="overflow-y: auto; flex-grow: 1;">
  25. <van-pull-refresh style="min-height: 100%;" v-model="refreshing" @refresh="onRefresh">
  26. <van-swipe-cell v-for="item in dataList" style="background-color: #fff; margin-bottom: 10px;">
  27. <template #right>
  28. <div style="width: 50px; height: 100%; background-color: red;
  29. display: flex; justify-content:center; align-items: center;">
  30. <div>
  31. <div style="color: #fff; font-weight: bold;">
  32. <span>删除</span>
  33. </div>
  34. </div>
  35. </div>
  36. </template>
  37. <van-cell clickable :to="'/device/detail/'+item.mac">
  38. <div style="text-align: left;">
  39. <!-- 第一行 -->
  40. <div style="display: flex; justify-content: space-between; margin-bottom: 5px;">
  41. <div style=" font-size: 0.9rem;">
  42. <span v-if="item.username" style="color: #000;">{{item.username}}</span>
  43. <span v-else>未知用户</span>
  44. </div>
  45. <div style="font-size: 0.9rem;">{{ item.productName }}</div>
  46. </div>
  47. <!-- 第二行 -->
  48. <div style="display: flex; align-items: flex-end;">
  49. <div style="color: #000; font-weight: bold; font-size: 1.1rem;">
  50. <span>{{ item.mac }}</span>
  51. </div>
  52. <div style="margin-left: 5px; margin-bottom: 2px;">
  53. <template v-if="getTimeSpan(item.modifytime) < 1200">
  54. <van-tag round size="medium" type="success">在线</van-tag>
  55. </template>
  56. <template v-else>
  57. <van-tag round size="medium" type="danger">离线</van-tag>
  58. </template>
  59. </div>
  60. </div>
  61. <!-- 第三行 -->
  62. <div style="display: flex; justify-content: space-between; margin-bottom: 5px;">
  63. <div style="font-size: 0.9rem; margin-left: 0px;">
  64. <span>{{ item.createtime }}</span>
  65. </div>
  66. <div style="font-size: 0.9rem; margin-left: 0px;">
  67. <span>{{item.modifytime}}</span>
  68. </div>
  69. </div>
  70. <!-- 第四行 -->
  71. <div style="display: flex; justify-content: space-between;">
  72. <div v-if="JSON.parse(item.data).lat" style="display: flex; color: #000;" @click.stop="onLocation(item.mac)">
  73. <div>
  74. <van-icon name="static/images/icon-location2.png" size="1.5rem" />
  75. </div>
  76. <div style="margin-left: 3px;">位置</div>
  77. </div>
  78. <div v-else>暂无定位</div>
  79. <div></div>
  80. <div style="display: flex; color: #000;" @click.stop="onLog(item.mac)">
  81. <div>
  82. <van-icon name="static/images/icon-log.png" size="1.5rem" />
  83. </div>
  84. <div style="margin-left: 3px;">传输日志</div>
  85. </div>
  86. <!-- <div style="display: flex; color: #000;">
  87. <div>
  88. <van-icon name="static/images/icon-edit.png" size="1.5rem" />
  89. </div>
  90. <div style="margin-left: 3px;">编辑</div>
  91. </div> -->
  92. </div>
  93. </div>
  94. </van-cell>
  95. </van-swipe-cell>
  96. <!-- 数据提示 -->
  97. <div>
  98. <div v-if="refreshing"></div>
  99. <div v-else-if="dataList.length == 0" style="text-align: center; padding: 20px; color: #ccc;">
  100. <span>暂无数据</span>
  101. </div>
  102. <div v-else-if="isLoading" style="text-align: center; padding: 20px;">
  103. <van-loading type="spinner" color="#1989fa" />
  104. </div>
  105. <div v-else-if="page.pages <= page.pageNum" style="text-align: center; padding: 20px; color: #ccc;">
  106. <span>没有更多了</span>
  107. </div>
  108. <div v-else style="text-align: center; padding: 20px;">
  109. <span @click="clickLoading">点击加载</span>
  110. </div>
  111. </div>
  112. <div style="height: 60px; "></div>
  113. </van-pull-refresh>
  114. <!-- 返回顶部 -->
  115. <van-back-top target=".container" right="5vw" bottom="80px" />
  116. </div>
  117. </div>
  118. </template>
  119. <script setup lang="ts">
  120. import { onMounted, reactive, ref } from 'vue';
  121. import { useRouter } from 'vue-router'
  122. import { post_promise } from '@/network/axios';
  123. import 'vant/es/toast/style';
  124. // 路由
  125. const router = useRouter();
  126. const onLocation = (deviceId: string) => {
  127. console.log(deviceId)
  128. // 跳转到定位
  129. router.push('/device/location/' + deviceId)
  130. }
  131. // 跳转到日志
  132. const onLog = (deviceId: string) => {
  133. console.log(deviceId)
  134. // 跳转到定位
  135. router.push('/device/log/' + deviceId)
  136. }
  137. // 搜索关键字
  138. const keyWord = ref('');
  139. // 分页
  140. const page = reactive({
  141. total: 0,
  142. pageNum: 1,
  143. pageSize: 10,
  144. pages: 0,
  145. })
  146. const dataList = ref<any[]>([]);
  147. const refreshing = ref(false);
  148. const isLoading = ref(false);
  149. const finished = ref(false);
  150. // 获取数据
  151. const getData = () => {
  152. console.log('onload.....')
  153. post_promise({url: '/device/search', data: {
  154. size: page.pageSize,
  155. page: page.pageNum,
  156. sort: "createtime",
  157. order: "desc",
  158. keyWord: keyWord.value,
  159. mac: ''
  160. }})
  161. .then((result) => {
  162. console.log(result)
  163. // 刷新结束
  164. isLoading.value = false;
  165. refreshing.value = false;
  166. // 处理成功结果
  167. if(result.code == 0){
  168. // 下拉刷新时清空列表
  169. const dataArr:any[] = result.data;
  170. const total = result.total;
  171. const pages = Math.ceil(total / page.pageSize);
  172. console.log(pages);
  173. console.log(dataArr)
  174. if(page.pageNum == 1){
  175. dataList.value.splice(0, dataList.value.length);
  176. }
  177. dataList.value.push(...dataArr);
  178. page.pages = pages
  179. page.total = total
  180. console.log(dataList.value, pages)
  181. }
  182. },(result) => {
  183. console.log(result)
  184. isLoading.value = false;
  185. refreshing.value = false;
  186. // 跳转到首页
  187. }).catch((ex) => {
  188. console.log(ex)
  189. isLoading.value = false;
  190. refreshing.value = false;
  191. // 跳转到首页
  192. })
  193. };
  194. const onRefresh = () => {
  195. console.log('onrefresh...')
  196. console.log(refreshing.value)
  197. page.pageNum = 1;
  198. // 清空列表数据
  199. finished.value = false;
  200. // 重新加载数据
  201. // 将 loading 设置为 true,表示处于加载状态
  202. isLoading.value = true;
  203. getData();
  204. };
  205. const getTimeSpan = (time: string) => {
  206. const before = Date.parse(time);
  207. const now = new Date().getTime();
  208. return (now - before) / 1000;
  209. }
  210. // 生命周期
  211. onMounted(() => {
  212. console.log('onMounted');
  213. // const before = Date.parse("2011-10-10 14:48:00");
  214. // const now = Date.parse("2011-10-10 15:08:00");
  215. // console.log(before)
  216. // console.log(now)
  217. // console.log(now - before)
  218. getData();
  219. })
  220. // 点击加载
  221. const clickLoading = () => {
  222. console.log('clickLoading');
  223. page.pageNum++
  224. isLoading.value = true
  225. getData();
  226. }
  227. </script>
  228. <style scoped>
  229. </style>