0

我有一个应用程序,每当数据库项目被更改时向用户发送推送通知。但是,问题是每当我发送通知时,它都会在通知抽屉中创建一个新项目。但是我想要做的是对这些通知进行堆叠或分组,因此只有一个项目表示“9个项目已更改”。Ionic 3 phonegap推送插件如何堆叠firebase通知

我如何用Ionic 3,phonegap push插件和firebase做到这一点?

这里是我当前的代码:

const options: PushOptions = { 
     android: { 
      senderID: SENDER_ID 
     }, 
     ios: { 
      alert: 'true', 
      badge: true, 
      sound: 'false' 
     }, 
     windows: {}, 
     browser: { 
      pushServiceURL: 'http://push.api.phonegap.com/v1/push' 
     } 
     }, 
     pushObject: PushObject = this.push.init(options); 

    pushObject.on('registration').subscribe((registration: any) => { 
     this.afDatabase.list('/users') 
     .update(`/${user.uid}/devices/${registration.registrationId}/`, {isKept: true}); 
    }); 
    pushObject.on('error').subscribe(error => alert('Error with Push plugin' + JSON.stringify(error))); 

而且我在火力功能是什么:

const functions = require('firebase-functions'); 
const admin = require('firebase-admin'); 
const _ = require('lodash'); 

admin.initializeApp(functions.config().firebase); 

exports.onItemsListItemAdd = functions.database.ref('/items-list/{item_id}').onCreate(event => { 
    let payload = { 
     notification: { 
      title: 'Items list', 
      body: `Added: ${event.data.val().itemName} [${event.data.val().itemNumber}]`, 
      icon: 'default' 
     } 
    }; 

    return sendToDevices(payload); 
}); 

exports.onItemsListItemUpdate = functions.database.ref('/items-list/{item_id}').onUpdate(event => { 
    let payload = { 
     notification: { 
      title: 'Items list', 
      body: `Updated: ${event.data.val().itemName} [${event.data.val().itemNumber}]`, 
      icon: 'default' 
     } 
    }; 

    return sendToDevices(payload); 
}); 

exports.onItemsListItemDelete = functions.database.ref('/items-list/{item_id}').onDelete(event => { 
    let payload = { 
     notification: { 
      title: 'Items list', 
      body: `Deleted: ${event.data.previous.val().itemName} [${event.data.previous.val().itemNumber}]`, 
      icon: 'default' 
     } 
    }; 

    return sendToDevices(payload); 
}); 

function sendToDevices(payload) { 
    const deviceTokens = admin.database().ref('/users').once('value'); 

    return deviceTokens.then(allTokens => { 
     if (allTokens.val()) { 
      // Listing all tokens. 
      const tokens = _(allTokens.val()) 
       .mapValues(user => user.devices) 
       .values() 
       .map(device => Object.keys(device)) 
       .flatten() 
       .value(); 

      // Send notifications to all tokens. 
      return admin.messaging().sendToDevice(tokens, payload).then(response => { 
       // For each message check if there was an error. 
       const tokensToRemove = []; 
       response.results.forEach((result, index) => { 
        const error = result.error; 
        if (error) { 
         console.error('Failure sending notification to', tokens[index], error); 
         // Cleanup the tokens who are not registered anymore. 
         if (error.code === 'messaging/invalid-registration-token' || 
          error.code === 'messaging/registration-token-not-registered') { 
          tokensToRemove.push(allTokens.ref.child(tokens[index]).remove()); 
         } 
        } 
       }); 
       return Promise.all(tokensToRemove); 
      }); 
     } 
    }); 
} 

回答

0

通过官方文件和一个小experimnting的寻找后,我终于找到了回答。基本上我需要做的是用我的推送通知中的“数据”字段替换“通知”字段,并给它不同的属性。请注意,当且仅当您完全删除“通知”字段时,给定的代码才有效。

这是当前载荷:

let payload = { 
    data: { 
     title: 'Items list', 
     message: `Added: ${event.data.val().itemName} [${event.data.val().itemNumber}]`, 
     style: 'inbox', 
     summaryText: 'There are %n% notifications' 
    } 
}; 

其中,“风格”属性使得离子堆的通知。

如果您不使用“style”属性,则每个新通知都会替换上一个。

如果您使用“通知”属性而不是“数据”,它会在每次推送的通知窗口中创建新通知。

另请注意,如果邮件尚未到达,您可以将collapseKey选项添加到您的请求中,以仅向用户显示最新消息。你可以这样做:

const options = { 
    collapseKey: 'sl_update' 
}; 

admin.messaging().sendToDevice(tokens, payload, options); 

我希望这会帮助别人。

欲了解更多信息,请参阅https://github.com/phonegap/phonegap-plugin-push/blob/master/docs/PAYLOAD.md#stacking