1
0
Fork 0
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:
Michael Mee 2017-04-13 13:54:47 -07:00
parent a9590a92a6
commit 7626468b58

View file

@ -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);
}
}
} }