kwikid-camera
Version:
KwikID's Camera Component
236 lines • 40.7 kB
JavaScript
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"]}