I am trying to display a message in a new TextView when an adapter is empty, but I keep getting the following error: E/RecyclerView: No adapter attached; skipping layout.
The method where the error is occurring:
@BindView(R.id.courses_recycler_view)
RecyclerView coursesRecyclerView;
private CoursesAdapter coursesAdapter;
private List<CourseEntity> coursesData = new ArrayList<>();
private TextView noCourses;
private void initViewModel() {
final Observer<List<CourseEntity>> coursesObserver = new Observer<List<CourseEntity>>() {
@Override
public void onChanged(List<CourseEntity> courseEntities) {
coursesData.clear();
coursesData.addAll(courseEntities);
if(coursesAdapter == null) {
coursesAdapter = new CoursesAdapter(coursesData, TermDetailsActivity.this);
coursesRecyclerView.setAdapter(termsAdapter);
if (coursesAdapter.getItemCount() == 0) {
noCourses = new TextView(getApplicationContext());
noCourses.setId(R.id.noTerms);
ConstraintLayout.LayoutParams lp = new ConstraintLayout.LayoutParams(
ConstraintLayout.LayoutParams.WRAP_CONTENT,
ConstraintLayout.LayoutParams.WRAP_CONTENT);
noCourses.setLayoutParams(lp);
noCourses.setText("No terms found.");
noCourses.setTextColor(Color.parseColor("#000000"));
coursesLayout.addView(noCourses);
ConstraintSet cs = new ConstraintSet();
cs.constrainHeight(noCourses.getId(), ConstraintSet.WRAP_CONTENT);
cs.constrainWidth(noCourses.getId(), ConstraintSet.WRAP_CONTENT);
cs.connect(noCourses.getId(), ConstraintSet.LEFT, ConstraintSet.PARENT_ID, ConstraintSet.LEFT, 0);
cs.connect(noCourses.getId(), ConstraintSet.RIGHT, ConstraintSet.PARENT_ID, ConstraintSet.RIGHT, 0);
cs.connect(noCourses.getId(), ConstraintSet.TOP, ConstraintSet.PARENT_ID, ConstraintSet.TOP, 0);
cs.connect(noCourses.getId(), ConstraintSet.BOTTOM, ConstraintSet.PARENT_ID, ConstraintSet.BOTTOM, 0);
cs.applyTo(coursesLayout);
}
} else {
coursesAdapter.notifyDataSetChanged();
}
}
};
termDetailsViewModel = new ViewModelProvider(this).get(TermDetailsViewModel.class);
termDetailsViewModel.mCourses.observe(this, coursesObserver);
}
My adapter class:
public class CoursesAdapter extends RecyclerView.Adapter<CoursesAdapter.ViewHolder> {
String pattern = "MM/dd/yyyy";
DateFormat df = new SimpleDateFormat(pattern);
public final List<CourseEntity> mCourses;
private final Context mContext;
public CoursesAdapter(List<CourseEntity> mCourses, Context mContext) {
this.mCourses = mCourses;
this.mContext = mContext;
}
@NonNull
@Override
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
LayoutInflater inflater = LayoutInflater.from(parent.getContext());
View view = inflater.inflate(R.layout.courses_list_item, parent, false);
return new ViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
final CourseEntity course = mCourses.get(position);
String courseStartDate = df.format(course.getCourseStartDate());
String courseEndDate = df.format(course.getCourseEndDate());
holder.courseName.setText(course.getCourseName());
holder.courseStartDate.setText(courseStartDate);
holder.courseEndDate.setText(courseEndDate);
holder.courseListItem.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
}
});
}
@Override
public int getItemCount() {
return mCourses.size();
}
public class ViewHolder extends RecyclerView.ViewHolder {
@BindView(R.id.list_course_name)
TextView courseName;
@BindView(R.id.list_course_start_date)
TextView courseStartDate;
@BindView(R.id.list_course_end_date)
TextView courseEndDate;
@BindView(R.id.course_list_layout)
ConstraintLayout courseListItem;
public ViewHolder(@NonNull View itemView) {
super(itemView);
ButterKnife.bind(this, itemView);
}
}
}
The TextView is being added this way as this is a school project and part of the requirements is to be able to add views programatically.