Commit 052de30a authored by Grigory Fedorov's avatar Grigory Fedorov

Chat selection mechanism refactored and reviewed. Special intent action for...

Chat selection mechanism refactored and reviewed. Special intent action for recent chats. Also recent chats selected flag stored.
parent f78cf5f0
...@@ -493,10 +493,8 @@ public class NotificationManager implements OnInitializedListener, OnAccountChan ...@@ -493,10 +493,8 @@ public class NotificationManager implements OnInitializedListener, OnAccountChan
return messageNotification.getCount(); return messageNotification.getCount();
} }
public void removeMessageNotification(final String account, public void removeMessageNotification(final String account, final String user) {
final String user) { MessageNotification messageNotification = getMessageNotification(account, user);
MessageNotification messageNotification = getMessageNotification(
account, user);
if (messageNotification == null) if (messageNotification == null)
return; return;
messageNotifications.remove(messageNotification); messageNotifications.remove(messageNotification);
......
...@@ -18,6 +18,7 @@ import android.app.Activity; ...@@ -18,6 +18,7 @@ import android.app.Activity;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.os.Bundle; import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager;
import android.view.View; import android.view.View;
import android.view.WindowManager; import android.view.WindowManager;
...@@ -65,6 +66,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -65,6 +66,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
private static final String SAVED_ACCOUNT = "com.xabber.android.ui.ChatViewer.SAVED_ACCOUNT"; private static final String SAVED_ACCOUNT = "com.xabber.android.ui.ChatViewer.SAVED_ACCOUNT";
private static final String SAVED_USER = "com.xabber.android.ui.ChatViewer.SAVED_USER"; private static final String SAVED_USER = "com.xabber.android.ui.ChatViewer.SAVED_USER";
private static final String SAVED_EXIT_ON_SEND = "com.xabber.android.ui.ChatViewer.EXIT_ON_SEND"; private static final String SAVED_EXIT_ON_SEND = "com.xabber.android.ui.ChatViewer.EXIT_ON_SEND";
private static final String SAVED_IS_RECENT_CHATS_SELECTED = "com.xabber.android.ui.ChatViewer.SAVED_IS_RECENT_CHATS_SELECTED";
private boolean exitOnSend; private boolean exitOnSend;
...@@ -78,12 +80,12 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -78,12 +80,12 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
Collection<ChatViewerFragment> registeredChats = new HashSet<>(); Collection<ChatViewerFragment> registeredChats = new HashSet<>();
Collection<RecentChatFragment> recentChatFragments = new HashSet<>(); Collection<RecentChatFragment> recentChatFragments = new HashSet<>();
private String actionWithAccount = null; private String account = null;
private String actionWithUser = null; private String user = null;
private StatusBarPainter statusBarPainter; private StatusBarPainter statusBarPainter;
private boolean isChatSelected; private boolean isRecentChatsSelected;
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
...@@ -93,21 +95,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -93,21 +95,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
return; return;
} }
Intent intent = getIntent(); getSelectedPageDataFromIntent();
String account = getAccount(intent);
String user = getUser(intent);
if (hasAttention(intent)) {
AttentionManager.getInstance().removeAccountNotifications(account, user);
}
if (savedInstanceState != null) {
if (account == null || user == null) {
account = savedInstanceState.getString(SAVED_ACCOUNT);
user = savedInstanceState.getString(SAVED_USER);
}
exitOnSend = savedInstanceState.getBoolean(SAVED_EXIT_ON_SEND);
}
setContentView(R.layout.activity_chat_viewer); setContentView(R.layout.activity_chat_viewer);
...@@ -115,12 +103,10 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -115,12 +103,10 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN); getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);
if (account != null && user != null) { if (isRecentChatsSelected) {
chatViewerAdapter = new ChatViewerAdapter(getFragmentManager(), account, user, this);
isChatSelected = true;
} else {
chatViewerAdapter = new ChatViewerAdapter(getFragmentManager(), this); chatViewerAdapter = new ChatViewerAdapter(getFragmentManager(), this);
isChatSelected = false; } else {
chatViewerAdapter = new ChatViewerAdapter(getFragmentManager(), account, user, this);
} }
chatScrollIndicatorAdapter = new ChatScrollIndicatorAdapter(this, chatScrollIndicatorAdapter = new ChatScrollIndicatorAdapter(this,
...@@ -131,27 +117,40 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -131,27 +117,40 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
viewPager.setAdapter(chatViewerAdapter); viewPager.setAdapter(chatViewerAdapter);
viewPager.setOnPageChangeListener(this); viewPager.setOnPageChangeListener(this);
viewPager.getBackground().setAlpha(30); viewPager.getBackground().setAlpha(30);
}
selectPage(account, user, false); private void getSelectedPageDataFromIntent() {
Intent intent = getIntent();
if (intent.getAction() != null && intent.getAction().equals(ACTION_RECENT_CHATS)) {
isRecentChatsSelected = true;
account = null;
user = null;
} else {
isRecentChatsSelected = false;
account = getAccount(intent);
user = getUser(intent);
}
} }
@Override @Override
protected void onNewIntent(Intent intent) { protected void onNewIntent(Intent intent) {
super.onNewIntent(intent); super.onNewIntent(intent);
if (isFinishing()) if (isFinishing()) {
return; return;
}
chatViewerAdapter.updateChats(); setIntent(intent);
; getSelectedPageDataFromIntent();
chatScrollIndicatorAdapter.update(chatViewerAdapter.getActiveChats()); }
String account = getAccount(intent); @Override
String user = getUser(intent); protected void onRestoreInstanceState(@NonNull Bundle savedInstanceState) {
if (account == null || user == null) { super.onRestoreInstanceState(savedInstanceState);
return;
}
selectPage(account, user, false); account = savedInstanceState.getString(SAVED_ACCOUNT);
user = savedInstanceState.getString(SAVED_USER);
exitOnSend = savedInstanceState.getBoolean(SAVED_EXIT_ON_SEND);
isRecentChatsSelected = savedInstanceState.getBoolean(SAVED_IS_RECENT_CHATS_SELECTED);
} }
@Override @Override
...@@ -161,7 +160,16 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -161,7 +160,16 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
Application.getInstance().addUIListener(OnContactChangedListener.class, this); Application.getInstance().addUIListener(OnContactChangedListener.class, this);
Application.getInstance().addUIListener(OnAccountChangedListener.class, this); Application.getInstance().addUIListener(OnAccountChangedListener.class, this);
chatViewerAdapter.updateChats();
chatScrollIndicatorAdapter.update(chatViewerAdapter.getActiveChats());
selectPage();
Intent intent = getIntent(); Intent intent = getIntent();
if (hasAttention(intent)) {
AttentionManager.getInstance().removeAccountNotifications(account, user);
}
if (Intent.ACTION_SEND.equals(intent.getAction())) { if (Intent.ACTION_SEND.equals(intent.getAction())) {
extraText = intent.getStringExtra(Intent.EXTRA_TEXT); extraText = intent.getStringExtra(Intent.EXTRA_TEXT);
...@@ -170,18 +178,23 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -170,18 +178,23 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
exitOnSend = true; exitOnSend = true;
} }
} }
}
if (actionWithAccount != null && actionWithUser != null) { private void selectPage() {
updateActionBar(actionWithAccount); if (isRecentChatsSelected) {
selectRecentChatsPage();
} else {
selectChatPage(account, user, false);
} }
} }
@Override @Override
protected void onSaveInstanceState(Bundle outState) { protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState); super.onSaveInstanceState(outState);
outState.putString(SAVED_ACCOUNT, actionWithAccount); outState.putString(SAVED_ACCOUNT, account);
outState.putString(SAVED_USER, actionWithUser); outState.putString(SAVED_USER, user);
outState.putBoolean(SAVED_EXIT_ON_SEND, exitOnSend); outState.putBoolean(SAVED_EXIT_ON_SEND, exitOnSend);
outState.putBoolean(SAVED_IS_RECENT_CHATS_SELECTED, isRecentChatsSelected);
} }
@Override @Override
...@@ -193,9 +206,12 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -193,9 +206,12 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
MessageManager.getInstance().removeVisibleChat(); MessageManager.getInstance().removeVisibleChat();
} }
private void selectPage(String account, String user, boolean smoothScroll) { private void selectChatPage(String account, String user, boolean smothScroll) {
int position = chatViewerAdapter.getPageNumber(account, user); selectPage(chatViewerAdapter.getPageNumber(account, user), smothScroll);
selectPage(position, smoothScroll); }
private void selectRecentChatsPage() {
selectPage(chatViewerAdapter.getPageNumber(null, null), false);
} }
private void selectPage(int position, boolean smoothScroll) { private void selectPage(int position, boolean smoothScroll) {
...@@ -205,54 +221,34 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -205,54 +221,34 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
@Override @Override
public void onChatChanged(final String account, final String user, final boolean incoming) { public void onChatChanged(final String account, final String user, final boolean incoming) {
String currentAccount = null;
String currentUser = null;
AbstractChat chatByPageNumber = chatViewerAdapter.getChatByPageNumber(viewPager.getCurrentItem());
if (chatByPageNumber != null) {
currentAccount = chatByPageNumber.getAccount();
currentUser = chatByPageNumber.getUser();
}
if (chatViewerAdapter.updateChats()) { if (chatViewerAdapter.updateChats()) {
selectPage(currentAccount, currentUser, false); selectPage();
chatScrollIndicatorAdapter.update(chatViewerAdapter.getActiveChats()); chatScrollIndicatorAdapter.update(chatViewerAdapter.getActiveChats());
} else { } else {
updateRegisteredChats(); updateRegisteredChats();
updateRegisteredRecentChatsFragments(); updateRegisteredRecentChatsFragments();
updateStatusBar();
for (ChatViewerFragment chat : registeredChats) { for (ChatViewerFragment chat : registeredChats) {
if (chat.isEqual(account, user)) { if (chat.isEqual(account, user) && incoming) {
chat.playIncomingAnimation(); chat.playIncomingAnimation();
} }
} }
} }
if (actionWithAccount != null && actionWithAccount.equals(account)
&& actionWithUser != null && actionWithUser.equals(user)) {
updateActionBar(account);
}
} }
@Override @Override
public void onContactsChanged(Collection<BaseEntity> entities) { public void onContactsChanged(Collection<BaseEntity> entities) {
updateRegisteredChats(); updateRegisteredChats();
updateRegisteredRecentChatsFragments(); updateRegisteredRecentChatsFragments();
updateStatusBar();
if (actionWithAccount != null && actionWithUser != null) {
updateActionBar(actionWithAccount);
}
} }
@Override @Override
public void onAccountsChanged(Collection<String> accounts) { public void onAccountsChanged(Collection<String> accounts) {
updateRegisteredChats(); updateRegisteredChats();
updateRegisteredRecentChatsFragments(); updateRegisteredRecentChatsFragments();
updateStatusBar();
if (actionWithAccount != null && actionWithUser != null) {
updateActionBar(actionWithAccount);
}
} }
@Override @Override
...@@ -263,38 +259,37 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -263,38 +259,37 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
@Override @Override
public void onPageSelected(int position) { public void onPageSelected(int position) {
hideKeyboard(this); hideKeyboard(this);
AbstractChat selectedChat = chatViewerAdapter.getChatByPageNumber(position);
chatScrollIndicatorAdapter.select(chatViewerAdapter.getRealPagePosition(position)); chatScrollIndicatorAdapter.select(chatViewerAdapter.getRealPagePosition(position));
isChatSelected = selectedChat != null; AbstractChat selectedChat = chatViewerAdapter.getChatByPageNumber(position);
if (isChatSelected) { isRecentChatsSelected = selectedChat == null;
actionWithAccount = selectedChat.getAccount();
actionWithUser = selectedChat.getUser();
} else {
actionWithAccount = null;
actionWithUser = null;
}
if (!isChatSelected) { if (isRecentChatsSelected) {
statusBarPainter.restore(); account = null;
user = null;
MessageManager.getInstance().removeVisibleChat(); MessageManager.getInstance().removeVisibleChat();
return; } else {
} account = selectedChat.getAccount();
user = selectedChat.getUser();
updateActionBar(actionWithAccount); MessageManager.getInstance().setVisibleChat(account, user);
MessageManager.getInstance().setVisibleChat(actionWithAccount, actionWithUser); MessageArchiveManager.getInstance().requestHistory(account, user, 0,
MessageManager.getInstance().getChat(account, user).getRequiredMessageCount());
MessageArchiveManager.getInstance().requestHistory( actionWithAccount, actionWithUser, 0, NotificationManager.getInstance().removeMessageNotification(account, user);
MessageManager.getInstance().getChat(actionWithAccount, actionWithUser).getRequiredMessageCount()); }
NotificationManager.getInstance().removeMessageNotification(actionWithAccount, actionWithUser); updateStatusBar();
} }
private void updateActionBar(String account) { private void updateStatusBar() {
statusBarPainter.updateWithAccountName(account); if (isRecentChatsSelected) {
statusBarPainter.restore();
} else {
statusBarPainter.updateWithAccountName(account);
}
} }
private void updateRegisteredChats() { private void updateRegisteredChats() {
...@@ -337,7 +332,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -337,7 +332,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
boolean isExtraTextInserted = false; boolean isExtraTextInserted = false;
for (ChatViewerFragment chat : registeredChats) { for (ChatViewerFragment chat : registeredChats) {
if (chat.isEqual(actionWithAccount, actionWithUser)) { if (chat.isEqual(account, user)) {
chat.setInputText(extraText); chat.setInputText(extraText);
isExtraTextInserted = true; isExtraTextInserted = true;
} }
...@@ -350,7 +345,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -350,7 +345,7 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
@Override @Override
public void onChatSelected(AbstractChat chat) { public void onChatSelected(AbstractChat chat) {
selectPage(chat.getAccount(), chat.getUser(), true); selectChatPage(chat.getAccount(), chat.getUser(), true);
} }
public ChatViewerAdapter getChatViewerAdapter() { public ChatViewerAdapter getChatViewerAdapter() {
return chatViewerAdapter; return chatViewerAdapter;
...@@ -424,7 +419,9 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener ...@@ -424,7 +419,9 @@ public class ChatViewer extends ManagedActivity implements OnChatChangedListener
} }
public static Intent createRecentChatsIntent(Context context) { public static Intent createRecentChatsIntent(Context context) {
return new EntityIntentBuilder(context, ChatViewer.class).build(); Intent intent = new EntityIntentBuilder(context, ChatViewer.class).build();
intent.setAction(ACTION_RECENT_CHATS);
return intent;
} }
public static Intent createClearTopIntent(Context context, String account, String user) { public static Intent createClearTopIntent(Context context, String account, String user) {
......
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