edit dataset form
This commit is contained in:
parent
ec2219680a
commit
d3754d31c3
|
@ -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,27 +60,27 @@ 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();
|
||||||
this.datasetProfileDropDown.options = [];
|
this.datasetProfileDropDown.options = [];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
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,47 +121,47 @@ 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");
|
||||||
console.log(response);
|
console.log(response);
|
||||||
this.datasets = [];
|
this.datasets = [];
|
||||||
response.forEach(resp => {
|
response.forEach(resp => {
|
||||||
|
|
||||||
let dt = new Dataset();
|
let dt = new Dataset();
|
||||||
dt.id = resp.id;
|
dt.id = resp.id;
|
||||||
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,28 +170,44 @@ 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");
|
||||||
console.log(response);
|
console.log(response);
|
||||||
this.datasets = [];
|
this.datasets = [];
|
||||||
response.forEach(resp => {
|
response.forEach(resp => {
|
||||||
|
|
||||||
let dt = new Dataset();
|
let dt = new Dataset();
|
||||||
dt.id = resp.id;
|
dt.id = resp.id;
|
||||||
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");
|
||||||
}
|
}
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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">
|
<div class="form-group">
|
||||||
<label for="start-date" class="form-control-label">Start Date:</label>
|
<label for="start-date" class="form-control-label">Properties:</label>
|
||||||
<input class="form-control" id="startDate-date" [(ngModel)]= "dataset.startDate" name = "startDate">
|
<input class="form-control" id="startDate-date" [(ngModel)]= "dataset.properties" name = "properties">
|
||||||
</div>
|
</div>
|
||||||
<div class="form-group">
|
<!-- <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> -->
|
||||||
|
|
|
@ -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();
|
||||||
|
}
|
||||||
|
console.log(`Backend returned code ${err.status}, body was: ${err.error}`);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// (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();
|
|
||||||
// }
|
|
||||||
// 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");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
|
@ -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;
|
||||||
}
|
}
|
|
@ -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();
|
||||||
|
|
|
@ -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,41 +224,43 @@ 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) => {
|
||||||
|
console.log(data);
|
||||||
this.restBase.proxy_get(attr.sources.source.url._value).subscribe((data) => {
|
newAttribute.sources.forEach(src => {
|
||||||
console.log(data);
|
src.params = new Array();
|
||||||
newAttribute.sources.forEach(src => {
|
data.data.forEach(data => {
|
||||||
src.params = new Array();
|
let prm = new Param();
|
||||||
data.data.forEach(data => {
|
prm.key = data.id;
|
||||||
let prm = new Param();
|
prm.value = data.attributes.name;
|
||||||
prm.key = data.id;
|
src.params.push(prm);
|
||||||
prm.value = data.attributes.name;
|
});
|
||||||
src.params.push(prm);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
newAttribute.sources.forEach(src => {
|
||||||
|
|
||||||
});
|
src.params = new Array();
|
||||||
} else {
|
for (var i = 0, len = attr.sources.source[i].value.length; i < len; i++) {
|
||||||
newAttribute.sources.forEach(src => {
|
let prm = new Param();
|
||||||
|
prm.key = attr.sources.source[i].value[i]._value;
|
||||||
src.params = new Array();
|
prm.value = attr.sources.source[i].value[i]._label;
|
||||||
for (var i = 0, len = attr.sources.source.value.length; i < len; i++) {
|
src.params.push(prm);
|
||||||
let prm = new Param();
|
}
|
||||||
prm.key = attr.sources.source.value[i]._value;
|
|
||||||
prm.value = attr.sources.source.value[i]._label;
|
|
||||||
src.params.push(prm);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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";*/
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue