From 3a5f09c61a87adb8dba2cc4a5366893886ba1c1d Mon Sep 17 00:00:00 2001
From: dupengyue <dupengyue@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期四, 20 七月 2017 17:31:40 +0800
Subject: [PATCH] 接口初步完成

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java |  164 ++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 104 insertions(+), 60 deletions(-)

diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java
index e753b04..f5d4cd8 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java
@@ -4,16 +4,23 @@
 
 import cn.com.basic.face.base.BaseApplication;
 import cn.com.basic.face.discern.common.CommonVariables;
+import cn.com.basic.face.discern.common.ResultBean;
+import cn.com.basic.face.discern.entity.Visit;
+import cn.com.basic.face.discern.entity.VisitDetail;
 import cn.com.basic.face.discern.query.condition.CheckInQueryCondition;
 import cn.com.basic.face.fragment.CheckInFragment;
+import cn.com.basic.face.service.sqlite.CheckInDao;
+import cn.com.basic.face.service.sqlite.DictionaryDao;
 import cn.com.basic.face.util.AppApi;
 
 import org.xutils.http.RequestParams;
 import org.xutils.x;
 
+import java.text.SimpleDateFormat;
 import java.util.ArrayList;
 import java.util.Collections;
 import java.util.Comparator;
+import java.util.Date;
 import java.util.List;
 
 import cn.com.basic.face.discern.common.BaseCommonCallBack;
@@ -33,80 +40,110 @@
         if (!BaseApplication.deviceAvailable) {
             return;
         }
-        params.setUri(AppApi.BASE_URL +AppApi.VISIT_ADD);
-        x.http().post(params, new BaseCommonCallBack() {
-            @Override
-            public void success() {
-                Toast.makeText(BaseApplication.getInstance(),"娣诲姞鎴愬姛", Toast.LENGTH_SHORT).show();
-                CheckInFragment.getInstance().resetForm();
-                if (visitReasonId == null || "".equals(visitReasonId)) {
-                    DictionaryMng.getInstance().loadVisitReasonList();
+        if (BaseApplication.getInstance().networkAvailable()) {
+            params.setUri(AppApi.BASE_URL +AppApi.VISIT_ADD);
+            x.http().post(params, new BaseCommonCallBack() {
+                @Override
+                public void success() {
+                    Toast.makeText(BaseApplication.getInstance(),"娣诲姞鎴愬姛", Toast.LENGTH_SHORT).show();
+                    CheckInFragment.getInstance().resetForm();
+                    if (visitReasonId == null || "".equals(visitReasonId)) {
+                        DictionaryMng.getInstance().loadVisitReasonList();
+                    }
                 }
+            });
+        } else {
+//            params.addBodyParameter(Visit.FieldNames.visitReasonId, visitReasonId);
+//            params.addBodyParameter(Visit.FieldNames.visitReason, fragment_check_in_right_visitor_reason.getText().toString());
+//            params.addBodyParameter(Visit.FieldNames.remark, fragment_check_in_right_remark.getText().toString());
+//            params.addBodyParameter(Visit.FieldNames.visitorId, visitor.getRegisterId());
+//            params.addBodyParameter(Visit.FieldNames.visiteeId, interviewee.getRegisterId());
+//            params.addBodyParameter(Visit.FieldNames.visitorCompanyId, visitor.getCompanyId());
+//            params.addBodyParameter(Visit.FieldNames.visiteeCompanyId, interviewee.getCompanyId());
+//            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+//            params.addBodyParameter(Visit.FieldNames.enterTime, sdf.format(new Date()));
+//            params.addBodyParameter(Visit.FieldNames.currentStateId, ""+ CommonVariables.VisitType.VISITOR_ENTERED);
+//            params.addBodyParameter(Visit.FieldNames.warning, visitor.getWarning());
+//
+//            params.addBodyParameter(VisitDetail.FieldNames.stateId, ""+CommonVariables.VisitType.VISITOR_ENTERED);
+//            params.addBodyParameter(VisitDetail.FieldNames.createTime, sdf.format(new Date()));
+//            params.addBodyParameter(VisitDetail.FieldNames.deviceId, BaseApplication.getInstance().getAndroidDevice().getDeviceId());
+            CheckInDao.getInstance().add(params);
+            if (visitReasonId == null || "".equals(visitReasonId)) {
+                DictionaryMng.getInstance().loadVisitReasonList();
             }
-        });
+        }
     }
 
     public void findCheckInLeftList(final boolean isVisitorList, final boolean isSortByDept, String searchText, final int pageNum, final boolean append) {
         if (!BaseApplication.deviceAvailable) {
             return;
         }
-        RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.CHECK_IN_QUERY);
-        String deviceCompanyId = BaseApplication.getInstance().getAndroidDevice().getCompanyId();
-        if (isVisitorList) {
-            params.addBodyParameter(CheckInQueryCondition.FieldNames.visitorCompanyId, deviceCompanyId);
+        if (BaseApplication.getInstance().networkAvailable()) {
+            RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.CHECK_IN_QUERY);
+            String deviceCompanyId = BaseApplication.getInstance().getAndroidDevice().getCompanyId();
+            if (isVisitorList) {
+                params.addBodyParameter(CheckInQueryCondition.FieldNames.visitorCompanyId, deviceCompanyId);
+            } else {
+                params.addBodyParameter(CheckInQueryCondition.FieldNames.employeeCompanyId, deviceCompanyId);
+            }
+            params.addBodyParameter(CheckInQueryCondition.FieldNames.username, searchText);
+            params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum+"");
+            params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, CommonVariables.Page.DEFAULT_PAGE_SIZE);
+            x.http().post(params, new BaseCommonCallBack() {
+                public void success() {
+                    findCheckInLeftListAfterReturn(resultBean, isVisitorList, isSortByDept, append);
+                }
+            });
         } else {
-            params.addBodyParameter(CheckInQueryCondition.FieldNames.employeeCompanyId, deviceCompanyId);
+            findCheckInLeftListAfterReturn(CheckInDao.getInstance().findCheckInLeftList(isVisitorList, searchText, pageNum), isVisitorList, isSortByDept, append);
         }
