subscription.vue 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. <template>
  2. <!-- 消息订阅组件 -->
  3. <view class="message_subscription">
  4. <button @click="judgementMessageSwitch()"
  5. style="margin: 20px;background-color: rgb(55,186,189);">消息订阅测试</button>
  6. <button @click="getUser()" style="margin: 20px;background-color: rgb(55,186,189);">获取用户信息</button>
  7. <button @click="login()" style="margin: 20px;background-color: rgb(55,186,189);">使用微信登录</button>
  8. <u-popup v-model="showOpenSettingDialog" mode="center" width="520rpx" :mask-close-able="false" height="300rpx"
  9. border-radius="18">
  10. <div class="mock-dialog">
  11. <div class="mock-dialog-content">
  12. <div class="mock-dialog-title">提示</div>
  13. <div class="mock-dialog-text">
  14. {{tipsContent}}
  15. </div>
  16. </div>
  17. <div class="mock-dialog-button">
  18. <div class="color-gray" @click="dontOpenSetting">{{buttonCancelText}}</div>
  19. <div class="color-blue" @click="openSetting">{{buttonConfirmText}}</div>
  20. </div>
  21. </div>
  22. </u-popup>
  23. </view>
  24. </template>
  25. <script>
  26. export default {
  27. name: 'messageSubscription',
  28. components: {},
  29. data() {
  30. return {
  31. showOpenSettingDialog: false, // 授权询问弹框,uview
  32. tipsContent: '为了及时获取订单状态,您是否想接收订单状态的消息提醒?', // 弹框提示内容,
  33. buttonConfirmText: '去开启消息提醒',
  34. buttonCancelText: '不需要提醒',
  35. tmplId: []
  36. }
  37. },
  38. methods: {
  39. // 判断消息订阅总开关是否打开
  40. judgementMessageSwitch(flag) {
  41. let that = this
  42. uni.getSetting({
  43. withSubscriptions: true,
  44. success(res) {
  45. console.log(res)
  46. if (!res.subscriptionsSetting.mainSwitch) { // 订阅消息的总开关,如果是关着的,引导用户去打开
  47. that.showOpenSettingDialog = true
  48. } else { // 如果开着,则继续向下打开弹窗,获取用户授权
  49. that.messageSubscription()
  50. }
  51. },
  52. fail() {
  53. that.messageSubscription() // 如果失败,则继续向下打开弹窗,获取用户授权
  54. }
  55. })
  56. },
  57. // 弹窗点订阅,开启消息订阅提醒
  58. openSetting() {
  59. if (this.buttonConfirmText == '确定') {
  60. this.messageSubscription()
  61. return
  62. }
  63. var that = this
  64. uni.openSetting({
  65. withSubscriptions: true,
  66. complete(res) {
  67. uni.getSetting({
  68. withSubscriptions: true,
  69. success(res) {
  70. if (res.subscriptionsSetting.mainSwitch) { // 订阅消息的总开关,如果是开着的
  71. that.tipsContent = '再次点击确定,弹出可订阅列表进行订阅'
  72. that.buttonCancelText = '取消'
  73. that.buttonConfirmText = '确定'
  74. } else {
  75. that.showOpenSettingDialog = false;
  76. }
  77. }
  78. })
  79. }
  80. })
  81. },
  82. getUser() {
  83. uni.getUserProfile({
  84. desc: "获取你的昵称、头像信息", //必填项,声明获取用户个人信息后的用途,不超过30个字符
  85. success: (res) => {
  86. const userInfo = res.userInfo;
  87. console.log("用户基本信息", userInfo);
  88. },
  89. fail: (res) => {
  90. //拒绝授权
  91. wx.showToast({
  92. title: "获取失败",
  93. icon: "error",
  94. duration: 2000,
  95. });
  96. return;
  97. },
  98. });
  99. },
  100. // 弹窗点不订阅
  101. dontOpenSetting() {
  102. this.showOpenSettingDialog = false;
  103. },
  104. // 订阅申请弹出,只允许点击弹出
  105. messageSubscription() {
  106. this.tipsContent = '为了及时掌握订单状态,您是否想接收订单状态的消息提醒?' // 弹框提示内容,
  107. this.buttonConfirmText = '去开启消息提醒'
  108. this.buttonCancelText = '不需要提醒'
  109. let that = this
  110. that.showOpenSettingDialog = false;
  111. let tmplId = ['2nFR6OXrC7d6w3ZkqaLsKjXYBQB3k78xzRvQoPacfKA']
  112. // let tmplId = ['qgp7iG6xTRm4JewW8N46nXJT-E6xorFn2hZ2V7gD8wY']
  113. // 'Toomi1XWGMzNxOCoPX1rRNj7gLuykgszEzUstXaAp9c', 'CdLBnE4unNbHlQikYoGHehagWZAK8gSGu52QCbAesLIQUE'
  114. // 模板ID,去小程序后台管理开一个,写进数组里,官方文档也有介绍
  115. uni.requestSubscribeMessage({
  116. tmplIds: tmplId,
  117. success(res) {
  118. console.log("success", res)
  119. // if (res['qgp7iG6xTRm4JewW8N46nXJT-E6xorFn2hZ2V7gD8wY'] == 'accept') {
  120. console.log('订阅成功');
  121. // }
  122. }
  123. })
  124. }
  125. }
  126. }
  127. </script>
  128. <style lang="scss" scoped></style>