From 58a4a54c62c65cab92c85fd3edeff832e4572ead Mon Sep 17 00:00:00 2001
From: nilupeng <qingingrunt2010@qq.com>
Date: Tue, 09 Aug 2022 10:59:47 +0000
Subject: [PATCH] gson 转换日期问题 接入登录接口 修改图标和启动页

---
 app/src/main/java/com/runt/open/mvvm/base/model/LoadPageViewModel.java |   34 +++++++++++++++++++++++++++-------
 1 files changed, 27 insertions(+), 7 deletions(-)

diff --git a/app/src/main/java/com/runt/open/mvvm/base/model/LoadPageViewModel.java b/app/src/main/java/com/runt/open/mvvm/base/model/LoadPageViewModel.java
index 5560ad5..a001534 100644
--- a/app/src/main/java/com/runt/open/mvvm/base/model/LoadPageViewModel.java
+++ b/app/src/main/java/com/runt/open/mvvm/base/model/LoadPageViewModel.java
@@ -2,10 +2,15 @@
 
 import androidx.lifecycle.MutableLiveData;
 
+import com.google.gson.Gson;
 import com.runt.open.mvvm.data.HttpApiResult;
 import com.runt.open.mvvm.data.PageResult;
 import com.runt.open.mvvm.retrofit.observable.HttpObserver;
 
+import org.json.JSONObject;
+
+import java.lang.reflect.ParameterizedType;
+import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
 
@@ -13,20 +18,35 @@
  * 分页
  * Created by Administrator on 2021/11/3 0003.
  */
-public abstract class LoadPageViewModel<RESULT extends PageResult> extends BaseViewModel {
+public abstract class LoadPageViewModel<D> extends BaseViewModel {
 
     public final int SIZE = 10;
-    private MutableLiveData<List> liveData = new MutableLiveData<>();
+    private MutableLiveData<List<D>> liveData = new MutableLiveData<>();
     private MutableLiveData liveFailed = new MutableLiveData();
 
+    /**
+     * 请求地址
+     * @return
+     */
     protected abstract String requestUrl();
 
+    /**
+     * 数据请求
+     * @param page  页数
+     * @param param 请求参数
+     */
     public void requestData(int page,Map param){
-        httpObserverOn( commonApi.getPageData(requestUrl(), page, SIZE, param), new HttpObserver<RESULT>() {
-
+        final ParameterizedType type = (ParameterizedType) this.getClass().getGenericSuperclass();
+        Class<D> entityClass = (Class<D>) type.getActualTypeArguments()[0];
+        httpObserverOn( commonApi.getPageData(requestUrl(), page, SIZE, param), new HttpObserver<PageResult>() {
             @Override
-            protected void onSuccess(RESULT data) {
-                liveData.postValue(data.rows);
+            protected void onSuccess(PageResult data) {
+                //数据转换
+                List<D> list = new ArrayList<>();
+                for(Object map : data.rows){
+                    list.add(new Gson().fromJson(new JSONObject((Map) map).toString(),entityClass));
+                }
+                liveData.postValue(list);
             }
 
             @Override
@@ -37,7 +57,7 @@
         });
     }
 
-    public MutableLiveData<List> getLiveData(){
+    public MutableLiveData<List<D>> getLiveData(){
         return liveData;
     }
 

--
Gitblit v1.9.1