diff --git a/app/build.gradle b/app/build.gradle index 4e8115af5..16609fbab 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -8,8 +8,8 @@ android { applicationId "org.schabi.newpipe" minSdkVersion 15 targetSdkVersion 27 - versionCode 47 - versionName "0.11.6" + versionCode 48 + versionName "0.12.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" vectorDrawables.useSupportLibrary = true @@ -55,7 +55,7 @@ dependencies { exclude module: 'support-annotations' } - implementation 'com.github.TeamNewPipe:NewPipeExtractor:e51bc58a856dcf3' + implementation 'com.github.TeamNewPipe:NewPipeExtractor:7716b1437815' testImplementation 'junit:junit:4.12' testImplementation 'org.mockito:mockito-core:1.10.19' diff --git a/app/src/main/java/org/schabi/newpipe/MainActivity.java b/app/src/main/java/org/schabi/newpipe/MainActivity.java index cbd2bacaa..ac058f52c 100644 --- a/app/src/main/java/org/schabi/newpipe/MainActivity.java +++ b/app/src/main/java/org/schabi/newpipe/MainActivity.java @@ -37,19 +37,23 @@ import android.support.v7.app.ActionBarDrawerToggle; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.Toolbar; import android.util.Log; +import android.view.Gravity; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; import android.view.View; import android.widget.Button; import android.widget.ImageButton; +import android.widget.TextView; import android.widget.Toast; +import org.schabi.newpipe.extractor.NewPipe; import org.schabi.newpipe.extractor.StreamingService; import org.schabi.newpipe.fragments.BackPressable; import org.schabi.newpipe.fragments.MainFragment; import org.schabi.newpipe.fragments.detail.VideoDetailFragment; import org.schabi.newpipe.fragments.list.search.SearchFragment; +import org.schabi.newpipe.report.ErrorActivity; import org.schabi.newpipe.util.Constants; import org.schabi.newpipe.util.NavigationHelper; import org.schabi.newpipe.util.ServiceHelper; @@ -61,6 +65,9 @@ public class MainActivity extends AppCompatActivity { public static final boolean DEBUG = !BuildConfig.BUILD_TYPE.equals("release"); private ActionBarDrawerToggle toggle = null; + private DrawerLayout drawer = null; + private NavigationView drawerItems = null; + private TextView headerServiceView = null; /*////////////////////////////////////////////////////////////////////////// // Activity's LifeCycle @@ -81,13 +88,12 @@ public class MainActivity extends AppCompatActivity { setSupportActionBar(findViewById(R.id.toolbar)); setupDrawer(); - setupDrawerFooter(); } private void setupDrawer() { final Toolbar toolbar = findViewById(R.id.toolbar); - final DrawerLayout drawer = findViewById(R.id.drawer_layout); - final NavigationView drawerItems = findViewById(R.id.navigation); + drawer = findViewById(R.id.drawer_layout); + drawerItems = findViewById(R.id.navigation); //drawerItems.setItemIconTintList(null); // Set null to use the original icon drawerItems.getMenu().getItem(ServiceHelper.getSelectedServiceId(this)).setChecked(true); @@ -112,30 +118,48 @@ public class MainActivity extends AppCompatActivity { } }); - drawerItems.setNavigationItemSelectedListener(item -> { - if (item.getGroupId() == R.id.menu_services_group) { - drawerItems.getMenu().getItem(ServiceHelper.getSelectedServiceId(this)).setChecked(false); - ServiceHelper.setSelectedServiceId(this, item.getTitle().toString()); - drawerItems.getMenu().getItem(ServiceHelper.getSelectedServiceId(this)).setChecked(true); - } - drawer.closeDrawers(); - return true; - }); + drawerItems.setNavigationItemSelectedListener(this::changeService); + + setupDrawerFooter(); + setupDrawerHeader(); } else { drawer.setDrawerLockMode(DrawerLayout.LOCK_MODE_LOCKED_CLOSED); } } + private boolean changeService(MenuItem item) { + if (item.getGroupId() == R.id.menu_services_group) { + drawerItems.getMenu().getItem(ServiceHelper.getSelectedServiceId(this)).setChecked(false); + ServiceHelper.setSelectedServiceId(this, item.getTitle().toString()); + drawerItems.getMenu().getItem(ServiceHelper.getSelectedServiceId(this)).setChecked(true); + headerServiceView.setText("gurken"); + } else { + return false; + } + drawer.closeDrawers(); + return true; + } + private void setupDrawerFooter() { ImageButton settings = findViewById(R.id.drawer_settings); ImageButton downloads = findViewById(R.id.drawer_downloads); ImageButton history = findViewById(R.id.drawer_history); - settings.setOnClickListener(view -> NavigationHelper.openSettings(this) ); - downloads.setOnClickListener(view -> NavigationHelper.openDownloads(this)); + settings.setOnClickListener(view -> NavigationHelper.openSettings(this)); + downloads.setOnClickListener(view ->NavigationHelper.openDownloads(this)); history.setOnClickListener(view -> NavigationHelper.openHistory(this)); } + private void setupDrawerHeader() { + headerServiceView = findViewById(R.id.drawer_header_service_view); + Button action = findViewById(R.id.drawer_header_action_button); + action.setOnClickListener(view -> { + Toast.makeText(this, + R.string.drawer_header_action_paceholder_text, Toast.LENGTH_SHORT).show(); + drawer.closeDrawers(); + }); + } + @Override protected void onDestroy() { super.onDestroy(); @@ -148,6 +172,17 @@ public class MainActivity extends AppCompatActivity { protected void onResume() { super.onResume(); + // close drawer on return, and don't show animation, so its looks like the drawer isn't open + // when the user returns to MainActivity + drawer.closeDrawer(Gravity.START, false); + try { + String selectedServiceName = NewPipe.getService( + ServiceHelper.getSelectedServiceId(this)).getServiceInfo().getName(); + headerServiceView.setText(selectedServiceName); + } catch (Exception e) { + ErrorActivity.reportUiError(this, e); + } + SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this); if (sharedPreferences.getBoolean(Constants.KEY_THEME_CHANGE, false)) { if (DEBUG) Log.d(TAG, "Theme has changed, recreating activity..."); diff --git a/app/src/main/java/org/schabi/newpipe/settings/SelectKioskFragment.java b/app/src/main/java/org/schabi/newpipe/settings/SelectKioskFragment.java index 5ab1ed1f2..00b618889 100644 --- a/app/src/main/java/org/schabi/newpipe/settings/SelectKioskFragment.java +++ b/app/src/main/java/org/schabi/newpipe/settings/SelectKioskFragment.java @@ -13,6 +13,7 @@ import android.view.ViewGroup; import android.widget.ImageView; import android.widget.TextView; +import org.schabi.newpipe.MainActivity; import org.schabi.newpipe.R; import org.schabi.newpipe.extractor.NewPipe; import org.schabi.newpipe.extractor.ServiceList; @@ -45,6 +46,8 @@ import java.util.Vector; public class SelectKioskFragment extends DialogFragment { + private static final boolean DEBUG = MainActivity.DEBUG; + RecyclerView recyclerView = null; SelectKioskAdapter selectKioskAdapter = null; @@ -122,7 +125,7 @@ public class SelectKioskFragment extends DialogFragment { for(StreamingService service : NewPipe.getServices()) { //TODO: Multi-service support - if (service.getServiceId() != ServiceList.YouTube.getServiceId()) continue; + if (service.getServiceId() != ServiceList.YouTube.getServiceId() && !DEBUG) continue; for(String kioskId : service.getKioskList().getAvailableKiosks()) { String name = String.format(getString(R.string.service_kiosk_string), diff --git a/app/src/main/res/drawable-nodpi/background_header.png b/app/src/main/res/drawable-nodpi/background_header.png new file mode 100644 index 000000000..b417038f6 Binary files /dev/null and b/app/src/main/res/drawable-nodpi/background_header.png differ diff --git a/app/src/main/res/drawable-nodpi/np_logo_nude_shadow.png b/app/src/main/res/drawable-nodpi/np_logo_nude_shadow.png new file mode 100644 index 000000000..99b91d374 Binary files /dev/null and b/app/src/main/res/drawable-nodpi/np_logo_nude_shadow.png differ diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml index b894c23aa..99c637389 100644 --- a/app/src/main/res/layout/activity_main.xml +++ b/app/src/main/res/layout/activity_main.xml @@ -6,6 +6,7 @@ android:layout_width="match_parent" android:layout_height="match_parent"> + - + \ No newline at end of file diff --git a/app/src/main/res/layout/drawer_laoyut.xml b/app/src/main/res/layout/drawer_layout.xml similarity index 52% rename from app/src/main/res/layout/drawer_laoyut.xml rename to app/src/main/res/layout/drawer_layout.xml index dcf29c42f..aba90430c 100644 --- a/app/src/main/res/layout/drawer_laoyut.xml +++ b/app/src/main/res/layout/drawer_layout.xml @@ -6,9 +6,11 @@ android:layout_width="wrap_content" android:layout_gravity="start" xmlns:app="http://schemas.android.com/apk/res-auto" - android:background="?attr/android:windowBackground"> + android:background="?attr/android:windowBackground" + android:clickable="true" + android:focusable="true"> - + android:clickable="true" + android:focusable="true"> + +