0

我正在做一个带有登录片段的应用程序,当我登录或注销时,它应该更新菜单项(仅限访客登录项,登录用户:主页、收藏夹、注销)

当我登录时,

仅在第二次尝试登录后没有任何变化(例如第一次单击仅登录)

当我注销它禁用(主页,收藏,注销)但不显示登录项。

这里的代码和照片

在此处输入图像描述

注销后:

在此处输入图像描述

代码 :

class MainActivity : AppCompatActivity(), NavigationView.OnNavigationItemSelectedListener {

lateinit var toogle : ActionBarDrawerToggle
lateinit var displayed_email: TextView

private lateinit var database: DatabaseReference
private lateinit var mAuth: FirebaseAuth




override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)



    val navigationView: NavigationView
    navigationView = findViewById(R.id.nav_view)
    navigationView.itemIconTintList=null
    navigationView.setNavigationItemSelectedListener(this)

    val headerView: View
    headerView = navigationView.getHeaderView(0)

    displayed_email = headerView.findViewById(R.id.nav_header_name)



    //Dokonczyc jutro
    //Dodac tez fragmenty z logowaniem i rejestracja
    //Kazdy ma miec swoje view modele


    toogle = ActionBarDrawerToggle(this, drawerLayout,findViewById(R.id.toolbar), R.string.open_menu, R.string.close_menu)
    drawerLayout.addDrawerListener(toogle)
    toogle.syncState()




    if(savedInstanceState==null){
        supportFragmentManager.beginTransaction().replace(R.id.fragment_container, LoginFragment()).commit()

    }

    updateUI()
}


override fun onNavigationItemSelected(item: MenuItem): Boolean {

    when(item.itemId){
        R.id.nav_login_item -> {
            Toast.makeText(applicationContext, "Login clicked",Toast.LENGTH_SHORT).show()
        }

        R.id.nav_logout_item->{
                mAuth.signOut()
                updateUI()
        }

        R.id.nav_home_item->{
            Toast.makeText(applicationContext, "Home clicked",Toast.LENGTH_SHORT).show()
        }
        R.id.nav_fav_item->{
            Toast.makeText(applicationContext, "Favorite clicked",Toast.LENGTH_SHORT).show()
        }
    }

    drawerLayout.closeDrawer(GravityCompat.START)
    return true
}



fun updateUI(){
    println("Updating UI")
    mAuth = FirebaseAuth.getInstance()
    database = FirebaseDatabase.getInstance().reference


    val navigationView: NavigationView
    navigationView = findViewById(R.id.nav_view)
    val nav_menu  = navigationView.menu


    if(mAuth.currentUser!=null) {

        displayed_email.setText(mAuth.currentUser!!.email.toString())
        displayed_email.textSize = 18F



        nav_menu.findItem(R.id.nav_login_item).isVisible = false
        nav_menu.findItem(R.id.nav_home_item).isVisible = true
        nav_menu.findItem(R.id.nav_fav_item).isVisible = true
        nav_menu.findItem(R.id.nav_logout_item).isVisible = true
    }else{

            displayed_email.setText("Guest")
            displayed_email.textSize= 30F


            //Naprawic pokazywanie login ikony itemu jak sie wylogujesz etc
        //Problem jest w zmianie stanu visibility podczas aplikacji
        //Niewazne w ktora strone



        nav_menu.findItem(R.id.nav_login_item).isVisible = true
        nav_menu.findItem(R.id.nav_home_item).isVisible = false
        nav_menu.findItem(R.id.nav_fav_item).isVisible = false
        nav_menu.findItem(R.id.nav_logout_item).isVisible = false


    }

  }

 }
4

2 回答 2

0

为了确保mAuth.currentUsernull,您需要在用户注销时添加一个侦听器,以便您可以更新菜单项的可见性;因为您可能会updateUI()在用户退出之前调用,所以mAuth.currentUser仍然有一个值。

所以在onNavigationItemSelected()回调中:添加这个监听器

R.id.nav_logout_item->{

    mAuth.signOut()
        
    AuthUI.getInstance()
            .signOut(this) // context
            .addOnCompleteListener {
            
                // User has been logged out 
                updateUI()
                
            }
}

并对登录行为执行相同操作以将可见性返回到菜单项。

于 2021-02-06T21:04:34.087 回答
0

我认为您无法动态更改项目的可见性。可能你只能 addItem() 和 removeItem()

如果我在你那里,我会尝试使用两个单独的菜单 xml 的解决方案,如下所示: Change NavigationView items when user is logged

解决方案很明确,并且根据答案的分数看起来它适用于人们。

于 2021-02-06T20:28:23.927 回答