bc5c7fb66a433aae42881bf83c39569ae0d9a166
[PrivacyBrowser.git] / app / src / main / java / com / stoutner / privacybrowser / activities / AboutActivity.java
1 /*
2  * Copyright 2016-2017 Soren Stoutner <soren@stoutner.com>.
3  *
4  * This file is part of Privacy Browser <https://www.stoutner.com/privacy-browser>.
5  *
6  * Privacy Browser is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * Privacy Browser is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Privacy Browser.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20 package com.stoutner.privacybrowser.activities;
21
22 import android.os.Bundle;
23 import android.support.design.widget.TabLayout;
24 import android.support.v4.app.Fragment;
25 import android.support.v4.app.FragmentManager;
26 import android.support.v4.app.FragmentPagerAdapter;
27 import android.support.v4.view.ViewPager;
28 import android.support.v7.app.ActionBar;
29 import android.support.v7.app.AppCompatActivity;
30 import android.support.v7.widget.Toolbar;
31
32 import com.stoutner.privacybrowser.fragments.AboutTabFragment;
33 import com.stoutner.privacybrowser.R;
34
35 public class AboutActivity extends AppCompatActivity {
36     @Override
37     protected void onCreate(Bundle savedInstanceState) {
38         super.onCreate(savedInstanceState);
39         setContentView(R.layout.about_coordinatorlayout);
40
41         // We need to use the SupportActionBar from android.support.v7.app.ActionBar until the minimum API is >= 21.
42         Toolbar aboutAppBar = (Toolbar) findViewById(R.id.about_toolbar);
43         setSupportActionBar(aboutAppBar);
44
45         // Display the home arrow on supportAppBar.
46         final ActionBar appBar = getSupportActionBar();
47         assert appBar != null;// This assert removes the incorrect warning in Android Studio on the following line that appBar might be null.
48         appBar.setDisplayHomeAsUpEnabled(true);
49
50         //  Setup the ViewPager.
51         ViewPager aboutViewPager = (ViewPager) findViewById(R.id.about_viewpager);
52         aboutViewPager.setAdapter(new aboutPagerAdapter(getSupportFragmentManager()));
53
54         // Setup the TabLayout and connect it to the ViewPager.
55         TabLayout aboutTabLayout = (TabLayout) findViewById(R.id.about_tablayout);
56         aboutTabLayout.setupWithViewPager(aboutViewPager);
57     }
58
59     private class aboutPagerAdapter extends FragmentPagerAdapter {
60         private aboutPagerAdapter(FragmentManager fm) {
61             super(fm);
62         }
63
64         @Override
65         // Get the count of the number of tabs.
66         public int getCount() {
67             return 7;
68         }
69
70         @Override
71         // Get the name of each tab.  Tab numbers start at 0.
72         public CharSequence getPageTitle(int tab) {
73             switch (tab) {
74                 case 0:
75                     return getString(R.string.version);
76
77                 case 1:
78                     return getString(R.string.permissions);
79
80                 case 2:
81                     return getString(R.string.privacy_policy);
82
83                 case 3:
84                     return getString(R.string.changelog);
85
86                 case 4:
87                     return getString(R.string.licenses);
88
89                 case 5:
90                     return getString(R.string.contributors);
91
92                 case 6:
93                     return getString(R.string.links);
94
95                 default:
96                     return "";
97             }
98         }
99
100         @Override
101         // Setup each tab.
102         public Fragment getItem(int tab) {
103             return AboutTabFragment.createTab(tab);
104         }
105     }
106 }