From 109ffe9a777658936a38d0c146579a67c60a0d17 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 11 五月 2017 17:48:48 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java | 95 +++++++++++++++++++++++++++++++++++------------ 1 files changed, 71 insertions(+), 24 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 cd80498..a91c66e 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,6 +3,9 @@ import android.widget.Toast; import cn.com.basic.face.base.BaseApplication; +import cn.com.basic.face.discern.common.CommonVariables; +import cn.com.basic.face.discern.query.condition.CheckInQueryCondition; +import cn.com.basic.face.discern.query.item.PhoneCallQueryItem; import cn.com.basic.face.fragment.CheckInFragment; import cn.com.basic.face.util.AppApi; @@ -19,7 +22,7 @@ import cn.com.basic.face.discern.query.item.CheckInQueryItem; import cn.com.basic.face.util.CharacterParser; -public class CheckInMng { +public class CheckInMng extends BaseMng { public static CheckInMng instance = new CheckInMng(); @@ -27,74 +30,118 @@ return instance; } - public void add(RequestParams params) { + public void add(RequestParams params, final String visitReasonId) { + 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(); + } } }); } - public void findCheckInLeftList(final boolean isVisitorList, final boolean isSortByDept, String searchText) { - RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.REGISTER_QUERY); - if (isVisitorList) { - params.addBodyParameter(VisitorQueryCondition.FieldNames.notCompanyId, BaseApplication.getInstance().getDevice().getCompanyId()); - } else { - params.addBodyParameter(VisitorQueryCondition.FieldNames.companyId, BaseApplication.getInstance().getDevice().getCompanyId()); + public void findCheckInLeftList(final boolean isVisitorList, final boolean isSortByDept, String searchText, final int pageNum, final boolean append) { + if (!BaseApplication.deviceAvailable) { + return; } - params.addBodyParameter(VisitorQueryCondition.FieldNames.name, searchText); + RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.CHECK_IN_QUERY); + String deviceCompanyId = BaseApplication.getInstance().getDevice().getDeviceCompanyId(); + 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() { 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); + } + } + } + sort(list, isSortByDept); - List allItems = new ArrayList(); + List itemList = new ArrayList(); String name = ""; String prev = ""; for (int i = 0; i < list.size(); i++) { CheckInQueryItem item = list.get(i); if (isSortByDept) { - name = CharacterParser.getInstance().getSelling(item.getDeptName()).substring(0, 1); + 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)) { - allItems.add(name); + itemList.add(name); } - allItems.add(item); + itemList.add(item); prev = name; } + addPageFooter(hasMorePages(), getPageNum(), itemList); if (isVisitorList) { - CheckInFragment.getInstance().get_fragment_check_in_left_visitor().show(allItems); + CheckInFragment.getInstance().get_fragment_check_in_left_visitor().show(itemList); } else { - CheckInFragment.getInstance().get_fragment_check_in_left_interviewee().show(allItems); + 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; + } 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)) { - String dept1Name_a = CharacterParser.getInstance().getSelling(dept1Name).toLowerCase(); - String dept1Name_b = CharacterParser.getInstance().getSelling(dept2Name).toLowerCase(); + 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.getUsername()==null?"":t1.getUsername(); - String name2 = t2.getUsername()==null?"":t2.getUsername(); - String dept1Name_a = CharacterParser.getInstance().getSelling(name1).toLowerCase(); - String dept1Name_b = CharacterParser.getInstance().getSelling(name2).toLowerCase(); + 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); } }); } + } -- Gitblit v1.8.0