made ui handle missing information on search

This commit is contained in:
Christian Schabesberger 2016-02-29 16:10:46 +01:00
parent d7e75e6011
commit 1a2840b33f
3 changed files with 31 additions and 8 deletions

View File

@ -41,8 +41,10 @@ class VideoInfoItemViewCreator {
this.inflater = inflater; this.inflater = inflater;
} }
public View getViewFromVideoInfoItem(View convertView, ViewGroup parent, StreamPreviewInfo info, Context context) { public View getViewFromVideoInfoItem(View convertView, ViewGroup parent, StreamPreviewInfo info) {
ViewHolder holder; ViewHolder holder;
// generate holder
if(convertView == null) { if(convertView == null) {
convertView = inflater.inflate(R.layout.video_item, parent, false); convertView = inflater.inflate(R.layout.video_item, parent, false);
holder = new ViewHolder(); holder = new ViewHolder();
@ -57,20 +59,41 @@ class VideoInfoItemViewCreator {
holder = (ViewHolder) convertView.getTag(); holder = (ViewHolder) convertView.getTag();
} }
// fill with information
/*
if(info.thumbnail == null) { if(info.thumbnail == null) {
holder.itemThumbnailView.setImageResource(R.drawable.dummy_thumbnail); holder.itemThumbnailView.setImageResource(R.drawable.dummy_thumbnail);
} else { } else {
holder.itemThumbnailView.setImageBitmap(info.thumbnail); holder.itemThumbnailView.setImageBitmap(info.thumbnail);
} }
*/
holder.itemVideoTitleView.setText(info.title); holder.itemVideoTitleView.setText(info.title);
holder.itemUploaderView.setText(info.uploader); if(info.uploader != null && !info.uploader.isEmpty()) {
holder.itemDurationView.setText(info.duration); holder.itemUploaderView.setText(info.uploader);
holder.itemViewCountView.setText(shortViewCount(info.view_count)); } else {
holder.itemDurationView.setVisibility(View.INVISIBLE);
}
if(info.duration != null && !info.duration.isEmpty()) {
holder.itemDurationView.setText(info.duration);
} else {
holder.itemDurationView.setVisibility(View.GONE);
}
if(info.view_count >= 0) {
holder.itemViewCountView.setText(shortViewCount(info.view_count));
} else {
holder.itemViewCountView.setVisibility(View.GONE);
}
if(!info.upload_date.isEmpty()) { if(!info.upload_date.isEmpty()) {
holder.itemUploadDateView.setText(info.upload_date+""); holder.itemUploadDateView.setText(info.upload_date+"");
} }
imageLoader.displayImage(info.thumbnail_url, holder.itemThumbnailView, displayImageOptions); if(info.thumbnail_url != null && !info.thumbnail_url.isEmpty()) {
imageLoader.displayImage(info.thumbnail_url, holder.itemThumbnailView, displayImageOptions);
} else {
holder.itemThumbnailView.setImageResource(R.drawable.dummy_thumbnail);
}
return convertView; return convertView;
} }

View File

@ -290,7 +290,7 @@ public class VideoItemDetailFragment extends Fragment {
View nextVideoView = null; View nextVideoView = null;
if(info.next_video != null) { if(info.next_video != null) {
nextVideoView = videoItemViewCreator nextVideoView = videoItemViewCreator
.getViewFromVideoInfoItem(null, nextVideoFrame, info.next_video, getContext()); .getViewFromVideoInfoItem(null, nextVideoFrame, info.next_video);
} else { } else {
activity.findViewById(R.id.detailNextVidButtonAndContentLayout).setVisibility(View.GONE); activity.findViewById(R.id.detailNextVidButtonAndContentLayout).setVisibility(View.GONE);
activity.findViewById(R.id.detailNextVideoTitle).setVisibility(View.GONE); activity.findViewById(R.id.detailNextVideoTitle).setVisibility(View.GONE);
@ -672,7 +672,7 @@ public class VideoItemDetailFragment extends Fragment {
ArrayList<StreamPreviewInfo> similar = new ArrayList<>(info.related_videos); ArrayList<StreamPreviewInfo> similar = new ArrayList<>(info.related_videos);
for (final StreamPreviewInfo item : similar) { for (final StreamPreviewInfo item : similar) {
View similarView = videoItemViewCreator View similarView = videoItemViewCreator
.getViewFromVideoInfoItem(null, similarLayout, item, getContext()); .getViewFromVideoInfoItem(null, similarLayout, item);
similarView.setClickable(true); similarView.setClickable(true);
similarView.setFocusable(true); similarView.setFocusable(true);

View File

@ -78,7 +78,7 @@ class VideoListAdapter extends BaseAdapter {
@Override @Override
public View getView(int position, View convertView, ViewGroup parent) { public View getView(int position, View convertView, ViewGroup parent) {
convertView = viewCreator.getViewFromVideoInfoItem(convertView, parent, videoList.get(position), context); convertView = viewCreator.getViewFromVideoInfoItem(convertView, parent, videoList.get(position));
if(listView.isItemChecked(position)) { if(listView.isItemChecked(position)) {
convertView.setBackgroundColor(ContextCompat.getColor(context,R.color.light_youtube_primary_color)); convertView.setBackgroundColor(ContextCompat.getColor(context,R.color.light_youtube_primary_color));