Java – How to implement an OnClick item using firebase search query result items

How to implement an OnClick item using firebase search query result items… here is a solution to the problem.

How to implement an OnClick item using firebase search query result items

I’ve created a firebase search query and it works fine. But now I can’t seem to figure out how to do onlick and get project location. Here is my Firebase search activity:

mUserDatabase=FirebaseDatabase.getInstance().getReference("Users").child("UserProfile";
        mSearchField = findViewById(R.id.search_field);
        mSearchBtn = findViewById(R.id.search_btn);
        mResultList = findViewById(R.id.result_list);
        mResultList.setHasFixedSize(true);
        mResultList.setLayoutManager(new LinearLayoutManager(this));
        mSearchBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                String searchText = mSearchField.getText().toString();
                firebaseUserSearch(searchText);
            }
        });
    }
    private void firebaseUserSearch(String searchText) {
        Toast.makeText(SearchActivity.this, "Searching......", Toast.LENGTH_LONG).show();

Query firebaseSearchQuery = mUserDatabase.orderByChild("profession").startAt(searchText).endAt(searchText + "\uf8ff");

FirebaseRecyclerAdapter<Users, UsersViewHolder> firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Users, UsersViewHolder>(
                Users.class,
                R.layout.search_list_layout,
                UsersViewHolder.class,
                firebaseSearchQuery
        ) {
            @Override
            protected void populateViewHolder(UsersViewHolder viewHolder, Users model, int position) {

viewHolder.setDetails(getApplicationContext(), model.getUsername(), model.getSummary(), model.getImageurl());
            }
        };
        mResultList.setAdapter(firebaseRecyclerAdapter);
    }
    public static class UsersViewHolder extends RecyclerView.ViewHolder {
        View mView;
        private TextView user_name;
        private TextView user_summary;
        private ImageView user_image;
        public UsersViewHolder(View itemView) {
            super(itemView);
            mView = itemView;
        }

public void setDetails(Context ctx, String userName,String userSummary,String userImage){
            user_name = mView.findViewById(R.id.name_text);
             user_summary = mView.findViewById(R.id.summary_text);
            user_image = mView.findViewById(R.id.profile_image);
            user_name.setText(userName);
            user_summary.setText(userSummary);
            Glide.with(ctx).load(userImage).into(user_image);

itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    int pos = getAdapterPosition();
                    Snackbar.make(v, "Hello,How may i help you", Snackbar.LENGTH_LONG).setAction("Action", null).show();
                }
            });
        }

How content is displayed in a Details activity when a single item in a search result is clicked.

I tried the following at Parag Pawar’s suggestion, but it didn’t work >

       @Override
        protected void populateViewHolder(UsersViewHolder viewHolder, Users model, int position) {

viewHolder.setDetails(getApplicationContext(), model.getUsername(), model.getSummary(), model.getImageurl());
            final String each_key = getRef(position).getKey();

}

};

Then in my UserViewHolder I initialized onclick:

  mView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

Intent pDetail = new Intent(SearchActivity.this, ProfileDetail.class);
                Users each_key = each_key.get(getAdapterPosition());
                pDetail.putExtra(ProfileDetail.EXTRA_POSITION, each_key.getUserId());
                startActivity(pDetail);

}
        });

But I get the error message variable each_key might not have been initialized

Fixed my bug based on Parag Pawar’s top suggestion and implemented his onclick in populateView’holder, as follows:

 viewHolder.itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    /*Here use intent.putExtra() to send each_key on other activity and fetch data there*/
                    Toast.makeText(SearchActivity.this, "u clicked......" +position, Toast.LENGTH_LONG).show();
                    Intent each_key = new Intent(SearchActivity.this, ProfileDetail.class);
                    Users user = mResultList.get(position);
                    each_key.putExtra(ProfileDetail.EXTRA_POSITION, user.getUserId());
                    startActivity(each_key);

} });

But I’m getting the error here :

 Users user = mResultList.get(position);

Unable to resolve method ‘get(int)’

mReultList is the name of my Recyclerview, which I initialize as follows:

private RecyclerView mResultList;     

But I don’t know if I’m doing it right. I know I should attach the result to the adapter, but I don’t know how to do that. So I tried:

  listItems = new ArrayList<>();
    firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<UsersList>(listItems,this);

But that doesn’t seem to work either

Update the code

I created an array:

 private List<UsersList> listItems;//UsersList is my modal class

Then add that to my onCreate:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_search);
    listItems = new ArrayList<>();

Then I implemented putExtra: using this array as follows

Intent each_key = new Intent(TestSearch.this, ProfileDetail.class);
                    UsersList user = listItems.get(position);
                  Here use intent.putExtra() to send each_key on other activity and fetch data there
                    Toast.makeText(TestSearch.this, "u clicked......" +position, Toast.LENGTH_LONG).show();
                    each_key.putExtra(ProfileDetail.EXTRA_POSITION, user.getUserId());
                    startActivity(each_key);

But I get this error when I click on an item :

java.lang.IndexOutOfBoundsException: Index: 0, Size: 0
                  at java.util.ArrayList.get(ArrayList.java:411)
                  at com.ecard.ecard.search.TestSearch$2$1.onClick(TestSearch.java:94)
                  at android.view.View.performClick(View.java:5637)
                  at android.view.View$PerformClick.run(View.java:22429)
                  at android.os.Handler.handleCallback(Handler.java:751)
                  at android.os.Handler.dispatchMessage(Handler.java:95)
                  at android.os.Looper.loop(Looper.java:154)
                  at android.app.ActivityThread.main(ActivityThread.java:6119)
                  at java.lang.reflect.Method.invoke(Native Method)
                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)

Solution

To get the key from each item, execute it in populateViewholder
Example: –

final String each_key = getRef(position).getKey();

To set up a click listener on each item, execute it in populateViewholder

viewHolder.itemView.setOnClickListener(new View.OnClickListener() { 
@Override 
public void onClick(View v) { 
            /*Here use intent.putExtra() to send each_key on other activity and fetch data there*/

} }); }

Related Problems and Solutions