import { Type } from '@angular/core'; import { InputElement, InputElementProperties, UIElementType } from 'common/models/elements/element'; import { ElementComponent } from 'common/directives/element-component.directive'; import { CheckboxComponent } from 'common/components/input-elements/checkbox.component'; import { VariableInfo, VariableValue } from '@iqb/responses'; import { BasicStyles, PropertyGroupGenerators, PropertyGroupValidators } from 'common/models/elements/property-group-interfaces'; import { environment } from 'common/environment'; import { InstantiationEror } from 'common/util/errors'; export class CheckboxElement extends InputElement implements CheckboxProperties { type: UIElementType = 'checkbox'; label: string = 'Beschriftung'; value: boolean = false; crossOutChecked: boolean = false; styling: BasicStyles; static title: string = 'Kontrollkästchen'; static icon: string = 'check_box'; constructor(element?: CheckboxProperties) { super(element); if (element && isValid(element)) { this.label = element.label; this.value = element.value; this.crossOutChecked = element.crossOutChecked; this.styling = { ...element.styling }; } else { if (environment.strictInstantiation) { throw new InstantiationEror('Error at Checkbox instantiation', element); } if (element?.label !== undefined) this.label = element.label; if (element?.value !== undefined) this.value = element.value; if (element?.crossOutChecked !== undefined) this.crossOutChecked = element.crossOutChecked; this.dimensions = PropertyGroupGenerators.generateDimensionProps({ width: 215, ...element?.dimensions }); this.styling = PropertyGroupGenerators.generateBasicStyleProps(element?.styling); } } getDuplicate(): CheckboxElement { return new CheckboxElement(this); } getVariableInfos(): VariableInfo[] { return [{ id: this.id, type: 'boolean', format: '', multiple: false, nullable: false, values: this.getVariableInfoValues(), valuePositionLabels: [], page: '', valuesComplete: true }]; } private getVariableInfoValues(): VariableValue[] { return [ { value: 'true', label: `Angekreuzt: ${this.label}` }, { value: 'false', label: `Nicht Angekreuzt: ${this.label}` } ]; } getElementComponent(): Type<ElementComponent> { return CheckboxComponent; } } export interface CheckboxProperties extends InputElementProperties { label: string; value: boolean; crossOutChecked: boolean; styling: BasicStyles; } function isValid(blueprint?: CheckboxProperties): boolean { if (!blueprint) return false; return blueprint.label !== undefined && blueprint.crossOutChecked !== undefined && PropertyGroupValidators.isValidBasicStyles(blueprint.styling); }