From d0a0e8e242e293ad35dfbee1217f1103302818cd Mon Sep 17 00:00:00 2001
From: zuojincheng <lf_zuo@163.com>
Date: 星期四, 03 四月 2025 10:22:48 +0800
Subject: [PATCH] refactor(generallibrary):重构卡片和用户搜索功能

---
 generallibrary/src/main/java/com/dayu/general/activity/MainActivity.kt |   62 +++++++++++++++++++++++++++++-
 1 files changed, 59 insertions(+), 3 deletions(-)

diff --git a/generallibrary/src/main/java/com/dayu/general/activity/MainActivity.kt b/generallibrary/src/main/java/com/dayu/general/activity/MainActivity.kt
index 0f8a324..4e425e0 100644
--- a/generallibrary/src/main/java/com/dayu/general/activity/MainActivity.kt
+++ b/generallibrary/src/main/java/com/dayu/general/activity/MainActivity.kt
@@ -1,17 +1,27 @@
 package com.dayu.general.activity
 
 import android.os.Bundle
+import android.view.KeyEvent
 import android.view.LayoutInflater
+import android.widget.Toast
 import androidx.core.content.ContextCompat
 import androidx.fragment.app.Fragment
+import com.dayu.baselibrary.net.subscribers.SubscriberListener
+import com.dayu.baselibrary.utils.ToastUtil
+import com.dayu.general.BaseApplication
 import com.dayu.general.R
 import com.dayu.general.adapter.TabAdapter
+import com.dayu.general.bean.net.UserInfoResult
 import com.dayu.general.databinding.ActivityMainBinding
+import com.dayu.general.net.ApiManager
+import com.dayu.general.net.BaseResponse
 
 class MainActivity : BaseActivity() {
 
     var binding: ActivityMainBinding? = null
     private val fragments: ArrayList<Fragment> = ArrayList()
+    var mExitTime: Long = 0
+
     override fun onCreate(savedInstanceState: Bundle?) {
         super.onCreate(savedInstanceState)
         binding = ActivityMainBinding.inflate(LayoutInflater.from(this))
@@ -19,15 +29,42 @@
         setupFragments()
         initView()
         initTab()
+        getUserInfo()
+    }
 
 
+    private fun getUserInfo() {
+        // 浣跨敤姝g‘鐨勭被鍨嬪弬鏁�
+        ApiManager.getInstance().requestGetLoading(
+            this,
+            "base/user/getUserInfos/" + BaseApplication.userId,
+            UserInfoResult::class.java,
+            null,
+            object : SubscriberListener<BaseResponse<UserInfoResult>>() {
+                override fun onNext(t: BaseResponse<UserInfoResult>) {
+                    if (t.success) {
+                        BaseApplication.userName = t.content?.userName ?: ""
+                        BaseApplication.userPhone = t.content?.phone ?: ""
+                        BaseApplication.blockName = t.content?.blockName ?: ""
+                    } else {
+                        // 澶勭悊鎼滅储澶辫触鐨勬儏鍐�
+                        ToastUtil.show(t.msg)
+                    }
+                }
+
+                override fun onError(e: Throwable?) {
+                    super.onError(e)
+                    ToastUtil.show("鎼滅储澶辫触: ${e?.message ?: "鏈煡閿欒"}")
+                }
+            }
+        )
     }
 
 
     private fun initView() {
-        binding!!.BSCardLL.setOnClickListener { v -> changeBottomState(Tab.BSC) }
-        binding!!.rechargeLL.setOnClickListener { v -> changeBottomState(Tab.RECHARGE) }
-        binding!!.myLL.setOnClickListener { v -> changeBottomState(Tab.MY) }
+        binding!!.BSCardLL.setOnClickListener {  changeBottomState(Tab.BSC) }
+        binding!!.rechargeLL.setOnClickListener {  changeBottomState(Tab.RECHARGE) }
+        binding!!.myLL.setOnClickListener { changeBottomState(Tab.MY) }
     }
 
 
@@ -115,4 +152,23 @@
             }
         }
     }
+
+
+
+    //鐐瑰嚮涓ゆ閫�鍑虹▼搴� 鏈夋椂闂撮棿闅� 闂撮殧鍐呯偣鍑诲垯閫�鍑虹▼搴� 鍚﹀垯 鍒欐彁绀�
+    override fun onKeyDown(keyCode: Int, event: KeyEvent?): Boolean {
+        if (keyCode == KeyEvent.KEYCODE_BACK) {
+            if ((System.currentTimeMillis() - mExitTime) > 2000) {
+                Toast.makeText(this@MainActivity, "鍐嶆寜涓�娆¢��鍑虹▼搴�", Toast.LENGTH_SHORT)
+                    .show()
+                mExitTime = System.currentTimeMillis()
+            } else {
+                this@MainActivity.finish()
+            }
+            return true
+        }
+        return super.onKeyDown(keyCode, event)
+    }
+
+
 }
\ No newline at end of file

--
Gitblit v1.8.0