/*
- * Copyright © 2016-2018 Soren Stoutner <soren@stoutner.com>.
+ * Copyright © 2016-2020 Soren Stoutner <soren@stoutner.com>.
*
* This file is part of Privacy Browser <https://www.stoutner.com/privacy-browser>.
*
package com.stoutner.privacybrowser.activities;
+import android.content.SharedPreferences;
import android.os.Bundle;
-import android.support.design.widget.TabLayout;
-import android.support.v4.app.Fragment;
-import android.support.v4.app.FragmentManager;
-import android.support.v4.app.FragmentPagerAdapter;
-import android.support.v4.view.ViewPager;
-import android.support.v7.app.ActionBar;
-import android.support.v7.app.AppCompatActivity;
-import android.support.v7.widget.Toolbar;
+import android.preference.PreferenceManager;
import android.view.WindowManager;
-import com.stoutner.privacybrowser.fragments.GuideTabFragment;
+import androidx.appcompat.app.ActionBar;
+import androidx.appcompat.app.AppCompatActivity;
+import androidx.appcompat.widget.Toolbar;
+import androidx.viewpager.widget.ViewPager;
+
+import com.google.android.material.tabs.TabLayout;
+
+import com.stoutner.privacybrowser.adapters.GuidePagerAdapter;
import com.stoutner.privacybrowser.R;
public class GuideActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
+ // Get a handle for the shared preferences.
+ SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);
+
+ // Get the screenshot preference.
+ boolean allowScreenshots = sharedPreferences.getBoolean("allow_screenshots", false);
+
// Disable screenshots if not allowed.
- if (!MainWebViewActivity.allowScreenshots) {
+ if (!allowScreenshots) {
getWindow().addFlags(WindowManager.LayoutParams.FLAG_SECURE);
}
// Set the theme.
- if (MainWebViewActivity.darkTheme) {
- setTheme(R.style.PrivacyBrowserDark_SecondaryActivity);
- } else {
- setTheme(R.style.PrivacyBrowserLight_SecondaryActivity);
- }
+ setTheme(R.style.PrivacyBrowser);
// Run the default commands.
super.onCreate(savedInstanceState);
// Set the content view.
setContentView(R.layout.guide_coordinatorlayout);
- // We need to use `SupportActionBar` from `android.support.v7.app.ActionBar` until the minimum API is >= 21.
- Toolbar guideAppBar = findViewById(R.id.guide_toolbar);
- setSupportActionBar(guideAppBar);
-
- // Display the home arrow on `ppBar`.
- final ActionBar appBar = getSupportActionBar();
- assert appBar != null; // This assert removes the incorrect lint warning in Android Studio on the following line that `appBar` might be `null`.
- appBar.setDisplayHomeAsUpEnabled(true);
-
- // Setup the ViewPager.
- ViewPager aboutViewPager = findViewById(R.id.guide_viewpager);
- assert aboutViewPager != null; // This assert removes the incorrect warning in Android Studio on the following line that aboutViewPager might be null.
- aboutViewPager.setAdapter(new guidePagerAdapter(getSupportFragmentManager()));
-
- // Setup the TabLayout and connect it to the ViewPager.
- TabLayout aboutTabLayout = findViewById(R.id.guide_tablayout);
- assert aboutTabLayout != null; // This assert removes the incorrect warning in Android Studio on the following line that aboutTabLayout might be null.
- aboutTabLayout.setupWithViewPager(aboutViewPager);
- }
-
- private class guidePagerAdapter extends FragmentPagerAdapter {
- private guidePagerAdapter(FragmentManager fm) {
- super(fm);
- }
-
- @Override
- // Get the count of the number of tabs.
- public int getCount() {
- return 10;
- }
-
- @Override
- // Get the name of each tab. Tab numbers start at 0.
- public CharSequence getPageTitle(int tab) {
- switch (tab) {
- case 0:
- return getString(R.string.overview);
-
- case 1:
- return getString(R.string.javascript);
-
- case 2:
- return getString(R.string.local_storage);
-
- case 3:
- return getString(R.string.user_agent);
+ // The AndroidX toolbar must be used until the minimum API is >= 21.
+ Toolbar toolbar = findViewById(R.id.guide_toolbar);
+ setSupportActionBar(toolbar);
- case 4:
- return getString(R.string.requests);
+ // Get a handle for the action bar.
+ final ActionBar actionBar = getSupportActionBar();
- case 5:
- return getString(R.string.domain_settings);
+ // Remove the incorrect lint warning that the action bar might be null.
+ assert actionBar != null;
- case 6:
- return getString(R.string.ssl_certificates);
+ // Display the home arrow on the action bar.
+ actionBar.setDisplayHomeAsUpEnabled(true);
- case 7:
- return getString(R.string.tor);
-
- case 8:
- return getString(R.string.tracking_ids);
+ // Get a handle for the view pager and the tab layout.
+ ViewPager aboutViewPager = findViewById(R.id.guide_viewpager);
+ TabLayout aboutTabLayout = findViewById(R.id.guide_tablayout);
- case 9:
- return getString(R.string.bookmarks);
+ // Remove the incorrect lint warnings that the views might be null
+ assert aboutViewPager != null;
+ assert aboutTabLayout != null;
- default:
- return "";
- }
- }
+ // Set the view pager adapter.
+ aboutViewPager.setAdapter(new GuidePagerAdapter(getSupportFragmentManager(), getApplicationContext()));
- @Override
- // Setup each tab.
- public Fragment getItem(int tab) {
- return GuideTabFragment.createTab(tab);
- }
+ // Link the tab layout to the view pager.
+ aboutTabLayout.setupWithViewPager(aboutViewPager);
}
-}
+}
\ No newline at end of file