From 2d7ba0113de701d4938e30789cb13779a40f6220 Mon Sep 17 00:00:00 2001 From: kosh Date: Mon, 28 Mar 2016 22:53:02 +0800 Subject: [PATCH] released v1.0.9 --- .idea/misc.xml | 2 +- README.md | 2 +- app/build.gradle | 3 +- .../permission/sample/MainActivity.java | 6 +- .../permission/sample/SampleActivity.java | 30 +++----- .../sample/SamplePagerActivity.java | 24 ++---- build.gradle | 2 +- gradle.properties | 4 +- gradle/wrapper/gradle-wrapper.properties | 4 +- permission/build.gradle | 6 +- .../permission/base/PermissionHelper.java | 25 ++++--- .../base/activity/BasePermissionActivity.java | 73 +++++++------------ .../base/callback/OnPermissionCallback.java | 12 +-- .../base/fragment/PermissionFragment.java | 47 +++++------- .../base/model/PermissionModelBuilder.java | 29 +++----- .../permission/base/utils/ThemeUtil.java | 6 +- .../main/res/layout-land/fragment_layout.xml | 2 +- .../permission/ExampleUnitTest.java | 15 ---- 18 files changed, 108 insertions(+), 184 deletions(-) delete mode 100644 permission/src/test/java/com/fastaccess/permission/ExampleUnitTest.java diff --git a/.idea/misc.xml b/.idea/misc.xml index 292d839..9039302 100644 --- a/.idea/misc.xml +++ b/.idea/misc.xml @@ -198,7 +198,7 @@ - + diff --git a/README.md b/README.md index 46b80e1..d0b403a 100644 --- a/README.md +++ b/README.md @@ -24,7 +24,7 @@ Nexus 10 (L) # Installation ``` - compile 'com.github.k0shk0sh:PermissionHelper:1.0.8' + compile 'com.github.k0shk0sh:PermissionHelper:1.0.9' ``` Usage diff --git a/app/build.gradle b/app/build.gradle index 51b8d73..4b9db1c 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -21,7 +21,6 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - testCompile 'junit:junit:4.12' - compile 'com.android.support:appcompat-v7:23.1.1' + compile 'com.android.support:appcompat-v7:23.2.1' compile project(':permission') } diff --git a/app/src/main/java/com/fastaccess/permission/sample/MainActivity.java b/app/src/main/java/com/fastaccess/permission/sample/MainActivity.java index cf8b44b..37861e2 100644 --- a/app/src/main/java/com/fastaccess/permission/sample/MainActivity.java +++ b/app/src/main/java/com/fastaccess/permission/sample/MainActivity.java @@ -7,16 +7,14 @@ public class MainActivity extends AppCompatActivity implements View.OnClickListener { - @Override - protected void onCreate(Bundle savedInstanceState) { + @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main_activity); findViewById(R.id.badAss).setOnClickListener(this); findViewById(R.id.pagerActivity).setOnClickListener(this); } - @Override - public void onClick(View v) { + @Override public void onClick(View v) { boolean isBadAss = v.getId() == R.id.badAss; Intent intent; if (isBadAss) { diff --git a/app/src/main/java/com/fastaccess/permission/sample/SampleActivity.java b/app/src/main/java/com/fastaccess/permission/sample/SampleActivity.java index cd073b4..349059f 100644 --- a/app/src/main/java/com/fastaccess/permission/sample/SampleActivity.java +++ b/app/src/main/java/com/fastaccess/permission/sample/SampleActivity.java @@ -36,8 +36,7 @@ public class SampleActivity extends AppCompatActivity implements OnPermissionCal Manifest.permission.WRITE_EXTERNAL_STORAGE }; - @Override - protected void onCreate(Bundle savedInstanceState) { + @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_sample); result = (TextView) findViewById(R.id.result); @@ -52,36 +51,30 @@ protected void onCreate(Bundle savedInstanceState) { *

