From e09e9f8a34cbc99a33dfa9ef1792b0025575c3a8 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期二, 01 八月 2017 11:41:19 +0800
Subject: [PATCH] 

---
 VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java |  315 +++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 226 insertions(+), 89 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 c26de98..588f975 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
@@ -1,28 +1,43 @@
 package cn.com.basic.face.service;
 
+import android.database.Cursor;
+import android.database.sqlite.SQLiteDatabase;
 import android.widget.Toast;
 
 import cn.com.basic.face.base.BaseApplication;
-import cn.com.basic.face.fragment.HomeFragment;
+import cn.com.basic.face.base.MainActivity;
+import cn.com.basic.face.discern.common.CommonVariables;
+import cn.com.basic.face.discern.common.ResultBean;
+import cn.com.basic.face.discern.common.SqliteSqlBean;
+import cn.com.basic.face.discern.entity.Visit;
+import cn.com.basic.face.discern.entity.VisitDetail;
+import cn.com.basic.face.discern.query.condition.AttendanceQueryCondition;
+import cn.com.basic.face.discern.query.condition.CheckInQueryCondition;
+import cn.com.basic.face.discern.query.item.OfflineAttenderRegisterItem;
+import cn.com.basic.face.discern.query.item.OfflineVisitItem;
 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;
-import cn.com.basic.face.discern.query.condition.VisitorQueryCondition;
 import cn.com.basic.face.discern.query.item.CheckInQueryItem;
+import cn.com.basic.face.util.CharacterParser;
+import cn.com.basic.face.util.DateUtil;
+import cn.com.basic.face.util.SqliteSqlUtil;
 
