UNPKG

ionic-native

Version:

Native plugin wrappers for Cordova and Ionic with TypeScript, ES6+, Promise and Observable support

139 lines (138 loc) 5.35 kB
/** * @name Social Sharing * @description * Share text, files, images, and links via social networks, sms, and email. * @usage * ```typescript * import { SocialSharing } from 'ionic-native'; * * // Check if sharing via email is supported * SocialSharing.canShareViaEmail().then(() => { * // Sharing via email is possible * }).catch(() => { * // Sharing via email is not possible * }); * * // Share via email * SocialSharing.shareViaEmail('Body', 'Subject', 'recipient@example.org').then(() => { * // Success! * }).catch(() => { * // Error! * }); * ``` */ export declare class SocialSharing { /** * Shares using the share sheet * @param message {string} The message you would like to share. * @param subject {string} The subject * @param file {string|string[]} URL(s) to file(s) or image(s), local path(s) to file(s) or image(s), or base64 data of an image. Only the first file/image will be used on Windows Phone. * @param url {string} A URL to share * @returns {Promise<any>} */ static share(message?: string, subject?: string, file?: string | string[], url?: string): Promise<any>; /** * Shares using the share sheet with additional options and returns a result object or an error message (requires plugin version 5.1.0+) * @param options {object} The options object with the message, subject, files, url and chooserTitle properties. * @returns {Promise<any>} */ static shareWithOptions(options: { message?: string; subject?: string; files?: string | string[]; url?: string; chooserTitle?: string; }): Promise<any>; /** * Checks if you can share via a specific app. * @param appName {string} App name or package name. Examples: instagram or com.apple.social.facebook * @param message {string} * @param subject {string} * @param image {string} * @param url {string} * @returns {Promise<any>} */ static canShareVia(appName: string, message?: string, subject?: string, image?: string, url?: string): Promise<any>; /** * Shares directly to Twitter * @param message {string} * @param image {string} * @param url {string} * @returns {Promise<any>} */ static shareViaTwitter(message: string, image?: string, url?: string): Promise<any>; /** * Shares directly to Facebook * @param message {string} * @param image {string} * @param url {string} * @returns {Promise<any>} */ static shareViaFacebook(message: string, image?: string, url?: string): Promise<any>; /** * Shares directly to Facebook with a paste message hint * @param message {string} * @param image {string} * @param url {string} * @param pasteMessageHint {string} * @returns {Promise<any>} */ static shareViaFacebookWithPasteMessageHint(message: string, image?: string, url?: string, pasteMessageHint?: string): Promise<any>; /** * Shares directly to Instagram * @param message {string} * @param image {string} * @returns {Promise<any>} */ static shareViaInstagram(message: string, image: string): Promise<any>; /** * Shares directly to WhatsApp * @param message {string} * @param image {string} * @param url {string} * @returns {Promise<any>} */ static shareViaWhatsApp(message: string, image?: string, url?: string): Promise<any>; /** * Shares directly to a WhatsApp Contact * @param receiver {string} Pass phone number on Android, and Addressbook ID (abid) on iOS * @param message {string} Message to send * @param image {string} Image to send (does not work on iOS * @param url {string} Link to send * @returns {Promise<any>} */ static shareViaWhatsAppToReceiver(receiver: string, message: string, image?: string, url?: string): Promise<any>; /** * Share via SMS * @param messge {string} message to send * @param phoneNumber {string} Number or multiple numbers seperated by commas * @returns {Promise<any>} */ static shareViaSMS(messge: string, phoneNumber: string): Promise<any>; /** * Checks if you can share via email * @returns {Promise<any>} */ static canShareViaEmail(): Promise<any>; /** * Share via Email * @param message {string} * @param subject {string} * @param to {string[]} * @param cc {string[]} Optional * @param bcc {string[]} Optional * @param files {string|string[]} Optional URL or local path to file(s) to attach * @returns {Promise<any>} */ static shareViaEmail(message: string, subject: string, to: string[], cc?: string[], bcc?: string[], files?: string | string[]): Promise<any>; /** * Share via AppName * @param appName {string} App name or package name. Examples: instagram or com.apple.social.facebook * @param message {string} * @param subject {string} * @param image {string} * @param url {string} * @returns {Promise<any>} */ static shareVia(appName: string, message: string, subject?: string, image?: string, url?: string): Promise<any>; }