From 784f977cc7f9b9aad8cc3528a4f2026c1f686a0a Mon Sep 17 00:00:00 2001
From: chenke <chenke@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期三, 09 八月 2017 13:44:20 +0800
Subject: [PATCH] JsonCpp和CapnpProtocol功能初步实现
---
VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java | 143 ++++++++++++++++++++++++++++++++++-------------
1 files changed, 102 insertions(+), 41 deletions(-)
diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java
index cc6b3ad..8c1811f 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/AttendanceMng.java
@@ -3,65 +3,126 @@
import org.xutils.http.RequestParams;
import org.xutils.x;
+import java.text.SimpleDateFormat;
import java.util.ArrayList;
+import java.util.Date;
import java.util.List;
+import cn.com.basic.face.base.BaseApplication;
+import cn.com.basic.face.base.MainActivity;
import cn.com.basic.face.discern.common.BaseCommonCallBack;
-import cn.com.basic.face.discern.query.condition.VisitorQueryCondition;
+import cn.com.basic.face.discern.common.CommonVariables;
+import cn.com.basic.face.discern.common.ResultBean;
+import cn.com.basic.face.discern.query.condition.AttendanceDetailQueryCondition;
+import cn.com.basic.face.discern.query.condition.AttendanceQueryCondition;
+import cn.com.basic.face.discern.query.item.AttendanceDetailQueryItem;
import cn.com.basic.face.discern.query.item.AttendanceQueryItem;
import cn.com.basic.face.fragment.AttendanceFragment;
-import cn.com.basic.face.service.vo.CheckInFragment;
-import cn.com.basic.face.service.vo.VisitFragment;
+import cn.com.basic.face.service.sqlite.AttendanceDao;
import cn.com.basic.face.util.AppApi;
+import cn.com.basic.face.util.DateUtil;
-public class AttendanceMng {
+public class AttendanceMng extends BaseMng{
private static AttendanceMng instance = new AttendanceMng();
public static AttendanceMng getInstance() {
return instance;
}
-
- public void reloadRightList() {
- RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.CheckInQuery);
- x.http().post(params, new BaseCommonCallBack() {
- public void success() {
- List<VisitFragment.VisitQueryItem> list = getList(VisitFragment.VisitQueryItem.class);
- String date = "";
- List itemList = new ArrayList();
- int i = 0;
- for (VisitFragment.VisitQueryItem item : list) {
- if (i % 3 == 0) {
- itemList.add("2016-10-10");
- }
- itemList.add(item);
- i++;
+ public void reloadLeftList(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.ATTENDANCE_QUERY);
+ params.addBodyParameter(AttendanceQueryCondition.FieldNames.username, searchText);
+ params.addBodyParameter(AttendanceQueryCondition.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+ 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() {
+ reloadLeftListAfterReturn(append, resultBean);
}
- AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(itemList);
- }
- });
+ });
+ } else {
+ reloadLeftListAfterReturn(append, AttendanceDao.getInstance().reloadLeftList(searchText, pageNum, append));
+ }
}
- public void reloadLeftList(String searchText) {
- RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.ATTENDANCE_QUERY);
- params.addBodyParameter(VisitorQueryCondition.FieldNames.name, searchText);
- x.http().post(params, new BaseCommonCallBack() {
- public void success() {
- List<AttendanceQueryItem> list = getList(AttendanceQueryItem.class);
- String date = "";
- List itemList = new ArrayList();
- int i = 0;
- for (AttendanceQueryItem item : list) {
- if (i % 3 == 0) {
- itemList.add("2016-10-10");
- }
- itemList.add(item);
- i++;
+ public void reloadLeftListAfterReturn(final boolean append, ResultBean resultBean) {
+ List<AttendanceQueryItem> list = resultBean.getList(AttendanceQueryItem.class);
+ final List itemList = new ArrayList();
+ int i = 0;
+ String previewDate = "";
+ if (append) {
+// List prevList = AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().getPrevList();
+// if (prevList != null && prevList.size() > 1) {
+// previewDate = DateUtil.yyyy_MM_dd_to_yyyy骞碝M鏈坉d鏃�(
+// ((AttendanceQueryItem) prevList.get(prevList.size() - 2)).getTime());
+// }
+ }
+ for (AttendanceQueryItem item : list) {
+// try {
+// String yyyyMMdd = DateUtil.yyyy_MM_dd_to_yyyy骞碝M鏈坉d鏃�(item.getTime());
+// if (!previewDate.equals(yyyyMMdd)) {
+// itemList.add(yyyyMMdd);
+// previewDate = yyyyMMdd;
+// }
+// } catch (Exception e) {
+// }
+ itemList.add(item);
+ i++;
+ }
+ addPageFooter(resultBean.hasMorePages(), resultBean.getPageNum(), itemList);
+ if (BaseApplication.getInstance().networkAvailable()) {
+ AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList, append);
+ } else {
+ MainActivity.getInstance().runOnUiThread(new Runnable() {
+ @Override
+ public void run() {
+ AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList, append);
}
- AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList);
- }
- });
-
+ });
+ }
}
+ public void reloadAttendanceDetail(final AttendanceQueryItem item) {
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
+ if (BaseApplication.getInstance().networkAvailable()) {
+ try {
+ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+ RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.ATTENDANCE_DETAIL_QUERY);
+ params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.time, sdf.format(new Date()));
+ params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.registerId, item.getRegisterId());
+ params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId());
+ params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, "20");
+ x.http().post(params, new BaseCommonCallBack() {
+ public void success() {
+ AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(getList(AttendanceDetailQueryItem.class));
+ }
+ });
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ } else {
+ MainActivity.getInstance().runOnUiThread(new Runnable() {
+ @Override
+ public void run() {
+ AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(AttendanceDao.getInstance().reloadAttendanceDetail(item));
+ }
+ });
+ }
+ }
+
+ public void removeBeforeToday() {
+ try {
+ String sql = "delete from attendance where 1=1 and time< '" + DateUtil.getYesterday() + "'";
+ MainActivity.getInstance().db.execSQL(sql);
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+
+ }
}
--
Gitblit v1.8.0