mirror of
				https://github.com/commons-app/apps-android-commons.git
				synced 2025-10-26 20:33:53 +01:00 
			
		
		
		
	Cleanup the logout positive button lambda.
This commit is contained in:
		
							parent
							
								
									7c956e803c
								
							
						
					
					
						commit
						a615e0784e
					
				
					 2 changed files with 20 additions and 18 deletions
				
			
		|  | @ -13,7 +13,6 @@ import android.content.pm.PackageManager; | |||
| import android.database.sqlite.SQLiteDatabase; | ||||
| import android.preference.PreferenceManager; | ||||
| import android.support.v4.util.LruCache; | ||||
| import android.util.Log; | ||||
| 
 | ||||
| import com.facebook.drawee.backends.pipeline.Fresco; | ||||
| import com.facebook.stetho.Stetho; | ||||
|  | @ -35,7 +34,6 @@ import fr.free.nrw.commons.modifications.ModifierSequence; | |||
| import fr.free.nrw.commons.mwapi.ApacheHttpClientMediaWikiApi; | ||||
| import fr.free.nrw.commons.mwapi.MediaWikiApi; | ||||
| import fr.free.nrw.commons.nearby.NearbyPlaces; | ||||
| import fr.free.nrw.commons.theme.NavigationBaseActivity; | ||||
| import fr.free.nrw.commons.utils.FileUtils; | ||||
| import timber.log.Timber; | ||||
| 
 | ||||
|  | @ -190,7 +188,7 @@ public class CommonsApplication extends Application { | |||
|                 pm.hasSystemFeature(PackageManager.FEATURE_CAMERA_FRONT); | ||||
|     } | ||||
| 
 | ||||
|     public void clearApplicationData(Context context, NavigationBaseActivity.LogoutListener logoutListener) { | ||||
|     public void clearApplicationData(Context context, LogoutListener logoutListener) { | ||||
|         File cacheDirectory = context.getCacheDir(); | ||||
|         File applicationDirectory = new File(cacheDirectory.getParent()); | ||||
|         if (applicationDirectory.exists()) { | ||||
|  | @ -265,4 +263,8 @@ public class CommonsApplication extends Application { | |||
|         Category.Table.onDelete(db); | ||||
|         Contribution.Table.onDelete(db); | ||||
|     } | ||||
| 
 | ||||
|     public interface LogoutListener { | ||||
|         void onLogoutComplete(); | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -24,15 +24,13 @@ import fr.free.nrw.commons.nearby.NearbyActivity; | |||
| import fr.free.nrw.commons.settings.SettingsActivity; | ||||
| import timber.log.Timber; | ||||
| 
 | ||||
| public class NavigationBaseActivity extends BaseActivity | ||||
| public abstract class NavigationBaseActivity extends BaseActivity | ||||
|         implements NavigationView.OnNavigationItemSelectedListener { | ||||
| 
 | ||||
|     @BindView(R.id.toolbar) | ||||
|     Toolbar toolbar; | ||||
| 
 | ||||
|     @BindView(R.id.navigation_view) | ||||
|     NavigationView navigationView; | ||||
| 
 | ||||
|     @BindView(R.id.drawer_layout) | ||||
|     DrawerLayout drawerLayout; | ||||
| 
 | ||||
|  | @ -121,16 +119,9 @@ public class NavigationBaseActivity extends BaseActivity | |||
|                         .setMessage(R.string.logout_verification) | ||||
|                         .setCancelable(false) | ||||
|                         .setPositiveButton(R.string.yes, (dialog, which) -> { | ||||
|                             ((CommonsApplication) getApplicationContext()) | ||||
|                                     .clearApplicationData(NavigationBaseActivity.this, () -> { | ||||
|                                         Timber.d("Logout complete callback received."); | ||||
|                                         Intent nearbyIntent = new Intent( | ||||
|                                                 NavigationBaseActivity.this, LoginActivity.class); | ||||
|                                         nearbyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK); | ||||
|                                         nearbyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); | ||||
|                                         startActivity(nearbyIntent); | ||||
|                                         finish(); | ||||
|                                     }); | ||||
|                             BaseLogoutListener logoutListener = new BaseLogoutListener(); | ||||
|                             CommonsApplication app = (CommonsApplication) getApplication(); | ||||
|                             app.clearApplicationData(this, logoutListener); | ||||
|                         }) | ||||
|                         .setNegativeButton(R.string.no, (dialog, which) -> dialog.cancel()) | ||||
|                         .show(); | ||||
|  | @ -140,7 +131,16 @@ public class NavigationBaseActivity extends BaseActivity | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     public interface LogoutListener { | ||||
|         void onLogoutComplete(); | ||||
|     private class BaseLogoutListener implements CommonsApplication.LogoutListener { | ||||
|         @Override | ||||
|         public void onLogoutComplete() { | ||||
|             Timber.d("Logout complete callback received."); | ||||
|             Intent nearbyIntent = new Intent( | ||||
|                     NavigationBaseActivity.this, LoginActivity.class); | ||||
|             nearbyIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK); | ||||
|             nearbyIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); | ||||
|             startActivity(nearbyIntent); | ||||
|             finish(); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Paul Hawke
						Paul Hawke