Commit ae5211eb authored by Yusuke Iwaki's avatar Yusuke Iwaki

Revert "Won't disrupt message reading"

This reverts commit 24809ec5.
parent d4836796
...@@ -28,7 +28,6 @@ import chat.rocket.android.helper.LoadMoreScrollListener; ...@@ -28,7 +28,6 @@ import chat.rocket.android.helper.LoadMoreScrollListener;
import chat.rocket.android.helper.LogcatIfError; import chat.rocket.android.helper.LogcatIfError;
import chat.rocket.android.helper.OnBackPressListener; import chat.rocket.android.helper.OnBackPressListener;
import chat.rocket.android.helper.TextUtils; import chat.rocket.android.helper.TextUtils;
import chat.rocket.android.layouthelper.ExtRealmModelListAdapter;
import chat.rocket.android.layouthelper.chatroom.MessageFormManager; import chat.rocket.android.layouthelper.chatroom.MessageFormManager;
import chat.rocket.android.layouthelper.chatroom.MessageListAdapter; import chat.rocket.android.layouthelper.chatroom.MessageListAdapter;
import chat.rocket.android.layouthelper.chatroom.PairedMessage; import chat.rocket.android.layouthelper.chatroom.PairedMessage;
...@@ -71,17 +70,6 @@ public class RoomFragment extends AbstractChatRoomFragment ...@@ -71,17 +70,6 @@ public class RoomFragment extends AbstractChatRoomFragment
private LoadMoreScrollListener scrollListener; private LoadMoreScrollListener scrollListener;
private RealmObjectObserver<LoadMessageProcedure> procedureObserver; private RealmObjectObserver<LoadMessageProcedure> procedureObserver;
private MessageFormManager messageFormManager; private MessageFormManager messageFormManager;
private LinearLayoutManager layoutManager;
private boolean userScrolledToEnd = true;
private ExtRealmModelListAdapter.UpdateListener updateListener =
count -> {
if (userScrolledToEnd) {
scrollToEnd();
} else {
// showNewMessagesAtEndIndicator();
}
};
public RoomFragment() { public RoomFragment() {
} }
...@@ -154,10 +142,9 @@ public class RoomFragment extends AbstractChatRoomFragment ...@@ -154,10 +142,9 @@ public class RoomFragment extends AbstractChatRoomFragment
listView.setAdapter(adapter); listView.setAdapter(adapter);
adapter.setOnItemClickListener(this); adapter.setOnItemClickListener(this);
layoutManager = new LinearLayoutManager(getContext(), LinearLayoutManager layoutManager = new LinearLayoutManager(getContext(),
LinearLayoutManager.VERTICAL, true); LinearLayoutManager.VERTICAL, true);
listView.setLayoutManager(layoutManager); listView.setLayoutManager(layoutManager);
adapter.setUpdateListener(updateListener);
scrollListener = new LoadMoreScrollListener(layoutManager, 40) { scrollListener = new LoadMoreScrollListener(layoutManager, 40) {
@Override @Override
...@@ -166,13 +153,6 @@ public class RoomFragment extends AbstractChatRoomFragment ...@@ -166,13 +153,6 @@ public class RoomFragment extends AbstractChatRoomFragment
} }
}; };
listView.addOnScrollListener(scrollListener); listView.addOnScrollListener(scrollListener);
listView.addOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
super.onScrollStateChanged(recyclerView, newState);
setUserScrolledToEnd(newState);
}
});
setupSideMenu(); setupSideMenu();
setupMessageComposer(); setupMessageComposer();
...@@ -392,18 +372,4 @@ public class RoomFragment extends AbstractChatRoomFragment ...@@ -392,18 +372,4 @@ public class RoomFragment extends AbstractChatRoomFragment
protected void onExtraActionSelected(MessageExtraActionBehavior action) { protected void onExtraActionSelected(MessageExtraActionBehavior action) {
action.handleItemSelectedOnFragment(RoomFragment.this); action.handleItemSelectedOnFragment(RoomFragment.this);
} }
private void setUserScrolledToEnd(int newState) {
if (newState == RecyclerView.SCROLL_STATE_DRAGGING
|| newState == RecyclerView.SCROLL_STATE_IDLE) {
userScrolledToEnd = layoutManager.findFirstCompletelyVisibleItemPosition() == 1;
}
}
private void scrollToEnd() {
if (layoutManager == null) {
return;
}
layoutManager.scrollToPosition(0);
}
} }
...@@ -17,8 +17,6 @@ public abstract class ExtRealmModelListAdapter<T extends RealmObject, VM, ...@@ -17,8 +17,6 @@ public abstract class ExtRealmModelListAdapter<T extends RealmObject, VM,
protected static final int VIEW_TYPE_HEADER = -1; protected static final int VIEW_TYPE_HEADER = -1;
protected static final int VIEW_TYPE_FOOTER = -2; protected static final int VIEW_TYPE_FOOTER = -2;
private UpdateListener updateListener;
protected ExtRealmModelListAdapter(Context context) { protected ExtRealmModelListAdapter(Context context) {
super(context); super(context);
} }
...@@ -40,17 +38,10 @@ public abstract class ExtRealmModelListAdapter<T extends RealmObject, VM, ...@@ -40,17 +38,10 @@ public abstract class ExtRealmModelListAdapter<T extends RealmObject, VM,
notifyItemChanged(position + 1); notifyItemChanged(position + 1);
} }
public void setUpdateListener(UpdateListener updateListener) {
this.updateListener = updateListener;
}
protected ListUpdateCallback listUpdateCallback = new ListUpdateCallback() { protected ListUpdateCallback listUpdateCallback = new ListUpdateCallback() {
@Override @Override
public void onInserted(int position, int count) { public void onInserted(int position, int count) {
notifyItemRangeInserted(position + 1, count); notifyItemRangeInserted(position + 1, count);
if (updateListener != null) {
updateListener.onInserted(count);
}
} }
@Override @Override
...@@ -120,10 +111,4 @@ public abstract class ExtRealmModelListAdapter<T extends RealmObject, VM, ...@@ -120,10 +111,4 @@ public abstract class ExtRealmModelListAdapter<T extends RealmObject, VM,
public ListUpdateCallback getListUpdateCallback() { public ListUpdateCallback getListUpdateCallback() {
return listUpdateCallback; return listUpdateCallback;
} }
// We'll be using the insert event only as of now
// Let's add more events when/if needed
public interface UpdateListener {
void onInserted(int count);
}
} }
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