* if you never passed the permission this method won't be called. */ - @Override - protected void onActivityResult(int requestCode, int resultCode, Intent data) { + @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { permissionHelper.onActivityForResult(requestCode); } - @Override - public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { + @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { permissionHelper.onRequestPermissionsResult(requestCode, permissions, grantResults); } - @Override - public void onPermissionGranted(String[] permissionName) { + @Override public void onPermissionGranted(@NonNull String[] permissionName) { result.setText("Permission(s) " + Arrays.toString(permissionName) + " Granted"); Log.i("onPermissionGranted", "Permission(s) " + Arrays.toString(permissionName) + " Granted"); } - @Override - public void onPermissionDeclined(String[] permissionName) { + @Override public void onPermissionDeclined(@NonNull String[] permissionName) { result.setText("Permission(s) " + Arrays.toString(permissionName) + " Declined"); Log.i("onPermissionDeclined", "Permission(s) " + Arrays.toString(permissionName) + " Declined"); } - @Override - public void onPermissionPreGranted(String permissionsName) { + @Override public void onPermissionPreGranted(@NonNull String permissionsName) { result.setText("Permission( " + permissionsName + " ) preGranted"); Log.i("onPermissionPreGranted", "Permission( " + permissionsName + " ) preGranted"); } - @Override - public void onPermissionNeedExplanation(String permissionName) { + @Override public void onPermissionNeedExplanation(@NonNull String permissionName) { Log.i("NeedExplanation", "Permission( " + permissionName + " ) needs Explanation"); if (!isSingle) { neededPermission = PermissionHelper.declinedPermissions(this, MULTI_PERMISSIONS); @@ -102,21 +95,18 @@ public void onPermissionNeedExplanation(String permissionName) { } } - @Override - public void onPermissionReallyDeclined(String permissionName) { + @Override public void onPermissionReallyDeclined(@NonNull String permissionName) { result.setText("Permission " + permissionName + " can only be granted from SettingsScreen"); Log.i("ReallyDeclined", "Permission " + permissionName + " can only be granted from settingsScreen"); /** you can call {@link PermissionHelper#openSettingsScreen(Context)} to open the settings screen */ } - @Override - public void onNoPermissionNeeded() { + @Override public void onNoPermissionNeeded() { result.setText("Permission(s) not needed"); Log.i("onNoPermissionNeeded", "Permission(s) not needed"); } - @Override - public void onClick(View v) { + @Override public void onClick(View v) { if (v.getId() == R.id.single || v.getId() == R.id.multi) { isSingle = v.getId() == R.id.single; permissionHelper diff --git a/app/src/main/java/com/fastaccess/permission/sample/SamplePagerActivity.java b/app/src/main/java/com/fastaccess/permission/sample/SamplePagerActivity.java index de67bb0..7ffac8a 100644 --- a/app/src/main/java/com/fastaccess/permission/sample/SamplePagerActivity.java +++ b/app/src/main/java/com/fastaccess/permission/sample/SamplePagerActivity.java @@ -16,9 +16,7 @@ public class SamplePagerActivity extends BasePermissionActivity { - @NonNull - @Override - protected List permissions() { + @NonNull @Override protected List permissions() { List permissions = new ArrayList<>(); permissions.add(PermissionModelBuilder.withContext(this) .withCanSkip(true) @@ -71,38 +69,30 @@ protected List permissions() { return permissions; } - @Override - protected int theme() { + @Override protected int theme() { return R.style.noActionBar; } - @Override - protected void onIntroFinished() { + @Override protected void onIntroFinished() { Log.i("onIntroFinished", "Intro has finished"); // do whatever you like! finish(); } - @Nullable - @Override - protected ViewPager.PageTransformer pagerTransformer() { + @Nullable @Override protected ViewPager.PageTransformer pagerTransformer() { return null;//use default } - @NonNull - @Override - protected boolean backPressIsEnabled() { + @Override protected boolean backPressIsEnabled() { return false; } - @Override - protected void permissionIsPermanentlyDenied(String permissionName) { + @Override protected void permissionIsPermanentlyDenied(String permissionName) { Log.e("DANGER", "Permission ( " + permissionName + " ) is permanentlyDenied and can only be granted via settings screen"); /** {@link com.fastaccess.permission.base.PermissionHelper#openSettingsScreen(Context)} can help you to open it if you like */ } - @Override - protected void onUserDeclinePermission(String permissionName) { + @Override protected void onUserDeclinePermission(String permissionName) { Log.w("Warning", "Permission ( " + permissionName + " ) is skipped you can request it again by calling doing such\n " + "if (permissionHelper.isExplanationNeeded(permissionName)) {\n" + " permissionHelper.requestAfterExplanation(permissionName);\n" + diff --git a/build.gradle b/build.gradle index be515a8..e293b0d 100644 --- a/build.gradle +++ b/build.gradle @@ -5,7 +5,7 @@ buildscript { jcenter() } dependencies { - classpath 'com.android.tools.build:gradle:1.3.0' + classpath 'com.android.tools.build:gradle:2.1.0-alpha3' // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files diff --git a/gradle.properties b/gradle.properties index fcca366..6d48568 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,5 +1,5 @@ -VERSION_NAME=1.0.8 -VERSION_CODE=8 +VERSION_NAME=1.0.9 +VERSION_CODE=9 GROUP=com.github.k0shk0sh POM_DESCRIPTION=A Library that simplify Android Runtime Permissions POM_URL=https://github.com/k0shk0sh/PermissionHelper diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index f23df6e..20932f1 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Wed Oct 21 11:34:03 PDT 2015 +#Mon Mar 28 22:21:48 MYT 2016 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.8-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-2.10-all.zip diff --git a/permission/build.gradle b/permission/build.gradle index a5ebf87..302b863 100644 --- a/permission/build.gradle +++ b/permission/build.gradle @@ -8,8 +8,8 @@ android { defaultConfig { minSdkVersion 14 targetSdkVersion 23 - versionCode 8 - versionName "1.0.8" + versionCode 9 + versionName "1.0.0" } buildTypes { release { @@ -21,5 +21,5 @@ android { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'com.android.support:appcompat-v7:23.1.1' + compile 'com.android.support:appcompat-v7:23.2.1' } diff --git a/permission/src/main/java/com/fastaccess/permission/base/PermissionHelper.java b/permission/src/main/java/com/fastaccess/permission/base/PermissionHelper.java index 18c0a51..881a017 100644 --- a/permission/src/main/java/com/fastaccess/permission/base/PermissionHelper.java +++ b/permission/src/main/java/com/fastaccess/permission/base/PermissionHelper.java @@ -1,7 +1,6 @@ package com.fastaccess.permission.base; import android.Manifest; -import android.annotation.TargetApi; import android.app.Activity; import android.content.Context; import android.content.Intent; @@ -51,8 +50,7 @@ public static PermissionHelper getInstance(@NonNull Activity context, @NonNull O return new PermissionHelper(context, permissionCallback); } - @Override - public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { + @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { if (requestCode == REQUEST_PERMISSIONS) { if (verifyPermissions(grantResults)) { permissionCallback.onPermissionGranted(permissions); @@ -131,6 +129,8 @@ public void requestSystemAlertPermission() { if (!isSystemAlertGranted()) { Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + context.getPackageName())); context.startActivityForResult(intent, OVERLAY_PERMISSION_REQ_CODE); + } else { + permissionCallback.onPermissionPreGranted(Manifest.permission.SYSTEM_ALERT_WINDOW); } } catch (Exception e) { Log.e("SystemAlertPermission", "Failed. How? god only know", e); @@ -195,9 +195,7 @@ public void requestAfterExplanation(@NonNull String permissionName) { * to be called when explanation is presented to the user */ public void requestAfterExplanation(@NonNull String[] permissions) { - ArrayList permissionsToRequest = new ArrayList<>(); - for (String permissionName : permissions) { if (isPermissionDeclined(permissionName)) { permissionsToRequest.add(permissionName); // add permission to request @@ -205,9 +203,8 @@ public void requestAfterExplanation(@NonNull String[] permissions) { permissionCallback.onPermissionPreGranted(permissionName); // do not request, since it is already granted } } - + if (permissionsToRequest.isEmpty()) return; permissions = permissionsToRequest.toArray(new String[permissionsToRequest.size()]); - ActivityCompat.requestPermissions(context, permissions, REQUEST_PERMISSIONS); } @@ -276,11 +273,13 @@ public boolean permissionExists(@NonNull String permissionName) { } /** - * @return true if {@link android.Manifest.permission#SYSTEM_ALERT_WINDOW} is granted + * @return true if {@link Manifest.permission#SYSTEM_ALERT_WINDOW} is granted */ - @TargetApi(Build.VERSION_CODES.M) public boolean isSystemAlertGranted() { - return Settings.canDrawOverlays(context); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + return Settings.canDrawOverlays(context); + } + return true; } /** @@ -388,9 +387,11 @@ public static boolean permissionExists(@NonNull Context context, @NonNull String /** * @return true if {@link android.Manifest.permission#SYSTEM_ALERT_WINDOW} is granted */ - @TargetApi(Build.VERSION_CODES.M) public static boolean isSystemAlertGranted(@NonNull Context context) { - return Settings.canDrawOverlays(context); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { + return Settings.canDrawOverlays(context); + } + return true; } } diff --git a/permission/src/main/java/com/fastaccess/permission/base/activity/BasePermissionActivity.java b/permission/src/main/java/com/fastaccess/permission/base/activity/BasePermissionActivity.java index 0a8c226..f15139a 100644 --- a/permission/src/main/java/com/fastaccess/permission/base/activity/BasePermissionActivity.java +++ b/permission/src/main/java/com/fastaccess/permission/base/activity/BasePermissionActivity.java @@ -42,21 +42,17 @@ public abstract class BasePermissionActivity extends AppCompatActivity implement private int systemOverRequestNumber = 0;/* only show the explanation once otherwise infinite LOOP if canSkip is false */ - @NonNull - protected abstract List permissions(); + @NonNull protected abstract List permissions(); - @StyleRes - protected abstract int theme(); + @StyleRes protected abstract int theme(); /** * Intro has finished. */ protected abstract void onIntroFinished(); - @Nullable - protected abstract ViewPager.PageTransformer pagerTransformer(); + @Nullable protected abstract ViewPager.PageTransformer pagerTransformer(); - @NonNull protected abstract boolean backPressIsEnabled(); /** @@ -66,13 +62,12 @@ public abstract class BasePermissionActivity extends AppCompatActivity implement /** * used to notify that the user ignored the permission - *

