mirror of
https://github.com/ethauvin/android-about-box.git
synced 2025-04-27 19:38:11 -07:00
Extract logUIEventName method and individual card methods
Fix PMD god class failure
This commit is contained in:
parent
a9590a92a6
commit
7626468b58
1 changed files with 60 additions and 48 deletions
|
@ -5,6 +5,7 @@ import android.content.ActivityNotFoundException;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
|
import android.support.annotation.NonNull;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
@ -15,6 +16,7 @@ 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.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;
|
||||||
|
@ -31,6 +33,25 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
|
|
||||||
final AboutConfig config = AboutConfig.getInstance();
|
final AboutConfig config = AboutConfig.getInstance();
|
||||||
|
|
||||||
|
MaterialAboutCard.Builder generalInfoCardBuilder = buildGeneralInfoCard(config);
|
||||||
|
MaterialAboutCard.Builder supportCardBuilder = buildSupportCard(config);
|
||||||
|
MaterialAboutCard.Builder shareCardBuilder = buildShareCard(config);
|
||||||
|
MaterialAboutCard.Builder aboutCardBuilder = buildAboutCard(config);
|
||||||
|
MaterialAboutCard.Builder socialNetworksCardBuilder = buildSocialNetworksCard(config);
|
||||||
|
MaterialAboutCard.Builder privacyCardBuilder = buildPrivacyCard(config);
|
||||||
|
|
||||||
|
return new MaterialAboutList.Builder()
|
||||||
|
.addCard(generalInfoCardBuilder.build())
|
||||||
|
.addCard(supportCardBuilder.build())
|
||||||
|
.addCard(shareCardBuilder.build())
|
||||||
|
.addCard(aboutCardBuilder.build())
|
||||||
|
.addCard(socialNetworksCardBuilder.build())
|
||||||
|
.addCard(privacyCardBuilder.build())
|
||||||
|
.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
private MaterialAboutCard.Builder 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()
|
||||||
|
@ -42,8 +63,11 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
.text(R.string.egab_version)
|
.text(R.string.egab_version)
|
||||||
.subText(config.version)
|
.subText(config.version)
|
||||||
.build());
|
.build());
|
||||||
|
return generalInfoCardBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
private MaterialAboutCard.Builder buildSupportCard(final AboutConfig config) {
|
||||||
MaterialAboutCard.Builder supportCardBuilder = new MaterialAboutCard.Builder();
|
MaterialAboutCard.Builder supportCardBuilder = new MaterialAboutCard.Builder();
|
||||||
if (!TextUtils.isEmpty(config.guideHtmlPath)) {
|
if (!TextUtils.isEmpty(config.guideHtmlPath)) {
|
||||||
supportCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
supportCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
|
@ -53,9 +77,7 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
openHTMLPage(config.guideHtmlPath);
|
openHTMLPage(config.guideHtmlPath);
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_guide));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_guide));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
@ -67,12 +89,14 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
EmailUtil.contactUs(AboutActivity.this);
|
EmailUtil.contactUs(AboutActivity.this);
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_contact_log_event));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_contact_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}).build());
|
}).build());
|
||||||
|
return supportCardBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
private MaterialAboutCard.Builder buildShareCard(final AboutConfig config) {
|
||||||
MaterialAboutCard.Builder shareCardBuilder = new MaterialAboutCard.Builder();
|
MaterialAboutCard.Builder shareCardBuilder = new MaterialAboutCard.Builder();
|
||||||
shareCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
shareCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
.text(R.string.egab_leave_review)
|
.text(R.string.egab_leave_review)
|
||||||
|
@ -81,9 +105,7 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
openApp(config.buildType, config.packageName);
|
openApp(config.buildType, config.packageName);
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_review_log_event));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_review_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
@ -94,14 +116,15 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
ShareUtil.share(AboutActivity.this);
|
ShareUtil.share(AboutActivity.this);
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_share_log_event));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_share_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
return shareCardBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
private MaterialAboutCard.Builder buildAboutCard(final AboutConfig config) {
|
||||||
MaterialAboutCard.Builder aboutCardBuilder = new MaterialAboutCard.Builder();
|
MaterialAboutCard.Builder aboutCardBuilder = new MaterialAboutCard.Builder();
|
||||||
aboutCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
aboutCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
.text(R.string.egab_try_other_apps)
|
.text(R.string.egab_try_other_apps)
|
||||||
|
@ -110,9 +133,7 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
openPublisher(config.buildType, config.appPublisher, config.packageName);
|
openPublisher(config.buildType, 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.egab_try_other_app_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
@ -127,15 +148,15 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
} 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 aboutCardBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
private MaterialAboutCard.Builder buildSocialNetworksCard(final AboutConfig config) {
|
||||||
MaterialAboutCard.Builder socialNetworksCardBuilder = new MaterialAboutCard.Builder();
|
MaterialAboutCard.Builder socialNetworksCardBuilder = new MaterialAboutCard.Builder();
|
||||||
socialNetworksCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
socialNetworksCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
.text(R.string.egab_facebook_label)
|
.text(R.string.egab_facebook_label)
|
||||||
|
@ -145,9 +166,7 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
getOpenFacebookIntent(AboutActivity.this, config.facebookUserName);
|
getOpenFacebookIntent(AboutActivity.this, config.facebookUserName);
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_facebook_log_event));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_facebook_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
@ -159,9 +178,7 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
startTwitter(AboutActivity.this, config.twitterUserName);
|
startTwitter(AboutActivity.this, config.twitterUserName);
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_twitter_log_event));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_twitter_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
@ -174,13 +191,15 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(boolean b) {
|
public void onClick(boolean b) {
|
||||||
openHTMLPage(config.webHomePage);
|
openHTMLPage(config.webHomePage);
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_website_log_event));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_website_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
return socialNetworksCardBuilder;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
private MaterialAboutCard.Builder buildPrivacyCard(final AboutConfig config) {
|
||||||
MaterialAboutCard.Builder privacyCardBuilder = new MaterialAboutCard.Builder();
|
MaterialAboutCard.Builder privacyCardBuilder = new MaterialAboutCard.Builder();
|
||||||
privacyCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
privacyCardBuilder.addItem(new MaterialAboutActionItem.Builder()
|
||||||
.text(R.string.egab_privacy_policy)
|
.text(R.string.egab_privacy_policy)
|
||||||
|
@ -194,9 +213,7 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
config.dialog.open(AboutActivity.this, config.privacyHtmlPath, getString(R.string.egab_privacy_policy));
|
config.dialog.open(AboutActivity.this, config.privacyHtmlPath, getString(R.string.egab_privacy_policy));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config.analytics != null) {
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_privacy_log_event));
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_privacy_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
@ -211,25 +228,14 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
} else {
|
} else {
|
||||||
config.dialog.open(AboutActivity.this, config.acknowledgmentHtmlPath, getString(R.string.egab_acknowledgements));
|
config.dialog.open(AboutActivity.this, config.acknowledgmentHtmlPath, getString(R.string.egab_acknowledgements));
|
||||||
}
|
}
|
||||||
|
logUIEventName(config.analytics, config.logUiEventName, getString(R.string.egab_acknowledgements_log_event));
|
||||||
if (config.analytics != null) {
|
|
||||||
config.analytics.logUiEvent(config.logUiEventName, getString(R.string.egab_acknowledgements_log_event));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.build());
|
.build());
|
||||||
|
return privacyCardBuilder;
|
||||||
|
|
||||||
return new MaterialAboutList.Builder()
|
|
||||||
.addCard(generalInfoCardBuilder.build())
|
|
||||||
.addCard(supportCardBuilder.build())
|
|
||||||
.addCard(shareCardBuilder.build())
|
|
||||||
.addCard(aboutCardBuilder.build())
|
|
||||||
.addCard(socialNetworksCardBuilder.build())
|
|
||||||
.addCard(privacyCardBuilder.build())
|
|
||||||
.build();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected CharSequence getActivityTitle() {
|
protected CharSequence getActivityTitle() {
|
||||||
return getString(R.string.egab_about_screen_title);
|
return getString(R.string.egab_about_screen_title);
|
||||||
|
@ -318,4 +324,10 @@ public class AboutActivity extends MaterialAboutActivity {
|
||||||
private void openHTMLPage(String htmlPath) {
|
private void openHTMLPage(String htmlPath) {
|
||||||
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(htmlPath)));
|
startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(htmlPath)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void logUIEventName(IAnalytic analytics, String eventType, String eventValue) {
|
||||||
|
if (analytics != null) {
|
||||||
|
analytics.logUiEvent(eventType, eventValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue