mirror of
https://github.com/TeamNewPipe/NewPipe
synced 2025-01-05 06:50:31 +00:00
Fix PR review
Make all of the uploader section on stream page navigate to the channel page Extract hard coded strings Remove redundant spaces Fix open streams from a channel Rename "ParentChannel" to "SubChannel" Config royosef:NewPipeExtractor in app/build.gradle
This commit is contained in:
parent
2d0bc05488
commit
cc8874b687
@ -158,7 +158,7 @@ dependencies {
|
|||||||
exclude module: 'support-annotations'
|
exclude module: 'support-annotations'
|
||||||
})
|
})
|
||||||
|
|
||||||
implementation 'com.github.TeamNewPipe:NewPipeExtractor:665c69b5306d335985d5c0692f5119b5172c1b7a'
|
implementation 'com.github.Royosef:NewPipeExtractor:a4086617719e53b293efa1e8873799ba7714cb14'
|
||||||
testImplementation 'junit:junit:4.12'
|
testImplementation 'junit:junit:4.12'
|
||||||
testImplementation 'org.mockito:mockito-core:2.23.0'
|
testImplementation 'org.mockito:mockito-core:2.23.0'
|
||||||
|
|
||||||
|
@ -172,10 +172,11 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
private TextView videoUploadDateView;
|
private TextView videoUploadDateView;
|
||||||
private TextView videoDescriptionView;
|
private TextView videoDescriptionView;
|
||||||
|
|
||||||
|
private View uploaderRootLayout;
|
||||||
private TextView uploaderTextView;
|
private TextView uploaderTextView;
|
||||||
private ImageView uploaderThumb;
|
private ImageView uploaderThumb;
|
||||||
private TextView parentChannelTextView;
|
private TextView subChannelTextView;
|
||||||
private ImageView parentChannelThumb;
|
private ImageView subChannelThumb;
|
||||||
|
|
||||||
private TextView thumbsUpTextView;
|
private TextView thumbsUpTextView;
|
||||||
private ImageView thumbsUpImageView;
|
private ImageView thumbsUpImageView;
|
||||||
@ -419,25 +420,16 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
this.openDownloadDialog();
|
this.openDownloadDialog();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case R.id.detail_parent_channel_text_view:
|
case R.id.detail_uploader_root_layout:
|
||||||
case R.id.detail_parent_channel_thumbnail_view:
|
if (TextUtils.isEmpty(currentInfo.getSubChannelUrl())) {
|
||||||
if (TextUtils.isEmpty(currentInfo.getParentChannelUrl())) {
|
Log.w(TAG, "Can't open sub-channel because we got no channel URL");
|
||||||
Log.w(TAG, "Can't open parent's channel because we got no channel URL");
|
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(currentInfo.getUploaderUrl())) {
|
if (!TextUtils.isEmpty(currentInfo.getUploaderUrl())) {
|
||||||
openChannel(currentInfo.getUploaderUrl(), currentInfo.getUploaderName());
|
openChannel(currentInfo.getUploaderUrl(), currentInfo.getUploaderName());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
openChannel(currentInfo.getParentChannelUrl(),
|
openChannel(currentInfo.getSubChannelUrl(),
|
||||||
currentInfo.getParentChannelName());
|
currentInfo.getSubChannelName());
|
||||||
}
|
|
||||||
break;
|
|
||||||
case R.id.detail_uploader_text_view:
|
|
||||||
case R.id.detail_uploader_thumbnail_view:
|
|
||||||
if (TextUtils.isEmpty(currentInfo.getUploaderUrl())) {
|
|
||||||
Log.w(TAG, "Can't open channel because we got no channel URL");
|
|
||||||
} else {
|
|
||||||
openChannel(currentInfo.getUploaderUrl(), currentInfo.getUploaderName());
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case R.id.detail_thumbnail_root_layout:
|
case R.id.detail_thumbnail_root_layout:
|
||||||
@ -454,13 +446,13 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void openChannel(final String parentChannelUrl, final String parentChannelName) {
|
private void openChannel(final String subChannelUrl, final String subChannelName) {
|
||||||
try {
|
try {
|
||||||
NavigationHelper.openChannelFragment(
|
NavigationHelper.openChannelFragment(
|
||||||
getFragmentManager(),
|
getFragmentManager(),
|
||||||
currentInfo.getServiceId(),
|
currentInfo.getServiceId(),
|
||||||
parentChannelUrl,
|
subChannelUrl,
|
||||||
parentChannelName);
|
subChannelName);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
ErrorActivity.reportUiError((AppCompatActivity) getActivity(), e);
|
ErrorActivity.reportUiError((AppCompatActivity) getActivity(), e);
|
||||||
}
|
}
|
||||||
@ -541,10 +533,11 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
thumbsDownImageView = rootView.findViewById(R.id.detail_thumbs_down_img_view);
|
thumbsDownImageView = rootView.findViewById(R.id.detail_thumbs_down_img_view);
|
||||||
thumbsDisabledTextView = rootView.findViewById(R.id.detail_thumbs_disabled_view);
|
thumbsDisabledTextView = rootView.findViewById(R.id.detail_thumbs_disabled_view);
|
||||||
|
|
||||||
|
uploaderRootLayout = rootView.findViewById(R.id.detail_uploader_root_layout);
|
||||||
uploaderTextView = rootView.findViewById(R.id.detail_uploader_text_view);
|
uploaderTextView = rootView.findViewById(R.id.detail_uploader_text_view);
|
||||||
uploaderThumb = rootView.findViewById(R.id.detail_uploader_thumbnail_view);
|
uploaderThumb = rootView.findViewById(R.id.detail_uploader_thumbnail_view);
|
||||||
parentChannelTextView = rootView.findViewById(R.id.detail_parent_channel_text_view);
|
subChannelTextView = rootView.findViewById(R.id.detail_sub_channel_text_view);
|
||||||
parentChannelThumb = rootView.findViewById(R.id.detail_parent_channel_thumbnail_view);
|
subChannelThumb = rootView.findViewById(R.id.detail_sub_channel_thumbnail_view);
|
||||||
|
|
||||||
appBarLayout = rootView.findViewById(R.id.appbarlayout);
|
appBarLayout = rootView.findViewById(R.id.appbarlayout);
|
||||||
viewPager = rootView.findViewById(R.id.viewpager);
|
viewPager = rootView.findViewById(R.id.viewpager);
|
||||||
@ -574,11 +567,7 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
protected void initListeners() {
|
protected void initListeners() {
|
||||||
super.initListeners();
|
super.initListeners();
|
||||||
|
|
||||||
uploaderTextView.setOnClickListener(this);
|
uploaderRootLayout.setOnClickListener(this);
|
||||||
uploaderThumb.setOnClickListener(this);
|
|
||||||
parentChannelTextView.setOnClickListener(this);
|
|
||||||
parentChannelThumb.setOnClickListener(this);
|
|
||||||
|
|
||||||
videoTitleRoot.setOnClickListener(this);
|
videoTitleRoot.setOnClickListener(this);
|
||||||
thumbnailBackgroundButton.setOnClickListener(this);
|
thumbnailBackgroundButton.setOnClickListener(this);
|
||||||
detailControlsBackground.setOnClickListener(this);
|
detailControlsBackground.setOnClickListener(this);
|
||||||
@ -627,8 +616,8 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
ImageDisplayConstants.DISPLAY_THUMBNAIL_OPTIONS, onFailListener);
|
ImageDisplayConstants.DISPLAY_THUMBNAIL_OPTIONS, onFailListener);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(info.getParentChannelAvatarUrl())) {
|
if (!TextUtils.isEmpty(info.getSubChannelAvatarUrl())) {
|
||||||
IMAGE_LOADER.displayImage(info.getParentChannelAvatarUrl(), parentChannelThumb,
|
IMAGE_LOADER.displayImage(info.getSubChannelAvatarUrl(), subChannelThumb,
|
||||||
ImageDisplayConstants.DISPLAY_AVATAR_OPTIONS);
|
ImageDisplayConstants.DISPLAY_AVATAR_OPTIONS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -993,7 +982,7 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
@NonNull final StreamInfo info,
|
@NonNull final StreamInfo info,
|
||||||
@NonNull final Stream selectedStream) {
|
@NonNull final Stream selectedStream) {
|
||||||
NavigationHelper.playOnExternalPlayer(context, currentInfo.getName(),
|
NavigationHelper.playOnExternalPlayer(context, currentInfo.getName(),
|
||||||
currentInfo.getParentChannelName(), selectedStream);
|
currentInfo.getSubChannelName(), selectedStream);
|
||||||
|
|
||||||
final HistoryRecordManager recordManager = new HistoryRecordManager(requireContext());
|
final HistoryRecordManager recordManager = new HistoryRecordManager(requireContext());
|
||||||
disposables.add(recordManager.onViewed(info).onErrorComplete()
|
disposables.add(recordManager.onViewed(info).onErrorComplete()
|
||||||
@ -1126,9 +1115,9 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
}
|
}
|
||||||
|
|
||||||
IMAGE_LOADER.cancelDisplayTask(thumbnailImageView);
|
IMAGE_LOADER.cancelDisplayTask(thumbnailImageView);
|
||||||
IMAGE_LOADER.cancelDisplayTask(parentChannelThumb);
|
IMAGE_LOADER.cancelDisplayTask(subChannelThumb);
|
||||||
thumbnailImageView.setImageBitmap(null);
|
thumbnailImageView.setImageBitmap(null);
|
||||||
parentChannelThumb.setImageBitmap(null);
|
subChannelThumb.setImageBitmap(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -1156,17 +1145,17 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
animateView(thumbnailPlayButton, true, 200);
|
animateView(thumbnailPlayButton, true, 200);
|
||||||
videoTitleTextView.setText(name);
|
videoTitleTextView.setText(name);
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(info.getParentChannelName())) {
|
if (!TextUtils.isEmpty(info.getSubChannelName())) {
|
||||||
displayBothUploaderAndParentChannel(info);
|
displayBothUploaderAndSubChannel(info);
|
||||||
} else if (!TextUtils.isEmpty(info.getUploaderName())) {
|
} else if (!TextUtils.isEmpty(info.getUploaderName())) {
|
||||||
displayUploaderAsParentChannel(info);
|
displayUploaderAsSubChannel(info);
|
||||||
} else {
|
} else {
|
||||||
parentChannelThumb.setVisibility(View.GONE);
|
subChannelThumb.setVisibility(View.GONE);
|
||||||
uploaderTextView.setVisibility(View.GONE);
|
uploaderTextView.setVisibility(View.GONE);
|
||||||
uploaderThumb.setVisibility(View.GONE);
|
uploaderThumb.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
parentChannelThumb.setImageDrawable(ContextCompat.getDrawable(activity, R.drawable.buddy));
|
subChannelThumb.setImageDrawable(ContextCompat.getDrawable(activity, R.drawable.buddy));
|
||||||
uploaderThumb.setImageDrawable(ContextCompat.getDrawable(activity, R.drawable.buddy));
|
uploaderThumb.setImageDrawable(ContextCompat.getDrawable(activity, R.drawable.buddy));
|
||||||
|
|
||||||
if (info.getViewCount() >= 0) {
|
if (info.getViewCount() >= 0) {
|
||||||
@ -1297,21 +1286,22 @@ public class VideoDetailFragment extends BaseStateFragment<StreamInfo>
|
|||||||
viewPager.setVisibility(View.GONE);
|
viewPager.setVisibility(View.GONE);
|
||||||
tabLayout.setVisibility(View.GONE);
|
tabLayout.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
private void displayUploaderAsParentChannel(final StreamInfo info) {
|
private void displayUploaderAsSubChannel(final StreamInfo info) {
|
||||||
parentChannelTextView.setText(info.getUploaderName());
|
subChannelTextView.setText(info.getUploaderName());
|
||||||
parentChannelTextView.setVisibility(View.VISIBLE);
|
subChannelTextView.setVisibility(View.VISIBLE);
|
||||||
parentChannelTextView.setSelected(true);
|
subChannelTextView.setSelected(true);
|
||||||
parentChannelThumb.setVisibility(View.GONE);
|
subChannelThumb.setVisibility(View.GONE);
|
||||||
uploaderTextView.setVisibility(View.GONE);
|
uploaderTextView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void displayBothUploaderAndParentChannel(final StreamInfo info) {
|
private void displayBothUploaderAndSubChannel(final StreamInfo info) {
|
||||||
parentChannelTextView.setText(info.getParentChannelName());
|
subChannelTextView.setText(info.getSubChannelName());
|
||||||
parentChannelTextView.setVisibility(View.VISIBLE);
|
subChannelTextView.setVisibility(View.VISIBLE);
|
||||||
parentChannelTextView.setSelected(true);
|
subChannelTextView.setSelected(true);
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(info.getUploaderName())) {
|
if (!TextUtils.isEmpty(info.getUploaderName())) {
|
||||||
uploaderTextView.setText("By " + info.getUploaderName());
|
uploaderTextView.setText(
|
||||||
|
String.format(getString(R.string.video_detail_by), info.getUploaderName()));
|
||||||
uploaderTextView.setVisibility(View.VISIBLE);
|
uploaderTextView.setVisibility(View.VISIBLE);
|
||||||
uploaderTextView.setSelected(true);
|
uploaderTextView.setSelected(true);
|
||||||
} else {
|
} else {
|
||||||
|
@ -82,8 +82,8 @@ public class ChannelFragment extends BaseListInfoFragment<ChannelInfo>
|
|||||||
private ImageView headerChannelBanner;
|
private ImageView headerChannelBanner;
|
||||||
private ImageView headerAvatarView;
|
private ImageView headerAvatarView;
|
||||||
private TextView headerTitleView;
|
private TextView headerTitleView;
|
||||||
private ImageView headerParentChannelAvatarView;
|
private ImageView headerSubChannelAvatarView;
|
||||||
private TextView headerParentChannelTitleView;
|
private TextView headerSubChannelTitleView;
|
||||||
private TextView headerSubscribersTextView;
|
private TextView headerSubscribersTextView;
|
||||||
private Button headerSubscribeButton;
|
private Button headerSubscribeButton;
|
||||||
private View playlistCtrl;
|
private View playlistCtrl;
|
||||||
@ -161,10 +161,10 @@ public class ChannelFragment extends BaseListInfoFragment<ChannelInfo>
|
|||||||
headerSubscribersTextView = headerRootLayout.findViewById(R.id.channel_subscriber_view);
|
headerSubscribersTextView = headerRootLayout.findViewById(R.id.channel_subscriber_view);
|
||||||
headerSubscribeButton = headerRootLayout.findViewById(R.id.channel_subscribe_button);
|
headerSubscribeButton = headerRootLayout.findViewById(R.id.channel_subscribe_button);
|
||||||
playlistCtrl = headerRootLayout.findViewById(R.id.playlist_control);
|
playlistCtrl = headerRootLayout.findViewById(R.id.playlist_control);
|
||||||
headerParentChannelAvatarView =
|
headerSubChannelAvatarView =
|
||||||
headerRootLayout.findViewById(R.id.parent_channel_avatar_view);
|
headerRootLayout.findViewById(R.id.sub_channel_avatar_view);
|
||||||
headerParentChannelTitleView =
|
headerSubChannelTitleView =
|
||||||
headerRootLayout.findViewById(R.id.parent_channel_title_view);
|
headerRootLayout.findViewById(R.id.sub_channel_title_view);
|
||||||
|
|
||||||
headerPlayAllButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_all_button);
|
headerPlayAllButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_all_button);
|
||||||
headerPopupButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_popup_button);
|
headerPopupButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_popup_button);
|
||||||
@ -175,8 +175,10 @@ public class ChannelFragment extends BaseListInfoFragment<ChannelInfo>
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void initListeners() {
|
protected void initListeners() {
|
||||||
headerParentChannelTitleView.setOnClickListener(this);
|
super.initListeners();
|
||||||
headerParentChannelAvatarView.setOnClickListener(this);
|
|
||||||
|
headerSubChannelTitleView.setOnClickListener(this);
|
||||||
|
headerSubChannelAvatarView.setOnClickListener(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*//////////////////////////////////////////////////////////////////////////
|
/*//////////////////////////////////////////////////////////////////////////
|
||||||
@ -419,17 +421,17 @@ public class ChannelFragment extends BaseListInfoFragment<ChannelInfo>
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch (v.getId()) {
|
switch (v.getId()) {
|
||||||
case R.id.parent_channel_avatar_view:
|
case R.id.sub_channel_avatar_view:
|
||||||
case R.id.parent_channel_title_view:
|
case R.id.sub_channel_title_view:
|
||||||
if (TextUtils.isEmpty(currentInfo.getParentChannelUrl())) {
|
if (TextUtils.isEmpty(currentInfo.getSubChannelUrl())) {
|
||||||
Log.w(TAG, "Can't open parent's channel because we got no channel URL");
|
Log.w(TAG, "Can't open sub-channel because we got no channel URL");
|
||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
NavigationHelper.openChannelFragment(
|
NavigationHelper.openChannelFragment(
|
||||||
getFragmentManager(),
|
getFragmentManager(),
|
||||||
currentInfo.getServiceId(),
|
currentInfo.getServiceId(),
|
||||||
currentInfo.getParentChannelUrl(),
|
currentInfo.getSubChannelUrl(),
|
||||||
currentInfo.getParentChannelName());
|
currentInfo.getSubChannelName());
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
ErrorActivity.reportUiError((AppCompatActivity) getActivity(), e);
|
ErrorActivity.reportUiError((AppCompatActivity) getActivity(), e);
|
||||||
}
|
}
|
||||||
@ -448,7 +450,7 @@ public class ChannelFragment extends BaseListInfoFragment<ChannelInfo>
|
|||||||
|
|
||||||
IMAGE_LOADER.cancelDisplayTask(headerChannelBanner);
|
IMAGE_LOADER.cancelDisplayTask(headerChannelBanner);
|
||||||
IMAGE_LOADER.cancelDisplayTask(headerAvatarView);
|
IMAGE_LOADER.cancelDisplayTask(headerAvatarView);
|
||||||
IMAGE_LOADER.cancelDisplayTask(headerParentChannelAvatarView);
|
IMAGE_LOADER.cancelDisplayTask(headerSubChannelAvatarView);
|
||||||
animateView(headerSubscribeButton, false, 100);
|
animateView(headerSubscribeButton, false, 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -461,7 +463,7 @@ public class ChannelFragment extends BaseListInfoFragment<ChannelInfo>
|
|||||||
ImageDisplayConstants.DISPLAY_BANNER_OPTIONS);
|
ImageDisplayConstants.DISPLAY_BANNER_OPTIONS);
|
||||||
IMAGE_LOADER.displayImage(result.getAvatarUrl(), headerAvatarView,
|
IMAGE_LOADER.displayImage(result.getAvatarUrl(), headerAvatarView,
|
||||||
ImageDisplayConstants.DISPLAY_AVATAR_OPTIONS);
|
ImageDisplayConstants.DISPLAY_AVATAR_OPTIONS);
|
||||||
IMAGE_LOADER.displayImage(result.getParentChannelAvatarUrl(), headerParentChannelAvatarView,
|
IMAGE_LOADER.displayImage(result.getSubChannelAvatarUrl(), headerSubChannelAvatarView,
|
||||||
ImageDisplayConstants.DISPLAY_AVATAR_OPTIONS);
|
ImageDisplayConstants.DISPLAY_AVATAR_OPTIONS);
|
||||||
|
|
||||||
headerSubscribersTextView.setVisibility(View.VISIBLE);
|
headerSubscribersTextView.setVisibility(View.VISIBLE);
|
||||||
@ -472,13 +474,15 @@ public class ChannelFragment extends BaseListInfoFragment<ChannelInfo>
|
|||||||
headerSubscribersTextView.setText(R.string.subscribers_count_not_available);
|
headerSubscribersTextView.setText(R.string.subscribers_count_not_available);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(currentInfo.getParentChannelName())) {
|
if (!TextUtils.isEmpty(currentInfo.getSubChannelName())) {
|
||||||
headerParentChannelTitleView.setText(
|
headerSubChannelTitleView.setText(String.format(
|
||||||
"Created by " + currentInfo.getParentChannelName());
|
getString(R.string.channel_created_by),
|
||||||
headerParentChannelTitleView.setVisibility(View.VISIBLE);
|
currentInfo.getSubChannelName())
|
||||||
|
);
|
||||||
|
headerSubChannelTitleView.setVisibility(View.VISIBLE);
|
||||||
} else {
|
} else {
|
||||||
headerParentChannelTitleView.setVisibility(View.GONE);
|
headerSubChannelTitleView.setVisibility(View.GONE);
|
||||||
headerParentChannelAvatarView.setVisibility(View.GONE);
|
headerSubChannelAvatarView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (menuRssButton != null) {
|
if (menuRssButton != null) {
|
||||||
|
@ -264,7 +264,7 @@
|
|||||||
android:src="@drawable/buddy" />
|
android:src="@drawable/buddy" />
|
||||||
|
|
||||||
<de.hdodenhof.circleimageview.CircleImageView
|
<de.hdodenhof.circleimageview.CircleImageView
|
||||||
android:id="@+id/detail_parent_channel_thumbnail_view"
|
android:id="@+id/detail_sub_channel_thumbnail_view"
|
||||||
android:layout_width="@dimen/video_item_detail_uploader_image_size"
|
android:layout_width="@dimen/video_item_detail_uploader_image_size"
|
||||||
android:layout_height="@dimen/video_item_detail_uploader_image_size"
|
android:layout_height="@dimen/video_item_detail_uploader_image_size"
|
||||||
android:layout_gravity="bottom|right"
|
android:layout_gravity="bottom|right"
|
||||||
@ -280,7 +280,7 @@
|
|||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/detail_parent_channel_text_view"
|
android:id="@+id/detail_sub_channel_text_view"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginLeft="15dp"
|
android:layout_marginLeft="15dp"
|
||||||
@ -290,7 +290,7 @@
|
|||||||
android:scrollHorizontally="true"
|
android:scrollHorizontally="true"
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
android:textAppearance="?android:attr/textAppearanceLarge"
|
android:textAppearance="?android:attr/textAppearanceLarge"
|
||||||
android:textSize="@dimen/video_item_detail_parent_channel_text_size"
|
android:textSize="@dimen/video_item_detail_sub_channel_text_size"
|
||||||
android:textStyle="bold"
|
android:textStyle="bold"
|
||||||
tools:ignore="RtlHardcoded"
|
tools:ignore="RtlHardcoded"
|
||||||
tools:text="Channel" />
|
tools:text="Channel" />
|
||||||
|
@ -40,7 +40,7 @@
|
|||||||
tools:ignore="RtlHardcoded" />
|
tools:ignore="RtlHardcoded" />
|
||||||
|
|
||||||
<de.hdodenhof.circleimageview.CircleImageView
|
<de.hdodenhof.circleimageview.CircleImageView
|
||||||
android:id="@+id/parent_channel_avatar_view"
|
android:id="@+id/sub_channel_avatar_view"
|
||||||
android:layout_width="35dp"
|
android:layout_width="35dp"
|
||||||
android:layout_height="35dp"
|
android:layout_height="35dp"
|
||||||
android:layout_gravity="bottom|right"
|
android:layout_gravity="bottom|right"
|
||||||
@ -68,7 +68,7 @@
|
|||||||
tools:text="Lorem ipsum dolor" />
|
tools:text="Lorem ipsum dolor" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/parent_channel_title_view"
|
android:id="@+id/sub_channel_title_view"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/channel_title_view"
|
android:layout_below="@id/channel_title_view"
|
||||||
@ -87,7 +87,7 @@
|
|||||||
android:id="@+id/channel_subscriber_view"
|
android:id="@+id/channel_subscriber_view"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_below="@id/parent_channel_title_view"
|
android:layout_below="@id/sub_channel_title_view"
|
||||||
android:layout_alignLeft="@id/channel_title_view"
|
android:layout_alignLeft="@id/channel_title_view"
|
||||||
android:layout_alignRight="@id/channel_title_view"
|
android:layout_alignRight="@id/channel_title_view"
|
||||||
android:ellipsize="end"
|
android:ellipsize="end"
|
||||||
|
@ -258,11 +258,11 @@
|
|||||||
tools:ignore="RtlHardcoded" />
|
tools:ignore="RtlHardcoded" />
|
||||||
|
|
||||||
<de.hdodenhof.circleimageview.CircleImageView
|
<de.hdodenhof.circleimageview.CircleImageView
|
||||||
android:id="@+id/detail_parent_channel_thumbnail_view"
|
android:id="@+id/detail_sub_channel_thumbnail_view"
|
||||||
android:layout_width="@dimen/video_item_detail_parent_channel_image_size"
|
android:layout_width="@dimen/video_item_detail_sub_channel_image_size"
|
||||||
android:layout_height="@dimen/video_item_detail_parent_channel_image_size"
|
android:layout_height="@dimen/video_item_detail_sub_channel_image_size"
|
||||||
android:layout_gravity="bottom|right"
|
android:layout_gravity="bottom|right"
|
||||||
android:contentDescription="@string/detail_parent_channel_thumbnail_view_description"
|
android:contentDescription="@string/detail_sub_channel_thumbnail_view_description"
|
||||||
android:src="@drawable/buddy"
|
android:src="@drawable/buddy"
|
||||||
tools:ignore="RtlHardcoded" />
|
tools:ignore="RtlHardcoded" />
|
||||||
|
|
||||||
@ -276,7 +276,7 @@
|
|||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/detail_parent_channel_text_view"
|
android:id="@+id/detail_sub_channel_text_view"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:ellipsize="marquee"
|
android:ellipsize="marquee"
|
||||||
@ -285,7 +285,7 @@
|
|||||||
android:scrollHorizontally="true"
|
android:scrollHorizontally="true"
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
android:textAppearance="?android:attr/textAppearanceLarge"
|
android:textAppearance="?android:attr/textAppearanceLarge"
|
||||||
android:textSize="@dimen/video_item_detail_parent_channel_text_size"
|
android:textSize="@dimen/video_item_detail_sub_channel_text_size"
|
||||||
android:textStyle="normal|bold"
|
android:textStyle="normal|bold"
|
||||||
tools:ignore="RtlHardcoded"
|
tools:ignore="RtlHardcoded"
|
||||||
tools:text="Channel" />
|
tools:text="Channel" />
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
<dimen name="video_item_detail_views_text_size">14sp</dimen>
|
<dimen name="video_item_detail_views_text_size">14sp</dimen>
|
||||||
<dimen name="video_item_detail_likes_text_size">13sp</dimen>
|
<dimen name="video_item_detail_likes_text_size">13sp</dimen>
|
||||||
<dimen name="video_item_detail_uploader_text_size">12sp</dimen>
|
<dimen name="video_item_detail_uploader_text_size">12sp</dimen>
|
||||||
<dimen name="video_item_detail_parent_channel_text_size">16sp</dimen>
|
<dimen name="video_item_detail_sub_channel_text_size">16sp</dimen>
|
||||||
<dimen name="video_item_detail_upload_date_text_size">14sp</dimen>
|
<dimen name="video_item_detail_upload_date_text_size">14sp</dimen>
|
||||||
<dimen name="video_item_detail_description_text_size">14sp</dimen>
|
<dimen name="video_item_detail_description_text_size">14sp</dimen>
|
||||||
<dimen name="video_item_detail_next_text_size">17sp</dimen>
|
<dimen name="video_item_detail_next_text_size">17sp</dimen>
|
||||||
@ -34,7 +34,7 @@
|
|||||||
<dimen name="channel_rss_title_size">14sp</dimen>
|
<dimen name="channel_rss_title_size">14sp</dimen>
|
||||||
<!-- Elements Size -->
|
<!-- Elements Size -->
|
||||||
<dimen name="video_item_detail_uploader_image_size">42dp</dimen>
|
<dimen name="video_item_detail_uploader_image_size">42dp</dimen>
|
||||||
<dimen name="video_item_detail_parent_channel_image_size">22dp</dimen>
|
<dimen name="video_item_detail_sub_channel_image_size">22dp</dimen>
|
||||||
<dimen name="video_item_detail_like_image_height">20sp</dimen>
|
<dimen name="video_item_detail_like_image_height">20sp</dimen>
|
||||||
<dimen name="video_item_detail_like_image_width">20sp</dimen>
|
<dimen name="video_item_detail_like_image_width">20sp</dimen>
|
||||||
<dimen name="channel_avatar_size">90dp</dimen>
|
<dimen name="channel_avatar_size">90dp</dimen>
|
||||||
|
@ -8,14 +8,14 @@
|
|||||||
<dimen name="video_item_detail_title_text_size">16sp</dimen>
|
<dimen name="video_item_detail_title_text_size">16sp</dimen>
|
||||||
<dimen name="video_item_detail_views_text_size">16sp</dimen>
|
<dimen name="video_item_detail_views_text_size">16sp</dimen>
|
||||||
<dimen name="video_item_detail_likes_text_size">14sp</dimen>
|
<dimen name="video_item_detail_likes_text_size">14sp</dimen>
|
||||||
<dimen name="video_item_detail_parent_channel_text_size">16sp</dimen>
|
<dimen name="video_item_detail_sub_channel_text_size">16sp</dimen>
|
||||||
<dimen name="video_item_detail_uploader_text_size">12sp</dimen>
|
<dimen name="video_item_detail_uploader_text_size">12sp</dimen>
|
||||||
<dimen name="video_item_detail_upload_date_text_size">16sp</dimen>
|
<dimen name="video_item_detail_upload_date_text_size">16sp</dimen>
|
||||||
<dimen name="video_item_detail_description_text_size">16sp</dimen>
|
<dimen name="video_item_detail_description_text_size">16sp</dimen>
|
||||||
<dimen name="video_item_detail_next_text_size">18sp</dimen>
|
<dimen name="video_item_detail_next_text_size">18sp</dimen>
|
||||||
<!-- Elements Size -->
|
<!-- Elements Size -->
|
||||||
<dimen name="video_item_detail_uploader_image_size">45dp</dimen>
|
<dimen name="video_item_detail_uploader_image_size">45dp</dimen>
|
||||||
<dimen name="video_item_detail_parent_channel_image_size">25dp</dimen>
|
<dimen name="video_item_detail_sub_channel_image_size">25dp</dimen>
|
||||||
<dimen name="video_item_detail_like_image_height">18sp</dimen>
|
<dimen name="video_item_detail_like_image_height">18sp</dimen>
|
||||||
<dimen name="video_item_detail_like_image_width">18sp</dimen>
|
<dimen name="video_item_detail_like_image_width">18sp</dimen>
|
||||||
<!-- Paddings & Margins -->
|
<!-- Paddings & Margins -->
|
||||||
|
@ -55,7 +55,7 @@
|
|||||||
<dimen name="video_item_detail_views_text_size">13sp</dimen>
|
<dimen name="video_item_detail_views_text_size">13sp</dimen>
|
||||||
<dimen name="video_item_detail_likes_text_size">12sp</dimen>
|
<dimen name="video_item_detail_likes_text_size">12sp</dimen>
|
||||||
<dimen name="video_item_detail_uploader_text_size">12sp</dimen>
|
<dimen name="video_item_detail_uploader_text_size">12sp</dimen>
|
||||||
<dimen name="video_item_detail_parent_channel_text_size">14sp</dimen>
|
<dimen name="video_item_detail_sub_channel_text_size">14sp</dimen>
|
||||||
<dimen name="video_item_detail_upload_date_text_size">13sp</dimen>
|
<dimen name="video_item_detail_upload_date_text_size">13sp</dimen>
|
||||||
<dimen name="video_item_detail_description_text_size">13sp</dimen>
|
<dimen name="video_item_detail_description_text_size">13sp</dimen>
|
||||||
<dimen name="video_item_detail_next_text_size">15sp</dimen>
|
<dimen name="video_item_detail_next_text_size">15sp</dimen>
|
||||||
@ -63,7 +63,7 @@
|
|||||||
<dimen name="channel_rss_title_size">12sp</dimen>
|
<dimen name="channel_rss_title_size">12sp</dimen>
|
||||||
<!-- Elements Size -->
|
<!-- Elements Size -->
|
||||||
<dimen name="video_item_detail_uploader_image_size">32dp</dimen>
|
<dimen name="video_item_detail_uploader_image_size">32dp</dimen>
|
||||||
<dimen name="video_item_detail_parent_channel_image_size">16dp</dimen>
|
<dimen name="video_item_detail_sub_channel_image_size">16dp</dimen>
|
||||||
<dimen name="video_item_detail_like_image_height">18sp</dimen>
|
<dimen name="video_item_detail_like_image_height">18sp</dimen>
|
||||||
<dimen name="video_item_detail_like_image_width">18sp</dimen>
|
<dimen name="video_item_detail_like_image_width">18sp</dimen>
|
||||||
<dimen name="channel_avatar_size">70dp</dimen>
|
<dimen name="channel_avatar_size">70dp</dimen>
|
||||||
|
@ -651,5 +651,7 @@
|
|||||||
<string name="feed_use_dedicated_fetch_method_disable_button">Disable fast mode</string>
|
<string name="feed_use_dedicated_fetch_method_disable_button">Disable fast mode</string>
|
||||||
<string name="feed_use_dedicated_fetch_method_help_text">Do you think feed loading is too slow? If so, try enabling fast loading (you can change it in settings or by pressing the button below).\n\nNewPipe offers two feed loading strategies:\n• Fetching the whole subscription channel, which is slow but complete.\n• Using a dedicated service endpoint, which is fast but usually not complete.\n\nThe difference between the two is that the fast one usually lacks some information, like the item\'s duration or type (can\'t distinguish between live videos and normal ones) and it may return less items.\n\nYouTube is an example of a service that offers this fast method with its RSS feed.\n\nSo the choice boils down to what you prefer: speed or precise information.</string>
|
<string name="feed_use_dedicated_fetch_method_help_text">Do you think feed loading is too slow? If so, try enabling fast loading (you can change it in settings or by pressing the button below).\n\nNewPipe offers two feed loading strategies:\n• Fetching the whole subscription channel, which is slow but complete.\n• Using a dedicated service endpoint, which is fast but usually not complete.\n\nThe difference between the two is that the fast one usually lacks some information, like the item\'s duration or type (can\'t distinguish between live videos and normal ones) and it may return less items.\n\nYouTube is an example of a service that offers this fast method with its RSS feed.\n\nSo the choice boils down to what you prefer: speed or precise information.</string>
|
||||||
<string name="content_not_supported">This content is not yet supported by NewPipe.\n\nIt will hopefully be supported in a future version.</string>
|
<string name="content_not_supported">This content is not yet supported by NewPipe.\n\nIt will hopefully be supported in a future version.</string>
|
||||||
<string name="detail_parent_channel_thumbnail_view_description">Channel\'s avatar thumbnail</string>
|
<string name="detail_sub_channel_thumbnail_view_description">Channel\'s avatar thumbnail</string>
|
||||||
|
<string name="channel_created_by">Created by %s</string>
|
||||||
|
<string name="video_detail_by">By %s</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
@ -1,7 +1 @@
|
|||||||
include ':app'
|
include ':app'
|
||||||
|
|
||||||
includeBuild('../NewPipeExtractor') {
|
|
||||||
dependencySubstitution {
|
|
||||||
substitute module('com.github.TeamNewPipe:NewPipeExtractor') with project(':extractor')
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user