Newer
Older
import {
InputElement, AnswerScheme, AnswerSchemeValue, TextImageLabel
} from 'common/models/elements/element';
import { ElementComponent } from 'common/directives/element-component.directive';
import {
LikertRadioButtonGroupComponent
} from 'common/components/compound-elements/likert/likert-radio-button-group.component';
export class LikertRowElement extends InputElement {
rowLabel: TextImageLabel = { text: '', imgSrc: null, imgPosition: 'above' };
columnCount: number = 0;
firstColumnSizeRatio: number = 5;
verticalButtonAlignment: 'auto' | 'center' = 'center';
constructor(element: Partial<LikertRowElement>) {
super(element);
if (element.rowLabel) this.rowLabel = { ...element.rowLabel };
if (element.columnCount) this.columnCount = element.columnCount;
if (element.firstColumnSizeRatio) this.firstColumnSizeRatio = element.firstColumnSizeRatio;
if (element.verticalButtonAlignment) this.verticalButtonAlignment = element.verticalButtonAlignment;
hasAnswerScheme(): boolean {
return Boolean(this.getAnswerScheme);
getAnswerScheme(): AnswerScheme {
return {
id: this.id,
type: 'integer',
format: '',
multiple: false,
nullable: !this.value && this.value !== 0,
values: this.getAnswerSchemeValues(),
private getAnswerSchemeValues(): AnswerSchemeValue[] {
{
value: !this.value && this.value !== 0 ? 'null' : (this.value as number + 1).toString(),
label: InputElement.stripHTML(this.rowLabel.text)
getElementComponent(): Type<ElementComponent> {
return LikertRadioButtonGroupComponent;
}
}