edit dataset form

This commit is contained in:
annampak 2017-10-30 16:56:50 +02:00
parent ec2219680a
commit d3754d31c3
10 changed files with 251 additions and 196 deletions

View File

@ -1,5 +1,5 @@
import { Component, OnInit, Input, ViewChild, NgZone ,Output ,EventEmitter} from '@angular/core'; import { Component, OnInit, Input, ViewChild, NgZone, Output, EventEmitter } from '@angular/core';
import {GoogleSignInSuccess} from 'angular-google-signin'; import { GoogleSignInSuccess } from 'angular-google-signin';
import { Router, ActivatedRoute } from '@angular/router'; import { Router, ActivatedRoute } from '@angular/router';
import { ServerService } from '../../app/services/server.service'; import { ServerService } from '../../app/services/server.service';
import { Project } from '../entities/model/project'; import { Project } from '../entities/model/project';
@ -9,49 +9,49 @@ import { DataTable, DataTableTranslations, DataTableResource } from 'angular-4-d
import { DropdownField } from '../../app/form/fields/dropdown/field-dropdown'; import { DropdownField } from '../../app/form/fields/dropdown/field-dropdown';
import { Param } from '../entities/model/param'; import { Param } from '../entities/model/param';
declare var $ :any; declare var $: any;
@Component({ @Component({
selector: 'datasets-table', selector: 'datasets-table',
templateUrl: 'dataset.html', templateUrl: 'dataset.html',
// template: ` // template: `
// <h1 class="title">Projects</h1> // <h1 class="title">Projects</h1>
// <ul class="list-group col-md-4"> // <ul class="list-group col-md-4">
// <li *ngFor="let project of projects" // <li *ngFor="let project of projects"
// class="list-group-item"> // class="list-group-item">
// <a [routerLink]="['/dynamic-form', project.id]" > // <a [routerLink]="['/dynamic-form', project.id]" >
// {{ project.name }} // {{ project.name }}
// </a> // </a>
// </li> // </li>
// </ul> // </ul>
// <router-outlet></router-outlet> // <router-outlet></router-outlet>
// `, // `,
providers: [ServerService] providers: [ServerService]
}) })
export class DatasetsComponent implements OnInit{ export class DatasetsComponent implements OnInit {
returnUrl: string; returnUrl: string;
@Input() datasets: Dataset[]; @Input() datasets: Dataset[];
@Input() datasetProfileDropDown: DropdownField; @Input() datasetProfileDropDown: DropdownField;
datasetResource :DataTableResource<Dataset>; datasetResource: DataTableResource<Dataset>;
@Input() datasetCount = 0; @Input() datasetCount = 0;
@Input() dmpIdforDatasets: string; @Input() dmpIdforDatasets: string;
dataset:any; dataset: any;
//@ViewChild(DataTable) projectsTable; //@ViewChild(DataTable) projectsTable;
dataSetValue:boolean dataSetValue: boolean
@Input() @Input()
get dataSetVisibe(){ get dataSetVisibe() {
return this.dataSetValue; return this.dataSetValue;
} }
@Output() @Output()
public dataSetValueChange = new EventEmitter(); public dataSetValueChange = new EventEmitter();
set dataSetVisibe(value:any){ set dataSetVisibe(value: any) {
this.dataSetValue = value this.dataSetValue = value
this.dataSetValueChange.emit(this.dataSetValue) this.dataSetValueChange.emit(this.dataSetValue)
} }
@ -60,15 +60,15 @@ export class DatasetsComponent implements OnInit{
private serverService: ServerService, private serverService: ServerService,
private route: ActivatedRoute, private route: ActivatedRoute,
private router: Router, private router: Router,
private ngZone: NgZone){ private ngZone: NgZone) {
this.dataset = { this.dataset = {
id:null, id: null,
label:'', label: '',
reference:'', reference: '',
uri:'', uri: '',
properties:'', properties: '',
profile:{"id": ''}, profile: { "id": '' },
dmp:{"id": ''} dmp: { "id": '' }
} }
this.datasetProfileDropDown = new DropdownField(); this.datasetProfileDropDown = new DropdownField();
@ -76,11 +76,11 @@ export class DatasetsComponent implements OnInit{
} }
ngOnInit() {debugger; ngOnInit() {
//this.projects = this.serverService.getDummyProjects(); //this.projects = this.serverService.getDummyProjects();
this.datasets = []; this.datasets = [];
console.log(this.dmpIdforDatasets); console.log(this.dmpIdforDatasets);
this.serverService.getDatasetForDmp({"id":this.dmpIdforDatasets}).subscribe( this.serverService.getDatasetForDmp({ "id": this.dmpIdforDatasets }).subscribe(
response => { response => {
console.log("response"); console.log("response");
@ -91,8 +91,11 @@ export class DatasetsComponent implements OnInit{
dt.id = resp.id; dt.id = resp.id;
dt.name = resp.label; dt.name = resp.label;
dt.uriDataset = resp.uri; dt.uriDataset = resp.uri;
dt.dmp = resp.dmp.label;
dt.profile = resp.profile.label;
dt.profileId = resp.profile.id;
this.datasets.push(dt); this.datasets.push(dt);
var params = {limit:8,offset:0, sortAsc:false} var params = { limit: 8, offset: 0, sortAsc: false }
this.afterLoad(); this.afterLoad();
this.datasetResource.query(params).then(datasets => this.datasets = datasets); this.datasetResource.query(params).then(datasets => this.datasets = datasets);
}); });
@ -118,28 +121,28 @@ export class DatasetsComponent implements OnInit{
reloadDatasets(params) { reloadDatasets(params) {
this.datasetResource = new DataTableResource(this.datasets); this.datasetResource = new DataTableResource(this.datasets);
this.datasetResource.query(params).then(datasets => this.datasets = datasets); this.datasetResource.query(params).then(datasets => this.datasets = datasets);
} }
afterLoad(){ afterLoad() {
this.datasetResource = new DataTableResource(this.datasets); this.datasetResource = new DataTableResource(this.datasets);
this.datasetResource.count().then(count => this.datasetCount = count); this.datasetResource.count().then(count => this.datasetCount = count);
} }
rowClick(rowEvent){ selectDataset(item) {debugger;
this.ngZone.run(() => this.router.navigateByUrl('dynamic-form', rowEvent.row.item.id)); this.ngZone.run(() => this.router.navigate(['dynamic-form', {id: item.profileId}]));
} }
SaveNewDataset(){debugger; SaveNewDataset() {
this.dataset.dmp={"id": this.dmpIdforDatasets} this.dataset.dmp = { "id": this.dmpIdforDatasets }
this.dataset.profile = {"id": this.dataset.profile} this.dataset.profile = { "id": this.dataset.profile }
this.serverService.createDatasetForDmp(this.dataset).subscribe( this.serverService.createDatasetForDmp(this.dataset).subscribe(
response=>{ response => {
console.log(response); console.log(response);
} }
) )
$("#newDatasetModal").modal("hide"); $("#newDatasetModal").modal("hide");
this.serverService.getDatasetForDmp({"id":this.dmpIdforDatasets}).subscribe( this.serverService.getDatasetForDmp({ "id": this.dmpIdforDatasets }).subscribe(
response => { response => {
console.log("response"); console.log("response");
@ -152,13 +155,13 @@ SaveNewDataset(){debugger;
dt.name = resp.label; dt.name = resp.label;
dt.uriDataset = resp.uri; dt.uriDataset = resp.uri;
this.datasets.push(dt); this.datasets.push(dt);
var params = {limit:8,offset:0, sortAsc:false} var params = { limit: 8, offset: 0, sortAsc: false }
this.afterLoad(); this.afterLoad();
this.datasetResource.query(params).then(datasets => this.datasets = datasets); this.datasetResource.query(params).then(datasets => this.datasets = datasets);
}); });
} }
); );
} }
// special params: // special params:
translations = <DataTableTranslations>{ translations = <DataTableTranslations>{
@ -167,10 +170,10 @@ SaveNewDataset(){debugger;
selectColumn: 'Select column', selectColumn: 'Select column',
paginationLimit: 'Max results', paginationLimit: 'Max results',
paginationRange: 'Result range' paginationRange: 'Result range'
}; };
getDatasetForDmpMethod(dmpid){ getDatasetForDmpMethod(dmpid) {
this.serverService.getDatasetForDmp({"id":dmpid}).subscribe( this.serverService.getDatasetForDmp({ "id": dmpid }).subscribe(
response => { response => {
console.log("response"); console.log("response");
@ -183,12 +186,28 @@ getDatasetForDmpMethod(dmpid){
dt.name = resp.label; dt.name = resp.label;
dt.uriDataset = resp.uri; dt.uriDataset = resp.uri;
this.datasets.push(dt); this.datasets.push(dt);
var params = {limit:8,offset:0, sortAsc:false} var params = { limit: 8, offset: 0, sortAsc: false }
this.afterLoad(); this.afterLoad();
this.datasetResource.query(params).then(datasets => this.datasets = datasets); this.datasetResource.query(params).then(datasets => this.datasets = datasets);
}); });
} }
); );
} }
editRow(item) {
this.dataset.label = item.label;
this.dataset.uri = item.uriDataset;
this.dataset.dmp = item.dmp;
this.dataset.profile = item.profileId;
$("#newDatasetModal").modal("show");
}
newDataset() {
this.dataset.label = "";
this.dataset.uri = "";
this.dataset.dmp =this.dmpIdforDatasets;
this.dataset.profile = "";
$("#newDatasetModal").modal("show");
}
} }

