aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/pixart/messenger/ui/EnterNameActivity.java
diff options
context:
space:
mode:
authorChristian Schneppe <christian@pix-art.de>2019-03-31 11:06:09 +0200
committerChristian Schneppe <christian@pix-art.de>2019-03-31 11:06:09 +0200
commit721bbf47774f452ec8a87a56f1042b555022efba (patch)
treef91980cce03bd61bd51c209d5119a82e163de64a /src/main/java/de/pixart/messenger/ui/EnterNameActivity.java
parentbde39e88511ca1ffd542ab587ab507382b8c77ae (diff)
add activity to define some important privacy settings on first start
Diffstat (limited to '')
-rw-r--r--src/main/java/de/pixart/messenger/ui/EnterNameActivity.java34
1 files changed, 27 insertions, 7 deletions
diff --git a/src/main/java/de/pixart/messenger/ui/EnterNameActivity.java b/src/main/java/de/pixart/messenger/ui/EnterNameActivity.java
index 1f59901a6..ccfd88dad 100644
--- a/src/main/java/de/pixart/messenger/ui/EnterNameActivity.java
+++ b/src/main/java/de/pixart/messenger/ui/EnterNameActivity.java
@@ -13,13 +13,12 @@ import de.pixart.messenger.databinding.ActivityEnterNameBinding;
import de.pixart.messenger.entities.Account;
import de.pixart.messenger.services.XmppConnectionService;
import de.pixart.messenger.utils.AccountUtils;
+import de.pixart.messenger.utils.FirstStartManager;
public class EnterNameActivity extends XmppActivity implements XmppConnectionService.OnAccountUpdate {
private ActivityEnterNameBinding binding;
-
private Account account;
-
private AtomicBoolean setNick = new AtomicBoolean(false);
@Override
@@ -28,19 +27,38 @@ public class EnterNameActivity extends XmppActivity implements XmppConnectionSer
this.binding = DataBindingUtil.setContentView(this, R.layout.activity_enter_name);
setSupportActionBar((Toolbar) this.binding.toolbar);
this.binding.next.setOnClickListener(this::next);
+ updateNextButton();
this.setNick.set(savedInstanceState != null && savedInstanceState.getBoolean("set_nick", false));
}
+ private void updateNextButton() {
+ if (account != null && (account.getStatus() == Account.State.CONNECTING || account.getStatus() == Account.State.REGISTRATION_SUCCESSFUL)) {
+ this.binding.next.setEnabled(false);
+ this.binding.next.setText(R.string.account_status_connecting);
+ } else if (account != null && (account.getStatus() == Account.State.ONLINE)) {
+ this.binding.next.setEnabled(true);
+ this.binding.next.setText(R.string.next);
+ }
+ }
+
private void next(View view) {
+ FirstStartManager firstStartManager = new FirstStartManager(this);
if (account != null) {
String name = this.binding.name.getText().toString().trim();
account.setDisplayName(name);
xmppConnectionService.publishDisplayName(account);
- Intent intent = new Intent(this, PublishProfilePictureActivity.class);
- intent.putExtra(PublishProfilePictureActivity.EXTRA_ACCOUNT, account.getJid().asBareJid().toEscapedString());
- intent.putExtra("setup", true);
- startActivity(intent);
- overridePendingTransition(R.animator.fade_in, R.animator.fade_out);
+ if (firstStartManager.isFirstTimeLaunch()) {
+ Intent intent = new Intent(this, SetSettingsActivity.class);
+ intent.putExtra("setup", true);
+ startActivity(intent);
+ overridePendingTransition(R.animator.fade_in, R.animator.fade_out);
+ } else {
+ Intent intent = new Intent(this, PublishProfilePictureActivity.class);
+ intent.putExtra(PublishProfilePictureActivity.EXTRA_ACCOUNT, account.getJid().asBareJid().toEscapedString());
+ intent.putExtra("setup", true);
+ startActivity(intent);
+ overridePendingTransition(R.animator.fade_in, R.animator.fade_out);
+ }
}
finish();
}
@@ -54,12 +72,14 @@ public class EnterNameActivity extends XmppActivity implements XmppConnectionSer
@Override
protected void refreshUiReal() {
checkSuggestPreviousNick();
+ updateNextButton();
}
@Override
void onBackendConnected() {
this.account = AccountUtils.getFirst(xmppConnectionService);
checkSuggestPreviousNick();
+ updateNextButton();
}
private void checkSuggestPreviousNick() {