Foxtrot 1-5
Foxtrot 1-5

Reputation: 379

Android kotlin show Navigation Drawer icon instead of Back Button in some fragment

I want to show navigation drawer icon instead of Back button on a certain fragment. I created the App with Navigation graph.

Let's say i have 2 fragments (LoginFragment and DashboardFragment) and one activity (MainActivity)

MainActivity.kt

class MainActivity : AppCompatActivity() {

    lateinit var drawerLayout: DrawerLayout

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        val binding = DataBindingUtil.setContentView<ActivityMainBinding>(this, R.layout.activity_main)
        drawerLayout = binding.drawerLayout

        val navController = this.findNavController(R.id.myNavHostFragment)

        // prevent nav gesture if not on start destination
        navController.addOnDestinationChangedListener { nc: NavController, nd: NavDestination, args: Bundle? ->
            if (nd.id == nc.graph.startDestination) {
                drawerLayout.setDrawerLockMode(DrawerLayout.LOCK_MODE_UNLOCKED)
            } else {
                drawerLayout.setDrawerLockMode(DrawerLayout.LOCK_MODE_LOCKED_CLOSED)
            }
        }

        NavigationUI.setupActionBarWithNavController(this, navController, drawerLayout)
        NavigationUI.setupWithNavController(binding.navView, navController)

    }


    // Set up the back button on action bar
    override fun onSupportNavigateUp(): Boolean {
        val navController = this.findNavController(R.id.myNavHostFragment)

        return NavigationUI.navigateUp(navController, drawerLayout)
    }
}

LoginFragment.kt

class LoginFragment : Fragment() {

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        val binding:FragmentLoginBinding = DataBindingUtil.inflate(inflater,
            R.layout.fragment_login, container, false)

        // Hide the Action bar
        (activity as AppCompatActivity).supportActionBar?.hide()

        binding.loginButton.setOnClickListener {
           //Some unimportant validation
        }


        return binding.root
    }

}

DashboardFragment.kt

class DashboardFragment : Fragment() {

    lateinit var binding : FragmentDashboardBinding

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {

        // Binding object for this fragment and the layout
        binding = DataBindingUtil.inflate(inflater,
            R.layout.fragment_dashboard, container, false)

        //Navigate to Product stock fragment when clicked
        binding.productStockButton.setOnClickListener(Navigation.createNavigateOnClickListener(
            R.id.action_dashboardFragment_to_productStockOutletList
        ))

        //Navigate to Switching History fragment when clicked
        binding.switchingHistoryButton.setOnClickListener(Navigation.createNavigateOnClickListener(
            R.id.action_dashboardFragment_to_switchingHistoryFragment
       ))

        //Navigate to Outlet List fragment for Outstanding Product when clicked
        binding.outstandingOrderButton.setOnClickListener(Navigation.createNavigateOnClickListener(
            R.id.action_dashboardFragment_to_outletListFragment
        ))


        // Set action bar title to "Main Dashboard"
        (activity as AppCompatActivity).supportActionBar?.title = "Main Dashboard"

        // Declare that this fragment has menu
        setHasOptionsMenu(true)

        (activity as AppCompatActivity).supportActionBar?.show()
        (activity as AppCompatActivity).supportActionBar?.setDisplayHomeAsUpEnabled(false)


        //Return.... i don't know.
        return binding.root
    }

    override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) {
        super.onCreateOptionsMenu(menu, inflater)
        inflater?.inflate(R.menu.nav_overflow_menu, menu)
    }
}

And this is my Navigation graph (I set up LoginFragment as home) enter image description here

I want to show the navigation drawer in the DashboardFragment instead of LoginFragment. (With LoginFragment still be the start of the graph). I already hide the Up button of the DashboardFragment

This is the current look of the dashboard. As you can see that the back button is already gone.

Is there anything i can do with it ? If there is something unclear let me know.

Upvotes: 1

Views: 1824

Answers (1)

Mohammed Alaa
Mohammed Alaa

Reputation: 3320

try this I hope that it will help you, this will hide actionBar on LoginFragment as it's the startDestination on graph and show it otherwise

class MainActivity : AppCompatActivity() {

private lateinit var appBarConfiguration: AppBarConfiguration

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)
    val toolbar: Toolbar = findViewById(R.id.toolbar)
    setSupportActionBar(toolbar)

    val drawerLayout: DrawerLayout = findViewById(R.id.drawer_layout)
    val navView: NavigationView = findViewById(R.id.nav_view)
    val navController = findNavController(R.id.nav_host_fragment)



    // prevent nav gesture if not on start destination
    navController.addOnDestinationChangedListener { nc: NavController, nd: NavDestination, args: Bundle? ->
        if (nd.id == nc.graph.startDestination) {
         drawerLayout.setDrawerLockMode(DrawerLayout.LOCK_MODE_LOCKED_CLOSED)
         supportActionBar?.hide()
        } else {
         supportActionBar?.show()
         drawerLayout.setDrawerLockMode(DrawerLayout.LOCK_MODE_UNLOCKED)
        }
    }

     // here this ids are form fragment which should show navigation icon
    appBarConfiguration = AppBarConfiguration(setOf(
            R.id.nav_home,R.id.nav_gallery, R.id.nav_slideshow), drawerLayout)
    setupActionBarWithNavController(navController, appBarConfiguration)
    navView.setupWithNavController(navController)
}

override fun onCreateOptionsMenu(menu: Menu): Boolean {
    // Inflate the menu; this adds items to the action bar if it is present.
    menuInflater.inflate(R.menu.main, menu)
    return true
}

override fun onSupportNavigateUp(): Boolean {
    val navController = findNavController(R.id.nav_host_fragment)
    return navController.navigateUp(appBarConfiguration) || super.onSupportNavigateUp()
 }
}

Upvotes: 3

Related Questions