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

@ -76,7 +76,7 @@ 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);
@ -91,6 +91,9 @@ 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();
@ -125,11 +128,11 @@ afterLoad(){
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(
@ -191,4 +194,20 @@ getDatasetForDmpMethod(dmpid){
); );
} }
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

@ -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() {