From a7820e2f1ee06a7b43b4d351cced3343d7e1a5e2 Mon Sep 17 00:00:00 2001 From: cloudroam <cloudroam> Date: 星期一, 31 三月 2025 08:55:52 +0800 Subject: [PATCH] fix 登录限制 --- app/src/main/java/com/example/firstapp/ui/home/HomeFragment.kt | 211 ++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 168 insertions(+), 43 deletions(-) diff --git a/app/src/main/java/com/example/firstapp/ui/home/HomeFragment.kt b/app/src/main/java/com/example/firstapp/ui/home/HomeFragment.kt index 230fb9c..481756d 100644 --- a/app/src/main/java/com/example/firstapp/ui/home/HomeFragment.kt +++ b/app/src/main/java/com/example/firstapp/ui/home/HomeFragment.kt @@ -8,6 +8,8 @@ import android.view.LayoutInflater import android.view.View import android.view.ViewGroup +import android.widget.TextView +import android.widget.Toast import androidx.core.content.ContextCompat import androidx.fragment.app.Fragment import androidx.lifecycle.ViewModelProvider @@ -17,7 +19,10 @@ import com.example.firstapp.activity.PickupActivity import com.example.firstapp.adapter.ExpressAdapter import com.example.firstapp.adapter.FinanceAdapter +import com.example.firstapp.adapter.CategorySelectorAdapter import com.example.firstapp.databinding.FragmentHomeBinding +import com.example.firstapp.databinding.DialogCategorySelectorBinding +import com.google.android.material.bottomsheet.BottomSheetDialog class HomeFragment : Fragment() { @@ -30,7 +35,9 @@ private lateinit var homeViewModel: HomeViewModel private lateinit var expressAdapter: ExpressAdapter private lateinit var financeAdapter: FinanceAdapter -// private lateinit var memorialAdapter: MemorialAdapter + private lateinit var incomeAdapter: FinanceAdapter + private lateinit var flightAdapter: FinanceAdapter + private lateinit var trainAdapter: FinanceAdapter private lateinit var dataUpdateReceiver: BroadcastReceiver //onCreateView这个方法创建后被调用,通常是初始化视图组件和观察者 @@ -46,15 +53,18 @@ override fun onViewCreated(view: View, savedInstanceState: Bundle?) { super.onViewCreated(view, savedInstanceState) - //通过 ViewModelProvider 获取 HomeViewModel 的实例,以便在视图中使用。 homeViewModel = ViewModelProvider(this).get(HomeViewModel::class.java) - // 加载广告图片 - //loadAdvertisements() + // 假设从某处获取用户ID +// val userId = getUserId() // 需要实现这个方法 + val userId ="123456" + homeViewModel.initialize(requireContext(), userId) + //调用这个方法来设置 RecyclerView用于设置 RecyclerView 的布局和适配器。 setupRecyclerViews() setupTabSwitching() //调用这个方法来观察 ViewModel 中的数据变化 observeViewModelData() + setupCategorySelector() } override fun onCreate(savedInstanceState: Bundle?) { @@ -107,13 +117,28 @@ startActivity(intent) } } -// -// // 纪念日列表 -// binding.memorialRecycler.apply { -// layoutManager = LinearLayoutManager(context) -// memorialAdapter = MemorialAdapter() -// adapter = memorialAdapter -// } + + // 添加新的 RecyclerView + binding.incomeRecycler.apply { + layoutManager = LinearLayoutManager(context) + incomeAdapter = FinanceAdapter() + adapter = incomeAdapter + visibility = View.GONE + } + + binding.flightRecycler.apply { + layoutManager = LinearLayoutManager(context) + flightAdapter = FinanceAdapter() + adapter = flightAdapter + visibility = View.GONE + } + + binding.trainRecycler.apply { + layoutManager = LinearLayoutManager(context) + trainAdapter = FinanceAdapter() + adapter = trainAdapter + visibility = View.GONE + } } private fun setupTabSwitching() { @@ -121,45 +146,63 @@ // 设置初始状态 tabExpress.setTextColor(ContextCompat.getColor(requireContext(), R.color.tab_selected)) tabFinance.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - others.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - + // 快递标签点击事件 tabExpress.setOnClickListener { + hideAllRecyclers() expressRecycler.visibility = View.VISIBLE - financeRecycler.visibility = View.GONE - tabExpress.setTextColor(ContextCompat.getColor(requireContext(), R.color.tab_selected)) - tabFinance.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - others.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - tabExpress.textSize = 16f - tabFinance.textSize = 14f - others.textSize = 14f + updateTabStyles(tabExpress) + homeViewModel.loadExpressData() } // 财务标签点击事件 tabFinance.setOnClickListener { - expressRecycler.visibility = View.GONE + hideAllRecyclers() financeRecycler.visibility = View.VISIBLE - tabExpress.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - tabFinance.setTextColor(ContextCompat.getColor(requireContext(), R.color.tab_selected)) - others.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - tabExpress.textSize = 14f - tabFinance.textSize = 16f - others.textSize = 14f - - // 在切换到财务标签时加载数据 - 添加这行 + updateTabStyles(tabFinance) homeViewModel.loadFinanceData() } - // 其他标签点击事件 - others.setOnClickListener { - expressRecycler.visibility = View.GONE - financeRecycler.visibility = View.GONE - tabExpress.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - tabFinance.setTextColor(ContextCompat.getColor(requireContext(), R.color.gray)) - others.setTextColor(ContextCompat.getColor(requireContext(), R.color.tab_selected)) - tabExpress.textSize = 14f - tabFinance.textSize = 14f - others.textSize = 16f + tabIncome.setOnClickListener { + hideAllRecyclers() + incomeRecycler.visibility = View.VISIBLE + updateTabStyles(tabIncome) + homeViewModel.loadIncomeData() + } + + tabFlight.setOnClickListener { + hideAllRecyclers() + flightRecycler.visibility = View.VISIBLE + updateTabStyles(tabFlight) + homeViewModel.loadFlightData() + } + + tabTrain.setOnClickListener { + hideAllRecyclers() + trainRecycler.visibility = View.VISIBLE + updateTabStyles(tabTrain) + homeViewModel.loadTrainData() + } + } + } + + private fun hideAllRecyclers() { + binding.apply { + expressRecycler.visibility = View.GONE + financeRecycler.visibility = View.GONE + incomeRecycler.visibility = View.GONE + flightRecycler.visibility = View.GONE + trainRecycler.visibility = View.GONE + } + } + + private fun updateTabStyles(selectedTab: TextView) { + binding.apply { + val tabs = listOf(tabExpress, tabFinance, tabIncome, tabFlight, tabTrain) + tabs.forEach { tab -> + tab.setTextColor(ContextCompat.getColor(requireContext(), + if (tab == selectedTab) R.color.tab_selected else R.color.gray)) + tab.textSize = if (tab == selectedTab) 16f else 14f } } } @@ -175,10 +218,56 @@ homeViewModel.financeItems.observe(viewLifecycleOwner) { items -> financeAdapter.submitList(items) } -// -// homeViewModel.memorialItems.observe(viewLifecycleOwner) { items -> -// memorialAdapter.submitList(items) -// } + + homeViewModel.incomeItems.observe(viewLifecycleOwner) { items -> + incomeAdapter.submitList(items) + } + + homeViewModel.flightItems.observe(viewLifecycleOwner) { items -> + flightAdapter.submitList(items) + } + + homeViewModel.trainItems.observe(viewLifecycleOwner) { items -> + trainAdapter.submitList(items) + } + + // 观察可见分类的变化 + homeViewModel.visibleCategories.observe(viewLifecycleOwner) { categories: List<String> -> + binding.apply { + // 隐藏所有标签 + tabExpress.visibility = View.GONE + tabFinance.visibility = View.GONE + tabIncome.visibility = View.GONE + tabFlight.visibility = View.GONE + tabTrain.visibility = View.GONE + + // 根据选中的分类显示对应的标签 + categories.forEachIndexed { index: Int, categoryName: String -> + when (categoryName) { + "快递" -> { + tabExpress.visibility = View.VISIBLE + if (index == 0) tabExpress.performClick() + } + "还款" -> { + tabFinance.visibility = View.VISIBLE + if (index == 0) tabFinance.performClick() + } + "收入" -> { + tabIncome.visibility = View.VISIBLE + if (index == 0) tabIncome.performClick() + } + "航班" -> { + tabFlight.visibility = View.VISIBLE + if (index == 0) tabFlight.performClick() + } + "火车票" -> { + tabTrain.visibility = View.VISIBLE + if (index == 0) tabTrain.performClick() + } + } + } + } + } } override fun onResume() { @@ -220,4 +309,40 @@ .load("http://192.168.1.235:9999/advertisement/down.png") .into(binding.bottomAdBanner) } + + private fun setupCategorySelector() { + binding.categoryButton.setOnClickListener { + // TODO: 检查会员状态 + if (true) { // 临时设置为true,实际应该检查会员状态 + showCategorySelectorDialog() + } else { + // 显示会员提示 + Toast.makeText(requireContext(), "该功能仅对会员开放", Toast.LENGTH_SHORT).show() + } + } + } + + private fun showCategorySelectorDialog() { + val dialog = BottomSheetDialog(requireContext()) + val dialogBinding = DialogCategorySelectorBinding.inflate(layoutInflater) + dialog.setContentView(dialogBinding.root) + + val adapter = CategorySelectorAdapter() + dialogBinding.categoryRecyclerView.apply { + layoutManager = LinearLayoutManager(context) + this.adapter = adapter + } + + // 加载现有分类 + homeViewModel.categories.observe(viewLifecycleOwner) { categories -> + adapter.setCategories(categories) + } + + dialogBinding.saveButton.setOnClickListener { + homeViewModel.saveCategories(adapter.getCategories()) + dialog.dismiss() + } + + dialog.show() + } } \ No newline at end of file -- Gitblit v1.9.3