Commit 7c90d07a authored by Thodoris Nestoridis's avatar Thodoris Nestoridis

prefix details

parent 5b62f738
<app-prefix-list></app-prefix-list>
<div> <div>
<div *ngIf="currentboilerplate.id" class="edit-form"> <div *ngIf="currentboilerplate.id" class="edit-form">
<h4>Boilerplate</h4> <h4>Boilerplate</h4>
...@@ -13,14 +14,13 @@ ...@@ -13,14 +14,13 @@
/> />
</div> </div>
<div style="display: flex; flex-grow: grow"> <div style="display: flex; flex-grow: grow">
<form class="example-form form-inline"> <form class="form-group form-inline ">
<mat-checkbox class="example-full-width" <mat-checkbox class="example-full-width"
[(ngModel)]="currentboilerplate.has_prefix" [(ngModel)]="currentboilerplate.has_prefix"
name="has_prefix" name="has_prefix"
>Prefix >Prefix
</mat-checkbox> </mat-checkbox>
</form> </form>
<app-prefix-details></app-prefix-details> <app-prefix-details></app-prefix-details>
</div> </div>
<div class="form-group"> <div class="form-group">
......
...@@ -11,4 +11,8 @@ ...@@ -11,4 +11,8 @@
.example-full-width { .example-full-width {
width: auto; width: auto;
}
.form-group{
min-width: 150px;
} }
\ No newline at end of file
<app-prefix-list></app-prefix-list> <div class="form-row">
<form class="form-group form-inline"> <div class="col">
<mat-form-field class="example-full-width"> <form class="form-group form-inline">
<mat-label>Prefix</mat-label> <mat-form-field class="example-full-width">
<input type="text" <mat-label>Prefix</mat-label>
placeholder="Pick one" <input type="text"
aria-label="Number" placeholder="Pick one"
matInput aria-label="Number"
[formControl]="simpleprefixControl" matInput
[matAutocomplete]="autosimpleprefix" [formControl]="simpleprefixControl"
> [matAutocomplete]="autosimpleprefix"
<mat-autocomplete autoActiveFirstOption #autosimpleprefix="matAutocomplete"> >
<mat-option *ngFor="let option of simpleprefixfilteredOptions | async" [value]="option"> <mat-autocomplete autoActiveFirstOption #autosimpleprefix="matAutocomplete">
{{option}} <mat-option *ngFor="let option of simpleprefixfilteredOptions | async" [value]="option">
</mat-option> {{option}}
</mat-autocomplete> </mat-option>
</mat-form-field> </mat-autocomplete>
</form> </mat-form-field>
<form class="example-form form-inline"> </form>
<mat-form-field> </div>
<mat-label>Subject</mat-label> <div class="col">
<input type="text" <form class="example-form form-inline">
placeholder="Pick one" <mat-form-field>
aria-label="Number" <mat-label>Subject</mat-label>
matInput <input type="text"
[formControl]="subjectsControl" placeholder="Pick one"
[matAutocomplete]="autosub" aria-label="Number"
> matInput
<mat-autocomplete autoActiveFirstOption #autosub="matAutocomplete"> [formControl]="subjectsControl"
<mat-option *ngFor="let option of subjectsfilteredOptions | async" [value]="option"> [matAutocomplete]="autosub"
{{option}} >
</mat-option> <mat-autocomplete autoActiveFirstOption #autosub="matAutocomplete">
</mat-autocomplete> <mat-option *ngFor="let option of subjectsfilteredOptions | async" [value]="option">
</mat-form-field> {{option}}
</form> </mat-option>
<button </mat-autocomplete>
type="submit" </mat-form-field>
class="badge badge-success mb-2" </form>
(click)="updatePrefix()" </div>
> <div class="col">
Update <form class="example-form form-inline">
</button> <mat-form-field>
<mat-label>Verb or State</mat-label>
<input type="text"
placeholder="Pick one"
aria-label="Number"
matInput
[formControl]="verbsControl"
[matAutocomplete]="autoverb"
>
<mat-autocomplete autoActiveFirstOption #autoverb="matAutocomplete">
<mat-option *ngFor="let option of verbsfilteredOptions | async" [value]="option">
{{option}}
</mat-option>
</mat-autocomplete>
</mat-form-field>
</form>
</div>
<div class="col">
<form class="example-form form-inline">
<mat-form-field>
<mat-label>Object</mat-label>
<input type="text"
placeholder="Pick one"
aria-label="Number"
matInput
[formControl]="objectsControl"
[matAutocomplete]="autobjects"
>
<mat-autocomplete autoActiveFirstOption #autobjects="matAutocomplete">
<mat-option *ngFor="let option of objectsfilteredOptions | async" [value]="option">
{{option}}
</mat-option>
</mat-autocomplete>
</mat-form-field>
</form>
</div>
<div class="col">
<form class="example-form form-inline" >
<fieldset disabled>
<mat-form-field>
<mat-label>Logic connectivity</mat-label>
<input type="text"
placeholder="Pick one"
aria-label="Number"
matInput
[formControl]="logic_conControl"
[matAutocomplete]="autolog_con"
>
<mat-autocomplete autoActiveFirstOption #autolog_con="matAutocomplete">
<mat-option *ngFor="let option of logic_confilteredOptions | async" [value]="option">
{{option}}
</mat-option>
</mat-autocomplete>
</mat-form-field>
</fieldset>
</form>
</div>
<div class="col">
<button
type="submit"
class="badge badge-success mb-2"
(click)="updatePrefix()"
>
Update
</button>
</div>
</div>
<!-- <!--
......
...@@ -22,13 +22,23 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -22,13 +22,23 @@ export class PrefixDetailsComponent implements OnInit {
subjectsControl = new FormControl(); subjectsControl = new FormControl();
subjects:string[] = []; subjects:string[] = [];
subjectsfilteredOptions: Observable<string[]>; subjectsfilteredOptions: Observable<string[]>;
verbs = []; verbsControl = new FormControl();
objects = []; verbs:string[] = [];
logic_con = []; verbsfilteredOptions: Observable<string[]>;
objectsControl = new FormControl();
objects:string[] = [];
objectsfilteredOptions: Observable<string[]>;
logic_conControl = new FormControl();
logic_con:string[] = [];
logic_confilteredOptions: Observable<string[]>;
public static id: any [] = []; public static id: any [] = [];
private readonly notifier: NotifierService; private readonly notifier: NotifierService;
disable = true;
//for the moment only one prefix can showed/updates //for the moment only one prefix can showed/updates
currentprefix: Prefix = { currentprefix: Prefix = {
...@@ -53,6 +63,18 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -53,6 +63,18 @@ export class PrefixDetailsComponent implements OnInit {
startWith(""), startWith(""),
map(value => this._filter(this.subjects, value)) map(value => this._filter(this.subjects, value))
); );
this.verbsfilteredOptions = this.verbsControl.valueChanges.pipe(
startWith(""),
map(value => this._filter(this.verbs, value))
);
this.objectsfilteredOptions = this.objectsControl.valueChanges.pipe(
startWith(""),
map(value => this._filter(this.objects, value))
);
this.logic_confilteredOptions = this.logic_conControl.valueChanges.pipe(
startWith(""),
map(value => this._filter(this.logic_con, value))
);
} }
ngOnInit(): void { ngOnInit(): void {
...@@ -65,9 +87,6 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -65,9 +87,6 @@ export class PrefixDetailsComponent implements OnInit {
private _filter(data:string[], value: string): string[] { private _filter(data:string[], value: string): string[] {
const filterValue = value.toLowerCase(); const filterValue = value.toLowerCase();
this.currentprefix.prefix = this.simpleprefixControl.value;
this.currentprefix.system_fun_item = this.subjectsControl.value;
return data.filter(option => option.toLowerCase().indexOf(filterValue) === 0); return data.filter(option => option.toLowerCase().indexOf(filterValue) === 0);
} }
...@@ -80,8 +99,12 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -80,8 +99,12 @@ export class PrefixDetailsComponent implements OnInit {
this.currentprefix = data; this.currentprefix = data;
console.log(data) console.log(data)
this.simpleprefixControl.setValue(this.currentprefix.prefix); this.simpleprefixControl.setValue(this.currentprefix.prefix);
//make it null need solution this.subjectsControl.setValue(this.currentprefix.system_fun_item);
//this.subjectsControl.setValue(this.currentprefix.system_fun_item); this.verbsControl.setValue(this.currentprefix.state_or_verb);
this.objectsControl.setValue(this.currentprefix.item_function_flow_statevalue);
this.logic_conControl.setValue(this.currentprefix.logic_connective);
}, },
error => { error => {
...@@ -91,11 +114,16 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -91,11 +114,16 @@ export class PrefixDetailsComponent implements OnInit {
updatePrefix(): void { updatePrefix(): void {
this.currentprefix.prefix = this.simpleprefixControl.value;
this.currentprefix.system_fun_item = this.subjectsControl.value;
this.currentprefix.state_or_verb = this.verbsControl.value;
this.currentprefix.item_function_flow_statevalue = this.objectsControl.value;
this.currentprefix.logic_connective = this.logic_conControl.value;
for (let i=0; i<PrefixDetailsComponent.id.length; i++){ for (let i=0; i<PrefixDetailsComponent.id.length; i++){
this.prefixService.update(this.route.snapshot.params.id, PrefixDetailsComponent.id[i], this.currentprefix) this.prefixService.update(this.route.snapshot.params.id, PrefixDetailsComponent.id[i], this.currentprefix)
.subscribe( .subscribe(
response => { response => {
console.log(response); this.notifier.notify("success",JSON.stringify("Prefix updated"));
this.message = response.message; this.message = response.message;
}, },
error => { error => {
...@@ -119,7 +147,8 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -119,7 +147,8 @@ export class PrefixDetailsComponent implements OnInit {
this.prefixService.getlogcon() this.prefixService.getlogcon()
.subscribe( .subscribe(
data => { data => {
this.logic_con = data; for (let x=0; x < data.length; x++ ){
this.logic_con.push(data[x][1]);}
}, },
error => { error => {
console.log(error); console.log(error);
...@@ -127,7 +156,8 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -127,7 +156,8 @@ export class PrefixDetailsComponent implements OnInit {
this.prefixService.getverb() this.prefixService.getverb()
.subscribe( .subscribe(
data => { data => {
this.verbs = data; for (let x=0; x < data.length; x++ ){
this.verbs.push(data[x][1]);}
}, },
error => { error => {
console.log(error); console.log(error);
...@@ -137,7 +167,6 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -137,7 +167,6 @@ export class PrefixDetailsComponent implements OnInit {
data => { data => {
for (let x=0; x < data.length; x++ ){ for (let x=0; x < data.length; x++ ){
this.subjects.push(data[x][1]);} this.subjects.push(data[x][1]);}
//this.subjects = data;
}, },
error => { error => {
console.log(error); console.log(error);
...@@ -145,7 +174,8 @@ export class PrefixDetailsComponent implements OnInit { ...@@ -145,7 +174,8 @@ export class PrefixDetailsComponent implements OnInit {
this.prefixService.getoobject() this.prefixService.getoobject()
.subscribe( .subscribe(
data => { data => {
this.objects = data; for (let x=0; x < data.length; x++ ){
this.objects.push(data[x][1]);}
}, },
error => { error => {
console.log(error); console.log(error);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment