Skip to content
Snippets Groups Projects
likert-element.ts 1.82 KiB
Newer Older
import { InputElementValue, UIElement } from '../uI-element';
import { LikertElementRow } from './likert-element-row';
import { LikertColumn, FontElement, SurfaceUIElement } from '../../interfaces/UIElementInterfaces';
import { initFontElement, initSurfaceElement } from '../../util/unit-interface-initializer';
export class LikertElement extends UIElement implements FontElement, SurfaceUIElement {
  rows: LikertElementRow[] = [];
  columns: LikertColumn[] = [];
  firstColumnSizeRatio: number = 5;
  lineColoring: boolean = true;
  lineColoringColor: string = '#D0F6E7';
  readOnly: boolean = false;
  fontColor: string = 'black';
  font: string = 'Roboto';
  fontSize: number = 18;
  lineHeight: number = 120;
  bold: boolean = false;
  italic: boolean = false;
  underline: boolean = false;

  backgroundColor: string = 'transparent';

  constructor(serializedElement: UIElement) {
    super(serializedElement);
    Object.assign(this, serializedElement);
    Object.assign(this, initFontElement(serializedElement));
    Object.assign(this, initSurfaceElement(serializedElement));
    if (serializedElement?.rows) {
      this.rows = [];
      (serializedElement?.rows as LikertElementRow[]).forEach((row: LikertElementRow) => {
        this.rows.push(new LikertElementRow(row));
      });
    }

    this.height = serializedElement.height || 200;
    this.width = serializedElement.width || 400;
    this.backgroundColor = serializedElement.backgroundColor as string || 'transparent';
  setProperty(property: string, value: InputElementValue): void {
    super.setProperty(property, value);
rhenck's avatar
rhenck committed
    if (property === 'columns') {
      this.rows.forEach(row => {
        row.columnCount = this.columns.length;
    if (property === 'readOnly') {
rhenck's avatar
rhenck committed
      this.rows.forEach(row => {
        row.readOnly = this.readOnly;