+ *

* note: if the {@link PermissionModel#isCanSkip()} return false, we could display the explanation immediately. */ protected abstract void onUserDeclinePermission(String permissionName); - @Override - protected void onSaveInstanceState(Bundle outState) { + @Override protected void onSaveInstanceState(Bundle outState) { super.onSaveInstanceState(outState); if (pager != null) { outState.putInt(PAGER_POSITION, pager.getCurrentItem()); @@ -80,8 +75,7 @@ protected void onSaveInstanceState(Bundle outState) { outState.putInt(SYSTEM_OVERLAY_NUM_INSTANCE, systemOverRequestNumber); } - @Override - protected void onCreate(@Nullable Bundle savedInstanceState) { + @Override protected void onCreate(@Nullable Bundle savedInstanceState) { if (theme() != 0) setTheme(theme()); super.onCreate(savedInstanceState); setContentView(R.layout.main_layout); @@ -110,11 +104,7 @@ public void onPageSelected(int position) { animateColorChange(pager, color); } }); - if (pagerTransformer() == null) - pager.setPageTransformer(true, new IntroTransformer()); - else - pager.setPageTransformer(true, pagerTransformer()); - + pager.setPageTransformer(true, pagerTransformer() == null ? new IntroTransformer() : pagerTransformer()); if (savedInstanceState != null) { pager.setCurrentItem(savedInstanceState.getInt(PAGER_POSITION), true); systemOverRequestNumber = savedInstanceState.getInt(SYSTEM_OVERLAY_NUM_INSTANCE); @@ -123,28 +113,25 @@ public void onPageSelected(int position) { /** * Used to determine if the user accepted {@link android.Manifest.permission#SYSTEM_ALERT_WINDOW} or no. - *

+ *

* if you never passed the permission this method won't be called. */ - @Override - protected void onActivityResult(int requestCode, int resultCode, Intent data) { + @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { permissionHelper.onActivityForResult(requestCode); + super.onActivityResult(requestCode, resultCode, data); } - @Override - public void onBackPressed() { + @Override public void onBackPressed() { if (backPressIsEnabled()) { super.onBackPressed(); } } - @Override - public void onPermissionGranted(String[] permissionName) { + @Override public void onPermissionGranted(@NonNull String[] permissionName) { onNext(permissionName[0]);// we are certain that one permission is requested. } - @Override - public void onPermissionDeclined(String[] permissionName) { + @Override public void onPermissionDeclined(@NonNull String[] permissionName) { PermissionModel model = getPermission(pager.getCurrentItem()); if (model != null) { if (!model.isCanSkip()) { @@ -167,13 +154,11 @@ public void onPermissionDeclined(String[] permissionName) { onNext(permissionName[0]); } - @Override - public void onPermissionPreGranted(String permissionsName) { + @Override public void onPermissionPreGranted(@NonNull String permissionsName) { onNext(permissionsName); } - @Override - public void onPermissionNeedExplanation(String permissionName) { + @Override public void onPermissionNeedExplanation(@NonNull String permissionName) { if (!permissionName.equalsIgnoreCase(Manifest.permission.SYSTEM_ALERT_WINDOW)) { PermissionModel model = getPermission(pager.getCurrentItem()); if (model != null) { @@ -186,14 +171,12 @@ public void onPermissionNeedExplanation(String permissionName) { } } - @Override - public void onPermissionReallyDeclined(String permissionName) { + @Override public void onPermissionReallyDeclined(@NonNull String permissionName) { permissionIsPermanentlyDenied(permissionName); onNoPermissionNeeded(); } - @Override - public void onNoPermissionNeeded() { + @Override public void onNoPermissionNeeded() { if ((pager.getAdapter().getCount() - 1) == pager.getCurrentItem()) { onIntroFinished(); } else { @@ -201,8 +184,7 @@ public void onNoPermissionNeeded() { } } - @Override - public void onStatusBarColorChange(@ColorInt int color) { + @Override public void onStatusBarColorChange(@ColorInt int color) { if (color == 0) return; if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { float cl = 0.9f; @@ -215,23 +197,21 @@ public void onStatusBarColorChange(@ColorInt int color) { } } - @Override - public void onSkip(@NonNull String permissionName) { + @Override public void onSkip(@NonNull String permissionName) { pager.setCurrentItem(pager.getCurrentItem() - 1, true); } - @Override - public void onNext(@NonNull String permissionName) { + @Override public void onNext(@NonNull String permissionName) { int currentPosition = pager.getCurrentItem(); if ((pager.getAdapter().getCount() - 1) == (currentPosition)) { onNoPermissionNeeded(); } else { - pager.setCurrentItem(pager.getCurrentItem() + 1, true); + currentPosition = pager.getCurrentItem() + 1; + pager.setCurrentItem(currentPosition, true); } } - @Override - public void onPermissionRequest(@NonNull String permissionName, boolean canSkip) { + @Override public void onPermissionRequest(@NonNull String permissionName, boolean canSkip) { if (permissionHelper.isExplanationNeeded(permissionName)) { onPermissionNeedExplanation(permissionName); } else { @@ -239,21 +219,20 @@ public void onPermissionRequest(@NonNull String permissionName, boolean canSkip) } } - @Override - public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { + @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { permissionHelper.onRequestPermissionsResult(requestCode, permissions, grantResults); } /** * @return instance of {@link PermissionFragment} */ - protected PermissionFragment getFragment(int index) { + @SuppressWarnings("unused") protected PermissionFragment getFragment(int index) { return (PermissionFragment) pager.getAdapter().instantiateItem(pager, index); } /** * return PermissionModel at specific index. - *

+ *

* if index > {@link #permissions().size()} null will be returned */ protected PermissionModel getPermission(int index) { diff --git a/permission/src/main/java/com/fastaccess/permission/base/callback/OnPermissionCallback.java b/permission/src/main/java/com/fastaccess/permission/base/callback/OnPermissionCallback.java index 3e1583d..f5b4c11 100644 --- a/permission/src/main/java/com/fastaccess/permission/base/callback/OnPermissionCallback.java +++ b/permission/src/main/java/com/fastaccess/permission/base/callback/OnPermissionCallback.java @@ -1,16 +1,18 @@ package com.fastaccess.permission.base.callback; +import android.support.annotation.NonNull; + public interface OnPermissionCallback { - void onPermissionGranted(String[] permissionName); + void onPermissionGranted(@NonNull String[] permissionName); - void onPermissionDeclined(String[] permissionName); + void onPermissionDeclined(@NonNull String[] permissionName); - void onPermissionPreGranted(String permissionsName); + void onPermissionPreGranted(@NonNull String permissionsName); - void onPermissionNeedExplanation(String permissionName); + void onPermissionNeedExplanation(@NonNull String permissionName); - void onPermissionReallyDeclined(String permissionName); + void onPermissionReallyDeclined(@NonNull String permissionName); void onNoPermissionNeeded(); } diff --git a/permission/src/main/java/com/fastaccess/permission/base/fragment/PermissionFragment.java b/permission/src/main/java/com/fastaccess/permission/base/fragment/PermissionFragment.java index 14c017b..1c139ce 100644 --- a/permission/src/main/java/com/fastaccess/permission/base/fragment/PermissionFragment.java +++ b/permission/src/main/java/com/fastaccess/permission/base/fragment/PermissionFragment.java @@ -40,8 +40,7 @@ public static PermissionFragment newInstance(PermissionModel permissionModel) { return fragment; } - @Override - public void onAttach(Context context) { + @Override public void onAttach(Context context) { super.onAttach(context); if (context instanceof BaseCallback) { callback = (BaseCallback) context; @@ -50,28 +49,23 @@ public void onAttach(Context context) { } } - @Override - public void onDetach() { + @Override public void onDetach() { super.onDetach(); callback = null; } - @Override - public void onSaveInstanceState(Bundle outState) { + @Override public void onSaveInstanceState(Bundle outState) { super.onSaveInstanceState(outState); if (permissionModel != null) { outState.putParcelable(PERMISSION_INSTANCE, permissionModel); } } - @Nullable - @Override - public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { + @Nullable @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { return inflater.inflate(R.layout.fragment_layout, container, false); } - @Override - public void onViewCreated(View view, Bundle savedInstanceState) { + @Override public void onViewCreated(View view, Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); if (savedInstanceState != null) { permissionModel = savedInstanceState.getParcelable(PERMISSION_INSTANCE); @@ -93,11 +87,25 @@ public void onViewCreated(View view, Bundle savedInstanceState) { initViews(); } + @Override public void onClick(View v) { + if (v.getId() == R.id.previous) { + callback.onSkip(permissionModel.getPermissionName()); + } else if (v.getId() == R.id.next) { + if (!permissionModel.isCanSkip()) { + callback.onPermissionRequest(permissionModel.getPermissionName(), false); + } else { + callback.onNext(permissionModel.getPermissionName()); + } + } else if (v.getId() == R.id.request) { + callback.onPermissionRequest(permissionModel.getPermissionName(), true); + } + } + private void initViews() { request.setVisibility(Build.VERSION.SDK_INT < Build.VERSION_CODES.M ? View.GONE : View.VISIBLE); image.setImageResource(permissionModel.getImageResourceId()); title.setText(permissionModel.getTitle()); - title.setTextSize(permissionModel.getTextSize()); + title.setTextSize(TypedValue.COMPLEX_UNIT_PX, permissionModel.getTextSize()); title.setTextColor(permissionModel.getTextColor() == 0 ? Color.WHITE : permissionModel.getTextColor()); message.setText(permissionModel.getMessage()); message.setTextColor(permissionModel.getTextColor() == 0 ? Color.WHITE : permissionModel.getTextColor()); @@ -113,19 +121,4 @@ private void initViews() { } } } - - @Override - public void onClick(View v) { - if (v.getId() == R.id.previous) { - callback.onSkip(permissionModel.getPermissionName()); - } else if (v.getId() == R.id.next) { - if (!permissionModel.isCanSkip()) { - callback.onPermissionRequest(permissionModel.getPermissionName(), false); - } else { - callback.onNext(permissionModel.getPermissionName()); - } - } else if (v.getId() == R.id.request) { - callback.onPermissionRequest(permissionModel.getPermissionName(), true); - } - } } diff --git a/permission/src/main/java/com/fastaccess/permission/base/model/PermissionModelBuilder.java b/permission/src/main/java/com/fastaccess/permission/base/model/PermissionModelBuilder.java index 8c792cd..10dd5a2 100644 --- a/permission/src/main/java/com/fastaccess/permission/base/model/PermissionModelBuilder.java +++ b/permission/src/main/java/com/fastaccess/permission/base/model/PermissionModelBuilder.java @@ -1,30 +1,27 @@ package com.fastaccess.permission.base.model; import android.content.Context; -import android.content.res.Resources; import android.graphics.Color; -import android.os.Build; import android.support.annotation.ColorInt; import android.support.annotation.ColorRes; import android.support.annotation.DimenRes; import android.support.annotation.DrawableRes; import android.support.annotation.NonNull; import android.support.annotation.StringRes; +import android.support.v4.app.ActivityCompat; import com.fastaccess.permission.R; public class PermissionModelBuilder { - private final Resources res; - private Resources.Theme theme; private final PermissionModel permissionModel; + private Context context; private PermissionModelBuilder(@NonNull Context context) { - this.res = context.getResources(); - this.theme = context.getTheme(); + this.context = context; this.permissionModel = new PermissionModel(); // Generate sane default values withTextColor(Color.WHITE); - withTextSize(res.getDimensionPixelSize(R.dimen.permissions_text_size)); + withTextSize(context.getResources().getDimensionPixelSize(R.dimen.permissions_text_size)); withRequestIcon(R.drawable.ic_arrow_done); withPreviousIcon(R.drawable.ic_arrow_left); withNextIcon(R.drawable.ic_arrow_right); @@ -54,11 +51,7 @@ public PermissionModelBuilder withLayoutColor(@ColorInt int layoutColor) { } public PermissionModelBuilder withLayoutColorRes(@ColorRes int layoutColor) { - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { - this.permissionModel.setLayoutColor(res.getColor(layoutColor, theme)); - } else { - this.permissionModel.setLayoutColor(res.getColor(layoutColor)); - } + this.permissionModel.setLayoutColor(ActivityCompat.getColor(context, layoutColor)); return this; } @@ -68,11 +61,7 @@ public PermissionModelBuilder withTextColor(@ColorInt int textColor) { } public PermissionModelBuilder withTextColorRes(@ColorRes int textColor) { - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { - this.permissionModel.setTextColor(res.getColor(textColor, theme)); - } else { - this.permissionModel.setTextColor(res.getColor(textColor)); - } + this.permissionModel.setTextColor(ActivityCompat.getColor(context, textColor)); return this; } @@ -87,7 +76,7 @@ public PermissionModelBuilder withExplanationMessage(@NonNull String explanation } public PermissionModelBuilder withExplanationMessage(@StringRes int explanationMessage) { - this.permissionModel.setExplanationMessage(res.getString(explanationMessage)); + this.permissionModel.setExplanationMessage(context.getString(explanationMessage)); return this; } @@ -117,7 +106,7 @@ public PermissionModelBuilder withMessage(@NonNull String message) { } public PermissionModelBuilder withMessage(@StringRes int message) { - this.permissionModel.setMessage(res.getString(message)); + this.permissionModel.setMessage(context.getString(message)); return this; } @@ -127,7 +116,7 @@ public PermissionModelBuilder withTitle(@NonNull String title) { } public PermissionModelBuilder withTitle(@StringRes int title) { - this.permissionModel.setTitle(res.getString(title)); + this.permissionModel.setTitle(context.getString(title)); return this; } diff --git a/permission/src/main/java/com/fastaccess/permission/base/utils/ThemeUtil.java b/permission/src/main/java/com/fastaccess/permission/base/utils/ThemeUtil.java index c367fd6..95ce137 100644 --- a/permission/src/main/java/com/fastaccess/permission/base/utils/ThemeUtil.java +++ b/permission/src/main/java/com/fastaccess/permission/base/utils/ThemeUtil.java @@ -11,15 +11,13 @@ */ public class ThemeUtil { - @ColorInt - public static int getPrimaryColor(Context context) { + @ColorInt public static int getPrimaryColor(Context context) { TypedValue value = new TypedValue(); context.getTheme().resolveAttribute(R.attr.colorPrimary, value, true); return value.data; } - @ColorInt - public static int getThemeAccentColor(Context context) { + @ColorInt public static int getThemeAccentColor(Context context) { TypedValue value = new TypedValue(); context.getTheme().resolveAttribute(R.attr.colorAccent, value, true); return value.data; diff --git a/permission/src/main/res/layout-land/fragment_layout.xml b/permission/src/main/res/layout-land/fragment_layout.xml index c3fd2ae..3e4da4b 100644 --- a/permission/src/main/res/layout-land/fragment_layout.xml +++ b/permission/src/main/res/layout-land/fragment_layout.xml @@ -52,7 +52,7 @@ android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="center" - android:layout_marginBottom="10dip" + android:layout_marginBottom="10dp" android:gravity="center" android:autoLink="all" android:maxLines="4"/> diff --git a/permission/src/test/java/com/fastaccess/permission/ExampleUnitTest.java b/permission/src/test/java/com/fastaccess/permission/ExampleUnitTest.java deleted file mode 100644 index d602a7f..0000000 --- a/permission/src/test/java/com/fastaccess/permission/ExampleUnitTest.java +++ /dev/null @@ -1,15 +0,0 @@ -package com.fastaccess.permission; - -import org.junit.Test; - -import static org.junit.Assert.*; - -/** - * To work on unit tests, switch the Test Artifact in the Build Variants view. - */ -public class ExampleUnitTest { - @Test - public void addition_isCorrect() throws Exception { - assertEquals(4, 2 + 2); - } -} \ No newline at end of file