From 46a8044f3449c6e9a884c90477ada5a5e6879367 Mon Sep 17 00:00:00 2001
From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期二, 01 八月 2017 17:37:39 +0800
Subject: [PATCH]
---
VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java | 144 ++++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 128 insertions(+), 16 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 8daedb3..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,26 +1,40 @@
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.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.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 extends BaseMng {
@@ -31,21 +45,42 @@
return instance;
}
- public void add(RequestParams params, final String visitReasonId) {
+ public void add(RequestParams params, final String visitReasonId, OfflineVisitItem offlineVisitItem) {
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);
+ 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) {
@@ -63,6 +98,7 @@
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);
@@ -73,8 +109,11 @@
}
}
- public void findCheckInLeftListAfterReturn(ResultBean resultBean, boolean isVisitorList, boolean isSortByDept, boolean 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) {
@@ -92,7 +131,7 @@
}
sort(list, isSortByDept);
- List itemList = new ArrayList();
+ final List itemList = new ArrayList();
String name = "";
String prev = "";
for (int i = 0; i < list.size(); i++) {
@@ -112,16 +151,32 @@
prev = name;
}
addPageFooter(resultBean.hasMorePages(), resultBean.getPageNum(), itemList);
- if (isVisitorList) {
- CheckInFragment.getInstance().get_fragment_check_in_left_visitor().show(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 {
- CheckInFragment.getInstance().get_fragment_check_in_left_interviewee().show(itemList, isSortByDept, append);
+ 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
@@ -153,4 +208,61 @@
}
+ 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