-/**
- * 鏉ヨ鐧昏
- */
-
-public class CheckInMng {
+//鐧昏
+public class CheckInMng extends BaseMng {
 
     public static CheckInMng instance = new CheckInMng();
 
@@ -30,102 +45,224 @@
         return instance;
     }
 
-    /**
-     * 鏌ヨ鏉ヨ浜哄憳鍒楄〃
-     */
-    public void findVisitorList(String pageNum, String name, final boolean isClear) {
-        //id锛屽悕绉帮紝澶村儚璺緞锛岃仈绯荤數璇濓紝鍏徃鍚嶇О锛岃瘉浠剁紪鍙�
-        RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.CheckInQuery);
-        params.addBodyParameter(VisitorQueryCondition.FieldNames.notCompanyId, BaseApplication.getInstance().getPlace().getCompanyId());
-        params.addBodyParameter(VisitorQueryCondition.FieldNames.name, name);
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                //CheckInFragment.getInstance().listChanged(getList(CheckInQueryItem.class), isClear);
-            }
-        });
-    }
-
-    /**
-     * 鏌ヨ鏉ヨ浜哄憳鍒楄〃
-     */
-    public void findVisitorList() {
-        //id锛屽悕绉帮紝澶村儚璺緞锛岃仈绯荤數璇濓紝鍏徃鍚嶇О锛岃瘉浠剁紪鍙�
-        RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.CheckInQuery);
-        params.addBodyParameter(VisitorQueryCondition.FieldNames.notCompanyId, BaseApplication.getInstance().getPlace().getCompanyId());
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                //HomeFragment.getInstance().visitorListChanged(getList(CheckInQueryItem.class));
-            }
-        });
-    }
-
-    /**
-     * 鏌ヨ琚闂汉鍛樺垪琛�
-     */
-    public void findIntervieweeList(String pageNum, String name, final boolean isClear) {
-        RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.CheckInQuery);
-        params.addBodyParameter(VisitorQueryCondition.FieldNames.companyId, BaseApplication.getInstance().getPlace().getCompanyId());
-        params.addBodyParameter(VisitorQueryCondition.FieldNames.name, name);
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                //CheckInFragment.getInstance().listChanged(getList(CheckInQueryItem.class), isClear);
-            }
-        });
-    }
-
-    /**
-     * 娣诲姞璁垮璁板綍
-     * @param params
-     */
-    public void add(RequestParams params) {
-
-        params.setUri(AppApi.BASEURL+AppApi.CHECK_IN_ADD);
-        x.http().post(params, new BaseCommonCallBack() {
-            @Override
-            public void success() {
-                Toast.makeText(BaseApplication.getInstance(),"娣诲姞鎴愬姛", Toast.LENGTH_SHORT).show();
-            }
-        });
-
-    }
-
-    public void findCheckInLeftList(final boolean isVisitorList, final boolean isSortByDept, String searchText) {
-        RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.CheckInQuery);
-        if (isVisitorList) {
-            params.addBodyParameter(VisitorQueryCondition.FieldNames.notCompanyId, BaseApplication.getInstance().getPlace().getCompanyId());
-        } else {
-            params.addBodyParameter(VisitorQueryCondition.FieldNames.companyId, BaseApplication.getInstance().getPlace().getCompanyId());
+    public void add(RequestParams params, final String visitReasonId, OfflineVisitItem offlineVisitItem) {
+        if (!BaseApplication.deviceAvailable) {
+            return;
         }
-        params.addBodyParameter(VisitorQueryCondition.FieldNames.name, searchText);
-        x.http().post(params, new BaseCommonCallBack() {
-            public void success() {
-                List<CheckInQueryItem> list = getList(CheckInQueryItem.class);
-                sort(list, isSortByDept);
-                CheckInFragment.getInstance().get_fragment_check_in_left_list_view().show(list, isVisitorList);
+        if (BaseApplication.getInstance().networkAvailable()) {
+            params.setUri(AppApi.BASE_URL +AppApi.VISIT_ADD);
+            params.addBodyParameter(Visit.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+            x.http().post(params, new BaseCommonCallBack() {
+                @Override
+                public void success() {
+                    SqliteSqlUtil.insert(getExtraList(SqliteSqlBean.class));
+                    Toast.makeText(BaseApplication.getInstance(),"娣诲姞鎴愬姛", Toast.LENGTH_SHORT).show();
+                    CheckInFragment.getInstance().resetForm();
+                    if (visitReasonId == null || "".equals(visitReasonId)) {
+                        DictionaryMng.getInstance().loadVisitReasonList();
+                    }
+                }
+            });
+        } else {
+            final long result = CheckInDao.getInstance().addOfflineVisit(offlineVisitItem);
+
+            MainActivity.getInstance().runOnUiThread(new Runnable() {
+                @Override
+                public void run() {
+                    if (result > 0) {
+                        Toast.makeText(BaseApplication.getInstance(), "娣诲姞鎴愬姛", Toast.LENGTH_SHORT).show();
+                        if (visitReasonId == null || "".equals(visitReasonId)) {
+                            DictionaryMng.getInstance().loadVisitReasonList();
+                        }
+                        CheckInFragment.getInstance().resetForm();
+                    } else {
+                        Toast.makeText(BaseApplication.getInstance(), "娣诲姞澶辫触", Toast.LENGTH_SHORT).show();
+                    }
+                }
+            });
+        }
+    }
+
+    public void findCheckInLeftList(final boolean isVisitorList, final boolean isSortByDept, String searchText, final int pageNum, final boolean append) {
+        if (!BaseApplication.deviceAvailable) {
+            return;
+        }
+        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);
+            params.addBodyParameter("deviceCompanyId", BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+            x.http().post(params, new BaseCommonCallBack() {
+                public void success() {
+                    findCheckInLeftListAfterReturn(resultBean, isVisitorList, isSortByDept, append);
+                }
+            });
+        } else {
+            findCheckInLeftListAfterReturn(CheckInDao.getInstance().findCheckInLeftList(isVisitorList, searchText, pageNum), isVisitorList, isSortByDept, append);
+        }
+    }
+
+    public void findCheckInLeftListAfterReturn(ResultBean resultBean, final boolean isVisitorList, final boolean isSortByDept, final boolean append) {
+        List<CheckInQueryItem> list = resultBean.getList(CheckInQueryItem.class);
+        if (list == null) {
+            list = new ArrayList<>();
+        }
+
+        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);
+        final 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 (BaseApplication.getInstance().networkAvailable()) {
+            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);
+            }
+        } else {
+            MainActivity.getInstance().runOnUiThread(new Runnable() {
+                @Override
+                public void run() {
+                    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) {
+        if (!BaseApplication.deviceAvailable) {
+            return;
+        }
+        if (list == null) {
+            list = new ArrayList<>();
+        }
         Collections.sort(list, new Comparator<CheckInQueryItem>() {
             @Override
-            public int compare(CheckInQueryItem t1, CheckInQueryItem t2) {
+            public int compare(CheckInQueryItem item1, CheckInQueryItem item2) {
                 if (sortedByDept) {
-                    String dept1Name = t1.getDeptName()==null?"":t1.getDeptName();
-                    String dept2Name = t2.getDeptName()==null?"":t2.getDeptName();
+                    String dept1Name = item1.getDeptName()==null?"":item1.getDeptName();
+                    String dept2Name = item2.getDeptName()==null?"":item2.getDeptName();
                     if(!dept1Name.equals(dept2Name)) {
-                        return dept1Name.compareTo(dept2Name);
+                        String dept1Name_a = dept1Name.trim();
+                        String dept1Name_b = dept2Name.trim();
+                        if (dept1Name_a.length() > 0 && dept1Name_b.length() > 0) {
+                            dept1Name_a = CharacterParser.getInstance().getSelling(dept1Name).toLowerCase();
+                            dept1Name_b = CharacterParser.getInstance().getSelling(dept2Name).toLowerCase();
+                        }
+                        return dept1Name_a.compareTo(dept1Name_b);
                     }
                 }
-                String name1 = t1.getName()==null?"":t1.getName();
-                String name2 = t2.getName()==null?"":t2.getName();
-                return name1.compareTo(name2);
+                String username1 = item1.getUsername()==null?"":item1.getUsername();
+                String username2 = item2.getUsername()==null?"":item2.getUsername();
+                String dept1Name_a = username1.trim();
+                String dept1Name_b = username2.trim();
+                if (dept1Name_a.length() > 0 && dept1Name_b.length() > 0) {
+                    dept1Name_a = CharacterParser.getInstance().getSelling(username1).toLowerCase();
+                    dept1Name_b = CharacterParser.getInstance().getSelling(username2).toLowerCase();
+                }
+                return dept1Name_a.compareTo(dept1Name_b);
             }
         });
     }
 
-    /**
-     * 鏌ヨ鎷滆浜嬬敱鍒楄〃
-     */
+
+    public void sendOfflineCheckInToServer(Integer mysqlVisitorId, long sqliteVisitorId) {
+
+    }
+
+    public boolean hasOfflineCheckInData() {
+        return CheckInDao.getInstance().hasOfflineCheckInData();
+    }
+
+    public void removeVisitorLastMonthData() {
+        try {
+            SQLiteDatabase db = MainActivity.getInstance().db;
+            String sql="SELECT" +
+                    " a.register_id," +
+                    "a.username," +
+                    "a.surveillance_photo," +
+                    "d.company_name," +
+                    "a.tel," +
+                    "a.identify_num," +
+                    "b.dept_name," +
+                    "d.company_id," +
+                    "e.post_name," +
+                    "a.mobile_phone," +
+                    "a.warning," +
+                    "a.company" +
+                    " FROM" +
+                    " register a" +
+                    " LEFT JOIN company d ON d.company_id = a.company_id" +
+                    " LEFT JOIN department b ON a.department_id = b.dept_id" +
+                    " LEFT JOIN post e ON e.post_id = a.post_id" +
+                    " LEFT JOIN ( SELECT register_id, device_company_id from employee  ) f ON f.register_id = a.register_id" +
+                    " WHERE" +
+                    " 1 = 1";
+            String deviceCompanyId = BaseApplication.getInstance().getAndroidDevice().getCompanyId();
+            sql +=  " AND ( f.device_company_id != " + deviceCompanyId+" OR f.device_company_id IS NULL"+")";
+
+            sql+=" order by a.name_en";
+
+            String count = "select count(*) as count from (" + sql + " ) _table";
+            sql += " LIMIT 0, 100000";
+            List<CheckInQueryItem> list = new ArrayList<CheckInQueryItem>();
+            int b = list.size();
+            CheckInQueryItem cqi = null;
+            Cursor c = db.rawQuery(sql,new String[]{});
+            while (c.moveToNext()) {
+                cqi = new CheckInQueryItem();
+                cqi.setRegisterId(c.getString(c.getColumnIndex("register_id")));
+                list.add(cqi);
+            }
+            for (CheckInQueryItem item : list) {
+                String sql1 = "delete from register where 1=1 and register_id = '" + item.getRegisterId() + "'";
+                MainActivity.getInstance().db.execSQL(sql1);
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
 
 }

--
Gitblit v1.8.0