ironmantis7x
ironmantis7x

Reputation: 827

Null Pointer exception error inflating a View fragment due to Firebase reference error

I am stuck on this issue ....

I keep getting this particular error in my app:

java.lang.NullPointerException: Attempt to invoke virtual method 'com.google.firebase.database.ValueEventListener com.google.firebase.database.DatabaseReference.addValueEventListener(com.google.firebase.database.ValueEventListener)' on a null object reference

Now, what i am trying to do is post the results of items listed in a Firebase database.

here is my code for the making that list:

public class WatchListFragment extends Fragment {

    private static final String TAG = "WatchListFragment";
    private static final int NUM_GRID_COLUMNS = 3;
    private static final int GRID_ITEM_MARGIN = 5;

    //widgets
    private FrameLayout mFrameLayout;

    //reference for listening when items are added or removed from the watch list
    //vars
//    private DatabaseReference mReference = FirebaseDatabase.getInstance().getReference()
//            .child(getString(R.string.node_watch_list))
//            .child(FirebaseAuth.getInstance().getCurrentUser().getUid());

    private PostAdapter mAdapter;
    private ArrayList<Post> mPosts;

    private RecyclerView mRecyclerView;

    private DatabaseReference mReference;


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

        View view = inflater.inflate(R.layout.fragment_watch_list, container, true);
        mRecyclerView = (RecyclerView) view.findViewById(R.id.watchListRecyclerView);
        mFrameLayout = (FrameLayout) view.findViewById(R.id.watch_list_container);

        Log.d(TAG, "init: initializing.");
        mPosts = new ArrayList<>();

        //set the listener to the reference
        mReference.addValueEventListener(mLisenter);

        if(isAdded()){
            getResources().getString(R.string.app_name);
            mReference = FirebaseDatabase.getInstance().getReference()
                    .child(getString(R.string.node_watch_list))
                    .child(FirebaseAuth.getInstance().getCurrentUser().getUid());
        }

        mPosts = new ArrayList<Post>();
        mAdapter = new PostAdapter(this, mPosts);
        mRecyclerView = (RecyclerView) view.findViewById(R.id.watchListRecyclerView); //unsere (Recycleriew)Liste aus dem Design wird in eine RecyclerView ungewandelt
        mRecyclerView.setHasFixedSize(true);
        mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity())); //Hier könnten wir auch verschiedene Layouts festlegen. Bei der ListView, die vorher hatten, ist das Linearlayout fest eingestellt.
        mRecyclerView.addItemDecoration(new DividerItemDecoration(getActivity(), LinearLayoutManager.VERTICAL)); // Der Divider trennt die Zeilen mit einem Strich
        mRecyclerView.setAdapter(mAdapter); //Adapter wird gesetzt


//        RecyclerViewMargin itemDecorator = new RecyclerViewMargin(GRID_ITEM_MARGIN, NUM_GRID_COLUMNS);
//        mRecyclerView.addItemDecoration(itemDecorator);
//        GridLayoutManager gridLayoutManager = new GridLayoutManager(getActivity(), NUM_GRID_COLUMNS);
//        mRecyclerView.setLayoutManager(gridLayoutManager);
//        mAdapter = new PostListAdapter(getActivity(), mPosts);
//        mRecyclerView.setAdapter(mAdapter);

        return view;
    }

    public void viewPost(String postId){
        ViewPostFragment fragment = new ViewPostFragment();
        Activity activity = getActivity();
        if (isAdded() && activity != null) {


        FragmentTransaction transaction = getActivity().getSupportFragmentManager().beginTransaction();

        Bundle args = new Bundle();
        args.putString(getString(R.string.arg_post_id), postId);
        fragment.setArguments(args);

        transaction.replace(R.id.watch_list_container, fragment, getString(R.string.fragment_view_post));
        transaction.addToBackStack(getString(R.string.fragment_view_post));
        transaction.commit();

        mFrameLayout.setVisibility(View.VISIBLE);
        }
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        mReference.removeEventListener(mLisenter);
    }

    ValueEventListener mLisenter = new ValueEventListener() {
        @Override
        public void onDataChange(DataSnapshot dataSnapshot) {
            Log.d(TAG, "onDataChange: a change was made to this users watch lits node.");

            DatabaseReference reference = FirebaseDatabase.getInstance().getReference();

            Query query = reference.child("posts")
                    .orderByKey()
                    .equalTo(FirebaseAuth.getInstance().getCurrentUser().getUid());

            reference.addValueEventListener(new ValueEventListener() {
                @Override
                public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
                    DataSnapshot dShot = dataSnapshot.getChildren().iterator().next();

                    for (DataSnapshot dShot2 : dShot.getChildren()) {
                        Post post = (Post) dShot2.getValue(Post.class);
                        mPosts.add(post);
                    }

                    mAdapter.notifyDataSetChanged();


                }

                @Override
                public void onCancelled(@NonNull DatabaseError databaseError) {

                }
            });

        }

        @Override
        public void onCancelled(DatabaseError databaseError) {

        }
    };
}

The offending line of code flagged in the logcat is this: mReference.addValueEventListener(mLisenter);

I am not totally sure it is that is the issue. I have followed the tutorials and googled for an answer and I am still stuck as to why I am getting this particular issue

Upvotes: 0

Views: 124

Answers (1)

Kubik
Kubik

Reputation: 610

You have commented out initialization of mReference:

// private DatabaseReference mReference = FirebaseDatabase.getInstance().getReference() // .child(getString(R.string.node_watch_list)) // .child(FirebaseAuth.getInstance().getCurrentUser().getUid());

and instead initialize it to null:

private DatabaseReference mReference; is same as private DatabaseReference mReference = null;

Later in your onCreateView, you try to add listener to this null reference:

mReference.addValueEventListener(mLisenter); is same as null.addValueEventListener(mLisenter)

EDIT: Now I see, that you initialize mReference later in your code, try this:

if(isAdded()){
  getResources().getString(R.string.app_name);
  mReference = FirebaseDatabase.getInstance().getReference()
    .child(getString(R.string.node_watch_list))  
    .child(FirebaseAuth.getInstance().getCurrentUser().getUid());
  //move add listener here
  mReference.addValueEventListener(mLisenter);
}

Upvotes: 1

Related Questions