From c7caa54d8d58af6159f2c758ad5d6687d461a333 Mon Sep 17 00:00:00 2001 From: sujinwen <sujinwen@454eff88-639b-444f-9e54-f578c98de674> Date: 星期二, 25 七月 2017 10:53:23 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java | 108 ++++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 92 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..e811393 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 @@ -3,24 +3,35 @@ 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.SqliteSqlUtil; //鐧昏 public class CheckInMng extends BaseMng { @@ -31,21 +42,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 +95,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 +106,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 +128,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 +148,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 +205,28 @@ } + public void sendOfflineCheckInToServer(Integer mysqlVisitorId, long sqliteVisitorId) { + RequestParams params = new RequestParams(); + + List<OfflineVisitItem> offlineVisitItems = CheckInDao.getInstance().readOfflineVisitItemFromLocal(sqliteVisitorId); + for (OfflineVisitItem item : offlineVisitItems) { + 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(); +// } + } + }); + } + } + + public boolean hasOfflineCheckInData() { + return CheckInDao.getInstance().hasOfflineCheckInData(); + } } -- Gitblit v1.8.0