Обновить поле Firestore внутри RecycleView - PullRequest
0 голосов
/ 03 мая 2019

Я хочу обновить поле внутри моего Firestore, когда происходит OnClick. Проблема в том, что я не знаю, как получить идентификатор моего фактического элемента, потому что это автоматически сгенерировано. (Я хочу обновить назначенное поле ). Структура Firestore следующая: enter image description here:

Фрагмент кода моего адаптера моего RecyclerView:

public class AvailableTaskListAdapter extends RecyclerView.Adapter<AvailableTaskListAdapter.ViewHolder> {
public List<Task> taskList;
Activity mActivity;
FirebaseFirestore firestore;

public AvailableTaskListAdapter(List<Task> taskList, Context mContext, FirebaseFirestore firestore) {
    this.taskList = taskList;
    this.mActivity = (Activity) mContext;
    this.firestore = firestore;
}

@NonNull
@Override
public AvailableTaskListAdapter.ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
    View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.layout_available_tasks_item, viewGroup, false);
    view.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {


            //HERE I want to be happening the update of my field.


        }
    });
    return new AvailableTaskListAdapter.ViewHolder(view);

}

@Override
public void onBindViewHolder(@NonNull AvailableTaskListAdapter.ViewHolder viewHolder, int i) {
    viewHolder.tvEmail.setText(taskList.get(i).getUser());
    ...
}

@Override
public int getItemCount() {
    return taskList.size();
}

public class ViewHolder extends RecyclerView.ViewHolder {
    View mView;

    public TextView tvEmail;
    ...

    public ViewHolder(View itemView) {
        super(itemView);
        mView = itemView;

        tvEmail = (TextView) mView.findViewById(R.id.tvEmail);
        ...
    }
}

public void showDialog(final Activity activity) {
    final Dialog dialog = new Dialog(activity);
    dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
    dialog.setCancelable(false);
    dialog.setContentView(R.layout.dialog_apply_to_task);
    dialog.getWindow().setBackgroundDrawable(new ColorDrawable(android.graphics.Color.TRANSPARENT));

    FrameLayout mDialogNo = dialog.findViewById(R.id.frmNo);
    mDialogNo.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {

            Toast.makeText(activity.getApplicationContext(),"Cancel" ,Toast.LENGTH_SHORT).show();
            dialog.dismiss();
        }
    });

    FrameLayout mDialogOk = dialog.findViewById(R.id.frmOk);
    mDialogOk.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Toast.makeText(activity.getApplicationContext(),"Okay" ,Toast.LENGTH_SHORT).show();
            dialog.cancel();
        }
    });

    dialog.show();
}}

Ответы [ 2 ]

0 голосов
/ 08 мая 2019

Как я вижу в вашем коде, вы получаете список Task объектов, но не получаете ключ каждого документа. Чтобы решить эту проблему, вам необходимо отслеживать ключи и значения документов в вашем адаптере. Рекомендуемый способ сделать это - сохранить два списка, один с ключами, а другой со значениями.

Итак, сначала вы добавляете List<String> для ключей в вашем классе адаптера следующим образом:

private List<Task> taskList;
private List<String> keys;

А затем измените конструктор, чтобы он принимал оба списка:

public AvailableTaskListAdapter(List<Task> taskList, List<String> keys, Context mContext, FirebaseFirestore firestore) {
//                                                                ^^^^
    this.taskList = taskList;
    this.keys = keys; //Intialize the the second list
    this.mActivity = (Activity) mContext;
    this.firestore = firestore;
}

Затем, когда вы создаете новый объект вашего класса AvailableTaskListAdapter, рядом с taskList, передайте также список keys.

AvailableTaskListAdapter adapter = new AvailableTaskListAdapter(taskList, keys, mContext, firestore);

Как правило, список ключей создается так же, как вы создаете список значений. Поэтому, когда вы перебираете коллекцию в цикле для создания списка Task объекта, получите также идентификатор, подобный этому:

FirebaseFirestore rootRef = FirebaseFirestore.getInstance();
CollectionReference tasksRef = rootRef.collection("tasks");
tasksRef.get().addOnCompleteListener(new OnCompleteListener<QuerySnapshot>() {
    @Override
    public void onComplete(@NonNull Task<QuerySnapshot> task) {
        if (task.isSuccessful()) {
            List<Task> taskList = new ArrayList<>();
            List<String> keys = new ArrayList<>();
            for (QueryDocumentSnapshot document : task.getResult()) {
                Task t = document.toObject(Task.class);
                taskList.add(t);
                String key = document.getId();
                keys.add(key);
            }

            //Create/notify the adapter
        }
    }
});
0 голосов
/ 03 мая 2019

Просто сохраните идентификатор документа в объекте Task.добавьте новое поле наподобие «taskId» к объекту задачи, а при получении задачи из firebase используйте пример document.id:

db.collection("cities")
    .whereEqualTo("capital", true)
    .get()
    .addOnSuccessListener { documents ->
        for (document in documents) {
            Log.d(TAG, "${document.id} => ${document.data}")
        }
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...