View File

@ -1,21 +1,37 @@
<div style="margin: auto; max-width: 1000px; margin-top:50px"> <div style="margin: auto; max-width: 1000px; margin-top:50px">
<data-table id="films-grid" headerTitle="Datasets" [items]="datasets" [itemCount]="datasetCount" (reload)="reloadDatasets($event)" <data-table id="films-grid" headerTitle="Datasets" [items]="datasets" [itemCount]="datasetCount" (reload)="reloadDatasets($event)"
[limit]="8" [sortBy]="'rating'" [sortAsc]="false" [substituteRows]="false" [limit]="8" [sortBy]="'rating'" [sortAsc]="false" [substituteRows]="false"
[translations]="translations" [selectOnRowClick]="true" (rowClick)="rowClick($event)"> [translations]="translations" >
<data-table-column [property]="'name'" [header]="'Label'" [sortable]="true"> <data-table-column [property]="'name'" [header]="'Label'" [sortable]="true">
</data-table-column> </data-table-column>
<!-- <data-table-column [property]="'abbreviation'" [header]="'Abbreviation'" [sortable]="true"> <data-table-column [property]="'dmp'" [header]="'DMP'" [sortable]="true">
</data-table-column> --> </data-table-column>
<data-table-column [property]="'id'" [header]="'Id'" [sortable]="true"> <data-table-column [property]="'profile'" [header]="'Profile'" [sortable]="true">
</data-table-column> </data-table-column>
<data-table-column [property]="'uriDataset'" [header]="'Uri'" [sortable]="true"> <data-table-column [property]="'uriDataset'" [header]="'Uri'" [sortable]="true">
</data-table-column> </data-table-column>
<!-- <data-table-column [property]="'definition'" [header]="'Definition'" [sortable]="true"> <!-- <data-table-column [property]="'definition'" [header]="'Definition'" [sortable]="true">
</data-table-column> --> </data-table-column> -->
<data-table-column header="Actions">
<template #dataTableHeader let-item="item">
<i>Actions</i>
</template>
<template #dataTableCell let-item="item">
<a class="editGridColumn" (click) = "editRow(item)"><i class="fa fa-pencil fa-fw"></i></a> <!--data-toggle="modal" data-target="#exampleModalDmps" -->
</template>
</data-table-column>
<data-table-column header="Edit">
<template #dataTableHeader let-item="item">
<i>Edit</i>
</template>
<template #dataTableCell let-item="item">
<a class="editGridColumn" (click) = "selectDataset(item)"><i class="fa fa-pencil fa-fw"></i></a> <!--data-toggle="modal" data-target="#exampleModalDmps" -->
</template>
</data-table-column>
</data-table> </data-table>
<div style="margin-top: 10px"> <div style="margin-top: 10px">
<button type="button" class="btn btn-info" data-toggle="modal" data-target="#newDatasetModal">New Dataset</button> <button type="button" class="btn btn-info" (click) = "newDataset(item)" >New Dataset</button> <!-- data-toggle="modal" data-target="#newDatasetModal" -->
<!-- <b>Selected:</b> <!-- <b>Selected:</b>
<span *ngIf="projectsTable.selectedRow == null"><i>No item selected</i></span> <span *ngIf="projectsTable.selectedRow == null"><i>No item selected</i></span>
<span [textContent]="projectsTable.selectedRow && projectsTable.selectedRow.item.name"></span> --> <span [textContent]="projectsTable.selectedRow && projectsTable.selectedRow.item.name"></span> -->
@ -44,23 +60,19 @@
<label for="label-name" class="form-control-label">Label:</label> <label for="label-name" class="form-control-label">Label:</label>
<input type="text" class="form-control" id="label-name" [(ngModel)]= "dataset.label" name = "label"> <input type="text" class="form-control" id="label-name" [(ngModel)]= "dataset.label" name = "label">
</div> </div>
<!-- <div class="form-group">
<label for="abbreviation-text" class="form-control-label">Abbreviation:</label>
<input class="form-control" id="abbreviation-text" [(ngModel)]= "dataset.abbreviation" name = "abbreviation">
</div> -->
<div class="form-group"> <div class="form-group">
<label for="reference-text" class="form-control-label">Reference:</label> <label for="abbreviation-text" class="form-control-label">DMP:</label>
<input class="form-control" id="reference-text" [(ngModel)]= "dataset.reference" name = "reference"> <input class="form-control" id="abbreviation-text" [(ngModel)]= "dataset.dmp" name = "dmp">
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="uri-text" class="form-control-label">Uri:</label> <label for="uri-text" class="form-control-label">Uri:</label>
<input class="form-control" id="uri-text" [(ngModel)]= "dataset.uri" name = "uri"> <input class="form-control" id="uri-text" [(ngModel)]= "dataset.uri" name = "uri">
</div> </div>
<!-- <div class="form-group">
<label for="start-date" class="form-control-label">Start Date:</label>
<input class="form-control" id="startDate-date" [(ngModel)]= "dataset.startDate" name = "startDate">
</div>
<div class="form-group"> <div class="form-group">
<label for="start-date" class="form-control-label">Properties:</label>
<input class="form-control" id="startDate-date" [(ngModel)]= "dataset.properties" name = "properties">
</div>
<!-- <div class="form-group">
<label for="end-date" class="form-control-label">End Date:</label> <label for="end-date" class="form-control-label">End Date:</label>
<input class="form-control" id="endDate-date" [(ngModel)]= "dataset.endDate" name = "endDate"> <input class="form-control" id="endDate-date" [(ngModel)]= "dataset.endDate" name = "endDate">
</div> --> </div> -->

