UNPKG

kwikid-camera

Version:
115 lines 14.5 kB
import { __awaiter } from "tslib"; import { isEmptyValue } from "kwikid-toolkit"; // TOOLKIT export function getDevicesList() { return __awaiter(this, void 0, void 0, function* () { const videoDevices = []; try { // Request permission to access media devices const temporaryStream = yield navigator.mediaDevices.getUserMedia({ audio: true, video: true }); // Enumerate devices if permission is granted yield navigator.mediaDevices.enumerateDevices().then((devices) => __awaiter(this, void 0, void 0, function* () { for (const device of devices) { if (device.kind === "videoinput") { const constraints = { video: { deviceId: { exact: device.deviceId } } }; yield navigator.mediaDevices .getUserMedia(constraints) .then((stream) => { const track = stream.getVideoTracks()[0]; const { facingMode } = track.getSettings(); videoDevices.push({ deviceId: device.deviceId, groupId: device.groupId, kind: device.kind, label: device.label, facingMode }); // You can now identify whether it's a front or back camera // Handle your logic accordingly stream.getTracks().forEach((track) => track.stop()); }) .catch((error) => { console.error("Error accessing camera:", error); }); } } // Stop the stream after enumeration temporaryStream.getTracks().forEach((track) => track.stop()); })); return videoDevices; } catch (error) { // Handle permission denied or other errors console.info("Error accessing video devices:", error); return videoDevices; // You might want to handle this differently based on your requirements } }); } // TOOLKIT export function getDevice(videoDevices, isFrontCamera) { return __awaiter(this, void 0, void 0, function* () { if (videoDevices.length === 0) { return { deviceId: null, facingMode: null }; } if (videoDevices.length === 1) { return videoDevices[0]; } if (videoDevices.length > 1) { const frontCameraDevices = videoDevices.filter((videoDevice) => { return videoDevice.facingMode === "user"; }); const backCameraDevices = videoDevices.filter((videoDevice) => { return videoDevice.facingMode === "environment"; }); if (isFrontCamera) { if (frontCameraDevices.length > 0) { return frontCameraDevices[0]; } return backCameraDevices[0]; } if (!isFrontCamera) { if (backCameraDevices.length > 0) { return backCameraDevices[0]; } return frontCameraDevices[0]; } } return { deviceId: null, facingMode: null }; }); } // TOOLKIT export function getBase64FromVideoFile(videoFile) { return new Promise((resolve, reject) => { const reader = new FileReader(); reader.onload = () => { const base64String = reader.result; resolve(base64String); // Resolve the Promise with the base64 string }; reader.onerror = (error) => { reject(error); // Reject the Promise in case of an error }; reader.readAsDataURL( // This conversion is required due to browser differences and also video tag can't play certain type of formats. new File([videoFile], "video.webm", { type: "video/webm" })); }); } export function getCorrectVideoFormat(video) { if (isEmptyValue(video)) { return ""; } if (Array.isArray(video)) { return video.find((vid) => typeof vid === "string" && vid.length !== 0); } if (typeof video === "string") { return video; } return ""; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kwikid-camera-record.helper.js","sourceRoot":"","sources":["../../../../../../projects/kwikid-camera/src/lib/components/kwikid-camera-record/kwikid-camera-record.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { isEmptyValue } from \"kwikid-toolkit\";\n\n// TOOLKIT\nexport async function getDevicesList(): Promise<any> {\n  const videoDevices: any[] = [];\n\n  try {\n    // Request permission to access media devices\n    const temporaryStream = await navigator.mediaDevices.getUserMedia({\n      audio: true,\n      video: true\n    });\n\n    // Enumerate devices if permission is granted\n    await navigator.mediaDevices.enumerateDevices().then(async (devices) => {\n      for (const device of devices) {\n        if (device.kind === \"videoinput\") {\n          const constraints = {\n            video: { deviceId: { exact: device.deviceId } }\n          };\n\n          await navigator.mediaDevices\n            .getUserMedia(constraints)\n            .then((stream) => {\n              const track = stream.getVideoTracks()[0];\n              const { facingMode } = track.getSettings();\n\n              videoDevices.push({\n                deviceId: device.deviceId,\n                groupId: device.groupId,\n                kind: device.kind,\n                label: device.label,\n                facingMode\n              });\n\n              // You can now identify whether it's a front or back camera\n              // Handle your logic accordingly\n\n              stream.getTracks().forEach((track) => track.stop());\n            })\n            .catch((error) => {\n              console.error(\"Error accessing camera:\", error);\n            });\n        }\n      }\n\n      // Stop the stream after enumeration\n      temporaryStream.getTracks().forEach((track: any) => track.stop());\n    });\n\n    return videoDevices;\n  } catch (error) {\n    // Handle permission denied or other errors\n    console.info(\"Error accessing video devices:\", error);\n\n    return videoDevices; // You might want to handle this differently based on your requirements\n  }\n}\n\n// TOOLKIT\nexport async function getDevice(\n  videoDevices: any,\n  isFrontCamera: boolean\n): Promise<any> {\n  if (videoDevices.length === 0) {\n    return { deviceId: null, facingMode: null };\n  }\n  if (videoDevices.length === 1) {\n    return videoDevices[0];\n  }\n  if (videoDevices.length > 1) {\n    const frontCameraDevices = videoDevices.filter((videoDevice: any) => {\n      return videoDevice.facingMode === \"user\";\n    });\n    const backCameraDevices = videoDevices.filter((videoDevice: any) => {\n      return videoDevice.facingMode === \"environment\";\n    });\n    if (isFrontCamera) {\n      if (frontCameraDevices.length > 0) {\n        return frontCameraDevices[0];\n      }\n      return backCameraDevices[0];\n    }\n    if (!isFrontCamera) {\n      if (backCameraDevices.length > 0) {\n        return backCameraDevices[0];\n      }\n      return frontCameraDevices[0];\n    }\n  }\n\n  return { deviceId: null, facingMode: null };\n}\n\n// TOOLKIT\nexport function getBase64FromVideoFile(videoFile: File): Promise<string> {\n  return new Promise((resolve, reject) => {\n    const reader = new FileReader();\n\n    reader.onload = () => {\n      const base64String = reader.result as string;\n      resolve(base64String); // Resolve the Promise with the base64 string\n    };\n\n    reader.onerror = (error) => {\n      reject(error); // Reject the Promise in case of an error\n    };\n\n    reader.readAsDataURL(\n      // This conversion is required due to browser differences and also video tag can't play certain type of formats.\n      new File([videoFile], \"video.webm\", {\n        type: \"video/webm\"\n      })\n    );\n  });\n}\n\nexport function getCorrectVideoFormat(video: any): string {\n  if (isEmptyValue(video)) {\n    return \"\";\n  }\n\n  if (Array.isArray(video)) {\n    return video.find((vid) => typeof vid === \"string\" && vid.length !== 0);\n  }\n\n  if (typeof video === \"string\") {\n    return video;\n  }\n\n  return \"\";\n}\n"]}