Commit 30d1e56a authored by Grigory Fedorov's avatar Grigory Fedorov

Notifications behavior corrected due to "show text" flag.

parent 81afb227
...@@ -59,15 +59,14 @@ public class MessageNotificationCreator { ...@@ -59,15 +59,14 @@ public class MessageNotificationCreator {
notificationBuilder.setContentText(getText(message, showText)); notificationBuilder.setContentText(getText(message, showText));
notificationBuilder.setSubText(message.getAccount()); notificationBuilder.setSubText(message.getAccount());
if (showText) { notificationBuilder.setTicker(getText(message, showText));
notificationBuilder.setTicker(message.getText());
}
notificationBuilder.setSmallIcon(getSmallIcon()); notificationBuilder.setSmallIcon(getSmallIcon());
notificationBuilder.setLargeIcon(getLargeIcon(message)); notificationBuilder.setLargeIcon(getLargeIcon(message));
notificationBuilder.setWhen(message.getTimestamp().getTime()); notificationBuilder.setWhen(message.getTimestamp().getTime());
notificationBuilder.setColor(NotificationManager.COLOR_MATERIAL_RED_500); notificationBuilder.setColor(NotificationManager.COLOR_MATERIAL_RED_500);
notificationBuilder.setStyle(getStyle(message, messageCount)); notificationBuilder.setStyle(getStyle(message, messageCount, showText));
notificationBuilder.setContentIntent(getIntent(message)); notificationBuilder.setContentIntent(getIntent(message));
...@@ -114,14 +113,14 @@ public class MessageNotificationCreator { ...@@ -114,14 +113,14 @@ public class MessageNotificationCreator {
} }
private CharSequence getText(MessageNotification message, boolean showText) { private CharSequence getText(MessageNotification message, boolean showText) {
if (!showText) {
return message.getAccount();
}
if (isFromOneContact()) { if (isFromOneContact()) {
return message.getText(); if (showText) {
return message.getText();
} else {
return null;
}
} else { } else {
return getContactNameAndMessage(message); return getContactNameAndMessage(message, showText);
} }
} }
...@@ -144,37 +143,54 @@ public class MessageNotificationCreator { ...@@ -144,37 +143,54 @@ public class MessageNotificationCreator {
return messageNotifications.size() == 1; return messageNotifications.size() == 1;
} }
private NotificationCompat.Style getStyle(MessageNotification message, int messageCount) { private NotificationCompat.Style getStyle(MessageNotification message, int messageCount, boolean showText) {
if (isFromOneContact()) { if (isFromOneContact()) {
NotificationCompat.BigTextStyle bigTextStyle = new NotificationCompat.BigTextStyle(); NotificationCompat.BigTextStyle bigTextStyle = new NotificationCompat.BigTextStyle();
bigTextStyle.setBigContentTitle(getSingleContactTitle(message, messageCount)); bigTextStyle.setBigContentTitle(getSingleContactTitle(message, messageCount));
bigTextStyle.bigText(message.getText()); if (showText) {
bigTextStyle.bigText(message.getText());
}
bigTextStyle.setSummaryText(message.getAccount()); bigTextStyle.setSummaryText(message.getAccount());
return bigTextStyle; return bigTextStyle;
} else { } else {
NotificationCompat.InboxStyle inboxStyle = new NotificationCompat.InboxStyle(); return getInboxStyle(messageCount, message.getAccount());
}
}
inboxStyle.setBigContentTitle(getMultiContactTitle(messageCount)); private NotificationCompat.Style getInboxStyle(int messageCount, String accountName) {
NotificationCompat.InboxStyle inboxStyle = new NotificationCompat.InboxStyle();
for (int i = 1; i <= messageNotifications.size(); i++) { inboxStyle.setBigContentTitle(getMultiContactTitle(messageCount));
MessageNotification messageNotification = messageNotifications.get(messageNotifications.size() - i);
inboxStyle.addLine(getContactNameAndMessage(messageNotification)); for (int i = 1; i <= messageNotifications.size(); i++) {
} MessageNotification messageNotification = messageNotifications.get(messageNotifications.size() - i);
inboxStyle.setSummaryText(message.getAccount()); boolean showTextForThisContact
= ChatManager.getInstance().isShowText(messageNotification.getAccount(), messageNotification.getUser());
return inboxStyle; inboxStyle.addLine(getContactNameAndMessage(messageNotification, showTextForThisContact));
} }
inboxStyle.setSummaryText(accountName);
return inboxStyle;
} }
private Spannable getContactNameAndMessage(MessageNotification messageNotification) { private Spannable getContactNameAndMessage(MessageNotification messageNotification, boolean showText) {
String userName = getContactName(messageNotification); String userName = getContactName(messageNotification);
String contactAndMessage = application.getString(
R.string.chat_contact_and_message, userName, messageNotification.getText()); Spannable spannableString;
Spannable spannableString = new SpannableString(contactAndMessage); if (showText) {
String contactAndMessage = application.getString(
R.string.chat_contact_and_message, userName, messageNotification.getText());
spannableString = new SpannableString(contactAndMessage);
} else {
spannableString = new SpannableString(userName);
}
spannableString.setSpan(new StyleSpan(android.graphics.Typeface.BOLD), 0, userName.length(), spannableString.setSpan(new StyleSpan(android.graphics.Typeface.BOLD), 0, userName.length(),
Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
return spannableString; return spannableString;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment