mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-12 20:43:08 +00:00
fix browse pages
This commit is contained in:
@@ -5,11 +5,11 @@ import { isNotEmpty } from '../../shared/empty.util';
|
|||||||
import { ObjectCacheService } from '../cache/object-cache.service';
|
import { ObjectCacheService } from '../cache/object-cache.service';
|
||||||
import { ErrorResponse, GenericSuccessResponse, RestResponse } from '../cache/response.models';
|
import { ErrorResponse, GenericSuccessResponse, RestResponse } from '../cache/response.models';
|
||||||
import { DSpaceRESTV2Response } from '../dspace-rest-v2/dspace-rest-v2-response.model';
|
import { DSpaceRESTV2Response } from '../dspace-rest-v2/dspace-rest-v2-response.model';
|
||||||
import { NormalizedObjectSerializer } from '../dspace-rest-v2/normalized-object.serializer';
|
import { DSpaceSerializer } from '../dspace-rest-v2/dspace.serializer';
|
||||||
|
import { BrowseEntry } from '../shared/browse-entry.model';
|
||||||
import { BaseResponseParsingService } from './base-response-parsing.service';
|
import { BaseResponseParsingService } from './base-response-parsing.service';
|
||||||
import { ResponseParsingService } from './parsing.service';
|
import { ResponseParsingService } from './parsing.service';
|
||||||
import { RestRequest } from './request.models';
|
import { RestRequest } from './request.models';
|
||||||
import { NormalizedBrowseEntry } from '../shared/normalized-browse-entry.model';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class BrowseEntriesResponseParsingService extends BaseResponseParsingService implements ResponseParsingService {
|
export class BrowseEntriesResponseParsingService extends BaseResponseParsingService implements ResponseParsingService {
|
||||||
@@ -26,7 +26,7 @@ export class BrowseEntriesResponseParsingService extends BaseResponseParsingServ
|
|||||||
if (isNotEmpty(data.payload)) {
|
if (isNotEmpty(data.payload)) {
|
||||||
let browseEntries = [];
|
let browseEntries = [];
|
||||||
if (isNotEmpty(data.payload._embedded) && Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) {
|
if (isNotEmpty(data.payload._embedded) && Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) {
|
||||||
const serializer = new NormalizedObjectSerializer(NormalizedBrowseEntry);
|
const serializer = new DSpaceSerializer(BrowseEntry);
|
||||||
browseEntries = serializer.deserializeArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]]);
|
browseEntries = serializer.deserializeArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]]);
|
||||||
}
|
}
|
||||||
return new GenericSuccessResponse(browseEntries, data.statusCode, data.statusText, this.processPageInfo(data.payload));
|
return new GenericSuccessResponse(browseEntries, data.statusCode, data.statusText, this.processPageInfo(data.payload));
|
||||||
|
@@ -3,15 +3,14 @@ import { Inject, Injectable } from '@angular/core';
|
|||||||
import { GLOBAL_CONFIG } from '../../../config';
|
import { GLOBAL_CONFIG } from '../../../config';
|
||||||
import { GlobalConfig } from '../../../config/global-config.interface';
|
import { GlobalConfig } from '../../../config/global-config.interface';
|
||||||
import { hasValue, isNotEmpty } from '../../shared/empty.util';
|
import { hasValue, isNotEmpty } from '../../shared/empty.util';
|
||||||
|
import { NormalizedDSpaceObject } from '../cache/models/normalized-dspace-object.model';
|
||||||
import { ObjectCacheService } from '../cache/object-cache.service';
|
import { ObjectCacheService } from '../cache/object-cache.service';
|
||||||
import { ErrorResponse, GenericSuccessResponse, RestResponse } from '../cache/response.models';
|
import { ErrorResponse, GenericSuccessResponse, RestResponse } from '../cache/response.models';
|
||||||
import { DSpaceRESTV2Response } from '../dspace-rest-v2/dspace-rest-v2-response.model';
|
import { DSpaceRESTV2Response } from '../dspace-rest-v2/dspace-rest-v2-response.model';
|
||||||
import { NormalizedObjectSerializer } from '../dspace-rest-v2/normalized-object.serializer';
|
import { DSpaceSerializer } from '../dspace-rest-v2/dspace.serializer';
|
||||||
import { BaseResponseParsingService } from './base-response-parsing.service';
|
import { BaseResponseParsingService } from './base-response-parsing.service';
|
||||||
import { ResponseParsingService } from './parsing.service';
|
import { ResponseParsingService } from './parsing.service';
|
||||||
import { RestRequest } from './request.models';
|
import { RestRequest } from './request.models';
|
||||||
import { DSpaceObject } from '../shared/dspace-object.model';
|
|
||||||
import { NormalizedDSpaceObject } from '../cache/models/normalized-dspace-object.model';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A ResponseParsingService used to parse DSpaceRESTV2Response coming from the REST API to Browse Items (DSpaceObject[])
|
* A ResponseParsingService used to parse DSpaceRESTV2Response coming from the REST API to Browse Items (DSpaceObject[])
|
||||||
@@ -35,7 +34,7 @@ export class BrowseItemsResponseParsingService extends BaseResponseParsingServic
|
|||||||
parse(request: RestRequest, data: DSpaceRESTV2Response): RestResponse {
|
parse(request: RestRequest, data: DSpaceRESTV2Response): RestResponse {
|
||||||
if (isNotEmpty(data.payload) && isNotEmpty(data.payload._embedded)
|
if (isNotEmpty(data.payload) && isNotEmpty(data.payload._embedded)
|
||||||
&& Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) {
|
&& Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) {
|
||||||
const serializer = new NormalizedObjectSerializer(NormalizedDSpaceObject);
|
const serializer = new DSpaceSerializer(NormalizedDSpaceObject);
|
||||||
const items = serializer.deserializeArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]]);
|
const items = serializer.deserializeArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]]);
|
||||||
return new GenericSuccessResponse(items, data.statusCode, data.statusText, this.processPageInfo(data.payload));
|
return new GenericSuccessResponse(items, data.statusCode, data.statusText, this.processPageInfo(data.payload));
|
||||||
} else if (hasValue(data.payload) && hasValue(data.payload.page)) {
|
} else if (hasValue(data.payload) && hasValue(data.payload.page)) {
|
||||||
|
@@ -1,11 +1,11 @@
|
|||||||
import { Injectable } from '@angular/core';
|
import { Injectable } from '@angular/core';
|
||||||
|
import { isNotEmpty } from '../../shared/empty.util';
|
||||||
|
import { ErrorResponse, GenericSuccessResponse, RestResponse } from '../cache/response.models';
|
||||||
|
import { DSpaceRESTV2Response } from '../dspace-rest-v2/dspace-rest-v2-response.model';
|
||||||
|
import { DSpaceSerializer } from '../dspace-rest-v2/dspace.serializer';
|
||||||
|
import { BrowseDefinition } from '../shared/browse-definition.model';
|
||||||
import { ResponseParsingService } from './parsing.service';
|
import { ResponseParsingService } from './parsing.service';
|
||||||
import { RestRequest } from './request.models';
|
import { RestRequest } from './request.models';
|
||||||
import { DSpaceRESTV2Response } from '../dspace-rest-v2/dspace-rest-v2-response.model';
|
|
||||||
import { GenericSuccessResponse, ErrorResponse, RestResponse } from '../cache/response.models';
|
|
||||||
import { isNotEmpty } from '../../shared/empty.util';
|
|
||||||
import { NormalizedObjectSerializer } from '../dspace-rest-v2/normalized-object.serializer';
|
|
||||||
import { BrowseDefinition } from '../shared/browse-definition.model';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class BrowseResponseParsingService implements ResponseParsingService {
|
export class BrowseResponseParsingService implements ResponseParsingService {
|
||||||
@@ -13,7 +13,7 @@ export class BrowseResponseParsingService implements ResponseParsingService {
|
|||||||
parse(request: RestRequest, data: DSpaceRESTV2Response): RestResponse {
|
parse(request: RestRequest, data: DSpaceRESTV2Response): RestResponse {
|
||||||
if (isNotEmpty(data.payload) && isNotEmpty(data.payload._embedded)
|
if (isNotEmpty(data.payload) && isNotEmpty(data.payload._embedded)
|
||||||
&& Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) {
|
&& Array.isArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]])) {
|
||||||
const serializer = new NormalizedObjectSerializer(BrowseDefinition);
|
const serializer = new DSpaceSerializer(BrowseDefinition);
|
||||||
const browseDefinitions = serializer.deserializeArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]]);
|
const browseDefinitions = serializer.deserializeArray(data.payload._embedded[Object.keys(data.payload._embedded)[0]]);
|
||||||
return new GenericSuccessResponse(browseDefinitions, data.statusCode, data.statusText);
|
return new GenericSuccessResponse(browseDefinitions, data.statusCode, data.statusText);
|
||||||
} else {
|
} else {
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
import { autoserialize } from 'cerialize';
|
import { autoserialize, autoserializeAs, deserialize } from 'cerialize';
|
||||||
import { ListableObject } from '../../shared/object-collection/shared/listable-object.model';
|
import { ListableObject } from '../../shared/object-collection/shared/listable-object.model';
|
||||||
import { resourceType } from '../cache/builders/build-decorators';
|
import { resourceType } from '../cache/builders/build-decorators';
|
||||||
import { TypedObject } from '../cache/object-cache.reducer';
|
import { TypedObject } from '../cache/object-cache.reducer';
|
||||||
@@ -26,24 +26,29 @@ export class BrowseEntry extends ListableObject implements TypedObject {
|
|||||||
/**
|
/**
|
||||||
* The authority string of this browse entry
|
* The authority string of this browse entry
|
||||||
*/
|
*/
|
||||||
|
@autoserialize
|
||||||
authority: string;
|
authority: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The value of this browse entry
|
* The value of this browse entry
|
||||||
*/
|
*/
|
||||||
|
@autoserialize
|
||||||
value: string;
|
value: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The language of the value of this browse entry
|
* The language of the value of this browse entry
|
||||||
*/
|
*/
|
||||||
|
@autoserializeAs('valueLang')
|
||||||
language: string;
|
language: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The count of this browse entry
|
* The count of this browse entry
|
||||||
*/
|
*/
|
||||||
@excludeFromEquals
|
@excludeFromEquals
|
||||||
|
@autoserialize
|
||||||
count: number;
|
count: number;
|
||||||
|
|
||||||
|
@deserialize
|
||||||
_links: {
|
_links: {
|
||||||
self: HALLink;
|
self: HALLink;
|
||||||
entries: HALLink;
|
entries: HALLink;
|
||||||
|
@@ -1,33 +0,0 @@
|
|||||||
import { autoserialize, autoserializeAs, inheritSerialization } from 'cerialize';
|
|
||||||
import { BrowseEntry } from './browse-entry.model';
|
|
||||||
import { NormalizedObject } from '../cache/models/normalized-object.model';
|
|
||||||
/**
|
|
||||||
* Class object representing a browse entry
|
|
||||||
* This class is not normalized because browse entries do not have self links
|
|
||||||
*/
|
|
||||||
@inheritSerialization(NormalizedObject)
|
|
||||||
export class NormalizedBrowseEntry extends NormalizedObject<BrowseEntry> {
|
|
||||||
/**
|
|
||||||
* The authority string of this browse entry
|
|
||||||
*/
|
|
||||||
@autoserialize
|
|
||||||
authority: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The value of this browse entry
|
|
||||||
*/
|
|
||||||
@autoserialize
|
|
||||||
value: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The language of the value of this browse entry
|
|
||||||
*/
|
|
||||||
@autoserializeAs('valueLang')
|
|
||||||
language: string;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The count of this browse entry
|
|
||||||
*/
|
|
||||||
@autoserialize
|
|
||||||
count: number;
|
|
||||||
}
|
|
Reference in New Issue
Block a user