Commit 8e5a4d1e authored by Grigory Fedorov's avatar Grigory Fedorov

Emoticons returned (as in classic Xabber). Android KitKat smiles used.

parent 4db87ab6
...@@ -35,9 +35,13 @@ import com.xabber.android.data.roster.AbstractContact; ...@@ -35,9 +35,13 @@ import com.xabber.android.data.roster.AbstractContact;
import com.xabber.android.service.XabberService; import com.xabber.android.service.XabberService;
import com.xabber.android.ui.adapter.ComparatorByName; import com.xabber.android.ui.adapter.ComparatorByName;
import com.xabber.android.ui.adapter.ComparatorByStatus; import com.xabber.android.ui.adapter.ComparatorByStatus;
import com.xabber.android.utils.Emoticons;
import com.xabber.xmpp.carbon.CarbonManager; import com.xabber.xmpp.carbon.CarbonManager;
import java.util.Collections;
import java.util.Comparator; import java.util.Comparator;
import java.util.Map;
import java.util.regex.Pattern;
/** /**
* Manage operations with common settings. * Manage operations with common settings.
...@@ -462,6 +466,17 @@ public class SettingsManager implements OnInitializedListener, ...@@ -462,6 +466,17 @@ public class SettingsManager implements OnInitializedListener,
throw new IllegalStateException(); throw new IllegalStateException();
} }
public static Map<Pattern, Integer> interfaceSmiles() {
String value = getString(R.string.interface_smiles_key, R.string.interface_smiles_default);
if (Application.getInstance().getString(R.string.interface_smiles_none_value).equals(value)) {
return Collections.unmodifiableMap(Emoticons.NONE_EMOTICONS);
} else if (Application.getInstance().getString(R.string.interface_smiles_android_value).equals(value)) {
return Collections.unmodifiableMap(Emoticons.ANDROID_EMOTICONS);
} else {
throw new IllegalStateException();
}
}
public static boolean securityCheckCertificate() { public static boolean securityCheckCertificate() {
return getBoolean(R.string.security_check_certificate_key, return getBoolean(R.string.security_check_certificate_key,
R.bool.security_check_certificate_default); R.bool.security_check_certificate_default);
......
...@@ -16,6 +16,7 @@ package com.xabber.android.ui.adapter; ...@@ -16,6 +16,7 @@ package com.xabber.android.ui.adapter;
import android.content.Context; import android.content.Context;
import android.support.v7.widget.RecyclerView; import android.support.v7.widget.RecyclerView;
import android.text.Spannable;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
...@@ -35,6 +36,7 @@ import com.xabber.android.data.message.MessageItem; ...@@ -35,6 +36,7 @@ import com.xabber.android.data.message.MessageItem;
import com.xabber.android.data.message.MessageManager; import com.xabber.android.data.message.MessageManager;
import com.xabber.android.data.roster.AbstractContact; import com.xabber.android.data.roster.AbstractContact;
import com.xabber.android.data.roster.RosterManager; import com.xabber.android.data.roster.RosterManager;
import com.xabber.android.utils.Emoticons;
import com.xabber.android.utils.StringUtils; import com.xabber.android.utils.StringUtils;
import java.util.ArrayList; import java.util.ArrayList;
...@@ -219,7 +221,9 @@ public class ChatMessageAdapter extends RecyclerView.Adapter<RecyclerView.ViewHo ...@@ -219,7 +221,9 @@ public class ChatMessageAdapter extends RecyclerView.Adapter<RecyclerView.ViewHo
message.messageText.setTextAppearance(context, appearanceStyle); message.messageText.setTextAppearance(context, appearanceStyle);
message.messageText.setText(messageItem.getSpannable()); final Spannable spannable = messageItem.getSpannable();
Emoticons.getSmiledText(context, spannable, message.messageText);
message.messageText.setText(spannable);
message.messageBalloon.getBackground().setLevel(AccountManager.getInstance().getColorLevel(account)); message.messageBalloon.getBackground().setLevel(AccountManager.getInstance().getColorLevel(account));
......
...@@ -15,8 +15,8 @@ import com.xabber.android.data.message.AbstractChat; ...@@ -15,8 +15,8 @@ import com.xabber.android.data.message.AbstractChat;
import com.xabber.android.data.message.MessageManager; import com.xabber.android.data.message.MessageManager;
import com.xabber.android.data.roster.AbstractContact; import com.xabber.android.data.roster.AbstractContact;
import com.xabber.android.ui.ContactEditor; import com.xabber.android.ui.ContactEditor;
import com.xabber.android.ui.ContactViewer;
import com.xabber.android.ui.OccupantList; import com.xabber.android.ui.OccupantList;
import com.xabber.android.utils.Emoticons;
import com.xabber.android.utils.StringUtils; import com.xabber.android.utils.StringUtils;
public class ContactItemInflater { public class ContactItemInflater {
...@@ -121,7 +121,7 @@ public class ContactItemInflater { ...@@ -121,7 +121,7 @@ public class ContactItemInflater {
viewHolder.secondLineMessage.setVisibility(View.GONE); viewHolder.secondLineMessage.setVisibility(View.GONE);
} else { } else {
viewHolder.secondLineMessage.setVisibility(View.VISIBLE); viewHolder.secondLineMessage.setVisibility(View.VISIBLE);
viewHolder.secondLineMessage.setText(statusText.trim()); viewHolder.secondLineMessage.setText(Emoticons.getSmiledText(context, statusText, viewHolder.secondLineMessage));
} }
viewHolder.statusIcon.setImageLevel(contact.getStatusMode().getStatusLevel()); viewHolder.statusIcon.setImageLevel(contact.getStatusMode().getStatusLevel());
......
/**
* Copyright (c) 2013, Redsolution LTD. All rights reserved.
*
* This file is part of Xabber project; you can redistribute it and/or
* modify it under the terms of the GNU General Public License, Version 3.
*
* Xabber is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License,
* along with this program. If not, see http://www.gnu.org/licenses/.
*/
package com.xabber.android.utils;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import android.content.Context;
import android.graphics.drawable.Drawable;
import android.text.Spannable;
import android.text.Spannable.Factory;
import android.text.style.DynamicDrawableSpan;
import android.text.style.ImageSpan;
import android.widget.TextView;
import com.xabber.android.data.SettingsManager;
import com.xabber.android.R;
/**
* Emoticons.
*
* @author alexander.ivanov
*/
public class Emoticons {
public static final Map<Pattern, Integer> ANDROID_EMOTICONS = new HashMap<>();
public static final Map<Pattern, Integer> NONE_EMOTICONS = new HashMap<>();
private static final Factory spannableFactory = Spannable.Factory
.getInstance();
static {
addPattern(ANDROID_EMOTICONS, ":)", R.drawable.emo_im_happy);
addPattern(ANDROID_EMOTICONS, ":-)", R.drawable.emo_im_happy);
addPattern(ANDROID_EMOTICONS, "=)", R.drawable.emo_im_happy);
addPattern(ANDROID_EMOTICONS, ":(", R.drawable.emo_im_sad);
addPattern(ANDROID_EMOTICONS, ":-(", R.drawable.emo_im_sad);
addPattern(ANDROID_EMOTICONS, ";)", R.drawable.emo_im_winking);
addPattern(ANDROID_EMOTICONS, ";-)", R.drawable.emo_im_winking);
addPattern(ANDROID_EMOTICONS, ":P", R.drawable.emo_im_tongue_sticking_out);
addPattern(ANDROID_EMOTICONS, ":-P", R.drawable.emo_im_tongue_sticking_out);
addPattern(ANDROID_EMOTICONS, "=-O", R.drawable.emo_im_surprised);
addPattern(ANDROID_EMOTICONS, ":*", R.drawable.emo_im_kissing);
addPattern(ANDROID_EMOTICONS, ":-*", R.drawable.emo_im_kissing);
addPattern(ANDROID_EMOTICONS, ":O", R.drawable.emo_im_wtf);
addPattern(ANDROID_EMOTICONS, ":-O", R.drawable.emo_im_wtf);
addPattern(ANDROID_EMOTICONS, "B)", R.drawable.emo_im_cool);
addPattern(ANDROID_EMOTICONS, "B-)", R.drawable.emo_im_cool);
addPattern(ANDROID_EMOTICONS, "8)", R.drawable.emo_im_cool);
addPattern(ANDROID_EMOTICONS, "8-)", R.drawable.emo_im_cool);
addPattern(ANDROID_EMOTICONS, ":-!", R.drawable.emo_im_foot_in_mouth);
addPattern(ANDROID_EMOTICONS, ":-[", R.drawable.emo_im_embarrassed);
addPattern(ANDROID_EMOTICONS, "O:)", R.drawable.emo_im_angel);
addPattern(ANDROID_EMOTICONS, "O:-)", R.drawable.emo_im_angel);
addPattern(ANDROID_EMOTICONS, ":\\", R.drawable.emo_im_undecided);
addPattern(ANDROID_EMOTICONS, ":-\\", R.drawable.emo_im_undecided);
addPattern(ANDROID_EMOTICONS, ":'(", R.drawable.emo_im_crying);
addPattern(ANDROID_EMOTICONS, ":D", R.drawable.emo_im_laughing);
addPattern(ANDROID_EMOTICONS, ":-D", R.drawable.emo_im_laughing);
addPattern(ANDROID_EMOTICONS, "O_o", R.drawable.emo_im_wtf);
addPattern(ANDROID_EMOTICONS, "o_O", R.drawable.emo_im_wtf);
addPattern(ANDROID_EMOTICONS, ">:O", R.drawable.emo_im_yelling);
addPattern(ANDROID_EMOTICONS, ">:0", R.drawable.emo_im_yelling);
addPattern(ANDROID_EMOTICONS, ":S", R.drawable.emo_im_lips_are_sealed);
addPattern(ANDROID_EMOTICONS, ":-S", R.drawable.emo_im_lips_are_sealed);
}
private static void addPattern(Map<Pattern, Integer> map, String smile, int resource) {
map.put(Pattern.compile(Pattern.quote(smile)), resource);
}
private Emoticons() {
}
/**
* @param text
* @return new spannable.
*/
public static Spannable newSpannable(CharSequence text) {
return spannableFactory.newSpannable(text);
}
/**
* @param context
* @param spannable
* @return Whether smiles have been added into <code>spannable</code>.
*/
public static boolean getSmiledText(Context context, Spannable spannable, TextView textView) {
boolean hasChanges = false;
Map<Pattern, Integer> emoticons = SettingsManager.interfaceSmiles();
for (Entry<Pattern, Integer> entry : emoticons.entrySet()) {
Matcher matcher = entry.getKey().matcher(spannable);
while (matcher.find()) {
boolean set = true;
for (ImageSpan span : spannable.getSpans(matcher.start(), matcher.end(), ImageSpan.class))
if (spannable.getSpanStart(span) >= matcher.start()
&& spannable.getSpanEnd(span) <= matcher.end()) {
spannable.removeSpan(span);
} else {
set = false;
break;
}
if (set) {
Drawable myIcon = context.getResources().getDrawable(entry.getValue());
myIcon.setBounds(0, 0, textView.getLineHeight(), textView.getLineHeight());
spannable.setSpan(new ImageSpan(myIcon, DynamicDrawableSpan.ALIGN_BOTTOM),
matcher.start(), matcher.end(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
hasChanges = true;
}
}
}
return hasChanges;
}
/**
* @param context
* @param text
* @return New spannable with added smiles if needed.
*/
public static Spannable getSmiledText(Context context, CharSequence text, TextView textView) {
Spannable spannable = spannableFactory.newSpannable(text);
getSmiledText(context, spannable, textView);
return spannable;
}
}
...@@ -26,6 +26,14 @@ ...@@ -26,6 +26,14 @@
android:title="@string/chats_hide_keyboard" android:title="@string/chats_hide_keyboard"
/> />
<ListPreference
android:title="@string/interface_smiles"
android:key="@string/interface_smiles_key"
android:entries="@array/interface_smiles_entries"
android:entryValues="@array/interface_smiles_entryvalues"
android:defaultValue="@string/interface_smiles_default"
/>
<CheckBoxPreference <CheckBoxPreference
android:defaultValue="@bool/chats_show_background_default" android:defaultValue="@bool/chats_show_background_default"
android:key="@string/chats_show_background_key" android:key="@string/chats_show_background_key"
......
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