Fix various issues
This commit is contained in:
parent
cdae5ae574
commit
8a7cfab3b8
|
@ -42,6 +42,13 @@ public class Organisations extends BaseController {
|
||||||
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem<List<Organisation>>().payload(organisations).status(ApiMessageCode.NO_MESSAGE));
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem<List<Organisation>>().payload(organisations).status(ApiMessageCode.NO_MESSAGE));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@RequestMapping(method = RequestMethod.POST, value = {"/general/organisations"}, produces = "application/json")
|
||||||
|
public @ResponseBody
|
||||||
|
ResponseEntity<ResponseItem<List<Organisation>>> listGeneralOrganisations(@RequestBody OrganisationsTableRequest organisationsTableRequest, Principal principal) throws Exception {
|
||||||
|
List<Organisation> organisations = organisationsManager.getWithExternal(organisationsTableRequest, principal);
|
||||||
|
return ResponseEntity.status(HttpStatus.OK).body(new ResponseItem<List<Organisation>>().payload(organisations).status(ApiMessageCode.NO_MESSAGE));
|
||||||
|
}
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.POST, value = {"/internal/organisations"}, produces = "application/json")
|
@RequestMapping(method = RequestMethod.POST, value = {"/internal/organisations"}, produces = "application/json")
|
||||||
public @ResponseBody
|
public @ResponseBody
|
||||||
ResponseEntity<ResponseItem<DataTableData<Organisation>>> getPaged(@Valid @RequestBody OrganisationsTableRequest organisationsTableRequest, Principal principal) throws Exception{
|
ResponseEntity<ResponseItem<DataTableData<Organisation>>> getPaged(@Valid @RequestBody OrganisationsTableRequest organisationsTableRequest, Principal principal) throws Exception{
|
||||||
|
|
|
@ -66,6 +66,32 @@ public class OrganisationsManager {
|
||||||
return organisationDataTableData;
|
return organisationDataTableData;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<Organisation> getWithExternal(OrganisationsTableRequest organisationsTableRequest, Principal principal) throws Exception {
|
||||||
|
eu.eudat.data.entities.UserInfo userInfo = new eu.eudat.data.entities.UserInfo();
|
||||||
|
userInfo.setId(principal.getId());
|
||||||
|
OrganisationDao organisationDao = databaseRepository.getOrganisationDao();
|
||||||
|
|
||||||
|
QueryableList<eu.eudat.data.entities.Organisation> items = organisationDao.getWithCriteria(organisationsTableRequest.getCriteria());
|
||||||
|
QueryableList<eu.eudat.data.entities.Organisation> authItems = organisationDao.getAuthenticated(items, userInfo);
|
||||||
|
QueryableList<eu.eudat.data.entities.Organisation> pagedItems = PaginationManager.applyPaging(authItems, organisationsTableRequest);
|
||||||
|
|
||||||
|
List<Organisation> org = pagedItems.toList().stream().distinct().map(item -> new Organisation().fromDataModel(item)).collect(Collectors.toList());
|
||||||
|
|
||||||
|
ExternalUrlCriteria externalUrlCriteria = new ExternalUrlCriteria(organisationsTableRequest.getCriteria().getLabelLike());
|
||||||
|
List<Map<String, String>> remoteRepos = apiContext.getOperationsContext().getRemoteFetcher().getOrganisations(externalUrlCriteria, null);
|
||||||
|
OrganisationsExternalSourcesModel organisationsExternalSourcesModel = new OrganisationsExternalSourcesModel().fromExternalItem(remoteRepos);
|
||||||
|
for (ExternalSourcesItemModel externalListingItem : organisationsExternalSourcesModel) {
|
||||||
|
Organisation organisation = apiContext.getOperationsContext().getBuilderFactory().getBuilder(OrganisationBuilder.class)
|
||||||
|
.name(externalListingItem.getName())
|
||||||
|
.reference(externalListingItem.getRemoteId())
|
||||||
|
.tag(externalListingItem.getTag())
|
||||||
|
.key(externalListingItem.getKey())
|
||||||
|
.build();
|
||||||
|
org.add(organisation);
|
||||||
|
}
|
||||||
|
return org;
|
||||||
|
}
|
||||||
|
|
||||||
public List<Organisation> getCriteriaWithExternal(String query, String type) throws HugeResultSet, NoURLFound {
|
public List<Organisation> getCriteriaWithExternal(String query, String type) throws HugeResultSet, NoURLFound {
|
||||||
ExternalUrlCriteria externalUrlCriteria = new ExternalUrlCriteria(query);
|
ExternalUrlCriteria externalUrlCriteria = new ExternalUrlCriteria(query);
|
||||||
List<Map<String, String>> remoteRepos = apiContext.getOperationsContext().getRemoteFetcher().getOrganisations(externalUrlCriteria, type);
|
List<Map<String, String>> remoteRepos = apiContext.getOperationsContext().getRemoteFetcher().getOrganisations(externalUrlCriteria, type);
|
||||||
|
|
|
@ -95,7 +95,7 @@ public class Researcher implements DataModel<eu.eudat.data.entities.Researcher,
|
||||||
if (this.key != null) {
|
if (this.key != null) {
|
||||||
if (this.key.toLowerCase().equals("internal")) {
|
if (this.key.toLowerCase().equals("internal")) {
|
||||||
if (this.reference != null) {
|
if (this.reference != null) {
|
||||||
researcher.setReference(this.reference);
|
researcher.setReference("dmp:" + this.reference);
|
||||||
} else {
|
} else {
|
||||||
researcher.setReference("dmp:" + this.id);
|
researcher.setReference("dmp:" + this.id);
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,8 @@ import { OrganizationModel } from "../../model/organisation/organization";
|
||||||
import { OrganisationCriteria } from "../../query/organisation/organisation-criteria";
|
import { OrganisationCriteria } from "../../query/organisation/organisation-criteria";
|
||||||
import { DataTableRequest } from "../../model/data-table/data-table-request";
|
import { DataTableRequest } from "../../model/data-table/data-table-request";
|
||||||
import { ConfigurationService } from '../configuration/configuration.service';
|
import { ConfigurationService } from '../configuration/configuration.service';
|
||||||
|
import { ExternalSourceItemModel } from "@app/core/model/external-sources/external-source-item";
|
||||||
|
import { RequestItem } from "@app/core/query/request-item";
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class OrganisationService {
|
export class OrganisationService {
|
||||||
|
@ -28,6 +30,10 @@ export class OrganisationService {
|
||||||
return this.http.post<DataTableData<OrganizationModel>>(this.actionUrl + 'internal/organisations', dataTableRequest , { headers: this.headers });
|
return this.http.post<DataTableData<OrganizationModel>>(this.actionUrl + 'internal/organisations', dataTableRequest , { headers: this.headers });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public searchGeneralOrganisations(dataTableRequest: RequestItem<OrganisationCriteria>): Observable<ExternalSourceItemModel[]> {
|
||||||
|
return this.http.post<ExternalSourceItemModel[]>(this.actionUrl + 'general/organisations', dataTableRequest , { headers: this.headers });
|
||||||
|
}
|
||||||
|
|
||||||
public searchPublicOrganisations(dataTableRequest: DataTableRequest<OrganisationCriteria>): Observable<DataTableData<OrganizationModel>> {
|
public searchPublicOrganisations(dataTableRequest: DataTableRequest<OrganisationCriteria>): Observable<DataTableData<OrganizationModel>> {
|
||||||
return this.http.post<DataTableData<OrganizationModel>>(this.actionUrl + 'public/organisations', dataTableRequest , { headers: this.headers });
|
return this.http.post<DataTableData<OrganizationModel>>(this.actionUrl + 'public/organisations', dataTableRequest , { headers: this.headers });
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import { LanguageInfoService } from '@app/core/services/culture/language-info-se
|
||||||
import { UserModel } from '@app/core/model/user/user';
|
import { UserModel } from '@app/core/model/user/user';
|
||||||
import { AuthService } from '@app/core/services/auth/auth.service';
|
import { AuthService } from '@app/core/services/auth/auth.service';
|
||||||
import { Principal } from '@app/core/model/auth/principal';
|
import { Principal } from '@app/core/model/auth/principal';
|
||||||
|
import { OrganisationService } from '@app/core/services/organisation/organisation.service';
|
||||||
|
|
||||||
interface Visible {
|
interface Visible {
|
||||||
value: boolean;
|
value: boolean;
|
||||||
|
@ -81,7 +82,8 @@ export class MainInfoComponent extends BaseComponent implements OnInit {
|
||||||
private dmpService: DmpService,
|
private dmpService: DmpService,
|
||||||
private dialog: MatDialog,
|
private dialog: MatDialog,
|
||||||
private languageInfoService: LanguageInfoService,
|
private languageInfoService: LanguageInfoService,
|
||||||
private authentication: AuthService
|
private authentication: AuthService,
|
||||||
|
private organizationService: OrganisationService
|
||||||
) {
|
) {
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
@ -145,7 +147,7 @@ export class MainInfoComponent extends BaseComponent implements OnInit {
|
||||||
}
|
}
|
||||||
|
|
||||||
filterOrganisations(value: string): Observable<ExternalSourceItemModel[]> {
|
filterOrganisations(value: string): Observable<ExternalSourceItemModel[]> {
|
||||||
return this.externalSourcesService.searchDMPOrganizations(value);
|
return this.organizationService.searchGeneralOrganisations({ criteria: { labelLike: value } });
|
||||||
}
|
}
|
||||||
|
|
||||||
cantAddOrganizations(): boolean {
|
cantAddOrganizations(): boolean {
|
||||||
|
|
Loading…
Reference in New Issue