Newer
Older
CompoundElement, UIElement,
PositionedUIElement, UIElementValue, OptionElement
} from 'common/models/elements/element';
import { LikertRowElement } from 'common/models/elements/compound-elements/likert/likert-row';
import { ElementComponent } from 'common/directives/element-component.directive';
import { LikertComponent } from 'common/components/compound-elements/likert/likert.component';
import { BasicStyles, DimensionProperties, PositionProperties } from 'common/models/elements/property-group-interfaces';
import { TextImageLabel } from 'common/models/elements/label-interfaces';
export class LikertElement extends CompoundElement implements PositionedUIElement, OptionElement {
options: TextImageLabel[] = [];
label: string = 'Optionentabelle Beschriftung';
label2: string = 'Beschriftung Erste Spalte';
position: PositionProperties;
styling: BasicStyles & {
lineHeight: number;
lineColoring: boolean;
lineColoringColor: string;
};
super({ dimensions: { width: 250, height: 200 } as DimensionProperties, ...element });
if (element.options) this.options = [...element.options];
if (element.firstColumnSizeRatio) this.firstColumnSizeRatio = element.firstColumnSizeRatio;
this.rows = element.rows !== undefined ? element.rows?.map(row => new LikertRowElement(row)) : [];
this.label = element.label !== undefined ? element.label : 'Optionentabelle Beschriftung';
this.label2 = element.label2 !== undefined ? element.label2 : 'Optionentabelle Erste Spalte';
this.stickyHeader = element.stickyHeader !== undefined ? element.stickyHeader : false;
this.position = UIElement.initPositionProps({ marginBottom: { value: 35, unit: 'px' }, ...element.position });
lineHeight: 135,
lineColoring: true,
lineColoringColor: '#c9e0e0',
...element.styling
})
};
}
getNewOptionLabel(optionText: string): TextImageLabel {
return UIElement.createOptionLabel(optionText, true) as TextImageLabel;
}
setProperty(property: string, value: UIElementValue): void {
super.setProperty(property, value);
if (property === 'rows') {
this.rows = value as LikertRowElement[];
}
if (property === 'options') {
this.getChildElements().forEach(childElement => childElement.setProperty('columnCount', this.options.length));
}
if (property === 'readOnly') {
this.getChildElements().forEach(childElement => childElement.setProperty('readOnly', value));
}
}
getElementComponent(): Type<ElementComponent> {