View File

@ -48,10 +48,10 @@ export class DmpComponent implements OnInit{
this.dataSetVisibe = false; this.dataSetVisibe = false;
this.dmp = { this.dmp = {
label: '', label: '',
abbreviation:'', previous:'',
reference:'', version:'',
uri:'', profileData:'',
definition:'' profile:''
} }
} }
@ -71,27 +71,30 @@ console.log(response);
dmp.version = resp.version; dmp.version = resp.version;
dmp.dataset = resp.dataset; dmp.dataset = resp.dataset;
dmp.projectLabel = resp.project.label; dmp.projectLabel = resp.project.label;
dmp.projectid = resp.project.id;
dmp.previous = resp.previous;
dmp.profile = resp.profile;
dmp.profileData = resp.profileData;
this.dmps.push(dmp); this.dmps.push(dmp);
var params = {limit:8,offset:0, sortAsc:false} var params = {limit:8,offset:0, sortAsc:false}
this.afterLoad(); this.afterLoad();
this.dmpResource.query(params).then(dmps => this.dmps = dmps); this.dmpResource.query(params).then(dmps => this.dmps = dmps);
} }
); );
(err: HttpErrorResponse) => {
if (err.error instanceof Error) {
// A client-side or network error occurred. Handle it accordingly.
console.log('An error occurred:', err.error.message);
} else {
// The backend returned an unsuccessful response code.
// The response body may contain clues as to what went wrong,
if(err.status == 401){
this.isignOutBtn.nativeElement.click();
} }
// (err: HttpErrorResponse) => { console.log(`Backend returned code ${err.status}, body was: ${err.error}`);
// if (err.error instanceof Error) { }
// // A client-side or network error occurred. Handle it accordingly. }
// console.log('An error occurred:', err.error.message); });
// } else {
// // The backend returned an unsuccessful response code.
// // The response body may contain clues as to what went wrong,
// if(err.status == 401){
// this.isignOutBtn.nativeElement.click();
// }
// console.log(`Backend returned code ${err.status}, body was: ${err.error}`);
// }
// }
);
this.serverService.getAllProjects().subscribe( this.serverService.getAllProjects().subscribe(
response => { response => {
@ -186,7 +189,7 @@ signOut() {
    this.serverService.logOut();     this.serverService.logOut();
} }
selectDmp(rowEvent){debugger; selectDmp(rowEvent){
this.dmpIdforDatasets = rowEvent.row.item.id; this.dmpIdforDatasets = rowEvent.row.item.id;
if(this.dataSetVisibe == false) if(this.dataSetVisibe == false)
this.dataSetVisibe = true; this.dataSetVisibe = true;
@ -194,12 +197,25 @@ selectDmp(rowEvent){debugger;
this.datasetsComponent.getDatasetForDmpMethod(rowEvent.row.item.id); this.datasetsComponent.getDatasetForDmpMethod(rowEvent.row.item.id);
} }
editRow(item){debugger; editRow(item){
this.dmp.label = item.label; this.dmp.label = item.label;
this.dmp.abbreviation = item.abbreviation; this.dmp.previous = item.previous;
this.dmp.uri = item.uri; this.dmp.version = item.version;
this.dmp.profile = item.profile;
this.dmp.profileData = item.profileData;
this.dmp.id = item.id; this.dmp.id = item.id;
this.dmp.project = item.project; this.dmp.project = item.projectid;
this.dmp.projectid = item.projectid;
$("#newDmpModal").modal("show");
}
newDmp(item){
this.dmp.label = "";
this.dmp.previous = "";
this.dmp.version = "";
this.dmp.profile = "";
this.dmp.profileData = "";
this.dmp.project = "";
$("#newDmpModal").modal("show"); $("#newDmpModal").modal("show");
} }

View File

@ -46,7 +46,7 @@
<!-- <span *ngIf="dmpsTable.selectedRow == null"><i>No item selected</i></span> <!-- <span *ngIf="dmpsTable.selectedRow == null"><i>No item selected</i></span>
<span [textContent]="dmpsTable.selectedRow && dmpsTable.selectedRow.item.name"></span> --> <span [textContent]="dmpsTable.selectedRow && dmpsTable.selectedRow.item.name"></span> -->
</div> </div>
<button type="button" class="btn btn-info" data-toggle="modal" data-target="#newDmpModal">New Dmp</button> <button type="button" class="btn btn-info" (click) = "newDmp(item)">New Dmp</button> <!-- data-toggle="modal" data-target="#newDmpModal" -->
<!-- <select class="form-control" [id]="datasetDropDownKey" [(ngModel)]="datasetDropDownKey"> <!-- <select class="form-control" [id]="datasetDropDownKey" [(ngModel)]="datasetDropDownKey">
<option *ngFor="let opt of datasetDropDown.options" [value]="opt.key">{{opt.value}}</option> <option *ngFor="let opt of datasetDropDown.options" [value]="opt.key">{{opt.value}}</option>
@ -74,23 +74,23 @@
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="label-name" class="form-control-label">Previous:</label> <label for="label-name" class="form-control-label">Previous:</label>
<input type="text" class="form-control" id="label-previous" [(ngModel)]= "dmp.previous" name = "label"> <input type="text" class="form-control" id="label-previous" [(ngModel)]= "dmp.previous" name = "previous">
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="label-name" class="form-control-label">Label:</label> <label for="label-name" class="form-control-label">Label:</label>
<input type="text" class="form-control" id="label-name" [(ngModel)]= "dmp.label" name = "label"> <input type="text" class="form-control" id="label-name" [(ngModel)]= "dmp.label" name = "label">
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="abbreviation-text" class="form-control-label">Abbreviation:</label> <label for="abbreviation-text" class="form-control-label">Version:</label>
<input class="form-control" id="abbreviation-text" [(ngModel)]= "dmp.version" name = "abbreviation"> <input class="form-control" id="abbreviation-text" [(ngModel)]= "dmp.version" name = "version">
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="reference-text" class="form-control-label">Reference:</label> <label for="reference-text" class="form-control-label">Profile Data:</label>
<input class="form-control" id="reference-text" [(ngModel)]= "dmp.profileData" name = "reference"> <textarea class="form-control" id="reference-text" [(ngModel)]= "dmp.profileData" name = "profileData"></textarea>
</div> </div>
<div class="form-group"> <div class="form-group">
<label for="uri-text" class="form-control-label">Uri:</label> <label for="uri-text" class="form-control-label">Profile:</label>
<input class="form-control" id="uri-text" [(ngModel)]= "dmp.profile" name = "uri"> <input class="form-control" id="uri-text" [(ngModel)]= "dmp.profile" name = "profile">
</div> </div>
<!-- <div class="form-group"> <!-- <div class="form-group">
<label for="start-date" class="form-control-label">Start Date:</label> <label for="start-date" class="form-control-label">Start Date:</label>

View File

@ -4,4 +4,7 @@ export class Dataset {
id:string; id:string;
name: string; name: string;
uriDataset: string; uriDataset: string;
dmp:string;
profile:string;
profileId:string;
} }

View File

@ -9,5 +9,6 @@ export class Dmp {
profile:string; profile:string;
profileData:string; profileData:string;
projectLabel:string; projectLabel:string;
projectid:string;
version: number; version: number;
} }

View File

@ -1,7 +1,7 @@
import { Component, Input, OnInit, AfterViewChecked, ViewChild } from '@angular/core'; import { Component, Input, OnInit, AfterViewChecked, ViewChild } from '@angular/core';
import { FormGroup, Validators } from '@angular/forms'; import { FormGroup, Validators } from '@angular/forms';
import { NgForm } from '@angular/forms'; import { NgForm } from '@angular/forms';
import { Router, ActivatedRoute, ParamMap } from '@angular/router'; import { Router, ActivatedRoute, ParamMap, Params } from '@angular/router';
import 'rxjs/add/operator/switchMap'; import 'rxjs/add/operator/switchMap';
//import { FieldBase } from '../../app/form/fields/field-base'; //import { FieldBase } from '../../app/form/fields/field-base';
@ -29,6 +29,7 @@ export class DynamicFormComponent implements OnInit {
@Input() dirtyValues: number = 0; @Input() dirtyValues: number = 0;
// pagination object // pagination object
@Input() pagination: any = {}; @Input() pagination: any = {};
id:string;
private fragment: string; private fragment: string;
xml2jsonOBJ: any; xml2jsonOBJ: any;
@ -48,11 +49,14 @@ export class DynamicFormComponent implements OnInit {
this.route.fragment.subscribe(fragment => { this.fragment = fragment; }); //navigate to certain section of the page this.route.fragment.subscribe(fragment => { this.fragment = fragment; }); //navigate to certain section of the page
console.log("DynamicFormComponent.ngOnInit() -- RUNNIGN");
let id = this.route.snapshot.paramMap.get('id'); //get the project id
//let id = this.route.snapshot.paramMap.get('id'); //get the project id
this.serverService.getData().subscribe( let sub = this.route.params.subscribe(params => {
this.id = params.id;
});
this.serverService.getDatsetsProfile(this.id).subscribe(
response => { response => {
@ -61,24 +65,18 @@ export class DynamicFormComponent implements OnInit {
const data = response; const data = response;
console.log("data.dataset--BEFORE")
console.log(response.dataset.profile.definition)
console.log(response.dataset.profile.ruleset.definition)
console.log(response.dataset.profile.viewstyle.definition)
//replace the xmls {model,view,rule} definitions with json -- https://github.com/abdmob/x2js library //replace the xmls {model,view,rule} definitions with json -- https://github.com/abdmob/x2js library
data.dataset.profile.definition = this.xml2jsonOBJ.xml_str2json(data.dataset.profile.definition); data.definition = this.xml2jsonOBJ.xml_str2json(data.definition);
data.dataset.profile.ruleset.definition = this.xml2jsonOBJ.xml_str2json(data.dataset.profile.ruleset.definition); data.ruleset.definition = this.xml2jsonOBJ.xml_str2json(data.ruleset.definition);
data.dataset.profile.viewstyle.definition = this.xml2jsonOBJ.xml_str2json(data.dataset.profile.viewstyle.definition); data.viewstyle.definition = this.xml2jsonOBJ.xml_str2json(data.viewstyle.definition);
//can be converted back to xml (which shouldn't be needed) with this.xml2jsonOBJ.json2xml_str //can be converted back to xml (which shouldn't be needed) with this.xml2jsonOBJ.json2xml_str
console.log("this.serverService.getFields"); console.log("this.serverService.getFields");
console.log("data.dataset") console.log("data.dataset")
console.log(data.dataset.profile.definition) console.log(data.definition)
console.log(data.dataset.profile.ruleset.definition) console.log(data.ruleset.definition)
console.log(data.dataset.profile.viewstyle.definition) console.log(data.viewstyle.definition)
this.dataModel = new DataModel(); this.dataModel = new DataModel();

View File

@ -26,12 +26,12 @@ export class dataModelBuilder {
return this.dataModel; return this.dataModel;
this.dataModel = new DataModel(); this.dataModel = new DataModel();
this.fields = this.buildFields(data.dataset.profile.viewstyle.definition.root.fields.field); this.fields = this.buildFields(data.viewstyle.definition.root.fields.field);
this.dataModel.groups = this.getGroups(data.dataset.profile.viewstyle.definition.root.fieldGroups.fieldGroup, this.fields); this.dataModel.groups = this.getGroups(data.viewstyle.definition.root.fieldGroups.fieldGroup, this.fields);
this.dataModel.semanticAttr = new Array(new Attribute); this.dataModel.semanticAttr = new Array(new Attribute);
//this.dataModel.semanticAttr = data.dataset.profile.definition.root.fields.field; //this.dataModel.semanticAttr = data.dataset.profile.definition.root.fields.field;
this.dataModel.semanticAttr = this.getFieldsAttributes(data.dataset.profile.definition.root.fields.field, data.dataset.profile.ruleset.definition.root.functions.function, this.fields); this.dataModel.semanticAttr = this.getFieldsAttributes(data.definition.root.fields.field, data.ruleset.definition.root.functions.function, this.fields);
this.dataModel.sections = this.getSections(data.dataset.profile.viewstyle.definition.root.sections.section, this.dataModel.groups); this.dataModel.sections = this.getSections(data.viewstyle.definition.root.sections.section, this.dataModel.groups);
this.dataModel.buildIndex(); this.dataModel.buildIndex();
return this.dataModel; return this.dataModel;
@ -224,14 +224,13 @@ export class dataModelBuilder {
if (attr.sources) { if (attr.sources) {
newAttribute.sources.push(attr.sources.source); newAttribute.sources.push(attr.sources.source);
for (var i = 0; i < attr.sources.source.length; i++) {
if (attr.sources.source.url !== undefined) { if (attr.sources.source[i].url !== undefined) {
fields.find(x => x.key == newAttribute.id).url.url = attr.sources.source[i].url._value;
fields.find(x => x.key == newAttribute.id).url.url = attr.sources.source.url._value; this.restBase.proxy_get(attr.sources.source[i].url._value).subscribe((data) => {
this.restBase.proxy_get(attr.sources.source.url._value).subscribe((data) => {
console.log(data); console.log(data);
newAttribute.sources.forEach(src => { newAttribute.sources.forEach(src => {
src.params = new Array(); src.params = new Array();
@ -244,20 +243,23 @@ export class dataModelBuilder {
}); });
}); });
break;
} else { } else {
newAttribute.sources.forEach(src => { newAttribute.sources.forEach(src => {
src.params = new Array(); src.params = new Array();
for (var i = 0, len = attr.sources.source.value.length; i < len; i++) { for (var i = 0, len = attr.sources.source[i].value.length; i < len; i++) {
let prm = new Param(); let prm = new Param();
prm.key = attr.sources.source.value[i]._value; prm.key = attr.sources.source[i].value[i]._value;
prm.value = attr.sources.source.value[i]._label; prm.value = attr.sources.source[i].value[i]._label;
src.params.push(prm); src.params.push(prm);
} }
}); });
} }
}
} }

View File

@ -22,7 +22,7 @@ export class RestBase {
webappname: string = "dmp-backend";//"dmp-backend-new";// webappname: string = "dmp-backend";//"dmp-backend-new";//
/* protocol: string = "http"; /*protocol: string = "http";
hostname: string = "dionysus.di.uoa.gr" ; hostname: string = "dionysus.di.uoa.gr" ;
port: number = 7070; port: number = 7070;
webappname: string = "dmp-backend";*/ webappname: string = "dmp-backend";*/

View File

@ -121,6 +121,10 @@ public getAllDatsetsProfile(){
return this.restBase.get("datasetprofile/getAll"); return this.restBase.get("datasetprofile/getAll");
} }
public getDatsetsProfile(id){debugger;
return this.restBase.get("datasetprofiles/"+id);
}
logOut() { logOut() {