From 892b48a614e7e003deb854c0a5726ed32329f001 Mon Sep 17 00:00:00 2001
From: houxiao <houxiao@454eff88-639b-444f-9e54-f578c98de674>
Date: 星期四, 04 五月 2017 12:00:25 +0800
Subject: [PATCH] optimize
---
VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/DictionaryMng.java | 107 ++++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 81 insertions(+), 26 deletions(-)
diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/DictionaryMng.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/DictionaryMng.java
index 7b2e127..06b5789 100644
--- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/DictionaryMng.java
+++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/DictionaryMng.java
@@ -1,23 +1,28 @@
package cn.com.basic.face.service;
+import cn.com.basic.face.base.BaseApplication;
import cn.com.basic.face.dialog.CountryDialog;
import cn.com.basic.face.dialog.SelectDialog;
-import cn.com.basic.face.fragment.RegisterFragment;
-import cn.com.basic.face.fragment.CheckInFragment;
+import cn.com.basic.face.discern.query.condition.DictionaryQueryCondition;
+import cn.com.basic.face.discern.query.item.PhoneCallQueryItem;
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.HashMap;
import java.util.List;
+import java.util.Map;
import cn.com.basic.face.discern.common.BaseCommonCallBack;
import cn.com.basic.face.discern.common.CommonVariables;
import cn.com.basic.face.discern.entity.Dictionary;
+import cn.com.basic.face.util.CharacterParser;
-public class DictionaryMng extends BaseMng {
+public class DictionaryMng {
public static DictionaryMng instance = new DictionaryMng();
@@ -25,33 +30,43 @@
return instance;
}
- public static List<String> nationList = new ArrayList<String>();
- public static List<String> mCredentialsList = new ArrayList<String>();
- public static List<String> genderList = new ArrayList<String>();
- public static List<String> uniqueFirstLetterList = new ArrayList<String>();
- public static HashMap<String,List<String>> countriesGroupByFirstLetter = new HashMap<String,List<String>>();
- public static String[] countryWordData = new String[]{};
- public static List<String> visitReasonList = new ArrayList<String>();
+ public Map<String, String> idMap = new HashMap<String, String>();
+
+ public String getId(String name) {
+ return idMap.get(name);
+ }
public void loadAllDictionaryData() {
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
loadCountries();
loadIdTypeList();
loadGenderList();
loadVisitReasonList();
+ loadVisitorTypeList();
}
public void loadCountries() {
- RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.DICTIONARY_TYPE_LIST);
- params.addParameter(Dictionary.FieldNames.type, CommonVariables.DictionaryType.COUNTRY);
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
+ RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.DICTIONARY_QUERY);
+ params.addParameter(DictionaryQueryCondition.FieldNames.type, CommonVariables.DictionaryType.COUNTRY);
x.http().get(params, new BaseCommonCallBack() {
public void success() {
List<Dictionary> items = getList(Dictionary.class);
- countryWordData = new String[items.size()];
int i=0;
+ List<String> uniqueFirstLetterList = new ArrayList<String>();
+ HashMap<String,List<String>> countriesGroupByFirstLetter = new HashMap<String,List<String>>();
+ sortCountries(items);
for (Dictionary item : items) {
- idMap.put(item.getName(), item.getId()+"");
- nationList.add(item.getName());
- String firstLetter = item.getRemark();
+ idMap.put(item.getName(), item.getDictId()+"");
+
+ String firstLetter = item.getName();
+ if (item.getName().length() > 0) {
+ firstLetter = CharacterParser.getInstance().getSelling(item.getName()).substring(0, 1).toUpperCase();
+ }
List list = countriesGroupByFirstLetter.get(firstLetter);
if (list == null) {
list = new ArrayList();
@@ -59,18 +74,39 @@
uniqueFirstLetterList.add(0, firstLetter);
}
list.add(item.getName());
- countryWordData[i] = item.getName();
i++;
}
CountryDialog.setCountries(uniqueFirstLetterList, countriesGroupByFirstLetter);
}
});
+ }
+ private void sortCountries(List<Dictionary> countries) {
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
+ Collections.sort(countries, new Comparator<Dictionary>() {
+ @Override
+ public int compare(Dictionary t1, Dictionary t2) {
+ String name1 = t1.getName()==null?"":t1.getName();
+ String name2 = t2.getName()==null?"":t2.getName();
+ 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_b.compareTo(dept1Name_a);
+ }
+ });
}
public void loadIdTypeList() {
- RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.DICTIONARY_TYPE_LIST);
- params.addParameter(Dictionary.FieldNames.type, CommonVariables.DictionaryType.ID_TYPE);
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
+ RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.DICTIONARY_QUERY);
+ params.addParameter(DictionaryQueryCondition.FieldNames.type, CommonVariables.DictionaryType.ID_TYPE);
x.http().get(params, new BaseCommonCallBack() {
public void success() {
SelectDialog.setIdTypeList(getDictionaryNameList(getList(Dictionary.class)));
@@ -79,8 +115,11 @@
}
private void loadGenderList() {
- RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.DICTIONARY_TYPE_LIST);
- params.addParameter(Dictionary.FieldNames.type, CommonVariables.DictionaryType.GENDER);
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
+ RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.DICTIONARY_QUERY);
+ params.addParameter(DictionaryQueryCondition.FieldNames.type, CommonVariables.DictionaryType.GENDER);
x.http().get(params, new BaseCommonCallBack() {
public void success() {
SelectDialog.setGenderList(getDictionaryNameList(getList(Dictionary.class)));
@@ -88,12 +127,15 @@
});
}
- private void loadVisitReasonList() {
- RequestParams params = new RequestParams(AppApi.BASEURL+AppApi.DICTIONARY_TYPE_LIST);
- params.addParameter(Dictionary.FieldNames.type, CommonVariables.DictionaryType.VISIT_REASON);
+ public void loadVisitReasonList() {
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
+ RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.DICTIONARY_QUERY);
+ params.addParameter(DictionaryQueryCondition.FieldNames.type, CommonVariables.DictionaryType.VISIT_REASON);
x.http().get(params, new BaseCommonCallBack() {
public void success() {
- SelectDialog.setVisitReason(getDictionaryNameList(getList(Dictionary.class)));
+ SelectDialog.setVisitReasonList(getDictionaryNameList(getList(Dictionary.class)));
}
});
}
@@ -101,10 +143,23 @@
public List<String> getDictionaryNameList(List<Dictionary> dictionaryList) {
List nameList = new ArrayList();
for (Dictionary dictionary : dictionaryList) {
- idMap.put(dictionary.getName(), dictionary.getId()+"");
+ idMap.put(dictionary.getName(), dictionary.getDictId()+"");
nameList.add(dictionary.getName());
}
return nameList;
}
+ private void loadVisitorTypeList() {
+ if (!BaseApplication.deviceAvailable) {
+ return;
+ }
+ RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.DICTIONARY_QUERY);
+ params.addParameter(DictionaryQueryCondition.FieldNames.type, CommonVariables.DictionaryType.VISIT_TYPE);
+ x.http().get(params, new BaseCommonCallBack() {
+ public void success() {
+ SelectDialog.setVisitorTypeList(getDictionaryNameList(getList(Dictionary.class)));
+ }
+ });
+ }
+
}
--
Gitblit v1.8.0