Skip to content
Snippets Groups Projects
frame.ts 1.2 KiB
Newer Older
  • Learn to ignore specific revisions
  • import { ElementFactory } from 'common/util/element.factory';
    import { BasicStyles, PositionedUIElement, PositionProperties, UIElement } from 'common/models/elements/element';
    import { FrameComponent } from 'common/components/frame/frame.component';
    import { ElementComponent } from 'common/directives/element-component.directive';
    import { Type } from '@angular/core';
    
    export class FrameElement extends UIElement implements PositionedUIElement {
      position: PositionProperties;
      styling: BasicStyles & {
        borderWidth: number;
        borderColor: string;
        borderStyle: 'solid' | 'dotted' | 'dashed' | 'double' | 'groove' | 'ridge' | 'inset' | 'outset';
        borderRadius: number;
      };
    
      constructor(element: Partial<FrameElement>) {
        super(element);
        Object.assign(this, element);
        this.position = ElementFactory.initPositionProps({ zIndex: -1, ...element.position });
        this.styling = {
          ...ElementFactory.initStylingProps({
            backgroundColor: 'transparent',
            borderWidth: 1,
            borderColor: 'black',
            borderStyle: 'solid',
            borderRadius:  0,
            ...element.styling
          })
        };
      }
    
      getComponentFactory(): Type<ElementComponent> {
        return FrameComponent;
      }
    }