-        params.addBodyParameter(CheckInQueryCondition.FieldNames.username, searchText);
-        params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum+"");
-        params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, CommonVariables.Page.DEFAULT_PAGE_SIZE);
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                List<CheckInQueryItem> list = getList(CheckInQueryItem.class);
+    }
 
-                List prevList = null;
-                if (append) {
-                    if (isVisitorList) {
-                        prevList = CheckInFragment.getInstance().get_fragment_check_in_left_visitor().getPrevList();
-                    } else {
-                        prevList = CheckInFragment.getInstance().get_fragment_check_in_left_interviewee().getPrevList();
-                    }
-                    for (int i = 0; i < prevList.size(); i++) {
-                        Object item = prevList.get(i);
-                        if (item instanceof CheckInQueryItem) {
-                            list.add(0, (CheckInQueryItem) item);
-                        }
-                    }
-                }
+    public void findCheckInLeftListAfterReturn(ResultBean resultBean, boolean isVisitorList, boolean isSortByDept, boolean append) {
+        List<CheckInQueryItem> list = resultBean.getList(CheckInQueryItem.class);
 
-                sort(list, isSortByDept);
-                List itemList = new ArrayList();
-                String name = "";
-                String prev = "";
-                for (int i = 0; i < list.size(); i++) {
-                    CheckInQueryItem item = list.get(i);
-                    if (isSortByDept) {
-                        if (item.getDeptName() != null && item.getDeptName().length() > 0) {
-                            name = CharacterParser.getInstance().getSelling(item.getDeptName()).substring(0, 1);
-                        }
-                    } else {
-                        if (item.getUsername() != null && item.getUsername().length() > 0)
-                        name = CharacterParser.getInstance().getSelling(item.getUsername()).substring(0, 1);
-                    }
-                    if (!name.equals(prev)) {
-                        itemList.add(name);
-                    }
-                    itemList.add(item);
-                    prev = name;
-                }
-                addPageFooter(hasMorePages(), getPageNum(), itemList);
-                if (isVisitorList) {
-                    CheckInFragment.getInstance().get_fragment_check_in_left_visitor().show(itemList);
-                } else {
-                    CheckInFragment.getInstance().get_fragment_check_in_left_interviewee().show(itemList, isSortByDept, append);
+        List prevList = null;
+        if (append) {
+            if (isVisitorList) {
+                prevList = CheckInFragment.getInstance().get_fragment_check_in_left_visitor().getPrevList();
+            } else {
+                prevList = CheckInFragment.getInstance().get_fragment_check_in_left_interviewee().getPrevList();
+            }
+            for (int i = 0; i < prevList.size(); i++) {
+                Object item = prevList.get(i);
+                if (item instanceof CheckInQueryItem) {
+                    list.add(0, (CheckInQueryItem) item);
                 }
             }
-        });
+        }
+
+        sort(list, isSortByDept);
+        List itemList = new ArrayList();
+        String name = "";
+        String prev = "";
+        for (int i = 0; i < list.size(); i++) {
+            CheckInQueryItem item = list.get(i);
+            if (isSortByDept) {
+                if (item.getDeptName() != null && item.getDeptName().length() > 0) {
+                    name = CharacterParser.getInstance().getSelling(item.getDeptName()).substring(0, 1);
+                }
+            } else {
+                if (item.getUsername() != null && item.getUsername().length() > 0)
+                    name = CharacterParser.getInstance().getSelling(item.getUsername()).substring(0, 1);
+            }
+            if (!name.equals(prev)) {
+                itemList.add(name);
+            }
+            itemList.add(item);
+            prev = name;
+        }
+        addPageFooter(resultBean.hasMorePages(), resultBean.getPageNum(), itemList);
+        if (isVisitorList) {
+            CheckInFragment.getInstance().get_fragment_check_in_left_visitor().show(itemList);
+        } else {
+            CheckInFragment.getInstance().get_fragment_check_in_left_interviewee().show(itemList, isSortByDept, append);
+        }
     }
 
     private void sort(List<CheckInQueryItem> list, final boolean sortedByDept) {
@@ -143,4 +180,11 @@
     }
 
 
+    public void sendOfflineCheckInToServer() {
+
+    }
+
+    public boolean hasOfflineCheckInData() {
+        return CheckInDao.getInstance().hasOfflineCheckInData();
+    }
 }

--
Gitblit v1.8.0