From 4660ced9b882b5cd26cd1ea6b51316650f465f31 Mon Sep 17 00:00:00 2001 From: Arjan Schrijver Date: Fri, 30 Aug 2024 21:47:51 +0200 Subject: [PATCH] Moyoung: Improve notifications --- .../devices/moyoung/MoyoungDeviceSupport.java | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/moyoung/MoyoungDeviceSupport.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/moyoung/MoyoungDeviceSupport.java index 7fcf3101c..975015852 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/moyoung/MoyoungDeviceSupport.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/moyoung/MoyoungDeviceSupport.java @@ -513,16 +513,21 @@ public class MoyoungDeviceSupport extends AbstractBTLEDeviceSupport { @Override public void onNotification(NotificationSpec notificationSpec) { - String sender = StringUtils.getFirstOf(notificationSpec.sender, StringUtils.getFirstOf(notificationSpec.sourceName, notificationSpec.sourceAppId)); - if (sender.isEmpty()) - sender = "(unknown)"; + final String senderOrTitle = StringUtils.getFirstOf(notificationSpec.sender, notificationSpec.title); - String text = NotificationUtils.getPreferredTextFor(notificationSpec, 0, 75, getContext()); - if (text.isEmpty()) - text = StringUtils.getFirstOf(StringUtils.getFirstOf(notificationSpec.title, notificationSpec.subject), notificationSpec.body); + String message = StringUtils.truncate(senderOrTitle, 32) + ":"; + if (notificationSpec.subject != null) { + message += StringUtils.truncate(notificationSpec.subject, 128) + "\n\n"; + } + if (notificationSpec.body != null) { + message += StringUtils.truncate(notificationSpec.body, 512); + } + if (notificationSpec.body == null && notificationSpec.subject == null) { + message += " "; + } // The notification is split at first : into sender and text - sendNotification(MoyoungConstants.notificationType(notificationSpec.type), sender + ":" + text); + sendNotification(MoyoungConstants.notificationType(notificationSpec.type), message); } @Override