App.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <script>
  2. var jpushModule = uni.requireNativePlugin("JG-JPush")
  3. export default {
  4. onLaunch: function() {
  5. console.log('App Launch')
  6. if(uni.getSystemInfoSync().platform == "ios"){
  7. // 请求定位权限
  8. let locationServicesEnabled = jpushModule.locationServicesEnabled()
  9. let locationAuthorizationStatus = jpushModule.getLocationAuthorizationStatus()
  10. console.log('locationAuthorizationStatus',locationAuthorizationStatus)
  11. if (locationServicesEnabled == true && locationAuthorizationStatus < 3) {
  12. jpushModule.requestLocationAuthorization((result)=>{
  13. console.log('定位权限',result.status)
  14. })
  15. }
  16. jpushModule.requestNotificationAuthorization((result)=>{
  17. let status = result.status
  18. if (status < 2) {
  19. uni.showToast({
  20. icon: 'none',
  21. title: '您还没有打开通知权限',
  22. duration: 3000
  23. })
  24. }
  25. })
  26. jpushModule.addGeofenceListener(result=>{
  27. let code = result.code
  28. let type = result.type
  29. let geofenceId = result.geofenceId
  30. let userInfo = result.userInfo
  31. uni.showToast({
  32. icon: 'none',
  33. title: '触发地理围栏',
  34. duration: 3000
  35. })
  36. })
  37. }
  38. jpushModule.initJPushService();
  39. jpushModule.setLoggerEnable(true);
  40. jpushModule.addConnectEventListener(result=>{
  41. let connectEnable = result.connectEnable
  42. uni.$emit('connectStatusChange',connectEnable)
  43. });
  44. jpushModule.addNotificationListener(result=>{
  45. let notificationEventType = result.notificationEventType
  46. let messageID = result.messageID
  47. let title = result.title
  48. let content = result.content
  49. let extras = result.extras
  50. uni.showToast({
  51. icon: 'none',
  52. title: JSON.stringify(result),
  53. duration: 3000
  54. })
  55. });
  56. jpushModule.addCustomMessageListener(result=>{
  57. let type = result.type
  58. let messageType = result.messageType
  59. let content = result.content
  60. uni.showToast({
  61. icon: 'none',
  62. title: JSON.stringify(result),
  63. duration: 3000
  64. })
  65. })
  66. jpushModule.addLocalNotificationListener(result=>{
  67. let messageID = result.messageID
  68. let title = result.title
  69. let content = result.content
  70. let extras = result.extras
  71. uni.showToast({
  72. icon: 'none',
  73. title: JSON.stringify(result),
  74. duration: 3000
  75. })
  76. })
  77. jpushModule.addGeofenceListener(result=>{
  78. let code = result.code
  79. let type = result.type
  80. let geofenceId = result.geofenceId
  81. let userInfo = result.userInfo
  82. uni.showToast({
  83. icon: 'none',
  84. title: '触发地理围栏',
  85. duration: 3000
  86. })
  87. })
  88. jpushModule.setIsAllowedInMessagePop(true)
  89. jpushModule.pullInMessage(result=>{
  90. let code = result.code
  91. console.log(code)
  92. })
  93. jpushModule.addInMessageListener(result=>{
  94. let eventType = result.eventType
  95. let messageType = result.messageType
  96. let content = result.content
  97. console.log('inMessageListener',eventType,messageType,content)
  98. uni.showToast({
  99. icon: 'none',
  100. title: JSON.stringify(result),
  101. duration: 3000
  102. })
  103. })
  104. },
  105. onShow: function() {
  106. console.log('App Show')
  107. },
  108. onHide: function() {
  109. console.log('App Hide')
  110. }
  111. }
  112. </script>
  113. <style lang="scss">
  114. @import "uview-ui/index.scss";
  115. /*每个页面公共css */
  116. .empty {
  117. padding: 40rpx 0;
  118. }
  119. .content {
  120. width: 100vw;
  121. min-height: 100vh;
  122. background: #F5F5F5;
  123. box-sizing: border-box;
  124. position: relative;
  125. }
  126. .hflex {
  127. display: flex;
  128. flex-direction: row;
  129. flex-wrap: nowrap;
  130. }
  131. .vflex {
  132. display: flex;
  133. flex-direction: column;
  134. flex-wrap: nowrap;
  135. }
  136. .jbetween {
  137. justify-content: space-between;
  138. }
  139. .jaround {
  140. justify-content: space-around;
  141. }
  142. .jend {
  143. justify-content: flex-end;
  144. }
  145. .jcenter {
  146. justify-content: center;
  147. }
  148. .acenter {
  149. align-items: center;
  150. }
  151. .abetween {
  152. align-content: space-between;
  153. }
  154. .astart {
  155. align-items: flex-start;
  156. }
  157. .aend {
  158. align-items: flex-end;
  159. }
  160. .fwrap {
  161. flex-wrap: wrap;
  162. }
  163. .text_hide {
  164. overflow: hidden;
  165. white-space: nowrap;
  166. text-overflow: ellipsis;
  167. }
  168. .text_hide2 {
  169. text-overflow: -o-ellipsis-lastline;
  170. overflow: hidden; //溢出内容隐藏
  171. text-overflow: ellipsis; //文本溢出部分用省略号表示
  172. display: -webkit-box; //特别显示模式
  173. -webkit-line-clamp: 2; //行数
  174. line-clamp: 2;
  175. -webkit-box-orient: vertical; //盒子中内容竖直排列
  176. }
  177. .text_hide3 {
  178. text-overflow: -o-ellipsis-lastline;
  179. overflow: hidden !important; //溢出内容隐藏
  180. text-overflow: ellipsis; //文本溢出部分用省略号表示
  181. display: -webkit-box; //特别显示模式
  182. -webkit-line-clamp: 3; //行数
  183. line-clamp: 3;
  184. -webkit-box-orient: vertical; //盒子中内容竖直排列
  185. }
  186. </style>