mirror of
https://github.com/ethauvin/android-about-box.git
synced 2025-04-29 12:18:12 -07:00
Compare commits
No commits in common. "master" and "1.0.0" have entirely different histories.
41 changed files with 630 additions and 599 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -34,7 +34,7 @@ captures/
|
||||||
|
|
||||||
# Intellij
|
# Intellij
|
||||||
*.iml
|
*.iml
|
||||||
.idea/
|
.idea/workspace.xml
|
||||||
|
|
||||||
# Keystore files
|
# Keystore files
|
||||||
*.jks
|
*.jks
|
||||||
|
|
22
.idea/compiler.xml
generated
Normal file
22
.idea/compiler.xml
generated
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="CompilerConfiguration">
|
||||||
|
<resourceExtensions />
|
||||||
|
<wildcardResourcePatterns>
|
||||||
|
<entry name="!?*.java" />
|
||||||
|
<entry name="!?*.form" />
|
||||||
|
<entry name="!?*.class" />
|
||||||
|
<entry name="!?*.groovy" />
|
||||||
|
<entry name="!?*.scala" />
|
||||||
|
<entry name="!?*.flex" />
|
||||||
|
<entry name="!?*.kt" />
|
||||||
|
<entry name="!?*.clj" />
|
||||||
|
<entry name="!?*.aj" />
|
||||||
|
</wildcardResourcePatterns>
|
||||||
|
<annotationProcessing>
|
||||||
|
<profile default="true" name="Default" enabled="false">
|
||||||
|
<processorPath useClasspath="true" />
|
||||||
|
</profile>
|
||||||
|
</annotationProcessing>
|
||||||
|
</component>
|
||||||
|
</project>
|
3
.idea/copyright/profiles_settings.xml
generated
Normal file
3
.idea/copyright/profiles_settings.xml
generated
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
<component name="CopyrightManager">
|
||||||
|
<settings default="" />
|
||||||
|
</component>
|
18
.idea/gradle.xml
generated
Normal file
18
.idea/gradle.xml
generated
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="GradleSettings">
|
||||||
|
<option name="linkedExternalProjectsSettings">
|
||||||
|
<GradleProjectSettings>
|
||||||
|
<option name="distributionType" value="DEFAULT_WRAPPED" />
|
||||||
|
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
||||||
|
<option name="modules">
|
||||||
|
<set>
|
||||||
|
<option value="$PROJECT_DIR$" />
|
||||||
|
<option value="$PROJECT_DIR$/library" />
|
||||||
|
</set>
|
||||||
|
</option>
|
||||||
|
<option name="resolveModulePerSourceSet" value="false" />
|
||||||
|
</GradleProjectSettings>
|
||||||
|
</option>
|
||||||
|
</component>
|
||||||
|
</project>
|
12
.idea/libraries/animated_vector_drawable_25_1_0.xml
generated
Normal file
12
.idea/libraries/animated_vector_drawable_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="animated-vector-drawable-25.1.0">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/animated-vector-drawable/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/animated-vector-drawable/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/animated-vector-drawable/25.1.0/animated-vector-drawable-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
10
.idea/libraries/answers_shim_0_0_6.xml
generated
Normal file
10
.idea/libraries/answers_shim_0_0_6.xml
generated
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="answers-shim-0.0.6">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.crashlytics.sdk.android/answers-shim/0.0.6/res" />
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.crashlytics.sdk.android/answers-shim/0.0.6/jars/classes.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/appcompat_v7_25_1_0.xml
generated
Normal file
15
.idea/libraries/appcompat_v7_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="appcompat-v7-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/appcompat-v7/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/appcompat-v7/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/appcompat-v7/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/appcompat-v7/25.1.0/appcompat-v7-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
12
.idea/libraries/cardview_v7_25_1_0.xml
generated
Normal file
12
.idea/libraries/cardview_v7_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="cardview-v7-25.1.0">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/cardview-v7/25.1.0/res" />
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/cardview-v7/25.1.0/jars/classes.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/cardview-v7/25.1.0/cardview-v7-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/design_25_1_0.xml
generated
Normal file
15
.idea/libraries/design_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="design-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/design/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/design/25.1.0/res" />
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/design/25.1.0/jars/classes.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/design/25.1.0/design-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/library_2_5_7.xml
generated
Normal file
15
.idea/libraries/library_2_5_7.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="library-2.5.7">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/io.branch.sdk.android/library/2.5.7/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/io.branch.sdk.android/library/2.5.7/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/io.branch.sdk.android/library/2.5.7/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/io.branch.sdk.android/library/2.5.7/72c56965e9f432e245fe85536f56fd3c688af6cf/library-2.5.7-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
13
.idea/libraries/material_about_library_1_5_0.xml
generated
Normal file
13
.idea/libraries/material_about_library_1_5_0.xml
generated
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="material-about-library-1.5.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.github.daniel-stoneuk/material-about-library/1.5.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.github.daniel-stoneuk/material-about-library/1.5.0/res" />
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.github.daniel-stoneuk/material-about-library/1.5.0/jars/classes.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/recyclerview_v7_25_1_0.xml
generated
Normal file
15
.idea/libraries/recyclerview_v7_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="recyclerview-v7-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/recyclerview-v7/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/recyclerview-v7/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/recyclerview-v7/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/recyclerview-v7/25.1.0/recyclerview-v7-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
11
.idea/libraries/support_annotations_25_1_0.xml
generated
Normal file
11
.idea/libraries/support_annotations_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-annotations-25.1.0">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-annotations/25.1.0/support-annotations-25.1.0.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-annotations/25.1.0/support-annotations-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/support_compat_25_1_0.xml
generated
Normal file
15
.idea/libraries/support_compat_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-compat-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-compat/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-compat/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-compat/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-compat/25.1.0/support-compat-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/support_core_ui_25_1_0.xml
generated
Normal file
15
.idea/libraries/support_core_ui_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-core-ui-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-core-ui/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-core-ui/25.1.0/res" />
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-core-ui/25.1.0/jars/classes.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-core-ui/25.1.0/support-core-ui-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/support_core_utils_25_1_0.xml
generated
Normal file
15
.idea/libraries/support_core_utils_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-core-utils-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-core-utils/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-core-utils/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-core-utils/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-core-utils/25.1.0/support-core-utils-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/support_fragment_25_1_0.xml
generated
Normal file
15
.idea/libraries/support_fragment_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-fragment-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-fragment/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-fragment/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-fragment/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-fragment/25.1.0/support-fragment-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
15
.idea/libraries/support_media_compat_25_1_0.xml
generated
Normal file
15
.idea/libraries/support_media_compat_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-media-compat-25.1.0">
|
||||||
|
<ANNOTATIONS>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-media-compat/25.1.0/annotations.zip!/" />
|
||||||
|
</ANNOTATIONS>
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-media-compat/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-media-compat/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-media-compat/25.1.0/support-media-compat-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
10
.idea/libraries/support_v4_25_1_0.xml
generated
Normal file
10
.idea/libraries/support_v4_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-v4-25.1.0">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-v4/25.1.0/res" />
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-v4/25.1.0/jars/classes.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES />
|
||||||
|
</library>
|
||||||
|
</component>
|
12
.idea/libraries/support_vector_drawable_25_1_0.xml
generated
Normal file
12
.idea/libraries/support_vector_drawable_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="support-vector-drawable-25.1.0">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-vector-drawable/25.1.0/jars/classes.jar!/" />
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/support-vector-drawable/25.1.0/res" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/support-vector-drawable/25.1.0/support-vector-drawable-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
12
.idea/libraries/transition_25_1_0.xml
generated
Normal file
12
.idea/libraries/transition_25_1_0.xml
generated
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<component name="libraryTable">
|
||||||
|
<library name="transition-25.1.0">
|
||||||
|
<CLASSES>
|
||||||
|
<root url="file://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/transition/25.1.0/res" />
|
||||||
|
<root url="jar://$PROJECT_DIR$/library/build/intermediates/exploded-aar/com.android.support/transition/25.1.0/jars/classes.jar!/" />
|
||||||
|
</CLASSES>
|
||||||
|
<JAVADOC />
|
||||||
|
<SOURCES>
|
||||||
|
<root url="jar://$USER_HOME$/AppData/Local/Android/Sdk/extras/android/m2repository/com/android/support/transition/25.1.0/transition-25.1.0-sources.jar!/" />
|
||||||
|
</SOURCES>
|
||||||
|
</library>
|
||||||
|
</component>
|
41
.idea/misc.xml
generated
Normal file
41
.idea/misc.xml
generated
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="EntryPointsManager">
|
||||||
|
<entry_points version="2.0" />
|
||||||
|
</component>
|
||||||
|
<component name="NullableNotNullManager">
|
||||||
|
<option name="myDefaultNullable" value="android.support.annotation.Nullable" />
|
||||||
|
<option name="myDefaultNotNull" value="android.support.annotation.NonNull" />
|
||||||
|
<option name="myNullables">
|
||||||
|
<value>
|
||||||
|
<list size="4">
|
||||||
|
<item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.Nullable" />
|
||||||
|
<item index="1" class="java.lang.String" itemvalue="javax.annotation.Nullable" />
|
||||||
|
<item index="2" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.Nullable" />
|
||||||
|
<item index="3" class="java.lang.String" itemvalue="android.support.annotation.Nullable" />
|
||||||
|
</list>
|
||||||
|
</value>
|
||||||
|
</option>
|
||||||
|
<option name="myNotNulls">
|
||||||
|
<value>
|
||||||
|
<list size="4">
|
||||||
|
<item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.NotNull" />
|
||||||
|
<item index="1" class="java.lang.String" itemvalue="javax.annotation.Nonnull" />
|
||||||
|
<item index="2" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.NonNull" />
|
||||||
|
<item index="3" class="java.lang.String" itemvalue="android.support.annotation.NonNull" />
|
||||||
|
</list>
|
||||||
|
</value>
|
||||||
|
</option>
|
||||||
|
</component>
|
||||||
|
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||||
|
<OptionsSetting value="true" id="Add" />
|
||||||
|
<OptionsSetting value="true" id="Remove" />
|
||||||
|
<OptionsSetting value="true" id="Checkout" />
|
||||||
|
<OptionsSetting value="true" id="Update" />
|
||||||
|
<OptionsSetting value="true" id="Status" />
|
||||||
|
<OptionsSetting value="true" id="Edit" />
|
||||||
|
<ConfirmationsSetting value="0" id="Add" />
|
||||||
|
<ConfirmationsSetting value="0" id="Remove" />
|
||||||
|
</component>
|
||||||
|
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_7" default="true" assert-keyword="true" jdk-15="true" project-jdk-name="1.8" project-jdk-type="JavaSDK" />
|
||||||
|
</project>
|
9
.idea/modules.xml
generated
Normal file
9
.idea/modules.xml
generated
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectModuleManager">
|
||||||
|
<modules>
|
||||||
|
<module fileurl="file://$PROJECT_DIR$/android-about-box.iml" filepath="$PROJECT_DIR$/android-about-box.iml" />
|
||||||
|
<module fileurl="file://$PROJECT_DIR$/library/library.iml" filepath="$PROJECT_DIR$/library/library.iml" />
|
||||||
|
</modules>
|
||||||
|
</component>
|
||||||
|
</project>
|
6
.idea/vcs.xml
generated
Normal file
6
.idea/vcs.xml
generated
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="" vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
152
README.md
152
README.md
|
@ -1,150 +1,2 @@
|
||||||
[](https://circleci.com/gh/eggheadgames/android-about-box)
|
# android-about-box
|
||||||
[](https://jitpack.io/#eggheadgames/android-about-box)
|
Modern About Box for an Android App
|
||||||

|
|
||||||
[](https://github.com/eggheadgames/android-about-box/blob/develop/LICENSE)
|
|
||||||
|
|
||||||
# About Box
|
|
||||||
A modern About Box for an Android App built on the [daniel-stoneuk/material-about-library](https://github.com/daniel-stoneuk/material-about-library).
|
|
||||||
|
|
||||||
### Easily display the common items of an About Box in a modern Android friendly way
|
|
||||||
|
|
||||||
## About
|
|
||||||
|
|
||||||
Android About Box is configured with a set of (mostly) strings for the company name, twitter and Facebook accounts, website, and filenames to html files for help files, privacy policy etc.
|
|
||||||
|
|
||||||
When triggered from a menu item, it will display the app name, icon and version, provide links to contact support, leave a review, share the app, go to other apps by the same company in the app store -- as well as links to Facebook etc.
|
|
||||||
|
|
||||||
You can omit most features if they don't apply (e.g. like website), by not setting the values.
|
|
||||||
|
|
||||||
## Installation Instructions
|
|
||||||
|
|
||||||
Add the JitPack.io repository to your root `build.gradle`:
|
|
||||||
|
|
||||||
```gradle
|
|
||||||
allprojects {
|
|
||||||
repositories {
|
|
||||||
maven { url "https://jitpack.io" }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Add a dependency to your application related `build.gradle`
|
|
||||||
|
|
||||||
```gradle
|
|
||||||
dependencies {
|
|
||||||
compile 'com.github.eggheadgames:android-about-box:<actual version>'
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Setup AboutBox
|
|
||||||
|
|
||||||
Add AboutBox configuration to your Application class
|
|
||||||
|
|
||||||
```java
|
|
||||||
AboutConfig aboutConfig = AboutConfig.getInstance();
|
|
||||||
aboutConfig.appName = getString(R.string.app_name);
|
|
||||||
aboutConfig.appIcon = R.mipmap.ic_launcher;
|
|
||||||
aboutConfig.version = "1.0.0";
|
|
||||||
aboutConfig.author = "Tolstoy";
|
|
||||||
aboutConfig.aboutLabelTitle = "About App";
|
|
||||||
aboutConfig.packageName = getApplicationContext().getPackageName();
|
|
||||||
aboutConfig.buildType = google ? AboutConfig.BuildType.GOOGLE : AboutConfig.BuildType.AMAZON;
|
|
||||||
|
|
||||||
aboutConfig.facebookUserName = FACEBOOK_USER_NAME;
|
|
||||||
aboutConfig.twitterUserName = TWITTER_USER_NAME;
|
|
||||||
aboutConfig.webHomePage = WEB_HOME_PAGE;
|
|
||||||
|
|
||||||
// app publisher for "Try Other Apps" item
|
|
||||||
aboutConfig.appPublisher = APP_PUBLISHER;
|
|
||||||
|
|
||||||
// if pages are stored locally, then you need to override aboutConfig.dialog to be able use custom WebView
|
|
||||||
aboutConfig.companyHtmlPath = COMPANY_HTML_PATH;
|
|
||||||
aboutConfig.privacyHtmlPath = PRIVACY_HTML_PATH;
|
|
||||||
aboutConfig.acknowledgmentHtmlPath = ACKNOWLEDGMENT_HTML_PATH;
|
|
||||||
|
|
||||||
aboutConfig.dialog = new IDialog() {
|
|
||||||
@Override
|
|
||||||
public void open(AppCompatActivity appCompatActivity, String url, String tag) {
|
|
||||||
// handle custom implementations of WebView. It will be called when user click to web items. (Example: "Privacy", "Acknowledgments" and "About")
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
aboutConfig.analytics = new IAnalytic() {
|
|
||||||
@Override
|
|
||||||
public void logUiEvent(String s, String s1) {
|
|
||||||
// handle log events.
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void logException(Exception e, boolean b) {
|
|
||||||
// handle exception events.
|
|
||||||
}
|
|
||||||
};
|
|
||||||
// set it only if aboutConfig.analytics is defined.
|
|
||||||
aboutConfig.logUiEventName = "Log";
|
|
||||||
|
|
||||||
// Contact Support email details
|
|
||||||
aboutConfig.emailAddress = EMAIL_ADDRESS;
|
|
||||||
aboutConfig.emailSubject = EMAIL_SUBJECT;
|
|
||||||
aboutConfig.emailBody = EMAIL_BODY;
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
## Open the About Box from your app
|
|
||||||
|
|
||||||
```java
|
|
||||||
AboutActivity.launch(activity);
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Sharing
|
|
||||||
|
|
||||||
By default, the default Android share intent will be called with the values specified in `shareMessage` and `sharingTitle`. For example:
|
|
||||||
```java
|
|
||||||
aboutConfig.shareMessage = getString(R.string.share_message);
|
|
||||||
aboutConfig.sharingTitle = getString(R.string.sharing_title);
|
|
||||||
```
|
|
||||||
The `share_message` string will have an app store URL appended to it (appropriately constructed for Google Play or Amazon).
|
|
||||||
|
|
||||||
Alternatively, you can provide a custom sharing function (and omit `shareMessage` and `sharingTitle`):
|
|
||||||
```java
|
|
||||||
aboutConfig.share = new IShare() {
|
|
||||||
@Override
|
|
||||||
public void share(Activity activity) {
|
|
||||||
// do custom sharing
|
|
||||||
}
|
|
||||||
};
|
|
||||||
```
|
|
||||||
|
|
||||||
## Theme
|
|
||||||
|
|
||||||
If you add the following to your AndroidManifest.xml file, the About Box will use these colours. This allows you to match your app colours:
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<activity
|
|
||||||
android:name="com.eggheadgames.aboutbox.activity.AboutActivity"
|
|
||||||
android:theme="@style/AppTheme.MaterialAboutActivity"/>
|
|
||||||
```
|
|
||||||
|
|
||||||
Ensure that `AppTheme.MaterialAboutActivity` theme extends either of these themes, and apply primary & accent colours:
|
|
||||||
```
|
|
||||||
Theme.Mal.Light.DarkActionBar
|
|
||||||
Theme.Mal.Light.LightActionBar
|
|
||||||
Theme.Mal.Dark.LightActionBar
|
|
||||||
Theme.Mal.Dark.DarkActionBar
|
|
||||||
```
|
|
||||||
|
|
||||||
```xml
|
|
||||||
<style name="AppTheme.MaterialAboutActivity" parent="Theme.Mal.Light.DarkActionBar" >
|
|
||||||
<!-- Customize your theme here. -->
|
|
||||||
<item name="colorPrimary">@color/colorPrimary</item>
|
|
||||||
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
|
|
||||||
<item name="colorAccent">@color/colorAccent</item>
|
|
||||||
</style>
|
|
||||||
```
|
|
||||||
## Screenshot
|
|
||||||
|
|
||||||
<img src="extras/example.png?raw=true">
|
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
dependencies:
|
dependencies:
|
||||||
pre:
|
pre:
|
||||||
- echo y | android update sdk --no-ui --all --filter tools,platform-tools,android-25
|
- echo y | android update sdk --no-ui --all --filter tools,platform-tools,android-24
|
||||||
- echo y | android update sdk --no-ui --all --filter build-tools-25.0.3
|
- echo y | android update sdk --no-ui --all --filter build-tools-24.0.2
|
||||||
|
|
||||||
test:
|
test:
|
||||||
override:
|
override:
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 122 KiB |
0
gradlew
vendored
Executable file → Normal file
0
gradlew
vendored
Executable file → Normal file
|
@ -5,14 +5,15 @@ apply plugin: 'com.github.dcendents.android-maven'
|
||||||
group='com.github.eggheadgames'
|
group='com.github.eggheadgames'
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 25
|
compileSdkVersion 24
|
||||||
buildToolsVersion "25.0.3"
|
buildToolsVersion "24.0.2"
|
||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 15
|
minSdkVersion 15
|
||||||
targetSdkVersion 24
|
targetSdkVersion 24
|
||||||
versionCode 7
|
versionCode 1
|
||||||
versionName "1.3.1"
|
versionName "1.0"
|
||||||
|
|
||||||
}
|
}
|
||||||
buildTypes {
|
buildTypes {
|
||||||
release {
|
release {
|
||||||
|
@ -28,5 +29,8 @@ android {
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile 'com.github.daniel-stoneuk:material-about-library:2.2.1'
|
compile 'com.github.daniel-stoneuk:material-about-library:1.5.0'
|
||||||
|
compile('io.branch.sdk.android:library:2.5.7') {
|
||||||
|
exclude module: 'answers.shim'
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
package="com.eggheadgames.aboutbox">
|
package="com.eggheadgames.aboutbox">
|
||||||
|
|
||||||
<application>
|
<application android:label="@string/app_name">
|
||||||
<activity
|
<activity
|
||||||
android:name="com.eggheadgames.aboutbox.activity.AboutActivity"
|
android:name="com.eggheadgames.aboutbox.activity.AboutActivity"
|
||||||
android:theme="@style/AppTheme.MaterialAboutActivity" />
|
android:theme="@style/AppTheme.MaterialAboutActivity" />
|
||||||
|
|
|
@ -1,109 +0,0 @@
|
||||||
package com.eggheadgames.aboutbox;
|
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.ActivityNotFoundException;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.net.Uri;
|
|
||||||
import android.widget.Toast;
|
|
||||||
|
|
||||||
public final class AboutBoxUtils {
|
|
||||||
|
|
||||||
public final static String playStoreAppURI = "https://play.google.com/store/apps/details?id=";
|
|
||||||
public final static String amznStoreAppURI = "https://www.amazon.com/gp/mas/dl/android?p=";
|
|
||||||
|
|
||||||
private AboutBoxUtils() {
|
|
||||||
//nothing
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void getOpenFacebookIntent(Activity context, String name) {
|
|
||||||
try {
|
|
||||||
context.getPackageManager().getPackageInfo("com.facebook.katana", 0);
|
|
||||||
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse("fb://profile/" + name));
|
|
||||||
context.startActivity(intent);
|
|
||||||
} catch (Exception e) {
|
|
||||||
try {
|
|
||||||
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse("https://www.facebook.com/" + name));
|
|
||||||
context.startActivity(intent);
|
|
||||||
} catch (Exception e1) {
|
|
||||||
Toast.makeText(context, R.string.egab_can_not_open, Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void startTwitter(Activity context, String name) {
|
|
||||||
try {
|
|
||||||
context.getPackageManager().getPackageInfo("com.twitter.android", 0);
|
|
||||||
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse("twitter://user?screen_name=" + name));
|
|
||||||
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
|
||||||
context.startActivity(intent);
|
|
||||||
} catch (Exception e) {
|
|
||||||
try {
|
|
||||||
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse("https://twitter.com/" + name));
|
|
||||||
context.startActivity(intent);
|
|
||||||
} catch (Exception e1) {
|
|
||||||
Toast.makeText(context, R.string.egab_can_not_open, Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void openApp(Activity context, AboutConfig.BuildType buildType, String packageName) {
|
|
||||||
String appURI = null;
|
|
||||||
String webURI = null;
|
|
||||||
switch (buildType) {
|
|
||||||
case GOOGLE:
|
|
||||||
appURI = "market://details?id=" + packageName;
|
|
||||||
webURI = playStoreAppURI + packageName;
|
|
||||||
break;
|
|
||||||
case AMAZON:
|
|
||||||
appURI = "amzn://apps/android?p=" + packageName;
|
|
||||||
webURI = amznStoreAppURI + packageName;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
//nothing
|
|
||||||
}
|
|
||||||
openApplication(context, appURI, webURI);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void openPublisher(Activity context, AboutConfig.BuildType buildType, String publisher, String packageName) {
|
|
||||||
String appURI = null;
|
|
||||||
String webURI = null;
|
|
||||||
switch (buildType) {
|
|
||||||
case GOOGLE:
|
|
||||||
// see:
|
|
||||||
// https://developer.android.com/distribute/marketing-tools/linking-to-google-play.html#OpeningPublisher
|
|
||||||
// https://stackoverflow.com/questions/32029408/how-to-open-developer-page-on-google-play-store-market
|
|
||||||
// https://issuetracker.google.com/65244694
|
|
||||||
if (publisher.matches("\\d+")) {
|
|
||||||
webURI = "https://play.google.com/store/apps/dev?id=" + publisher;
|
|
||||||
appURI = webURI;
|
|
||||||
} else {
|
|
||||||
appURI = "market://search?q=pub:" + publisher;
|
|
||||||
webURI = "https://play.google.com/store/search?q=pub:" + publisher;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case AMAZON:
|
|
||||||
appURI = "amzn://apps/android?showAll=1&p=" + packageName;
|
|
||||||
webURI = "http://www.amazon.com/gp/mas/dl/android?showAll=1&p=" + packageName;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
//nothing
|
|
||||||
}
|
|
||||||
openApplication(context, appURI, webURI);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void openApplication(Activity context, String appURI, String webURI) {
|
|
||||||
try {
|
|
||||||
context.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(appURI)));
|
|
||||||
} catch (ActivityNotFoundException e1) {
|
|
||||||
try {
|
|
||||||
openHTMLPage(context, webURI);
|
|
||||||
} catch (ActivityNotFoundException e2) {
|
|
||||||
Toast.makeText(context, R.string.egab_can_not_open, Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void openHTMLPage(Activity context, String htmlPath) {
|
|
||||||
context.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(htmlPath)));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -8,15 +8,11 @@ public class AboutConfig {
|
||||||
public String appName;
|
public String appName;
|
||||||
public int appIcon;
|
public int appIcon;
|
||||||
public String version;
|
public String version;
|
||||||
public String author;
|
|
||||||
public String extra;
|
|
||||||
public String extraTitle;
|
|
||||||
public String aboutLabelTitle;
|
public String aboutLabelTitle;
|
||||||
public String logUiEventName;
|
public String logUiEventName;
|
||||||
public String facebookUserName;
|
public String facebookUserName;
|
||||||
public String twitterUserName;
|
public String twitterUserName;
|
||||||
public String webHomePage;
|
public String webHomePage;
|
||||||
public String guideHtmlPath;
|
|
||||||
public String appPublisher;
|
public String appPublisher;
|
||||||
public String companyHtmlPath;
|
public String companyHtmlPath;
|
||||||
public String privacyHtmlPath;
|
public String privacyHtmlPath;
|
||||||
|
@ -24,10 +20,9 @@ public class AboutConfig {
|
||||||
public BuildType buildType;
|
public BuildType buildType;
|
||||||
public String packageName;
|
public String packageName;
|
||||||
|
|
||||||
// custom analytics, dialog and share
|
// custom analytics and dialog
|
||||||
public IAnalytic analytics;
|
public IAnalytic analytics;
|
||||||
public IDialog dialog;
|
public IDialog dialog;
|
||||||
public IShare share;
|
|
||||||
|
|
||||||
// email
|
// email
|
||||||
public String emailAddress;
|
public String emailAddress;
|
||||||
|
@ -35,6 +30,7 @@ public class AboutConfig {
|
||||||
public String emailBody;
|
public String emailBody;
|
||||||
|
|
||||||
// share
|
// share
|
||||||
|
public String shareMessageTitle;
|
||||||
public String shareMessage;
|
public String shareMessage;
|
||||||
public String sharingTitle;
|
public String sharingTitle;
|
||||||
|
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
package com.eggheadgames.aboutbox;
|
|
||||||
|
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
|
|
||||||
public interface IShare {
|
|
||||||
|
|
||||||
void share(Activity activity);
|
|
||||||
}
|
|
|
@ -1,20 +1,18 @@
|
||||||
package com.eggheadgames.aboutbox.activity;
|
package com.eggheadgames.aboutbox.activity;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
|
import android.content.ActivityNotFoundException;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.support.annotation.NonNull;
|
import android.net.Uri;
|
||||||
import android.text.TextUtils;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import com.danielstone.materialaboutlibrary.MaterialAboutActivity;
|
import com.danielstone.materialaboutlibrary.MaterialAboutActivity;
|
||||||
import com.danielstone.materialaboutlibrary.items.MaterialAboutActionItem;
|
import com.danielstone.materialaboutlibrary.model.MaterialAboutActionItem;
|
||||||
import com.danielstone.materialaboutlibrary.items.MaterialAboutItemOnClickAction;
|
|
||||||
import com.danielstone.materialaboutlibrary.items.MaterialAboutTitleItem;
|
|
||||||
import com.danielstone.materialaboutlibrary.model.MaterialAboutCard;
|
import com.danielstone.materialaboutlibrary.model.MaterialAboutCard;
|
||||||
import com.danielstone.materialaboutlibrary.model.MaterialAboutList;
|
import com.danielstone.materialaboutlibrary.model.MaterialAboutList;
|
||||||
import com.eggheadgames.aboutbox.AboutBoxUtils;
|
import com.danielstone.materialaboutlibrary.model.MaterialAboutTitleItem;
|
||||||
import com.eggheadgames.aboutbox.AboutConfig;
|
import com.eggheadgames.aboutbox.AboutConfig;
|
||||||
import com.eggheadgames.aboutbox.IAnalytic;
|
|
||||||
import com.eggheadgames.aboutbox.R;
|
import com.eggheadgames.aboutbox.R;
|
||||||
import com.eggheadgames.aboutbox.share.EmailUtil;
|
import com.eggheadgames.aboutbox.share.EmailUtil;
|
||||||
import com.eggheadgames.aboutbox.share.ShareUtil;
|
import com.eggheadgames.aboutbox.share.ShareUtil;
|
||||||
|
@ -23,7 +21,6 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
|
|
||||||
public static void launch(Activity activity) {
|
public static void launch(Activity activity) {
|
||||||
Intent intent = new Intent(activity, AboutActivity.class);
|
Intent intent = new Intent(activity, AboutActivity.class);
|
||||||
intent.setFlags(Intent.FLAG_ACTIVITY_REORDER_TO_FRONT);
|
|
||||||
activity.startActivity(intent);
|
activity.startActivity(intent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,18 +29,6 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
|
|
||||||
final AboutConfig config = AboutConfig.getInstance();
|
final AboutConfig config = AboutConfig.getInstance();
|
||||||
|
|
||||||
return new MaterialAboutList.Builder()
|
|
||||||
.addCard(buildGeneralInfoCard(config))
|
|
||||||
.addCard(buildSupportCard(config))
|
|
||||||
.addCard(buildShareCard(config))
|
|
||||||
.addCard(buildAboutCard(config))
|
|
||||||
.addCard(buildSocialNetworksCard(config))
|
|
||||||
.addCard(buildPrivacyCard(config))
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@NonNull
|
|
||||||
private MaterialAboutCard buildGeneralInfoCard(AboutConfig config) {
|
|
||||||
MaterialAboutCard.Builder generalInfoCardBuilder = new MaterialAboutCard.Builder();
|
MaterialAboutCard.Builder generalInfoCardBuilder = new MaterialAboutCard.Builder();
|
||||||
|
|
||||||
generalInfoCardBuilder.addItem(new MaterialAboutTitleItem.Builder()
|
generalInfoCardBuilder.addItem(new MaterialAboutTitleItem.Builder()
|
||||||
|
@ -52,222 +37,234 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
.build());
|
.build());
|
||||||
|
|
||||||
generalInfoCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
generalInfoCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
.text(R.string.egab_version)
|
.text(R.string.version)
|
||||||
.subText(config.version)
|
.subText(config.version)
|
||||||
.build());
|
.build());
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(config.author)) {
|
|
||||||
generalInfoCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
|
||||||
.text(R.string.egab_author)
|
|
||||||
.subText(config.author)
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(config.extra) && !TextUtils.isEmpty(config.extraTitle)) {
|
MaterialAboutCard.Builder supportCardBuilder = new MaterialAboutCard.Builder();
|
||||||
generalInfoCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
supportCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
.text(config.extraTitle)
|
.text(R.string.contact_support)
|
||||||
.subTextHtml(config.extra)
|
.icon(R.drawable.ic_email_black)
|
||||||
.build());
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
}
|
|
||||||
|
|
||||||
return generalInfoCardBuilder.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@NonNull
|
|
||||||
private MaterialAboutCard buildSupportCard(final AboutConfig config) {
|
|
||||||
MaterialAboutCard.Builder card = new MaterialAboutCard.Builder();
|
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(config.guideHtmlPath)) {
|
|
||||||
card.addItem(itemHelper(R.string.egab_guide, R.drawable.ic_help_green,
|
|
||||||
new MaterialAboutItemOnClickAction() {
|
|
||||||
@Override
|
|
||||||
public void onClick() {
|
|
||||||
if (config.dialog == null) {
|
|
||||||
AboutBoxUtils.openHTMLPage(AboutActivity.this, config.guideHtmlPath);
|
|
||||||
} else {
|
|
||||||
config.dialog.open(AboutActivity.this, config.guideHtmlPath, getString(R.string.egab_guide));
|
|
||||||
}
|
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_guide));
|
|
||||||
}
|
|
||||||
})
|
|
||||||
);
|
|
||||||
}
|
|
||||||
card.addItem(itemHelper(R.string.egab_contact_support, R.drawable.ic_email_black,
|
|
||||||
new MaterialAboutItemOnClickAction() {
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
EmailUtil.contactUs(AboutActivity.this);
|
EmailUtil.contactUs(AboutActivity.this);
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_contact_log_event));
|
if (config.analytics != null) {
|
||||||
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.contact_log_event));
|
||||||
}
|
}
|
||||||
}));
|
|
||||||
|
|
||||||
return card.build();
|
|
||||||
}
|
}
|
||||||
|
})
|
||||||
|
.build());
|
||||||
|
|
||||||
@NonNull
|
|
||||||
private MaterialAboutCard buildShareCard(final AboutConfig config) {
|
MaterialAboutCard.Builder shareCardBuilder = new MaterialAboutCard.Builder();
|
||||||
MaterialAboutCard.Builder card = new MaterialAboutCard.Builder();
|
shareCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
if (config.buildType != null && !TextUtils.isEmpty(config.packageName)) {
|
.text(R.string.leave_review)
|
||||||
card.addItem(itemHelper(R.string.egab_leave_review, R.drawable.ic_review,
|
.icon(R.drawable.ic_review)
|
||||||
new MaterialAboutItemOnClickAction() {
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
AboutBoxUtils.openApp(AboutActivity.this, config.buildType, config.packageName);
|
openApp(config.packageName, config.buildType == AboutConfig.BuildType.GOOGLE);
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_review_log_event));
|
if (config.analytics != null) {
|
||||||
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.review_log_event));
|
||||||
}
|
}
|
||||||
}));
|
|
||||||
}
|
}
|
||||||
card.addItem(itemHelper(R.string.egab_share, R.drawable.ic_share_black,
|
})
|
||||||
new MaterialAboutItemOnClickAction() {
|
.build());
|
||||||
|
shareCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
|
.text(R.string.share)
|
||||||
|
.icon(R.drawable.ic_share_black)
|
||||||
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
if (config.share == null) {
|
|
||||||
ShareUtil.share(AboutActivity.this);
|
ShareUtil.share(AboutActivity.this);
|
||||||
} else {
|
if (config.analytics != null) {
|
||||||
config.share.share(AboutActivity.this);
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.share_log_event));
|
||||||
}
|
}
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_share_log_event));
|
|
||||||
}
|
|
||||||
}));
|
|
||||||
return card.build();
|
|
||||||
}
|
}
|
||||||
|
})
|
||||||
|
.build());
|
||||||
|
|
||||||
@NonNull
|
|
||||||
private MaterialAboutCard buildAboutCard(final AboutConfig config) {
|
MaterialAboutCard.Builder aboutCardBuilder = new MaterialAboutCard.Builder();
|
||||||
MaterialAboutCard.Builder card = new MaterialAboutCard.Builder();
|
aboutCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
if (config.buildType != null && !TextUtils.isEmpty(config.appPublisher) && !TextUtils.isEmpty(config.packageName)) {
|
.text(R.string.try_other_apps)
|
||||||
card.addItem(itemHelper(R.string.egab_try_other_apps, R.drawable.ic_try_other_apps,
|
.icon(R.drawable.ic_try_other_apps)
|
||||||
new MaterialAboutItemOnClickAction() {
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
AboutBoxUtils.openPublisher(AboutActivity.this, config.buildType,
|
openPublisher(config.buildType == AboutConfig.BuildType.GOOGLE, config.appPublisher);
|
||||||
config.appPublisher, config.packageName);
|
if (config.analytics != null) {
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_try_other_app_log_event));
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.try_other_app_log_event));
|
||||||
}
|
}
|
||||||
}));
|
|
||||||
}
|
}
|
||||||
if (!TextUtils.isEmpty(config.companyHtmlPath) && !TextUtils.isEmpty(config.aboutLabelTitle)) {
|
})
|
||||||
card.addItem(new MaterialAboutActionItem.Builder()
|
.build());
|
||||||
|
aboutCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
.text(config.aboutLabelTitle)
|
.text(config.aboutLabelTitle)
|
||||||
.icon(R.drawable.ic_about_black)
|
.icon(R.drawable.ic_about_black)
|
||||||
.setOnClickAction(new MaterialAboutItemOnClickAction() {
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
if (config.dialog == null) {
|
if (config.dialog == null) {
|
||||||
AboutBoxUtils.openHTMLPage(AboutActivity.this, config.companyHtmlPath);
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(config.companyHtmlPath)));
|
||||||
} else {
|
} else {
|
||||||
config.dialog.open(AboutActivity.this, config.companyHtmlPath, config.aboutLabelTitle);
|
config.dialog.open(AboutActivity.this, config.companyHtmlPath, config.aboutLabelTitle);
|
||||||
}
|
}
|
||||||
logUIEventName(config.analytics, config.logUiEventName, config.aboutLabelTitle);
|
|
||||||
|
if (config.analytics != null) {
|
||||||
|
config.analytics.logUiEvent(config.logUiEventName, config.aboutLabelTitle);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
}
|
|
||||||
return card.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@NonNull
|
|
||||||
private MaterialAboutCard buildSocialNetworksCard(final AboutConfig config) {
|
MaterialAboutCard.Builder socialNetworksCardBuilder = new MaterialAboutCard.Builder();
|
||||||
MaterialAboutCard.Builder card = new MaterialAboutCard.Builder();
|
socialNetworksCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
if (!TextUtils.isEmpty(config.facebookUserName)) {
|
.text(R.string.facebook_label)
|
||||||
card.addItem(new MaterialAboutActionItem.Builder()
|
|
||||||
.text(R.string.egab_facebook_label)
|
|
||||||
.subText(config.facebookUserName)
|
.subText(config.facebookUserName)
|
||||||
.icon(R.drawable.ic_facebook_24)
|
.icon(R.drawable.ic_facebook_24)
|
||||||
.setOnClickAction(new MaterialAboutItemOnClickAction() {
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
AboutBoxUtils.getOpenFacebookIntent(AboutActivity.this, config.facebookUserName);
|
getOpenFacebookIntent(AboutActivity.this, config.facebookUserName);
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_facebook_log_event));
|
if (config.analytics != null) {
|
||||||
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.facebook_log_event));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
}
|
socialNetworksCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
if (!TextUtils.isEmpty(config.twitterUserName)) {
|
.text(R.string.twitter_label)
|
||||||
card.addItem(new MaterialAboutActionItem.Builder()
|
|
||||||
.text(R.string.egab_twitter_label)
|
|
||||||
.subText(config.twitterUserName)
|
.subText(config.twitterUserName)
|
||||||
.icon(R.drawable.ic_twitter_24dp)
|
.icon(R.drawable.ic_twitter_24dp)
|
||||||
.setOnClickAction(new MaterialAboutItemOnClickAction() {
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
AboutBoxUtils.startTwitter(AboutActivity.this, config.twitterUserName);
|
startTwitter(AboutActivity.this, config.twitterUserName);
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_twitter_log_event));
|
if (config.analytics != null) {
|
||||||
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.twitter_log_event));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
}
|
|
||||||
if (!TextUtils.isEmpty(config.webHomePage)) {
|
socialNetworksCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
card.addItem(new MaterialAboutActionItem.Builder()
|
.text(R.string.web_label)
|
||||||
.text(R.string.egab_web_label)
|
.subText(config.webHomePage.replace("https://", "").replace("http://", "").replace("/", ""))
|
||||||
.subText(config.webHomePage.replaceFirst("^https?://", "").replaceAll("/$", ""))
|
|
||||||
.icon(R.drawable.ic_web_black_24dp)
|
.icon(R.drawable.ic_web_black_24dp)
|
||||||
.setOnClickAction(new MaterialAboutItemOnClickAction() {
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
AboutBoxUtils.openHTMLPage(AboutActivity.this, config.webHomePage);
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(config.webHomePage)));
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_website_log_event));
|
if (config.analytics != null) {
|
||||||
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.website_log_event));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
}
|
|
||||||
return card.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@NonNull
|
MaterialAboutCard.Builder privacyCardBuilder = new MaterialAboutCard.Builder();
|
||||||
private MaterialAboutCard buildPrivacyCard(final AboutConfig config) {
|
privacyCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
MaterialAboutCard.Builder card = new MaterialAboutCard.Builder();
|
.text(R.string.privacy_policy)
|
||||||
if (!TextUtils.isEmpty(config.privacyHtmlPath)) {
|
.icon(R.drawable.ic_privacy)
|
||||||
card.addItem(itemHelper(R.string.egab_privacy_policy, R.drawable.ic_privacy,
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
new MaterialAboutItemOnClickAction() {
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
if (config.dialog == null) {
|
if (config.dialog == null) {
|
||||||
AboutBoxUtils.openHTMLPage(AboutActivity.this, config.privacyHtmlPath);
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(config.privacyHtmlPath)));
|
||||||
} else {
|
} else {
|
||||||
config.dialog.open(AboutActivity.this, config.privacyHtmlPath, getString(R.string.egab_privacy_policy));
|
config.dialog.open(AboutActivity.this, config.privacyHtmlPath, getString(R.string.privacy_policy));
|
||||||
}
|
}
|
||||||
|
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_privacy_log_event));
|
if (config.analytics != null) {
|
||||||
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.privacy_log_event));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
);
|
.build());
|
||||||
}
|
privacyCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
if (!TextUtils.isEmpty(config.acknowledgmentHtmlPath)) {
|
.text(R.string.acknowledgment)
|
||||||
card.addItem(itemHelper(R.string.egab_acknowledgements, R.drawable.ic_acknowledgements,
|
.icon(R.drawable.ic_acknowledgment)
|
||||||
new MaterialAboutItemOnClickAction() {
|
.setOnClickListener(new MaterialAboutActionItem.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick() {
|
public void onClick() {
|
||||||
if (config.dialog == null) {
|
if (config.dialog == null) {
|
||||||
AboutBoxUtils.openHTMLPage(AboutActivity.this, config.acknowledgmentHtmlPath);
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(config.acknowledgmentHtmlPath)));
|
||||||
} else {
|
} else {
|
||||||
config.dialog.open(AboutActivity.this, config.acknowledgmentHtmlPath, getString(R.string.egab_acknowledgements));
|
config.dialog.open(AboutActivity.this, config.acknowledgmentHtmlPath, getString(R.string.acknowledgment));
|
||||||
}
|
|
||||||
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_acknowledgements_log_event));
|
|
||||||
}
|
|
||||||
})
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return card.build();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private MaterialAboutActionItem itemHelper(int name, int icon, MaterialAboutItemOnClickAction clickAction) {
|
if (config.analytics != null) {
|
||||||
return new MaterialAboutActionItem.Builder()
|
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.asknowledgment_log_event));
|
||||||
.text(name)
|
}
|
||||||
.icon(icon)
|
}
|
||||||
.setOnClickAction(clickAction)
|
})
|
||||||
|
.build());
|
||||||
|
|
||||||
|
|
||||||
|
return new MaterialAboutList.Builder()
|
||||||
|
.addCard(generalInfoCardBuilder.build())
|
||||||
|
.addCard(supportCardBuilder.build())
|
||||||
|
.addCard(shareCardBuilder.build())
|
||||||
|
.addCard(aboutCardBuilder.build())
|
||||||
|
.addCard(socialNetworksCardBuilder.build())
|
||||||
|
.addCard(privacyCardBuilder.build())
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected CharSequence getActivityTitle() {
|
protected CharSequence getActivityTitle() {
|
||||||
return getString(R.string.egab_about_screen_title);
|
return getString(R.string.about_screen_title);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void logUIEventName(IAnalytic analytics, String eventType, String eventValue) {
|
public static void getOpenFacebookIntent(Activity context, String name) {
|
||||||
if (analytics != null) {
|
Intent intent;
|
||||||
analytics.logUiEvent(eventType, eventValue);
|
try {
|
||||||
|
context.getPackageManager().getPackageInfo("com.facebook.katana", 0);
|
||||||
|
intent = new Intent(Intent.ACTION_VIEW, Uri.parse("fb://profile/" + name));
|
||||||
|
} catch (Exception e) {
|
||||||
|
intent = new Intent(Intent.ACTION_VIEW, Uri.parse("https://www.facebook.com/" + name));
|
||||||
|
}
|
||||||
|
context.startActivity(intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static void startTwitter(Activity context, String name) {
|
||||||
|
Intent intent;
|
||||||
|
try {
|
||||||
|
context.getPackageManager().getPackageInfo("com.twitter.android", 0);
|
||||||
|
intent = new Intent(Intent.ACTION_VIEW, Uri.parse("twitter://user?screen_name=" + name));
|
||||||
|
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
|
} catch (Exception e) {
|
||||||
|
intent = new Intent(Intent.ACTION_VIEW, Uri.parse("https://twitter.com/" + name));
|
||||||
|
}
|
||||||
|
context.startActivity(intent);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void openApp(String packageName, boolean googlePlay) {//true if Google Play, false if Amazon Store
|
||||||
|
try {
|
||||||
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse((googlePlay ? "market://details?id=" : "amzn://apps/android?p=") + packageName)));
|
||||||
|
} catch (ActivityNotFoundException e1) {
|
||||||
|
try {
|
||||||
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse((googlePlay ? "http://play.google.com/store/apps/details?id=" : "http://www.amazon.com/gp/mas/dl/android?p=") + packageName)));
|
||||||
|
} catch (ActivityNotFoundException e2) {
|
||||||
|
Toast.makeText(this, R.string.can_not_open, Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void openPublisher(boolean googlePlay, String publisher) {//true if Google Play, false if Amazon Store
|
||||||
|
try {
|
||||||
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse((googlePlay ? "market://search?q=pub:" : "amzn://apps/android?showAll=1&p=") + publisher)));
|
||||||
|
} catch (ActivityNotFoundException e1) {
|
||||||
|
try {
|
||||||
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse((googlePlay ? "http://play.google.com/store/search?q=pub:" : "http://www.amazon.com/gp/mas/dl/android?showAll=1&p=") + publisher)));
|
||||||
|
} catch (ActivityNotFoundException e2) {
|
||||||
|
Toast.makeText(this, R.string.can_not_open, Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,11 +3,9 @@ package com.eggheadgames.aboutbox.share;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Build;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import com.eggheadgames.aboutbox.AboutConfig;
|
import com.eggheadgames.aboutbox.AboutConfig;
|
||||||
import com.eggheadgames.aboutbox.R;
|
import com.eggheadgames.aboutbox.BuildConfig;
|
||||||
|
|
||||||
public final class EmailUtil {
|
public final class EmailUtil {
|
||||||
|
|
||||||
|
@ -20,35 +18,26 @@ public final class EmailUtil {
|
||||||
|
|
||||||
final Uri mailto = Uri.fromParts("mailto", config.emailAddress, null);
|
final Uri mailto = Uri.fromParts("mailto", config.emailAddress, null);
|
||||||
|
|
||||||
String emailBody = config.emailBody;
|
final String emailSubject;
|
||||||
if (TextUtils.isEmpty(emailBody)) {
|
|
||||||
String deviceInfo = "";
|
|
||||||
deviceInfo += "\n App version: " + config.version;
|
|
||||||
deviceInfo += "\n Android version: " + Build.VERSION.RELEASE + " (" + android.os.Build.VERSION.SDK_INT + ")";
|
|
||||||
deviceInfo += "\n Device: " + android.os.Build.MODEL + " (" + android.os.Build.PRODUCT + ")";
|
|
||||||
deviceInfo += "\n Platform: " + platformName(config.buildType);
|
|
||||||
|
|
||||||
emailBody = activity.getString(R.string.egab_email_body_prompt) + "\n\n\n\n\n"
|
if ("google".equals(BuildConfig.FLAVOR)) {
|
||||||
+ "---------------------------" + deviceInfo;
|
emailSubject = config.emailSubject + "G";
|
||||||
|
} else if ("amazon".equals(BuildConfig.FLAVOR)) {
|
||||||
|
emailSubject = config.emailSubject + "K";
|
||||||
|
} else {
|
||||||
|
emailSubject = config.emailSubject;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Intent emailIntent = new Intent(Intent.ACTION_SENDTO, mailto);
|
Intent emailIntent = new Intent(Intent.ACTION_SENDTO, mailto);
|
||||||
emailIntent.putExtra(Intent.EXTRA_SUBJECT, config.emailSubject);
|
emailIntent.putExtra(Intent.EXTRA_SUBJECT, emailSubject);
|
||||||
emailIntent.putExtra(Intent.EXTRA_TEXT, emailBody);
|
emailIntent.putExtra(Intent.EXTRA_TEXT, config.emailBody);
|
||||||
activity.startActivity(Intent.createChooser(emailIntent, "Send email..."));
|
activity.startActivity(Intent.createChooser(emailIntent, "Send email..."));
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
if (config.analytics != null) {
|
if (config.analytics != null) {
|
||||||
config.analytics.logException(e, false);
|
config.analytics.logException(e, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private static String platformName(AboutConfig.BuildType buildType) {
|
|
||||||
switch (buildType) {
|
|
||||||
case GOOGLE: return "Google Play";
|
|
||||||
case AMAZON: return "Amazon Kindle";
|
|
||||||
default: return "Unknown";
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,17 @@
|
||||||
package com.eggheadgames.aboutbox.share;
|
package com.eggheadgames.aboutbox.share;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Intent;
|
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
|
||||||
import com.eggheadgames.aboutbox.AboutBoxUtils;
|
|
||||||
import com.eggheadgames.aboutbox.AboutConfig;
|
import com.eggheadgames.aboutbox.AboutConfig;
|
||||||
|
|
||||||
|
import io.branch.indexing.BranchUniversalObject;
|
||||||
|
import io.branch.referral.Branch;
|
||||||
|
import io.branch.referral.BranchError;
|
||||||
|
import io.branch.referral.SharingHelper;
|
||||||
|
import io.branch.referral.util.LinkProperties;
|
||||||
|
import io.branch.referral.util.ShareSheetStyle;
|
||||||
|
|
||||||
public final class ShareUtil {
|
public final class ShareUtil {
|
||||||
|
|
||||||
private ShareUtil() {
|
private ShareUtil() {
|
||||||
|
@ -14,29 +19,48 @@ public final class ShareUtil {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void share(Activity activity) {
|
public static void share(Activity activity) {
|
||||||
AboutConfig config = AboutConfig.getInstance();
|
BranchUniversalObject branchUniversalObject = new BranchUniversalObject();
|
||||||
|
final AboutConfig config = AboutConfig.getInstance();
|
||||||
|
|
||||||
Intent intent2 = new Intent();
|
ShareSheetStyle shareSheetStyle = new ShareSheetStyle(activity, config.shareMessageTitle,
|
||||||
intent2.setAction(Intent.ACTION_SEND);
|
config.shareMessage)
|
||||||
intent2.setType("text/plain");
|
.setCopyUrlStyle(activity.getResources().getDrawable(android.R.drawable.ic_menu_send),
|
||||||
|
"Copy", "Added to clipboard")
|
||||||
|
.setMoreOptionStyle(activity.getResources().getDrawable(android.R.drawable.ic_menu_search), "Show more")
|
||||||
|
.addPreferredSharingOption(SharingHelper.SHARE_WITH.FACEBOOK)
|
||||||
|
.addPreferredSharingOption(SharingHelper.SHARE_WITH.EMAIL)
|
||||||
|
.setSharingTitle(config.sharingTitle);
|
||||||
|
|
||||||
String shareMessage = config.shareMessage;
|
branchUniversalObject.showShareSheet(activity,
|
||||||
|
new LinkProperties(), shareSheetStyle, new Branch.BranchLinkShareListener() {
|
||||||
|
@Override
|
||||||
|
public void onShareLinkDialogLaunched() {
|
||||||
|
//nothing
|
||||||
|
}
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(config.packageName) && !TextUtils.isEmpty(shareMessage) && config.buildType != null) {
|
@Override
|
||||||
switch (config.buildType) {
|
public void onShareLinkDialogDismissed() {
|
||||||
case GOOGLE:
|
if (config.analytics != null) {
|
||||||
shareMessage = shareMessage + AboutBoxUtils.playStoreAppURI + config.packageName;
|
config.analytics.logUiEvent("Share", "Dismissed");
|
||||||
break;
|
|
||||||
case AMAZON:
|
|
||||||
shareMessage = shareMessage + AboutBoxUtils.amznStoreAppURI + config.packageName;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
intent2.putExtra(Intent.EXTRA_TEXT, shareMessage);
|
@Override
|
||||||
|
public void onLinkShareResponse(String sharedLink, String sharedChannel, BranchError error) {
|
||||||
|
if (config.analytics != null) {
|
||||||
|
if (error == null || TextUtils.isEmpty(error.getMessage())) {
|
||||||
|
config.analytics.logUiEvent("Share", sharedChannel);
|
||||||
|
} else {
|
||||||
|
config.analytics.logUiEvent("Share Failure", error.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChannelSelected(String channelName) {
|
||||||
|
//nothing
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
activity.startActivity(Intent.createChooser(intent2, config.sharingTitle));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
<?xml version="1.0"?>
|
|
||||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:width="24dp"
|
|
||||||
android:height="24dp"
|
|
||||||
android:viewportHeight="24.0"
|
|
||||||
android:viewportWidth="24.0">
|
|
||||||
|
|
||||||
<path
|
|
||||||
android:fillColor="#00c853"
|
|
||||||
android:pathData="M12,2C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2zm1,17h-2v-2h2v2zm2.07,-7.75l-0.9,0.92C13.45,12.9 13,13.5 13,15h-2v-0.5c0,-1.1 0.45,-2.1 1.17,-2.83l1.24,-1.26c0.37,-0.36 0.59,-0.86 0.59,-1.41 0,-1.1 -0.9,-2 -2,-2s-2,0.9 -2,2H8c0,-2.21 1.79,-4 4,-4s4,1.79 4,4c0,0.88 -0.36,1.68 -0.93,2.25z"/>
|
|
||||||
</vector>
|
|
|
@ -1,26 +0,0 @@
|
||||||
<resources>
|
|
||||||
<string name="egab_leave_review">Avaliar</string>
|
|
||||||
<string name="egab_contact_support">Contactar o Suporte</string>
|
|
||||||
<string name="egab_try_other_apps">Experimentar outras aplicações</string>
|
|
||||||
<string name="egab_version">Versão</string>
|
|
||||||
<string name="egab_author">Autor</string>
|
|
||||||
<string name="egab_facebook_label">Facebook</string>
|
|
||||||
<string name="egab_twitter_label">Twitter</string>
|
|
||||||
<string name="egab_web_label">Web</string>
|
|
||||||
<string name="egab_acknowledgements">Acknowledgements</string>
|
|
||||||
<string name="egab_privacy_policy">Política de Privacidade</string>
|
|
||||||
<string name="egab_about_screen_title">Sobre</string>
|
|
||||||
<string name="egab_share">Partilhar</string>
|
|
||||||
<string name="egab_contact_log_event">Contactos</string>
|
|
||||||
<string name="egab_review_log_event">Avalie</string>
|
|
||||||
<string name="egab_share_log_event">Partilhar</string>
|
|
||||||
<string name="egab_try_other_app_log_event">Experimentar outras aplicações</string>
|
|
||||||
<string name="egab_facebook_log_event">Facebook</string>
|
|
||||||
<string name="egab_twitter_log_event">Twitter</string>
|
|
||||||
<string name="egab_website_log_event">Website</string>
|
|
||||||
<string name="egab_privacy_log_event">Privacicidade</string>
|
|
||||||
<string name="egab_acknowledgements_log_event">Acknowledgements</string>
|
|
||||||
<string name="egab_can_not_open">Tu não tens nenhuma aplicação que possa abrir esta ligação</string>
|
|
||||||
<string name="egab_email_body_prompt">Digite sua pergunta aqui: </string>
|
|
||||||
<string name="egab_guide">Guia</string>
|
|
||||||
</resources>
|
|
|
@ -1,27 +1,25 @@
|
||||||
<resources>
|
<resources>
|
||||||
<string name="egab_leave_review">Leave Review</string>
|
<string name="app_name">AboutBox</string>
|
||||||
<string name="egab_contact_support">Contact Support</string>
|
<string name="leave_review">Leave Review</string>
|
||||||
<string name="egab_try_other_apps">Try Other Apps</string>
|
<string name="contact_support">Contact Support</string>
|
||||||
<string name="egab_version">Version</string>
|
<string name="try_other_apps">Try Other Apps</string>
|
||||||
<string name="egab_author">Author</string>
|
<string name="version">Version</string>
|
||||||
<string name="egab_facebook_label">Facebook</string>
|
<string name="facebook_label">Facebook</string>
|
||||||
<string name="egab_twitter_label">Twitter</string>
|
<string name="twitter_label">Twitter</string>
|
||||||
<string name="egab_web_label">Web</string>
|
<string name="web_label">Web</string>
|
||||||
<string name="egab_acknowledgements">Acknowledgements</string>
|
<string name="acknowledgment">Acknowledgment</string>
|
||||||
<string name="egab_privacy_policy">Privacy Policy</string>
|
<string name="privacy_policy">Privacy Policy</string>
|
||||||
<string name="egab_about_screen_title">About</string>
|
<string name="about_screen_title">About</string>
|
||||||
<string name="egab_share">Share</string>
|
<string name="share">Share</string>
|
||||||
<string name="egab_contact_log_event">Contact</string>
|
<string name="contact_log_event">Contact</string>
|
||||||
<string name="egab_review_log_event">Review</string>
|
<string name="review_log_event">Review</string>
|
||||||
<string name="egab_share_log_event">Share</string>
|
<string name="share_log_event">Share</string>
|
||||||
<string name="egab_try_other_app_log_event">Try Other Apps</string>
|
<string name="try_other_app_log_event">Try Other Apps</string>
|
||||||
<string name="egab_facebook_log_event">Facebook</string>
|
<string name="facebook_log_event">Facebook</string>
|
||||||
<string name="egab_twitter_log_event">Twitter</string>
|
<string name="twitter_log_event">Twitter</string>
|
||||||
<string name="egab_website_log_event">Website</string>
|
<string name="website_log_event">Website</string>
|
||||||
<string name="egab_privacy_log_event">Privacy</string>
|
<string name="privacy_log_event">Privacy</string>
|
||||||
<string name="egab_acknowledgements_log_event">Acknowledgements</string>
|
<string name="asknowledgment_log_event">Acknowledgement</string>
|
||||||
<string name="egab_can_not_open">You don\'t have any app that can open this link</string>
|
<string name="can_not_open">You don\'t have any app that can open this link</string>
|
||||||
<string name="egab_email_body_prompt">Please type your question here: </string>
|
|
||||||
<string name="egab_guide">Guide</string>
|
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
|
|
||||||
<style name="AppTheme.MaterialAboutActivity" parent="Theme.Mal.Light.DarkActionBar" >
|
<style name="AppTheme.MaterialAboutActivity" parent="Theme.Mal" >
|
||||||
<item name="colorPrimary">@color/colorPrimary</item>
|
<item name="colorPrimary">@color/colorPrimary</item>
|
||||||
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
|
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
|
||||||
<item name="colorAccent">@color/colorAccent</item>
|
<item name="colorAccent">@color/colorAccent</item>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue