Я новичок в разработке для Android и мне нужна помощь с заполнением данных из базы данных Firebase Realtime в FirebaseRecyclerAdapter
.
В моем приложении есть список семинаров.Пользователь может войти в мое тестовое приложение с помощью аутентификации GitHub, и я получаю электронное письмо пользователя для входа или выхода из мастерской, если нажата соответствующая кнопка.
Так что в какой-то момент моя мастерская содержит списокпользователей в соответствии с примером ниже в Firebase.
Проблема заключается в том, что мне нужно выделить семинары, в которые пользователи уже вошли, в представлении переработчика.
Основная проблема, с которой я сталкиваюсь, - это заполнениеинформация для каждой мастерской.Я могу легко заставить пользователей перечислять отдельно позже, но я не знаю, как сделать это в одном хорошем объекте Workshop с самого начала.
Я потерян.Пожалуйста, помогите.
Мой FirebaseRecyclerAdapter
:
public class WorkshopsFirebaseRecyclerAdapter extends FirebaseRecyclerAdapter<Workshop, WorkshopViewHolder> {
private Context mContext;
private ProgressBar progressBar;
public WorkshopsFirebaseRecyclerAdapter(FirebaseRecyclerOptions<Workshop> options, Context context, ProgressBar view) {
super(options);
mContext = context;
progressBar = view;
}
@Override
public void onDataChanged() {
if (progressBar != null) {
progressBar.setVisibility(View.GONE);
}
}
@Override
protected void onBindViewHolder(@NonNull final WorkshopViewHolder holder, final int position, @NonNull final Workshop model) {
final Workshop workshop = getItem(position);
final String id = getRef(position).getKey();
holder.date.setText(getUserFriendlyDate(workshop.getDate()));
holder.description.setText(workshop.getDescription());
if (workshop.getWorkshopAttendants() != null){
Timber.i("onBindViewHolder workshop is %s", workshop.toString());
}
holder.getView().setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
TinyDB tinyDB = new TinyDB(mContext);
tinyDB.putObject(mContext.getString(R.string.workshop_tinydb_key), workshop);
Intent intent = new Intent(mContext, WorkshopDetailsActivity.class);
intent.putExtra(mContext.getString(R.string.open_workshop_details_intent_key),
WorkshopDetailsActivity.INTENT_OPEN_UPDATE_WORKSHOP_DETAILS);
intent.putExtra(mContext.getString(R.string.current_workshop_id_key), id);
mContext.startActivity(intent);
}
});
}
@Override
public WorkshopViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
View itemView = LayoutInflater.from(viewGroup.getContext())
.inflate(R.layout.workshop_rv_item, viewGroup, false);
return new WorkshopViewHolder(itemView);
}
private String getUserFriendlyDate(String dateOld){
Date date = new Date();
SimpleDateFormat oldDateFormat = new SimpleDateFormat("dd-MM-yyyy", Locale.UK);
try {
date = oldDateFormat.parse(dateOld);
} catch (ParseException e) {
e.printStackTrace();
}
SimpleDateFormat newDateFormat = new SimpleDateFormat("dd MMM yyyy", Locale.UK);
return newDateFormat.format(date);
}
}
Мой метод, в котором я устанавливаю адаптер и запрос:
private void loadWorkshopsForCity(String city) {
Query query;
if (city.equals(getString(R.string.spinner_cities_all_value))) {
query = FirebaseDatabase.getInstance()
.getReference(getString(R.string.firebase_root_name))
.child(getString(R.string.firebase_workshops_root_name))
.limitToLast(50);
} else {
query = FirebaseDatabase.getInstance()
.getReference(getString(R.string.firebase_root_name))
.child(getString(R.string.firebase_workshops_root_name))
.orderByChild(getString(R.string.firebase_workshop_city_name_key))
.equalTo(city);
}
query.addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
for (DataSnapshot workshopSnapshot : dataSnapshot.getChildren()) {
Workshop workshop = workshopSnapshot.getValue(Workshop.class);
for(DataSnapshot usersSnapshot : workshopSnapshot.child("users").getChildren()){
if (usersSnapshot.exists()){
WorkshopAttendant user = usersSnapshot.getValue(WorkshopAttendant.class);
if (user!=null){
users.add(user);
}
}
}
if (users.size()!=0){
workshop.setWorkshopAttendants(users);
}
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
Timber.i(databaseError.toException());
}
});
FirebaseRecyclerOptions<Workshop> options =
new FirebaseRecyclerOptions.Builder<Workshop>()
.setQuery(query, Workshop.class)
.build();
if (adapter != null) {
adapter.stopListening();
}
adapter = new WorkshopsFirebaseRecyclerAdapter(options, this, progressBar);
mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
mRecyclerView.setAdapter(adapter);
adapter.startListening();
}
моя Мастерская, которая содержит список операторов:
public class Workshop {
private String date;
private String time;
private String description;
private String name;
private String address;
private String city;
private List<WorkshopAttendant> workshopAttendants;
private boolean isChecked;
// empty constructor for firebase
public Workshop() {
}
public Workshop(String date, String time, String description, String name, String address, String city,
List<WorkshopAttendant> workshopAttendants) {
this.date = date;
this.time = time;
this.description = description;
this.name = name;
this.address = address;
this.city = city;
this.workshopAttendants = workshopAttendants;
} .....
и другой WorkshopAttendant, который должен находиться внутри объекта Workshop.
public class WorkshopAttendant {
private String email;
private int role; // 1 - coach ; 0 - organiser ; 2 - student
public WorkshopAttendant(String userEmail, int role) {
this.email = userEmail;
this.role = role;
}
// for firebase
public WorkshopAttendant() {
}