malli
malli

Reputation: 640

Nested fragments no view found for id

I am working on simple application having nested fragments with tab layout. Parent activity is LandingActivity. Inside of the LandingActivity i am calling LandingFragment. Inside of the LandingFragment i have following functionlity.

Tasks TAB Fragments flow is TasksMainFragment->TasksFragment->DetailFragment.

Pending TAB Fragments flow is PendingMainFragment->PendingFragment->PendingDetailFragment

The following code represents calling TasksFragment from TasksMainFragment.

TasksFragment fragment=new TasksFragment();
        FragmentManager fragmentManager = getActivity().getSupportFragmentManager();
        FragmentTransaction fragmentTransaction=fragmentManager.beginTransaction();
        fragmentTransaction.add(R.id.id_frame, fragment, "tasks");
        fragmentTransaction.addToBackStack("tasks");
        fragmentTransaction.commit();

Below code represents calling DetailFragment from TasksFragment. Basically TasksFragment contains recyclerview with some tasks. When user tap on the task it will open the DetailFragment of the task.

Fragment fragment = new DetailFragment();

        FragmentManager manager = ((FragmentActivity) mContext).getSupportFragmentManager();

        FragmentTransaction fragmentTransaction = manager.beginTransaction();
        Bundle bundle = new Bundle();
        ItemModel item = list.get(position);
        bundle.putSerializable("item", item);
        bundle.putBoolean("having", havingStartedService());
        fragment.setArguments(bundle);
        fragmentTransaction.replace(R.id.id_frame, fragment, "details");
        fragmentTransaction.addToBackStack("details");
        fragmentTransaction.commit();

When the user switch to pending tab same behaviour or same functionality will work. But the problem is when i open application after some time or open application first time on morning everyday i am facing this problem.

Other scenario when i change the screen orientation also i am facing this problem.

I am posting logcat below for better understanding.

12-20 16:33:01.658 21590-21590/com.naushad.kenostaff E/AndroidRuntime: FATAL EXCEPTION: main
                                                                       Process: com.naushad.kenostaff, PID: 21590
                                                                       java.lang.RuntimeException: Unable to start activity ComponentInfo{com.naushad.kenostaff/com.naushad.kenostaff.landing.LandingActivity}: java.lang.IllegalArgumentException: No view found for id 0x7f070059 (com.naushad.kenostaff:id/id_frame) for fragment TasksFragment{b980f0d #7 id=0x7f070059 tasks}
                                                                           at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2684)
                                                                           at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2751)
                                                                           at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:4556)
                                                                           at android.app.ActivityThread.-wrap19(ActivityThread.java)
                                                                           at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1502)
                                                                           at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                           at android.os.Looper.loop(Looper.java:154)
                                                                           at android.app.ActivityThread.main(ActivityThread.java:6186)
                                                                           at java.lang.reflect.Method.invoke(Native Method)
                                                                           at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:889)
                                                                           at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:779)
                                                                        Caused by: java.lang.IllegalArgumentException: No view found for id 0x7f070059 (com.naushad.kenostaff:id/id_frame) for fragment TasksFragment{b980f0d #7 id=0x7f070059 tasks}
                                                                           at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1293)
                                                                           at android.support.v4.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManager.java:1528)
                                                                           at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1595)
                                                                           at android.support.v4.app.BackStackRecord.executeOps(BackStackRecord.java:758)
                                                                           at android.support.v4.app.FragmentManagerImpl.executeOps(FragmentManager.java:2363)
                                                                           at android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2149)
                                                                           at android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2103)
                                                                           at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:2013)
                                                                           at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388)
                                                                           at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:607)
                                                                           at android.support.v7.app.AppCompatActivity.onStart(AppCompatActivity.java:181)
                                                                           at com.stfalcon.androidmvvmhelper.mvvm.activities.BindingActivity.onStart(BindingActivity.java:50)
                                                                           at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1249)
                                                                           at android.app.Activity.performStart(Activity.java:6701)
                                                                           at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2647)
                                                                           at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2751) 
                                                                           at android.app.ActivityThread.handleRelaunchActivity(ActivityThread.java:4556) 
                                                                           at android.app.ActivityThread.-wrap19(ActivityThread.java) 
                                                                           at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1502) 
                                                                           at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                           at android.os.Looper.loop(Looper.java:154) 
                                                                           at android.app.ActivityThread.main(ActivityThread.java:6186) 
                                                                           at java.lang.reflect.Method.invoke(Native Method) 
                                                                           at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:889) 
                                                                           at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:779) 

please give me some help on this issue. I am facing this problem from past 1 week, i tried so many ways but nothing is helpful. Thanks in advance.

Upvotes: 3

Views: 1476

Answers (1)

malli
malli

Reputation: 640

By using getChildFragmentManager() instead of getActivity.getSupportFragmentManager().i resolved both crashes.

For Opening TasksFragment i am using below code.

FragmentManager fragmentManager = getChildFragmentManager();

For opening DetailFragment i am using below code.

FragmentManager fragmentManager = getActivity().getSupportFragmentManager(); in tasks tab. In pending tab also i am following same way to resolve crashes.

Now i am facing other issue. I am checking which fragment is visible to the user in both TasksMainFragment and PendingMainFragment. Because i am opening two fragments in both main fragments. So depends upon that i want to update UI of the visible fragment.

By using below code i am checking which fragment is visible to the user.

    Fragment f1 = getActivity().getSupportFragmentManager().findFragmentById(R.id.id_frame);
if (f1 instanceof TasksFragment) {
                Log.d("", "GCM Receiverf1task:Tasks");
//                ((TasksFragment) f1).updateUI(message, order);
            }
            else if (f1 instanceof DetailFragment) {
                Log.d("", "GCM Receiverf1task:Tasks Details");
//                if(message.contains("Started") || message.contains("Completed") || message.contains("cancelled"))
//                    ((DetailFragment) f1).updateUI(message, order);
            }

But when i am in TasksFragment the above code is not working. When i am in DetailFragment above code is working fine. Please help me to resolve this issue or let me know if anything wrong in my way.

Upvotes: 2

Related Questions