From 2e908783ff422fb1afb8c252955dbd7f23f9bdd8 Mon Sep 17 00:00:00 2001 From: Catfriend1 Date: Sun, 27 May 2018 20:58:02 +0200 Subject: [PATCH] Cleanup code duplications in FirstStartActivity (ref #622) --- .../activities/FirstStartActivity.java | 32 +++++++++++-------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/app/src/main/java/com/nutomic/syncthingandroid/activities/FirstStartActivity.java b/app/src/main/java/com/nutomic/syncthingandroid/activities/FirstStartActivity.java index 177ecf5c..d9f42f4e 100644 --- a/app/src/main/java/com/nutomic/syncthingandroid/activities/FirstStartActivity.java +++ b/app/src/main/java/com/nutomic/syncthingandroid/activities/FirstStartActivity.java @@ -9,6 +9,7 @@ import android.os.Bundle; import android.support.annotation.NonNull; import android.support.v4.app.ActivityCompat; import android.support.v4.content.ContextCompat; +import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.Toast; @@ -21,6 +22,7 @@ import javax.inject.Inject; public class FirstStartActivity extends Activity implements Button.OnClickListener { + private static String TAG = "FirstStartActivity"; private static final int REQUEST_WRITE_STORAGE = 142; @Inject SharedPreferences mPreferences; @@ -32,18 +34,13 @@ public class FirstStartActivity extends Activity implements Button.OnClickListen protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); ((SyncthingApp) getApplication()).component().inject(this); - startService(new Intent(this, SyncthingService.class)); if (!isFirstStart()) { - if (haveStoragePermission()) { - startApp(); - return; - } - else { - requestStoragePermission(); - } + startApp(); + return; } + // Show first start UI. setContentView(R.layout.activity_first_start); Button cont = findViewById(R.id.cont); cont.setOnClickListener(this); @@ -54,11 +51,23 @@ public class FirstStartActivity extends Activity implements Button.OnClickListen } private void startApp() { + if (!haveStoragePermission()) { + requestStoragePermission(); + /** + * startApp will be called in {@link #onRequestPermissionsResult()} + * after permission was granted. + */ + return; + } + boolean isFirstStart = isFirstStart(); if (isFirstStart) { + Log.v(TAG, "User completed first start UI."); mPreferences.edit().putBoolean("first_start", false).apply(); } + startService(new Intent(this, SyncthingService.class)); + // In case start_into_web_gui option is enabled, start both activities so that back // navigation works as expected. Intent mainIntent = new Intent(this, MainActivity.class); @@ -86,12 +95,7 @@ public class FirstStartActivity extends Activity implements Button.OnClickListen @Override public void onClick(View v) { - if (!haveStoragePermission()) { - requestStoragePermission(); - } - else { - startApp(); - } + startApp(); } @Override