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