Я обновляю уведомление для UNUserNotification фреймворка для моего приложения, похожего на тревогу, и я думал, что у меня это получилось, но я понял, что, когда я установил более одной тревоги, я получаю уведомление только о самой последней.Повторяющиеся дни работают тесто.Может ли быть проблема идентификатора триггера, который получает ту же строку, что и предыдущие, и перезаписывает ее?Я действительно не понимаю этого поведения, и я не могу найти, в чем проблема.
Это код:
func setRouteNotification(_ date: Date, onWeekdaysForNotify weekdays:[Int], snoozeEnabled:Bool, onSnooze: Bool, soundName: String, routeName: String, index: Int) {
configureCategory()
// Notification content
let routeCheckNotificationContent = UNMutableNotificationContent()
let datesForNotification = correctDate(date, onWeekdaysForNotify: weekdays)
routeCheckNotificationContent.title = "Hello!! Are you ready to cycle?"
routeCheckNotificationContent.body = "Check route for alerts?"
routeCheckNotificationContent.categoryIdentifier = Id.notificationCategory
routeCheckNotificationContent.sound = UNNotificationSound.init(named: soundName + ".mp3")
let repeating: Bool = !weekdays.isEmpty
routeCheckNotificationContent.userInfo = ["snooze" : snoozeEnabled, "index": index, "soundName": soundName, "routeName": routeName, "repeating" : repeating]
//repeat weekly if repeat weekdays are selected
//no repeat with snooze notification
if !weekdays.isEmpty && !onSnooze{ }
syncAlarmModel()
var counter = 1
for d in datesForNotification {
if onSnooze {
alarmModel.alarms[index].date = Scheduler.correctSecondComponent(date: alarmModel.alarms[index].date)
} else {
alarmModel.alarms[index].date = d
}
// Notification trigger
let calendar = Calendar(identifier: .gregorian)
let components = calendar.dateComponents(in: .current, from: d)
let newComponents = DateComponents(calendar: calendar, timeZone: .current, month: components.month, day: components.day, hour: components.hour, minute: components.minute, second: components.second)
let trigger = UNCalendarNotificationTrigger(dateMatching: newComponents, repeats: true)
// Notification Request
let routeNotificationRequest = UNNotificationRequest(identifier: "routeNotificationRequest\(scheduledNotifications.count + counter)", content: routeCheckNotificationContent, trigger: trigger)
// Add request
UNUserNotificationCenter.current().add(routeNotificationRequest) { (Error) in
if Error != nil {
print("something went wrong with adding notification")
}
}
print("added request\(alarmModel.alarms.count + weekdays.count + counter)")
scheduledNotifications.append(counter)
print("scheduled notifications are \(scheduledNotifications.count)")
counter = ( counter + 1 )
}
print(alarmModel.alarms)
}
Любая идея, почему нетустановить все запрограммированные уведомления?Большое спасибо, как обычно.
РЕДАКТИРОВАТЬ:
Я попытался настроить массив var scheduledNotifications: [Int] = []
, который будет хранить прогрессивный номер при добавлении уведомлений, и использовать его в качестве идентификатора для запроса
let routeNotificationRequest = UNNotificationRequest(identifier: "routeNotificationRequest\(scheduledNotifications.count + counter)", content: routeCheckNotificationContent, trigger: trigger)
, поэтому я уверен, что все добавленные уведомления имеют уникальный идентификатор запроса, но ничего не изменилось, но все равно получает уведомление только самый последний.
РЕДАКТИРОВАТЬ 2: вывод на консоль, когда я устанавливаю 2 уведомления на каждый день:
added request9B642AB7-D4F3-4BDA-A5B3-D259419390D5
scheduled notifications are 1
added requestBA0EF286-CD4D-408D-AEFC-E3DED24FBBB4
scheduled notifications are 2
added request947FEFEF-0B4E-4163-8435-DCEC725F21F7
scheduled notifications are 3
added request8FF19184-F970-45AD-95FE-39CFABF83348
scheduled notifications are 4
added requestA447CABF-AD80-4A73-B214-B8A1AA47F76B
scheduled notifications are 5
added request217EF2E4-6241-4840-9431-16744F2E5314
scheduled notifications are 6
added request28C92EF2-143C-4364-9CC3-EB5335AA9B6F
scheduled notifications are 7
[fix_it_mapView.Alarm(date: 2018-10-06 13:28:00 +0000, enabled: true, snoozeEnabled: false, repeatWeekdays: [1, 2, 3, 4, 5, 6, 7], uuid: "1C5A746F-F97D-4149-A0CC-47E6334BF3C3", mediaID: "", mediaLabel: "Burlone", label: "Route", onSnooze: false, routeLabel: "prova3"), fix_it_mapView.Alarm(date: 2018-09-23 13:29:00 +0000, enabled: true, snoozeEnabled: false, repeatWeekdays: [1, 2, 3, 4, 5, 6, 7], uuid: "B708BC27-82AA-4AA2-A8CA-252460E48476", mediaID: "", mediaLabel: "Burlone", label: "Route", onSnooze: false, routeLabel: "prova1")]
dates for notification are: [2018-09-30 13:28:00 +0000, 2018-10-01 13:28:00 +0000, 2018-10-02 13:28:00 +0000, 2018-10-03 13:28:00 +0000, 2018-10-04 13:28:00 +0000, 2018-10-05 13:28:00 +0000, 2018-10-06 13:28:00 +0000]
added request2467230C-BC4A-4307-A0FA-108C5C291DCC
scheduled notifications are 8
added requestF27D9E76-BCCC-4E3A-91D7-CA60E64B61B9
scheduled notifications are 9
added requestDFF37582-AB57-4029-A480-6FFA4068E316
scheduled notifications are 10
added requestBC5633BD-234C-4555-8259-988908B6E4DA
scheduled notifications are 11
added requestEC35384F-2E7F-4267-A745-777E0C2A2CE8
scheduled notifications are 12
added requestFF866674-ED94-4BA0-8BA5-E8314521EA4F
scheduled notifications are 13
added request4D739860-83CB-43F9-895D-2E8D48C5154E
scheduled notifications are 14
[fix_it_mapView.Alarm(date: 2018-10-06 13:28:00 +0000, enabled: true, snoozeEnabled: false, repeatWeekdays: [1, 2, 3, 4, 5, 6, 7], uuid: "1C5A746F-F97D-4149-A0CC-47E6334BF3C3", mediaID: "", mediaLabel: "Burlone", label: "Route", onSnooze: false, routeLabel: "prova3"), fix_it_mapView.Alarm(date: 2018-10-06 13:29:00 +0000, enabled: true, snoozeEnabled: false, repeatWeekdays: [1, 2, 3, 4, 5, 6, 7], uuid: "B708BC27-82AA-4AA2-A8CA-252460E48476", mediaID: "", mediaLabel: "Burlone", label: "Route", onSnooze: false, routeLabel: "prova1")]
dates for notification are: [2018-09-23 13:29:00 +0000, 2018-10-01 13:29:00 +0000, 2018-10-02 13:29:00 +0000, 2018-10-03 13:29:00 +0000, 2018-10-04 13:29:00 +0000, 2018-10-05 13:29:00 +0000, 2018-10-06 13:29:00 +0000]
2018-09-23 15:27:12.771112+0200 fix-it mapView[14162:297740] TIC Read Status [2:0x0]: 1:57
2018-09-23 15:27:12.771425+0200 fix-it mapView[14162:297740] TIC Read Status [2:0x0]: 1:57