Add i18n for status labels in filtering.
Code refactoring. (cherry picked from commit 8b5f516)
This commit is contained in:
parent
39f5df1d30
commit
f23ff44a87
2 changed files with 114 additions and 144 deletions
|
|
@ -36,13 +36,17 @@ import org.libreplan.business.resources.entities.Criterion;
|
||||||
import org.libreplan.business.resources.entities.CriterionType;
|
import org.libreplan.business.resources.entities.CriterionType;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|
||||||
|
import static org.libreplan.web.I18nHelper._;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implements all the methods needed to search the criterion to filter the
|
* Implements all the methods needed to search the criterion to filter the orders.
|
||||||
* orders. Provides multiples criterions to filter like {@link Criterion},
|
* Provides multiples criterions to filter like {@link Criterion},
|
||||||
* {@link Label}, {@link OrderStatusEnum},{@link ExternalCompany} object , or
|
* {@link Label}, {@link OrderStatusEnum},{@link ExternalCompany} object , or
|
||||||
* filter by order code or customer reference.
|
* filter by order code or customer reference.
|
||||||
|
*
|
||||||
* @author Susana Montes Pedreira <smontes@wirelessgalicia.com>
|
* @author Susana Montes Pedreira <smontes@wirelessgalicia.com>
|
||||||
|
* @author Vova Perebykivskyi <vova@libreplan-enterprise.com>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
@ -50,8 +54,7 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
@Autowired
|
@Autowired
|
||||||
private PredefinedDatabaseSnapshots databaseSnapshots;
|
private PredefinedDatabaseSnapshots databaseSnapshots;
|
||||||
|
|
||||||
protected OrdersMultipleFiltersFinder() {
|
protected OrdersMultipleFiltersFinder() {}
|
||||||
}
|
|
||||||
|
|
||||||
public List<FilterPair> getFirstTenFilters() {
|
public List<FilterPair> getFirstTenFilters() {
|
||||||
getListMatching().clear();
|
getListMatching().clear();
|
||||||
|
|
@ -62,19 +65,20 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
fillWihtFirstTenFiltersCodes();
|
fillWihtFirstTenFiltersCodes();
|
||||||
fillWihtFirstTenFiltersCustomerReferences();
|
fillWihtFirstTenFiltersCustomerReferences();
|
||||||
addNoneFilter();
|
addNoneFilter();
|
||||||
|
|
||||||
return getListMatching();
|
return getListMatching();
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersLabels() {
|
private List<FilterPair> fillWithFirstTenFiltersLabels() {
|
||||||
Map<LabelType, List<Label>> mapLabels = databaseSnapshots
|
Map<LabelType, List<Label>> mapLabels = databaseSnapshots.snapshotLabelsMap();
|
||||||
.snapshotLabelsMap();
|
|
||||||
Iterator<LabelType> iteratorLabelType = mapLabels.keySet().iterator();
|
Iterator<LabelType> iteratorLabelType = mapLabels.keySet().iterator();
|
||||||
|
|
||||||
while (iteratorLabelType.hasNext() && getListMatching().size() < 10) {
|
while (iteratorLabelType.hasNext() && getListMatching().size() < 10) {
|
||||||
LabelType type = iteratorLabelType.next();
|
LabelType type = iteratorLabelType.next();
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < mapLabels.get(type).size(); i++) {
|
for (int i = 0; getListMatching().size() < 10 && i < mapLabels.get(type).size(); i++) {
|
||||||
Label label = mapLabels.get(type).get(i);
|
Label label = mapLabels.get(type).get(i);
|
||||||
addLabel(type, label);
|
addLabel(label);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return getListMatching();
|
return getListMatching();
|
||||||
|
|
@ -82,12 +86,12 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersCriterions() {
|
private List<FilterPair> fillWithFirstTenFiltersCriterions() {
|
||||||
SortedMap<CriterionType, List<Criterion>> mapCriterions = getMapCriterions();
|
SortedMap<CriterionType, List<Criterion>> mapCriterions = getMapCriterions();
|
||||||
Iterator<CriterionType> iteratorCriterionType = mapCriterions.keySet()
|
Iterator<CriterionType> iteratorCriterionType = mapCriterions.keySet().iterator();
|
||||||
.iterator();
|
|
||||||
while (iteratorCriterionType.hasNext() && getListMatching().size() < 10) {
|
while (iteratorCriterionType.hasNext() && getListMatching().size() < 10) {
|
||||||
CriterionType type = iteratorCriterionType.next();
|
CriterionType type = iteratorCriterionType.next();
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < mapCriterions.get(type).size(); i++) {
|
for (int i = 0; getListMatching().size() < 10 && i < mapCriterions.get(type).size(); i++) {
|
||||||
Criterion criterion = mapCriterions.get(type).get(i);
|
Criterion criterion = mapCriterions.get(type).get(i);
|
||||||
addCriterion(type, criterion);
|
addCriterion(type, criterion);
|
||||||
}
|
}
|
||||||
|
|
@ -100,10 +104,9 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersCustomer() {
|
private List<FilterPair> fillWithFirstTenFiltersCustomer() {
|
||||||
List<ExternalCompany> externalCompanies = databaseSnapshots
|
List<ExternalCompany> externalCompanies = databaseSnapshots.snapshotExternalCompanies();
|
||||||
.snapshotExternalCompanies();
|
|
||||||
for (int i = 0; getListMatching().size() < 10
|
for (int i = 0; getListMatching().size() < 10 && i < externalCompanies.size(); i++) {
|
||||||
&& i < externalCompanies.size(); i++) {
|
|
||||||
ExternalCompany externalCompany = externalCompanies.get(i);
|
ExternalCompany externalCompany = externalCompanies.get(i);
|
||||||
addExternalCompany(externalCompany);
|
addExternalCompany(externalCompany);
|
||||||
}
|
}
|
||||||
|
|
@ -111,8 +114,7 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersState() {
|
private List<FilterPair> fillWithFirstTenFiltersState() {
|
||||||
for (int i = 0; getListMatching().size() < 10
|
for (int i = 0; getListMatching().size() < 10 && i < OrderStatusEnum.values().length; i++) {
|
||||||
&& i < OrderStatusEnum.values().length; i++) {
|
|
||||||
OrderStatusEnum state = OrderStatusEnum.values()[i];
|
OrderStatusEnum state = OrderStatusEnum.values()[i];
|
||||||
addState(state);
|
addState(state);
|
||||||
}
|
}
|
||||||
|
|
@ -129,10 +131,8 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWihtFirstTenFiltersCustomerReferences() {
|
private List<FilterPair> fillWihtFirstTenFiltersCustomerReferences() {
|
||||||
List<String> customerReferences = databaseSnapshots
|
List<String> customerReferences = databaseSnapshots.snapshotCustomerReferences();
|
||||||
.snapshotCustomerReferences();
|
for (int i = 0; getListMatching().size() < 10 && i < customerReferences.size(); i++) {
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < customerReferences.size(); i++) {
|
|
||||||
String reference = customerReferences.get(i);
|
String reference = customerReferences.get(i);
|
||||||
addCustomerReference(reference);
|
addCustomerReference(reference);
|
||||||
}
|
}
|
||||||
|
|
@ -163,10 +163,10 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInCriterionTypes(String filter) {
|
private void searchInCriterionTypes(String filter) {
|
||||||
Map<CriterionType, List<Criterion>> mapCriterions = getMapCriterions();
|
Map<CriterionType, List<Criterion>> mapCriterions = getMapCriterions();
|
||||||
boolean limited = (filter.length() < 3);
|
boolean limited = filter.length() < 3;
|
||||||
|
|
||||||
for (CriterionType type : mapCriterions.keySet()) {
|
for (CriterionType type : mapCriterions.keySet()) {
|
||||||
String name = StringUtils.deleteWhitespace(type.getName()
|
String name = StringUtils.deleteWhitespace(type.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
setFilterPairCriterionType(type, limited);
|
setFilterPairCriterionType(type, limited);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -177,8 +177,7 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInCriterions(CriterionType type, String filter) {
|
private void searchInCriterions(CriterionType type, String filter) {
|
||||||
for (Criterion criterion : getMapCriterions().get(type)) {
|
for (Criterion criterion : getMapCriterions().get(type)) {
|
||||||
String name = StringUtils.deleteWhitespace(criterion.getName()
|
String name = StringUtils.deleteWhitespace(criterion.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
addCriterion(type, criterion);
|
addCriterion(type, criterion);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
|
|
@ -199,10 +198,10 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInLabelTypes(String filter) {
|
private void searchInLabelTypes(String filter) {
|
||||||
Map<LabelType, List<Label>> mapLabels = getLabelsMap();
|
Map<LabelType, List<Label>> mapLabels = getLabelsMap();
|
||||||
boolean limited = (filter.length() < 3);
|
boolean limited = filter.length() < 3;
|
||||||
|
|
||||||
for (LabelType type : mapLabels.keySet()) {
|
for (LabelType type : mapLabels.keySet()) {
|
||||||
String name = StringUtils.deleteWhitespace(type.getName()
|
String name = StringUtils.deleteWhitespace(type.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
setFilterPairLabelType(type, limited);
|
setFilterPairLabelType(type, limited);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -217,10 +216,9 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInLabels(LabelType type, String filter) {
|
private void searchInLabels(LabelType type, String filter) {
|
||||||
for (Label label : getLabelsMap().get(type)) {
|
for (Label label : getLabelsMap().get(type)) {
|
||||||
String name = StringUtils.deleteWhitespace(label.getName()
|
String name = StringUtils.deleteWhitespace(label.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
addLabel(type, label);
|
addLabel(label);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -230,7 +228,7 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void setFilterPairLabelType(LabelType type, boolean limited) {
|
private void setFilterPairLabelType(LabelType type, boolean limited) {
|
||||||
for (Label label : getLabelsMap().get(type)) {
|
for (Label label : getLabelsMap().get(type)) {
|
||||||
addLabel(type, label);
|
addLabel(label);
|
||||||
if ((limited) && (getListMatching().size() > 9)) {
|
if ((limited) && (getListMatching().size() > 9)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -238,12 +236,10 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void searchInExternalCompanies(String filter){
|
private void searchInExternalCompanies(String filter){
|
||||||
for(ExternalCompany externalCompany : databaseSnapshots
|
for (ExternalCompany externalCompany : databaseSnapshots.snapshotExternalCompanies()) {
|
||||||
.snapshotExternalCompanies()){
|
String name = StringUtils.deleteWhitespace(externalCompany.getName().toLowerCase());
|
||||||
String name = StringUtils.deleteWhitespace(externalCompany
|
String nif = StringUtils.deleteWhitespace(externalCompany.getNif().toLowerCase());
|
||||||
.getName().toLowerCase());
|
|
||||||
String nif = StringUtils.deleteWhitespace(externalCompany.getNif()
|
|
||||||
.toLowerCase());
|
|
||||||
if ((name.contains(filter)) || (nif.contains(filter))) {
|
if ((name.contains(filter)) || (nif.contains(filter))) {
|
||||||
addExternalCompany(externalCompany);
|
addExternalCompany(externalCompany);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
|
|
@ -255,8 +251,7 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInOrderStatus(String filter) {
|
private void searchInOrderStatus(String filter) {
|
||||||
for (OrderStatusEnum state : OrderStatusEnum.values()) {
|
for (OrderStatusEnum state : OrderStatusEnum.values()) {
|
||||||
String name = StringUtils.deleteWhitespace(state.name()
|
String name = StringUtils.deleteWhitespace(_(state.name()).toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
addState(state);
|
addState(state);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
|
|
@ -269,8 +264,10 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
private void searchInOrderCodes(String filter) {
|
private void searchInOrderCodes(String filter) {
|
||||||
if (filter.indexOf("cod:") == 0) {
|
if (filter.indexOf("cod:") == 0) {
|
||||||
String codeFilter = filter.replaceFirst("cod:", "");
|
String codeFilter = filter.replaceFirst("cod:", "");
|
||||||
|
|
||||||
for (String code : databaseSnapshots.snapshotOrdersCodes()) {
|
for (String code : databaseSnapshots.snapshotOrdersCodes()) {
|
||||||
code = StringUtils.deleteWhitespace(code.toLowerCase());
|
code = StringUtils.deleteWhitespace(code.toLowerCase());
|
||||||
|
|
||||||
if (code.equals(codeFilter)) {
|
if (code.equals(codeFilter)) {
|
||||||
addCode(code);
|
addCode(code);
|
||||||
return;
|
return;
|
||||||
|
|
@ -282,10 +279,10 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
private void searchInCustomerReferences(String filter) {
|
private void searchInCustomerReferences(String filter) {
|
||||||
if (filter.indexOf("rc:") == 0) {
|
if (filter.indexOf("rc:") == 0) {
|
||||||
String referenceFilter = filter.replaceFirst("rc:", "");
|
String referenceFilter = filter.replaceFirst("rc:", "");
|
||||||
for (String reference : databaseSnapshots
|
|
||||||
.snapshotCustomerReferences()) {
|
for (String reference : databaseSnapshots.snapshotCustomerReferences()) {
|
||||||
reference = StringUtils.deleteWhitespace(reference
|
reference = StringUtils.deleteWhitespace(reference.toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (reference.equals(referenceFilter)) {
|
if (reference.equals(referenceFilter)) {
|
||||||
addCustomerReference(reference);
|
addCustomerReference(reference);
|
||||||
return;
|
return;
|
||||||
|
|
@ -296,29 +293,22 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void addCriterion(CriterionType type, Criterion criterion) {
|
private void addCriterion(CriterionType type, Criterion criterion) {
|
||||||
String pattern = criterion.getName() + " ( " + type.getName() + " )";
|
String pattern = criterion.getName() + " ( " + type.getName() + " )";
|
||||||
|
|
||||||
getListMatching().add(
|
getListMatching().add(
|
||||||
new FilterPair(OrderFilterEnum.Criterion, type.getResource()
|
new FilterPair(OrderFilterEnum.Criterion, type.getResource().toLowerCase(), pattern, criterion));
|
||||||
.toLowerCase(), pattern, criterion));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addLabel(LabelType type, Label label) {
|
private void addLabel(Label label) {
|
||||||
getListMatching().add(
|
getListMatching().add(new FilterPair(OrderFilterEnum.Label, label.getFinderPattern(), label));
|
||||||
new FilterPair(OrderFilterEnum.Label, label.getFinderPattern(),
|
|
||||||
label));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addExternalCompany(ExternalCompany externalCompany) {
|
private void addExternalCompany(ExternalCompany externalCompany) {
|
||||||
String pattern = externalCompany.getName() + " :: "
|
String pattern = externalCompany.getName() + " :: " + externalCompany.getNif();
|
||||||
+ externalCompany.getNif();
|
getListMatching().add(new FilterPair(OrderFilterEnum.ExternalCompany, pattern, externalCompany));
|
||||||
getListMatching().add(
|
|
||||||
new FilterPair(OrderFilterEnum.ExternalCompany,
|
|
||||||
pattern, externalCompany));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addState(OrderStatusEnum state) {
|
private void addState(OrderStatusEnum state) {
|
||||||
getListMatching().add(
|
getListMatching().add(new FilterPair(OrderFilterEnum.State, _(state.name()), state));
|
||||||
new FilterPair(OrderFilterEnum.State, state.name(),
|
|
||||||
state));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addCode(String code) {
|
private void addCode(String code) {
|
||||||
|
|
@ -326,9 +316,7 @@ public class OrdersMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addCustomerReference(String reference) {
|
private void addCustomerReference(String reference) {
|
||||||
getListMatching().add(
|
getListMatching().add(new FilterPair(OrderFilterEnum.CustomerReference, reference, reference));
|
||||||
new FilterPair(OrderFilterEnum.CustomerReference,
|
|
||||||
reference, reference));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -36,21 +36,22 @@ import org.libreplan.business.resources.entities.CriterionType;
|
||||||
import org.libreplan.business.resources.entities.Resource;
|
import org.libreplan.business.resources.entities.Resource;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
|
||||||
|
import static org.libreplan.web.I18nHelper._;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Implements all the methods needed to search the criteria to filter the
|
* Implements all the methods needed to search the criteria to filter the {@link TaskGroup} in company view Gantt.
|
||||||
* {@link TaskGroup} in company view Gantt. Provides multiples criteria to
|
* Provides multiples criteria to filter like {@link Criterion} and {@link Label}.
|
||||||
* filter like {@link Criterion} and {@link Label}.
|
|
||||||
*
|
*
|
||||||
* @author Manuel Rego Casasnovas <rego@igalia.com>
|
* @author Manuel Rego Casasnovas <rego@igalia.com>
|
||||||
|
* @author Vova Perebykivskyi <vova@libreplan-enterprise.com>
|
||||||
*/
|
*/
|
||||||
public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private PredefinedDatabaseSnapshots databaseSnapshots;
|
private PredefinedDatabaseSnapshots databaseSnapshots;
|
||||||
|
|
||||||
protected TaskGroupsMultipleFiltersFinder() {
|
protected TaskGroupsMultipleFiltersFinder() {}
|
||||||
}
|
|
||||||
|
|
||||||
public List<FilterPair> getFirstTenFilters() {
|
public List<FilterPair> getFirstTenFilters() {
|
||||||
getListMatching().clear();
|
getListMatching().clear();
|
||||||
|
|
@ -62,19 +63,20 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
fillWihtFirstTenFiltersCustomerReferences();
|
fillWihtFirstTenFiltersCustomerReferences();
|
||||||
fillWithFirstTenFiltersResources();
|
fillWithFirstTenFiltersResources();
|
||||||
addNoneFilter();
|
addNoneFilter();
|
||||||
|
|
||||||
return getListMatching();
|
return getListMatching();
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersLabels() {
|
private List<FilterPair> fillWithFirstTenFiltersLabels() {
|
||||||
Map<LabelType, List<Label>> mapLabels = databaseSnapshots
|
Map<LabelType, List<Label>> mapLabels = databaseSnapshots.snapshotLabelsMap();
|
||||||
.snapshotLabelsMap();
|
|
||||||
Iterator<LabelType> iteratorLabelType = mapLabels.keySet().iterator();
|
Iterator<LabelType> iteratorLabelType = mapLabels.keySet().iterator();
|
||||||
|
|
||||||
while (iteratorLabelType.hasNext() && getListMatching().size() < 10) {
|
while (iteratorLabelType.hasNext() && getListMatching().size() < 10) {
|
||||||
LabelType type = iteratorLabelType.next();
|
LabelType type = iteratorLabelType.next();
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < mapLabels.get(type).size(); i++) {
|
for (int i = 0; getListMatching().size() < 10 && i < mapLabels.get(type).size(); i++) {
|
||||||
Label label = mapLabels.get(type).get(i);
|
Label label = mapLabels.get(type).get(i);
|
||||||
addLabel(type, label);
|
addLabel(label);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return getListMatching();
|
return getListMatching();
|
||||||
|
|
@ -82,12 +84,12 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersCriterions() {
|
private List<FilterPair> fillWithFirstTenFiltersCriterions() {
|
||||||
SortedMap<CriterionType, List<Criterion>> mapCriterions = getMapCriterions();
|
SortedMap<CriterionType, List<Criterion>> mapCriterions = getMapCriterions();
|
||||||
Iterator<CriterionType> iteratorCriterionType = mapCriterions.keySet()
|
Iterator<CriterionType> iteratorCriterionType = mapCriterions.keySet().iterator();
|
||||||
.iterator();
|
|
||||||
while (iteratorCriterionType.hasNext() && getListMatching().size() < 10) {
|
while (iteratorCriterionType.hasNext() && getListMatching().size() < 10) {
|
||||||
CriterionType type = iteratorCriterionType.next();
|
CriterionType type = iteratorCriterionType.next();
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < mapCriterions.get(type).size(); i++) {
|
for (int i = 0; getListMatching().size() < 10 && i < mapCriterions.get(type).size(); i++) {
|
||||||
Criterion criterion = mapCriterions.get(type).get(i);
|
Criterion criterion = mapCriterions.get(type).get(i);
|
||||||
addCriterion(type, criterion);
|
addCriterion(type, criterion);
|
||||||
}
|
}
|
||||||
|
|
@ -100,10 +102,8 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersCustomer() {
|
private List<FilterPair> fillWithFirstTenFiltersCustomer() {
|
||||||
List<ExternalCompany> externalCompanies = databaseSnapshots
|
List<ExternalCompany> externalCompanies = databaseSnapshots.snapshotExternalCompanies();
|
||||||
.snapshotExternalCompanies();
|
for (int i = 0; getListMatching().size() < 10 && i < externalCompanies.size(); i++) {
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < externalCompanies.size(); i++) {
|
|
||||||
ExternalCompany externalCompany = externalCompanies.get(i);
|
ExternalCompany externalCompany = externalCompanies.get(i);
|
||||||
addExternalCompany(externalCompany);
|
addExternalCompany(externalCompany);
|
||||||
}
|
}
|
||||||
|
|
@ -111,8 +111,7 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersState() {
|
private List<FilterPair> fillWithFirstTenFiltersState() {
|
||||||
for (int i = 0; getListMatching().size() < 10
|
for (int i = 0; getListMatching().size() < 10 && i < OrderStatusEnum.values().length; i++) {
|
||||||
&& i < OrderStatusEnum.values().length; i++) {
|
|
||||||
OrderStatusEnum state = OrderStatusEnum.values()[i];
|
OrderStatusEnum state = OrderStatusEnum.values()[i];
|
||||||
addState(state);
|
addState(state);
|
||||||
}
|
}
|
||||||
|
|
@ -129,10 +128,8 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWihtFirstTenFiltersCustomerReferences() {
|
private List<FilterPair> fillWihtFirstTenFiltersCustomerReferences() {
|
||||||
List<String> customerReferences = databaseSnapshots
|
List<String> customerReferences = databaseSnapshots.snapshotCustomerReferences();
|
||||||
.snapshotCustomerReferences();
|
for (int i = 0; getListMatching().size() < 10 && i < customerReferences.size(); i++) {
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < customerReferences.size(); i++) {
|
|
||||||
String reference = customerReferences.get(i);
|
String reference = customerReferences.get(i);
|
||||||
addCustomerReference(reference);
|
addCustomerReference(reference);
|
||||||
}
|
}
|
||||||
|
|
@ -163,10 +160,9 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void searchInCriterionTypes(String filter) {
|
private void searchInCriterionTypes(String filter) {
|
||||||
boolean limited = (filter.length() < 3);
|
boolean limited = filter.length() < 3;
|
||||||
for (CriterionType type : getMapCriterions().keySet()) {
|
for (CriterionType type : getMapCriterions().keySet()) {
|
||||||
String name = StringUtils.deleteWhitespace(type.getName()
|
String name = StringUtils.deleteWhitespace(type.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
setFilterPairCriterionType(type, limited);
|
setFilterPairCriterionType(type, limited);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -180,9 +176,9 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
if (list == null) {
|
if (list == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Criterion criterion : list) {
|
for (Criterion criterion : list) {
|
||||||
String name = StringUtils.deleteWhitespace(criterion.getName()
|
String name = StringUtils.deleteWhitespace(criterion.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
addCriterion(type, criterion);
|
addCriterion(type, criterion);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
|
|
@ -203,10 +199,9 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInLabelTypes(String filter) {
|
private void searchInLabelTypes(String filter) {
|
||||||
Map<LabelType, List<Label>> mapLabels = getLabelsMap();
|
Map<LabelType, List<Label>> mapLabels = getLabelsMap();
|
||||||
boolean limited = (filter.length() < 3);
|
boolean limited = filter.length() < 3;
|
||||||
for (LabelType type : mapLabels.keySet()) {
|
for (LabelType type : mapLabels.keySet()) {
|
||||||
String name = StringUtils.deleteWhitespace(type.getName()
|
String name = StringUtils.deleteWhitespace(type.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
setFilterPairLabelType(type, limited);
|
setFilterPairLabelType(type, limited);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -221,10 +216,9 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInLabels(LabelType type, String filter) {
|
private void searchInLabels(LabelType type, String filter) {
|
||||||
for (Label label : getLabelsMap().get(type)) {
|
for (Label label : getLabelsMap().get(type)) {
|
||||||
String name = StringUtils.deleteWhitespace(label.getName()
|
String name = StringUtils.deleteWhitespace(label.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
addLabel(type, label);
|
addLabel(label);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -234,7 +228,7 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void setFilterPairLabelType(LabelType type, boolean limited) {
|
private void setFilterPairLabelType(LabelType type, boolean limited) {
|
||||||
for (Label label : getLabelsMap().get(type)) {
|
for (Label label : getLabelsMap().get(type)) {
|
||||||
addLabel(type, label);
|
addLabel(label);
|
||||||
if ((limited) && (getListMatching().size() > 9)) {
|
if ((limited) && (getListMatching().size() > 9)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -242,12 +236,10 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void searchInExternalCompanies(String filter){
|
private void searchInExternalCompanies(String filter){
|
||||||
for(ExternalCompany externalCompany : databaseSnapshots
|
for(ExternalCompany externalCompany : databaseSnapshots.snapshotExternalCompanies()){
|
||||||
.snapshotExternalCompanies()){
|
String name = StringUtils.deleteWhitespace(externalCompany.getName().toLowerCase());
|
||||||
String name = StringUtils.deleteWhitespace(externalCompany
|
String nif = StringUtils.deleteWhitespace(externalCompany.getNif().toLowerCase());
|
||||||
.getName().toLowerCase());
|
|
||||||
String nif = StringUtils.deleteWhitespace(externalCompany.getNif()
|
|
||||||
.toLowerCase());
|
|
||||||
if ((name.contains(filter)) || (nif.contains(filter))) {
|
if ((name.contains(filter)) || (nif.contains(filter))) {
|
||||||
addExternalCompany(externalCompany);
|
addExternalCompany(externalCompany);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
|
|
@ -259,8 +251,7 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void searchInOrderStatus(String filter) {
|
private void searchInOrderStatus(String filter) {
|
||||||
for (OrderStatusEnum state : OrderStatusEnum.values()) {
|
for (OrderStatusEnum state : OrderStatusEnum.values()) {
|
||||||
String name = StringUtils.deleteWhitespace(state.name()
|
String name = StringUtils.deleteWhitespace(_(state.name()).toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
addState(state);
|
addState(state);
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
|
|
@ -273,8 +264,10 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
private void searchInOrderCodes(String filter) {
|
private void searchInOrderCodes(String filter) {
|
||||||
if (filter.indexOf("cod:") == 0) {
|
if (filter.indexOf("cod:") == 0) {
|
||||||
String codeFilter = filter.replaceFirst("cod:", "");
|
String codeFilter = filter.replaceFirst("cod:", "");
|
||||||
|
|
||||||
for (String code : databaseSnapshots.snapshotOrdersCodes()) {
|
for (String code : databaseSnapshots.snapshotOrdersCodes()) {
|
||||||
code = StringUtils.deleteWhitespace(code.toLowerCase());
|
code = StringUtils.deleteWhitespace(code.toLowerCase());
|
||||||
|
|
||||||
if (code.equals(codeFilter)) {
|
if (code.equals(codeFilter)) {
|
||||||
addCode(code);
|
addCode(code);
|
||||||
return;
|
return;
|
||||||
|
|
@ -286,10 +279,10 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
private void searchInCustomerReferences(String filter) {
|
private void searchInCustomerReferences(String filter) {
|
||||||
if (filter.indexOf("rc:") == 0) {
|
if (filter.indexOf("rc:") == 0) {
|
||||||
String referenceFilter = filter.replaceFirst("rc:", "");
|
String referenceFilter = filter.replaceFirst("rc:", "");
|
||||||
for (String reference : databaseSnapshots
|
|
||||||
.snapshotCustomerReferences()) {
|
for (String reference : databaseSnapshots.snapshotCustomerReferences()) {
|
||||||
reference = StringUtils.deleteWhitespace(reference
|
reference = StringUtils.deleteWhitespace(reference.toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (reference.equals(referenceFilter)) {
|
if (reference.equals(referenceFilter)) {
|
||||||
addCustomerReference(reference);
|
addCustomerReference(reference);
|
||||||
return;
|
return;
|
||||||
|
|
@ -300,51 +293,40 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void addCriterion(CriterionType type, Criterion criterion) {
|
private void addCriterion(CriterionType type, Criterion criterion) {
|
||||||
String pattern = criterion.getName() + " ( " + type.getName() + " )";
|
String pattern = criterion.getName() + " ( " + type.getName() + " )";
|
||||||
getListMatching().add(
|
|
||||||
new FilterPair(TaskGroupFilterEnum.Criterion, type
|
getListMatching().add(new FilterPair(
|
||||||
.getResource()
|
TaskGroupFilterEnum.Criterion, type.getResource().toLowerCase(), pattern, criterion));
|
||||||
.toLowerCase(), pattern, criterion));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addLabel(LabelType type, Label label) {
|
private void addLabel(Label label) {
|
||||||
getListMatching().add(
|
getListMatching().add(new FilterPair(TaskGroupFilterEnum.Label, label.getFinderPattern(), label));
|
||||||
new FilterPair(TaskGroupFilterEnum.Label, label
|
|
||||||
.getFinderPattern(), label));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addExternalCompany(ExternalCompany externalCompany) {
|
private void addExternalCompany(ExternalCompany externalCompany) {
|
||||||
String pattern = externalCompany.getName() + " :: "
|
String pattern = externalCompany.getName() + " :: " + externalCompany.getNif();
|
||||||
+ externalCompany.getNif();
|
getListMatching().add(new FilterPair(TaskGroupFilterEnum.ExternalCompany, pattern, externalCompany));
|
||||||
getListMatching().add(
|
|
||||||
new FilterPair(TaskGroupFilterEnum.ExternalCompany,
|
|
||||||
pattern, externalCompany));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addState(OrderStatusEnum state) {
|
private void addState(OrderStatusEnum state) {
|
||||||
getListMatching().add(
|
getListMatching().add(new FilterPair(TaskGroupFilterEnum.State, _(state.name()), state));
|
||||||
new FilterPair(TaskGroupFilterEnum.State, state.name(),
|
|
||||||
state));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addCode(String code) {
|
private void addCode(String code) {
|
||||||
getListMatching().add(
|
getListMatching().add(new FilterPair(TaskGroupFilterEnum.Code, code, code));
|
||||||
new FilterPair(TaskGroupFilterEnum.Code, code, code));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addCustomerReference(String reference) {
|
private void addCustomerReference(String reference) {
|
||||||
getListMatching().add(
|
getListMatching().add(new FilterPair(TaskGroupFilterEnum.CustomerReference, reference, reference));
|
||||||
new FilterPair(TaskGroupFilterEnum.CustomerReference,
|
|
||||||
reference, reference));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<FilterPair> fillWithFirstTenFiltersResources() {
|
private List<FilterPair> fillWithFirstTenFiltersResources() {
|
||||||
Map<Class<?>, List<Resource>> mapResources = databaseSnapshots
|
Map<Class<?>, List<Resource>> mapResources = databaseSnapshots.snapshotMapResources();
|
||||||
.snapshotMapResources();
|
|
||||||
Iterator<Class<?>> iteratorClass = mapResources.keySet().iterator();
|
Iterator<Class<?>> iteratorClass = mapResources.keySet().iterator();
|
||||||
|
|
||||||
while (iteratorClass.hasNext() && getListMatching().size() < 10) {
|
while (iteratorClass.hasNext() && getListMatching().size() < 10) {
|
||||||
Class<?> className = iteratorClass.next();
|
Class<?> className = iteratorClass.next();
|
||||||
for (int i = 0; getListMatching().size() < 10
|
|
||||||
&& i < mapResources.get(className).size(); i++) {
|
for (int i = 0; getListMatching().size() < 10 && i < mapResources.get(className).size(); i++) {
|
||||||
Resource resource = mapResources.get(className).get(i);
|
Resource resource = mapResources.get(className).get(i);
|
||||||
addResource(className, resource);
|
addResource(className, resource);
|
||||||
}
|
}
|
||||||
|
|
@ -353,14 +335,14 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void searchInResources(String filter) {
|
private void searchInResources(String filter) {
|
||||||
Map<Class<?>, List<Resource>> mapResources = databaseSnapshots
|
Map<Class<?>, List<Resource>> mapResources = databaseSnapshots.snapshotMapResources();
|
||||||
.snapshotMapResources();
|
|
||||||
for (Class<?> className : mapResources.keySet()) {
|
for (Class<?> className : mapResources.keySet()) {
|
||||||
for (Resource resource : mapResources.get(className)) {
|
for (Resource resource : mapResources.get(className)) {
|
||||||
String name = StringUtils.deleteWhitespace(resource.getName()
|
String name = StringUtils.deleteWhitespace(resource.getName().toLowerCase());
|
||||||
.toLowerCase());
|
|
||||||
if (name.contains(filter)) {
|
if (name.contains(filter)) {
|
||||||
addResource(className, resource);
|
addResource(className, resource);
|
||||||
|
|
||||||
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
if ((filter.length() < 3) && (getListMatching().size() > 9)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -371,9 +353,9 @@ public class TaskGroupsMultipleFiltersFinder extends MultipleFiltersFinder {
|
||||||
|
|
||||||
private void addResource(Class className, Resource resource) {
|
private void addResource(Class className, Resource resource) {
|
||||||
String pattern = resource.getName();
|
String pattern = resource.getName();
|
||||||
getListMatching().add(
|
|
||||||
new FilterPair(TaskGroupFilterEnum.Resource, className
|
getListMatching().add(new FilterPair(
|
||||||
.getSimpleName(), pattern, resource));
|
TaskGroupFilterEnum.Resource, className.getSimpleName(), pattern, resource));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue