Add foslabel in searchFiles only for beta, dev. Change eoscifguidelines to refine. Input fix double icon in select with many values.

This commit is contained in:
Konstantinos Triantafyllou 2023-07-06 12:53:37 +03:00
parent ea1b054b63
commit 76cb586ebd
2 changed files with 79 additions and 61 deletions

View File

@ -168,11 +168,11 @@ declare var UIkit;
<ng-template [ngIf]="formControl.enabled"> <ng-template [ngIf]="formControl.enabled">
<icon *ngIf="!searchControl?.value && icon" [name]="icon" [flex]="true"></icon> <icon *ngIf="!searchControl?.value && icon" [name]="icon" [flex]="true"></icon>
<icon *ngIf="!icon && selectable && selectArrow" [name]="selectArrow" [flex]="true"></icon> <icon *ngIf="!icon && selectable && selectArrow" [name]="selectArrow" [flex]="true"></icon>
<button *ngIf="focused && type === 'autocomplete'" class="uk-close uk-icon" <button *ngIf="focused && type === 'autocomplete' && (!selectable || searchControl.value)" class="uk-close uk-icon"
(click)="resetSearch($event)"> (click)="resetSearch($event)">
<icon [flex]="true" name="close"></icon> <icon [flex]="true" name="close"></icon>
</button> </button>
<button *ngIf="(!focused && type === 'autocomplete') || (type !== 'autocomplete' && !searchControl?.value && !!formControl?.value && (searchable || !selectable))" <button *ngIf="(!focused && type === 'autocomplete' && !selectable) || (type !== 'autocomplete' && !searchControl?.value && !!formControl?.value && (searchable || !selectable))"
class="uk-close uk-icon" (click)="resetValue($event)"> class="uk-close uk-icon" (click)="resetValue($event)">
<icon [flex]="true" name="close"></icon> <icon [flex]="true" name="close"></icon>
</button> </button>

View File

