AI销管
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

App.vue 13 KiB

2年前
2年前
2年前
2年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
2年前
1年前
2年前
2年前
2年前
2年前
2年前
2年前
1年前
1年前
1年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
1年前
1年前
2年前
2年前
2年前
2年前
2年前
1年前
2年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
1年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
2年前
1年前
2年前
2年前
2年前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591
  1. <script>
  2. import Vue from 'vue';
  3. //app.js
  4. var config = require("./config");
  5. export default {
  6. onLaunch(options) {
  7. // 获取用户信息
  8. uni.getSystemInfo({
  9. success: function(e) {
  10. console.log(e, 'adjsakljdklasjdklsakjdslakjd')
  11. // #ifdef MP-WEIXIN
  12. Vue.prototype.StatusBar = e.statusBarHeight;
  13. let custom = wx.getMenuButtonBoundingClientRect();
  14. Vue.prototype.Custom = custom;
  15. Vue.prototype.CustomBar = custom.bottom + custom.top - e.statusBarHeight;
  16. Vue.prototype.windowHeight = e.safeArea.height
  17. // #endif
  18. Vue.mixin({
  19. data() {
  20. return {
  21. StatusBar: Vue.prototype.StatusBar,
  22. CustomBar: Vue.prototype.CustomBar,
  23. windowHeight: Vue.prototype.windowHeight,
  24. LOADING: false,
  25. bulidIngObj: uni.getStorageSync('buildingID'),
  26. };
  27. },
  28. methods: {
  29. //实时统计
  30. getTabBarBadge() {
  31. uni.request({
  32. url: config.service.realTimeStatistics,
  33. method: "POST",
  34. header: {
  35. 'content-type': 'application/json',
  36. 'Authorization': 'Bearer ' + uni.getStorageSync(
  37. 'weapp_session_login_data').token
  38. },
  39. data: {
  40. houseId: uni.getStorageSync('buildingID').id
  41. },
  42. success: (data) => {
  43. console.log(data.data.data.receivingCustomer,
  44. 'receivingCustomer')
  45. if (data.data.data == null) {
  46. uni.removeTabBarBadge({
  47. index: 0,
  48. })
  49. return
  50. } else {
  51. uni.removeTabBarBadge({
  52. index: 0,
  53. })
  54. if (data.data.data.receivingCustomer > 0) {
  55. uni.setTabBarBadge({
  56. index: 0,
  57. text: `${data.data.data.receivingCustomer}`
  58. })
  59. }
  60. }
  61. },
  62. fail: () => {
  63. uni.removeTabBarBadge({
  64. index: 0,
  65. })
  66. }
  67. })
  68. },
  69. upDateBulidIngObj() {
  70. this.bulidIngObj = uni.getStorageSync('buildingID')
  71. },
  72. addLookingCount(id) {
  73. uni.request({
  74. url: config.service.addLookingCount,
  75. method: "POST",
  76. header: {
  77. 'content-type': 'application/json',
  78. 'Authorization': 'Bearer ' + uni.getStorageSync(
  79. 'weapp_session_login_data').token
  80. },
  81. data: {
  82. houseId: uni.getStorageSync(
  83. 'buildingID').id,
  84. houseName: uni.getStorageSync(
  85. 'buildingID').name,
  86. recordId: id
  87. },
  88. })
  89. },
  90. sendLog(data) {
  91. uni.request({
  92. url: config.service.addLog,
  93. method: "POST",
  94. header: {
  95. 'content-type': 'application/json',
  96. 'Authorization': 'Bearer ' + uni.getStorageSync(
  97. 'weapp_session_login_data').token
  98. },
  99. data: {
  100. houseId: data.houseId || uni.getStorageSync(
  101. 'buildingID').id,
  102. houseName: data.houseName || uni.getStorageSync(
  103. 'buildingID').name,
  104. serviceId: "test",
  105. recordId: data.id
  106. },
  107. success: (data) => {
  108. console.log(data)
  109. }
  110. })
  111. },
  112. // 时分秒转换为秒
  113. TIMEEVENT(e) {
  114. var time = e;
  115. var len = time.split(':')
  116. if (len.length == 3) {
  117. var hour = time.split(':')[0];
  118. var min = time.split(':')[1];
  119. var sec = time.split(':')[2];
  120. return Number(hour * 3600) + Number(min * 60) + Number(sec);
  121. }
  122. if (len.length == 2) {
  123. var min = time.split(':')[0];
  124. var sec = time.split(':')[1];
  125. return Number(min * 60) + Number(sec);
  126. }
  127. if (len.length == 1) {
  128. var sec = time.split(':')[0];
  129. return Number(sec);
  130. }
  131. },
  132. // 目前使用页面为录音页面
  133. SPEAKERSTYLE(index) {
  134. let obj = {
  135. color: '',
  136. }
  137. switch (index) {
  138. case 1:
  139. obj.color = '#60CBEC';
  140. break;
  141. case 2:
  142. obj.color = '#EC8B47';
  143. break;
  144. case 3:
  145. obj.color = '#4F861E';
  146. break;
  147. case 5:
  148. obj.color = '#4980C8';
  149. break;
  150. case 6:
  151. obj.color = '#60CBEC';
  152. break;
  153. case 7:
  154. obj.color = '#EC8B47';
  155. break;
  156. case 8:
  157. obj.color = '#4F861E';
  158. break;
  159. default:
  160. obj.color = '#9F61C8';
  161. break;
  162. }
  163. return obj
  164. },
  165. // 检测权限 返回 Boolean类型
  166. CHECKAUTHORITY(name = '') {
  167. let menu = uni.getStorageSync('weapp_session_Menu_data')
  168. return menu[name] === undefined ? false : menu[name]
  169. },
  170. },
  171. filters: {
  172. // ASCII码转换 大写字母A是65 演讲人是从1开始所以num+64
  173. toCapital(num) {
  174. let str = ''
  175. if (num) {
  176. str = String.fromCharCode(num + 64)
  177. }
  178. return str
  179. }
  180. }
  181. });
  182. }
  183. });
  184. // 新版本更新
  185. if (wx.canIUse('getUpdateManager')) {
  186. const updateManager = wx.getUpdateManager()
  187. updateManager.onCheckForUpdate(function(res) {
  188. if (res.hasUpdate) {
  189. updateManager.onUpdateReady(function() {
  190. uni.showModal({
  191. title: '更新提示',
  192. cancelColor: "#999999",
  193. content: '新版本已经准备好,是否重启应用?',
  194. success: function(res) {
  195. if (res.confirm) {
  196. updateManager.applyUpdate()
  197. }
  198. }
  199. })
  200. })
  201. updateManager.onUpdateFailed(function() {
  202. uni.showModal({
  203. title: '已经有新版本了哟~',
  204. cancelColor: "#999999",
  205. content: '新版本已经上线啦~,请您删除当前小程序,重新搜索打开哟~'
  206. })
  207. })
  208. }
  209. })
  210. } else {
  211. uni.showModal({
  212. title: '提示',
  213. cancelColor: "#999999",
  214. content: '当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试。'
  215. })
  216. }
  217. // 判断token
  218. const token = uni.getStorageSync("weapp_session_login_data")
  219. if (typeof token.token != "string") {
  220. return
  221. }
  222. uni.request({
  223. url: config.service.getUser,
  224. method: "GET",
  225. header: {
  226. 'content-type': 'application/json',
  227. 'Authorization': 'Bearer ' + uni.getStorageSync('weapp_session_login_data').token
  228. },
  229. success: (res) => {
  230. let rescor = res.data.data;
  231. console.log(res, '数据', rescor)
  232. // return
  233. if (res.statusCode == 401) {
  234. uni.showToast({
  235. title: '登录过期请重新登录',
  236. icon: "none",
  237. duration: 2000,
  238. })
  239. uni.navigateTo({
  240. url: `/pages/login/index`
  241. })
  242. return
  243. }
  244. if (rescor.user.total == 0) {
  245. uni.showToast({
  246. title: '暂无绑定项目',
  247. duration: 2000,
  248. icon: "none"
  249. });
  250. return
  251. } else {
  252. let lopan = {
  253. id: rescor.houseList[0].id,
  254. name: rescor.houseList[0].propertyName
  255. }
  256. let users = rescor.user
  257. users.zkProperties = rescor.houseList
  258. console.log(users, '角色数据')
  259. uni.setStorageSync("weapp_session_userInfo_data", users); //写入缓存
  260. }
  261. }
  262. })
  263. this.$u.get(config.service.notReadNum, {
  264. id: uni.getStorageSync('weapp_session_userInfo_data').accountId,
  265. projectId: uni.getStorageSync('buildingID').id
  266. }).then(res => {
  267. if (res > 0) {
  268. uni.setTabBarBadge({ //显示数字
  269. index: 4, //tabbar下标
  270. text: res || 0 //数字
  271. })
  272. } else {
  273. uni.removeTabBarBadge({
  274. index: 4
  275. })
  276. }
  277. }).catch(e => {
  278. uni.removeTabBarBadge({
  279. index: 4
  280. })
  281. })
  282. // this.$u.get("/user/getUser")
  283. // .then(data => {
  284. // if (data.user.total==0) {
  285. // uni.showToast({
  286. // title: '暂无绑定项目',
  287. // duration: 2000,
  288. // icon:"none"
  289. // });
  290. // return
  291. // } else {
  292. // let lopan = {
  293. // id: data.houseList[0].id,
  294. // name: data.houseList[0].propertyName
  295. // }
  296. // let users=data.user
  297. // users.zkProperties=data.houseList
  298. // uni.setStorageSync("weapp_session_userInfo_data",users); //写入缓存
  299. // }
  300. // })
  301. wx.setInnerAudioOption({
  302. obeyMuteSwitch: false
  303. });
  304. },
  305. onShow(options) {
  306. const token = uni.getStorageSync("weapp_session_login_data")
  307. if (typeof token.token != "string") {
  308. console.log("没有")
  309. return
  310. } else {}
  311. }
  312. };
  313. </script>
  314. <style>
  315. @import "./app.css";
  316. </style>
  317. <style lang="scss">
  318. @import "uview-ui/index.scss";
  319. /*每个页面公共css */
  320. //图表样式等
  321. .single {
  322. width: 100%;
  323. background: #FFFFFF;
  324. .title {
  325. width: 100%;
  326. height: 80rpx;
  327. display: flex;
  328. align-items: center;
  329. .title1 {
  330. flex: 2;
  331. font-size: 30rpx;
  332. font-weight: 500;
  333. color: #333333;
  334. line-height: 80rpx;
  335. padding-left: 30rpx;
  336. font-family: PingFangSC-Medium, PingFang SC;
  337. }
  338. .title3 {
  339. flex: 3;
  340. height: 90rpx;
  341. display: flex;
  342. align-items: center;
  343. justify-content: flex-end;
  344. padding-right: 30rpx;
  345. .title3-box {
  346. display: flex;
  347. align-items: center;
  348. width: 25%;
  349. justify-content: center;
  350. .activecltab {
  351. color: #2671E2;
  352. border-bottom: 4rpx solid #2671E2;
  353. }
  354. }
  355. }
  356. .title2 {
  357. flex: 2;
  358. display: flex;
  359. justify-content: flex-end;
  360. align-items: center;
  361. height: 42rpx;
  362. font-size: 30rpx;
  363. font-family: PingFangSC-Regular, PingFang SC;
  364. font-weight: 400;
  365. color: #333333;
  366. line-height: 42rpx;
  367. margin-right: 30rpx;
  368. .righttochoose {
  369. width: 24rpx;
  370. height: 12rpx;
  371. margin-left: 12rpx;
  372. }
  373. }
  374. }
  375. .swiper-box {
  376. width: 97%;
  377. margin: 0 auto 26rpx;
  378. }
  379. .hejibox {
  380. width: 100%;
  381. height: 80rpx;
  382. display: flex;
  383. .heji {
  384. width: 50%;
  385. height: 100%;
  386. font-size: 28rpx;
  387. font-weight: 400;
  388. color: #666666;
  389. line-height: 80rpx;
  390. text-indent: 30rpx;
  391. }
  392. }
  393. .danwei {
  394. width: 100%;
  395. height: 40rpx;
  396. font-size: 24rpx;
  397. font-weight: 400;
  398. color: #999999;
  399. line-height: 40rpx;
  400. text-indent: 30rpx;
  401. }
  402. .uchaserbox {
  403. width: 95%;
  404. height: 470rpx;
  405. }
  406. .jindu {
  407. width: 100%;
  408. min-height: 400rpx;
  409. .jindu-box {
  410. width: 100%;
  411. padding: 0 30rpx;
  412. .jindu-boxche {
  413. width: 100%;
  414. height: 40rpx;
  415. display: flex;
  416. align-items: center;
  417. margin-bottom: 38rpx;
  418. .jindu-name {
  419. width: 120rpx;
  420. font-size: 28rpx;
  421. font-family: PingFangSC-Regular, PingFang SC;
  422. font-weight: 400;
  423. color: #333333;
  424. line-height: 40rpx;
  425. }
  426. .progress-cus {
  427. flex: 1;
  428. height: 30rpx;
  429. margin-left: 10rpx;
  430. background: #F0F1F2;
  431. .color {
  432. height: 30rpx;
  433. background: linear-gradient(90deg, #3A82EF 0%, #7EB2FF 100%);
  434. }
  435. .color4 {
  436. height: 30rpx;
  437. background: linear-gradient(270deg, #6DC5B8 0%, #07B79D 100%);
  438. }
  439. .color1 {
  440. height: 30rpx;
  441. background: linear-gradient(270deg, #F88881 0%, #E6625B 100%); //1
  442. }
  443. .color2 {
  444. height: 30rpx;
  445. background: linear-gradient(270deg, #FFC940 0%, #FF981E 100%); //2
  446. }
  447. .color3 {
  448. height: 30rpx;
  449. background: linear-gradient(270deg, #FFE800 0%, #FFCC00 100%); //3
  450. }
  451. }
  452. .jindu-zxl {
  453. width: 120rpx;
  454. font-size: 28rpx;
  455. margin-left: 12rpx;
  456. color: #333;
  457. text-align: left;
  458. line-height: 40rpx;
  459. }
  460. }
  461. }
  462. }
  463. }
  464. //时间切换的样式
  465. .boxtittab {
  466. width: 100;
  467. height: 92rpx;
  468. background: #FFFFFF;
  469. display: flex;
  470. align-items: center;
  471. .tabbox {
  472. flex: 1;
  473. height: 100%;
  474. text-align: center;
  475. line-height: 92rpx;
  476. color: #666666;
  477. font-size: 28rpx;
  478. font-weight: 400;
  479. display: flex;
  480. justify-content: center;
  481. .activecllasscet {
  482. width: 96rpx;
  483. color: #2671E2;
  484. font-weight: 600;
  485. border-bottom: 4rpx solid #2671E2;
  486. }
  487. }
  488. }
  489. //多个格子的样式
  490. .boxzonglan {
  491. width: 100%;
  492. min-height: 496rpx;
  493. background: #FFFFFF;
  494. padding: 30rpx 30rpx 30rpx 30rpx;
  495. .zonglantit {
  496. font-size: 30rpx;
  497. color: #333333;
  498. font-family: PingFangSC-Semibold, PingFang SC;
  499. font-weight: 500;
  500. }
  501. .zonglanbox {
  502. width: 100%;
  503. display: flex;
  504. flex-wrap: wrap;
  505. margin-top: 24rpx;
  506. box-shadow: 0px 0px 12rpx 0px rgba(38, 113, 226, 0.1);
  507. border-radius: 12rpx;
  508. .grid {
  509. width: 50%;
  510. // height: 128rpx;
  511. padding-bottom: 24rpx;
  512. // border: 1rpx solid #E0E0E0;
  513. .audonum {
  514. color: #666666;
  515. text-indent: 40rpx;
  516. font-size: 28rpx;
  517. margin-top: 20rpx;
  518. line-height: 40rpx;
  519. display: flex;
  520. align-items: center;
  521. .circle {
  522. width: 20rpx;
  523. height: 20rpx;
  524. background: #FFFFFF;
  525. border: 6rpx solid #2671E2;
  526. margin-right: 12rpx;
  527. margin-left: 30rpx;
  528. border-radius: 50%;
  529. }
  530. }
  531. .num {
  532. color: #333333;
  533. text-indent: 40rpx;
  534. font-size: 44rpx;
  535. font-weight: 600;
  536. line-height: 50rpx;
  537. margin-top: 18rpx;
  538. }
  539. }
  540. }
  541. }
  542. </style>