UNPKG

kwikid-camera

Version:
128 lines 15.9 kB
import { __awaiter, __decorate } from "tslib"; /* eslint-disable brace-style */ /* eslint-disable no-unused-vars */ /* eslint-disable @typescript-eslint/no-unused-vars */ import { ChangeDetectionStrategy, Component, Input, ViewChild } from "@angular/core"; import { TUI_SANITIZER } from "@taiga-ui/core"; import { NgDompurifySanitizer } from "@tinkoff/ng-dompurify"; import { checkObjectKeyExists, mergeObjects, logMethod } from "kwikid-toolkit"; import { DEFAULT_CONFIG } from "./kwikid-camera-view.constants"; import { getDeviceId } from "./kwikid-camera-view.helper"; import * as i0 from "@angular/core"; import * as i1 from "kwikui"; export class KwikIDCameraViewComponent { constructor(kwikuiLoaderService, ref) { this.kwikuiLoaderService = kwikuiLoaderService; this.ref = ref; this.config = DEFAULT_CONFIG; this.mediaStream = null; this.currentDeviceId = ""; this.changeDetectionRefInterval = undefined; } ngOnInit() { return __awaiter(this, void 0, void 0, function* () { this.config = mergeObjects({}, DEFAULT_CONFIG, this.config); this.changeDetectionRefInterval = setInterval(() => { this.ref.detectChanges(); }, 500); }); } ngOnChanges(changes) { if (checkObjectKeyExists(changes, "config") && !changes.config.firstChange) { this.config = mergeObjects({}, DEFAULT_CONFIG, changes.config.currentValue); this.applyCameraSettings(); } } ngAfterViewInit() { return __awaiter(this, void 0, void 0, function* () { this.currentDeviceId = yield getDeviceId(null); this.applyCameraSettings(); this.startCamera(); }); } ngOnDestroy() { this.stopCamera(); if (this.changeDetectionRefInterval) { clearInterval(this.changeDetectionRefInterval); } } applyCameraSettings() { var _a; if (this.videoElement) { this.videoElement.nativeElement.style.transform = ((_a = this.config.others) === null || _a === void 0 ? void 0 : _a.flipHorizontal) ? "scaleX(-1); translate(50%, -50%)" : "scaleX(1); translate(-50%, -50%)"; } } startCamera() { navigator.mediaDevices .getUserMedia({ audio: false, video: { facingMode: this.config.others.isFrontCamera ? "user" : "environment" } }) .then((stream) => { this.mediaStream = stream; this.videoElement.nativeElement.srcObject = stream; this.videoElement.nativeElement.play(); }) .catch((error) => { console.log("Error accessing camera:", error); }); } stopCamera() { if (this.mediaStream) { this.mediaStream.getTracks().forEach((track) => track.stop()); this.mediaStream = null; } } } /** @nocollapse */ KwikIDCameraViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDCameraViewComponent, deps: [{ token: i1.KwikUILoaderService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ KwikIDCameraViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikIDCameraViewComponent, selector: "kwikid-camera-view", inputs: { config: "config" }, providers: [ { provide: TUI_SANITIZER, useClass: NgDompurifySanitizer } ], viewQueries: [{ propertyName: "videoElement", first: true, predicate: ["videoElement"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<video\n #videoElement\n playsinline\n autoplay\n muted\n></video>\n", styles: [":host{position:relative;display:block;width:100%;height:100%}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{border-radius:10px}::-webkit-scrollbar-thumb{background:lightgray;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:gray}.button-icon{width:2.5rem;height:2.5rem;color:#fff;background-color:transparent;border-radius:100%;padding:.5rem;border:none;outline:none;transition:all .2s ease-in-out;filter:drop-shadow(0px 0px 3px black)}.button-icon:hover{transform:scale(1.05)}.button-icon#close tui-svg{font-size:1.4rem}.button-icon tui-svg{width:100%;height:100%}button{cursor:pointer;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center}video{width:100%;height:100%;object-fit:cover;overflow:hidden;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}video.flip-horizontal{transform:scaleX(-1) translate(50%,-50%)}#video-switching{position:absolute;width:100%;height:100%;top:0;left:0;object-fit:cover;-o-object-fit:cover;object-position:center;-o-object-position:center;transform:scaleX(1);-webkit-transform:scaleX(1);background:black;color:#fff;display:flex;flex-direction:row;align-content:center;justify-content:center;align-items:center}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); __decorate([ logMethod ], KwikIDCameraViewComponent.prototype, "ngOnInit", null); __decorate([ logMethod ], KwikIDCameraViewComponent.prototype, "ngOnChanges", null); __decorate([ logMethod ], KwikIDCameraViewComponent.prototype, "ngAfterViewInit", null); __decorate([ logMethod ], KwikIDCameraViewComponent.prototype, "ngOnDestroy", null); __decorate([ logMethod ], KwikIDCameraViewComponent.prototype, "applyCameraSettings", null); __decorate([ logMethod ], KwikIDCameraViewComponent.prototype, "startCamera", null); __decorate([ logMethod ], KwikIDCameraViewComponent.prototype, "stopCamera", null); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDCameraViewComponent, decorators: [{ type: Component, args: [{ selector: "kwikid-camera-view", templateUrl: "./kwikid-camera-view.component.html", styleUrls: ["./kwikid-camera-view.component.scss"], providers: [ { provide: TUI_SANITIZER, useClass: NgDompurifySanitizer } ], changeDetection: ChangeDetectionStrategy.OnPush }] }], ctorParameters: function () { return [{ type: i1.KwikUILoaderService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { videoElement: [{ type: ViewChild, args: ["videoElement", { static: true }] }], config: [{ type: Input }], ngOnInit: [], ngOnChanges: [], ngAfterViewInit: [], ngOnDestroy: [], applyCameraSettings: [], startCamera: [], stopCamera: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kwikid-camera-view.component.js","sourceRoot":"","sources":["../../../../../../projects/kwikid-camera/src/lib/components/kwikid-camera-view/kwikid-camera-view.component.ts","../../../../../../projects/kwikid-camera/src/lib/components/kwikid-camera-view/kwikid-camera-view.component.html"],"names":[],"mappings":";AAAA,gCAAgC;AAChC,mCAAmC;AACnC,sDAAsD;AACtD,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAET,KAAK,EAKL,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE/E,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;;;AAc1D,MAAM,OAAO,yBAAyB;IAepC,YACS,mBAAwC,EACvC,GAAsB;QADvB,wBAAmB,GAAnB,mBAAmB,CAAqB;QACvC,QAAG,GAAH,GAAG,CAAmB;QAVhC,WAAM,GAAQ,cAAc,CAAC;QAErB,gBAAW,GAAuB,IAAI,CAAC;QAE/C,oBAAe,GAAG,EAAE,CAAC;QAErB,+BAA0B,GAAQ,SAAS,CAAC;IAKzC,CAAC;IAGE,QAAQ;;YACZ,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5D,IAAI,CAAC,0BAA0B,GAAG,WAAW,CAAC,GAAG,EAAE;gBACjD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YAC3B,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC;KAAA;IAGD,WAAW,CAAC,OAAsB;QAChC,IAAI,oBAAoB,CAAC,OAAO,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,EAAE;YAC1E,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,EAAE,EAAE,cAAc,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YAC5E,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;IACH,CAAC;IAGK,eAAe;;YACnB,IAAI,CAAC,eAAe,GAAG,MAAM,WAAW,CAAC,IAAI,CAAC,CAAC;YAC/C,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;KAAA;IAGD,WAAW;QACT,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,IAAI,CAAC,0BAA0B,EAAE;YACnC,aAAa,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;SAChD;IACH,CAAC;IAGD,mBAAmB;;QACjB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS;gBAC7C,CAAA,MAAA,IAAI,CAAC,MAAM,CAAC,MAAM,0CAAE,cAAc,EAAC,CAAC,CAAC,kCAAkC,CAAC,CAAC,CAAC,kCAAkC,CAAC;SAChH;IACH,CAAC;IAGD,WAAW;QACT,SAAS,CAAC,YAAY;aACnB,YAAY,CAAC;YACZ,KAAK,EAAE,KAAK;YACZ,KAAK,EAAE;gBACL,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,aAAa;aACtE;SACF,CAAC;aACD,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YACf,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;YAC1B,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,GAAG,MAAM,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QACzC,CAAC,CAAC;aACD,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;YACf,OAAO,CAAC,GAAG,CAAC,yBAAyB,EAAE,KAAK,CAAC,CAAC;QAChD,CAAC,CAAC,CAAC;IACP,CAAC;IAGD,UAAU;QACR,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;YAC9D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;SACzB;IACH,CAAC;;0IApFU,yBAAyB;8HAAzB,yBAAyB,2EARzB;QACT;YACE,OAAO,EAAE,aAAa;YACtB,QAAQ,EAAE,oBAAoB;SAC/B;KACF,2KChCH,0EAMA;ADkDE;IADC,SAAS;yDAMT;AAGD;IADC,SAAS;4DAMT;AAGD;IADC,SAAS;gEAKT;AAGD;IADC,SAAS;4DAMT;AAGD;IADC,SAAS;oEAMT;AAGD;IADC,SAAS;4DAiBT;AAGD;IADC,SAAS;2DAMT;4FApFU,yBAAyB;kBAZrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,WAAW,EAAE,qCAAqC;oBAClD,SAAS,EAAE,CAAC,qCAAqC,CAAC;oBAClD,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,aAAa;4BACtB,QAAQ,EAAE,oBAAoB;yBAC/B;qBACF;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;0IAKC,YAAY;sBADX,SAAS;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI3C,MAAM;sBADL,KAAK;gBAeA,QAAQ,MAQd,WAAW,MAQL,eAAe,MAOrB,WAAW,MAQX,mBAAmB,MAQnB,WAAW,MAmBX,UAAU","sourcesContent":["/* eslint-disable brace-style */\n/* eslint-disable no-unused-vars */\n/* eslint-disable @typescript-eslint/no-unused-vars */\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  ViewChild\n} from \"@angular/core\";\nimport { TUI_SANITIZER } from \"@taiga-ui/core\";\nimport { NgDompurifySanitizer } from \"@tinkoff/ng-dompurify\";\nimport { checkObjectKeyExists, mergeObjects, logMethod } from \"kwikid-toolkit\";\nimport { KwikUILoaderService } from \"kwikui\";\nimport { DEFAULT_CONFIG } from \"./kwikid-camera-view.constants\";\nimport { getDeviceId } from \"./kwikid-camera-view.helper\";\n\n@Component({\n  selector: \"kwikid-camera-view\",\n  templateUrl: \"./kwikid-camera-view.component.html\",\n  styleUrls: [\"./kwikid-camera-view.component.scss\"],\n  providers: [\n    {\n      provide: TUI_SANITIZER,\n      useClass: NgDompurifySanitizer\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class KwikIDCameraViewComponent\n  implements OnInit, OnChanges, AfterViewInit, OnDestroy\n{\n  @ViewChild(\"videoElement\", { static: true })\n  videoElement: ElementRef<HTMLVideoElement>;\n\n  @Input()\n  config: any = DEFAULT_CONFIG;\n\n  private mediaStream: MediaStream | null = null;\n\n  currentDeviceId = \"\";\n\n  changeDetectionRefInterval: any = undefined;\n\n  constructor(\n    public kwikuiLoaderService: KwikUILoaderService,\n    private ref: ChangeDetectorRef\n  ) {}\n\n  @logMethod\n  async ngOnInit() {\n    this.config = mergeObjects({}, DEFAULT_CONFIG, this.config);\n    this.changeDetectionRefInterval = setInterval(() => {\n      this.ref.detectChanges();\n    }, 500);\n  }\n\n  @logMethod\n  ngOnChanges(changes: SimpleChanges): void {\n    if (checkObjectKeyExists(changes, \"config\") && !changes.config.firstChange) {\n      this.config = mergeObjects({}, DEFAULT_CONFIG, changes.config.currentValue);\n      this.applyCameraSettings();\n    }\n  }\n\n  @logMethod\n  async ngAfterViewInit(): Promise<void> {\n    this.currentDeviceId = await getDeviceId(null);\n    this.applyCameraSettings();\n    this.startCamera();\n  }\n\n  @logMethod\n  ngOnDestroy(): void {\n    this.stopCamera();\n    if (this.changeDetectionRefInterval) {\n      clearInterval(this.changeDetectionRefInterval);\n    }\n  }\n\n  @logMethod\n  applyCameraSettings(): void {\n    if (this.videoElement) {\n      this.videoElement.nativeElement.style.transform =\n        this.config.others?.flipHorizontal ? \"scaleX(-1); translate(50%, -50%)\" : \"scaleX(1); translate(-50%, -50%)\";\n    }\n  }\n\n  @logMethod\n  startCamera() {\n    navigator.mediaDevices\n      .getUserMedia({\n        audio: false,\n        video: {\n          facingMode: this.config.others.isFrontCamera ? \"user\" : \"environment\"\n        }\n      })\n      .then((stream) => {\n        this.mediaStream = stream;\n        this.videoElement.nativeElement.srcObject = stream;\n        this.videoElement.nativeElement.play();\n      })\n      .catch((error) => {\n        console.log(\"Error accessing camera:\", error);\n      });\n  }\n\n  @logMethod\n  stopCamera() {\n    if (this.mediaStream) {\n      this.mediaStream.getTracks().forEach((track) => track.stop());\n      this.mediaStream = null;\n    }\n  }\n}\n","<video\n  #videoElement\n  playsinline\n  autoplay\n  muted\n></video>\n"]}