From d2f697fa887e28b86d38332e2fbde930c54fb43f Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期四, 20 四月 2017 10:16:49 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/CheckInMng.java | 153 +++++++++++++++++++++++++++----------------------- 1 files changed, 82 insertions(+), 71 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 6290497..aabc67f 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,13 +3,16 @@ 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.fragment.SupervisoryFragment; import cn.com.basic.face.util.AppApi; import org.xutils.http.RequestParams; import org.xutils.x; +import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; @@ -17,10 +20,7 @@ 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; public class CheckInMng { @@ -30,83 +30,85 @@ return instance; } - /** - * 鏌ヨ鏉ヨ浜哄憳鍒楄〃 - */ - public void findSupervisoryBottomList(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 findSupervisoryBottomList() { - //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() { - //SupervisoryFragment.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); + 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.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 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); + if (isVisitorList) { + params.addBodyParameter(CheckInQueryCondition.FieldNames.visitorCompanyId, BaseApplication.getInstance().getDevice().getDeviceCompanyId()); + } else { + params.addBodyParameter(CheckInQueryCondition.FieldNames.employeeCompanyId, BaseApplication.getInstance().getDevice().getDeviceCompanyId()); + } + params.addBodyParameter(CheckInQueryCondition.FieldNames.username, searchText); + params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum+""); + params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, "5"); 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); + List allItems = 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)) { + allItems.add(name); + } + allItems.add(item); + prev = name; + } + if (hasMorePages()) { + allItems.add(CommonVariables.Page.hasMorePages); + } else { + if (getPageNum() > 1) { + allItems.add(CommonVariables.Page.reachBottom); + } else { + if (allItems.size() > 0) { + allItems.add(CommonVariables.Page.reachBottom); + } else { + allItems.add(CommonVariables.Page.noMorePage); + } + } + } + if (isVisitorList) { + CheckInFragment.getInstance().get_fragment_check_in_left_visitor().show(allItems, append); + } else { + CheckInFragment.getInstance().get_fragment_check_in_left_interviewee().show(allItems, 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) { @@ -114,18 +116,27 @@ String dept1Name = t1.getDeptName()==null?"":t1.getDeptName(); String dept2Name = t2.getDeptName()==null?"":t2.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 name1 = t1.getUsername()==null?"":t1.getUsername(); + String name2 = t2.getUsername()==null?"":t2.getUsername(); + String dept1Name_a = name1.trim(); + String dept1Name_b = name2.trim(); + if (dept1Name_a.length() > 0 && dept1Name_b.length() > 0) { + dept1Name_a = CharacterParser.getInstance().getSelling(name1).toLowerCase(); + dept1Name_b = CharacterParser.getInstance().getSelling(name2).toLowerCase(); + } + return dept1Name_a.compareTo(dept1Name_b); } }); } - /** - * 鏌ヨ鎷滆浜嬬敱鍒楄〃 - */ } -- Gitblit v1.8.0