Newer
Older
import { ElementFactory } from 'common/util/element.factory';
import {
BasicStyles,
InputElement,
PositionedUIElement,
PositionProperties,
SchemerData, SchemerValue
} from 'common/models/elements/element';
import { Type } from '@angular/core';
import { ElementComponent } from 'common/directives/element-component.directive';
import { RadioButtonGroupComponent } from 'common/components/input-elements/radio-button-group.component';
export class RadioButtonGroupElement extends InputElement implements PositionedUIElement {
richTextOptions: string[] = [];
alignment: 'column' | 'row' = 'column';
strikeOtherOptions: boolean = false;
position: PositionProperties;
styling: BasicStyles & {
lineHeight: number;
};
constructor(element: Partial<RadioButtonGroupElement>) {
super({ height: 100, ...element });
Object.assign(this, element);
this.position = ElementFactory.initPositionProps({ marginBottom: 30, ...element.position });
this.styling = {
...ElementFactory.initStylingProps({
backgroundColor: 'transparent',
lineHeight: 135,
...element.styling
})
};
}
getSchemerData(options: any): SchemerData {
return {
id: this.id,
type: 'integer',
format: 'integer',
multiple: false,
nullable: true,
values: this.getSchemerValues(),
valuesComplete: true
};
}
private getSchemerValues(): SchemerValue[] {
return this.richTextOptions
.map((option, index) => ({ value: (index + 1).toString(), label: option }));
}