Rendered resource list by dientifying facets

This commit is contained in:
Luca Frosini 2019-10-16 11:02:59 +02:00
parent 5a70c0ae75
commit 6b6de30af8
8 changed files with 158 additions and 48 deletions

12
.vscode/launch.json vendored
View File

@ -4,13 +4,21 @@
{ {
"version": "0.2.0", "version": "0.2.0",
"configurations": [ "configurations": [
{
"name": "Launch Chrome 127.0.0.1 (2)",
"type": "chrome",
"request": "launch",
"port": 9281,
"webRoot": "${workspaceFolder}",
"url": "http://127.0.0.1:39447/p/is-monitor/is-monitor-frontend/src/index.html?_cmAuth\u003dwfreghlipl"
},
{ {
"name": "Launch Chrome 127.0.0.1", "name": "Launch Chrome 127.0.0.1",
"type": "chrome", "type": "chrome",
"request": "launch", "request": "launch",
"port": 9207, "port": 9225,
"webRoot": "${workspaceFolder}", "webRoot": "${workspaceFolder}",
"url": "http://127.0.0.1:39447/p/is-monitor/is-monitor-frontend/src/index.html?_cmAuth\u003dwfreghlipl" "url": "http://127.0.0.1:39447/p/is-monitor/is-monitor-frontend/src/app/app.component.html?_cmAuth\u003dwfreghlipl"
} }
] ]
} }

View File

