forked from mirror/monocles_chat_clean
channel discovery screen code clean up
This commit is contained in:
parent
e0c8481d80
commit
56433c5ef8
1 changed files with 37 additions and 29 deletions
|
@ -18,6 +18,7 @@ import android.view.inputmethod.InputMethodManager;
|
|||
import android.widget.EditText;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.appcompat.app.AlertDialog;
|
||||
import androidx.appcompat.widget.Toolbar;
|
||||
import androidx.databinding.DataBindingUtil;
|
||||
|
@ -171,7 +172,7 @@ public class ChannelDiscoveryActivity extends XmppActivity implements MenuItem.O
|
|||
}
|
||||
|
||||
@Override
|
||||
public boolean onMenuItemActionExpand(MenuItem item) {
|
||||
public boolean onMenuItemActionExpand(@NonNull MenuItem item) {
|
||||
mSearchEditText.post(() -> {
|
||||
mSearchEditText.requestFocus();
|
||||
final InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
||||
|
@ -181,7 +182,7 @@ public class ChannelDiscoveryActivity extends XmppActivity implements MenuItem.O
|
|||
}
|
||||
|
||||
@Override
|
||||
public boolean onMenuItemActionCollapse(MenuItem item) {
|
||||
public boolean onMenuItemActionCollapse(@NonNull MenuItem item) {
|
||||
final InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
||||
imm.hideSoftInputFromWindow(mSearchEditText.getWindowToken(), InputMethodManager.HIDE_IMPLICIT_ONLY);
|
||||
mSearchEditText.setText("");
|
||||
|
@ -242,7 +243,7 @@ public class ChannelDiscoveryActivity extends XmppActivity implements MenuItem.O
|
|||
}
|
||||
|
||||
@Override
|
||||
public void onSaveInstanceState(Bundle savedInstanceState) {
|
||||
public void onSaveInstanceState(@NonNull Bundle savedInstanceState) {
|
||||
if (mMenuSearchView != null && mMenuSearchView.isActionViewExpanded()) {
|
||||
savedInstanceState.putString("search", mSearchEditText != null ? mSearchEditText.getText().toString() : null);
|
||||
}
|
||||
|
@ -302,40 +303,47 @@ public class ChannelDiscoveryActivity extends XmppActivity implements MenuItem.O
|
|||
}
|
||||
|
||||
@Override
|
||||
public boolean onContextItemSelected(MenuItem item) {
|
||||
public boolean onContextItemSelected(@NonNull MenuItem item) {
|
||||
final Room room = adapter.getCurrent();
|
||||
if (room != null) {
|
||||
switch (item.getItemId()) {
|
||||
case R.id.share_with:
|
||||
StartConversationActivity.shareAsChannel(this, room.address);
|
||||
return true;
|
||||
case R.id.open_join_dialog:
|
||||
final Intent intent = new Intent(this, StartConversationActivity.class);
|
||||
intent.setAction(Intent.ACTION_VIEW);
|
||||
intent.putExtra("force_dialog", true);
|
||||
intent.setData(Uri.parse(String.format("xmpp:%s?join", room.address)));
|
||||
startActivity(intent);
|
||||
return true;
|
||||
}
|
||||
if (room == null) {
|
||||
return false;
|
||||
}
|
||||
final int itemId = item.getItemId();
|
||||
if (itemId == R.id.share_with) {
|
||||
StartConversationActivity.shareAsChannel(this, room.address);
|
||||
return true;
|
||||
} else if (itemId == R.id.open_join_dialog) {
|
||||
final Intent intent = new Intent(this, StartConversationActivity.class);
|
||||
intent.setAction(Intent.ACTION_VIEW);
|
||||
intent.putExtra("force_dialog", true);
|
||||
intent.setData(Uri.parse(String.format("xmpp:%s?join", room.address)));
|
||||
startActivity(intent);
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public void joinChannelSearchResult(String selectedAccount, Room result) {
|
||||
final Jid jid = Config.DOMAIN_LOCK == null ? Jid.ofEscaped(selectedAccount) : Jid.ofLocalAndDomainEscaped(selectedAccount, Config.DOMAIN_LOCK);
|
||||
public void joinChannelSearchResult(final String selectedAccount, final Room result) {
|
||||
final Jid jid =
|
||||
Config.DOMAIN_LOCK == null
|
||||
? Jid.ofEscaped(selectedAccount)
|
||||
: Jid.ofLocalAndDomainEscaped(selectedAccount, Config.DOMAIN_LOCK);
|
||||
final boolean syncAutoJoin = getBooleanPreference("autojoin", R.bool.autojoin);
|
||||
final Account account = xmppConnectionService.findAccountByJid(jid);
|
||||
final Conversation conversation = xmppConnectionService.findOrCreateConversation(account, result.getRoom(), true, true, true);
|
||||
Bookmark bookmark = conversation.getBookmark();
|
||||
if (bookmark != null) {
|
||||
if (!bookmark.autojoin() && syncAutoJoin) {
|
||||
bookmark.setAutojoin(true);
|
||||
xmppConnectionService.createBookmark(account, bookmark);
|
||||
}
|
||||
} else {
|
||||
bookmark = new Bookmark(account, conversation.getJid().asBareJid());
|
||||
final Conversation conversation =
|
||||
xmppConnectionService.findOrCreateConversation(
|
||||
account, result.getRoom(), true, true, true);
|
||||
final var existingBookmark = conversation.getBookmark();
|
||||
if (existingBookmark == null) {
|
||||
final var bookmark = new Bookmark(account, conversation.getJid().asBareJid());
|
||||
bookmark.setAutojoin(syncAutoJoin);
|
||||
xmppConnectionService.createBookmark(account, bookmark);
|
||||
} else {
|
||||
if (!existingBookmark.autojoin() && syncAutoJoin) {
|
||||
existingBookmark.setAutojoin(true);
|
||||
xmppConnectionService.createBookmark(account, existingBookmark);
|
||||
}
|
||||
}
|
||||
switchToConversation(conversation);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue