var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { if (typeof b !== "function" && b !== null) throw new TypeError("Class extends value " + String(b) + " is not a constructor or null"); extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); import { AwesomeCordovaNativePlugin, cordova, cordovaPropertyGet, cordovaPropertySet } from '@awesome-cordova-plugins/core'; import { Observable } from 'rxjs'; var MediaCaptureOriginal = /** @class */ (function (_super) { __extends(MediaCaptureOriginal, _super); function MediaCaptureOriginal() { return _super !== null && _super.apply(this, arguments) || this; } MediaCaptureOriginal.prototype.captureAudio = function (options) { return cordova(this, "captureAudio", { "callbackOrder": "reverse" }, arguments); }; MediaCaptureOriginal.prototype.captureImage = function (options) { return cordova(this, "captureImage", { "callbackOrder": "reverse" }, arguments); }; MediaCaptureOriginal.prototype.captureVideo = function (options) { return cordova(this, "captureVideo", { "callbackOrder": "reverse" }, arguments); }; MediaCaptureOriginal.prototype.onPendingCaptureResult = function () { return cordova(this, "onPendingCaptureResult", { "eventObservable": true, "event": "pendingcaptureresult" }, arguments); }; MediaCaptureOriginal.prototype.onPendingCaptureError = function () { return cordova(this, "onPendingCaptureError", { "eventObservable": true, "event": "pendingcaptureerror" }, arguments); }; Object.defineProperty(MediaCaptureOriginal.prototype, "supportedImageModes", { get: function () { return cordovaPropertyGet(this, "supportedImageModes"); }, set: function (value) { cordovaPropertySet(this, "supportedImageModes", value); }, enumerable: false, configurable: true }); Object.defineProperty(MediaCaptureOriginal.prototype, "supportedAudioModes", { get: function () { return cordovaPropertyGet(this, "supportedAudioModes"); }, set: function (value) { cordovaPropertySet(this, "supportedAudioModes", value); }, enumerable: false, configurable: true }); Object.defineProperty(MediaCaptureOriginal.prototype, "supportedVideoModes", { get: function () { return cordovaPropertyGet(this, "supportedVideoModes"); }, set: function (value) { cordovaPropertySet(this, "supportedVideoModes", value); }, enumerable: false, configurable: true }); MediaCaptureOriginal.pluginName = "MediaCapture"; MediaCaptureOriginal.plugin = "cordova-plugin-media-capture"; MediaCaptureOriginal.pluginRef = "navigator.device.capture"; MediaCaptureOriginal.repo = "https://github.com/apache/cordova-plugin-media-capture"; MediaCaptureOriginal.platforms = ["Android", "Browser", "iOS", "Windows"]; return MediaCaptureOriginal; }(AwesomeCordovaNativePlugin)); var MediaCapture = new MediaCaptureOriginal(); export { MediaCapture }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/@awesome-cordova-plugins/plugins/media-capture/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,OAAO,+EAAgE,MAAM,+BAA+B,CAAC;AAC7G,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;;IA2JA,gCAA0B;;;;IAkC1D,mCAAY,aAAC,OAA6B;IAa1C,mCAAY,aAAC,OAA6B;IAa1C,mCAAY,aAAC,OAA6B;IAa1C,6CAAsB;IAatB,4CAAqB;0BA/ErB,6CAAmB;;;;;;0BAQnB,6CAAmB;;;;;;0BAQnB,6CAAmB;;;;;;;;;;;uBApLrB;EA6JkC,0BAA0B;SAA/C,YAAY","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Cordova, CordovaProperty, AwesomeCordovaNativePlugin, Plugin } from '@awesome-cordova-plugins/core';\nimport { Observable } from 'rxjs';\n\ndeclare const navigator: any;\n\nexport interface MediaFile {\n  /**\n   * The name of the file, without path information.\n   */\n  name: string;\n  /**\n   * The full path of the file, including the name.\n   */\n  fullPath: string;\n  /**\n   * The file's mime type\n   */\n  type: string;\n\n  /**\n   * The date and time when the file was last modified.\n   */\n  lastModifiedDate: Date;\n\n  /**\n   * The size of the file, in bytes.\n   */\n  size: number;\n\n  /**\n   * Retrieves the format information of the media file.\n   *\n   * @param {Function} successCallback\n   * @param {Function} errorCallback\n   */\n  getFormatData(successCallback: (data: MediaFileData) => any, errorCallback?: (err: any) => any): void;\n}\n\nexport interface MediaFileData {\n  /**\n   * The actual format of the audio and video content.\n   */\n  codecs: string;\n  /**\n   * The average bitrate of the content. The value is zero for images.\n   */\n  bitrate: number;\n  /**\n   * The height of the image or video in pixels. The value is zero for audio clips.\n   */\n  height: number;\n  /**\n   * The width of the image or video in pixels. The value is zero for audio clips.\n   */\n  width: number;\n  /**\n   * The length of the video or sound clip in seconds. The value is zero for images.\n   */\n  duration: number;\n}\n\nexport interface CaptureError {\n  code: string;\n}\n\nexport interface CaptureAudioOptions {\n  /**\n   * Maximum number of audio clips. Defaults to 1.\n   * On iOS you can only record one file.\n   */\n  limit?: number;\n  /**\n   * Maximum duration of an audio sound clip, in seconds. This does not work on Android devices.\n   */\n  duration?: number;\n}\n\nexport interface CaptureImageOptions {\n  /**\n   * Maximum number of images to capture. This limit is not supported on iOS, only one image will be taken per invocation.\n   */\n  limit?: number;\n}\n\nexport interface CaptureVideoOptions {\n  /**\n   * Maximum number of video clips to record. This value is ignored on iOS, only one video clip can be taken per invocation.\n   */\n  limit?: number;\n  /**\n   * Maximum duration per video clip. This will be ignored on BlackBerry.\n   */\n  duration?: number;\n  /**\n   * Quality of the video. This parameter can only be used with Android.\n   */\n  quality?: number;\n}\n\nexport interface ConfigurationData {\n  /**\n   * The ASCII-encoded lowercase string representing the media type.\n   */\n  type: string;\n  /**\n   * The height of the image or video in pixels. The value is zero for sound clips.\n   */\n  height: number;\n  /**\n   * The width of the image or video in pixels. The value is zero for sound clips.\n   */\n  width: number;\n}\n\n/**\n * @name Media Capture\n * @premier media-capture\n * @description\n * This plugin provides access to the device's audio, image, and video capture capabilities.\n *\n * Requires Cordova plugin: `cordova-plugin-media-capture`. For more info, please see the [Media Capture plugin docs](https://github.com/apache/cordova-plugin-media-capture).\n * @usage\n * ```typescript\n * import { MediaCapture, MediaFile, CaptureError, CaptureImageOptions } from '@awesome-cordova-plugins/media-capture/ngx';\n *\n *\n * constructor(private mediaCapture: MediaCapture) { }\n *\n * ...\n *\n *\n * let options: CaptureImageOptions = { limit: 3 }\n * this.mediaCapture.captureImage(options)\n *   .then(\n *     (data: MediaFile[]) => console.log(data),\n *     (err: CaptureError) => console.error(err)\n *   );\n *\n * ```\n * @interfaces\n * MediaFile\n * MediaFileData\n * CaptureError\n * CaptureAudioOptions\n * CaptureImageOptions\n * CaptureVideoOptions\n * ConfigurationData\n */\n@Plugin({\n  pluginName: 'MediaCapture',\n  plugin: 'cordova-plugin-media-capture',\n  pluginRef: 'navigator.device.capture',\n  repo: 'https://github.com/apache/cordova-plugin-media-capture',\n  platforms: ['Android', 'Browser', 'iOS', 'Windows'],\n})\n@Injectable()\nexport class MediaCapture extends AwesomeCordovaNativePlugin {\n  /**\n   * The recording image sizes and formats supported by the device.\n   *\n   * @returns {ConfigurationData[]}\n   */\n  @CordovaProperty()\n  supportedImageModes: ConfigurationData[];\n\n  /**\n   * The audio recording formats supported by the device.\n   *\n   * @returns {ConfigurationData[]}\n   */\n  @CordovaProperty()\n  supportedAudioModes: ConfigurationData[];\n\n  /**\n   * The recording video resolutions and formats supported by the device.\n   *\n   * @returns {ConfigurationData[]}\n   */\n  @CordovaProperty()\n  supportedVideoModes: ConfigurationData[];\n\n  /**\n   * Start the audio recorder application and return information about captured audio clip files.\n   *\n   * @param options\n   * @returns {Promise<MediaFile[]>}\n   */\n  @Cordova({\n    callbackOrder: 'reverse',\n  })\n  captureAudio(options?: CaptureAudioOptions): Promise<MediaFile[] | CaptureError> {\n    return;\n  }\n\n  /**\n   * Start the camera application and return information about captured image files.\n   *\n   * @param options\n   * @returns {Promise<MediaFile[]>}\n   */\n  @Cordova({\n    callbackOrder: 'reverse',\n  })\n  captureImage(options?: CaptureImageOptions): Promise<MediaFile[] | CaptureError> {\n    return;\n  }\n\n  /**\n   * Start the video recorder application and return information about captured video clip files.\n   *\n   * @param options\n   * @returns {Promise<MediaFile[]>}\n   */\n  @Cordova({\n    callbackOrder: 'reverse',\n  })\n  captureVideo(options?: CaptureVideoOptions): Promise<MediaFile[] | CaptureError> {\n    return;\n  }\n\n  /**\n   * is fired if the capture call is successful\n   *\n   * @returns {Observable<MediaFile[]>}\n   */\n  @Cordova({\n    eventObservable: true,\n    event: 'pendingcaptureresult',\n  })\n  onPendingCaptureResult(): Observable<MediaFile[]> {\n    return;\n  }\n\n  /**\n   * is fired if the capture call is unsuccessful\n   *\n   * @returns {Observable<CaptureError>}\n   */\n  @Cordova({\n    eventObservable: true,\n    event: 'pendingcaptureerror',\n  })\n  onPendingCaptureError(): Observable<CaptureError> {\n    return;\n  }\n}\n"]}