@ -1,8 +1,10 @@
import { Injectable } from '@angular/core'; import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http'; import { HttpClient } from '@angular/common/http';
import { Observable, of } from 'rxjs'; import { Observable, of } from 'rxjs';
import { catchError } from 'rxjs/operators';
import { ISType } from './ISType'; import { ISType } from './ISType';
import { types } from './types'; import { types } from './types';
import { list } from './list';
@Injectable({ @Injectable({
@ -12,6 +14,12 @@ export class IsService {
constructor(private httpClient: HttpClient) { } constructor(private httpClient: HttpClient) { }
private baseURL = 'http://pc-frosini.isti.cnr.it:8080/resource-registry';
private typesURL = this.baseURL + '/types';
private instancesURL = this.baseURL + '/instances';
private queryURL = this.baseURL + '/query';
/* NextNext Token */ /* NextNext Token */
private token = ''; private token = '';
@ -23,25 +31,30 @@ export class IsService {
*/ */
private handleError<T>(operation = 'operation', result?: T) { private handleError<T>(operation = 'operation', result?: T) {
return (error: any): Observable<T> => { return (error: any): Observable<T> => {
console.error(error); console.error(`${operation} failed: ${error.message}`);
console.error(`${operation} failed: ${error.message}`); // log to console instead if (result) {
// Let the app keep running by returning an empty result. console.warn(`${operation} is going to provide hard-coded data which is better than nothing.`);
}
return of(result as T); return of(result as T);
}; };
} }
public getResourceTypes(callback: (isTypes: ISType[]) => void): void { public getResourceTypes(callback: (isTypes: ISType[]) => void): void {
const url = this.typesURL + '/Resource?polymorphic=true&gcube-token=' + this.token;
const url = 'http://pc-frosini.isti.cnr.it:8080/resource-registry/types/Resource?polymorphic=true&gcube-token=' + this.token;
// const observable: Observable<ISType[]> = of(types); // const observable: Observable<ISType[]> = of(types);
const observable: Observable<ISType[]> = this.httpClient.get<ISType[]>(url); const observable: Observable<ISType[]> = this.httpClient.get<ISType[]>(url);
/*
observable.pipe( observable.pipe(
tap(_ => console.info('Fetched Resource Types')),
catchError(this.handleError<ISType[]>('getResourceTypes()', types)) catchError(this.handleError<ISType[]>('getResourceTypes()', types))
); ).subscribe(data => callback(data));
*/ }
observable.subscribe(data => callback(data));
public getIdentifyingFacets(resourceType: string, callback: (instances: any[]) => void): void {
const url = this.queryURL + resourceType + '?polymorphic=true&gcube-token=' + this.token;
// const observable: Observable<ISType[]> = of(types);
const observable: Observable<any[]> = this.httpClient.get<any[]>(url);
observable.pipe(
catchError(this.handleError<any[]>('getResourceInstances()', list))
).subscribe(data => callback(data));
} }
} }

View File

@ -0,0 +1,38 @@
export const list: any[] = [
{
"@class": "SoftwareFacet",
"group": "vre-management",
"name": "whn-manager",
"version": "1.3.0"
},
{
"@class": "SoftwareFacet",
"group": "vre-management",
"name": "smart-executor",
"version": "2.0.0"
},
{
"@class": "SoftwareFacet",
"group": "information-system",
"name": "resource-registry",
"version": "2.1.0"
},
{
"@class": "SoftwareFacet",
"group": "data-publishing",
"name": "gcat",
"version": "2.3.0"
},
{
"@class": "SoftwareFacet",
"group": "vre-management",
"name": "whn-manager",
"version": "1.3.0"
},
{
"@class": "SoftwareFacet",
"group": "vre-management",
"name": "whn-manager",
"version": "1.3.0"
}
];

View File

@ -1,26 +1,19 @@
<table class="table table-striped table-bordered"> <div style="margin-left:5px;">
<table class="table table-striped table-bordered" *ngFor="let resourceIdentification of resourceIdentificationList">
<thead> <thead>
<tr> <tr>
<th scope="col">Group</th> <th [attr.colspan]="resourceIdentification.mandatoryProperties.size">{{resourceIdentification.type}}</th>
<th scope="col">Name</th> </tr>
<th scope="col">Version</th> <tr>
<th scope="col" *ngFor="let property of resourceIdentification.mandatoryProperties">
{{ property.charAt(0).toLocaleUpperCase() + property.substr(1) }}
</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<tr> <tr *ngFor="let facet of resourceIdentification.instances">
<td>vre-management</td> <td *ngFor="let property of resourceIdentification.mandatoryProperties">{{ facet[property] }}</td>
<td>smart-executor</td>
<td>2.0.0</td>
</tr>
<tr>
<td>information-system</td>
<td>resource-registry</td>
<td>2.1.0</td>
</tr>
<tr>
<td>data-publishing</td>
<td>gcat</td>
<td>2.3.0</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
</div>

View File

@ -1,4 +1,6 @@
import { Component, OnInit } from '@angular/core'; import { Component, OnInit } from '@angular/core';
import { IsService } from '../is.service';
import { ResourceIdentification, TYPE_PROPERTY_KEY } from './resourceidentification';
@Component({ @Component({
selector: 'app-resource-list', selector: 'app-resource-list',
@ -7,9 +9,36 @@ import { Component, OnInit } from '@angular/core';
}) })
export class ResourceListComponent implements OnInit { export class ResourceListComponent implements OnInit {
constructor() { } public resourceIdentificationList: Array<ResourceIdentification>;
constructor(private isService: IsService) { }
ngOnInit() { ngOnInit() {
// this.isService.getIdentifyingFacets('Service', facets => {this.identifyingFacets = facets;});
this.isService.getIdentifyingFacets('Service', facets => { this.resourceIdentificationList = this.analyseIdentifyingFacets(facets); });
}
analyseIdentifyingFacets(identifyingFacets: any[]): Array<ResourceIdentification> {
const map = new Map<string, ResourceIdentification>();
const facets = new Array<ResourceIdentification>();
for (const facet of identifyingFacets) {
const facetType: string = facet[TYPE_PROPERTY_KEY];
let facetList: ResourceIdentification;
if (map.has(facetType)) {
facetList = map.get(facetType);
} else {
facetList = new ResourceIdentification(facetType);
map.set(facetType, facetList);
facets.push(facetList);
}
facetList.add(facet);
}
return facets;
} }
} }

View File

@ -0,0 +1,30 @@
export const TYPE_PROPERTY_KEY = '@class';
export class ResourceIdentification {
public type: string;
public mandatoryProperties: Set<string>;
public instances: any[];
private first = true;
constructor(type: string) {
this.type = type;
this.mandatoryProperties = new Set<string>();
this.instances = new Array<any>();
}
public add(facet: any) {
if (this.first) {
for (const propertyKey in facet) {
if (propertyKey.localeCompare(TYPE_PROPERTY_KEY) === 0) {
continue;
}
this.mandatoryProperties.add(propertyKey);
}
this.first = false;
}
this.instances.push(facet);
}
}

View File

@ -17,10 +17,10 @@ export class ResourceTypesTreeComponent implements OnInit {
} }
ngOnInit() { ngOnInit() {
this.isService.getResourceTypes(isTypes => {this.resources = this.analyseTypes(isTypes)}); this.isService.getResourceTypes(isTypes => { this.resources = this.analyseTypes(isTypes); });
} }
private analyseUnassociated = function(type: Type, map: Map<string, Type>, unassociated: Map<string, ISType>) { analyseUnassociated(type: Type, map: Map<string, Type>, unassociated: Map<string, ISType>) {
const associated: string[] = new Array(); const associated: string[] = new Array();
for (const name of unassociated.keys()) { for (const name of unassociated.keys()) {
@ -36,9 +36,9 @@ export class ResourceTypesTreeComponent implements OnInit {
unassociated.delete(a); unassociated.delete(a);
} }
}; }
private analyseType = function(isType: ISType, map: Map<string, Type>, unassociated: Map<string, ISType>) { analyseType(isType: ISType, map: Map<string, Type>, unassociated: Map<string, ISType>) {
const type: Type = new Type(isType); const type: Type = new Type(isType);
@ -53,9 +53,9 @@ export class ResourceTypesTreeComponent implements OnInit {
unassociated.set(type.name, isType); unassociated.set(type.name, isType);
} }
} }
}; }
private analyseTypes = function(isTypes: ISType[]): Type[] { analyseTypes(isTypes: ISType[]): Type[] {
const map = new Map<string, Type>(); const map = new Map<string, Type>();
const unassociated = new Map<string, ISType>(); const unassociated = new Map<string, ISType>();
@ -65,8 +65,7 @@ export class ResourceTypesTreeComponent implements OnInit {
} }
return map.get('Resource').children; return map.get('Resource').children;
}; }
loadResources(typeName: string) { loadResources(typeName: string) {
window.alert('Loading ' + typeName + ' resources'); window.alert('Loading ' + typeName + ' resources');