2017-12-04 16:02:52 +01:00
|
|
|
import { FormGroup } from '@angular/forms';
|
|
|
|
import { Field } from '../models/Field';
|
|
|
|
import { Component, Input, OnInit } from '@angular/core';
|
|
|
|
import { WordListData } from '../models/DataField/WordListData';
|
|
|
|
import { FormArray } from '@angular/forms/src/model';
|
|
|
|
import { ListingItem } from '../models/Commons/ListingItem';
|
|
|
|
import { JsonSerializer } from '../utilities/JsonSerializer';
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'wordlist-component',
|
|
|
|
templateUrl: './wordlist-component.html'
|
|
|
|
})
|
|
|
|
export class WordlistComponent implements OnInit{
|
|
|
|
@Input() dataModel: Field;
|
|
|
|
@Input() form: FormGroup;
|
|
|
|
private data: WordListData = new WordListData();
|
|
|
|
private options = new Array<ListingItem>();
|
|
|
|
|
|
|
|
ngOnInit(){
|
2017-12-05 12:02:03 +01:00
|
|
|
this.data.type = "wordlist";
|
2017-12-04 16:02:52 +01:00
|
|
|
if (this.form.get("data")) this.form.removeControl("data");
|
|
|
|
this.form.addControl("data", this.data.buildForm());
|
|
|
|
this.addNewRow();
|
|
|
|
}
|
|
|
|
|
|
|
|
addNewRow(){
|
|
|
|
let wordListOptions:ListingItem = new ListingItem();
|
|
|
|
(<FormArray>this.form.get("data").get("options")).push(wordListOptions.buildForm());
|
|
|
|
this.data.options = [];
|
|
|
|
this.data.options.push(wordListOptions);
|
|
|
|
this.dataModel.data = new JsonSerializer<WordListData>().fromJSONObject(this.data,WordListData);
|
|
|
|
}
|
|
|
|
}
|