export interface SafariViewControllerOptions { url?: string; hidden?: boolean; toolbarColor?: string; animated?: boolean; showDefaultShareMenuItem?: boolean; enterReaderModeIfAvailable?: boolean; tintColor?: string; transition?: string; } /** * @name SafariViewController * @description * @usage * ``` * import { SafariViewController } from 'ionic-native'; * * * SafariViewController.isAvailable() * .then( * (available: boolean) => { * if(available){ * * SafariViewController.show({ * url: 'http://ionic.io', * hidden: false, * animated: false, * transition: 'curl', * enterReaderModeIfAvailable: true, * tintColor: '#ff0000' * }) * .then( * (result: any) => { * if(result.event === 'opened') console.log('Opened'); * else if(result.event === 'loaded') console.log('Loaded'); * else if(result.event === 'closed') console.log('Closed'); * }, * (error: any) => console.error(error) * ); * * } else { * // use fallback browser, example InAppBrowser * } * } * ); * ``` * @interfaces * SafariViewControllerOptions */ export declare class SafariViewController { /** * Checks if SafariViewController is available * @returns {Promise} */ static isAvailable(): Promise; /** * Shows Safari View Controller * @param options {SafariViewControllerOptions} optional * @returns {Promise} */ static show(options?: SafariViewControllerOptions): Promise; /** * Hides Safari View Controller */ static hide(): Promise; /** * Tries to connect to the Chrome's custom tabs service. you must call this method before calling any of the other methods listed below. * @returns {Promise} */ static connectToService(): Promise; /** * Call this method whenever there's a chance the user will open an external url. * @returns {Promise} */ static warmUp(): Promise; /** * For even better performance optimization, call this methods if there's more than a 50% chance the user will open a certain URL. * @param url{string} * @returns {Promise} */ static mayLaunchUrl(url: string): Promise; }