UNPKG

kwikid-camera

Version:
236 lines 40.7 kB
import { __decorate } from "tslib"; /* eslint-disable no-empty-function */ /* eslint-disable @typescript-eslint/no-empty-function */ /* eslint-disable @typescript-eslint/no-unused-vars */ /* eslint-disable brace-style */ import { Component, EventEmitter, Input, Output, forwardRef } from "@angular/core"; import { FormControl, FormGroup, NG_VALUE_ACCESSOR } from "@angular/forms"; import { checkObjectKeyExists, isNotEmptyValue, logMethod } from "kwikid-toolkit"; import { Subscription } from "rxjs"; import { distinctUntilChanged } from "rxjs/operators"; import { DEFAULT_VALUES, VALIDATE_KEY_VALUES } from "./input-camera.constants"; import { isValidKeyValue } from "./input-camera.validation"; import * as i0 from "@angular/core"; import * as i1 from "@taiga-ui/core"; import * as i2 from "@angular/forms"; import * as i3 from "@angular/common"; export class KwikUIInputCameraComponent { constructor() { this.buttonText = DEFAULT_VALUES.buttonText; this.disabled = DEFAULT_VALUES.disabled; this.focus = DEFAULT_VALUES.focus; this.formControl = new FormControl({}); this.formControlName = DEFAULT_VALUES.formControlName; this.icon = DEFAULT_VALUES.icon; this.id = DEFAULT_VALUES.id; this.invalid = DEFAULT_VALUES.invalid; this.mediaFiles = DEFAULT_VALUES.mediaFiles; this.properties = { readOnly: false }; this.showMediaFiles = DEFAULT_VALUES.showMediaFiles; this.size = DEFAULT_VALUES.size; this.type = DEFAULT_VALUES.type; this.validators = { required: true }; this.onClick = new EventEmitter(); this.getRemovedFile = new EventEmitter(); this.openDropdown = false; this.formGroup = new FormGroup({}); this.subscriptions = new Subscription(); } ngOnInit() { this.formGroup = new FormGroup({ [this.formControlName]: new FormControl(this.formControl) }); this.validators = Object.assign({}, this.validators); this.setDisabled(); this.mediaFiles = this.filterDuplicatesAndEmpty(this.mediaFiles); this.loadMediaFiles(this.mediaFiles); this.subscriptions.add(this.formGroup.controls[this.formControlName].valueChanges .pipe(distinctUntilChanged()) // makes sure the value has actually changed. .subscribe((value) => this.loadMediaFiles(value))); } ngOnChanges(changes) { const verifyChange = (key) => { return checkObjectKeyExists(changes, key) && !changes[key].firstChange; }; for (const change of Object.entries(changes)) { const key = change[0]; const value = change[1].currentValue; this.validateInputProperty(key, value); } if (verifyChange("formControl")) { this.formControl = changes.formControl.currentValue; } if (verifyChange("icon")) { this.icon = changes.icon.currentValue; } if (verifyChange("size")) { this.size = changes.size.currentValue; } if (verifyChange("type")) { this.type = changes.type.currentValue; } if (verifyChange("mediaFiles")) { this.mediaFiles = this.filterDuplicatesAndEmpty(changes.mediaFiles.currentValue); this.loadMediaFiles(this.mediaFiles); } if (verifyChange("disabled")) { this.disabled = changes.disabled.currentValue; this.setDisabled(); } } ngOnDestroy() { this.subscriptions.unsubscribe(); // ensure when component is destroyed the subscription is also and not left open. } validateInputProperty(key, value) { if (VALIDATE_KEY_VALUES[key] && !isValidKeyValue(key, value)) { this[key] = DEFAULT_VALUES[key]; } } /** * @description Handles setting up of error and focus on the input field is it is invalid */ setDisabled() { if (this.formGroup.controls[this.formControlName] !== undefined) { if (this.disabled === true) { this.formGroup.controls[this.formControlName].disable({ emitEvent: false }); } else { this.formGroup.controls[this.formControlName].enable({ emitEvent: false }); } } } /** * @description Handles setting up of error and focus on the input field is it is invalid */ setError() { if (this.formGroup.controls[this.formControlName] !== undefined && this.formGroup.controls[this.formControlName].invalid) { this.invalid = true; this.focus = true; } else { this.invalid = false; this.focus = false; } } loadMediaFiles(files) { if (!Array.isArray(files)) { files = [files]; } this.formGroup.controls[this.formControlName].patchValue(files, { emitEvent: false }); } filterDuplicatesAndEmpty(files) { const uniqueFiles = []; files = files.filter((file) => isNotEmptyValue(file)); files.forEach((file) => { const isDuplicate = uniqueFiles.some((existingFile) => existingFile === file); if (!isDuplicate) { uniqueFiles.push(file); } }); return uniqueFiles; } /** * @description Handles firing of 2 events on (keyup) event * * @param value */ handleOnClick(e) { this.emitEvent(this.onClick, e); } handleOnClickRemoveFile(mediaFile) { const mediaFiles = this.mediaFiles.filter((f) => { return !(f === mediaFile); }); this.emitEvent(this.getRemovedFile, { key: this.formControlName, value: mediaFile, mediaFiles }); } handleFocusedChange(e) { if (!this.invalid) { this.focus = e; } } emitEvent(event, data) { event.emit(data); } /** Method Implementations for Abstract Control */ writeValue(value) { } registerOnChange(fn) { } registerOnTouched(fn) { } setDisabledState(isDisabled) { } } /** @nocollapse */ KwikUIInputCameraComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIInputCameraComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ KwikUIInputCameraComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikUIInputCameraComponent, selector: "kwikui-input-camera", inputs: { buttonText: "buttonText", disabled: "disabled", focus: "focus", formControl: "formControl", formControlName: "formControlName", icon: "icon", id: "id", invalid: "invalid", mediaFiles: "mediaFiles", properties: "properties", showMediaFiles: "showMediaFiles", size: "size", type: "type", validators: "validators" }, outputs: { onClick: "onClick", getRemovedFile: "getRemovedFile" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => KwikUIInputCameraComponent)), multi: true } ], usesOnChanges: true, ngImport: i0, template: "<div\n [formGroup]=\"formGroup\"\n [id]=\"id\"\n class=\"input-camera-container\"\n>\n <div\n class=\"input-camera-button-container\"\n *ngIf=\"size === 's'\"\n >\n <button\n *ngIf=\"size === 's'\"\n tuiButton\n appearance=\"flat\"\n shape=\"square\"\n size=\"m\"\n [disabled]=\"formControl.disabled\"\n class=\"input-camera-button\"\n [class.button-small]=\"size === 's'\"\n (click)=\"handleOnClick($event)\"\n >\n <tui-svg [src]=\"icon\"></tui-svg>\n </button>\n <button\n *ngIf=\"showMediaFiles && size === 's'\"\n tuiButton\n appearance=\"flat\"\n shape=\"square\"\n size=\"m\"\n class=\"input-camera-media-added\"\n [class.button-small]=\"size === 's'\"\n [tuiDropdown]=\"mediaFiles.length > 0 ? MEDIA_ADDED : MEDIA_ADDED_NONE\"\n [tuiDropdownManual]=\"openDropdown\"\n (click)=\"openDropdown = !openDropdown\"\n >\n {{ mediaFiles.length }}\n </button>\n </div>\n\n <button\n *ngIf=\"size === 'm'\"\n [disabled]=\"formControl.disabled\"\n class=\"input-camera-button\"\n [class.button-medium]=\"size === 'm'\"\n (click)=\"handleOnClick($event)\"\n >\n <div>{{ buttonText }}</div>\n <tui-svg [src]=\"icon\"></tui-svg>\n </button>\n\n <button\n *ngIf=\"size === 'l'\"\n [disabled]=\"formControl.disabled\"\n class=\"input-camera-button\"\n [class.button-large]=\"size === 'l'\"\n (click)=\"handleOnClick($event)\"\n >\n <tui-svg [src]=\"icon\"></tui-svg>\n <div>{{ buttonText }}</div>\n </button>\n\n <ng-container *ngIf=\"size !== 's'\">\n <ng-container *ngIf=\"mediaFiles.length > 0 && showMediaFiles\">\n <ng-container *ngTemplateOutlet=\"MEDIA_ADDED\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"mediaFiles.length === 0 && showMediaFiles\">\n <ng-container *ngTemplateOutlet=\"MEDIA_ADDED_NONE\"></ng-container>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #MEDIA_ADDED>\n <div\n class=\"media-added\"\n [class.small]=\"size === 's'\"\n [class.medium]=\"size === 'm'\"\n [class.large]=\"size === 'l'\"\n (click)=\"(null)\"\n >\n <ng-container *ngIf=\"type === 'capture'\">\n <ng-container *ngFor=\"let mediaFile of mediaFiles\">\n <div class=\"media-item-container\">\n <button\n *ngIf=\"!formControl.disabled\"\n tuiButton\n appearance=\"whiteblock\"\n shape=\"square\"\n size=\"s\"\n class=\"media-item-remove-button\"\n [tuiHint]=\"REMOVE_FILE_TOOPTIP\"\n (click)=\"handleOnClickRemoveFile(mediaFile)\"\n >\n <tui-svg src=\"tuiIconClose\"></tui-svg>\n </button>\n <img\n [src]=\"mediaFile\"\n class=\"media-image\"\n />\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"type === 'record'\">\n <ng-container *ngFor=\"let mediaFile of mediaFiles\">\n <div class=\"media-item-container\">\n <button\n *ngIf=\"!formControl.disabled\"\n tuiButton\n appearance=\"whiteblock\"\n shape=\"square\"\n size=\"s\"\n class=\"media-item-remove-button\"\n [tuiHint]=\"REMOVE_FILE_TOOPTIP\"\n (click)=\"handleOnClickRemoveFile(mediaFile)\"\n >\n <tui-svg src=\"tuiIconClose\"></tui-svg>\n </button>\n <video\n controls\n class=\"media-video\"\n >\n <source [src]=\"mediaFile\" />\n Your browser does not support the video tag.\n </video>\n </div>\n </ng-container>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #MEDIA_ADDED_NONE>\n <div\n *ngIf=\"showMediaFiles\"\n class=\"media-added-none\"\n (click)=\"(undefined)\"\n >\n No Media Added\n </div>\n</ng-template>\n\n<ng-template #REMOVE_FILE_TOOPTIP>\n <div> Remove File </div>\n</ng-template>\n", styles: [".input-camera-container{width:100%;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;grid-gap:1rem;gap:1rem}.input-camera-container .input-camera-button-container{align-content:center;align-items:center;cursor:pointer;display:flex;flex-direction:row;font-size:1rem;font-weight:bold;gap:.25rem;grid-gap:.25rem;justify-content:center;width:-moz-fit-content;width:fit-content}.input-camera-container .input-camera-button-container .input-camera-media-added{border-radius:50%}.input-camera-container .input-camera-button{display:flex;flex-direction:row;align-content:center;justify-content:space-between;align-items:center;grid-gap:1rem;gap:1rem;padding:1rem;border-radius:.5rem;outline:none;border:1px dashed var(--tui-primary);color:var(--tui-primary);background:white;text-transform:lowercase;font-size:1rem;cursor:pointer;transform:scale(1);transition:1s linear ease}.input-camera-container .input-camera-button:hover:not(:disabled)>tui-svg{transition:1s linear ease;transform:scale(1.1)}.input-camera-container .input-camera-button:active>tui-svg{transition:1s linear ease;transform:scale(.95)}.input-camera-container .input-camera-button:disabled{opacity:.5;cursor:not-allowed}.input-camera-container .input-camera-button.button-small{border-radius:50%}.input-camera-container .input-camera-button.button-medium{padding:.75rem 1rem}.input-camera-container .input-camera-button.button-large{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem}.media-added{display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;grid-gap:1rem;gap:1rem;padding:.15rem;border-radius:.5rem}.media-added .media-item-container{position:relative}.media-added .media-item-container .media-item-remove-button{position:absolute;right:.5rem;top:.5rem;border-radius:50%;z-index:2}.media-added .media-item-container .media-image{width:100%;height:auto;border-radius:5px;box-shadow:#00000005 0 1px 3px,#1b1f2326 0 0 0 1px}.media-added .media-item-container .media-video{width:100%;height:auto;border-radius:5px;box-shadow:#00000005 0 1px 3px,#1b1f2326 0 0 0 1px}.media-added-none{width:100%;border:1px solid lightgray;border-radius:.5rem;padding:.75rem 1rem;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:center;align-content:center;align-items:center}\n"], components: [{ type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }], directives: [{ type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { type: i1.TuiDropdownDriverDirective, selector: "[tuiDropdown]" }, { type: i1.TuiDropdownPositionDirective, selector: "[tuiDropdown]" }, { type: i1.TuiDropdownManualDirective, selector: "[tuiDropdown][tuiDropdownManual]", inputs: ["tuiDropdownManual"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.TuiHintDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHint", "tuiHintContext", "tuiHintAppearance"] }, { type: i1.TuiHintDriverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)" }, { type: i1.TuiHintHoverDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintShowDelay", "tuiHintHideDelay"], exportAs: ["tuiHintHover"] }, { type: i1.TuiHintPositionDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintDirection"] }] }); __decorate([ logMethod ], KwikUIInputCameraComponent.prototype, "ngOnChanges", null); __decorate([ logMethod ], KwikUIInputCameraComponent.prototype, "loadMediaFiles", null); __decorate([ logMethod ], KwikUIInputCameraComponent.prototype, "filterDuplicatesAndEmpty", null); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikUIInputCameraComponent, decorators: [{ type: Component, args: [{ selector: "kwikui-input-camera", templateUrl: "./input-camera.component.html", styleUrls: ["./input-camera.component.scss"], providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((() => KwikUIInputCameraComponent)), multi: true } ] }] }], propDecorators: { buttonText: [{ type: Input }], disabled: [{ type: Input }], focus: [{ type: Input }], formControl: [{ type: Input }], formControlName: [{ type: Input }], icon: [{ type: Input }], id: [{ type: Input }], invalid: [{ type: Input }], mediaFiles: [{ type: Input }], properties: [{ type: Input }], showMediaFiles: [{ type: Input }], size: [{ type: Input }], type: [{ type: Input }], validators: [{ type: Input }], onClick: [{ type: Output }], getRemovedFile: [{ type: Output }], ngOnChanges: [], loadMediaFiles: [], filterDuplicatesAndEmpty: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-camera.component.js","sourceRoot":"","sources":["../../../../../../projects/kwikid-camera/src/lib/components/kwikui-input-camera/input-camera.component.ts","../../../../../../projects/kwikid-camera/src/lib/components/kwikui-input-camera/input-camera.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-empty-function */\n/* eslint-disable @typescript-eslint/no-empty-function */\n/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable brace-style */\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  forwardRef\n} from \"@angular/core\";\nimport {\n  ControlValueAccessor,\n  FormControl,\n  FormGroup,\n  NG_VALUE_ACCESSOR\n} from \"@angular/forms\";\nimport {\n  checkObjectKeyExists,\n  isNotEmptyValue,\n  logMethod\n} from \"kwikid-toolkit\";\nimport { Subscription } from \"rxjs\";\nimport { distinctUntilChanged } from \"rxjs/operators\";\nimport { DEFAULT_VALUES, VALIDATE_KEY_VALUES } from \"./input-camera.constants\";\nimport {\n  TKwikUIInputCameraSize,\n  TKwikUIInputCameraType\n} from \"./input-camera.definitions\";\nimport { isValidKeyValue } from \"./input-camera.validation\";\n\n@Component({\n  selector: \"kwikui-input-camera\",\n  templateUrl: \"./input-camera.component.html\",\n  styleUrls: [\"./input-camera.component.scss\"],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => KwikUIInputCameraComponent),\n      multi: true\n    }\n  ]\n})\nexport class KwikUIInputCameraComponent\n  implements OnInit, OnChanges, ControlValueAccessor\n{\n  @Input() buttonText: string = DEFAULT_VALUES.buttonText;\n\n  @Input() disabled: boolean = DEFAULT_VALUES.disabled;\n\n  @Input() focus: boolean = DEFAULT_VALUES.focus;\n\n  @Input() formControl: FormControl = new FormControl({});\n\n  @Input() formControlName: string = DEFAULT_VALUES.formControlName;\n\n  @Input() icon: string = DEFAULT_VALUES.icon;\n\n  @Input() id: string = DEFAULT_VALUES.id;\n\n  @Input() invalid: boolean = DEFAULT_VALUES.invalid;\n\n  @Input() mediaFiles: any[] = DEFAULT_VALUES.mediaFiles;\n\n  @Input() properties = { readOnly: false };\n\n  @Input() showMediaFiles: boolean = DEFAULT_VALUES.showMediaFiles;\n\n  @Input() size: TKwikUIInputCameraSize = DEFAULT_VALUES.size;\n\n  @Input() type: TKwikUIInputCameraType = DEFAULT_VALUES.type;\n\n  @Input() validators = { required: true };\n\n  @Output() onClick: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output() getRemovedFile: EventEmitter<any> = new EventEmitter<any>();\n\n  openDropdown = false;\n\n  formGroup: FormGroup = new FormGroup({});\n\n  subscriptions = new Subscription();\n\n  ngOnInit(): void {\n    this.formGroup = new FormGroup({\n      [this.formControlName]: new FormControl(this.formControl)\n    });\n    this.validators = { ...this.validators };\n    this.setDisabled();\n\n    this.mediaFiles = this.filterDuplicatesAndEmpty(this.mediaFiles);\n    this.loadMediaFiles(this.mediaFiles);\n\n    this.subscriptions.add(\n      this.formGroup.controls[this.formControlName].valueChanges\n        .pipe(distinctUntilChanged()) // makes sure the value has actually changed.\n        .subscribe((value) => this.loadMediaFiles(value))\n    );\n  }\n\n  @logMethod\n  ngOnChanges(changes: SimpleChanges) {\n    const verifyChange = (key: string) => {\n      return checkObjectKeyExists(changes, key) && !changes[key].firstChange;\n    };\n\n    for (const change of Object.entries(changes)) {\n      const key: string = change[0];\n      const value: any = change[1].currentValue;\n      this.validateInputProperty(key, value);\n    }\n\n    if (verifyChange(\"formControl\")) {\n      this.formControl = changes.formControl.currentValue;\n    }\n    if (verifyChange(\"icon\")) {\n      this.icon = changes.icon.currentValue;\n    }\n    if (verifyChange(\"size\")) {\n      this.size = changes.size.currentValue;\n    }\n    if (verifyChange(\"type\")) {\n      this.type = changes.type.currentValue;\n    }\n    if (verifyChange(\"mediaFiles\")) {\n      this.mediaFiles = this.filterDuplicatesAndEmpty(\n        changes.mediaFiles.currentValue\n      );\n      this.loadMediaFiles(this.mediaFiles);\n    }\n    if (verifyChange(\"disabled\")) {\n      this.disabled = changes.disabled.currentValue;\n\n      this.setDisabled();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n    // ensure when component is destroyed the subscription is also and not left open.\n  }\n\n  private validateInputProperty(key: string, value: any): void {\n    if (VALIDATE_KEY_VALUES[key] && !isValidKeyValue(key, value)) {\n      this[key] = DEFAULT_VALUES[key];\n    }\n  }\n\n  /**\n   * @description Handles setting up of error and focus on the input field is it is invalid\n   */\n  setDisabled() {\n    if (this.formGroup.controls[this.formControlName] !== undefined) {\n      if (this.disabled === true) {\n        this.formGroup.controls[this.formControlName].disable({\n          emitEvent: false\n        });\n      } else {\n        this.formGroup.controls[this.formControlName].enable({\n          emitEvent: false\n        });\n      }\n    }\n  }\n\n  /**\n   * @description Handles setting up of error and focus on the input field is it is invalid\n   */\n  setError() {\n    if (\n      this.formGroup.controls[this.formControlName] !== undefined &&\n      this.formGroup.controls[this.formControlName].invalid\n    ) {\n      this.invalid = true;\n      this.focus = true;\n    } else {\n      this.invalid = false;\n      this.focus = false;\n    }\n  }\n\n  @logMethod\n  loadMediaFiles(files: any[]) {\n    if (!Array.isArray(files)) {\n      files = [files];\n    }\n\n    this.formGroup.controls[this.formControlName].patchValue(files, {\n      emitEvent: false\n    });\n  }\n\n  @logMethod\n  filterDuplicatesAndEmpty(files: any[]): any[] {\n    const uniqueFiles: any[] = [];\n\n    files = files.filter((file) => isNotEmptyValue(file));\n\n    files.forEach((file) => {\n      const isDuplicate = uniqueFiles.some(\n        (existingFile) => existingFile === file\n      );\n\n      if (!isDuplicate) {\n        uniqueFiles.push(file);\n      }\n    });\n\n    return uniqueFiles;\n  }\n\n  /**\n   * @description Handles firing of 2 events on (keyup) event\n   *\n   * @param value\n   */\n  handleOnClick(e: any) {\n    this.emitEvent(this.onClick, e);\n  }\n\n  handleOnClickRemoveFile(mediaFile: any) {\n    const mediaFiles = this.mediaFiles.filter((f: any) => {\n      return !(f === mediaFile);\n    });\n\n    this.emitEvent(this.getRemovedFile, {\n      key: this.formControlName,\n      value: mediaFile,\n      mediaFiles\n    });\n  }\n\n  handleFocusedChange(e: any) {\n    if (!this.invalid) {\n      this.focus = e;\n    }\n  }\n\n  emitEvent(event: any, data: any) {\n    event.emit(data);\n  }\n\n  /** Method Implementations for Abstract Control */\n  writeValue(value: any): void {}\n\n  registerOnChange(fn: any): void {}\n\n  registerOnTouched(fn: any): void {}\n\n  setDisabledState?(isDisabled: boolean): void {}\n}\n","<div\n  [formGroup]=\"formGroup\"\n  [id]=\"id\"\n  class=\"input-camera-container\"\n>\n  <div\n    class=\"input-camera-button-container\"\n    *ngIf=\"size === 's'\"\n  >\n    <button\n      *ngIf=\"size === 's'\"\n      tuiButton\n      appearance=\"flat\"\n      shape=\"square\"\n      size=\"m\"\n      [disabled]=\"formControl.disabled\"\n      class=\"input-camera-button\"\n      [class.button-small]=\"size === 's'\"\n      (click)=\"handleOnClick($event)\"\n    >\n      <tui-svg [src]=\"icon\"></tui-svg>\n    </button>\n    <button\n      *ngIf=\"showMediaFiles && size === 's'\"\n      tuiButton\n      appearance=\"flat\"\n      shape=\"square\"\n      size=\"m\"\n      class=\"input-camera-media-added\"\n      [class.button-small]=\"size === 's'\"\n      [tuiDropdown]=\"mediaFiles.length > 0 ? MEDIA_ADDED : MEDIA_ADDED_NONE\"\n      [tuiDropdownManual]=\"openDropdown\"\n      (click)=\"openDropdown = !openDropdown\"\n    >\n      {{ mediaFiles.length }}\n    </button>\n  </div>\n\n  <button\n    *ngIf=\"size === 'm'\"\n    [disabled]=\"formControl.disabled\"\n    class=\"input-camera-button\"\n    [class.button-medium]=\"size === 'm'\"\n    (click)=\"handleOnClick($event)\"\n  >\n    <div>{{ buttonText }}</div>\n    <tui-svg [src]=\"icon\"></tui-svg>\n  </button>\n\n  <button\n    *ngIf=\"size === 'l'\"\n    [disabled]=\"formControl.disabled\"\n    class=\"input-camera-button\"\n    [class.button-large]=\"size === 'l'\"\n    (click)=\"handleOnClick($event)\"\n  >\n    <tui-svg [src]=\"icon\"></tui-svg>\n    <div>{{ buttonText }}</div>\n  </button>\n\n  <ng-container *ngIf=\"size !== 's'\">\n    <ng-container *ngIf=\"mediaFiles.length > 0 && showMediaFiles\">\n      <ng-container *ngTemplateOutlet=\"MEDIA_ADDED\"></ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"mediaFiles.length === 0 && showMediaFiles\">\n      <ng-container *ngTemplateOutlet=\"MEDIA_ADDED_NONE\"></ng-container>\n    </ng-container>\n  </ng-container>\n</div>\n\n<ng-template #MEDIA_ADDED>\n  <div\n    class=\"media-added\"\n    [class.small]=\"size === 's'\"\n    [class.medium]=\"size === 'm'\"\n    [class.large]=\"size === 'l'\"\n    (click)=\"(null)\"\n  >\n    <ng-container *ngIf=\"type === 'capture'\">\n      <ng-container *ngFor=\"let mediaFile of mediaFiles\">\n        <div class=\"media-item-container\">\n          <button\n            *ngIf=\"!formControl.disabled\"\n            tuiButton\n            appearance=\"whiteblock\"\n            shape=\"square\"\n            size=\"s\"\n            class=\"media-item-remove-button\"\n            [tuiHint]=\"REMOVE_FILE_TOOPTIP\"\n            (click)=\"handleOnClickRemoveFile(mediaFile)\"\n          >\n            <tui-svg src=\"tuiIconClose\"></tui-svg>\n          </button>\n          <img\n            [src]=\"mediaFile\"\n            class=\"media-image\"\n          />\n        </div>\n      </ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"type === 'record'\">\n      <ng-container *ngFor=\"let mediaFile of mediaFiles\">\n        <div class=\"media-item-container\">\n          <button\n            *ngIf=\"!formControl.disabled\"\n            tuiButton\n            appearance=\"whiteblock\"\n            shape=\"square\"\n            size=\"s\"\n            class=\"media-item-remove-button\"\n            [tuiHint]=\"REMOVE_FILE_TOOPTIP\"\n            (click)=\"handleOnClickRemoveFile(mediaFile)\"\n          >\n            <tui-svg src=\"tuiIconClose\"></tui-svg>\n          </button>\n          <video\n            controls\n            class=\"media-video\"\n          >\n            <source [src]=\"mediaFile\" />\n            Your browser does not support the video tag.\n          </video>\n        </div>\n      </ng-container>\n    </ng-container>\n  </div>\n</ng-template>\n\n<ng-template #MEDIA_ADDED_NONE>\n  <div\n    *ngIf=\"showMediaFiles\"\n    class=\"media-added-none\"\n    (click)=\"(undefined)\"\n  >\n    No Media Added\n  </div>\n</ng-template>\n\n<ng-template #REMOVE_FILE_TOOPTIP>\n  <div> Remove File </div>\n</ng-template>\n"]}