@ -14,7 +14,7 @@ export class SearchFields {
// Remove Collected From Filter "collectedfrom","collectedfrom" // Remove Collected From Filter "collectedfrom","collectedfrom"
public RESULT_REFINE_FIELDS = [ public RESULT_REFINE_FIELDS = [
"resultbestaccessright", "instancetypename", "fos", "relfunder", "resultbestaccessright", "instancetypename", (properties.environment !== 'production' ? "foslabel" : "fos"), "relfunder",
"relfundinglevel0_id", "relfundinglevel1_id", "relfundinglevel2_id", "relfundinglevel0_id", "relfundinglevel1_id", "relfundinglevel2_id",
"relproject", "sdg", "country", "resultlanguagename", "resulthostingdatasource", "community"]; "relproject", "sdg", "country", "resultlanguagename", "resulthostingdatasource", "community"];
@ -59,7 +59,7 @@ export class SearchFields {
}, },
["eoscifguidelines"]: { ["eoscifguidelines"]: {
name: "EOSC Subject", name: "EOSC Subject",
type: "keyword", type: "refine",
param: "eoscSubj", param: "eoscSubj",
operator: "es", operator: "es",
equalityOperator: " exact ", equalityOperator: " exact ",
@ -81,9 +81,16 @@ export class SearchFields {
equalityOperator: "=", equalityOperator: "=",
filterType: null filterType: null
}, },
["pid"]: {name: "PID", type: "keyword", param: "pid", operator: "pd", equalityOperator: " exact ", filterType: null}, ["pid"]: {
name: "PID",
type: "keyword",
param: "pid",
operator: "pd",
equalityOperator: " exact ",
filterType: null
},
["resulthostingdatasourceid"]: { ["resulthostingdatasourceid"]: {
name: "Hosting "+OpenaireEntities.DATASOURCE, name: "Hosting " + OpenaireEntities.DATASOURCE,
type: "entity", type: "entity",
param: "hostedBy", param: "hostedBy",
operator: "hs", operator: "hs",
@ -219,7 +226,7 @@ export class SearchFields {
filterType: null filterType: null
}, },
["collectedfromdatasourceid"]: { ["collectedfromdatasourceid"]: {
name: "Collected from "+OpenaireEntities.DATASOURCE, name: "Collected from " + OpenaireEntities.DATASOURCE,
type: "entity", type: "entity",
param: "collectedFrom", param: "collectedFrom",
operator: "cl", operator: "cl",
@ -257,6 +264,14 @@ export class SearchFields {
operator: "fs", operator: "fs",
equalityOperator: " exact ", equalityOperator: " exact ",
filterType: "checkbox" filterType: "checkbox"
},
["foslabel"]: {
name: "Field of Science [Beta]",
type: "vocabulary",
param: "foslabel",
operator: "fl",
equalityOperator: " exact ",
filterType: "checkbox"
} }
}; };
@ -378,7 +393,7 @@ export class SearchFields {
// filterType: "radio" // filterType: "radio"
// }, // },
["projectoamandatepublications"]: { ["projectoamandatepublications"]: {
name: "OA "+OpenaireEntities.PUBLICATIONS+" Mandate", name: "OA " + OpenaireEntities.PUBLICATIONS + " Mandate",
type: "boolean", type: "boolean",
param: "oapubl", param: "oapubl",
operator: "oap", operator: "oap",
@ -386,7 +401,7 @@ export class SearchFields {
filterType: "radio" filterType: "radio"
}, },
["projectoamandatedata"]: { ["projectoamandatedata"]: {
name: "OA "+OpenaireEntities.DATASETS+" Mandate", name: "OA " + OpenaireEntities.DATASETS + " Mandate",
type: "boolean", type: "boolean",
param: "oadata", param: "oadata",
operator: "oad", operator: "oad",
@ -410,7 +425,7 @@ export class SearchFields {
filterType: null filterType: null
}, },
["collectedfromdatasourceid"]: { ["collectedfromdatasourceid"]: {
name: "Collected from "+OpenaireEntities.DATASOURCE, name: "Collected from " + OpenaireEntities.DATASOURCE,
type: "entity", type: "entity",
param: "collectedFrom", param: "collectedFrom",
operator: "cl", operator: "cl",
@ -423,7 +438,7 @@ export class SearchFields {
//DATAPROVIDERS //DATAPROVIDERS
// add Collected From Filter "collectedfromname" // add Collected From Filter "collectedfromname"
public DATASOURCE_REFINE_FIELDS: string[] = ["eoscdatasourcetype", "datasourceodlanguages", "datasourceodcontenttypes", public DATASOURCE_REFINE_FIELDS: string[] = ["eoscdatasourcetype", "datasourceodlanguages", "datasourceodcontenttypes",
"datasourcecompatibilityname", "country", "collectedfromname","datasourcethematic", "datasourcecompatibilityname", "country", "collectedfromname", "datasourcethematic",
"datasourcejurisdiction"]; "datasourcejurisdiction"];
public DATASOURCE_ADVANCED_FIELDS: string[] = ["q", "datasourceofficialname", public DATASOURCE_ADVANCED_FIELDS: string[] = ["q", "datasourceofficialname",
"datasourceenglishname", "datasourceodsubjects", "datasourcetypename", "datasourceodlanguages", "datasourceenglishname", "datasourceodsubjects", "datasourcetypename", "datasourceodlanguages",
@ -536,7 +551,7 @@ export class SearchFields {
filterType: "checkbox" filterType: "checkbox"
}, },
["collectedfromdatasourceid"]: { ["collectedfromdatasourceid"]: {
name: "Collected from "+OpenaireEntities.DATASOURCE, name: "Collected from " + OpenaireEntities.DATASOURCE,
type: "entity", type: "entity",
param: "collectedFrom", param: "collectedFrom",
operator: "cl", operator: "cl",
@ -579,7 +594,7 @@ export class SearchFields {
{"name": "country", "equalityOperator": " exact "}, {"name": "country", "equalityOperator": " exact "},
{"name": "datasourcesubject", "equalityOperator": " all "} {"name": "datasourcesubject", "equalityOperator": " all "}
]; ];
public DEPOSIT_DATASOURCE_REFINE_FIELDS: string[] = ["datasourcetypename", "country", "datasourceodsubjects", "datasourceodcontenttypes", "datasourcecompatibilityname","datasourcethematic", "datasourcejurisdiction"]; public DEPOSIT_DATASOURCE_REFINE_FIELDS: string[] = ["datasourcetypename", "country", "datasourceodsubjects", "datasourceodcontenttypes", "datasourcecompatibilityname", "datasourcethematic", "datasourcejurisdiction"];
public DEPOSIT_DATASOURCE_FIELDS: { [key: string]: FieldDetails } = { public DEPOSIT_DATASOURCE_FIELDS: { [key: string]: FieldDetails } = {
["datasourcetypeuiname"]: { ["datasourcetypeuiname"]: {
@ -634,15 +649,15 @@ export class SearchFields {
// public COMPATIBLE_DATAPROVIDER_FIELDS: string[] = ["datasourcetypename", "datasourcecompatibilityname"]; // public COMPATIBLE_DATAPROVIDER_FIELDS: string[] = ["datasourcetypename", "datasourcecompatibilityname"];
public COMPATIBLE_DATAPROVIDER_FIELDS: string[] = ["datasourcetypename", "datasourceodlanguages", "datasourceodcontenttypes", public COMPATIBLE_DATAPROVIDER_FIELDS: string[] = ["datasourcetypename", "datasourceodlanguages", "datasourceodcontenttypes",
"datasourcecompatibilityname", "country", "collectedfromname","datasourcethematic", "datasourcecompatibilityname", "country", "collectedfromname", "datasourcethematic",
"datasourcejurisdiction"]; "datasourcejurisdiction"];
// public ENTITY_REGISTRIES_FIELDS: string[] = ["datasourcetypename", "datasourcecompatibilityname"]; // public ENTITY_REGISTRIES_FIELDS: string[] = ["datasourcetypename", "datasourcecompatibilityname"];
public ENTITY_REGISTRIES_FIELDS: string[] = ["datasourcetypename", "datasourceodlanguages", "datasourceodcontenttypes", public ENTITY_REGISTRIES_FIELDS: string[] = ["datasourcetypename", "datasourceodlanguages", "datasourceodcontenttypes",
"datasourcecompatibilityname", "country", "collectedfromname","datasourcethematic", "datasourcecompatibilityname", "country", "collectedfromname", "datasourcethematic",
"datasourcejurisdiction"]; "datasourcejurisdiction"];
// public JOURNAL_FIELDS: string[] = ["datasourcetypename", "datasourcecompatibilityname"]; // public JOURNAL_FIELDS: string[] = ["datasourcetypename", "datasourcecompatibilityname"];
public JOURNAL_FIELDS: string[] = ["datasourcetypename", "datasourceodlanguages", "datasourceodcontenttypes", public JOURNAL_FIELDS: string[] = ["datasourcetypename", "datasourceodlanguages", "datasourceodcontenttypes",
"datasourcecompatibilityname", "country", "collectedfromname","datasourcethematic", "datasourcecompatibilityname", "country", "collectedfromname", "datasourcethematic",
"datasourcejurisdiction"]; "datasourcejurisdiction"];
@ -741,16 +756,17 @@ export class SearchFields {
return null; return null;
} }
} }
getFieldName(fieldId: string, fieldType: string): string { getFieldName(fieldId: string, fieldType: string): string {
let field = this.getField(fieldId, fieldType); let field = this.getField(fieldId, fieldType);
return field?field.name:"UNDEFINED"; return field ? field.name : "UNDEFINED";
} }
sortFieldsByName(fieldIds: string[], fieldIdsMap: { [key: string]: FieldDetails }) { sortFieldsByName(fieldIds: string[], fieldIdsMap: { [key: string]: FieldDetails }) {
fieldIds.sort((a: string, b: string) => { fieldIds.sort((a: string, b: string) => {
if(a == "q") { if (a == "q") {
return -1; return -1;
} else if(b == "q") { } else if (b == "q") {
return 1; return 1;
} }
let nameA: string = fieldIdsMap[a].name; let nameA: string = fieldIdsMap[a].name;
@ -761,30 +777,31 @@ export class SearchFields {
getFieldFilterType(fieldId: string, fieldType: string, usedBy: string = "search"): string { getFieldFilterType(fieldId: string, fieldType: string, usedBy: string = "search"): string {
let field = this.getField(fieldId, fieldType); let field = this.getField(fieldId, fieldType);
return field?field.filterType:"checkbox"; return field ? field.filterType : "checkbox";
} }
getFieldParam(fieldId: string, fieldType: string): string { getFieldParam(fieldId: string, fieldType: string): string {
let field = this.getField(fieldId, fieldType); let field = this.getField(fieldId, fieldType);
return field?field.param:"UNDEFINED"; return field ? field.param : "UNDEFINED";
} }
public static getParameterOrder(fieldId: string, params): number { public static getParameterOrder(fieldId: string, params): number {
let fields = []; let fields = [];
let searchFields = new SearchFields(); let searchFields = new SearchFields();
if (searchFields.RESULT_REFINE_FIELDS.indexOf(fieldId) !=-1) { if (searchFields.RESULT_REFINE_FIELDS.indexOf(fieldId) != -1) {
fields = searchFields.RESULT_REFINE_FIELDS; fields = searchFields.RESULT_REFINE_FIELDS;
} else if (searchFields.PROJECT_REFINE_FIELDS.indexOf(fieldId) !=-1) { } else if (searchFields.PROJECT_REFINE_FIELDS.indexOf(fieldId) != -1) {
fields = searchFields.PROJECT_REFINE_FIELDS fields = searchFields.PROJECT_REFINE_FIELDS
} else if (searchFields.ORGANIZATION_REFINE_FIELDS.indexOf(fieldId) !=-1) { } else if (searchFields.ORGANIZATION_REFINE_FIELDS.indexOf(fieldId) != -1) {
fields = searchFields.ORGANIZATION_REFINE_FIELDS; fields = searchFields.ORGANIZATION_REFINE_FIELDS;
} else if (searchFields.DATASOURCE_REFINE_FIELDS.indexOf(fieldId) !=-1) { } else if (searchFields.DATASOURCE_REFINE_FIELDS.indexOf(fieldId) != -1) {
fields = searchFields.DATASOURCE_REFINE_FIELDS; fields = searchFields.DATASOURCE_REFINE_FIELDS;
} }
let index = fields.indexOf(fieldId); let index = fields.indexOf(fieldId);
let paramIndex = 0; let paramIndex = 0;
if(index != -1){ if (index != -1) {
for(let keyValue of params){ for (let keyValue of params) {
if(fields.indexOf(keyValue[0])>index){ if (fields.indexOf(keyValue[0]) > index) {
break; break;
} }
paramIndex++ paramIndex++
@ -792,6 +809,7 @@ export class SearchFields {
} }
return paramIndex; return paramIndex;
} }
/* /*
AND AND
Funder: relfunder, relfundinglevel0_id, relfundinglevel1_id, relfundinglevel2_id Funder: relfunder, relfundinglevel0_id, relfundinglevel1_id, relfundinglevel2_id