aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/thedevstack/conversationsplus/ui/listeners/ConversationSwipeRefreshListener.java
blob: 6dc9f4a4165c515b94e672c02990d914f06855d5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
package de.thedevstack.conversationsplus.ui.listeners;

import android.widget.ListView;

import com.orangegangsters.github.swipyrefreshlayout.library.SwipyRefreshLayout;
import com.orangegangsters.github.swipyrefreshlayout.library.SwipyRefreshLayoutDirection;

import java.util.List;

import de.thedevstack.android.logcat.Logging;
import de.thedevstack.conversationsplus.Config;
import de.thedevstack.conversationsplus.R;
import de.thedevstack.conversationsplus.entities.Account;
import de.thedevstack.conversationsplus.entities.Conversation;
import de.thedevstack.conversationsplus.entities.Message;
import de.thedevstack.conversationsplus.services.MessageArchiveService;
import de.thedevstack.conversationsplus.ui.ConversationActivity;
import de.thedevstack.conversationsplus.ui.ConversationFragment;
import de.thedevstack.conversationsplus.ui.adapter.MessageAdapter;

/**
 * This listener starts loading messages from the server.
 */
public class ConversationSwipeRefreshListener implements SwipyRefreshLayout.OnRefreshListener {
    private List<Message> messageList;
    private ConversationFragment fragment;
    private ConversationMoreMessagesLoadedListener listener;
    private SwipyRefreshLayout swipeLayout;

    public ConversationSwipeRefreshListener(List<Message> messageList, SwipyRefreshLayout swipeLayout, ConversationFragment fragment, ListView messagesView, MessageAdapter messageListAdapter) {
        this.messageList = messageList;
        this.fragment = fragment;
        this.swipeLayout = swipeLayout;
        this.listener = new ConversationMoreMessagesLoadedListener(swipeLayout, messageList, fragment, messagesView, messageListAdapter);
    }

    @Override
    public void onRefresh(SwipyRefreshLayoutDirection direction) {
        Logging.d(Config.LOGTAG, "Refresh swipe container");
        Logging.d(Config.LOGTAG, "Refresh direction " + direction);
        final ConversationActivity activity = (ConversationActivity) fragment.getActivity();
        if (activity.getSelectedConversation().getAccount().getStatus() != Account.State.DISABLED) {
            synchronized (this.messageList) {
                long timestamp;
                if (SwipyRefreshLayoutDirection.TOP == direction) { // Load history -> messages sent/received before first message in database
                    if (messageList.isEmpty()) {
                        timestamp = System.currentTimeMillis();
                    } else {
                        timestamp = this.messageList.get(0).getTimeSent(); // works only because of the ordering (last msg = first msg in list)
                    }
                    this.listener.setLoadHistory(true);
                    activity.xmppConnectionService.loadMoreMessages(activity.getSelectedConversation(), timestamp, this.listener);
                } else if (SwipyRefreshLayoutDirection.BOTTOM == direction) { // load messages sent/received between last received or last session establishment and now
                    if (activity.getSelectedConversation().getAccount().isOnlineAndConnected()) {
                        Logging.d("mam", "loading missing messages from mam (last session establishing or last received message)");
                        long lastSessionEstablished = this.getTimestampOfLastSessionEstablished(activity.getSelectedConversation());
                        long lastReceivedMessage = this.getTimestampOfLastReceivedOrTransmittedMessage();
                        long startTimestamp = Math.min(lastSessionEstablished, lastReceivedMessage);
                        MessageArchiveService.Query query = activity.xmppConnectionService.getMessageArchiveService().query(activity.getSelectedConversation(), startTimestamp, System.currentTimeMillis(), this.listener);
                        if (query != null) {
                            this.listener.setLoadHistory(false);
                        } else {
                            Logging.d("mam", "no query built - no messages loaded");
                            this.listener.onMoreMessagesLoaded(0, activity.getSelectedConversation());
                            this.listener.informUser(R.string.no_more_history_on_server);
                        }
                        this.listener.informUser(R.string.fetching_history_from_server);
                    } else {
                        this.listener.informUser(R.string.not_connected_try_again);
                        swipeLayout.setRefreshing(false);
                    }
                }
            }
        } else {
            this.listener.informUser(R.string.this_account_is_disabled);
            swipeLayout.setRefreshing(false);
        }
        Logging.d(Config.LOGTAG, "End Refresh swipe container");
    }

    private long getTimestampOfLastReceivedOrTransmittedMessage() {
        long lastReceivedOrTransmittedMessage = Long.MAX_VALUE;
        if (null != this.messageList
                && !this.messageList.isEmpty()) {
            int lastMessageIndex = this.messageList.size() - 1;
            if (0 <= lastMessageIndex && this.messageList.size() > lastMessageIndex) {
                lastReceivedOrTransmittedMessage = this.messageList.get(lastMessageIndex).getTimeSent();
            }
        }

        return lastReceivedOrTransmittedMessage;
    }

    private long getTimestampOfLastSessionEstablished(Conversation conversation) {
        long lastSessionEstablished = Long.MAX_VALUE;
        if (null != conversation
                && null != conversation.getAccount()
                && null != conversation.getAccount().getXmppConnection()) {
            lastSessionEstablished = conversation.getAccount().getXmppConnection().getLastSessionEstablished();
        }
        return lastSessionEstablished;
    }
}