|
|
@ -329,7 +329,6 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|
|
|
protected HidingLinearLayout quickAttachmentToggle;
|
|
|
|
protected HidingLinearLayout quickAttachmentToggle;
|
|
|
|
protected HidingLinearLayout inlineAttachmentToggle;
|
|
|
|
protected HidingLinearLayout inlineAttachmentToggle;
|
|
|
|
private InputPanel inputPanel;
|
|
|
|
private InputPanel inputPanel;
|
|
|
|
private boolean alwaysEnableInputPanel = false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private LinkPreviewViewModel linkPreviewViewModel;
|
|
|
|
private LinkPreviewViewModel linkPreviewViewModel;
|
|
|
|
private ConversationSearchViewModel searchViewModel;
|
|
|
|
private ConversationSearchViewModel searchViewModel;
|
|
|
@ -354,6 +353,8 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|
|
|
private ArrayList<Mention> mentions = new ArrayList<>();
|
|
|
|
private ArrayList<Mention> mentions = new ArrayList<>();
|
|
|
|
private String oldText = "";
|
|
|
|
private String oldText = "";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Multi Device
|
|
|
|
|
|
|
|
private boolean isFriendsWithAnyDevice = false;
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
protected void onPreCreate() {
|
|
|
|
protected void onPreCreate() {
|
|
|
@ -2204,13 +2205,12 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|
|
|
|
|
|
|
|
|
|
|
private void updateInputPanel() {
|
|
|
|
private void updateInputPanel() {
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
alwaysEnableInputPanel caches whether we have enabled the input once.
|
|
|
|
isFriendsWithAnyDevice caches whether we are friends with any of the other users device.
|
|
|
|
|
|
|
|
|
|
|
|
This stops the case where the input panel disables and enables rapidly.
|
|
|
|
This stops the case where the input panel disables and enables rapidly.
|
|
|
|
- This can occur when we are not friends with the current thread BUT multi-device tells us that we are friends with another one of their devices.
|
|
|
|
- This can occur when we are not friends with the current thread BUT multi-device tells us that we are friends with another one of their devices.
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (recipient.isGroupRecipient() || isNoteToSelf() || isFriendsWithAnyDevice) {
|
|
|
|
if (recipient.isGroupRecipient() || isNoteToSelf() || alwaysEnableInputPanel) {
|
|
|
|
|
|
|
|
setInputPanelEnabled(true);
|
|
|
|
setInputPanelEnabled(true);
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -2220,13 +2220,23 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|
|
|
boolean isPending = friendRequestStatus == LokiThreadFriendRequestStatus.REQUEST_SENDING || friendRequestStatus == LokiThreadFriendRequestStatus.REQUEST_SENT || friendRequestStatus == LokiThreadFriendRequestStatus.REQUEST_RECEIVED;
|
|
|
|
boolean isPending = friendRequestStatus == LokiThreadFriendRequestStatus.REQUEST_SENDING || friendRequestStatus == LokiThreadFriendRequestStatus.REQUEST_SENT || friendRequestStatus == LokiThreadFriendRequestStatus.REQUEST_RECEIVED;
|
|
|
|
setInputPanelEnabled(!isPending);
|
|
|
|
setInputPanelEnabled(!isPending);
|
|
|
|
|
|
|
|
|
|
|
|
alwaysEnableInputPanel = friendRequestStatus == LokiThreadFriendRequestStatus.FRIENDS;
|
|
|
|
// We should always have the input panel enabled if we are friends with the current user
|
|
|
|
|
|
|
|
isFriendsWithAnyDevice = friendRequestStatus == LokiThreadFriendRequestStatus.FRIENDS;
|
|
|
|
|
|
|
|
|
|
|
|
// This promise correctly updates the UI for multidevice
|
|
|
|
// Multi-device input logic
|
|
|
|
if (friendRequestStatus != LokiThreadFriendRequestStatus.FRIENDS) {
|
|
|
|
if (!isFriendsWithAnyDevice) {
|
|
|
|
MultiDeviceUtilities.shouldEnableUserInput(this, recipient).success(shouldEnableInput -> {
|
|
|
|
// We should enable the input if we don't have any pending friend requests OR we are friends with a linked device
|
|
|
|
alwaysEnableInputPanel = shouldEnableInput;
|
|
|
|
MultiDeviceUtilities.hasPendingFriendRequestWithAnyLinkedDevice(this, recipient).success(hasPendingRequests -> {
|
|
|
|
setInputPanelEnabled(shouldEnableInput);
|
|
|
|
if (!hasPendingRequests) {
|
|
|
|
|
|
|
|
setInputPanelEnabled(true);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
MultiDeviceUtilities.isFriendsWithAnyLinkedDevice(this, recipient).success(isFriends -> {
|
|
|
|
|
|
|
|
// If we are friend with any of the other devices then we want to make sure the input panel is always enabled for the duration of this conversation
|
|
|
|
|
|
|
|
isFriendsWithAnyDevice = isFriends;
|
|
|
|
|
|
|
|
setInputPanelEnabled(isFriends);
|
|
|
|
|
|
|
|
return Unit.INSTANCE;
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
return Unit.INSTANCE;
|
|
|
|
return Unit.INSTANCE;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -2447,9 +2457,8 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void updateToggleButtonState() {
|
|
|
|
private void updateToggleButtonState() {
|
|
|
|
// Don't allow attachments if we're not friends
|
|
|
|
// Don't allow attachments if we're not friends with any device
|
|
|
|
LokiThreadFriendRequestStatus friendRequestStatus = DatabaseFactory.getLokiThreadDatabase(this).getFriendRequestStatus(threadId);
|
|
|
|
if (!isNoteToSelf() && !recipient.isGroupRecipient() && !isFriendsWithAnyDevice) {
|
|
|
|
if (!isNoteToSelf() && !recipient.isGroupRecipient() && friendRequestStatus != LokiThreadFriendRequestStatus.FRIENDS) {
|
|
|
|
|
|
|
|
buttonToggle.display(sendButton);
|
|
|
|
buttonToggle.display(sendButton);
|
|
|
|
quickAttachmentToggle.hide();
|
|
|
|
quickAttachmentToggle.hide();
|
|
|
|
inlineAttachmentToggle.hide();
|
|
|
|
inlineAttachmentToggle.hide();
|
|
|
|