smsAlarm.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330
  1. <template>
  2. <!-- pages/smsAlarm/smsAlarm.wxml -->
  3. <view class="container">
  4. <view style="height: 80rpx"></view>
  5. <view class="list-group">
  6. <view v-for="(item, index) in alarmList" :key="index">
  7. <view class="info-group list-item">
  8. <view class="top-group">
  9. <view class="group-view flex-row flex-between">
  10. <view class="flex-row">
  11. <view class="info-text">设备名称:</view>
  12. <view class="info-text-gray">{{ item.gpsbms_name }}</view>
  13. </view>
  14. <view class="flex-row">
  15. <view class="info-text">设备编号:</view>
  16. <view class="info-text-gray">{{ item.battery_sn }}</view>
  17. </view>
  18. </view>
  19. <view class="group-view flex-row">
  20. <view class="info-text">已发生报警短信次数:</view>
  21. <view class="red-text">{{ item.number }}次</view>
  22. </view>
  23. <view class="group-view flex-row">
  24. <view class="info-text">最近报警类型:</view>
  25. <view class="red-text">{{ item.last_alarm_name }}</view>
  26. </view>
  27. <view class="group-view flex-row">
  28. <view class="info-text">最近报警时间:</view>
  29. <view class="info-text-gray">{{ tools.formatTime(item.ctime) }}</view>
  30. </view>
  31. </view>
  32. <view class="op_view flex-row">
  33. <view @tap="bindAlarmConfigDevice" :data-index="index" class="item_alarm">报警类型开关</view>
  34. <view @tap="bindAlarmRecord" :data-index="index" class="item_record">报警记录</view>
  35. </view>
  36. </view>
  37. </view>
  38. </view>
  39. <view class="no-more">没有更多信息</view>
  40. <view style="height: 90rpx"></view>
  41. <view class="top-bar-container flex-row">
  42. <view style="font-size: 28rpx">短信报警通知</view>
  43. <image :src="!alarmStatus ? '/static/resource/images/kaiqi.png' : '/static/resource/images/guanbi.png'" class="notice-img" @tap="bindSetNotice"></image>
  44. </view>
  45. <view class="bottom-bar-container flex-row flex-between">
  46. <view @tap="bindSetConfigType" class="config_type_view">配置全部报警</view>
  47. <view @tap="bindSetBalance" class="balance_view">余额:{{ coin / 100 }}币</view>
  48. </view>
  49. <view v-if="isShowActivity" class="modal-group flex-row flex-around">
  50. <view class="pop_bg_view">
  51. <view class="avatar_view">
  52. <image :src="userInfo.type == 'group' && userInfo.info.headimg ? userInfo.info.headimg : '/resource/images/logo.png'" class="avatar_img"></image>
  53. </view>
  54. <view class="pop_view">
  55. <view class="name_text">{{ userInfo.info.name }}</view>
  56. <view class="give_view">
  57. <text>赠送:</text>
  58. <text class="red_view">{{ coupon.send_gift / 100 }}币</text>
  59. </view>
  60. <!-- <rich-text nodes="{{useHtml}}"></rich-text> -->
  61. <view class="use_view">
  62. <text>用途:</text>
  63. <text class="use_mark">可用于短信报警通知,每条短信消耗{{ coupon.cost / 100 }}币</text>
  64. </view>
  65. <view @tap="clickUseCoupon" class="get_wallet">领取到钱包</view>
  66. </view>
  67. </view>
  68. </view>
  69. </view>
  70. </template>
  71. <script module="tools" lang="wxs" src="@/pages/common/wxs/tools.wxs"></script>
  72. <script>
  73. // pages/smsAlarm/smsAlarm.js
  74. var appConfig = require('../../common/appConfig.js');
  75. const config = require('../../common/config.js');
  76. const http = require('../../common/http.js');
  77. const common = require('../../common/common.js');
  78. var storage = require('../../common/storage.js');
  79. const LIMT_PAGE = 20;
  80. export default {
  81. data() {
  82. return {
  83. isLoading: false,
  84. alarmList: [],
  85. start_page: 1,
  86. limit_page: LIMT_PAGE,
  87. alarmStatus: false,
  88. // 0 开启短信报警 1 关闭短信报警
  89. coin: 0,
  90. userInfo: {
  91. type: '',
  92. info: {
  93. headimg: '',
  94. name: ''
  95. }
  96. },
  97. isShowActivity: false,
  98. coupon: {
  99. send_gift: 0,
  100. cost: 0
  101. },
  102. useHtml: ''
  103. };
  104. }
  105. /**
  106. * 生命周期函数--监听页面加载
  107. */,
  108. onLoad: function (options) {
  109. const userInfo = storage.getUserInfo();
  110. this.setData({
  111. userInfo: userInfo,
  112. useHtml:
  113. "<span style='font-size: 13px;'>\u7528\u9014\uFF1A</span><span style='color: rgb(51, 51, 51,0.38);font-size: 13px;'>\u53EF\u7528\u4E8E\u77ED\u4FE1\u62A5\u8B66\u901A\u77E5\uFF0C\u6BCF\u6761\u77ED\u4FE1\u6D88\u80170.1\u5E01</span>"
  114. });
  115. this.refreshLoadSmsAlarmList();
  116. this.loadHasCoupon();
  117. },
  118. /**
  119. * 生命周期函数--监听页面显示
  120. */
  121. onShow: function () {
  122. this.loadGetCoin();
  123. },
  124. /**
  125. * 页面相关事件处理函数--监听用户下拉动作
  126. */
  127. onPullDownRefresh: function () {
  128. this.refreshLoadSmsAlarmList();
  129. },
  130. /**
  131. * 页面上拉触底事件的处理函数
  132. */
  133. onReachBottom: function () {
  134. if (this.isLoading) {
  135. return;
  136. }
  137. this.setData({
  138. isLoading: true
  139. });
  140. this.start_page++;
  141. this.loadWarnList();
  142. },
  143. methods: {
  144. refreshLoadSmsAlarmList: function () {
  145. if (this.isLoading) {
  146. return;
  147. }
  148. this.setData({
  149. alarmList: [],
  150. isLoading: true
  151. });
  152. common.loading();
  153. this.limit_page = LIMT_PAGE;
  154. this.start_page = 1;
  155. this.loadWarnList();
  156. },
  157. bindSetConfigType() {
  158. uni.navigateTo({
  159. url: '/pages/smsConfig/smsConfig?type=1',
  160. success: function (res) {},
  161. fail: function (res) {},
  162. complete: function (res) {}
  163. });
  164. },
  165. bindSetBalance() {
  166. uni.navigateTo({
  167. url: '/pages/wallet/wallet',
  168. success: function (res) {},
  169. fail: function (res) {},
  170. complete: function (res) {}
  171. });
  172. },
  173. bindAlarmConfigDevice: function (e) {
  174. const index = e.currentTarget.dataset.index;
  175. uni.navigateTo({
  176. url: '/pages/smsConfig/smsConfig?type=0&macid=' + this.alarmList[index].battery_sn,
  177. success: function (res) {},
  178. fail: function (res) {},
  179. complete: function (res) {}
  180. });
  181. },
  182. bindAlarmRecord: function (e) {
  183. const index = e.currentTarget.dataset.index;
  184. uni.navigateTo({
  185. url: '/pages/smsRecord/smsRecord?macid=' + this.alarmList[index].battery_sn,
  186. success: function (res) {},
  187. fail: function (res) {},
  188. complete: function (res) {}
  189. });
  190. },
  191. loadHasCoupon() {
  192. const me = this;
  193. http.postRequest(config.API_HAS_COUPON, {}, function (resp) {
  194. if (resp.data.code === 200) {
  195. me.setData({
  196. coupon: resp.data.data
  197. });
  198. if (me.coupon.has_coupon) {
  199. me.setData({
  200. isShowActivity: true
  201. });
  202. }
  203. } else {
  204. common.simpleToast(resp.data.msg);
  205. }
  206. });
  207. },
  208. clickUseCoupon() {
  209. const me = this;
  210. http.postRequest(config.API_USE_COUPON, {}, function (resp) {
  211. if (resp.data.code === 200) {
  212. me.setData({
  213. isShowActivity: false
  214. });
  215. me.loadGetCoin();
  216. common.simpleToast('领取成功');
  217. } else {
  218. common.simpleToast(resp.data.msg);
  219. }
  220. });
  221. },
  222. loadGetCoin() {
  223. const me = this;
  224. http.postApi(config.API_GET_COIN, {}, function (resp) {
  225. if (resp.data.code === 200) {
  226. me.setData({
  227. coin: resp.data.data.coin
  228. });
  229. }
  230. });
  231. },
  232. loadWarnList() {
  233. const me = this;
  234. common.loading();
  235. const pData = {
  236. size: me.limit_page,
  237. page: me.start_page
  238. };
  239. http.postRequest(config.API_ALARM_SUMMARY, pData, function (resp) {
  240. uni.hideLoading();
  241. uni.stopPullDownRefresh();
  242. if (resp.data.code === 200) {
  243. let alarmList = me.alarmList;
  244. var alarm_list = resp.data.data.list;
  245. for (var i = 0; alarm_list.length > i; i++) {
  246. var import_alarm_list = alarm_list[i].alarm_setting[0].list;
  247. var warn_alarm_list = alarm_list[i].alarm_setting[1].list;
  248. var importAlarmList = [];
  249. var warnAlarmList = [];
  250. for (var j = 0; import_alarm_list.length > j; j++) {
  251. importAlarmList.push(import_alarm_list[j].alarmName);
  252. }
  253. for (var m = 0; warn_alarm_list.length > m; m++) {
  254. warnAlarmList.push(warn_alarm_list[m].alarmName);
  255. }
  256. alarm_list[i].importAlarm = importAlarmList.toString();
  257. alarm_list[i].warnAlarm = warnAlarmList.toString();
  258. }
  259. console.log(alarm_list);
  260. alarmList.push.apply(alarmList, alarm_list);
  261. me.setData({
  262. alarmList: alarmList,
  263. alarmStatus: resp.data.data.close_alarm,
  264. coin: resp.data.data.coin,
  265. isLoading: false
  266. });
  267. } else {
  268. common.simpleToast(resp.data.msg);
  269. }
  270. });
  271. },
  272. bindSetNotice() {
  273. if (!this.alarmStatus) {
  274. const me = this;
  275. uni.showModal({
  276. title: '',
  277. content: '您正在关闭短信通知,关闭后您将接收不到短信警报提醒,您是否要继续关闭?',
  278. showCancel: true,
  279. cancelText: '取消',
  280. confirmText: '确定',
  281. success: function (res) {
  282. if (res.confirm) {
  283. me.loadCloseAlarm();
  284. }
  285. }
  286. });
  287. } else {
  288. this.loadCloseAlarm();
  289. }
  290. },
  291. loadCloseAlarm() {
  292. const me = this;
  293. common.loading();
  294. http.postRequest(
  295. config.API_CLOSE_ALARM,
  296. {
  297. status: !this.alarmStatus
  298. },
  299. function (resp) {
  300. uni.hideLoading();
  301. if (resp.data.code === 200) {
  302. me.setData({
  303. alarmStatus: !me.alarmStatus
  304. });
  305. } else {
  306. common.simpleToast(resp.data.msg);
  307. }
  308. }
  309. );
  310. }
  311. }
  312. };
  313. </script>
  314. <style>
  315. @import './smsAlarm.css';
  316. </style>