From a3ba0015eda437fe60e8f05852447c92cff8f31c Mon Sep 17 00:00:00 2001 From: Maxim Belov Date: Wed, 17 Apr 2024 12:27:17 +0300 Subject: [PATCH] feat(screenshot): add plugin (#4751) --- .../plugins/screenshot/index.ts | 78 +++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 src/@awesome-cordova-plugins/plugins/screenshot/index.ts diff --git a/src/@awesome-cordova-plugins/plugins/screenshot/index.ts b/src/@awesome-cordova-plugins/plugins/screenshot/index.ts new file mode 100644 index 000000000..b6a1b2e83 --- /dev/null +++ b/src/@awesome-cordova-plugins/plugins/screenshot/index.ts @@ -0,0 +1,78 @@ +import { Injectable } from '@angular/core'; +import { AwesomeCordovaNativePlugin, Plugin, getPromise } from '@awesome-cordova-plugins/core'; + +declare const navigator: any; + +/** + * @name Screenshot + * @description Captures a screen shot + * @usage + * ```typescript + * import { Screenshot } from '@ionic-native/screenshot/ngx'; + * + * constructor(private screenshot: Screenshot) { } + * + * ... + * + * // Take a screenshot and save to file + * this.screenshot.save('jpg', 80, 'myscreenshot.jpg').then(onSuccess, onError); + * + * // Take a screenshot and get temporary file URI + * this.screenshot.URI(80).then(onSuccess, onError); + * ``` + */ +@Plugin({ + pluginName: 'Screenshot', + plugin: '@herdwatch-apps/cordova-plugin-screenshot', + pluginRef: 'navigator.screenshot', + repo: 'https://github.com/herdwatch-apps/cordova-plugin-screenshot', + platforms: ['Android', 'iOS'], +}) +@Injectable() +export class Screenshot extends AwesomeCordovaNativePlugin { + /** + * Takes screenshot and saves the image + * + * @param format {string} Format can take the value of either 'jpg' or 'png' + * On ios, only 'jpg' format is supported + * @param quality {number} Determines the quality of the screenshot. + * Default quality is set to 100. + * @param filename {string} Name of the file as stored on the storage + * @returns {Promise} + */ + save(format?: string, quality?: number, filename?: string): Promise { + return getPromise((resolve, reject) => { + navigator.screenshot.save( + (error: any, result: any) => { + if (error) { + reject(error); + } else { + resolve(result); + } + }, + format, + quality, + filename + ); + }); + } + + /** + * Takes screenshot and returns the image as an URI + * + * @param quality {number} Determines the quality of the screenshot. + * Default quality is set to 100. + * @returns {Promise} + */ + URI(quality?: number): Promise { + return getPromise((resolve, reject) => { + navigator.screenshot.URI((error: any, result: any) => { + if (error) { + reject(error); + } else { + resolve(result); + } + }, quality); + }); + } +}