// Type definitions for uk.co.workingedge.phonegap.plugin.launchnavigator@5 // Project: https://github.com/dpa99c/phonegap-launch-navigator // Definitions by: Dave Alden // Usage: import { LaunchNavigator, LaunchNavigatorOptions, PromptsOptions, RememberChoiceOptions, AppSelectionOptions, UserChoice, UserPrompted, AppSelection } from 'react-native-launch-navigator'; export as namespace launchnavigator; export interface PromptsOptions { /** * a function to pass the user's decision whether to remember their choice of app. * This will be passed a single boolean value indicating the user's decision. * @param rememberChoice */ callback?: (rememberChoice: boolean) => void; /** * text to display in the native prompt header asking user whether to remember their choice. * Defaults to "Remember your choice?" if not specified. */ headerText?: string; /** * text to display in the native prompt body asking user whether to remember their choice. * Defaults to "Use the same app for navigating next time?" if not specified. */ bodyText?: string; /** * text to display for the Yes button. * Defaults to "Yes" if not specified. */ yesButtonText?: string; /** * text to display for the No button. * Defaults to "No" if not specified. */ noButtonText?: string; } export interface RememberChoiceOptions { /** * whether to remember user choice of app for next time, instead of asking again for user choice. * `"prompt"` - Prompt user to decide whether to remember choice. * - Default value if unspecified. * - If `promptFn` is defined, this will be used for user confirmation. * - Otherwise (by default), a native dialog will be displayed to ask user. * `false` - Do not remember user choice. * `true` - Remember user choice. */ enabled?:boolean|string; /** * a function which asks the user whether to remember their choice of app. * If this is defined, then the default dialog prompt will not be shown, allowing for a custom UI for asking the user. * This will be passed a callback function which should be invoked with a single boolean argument which indicates the user's decision to remember their choice. * @param callback */ promptFn?: (callback: (rememberChoice: boolean) => void) => void; /** * options related to the default dialog prompt used to ask the user whether to remember their choice of app. */ prompt?: PromptsOptions } export interface AppSelectionOptions { /** * text to display in the native picker which enables user to select which navigation app to launch. * Defaults to "Select app for navigation" if not specified. */ dialogHeaderText?: string; /** * text to display for the cancel button in the native picker which enables user to select which navigation app to launch. * Defaults to "Cancel" if not specified. */ cancelButtonText?: string; /** * List of apps, defined as `launchnavigator.APP` constants, which should be displayed in the picker if the app is available. * This can be used to restrict which apps are displayed, even if they are installed. * By default, all available apps will be displayed. */ list?: string[]; /** * Callback to invoke when the user selects an app in the native picker. * A single string argument is passed which is the app what was selected defined as a `launchnavigator.APP` constant. */ callback?: (app: string) => void; /** * (Android only) native picker theme. Specify using `actionsheet.ANDROID_THEMES` constants. * Default `actionsheet.ANDROID_THEMES.THEME_HOLO_LIGHT` */ androidTheme?: number; /** * options related to whether to remember user choice of app for next time, instead of asking again for user choice. */ rememberChoice?: RememberChoiceOptions; } export interface LaunchNavigatorOptions { /** * A callback to invoke when the navigation app is successfully launched. */ successCallback?: Function; /** * A callback to invoke if an error is encountered while launching the app. * A single string argument containing the error message will be passed in. */ errorCallback?: (error: string) => void; /** * name of the navigation app to use for directions. * Specify using launchnavigator.APP constants. * e.g. `launchnavigator.APP.GOOGLE_MAPS`. * If not specified, defaults to User Selection. */ app?: string; /** * nickname to display in app for destination. e.g. "Bob's House". */ destinationName?: string; /** * Start point of the navigation. * If not specified, the current device location will be used. * Either: * - a {string} containing the address. e.g. "Buckingham Palace, London" * - a {string} containing a latitude/longitude coordinate. e.g. "50.1. -4.0" * - an {array}, where the first element is the latitude and the second element is a longitude, as decimal numbers. e.g. [50.1, -4.0] */ start?: string | number[]; /** * nickname to display in app for start . e.g. "My House". */ startName?: string; /** * Transportation mode for navigation: "driving", "walking" or "transit". Defaults to "driving" if not specified. */ transportMode?: string; /** * a key/value map of extra app-specific parameters. For example, to tell Google Maps on Android to display Satellite view in "maps" launch mode: `{"t": "k"}` */ extras?: any; /** * (Android only) mode in which to open Google Maps app. * `launchnavigator.LAUNCH_MODE.MAPS` or `launchnavigator.LAUNCH_MODE.TURN_BY_TURN` * Defaults to `launchnavigator.LAUNCH_MODE.MAPS` if not specified. */ launchModeGoogleMaps?: string; /** * (iOS only) method to use to open Apple Maps app. * `launchnavigator.LAUNCH_MODE.URI_SCHEME` or `launchnavigator.LAUNCH_MODE.MAPKIT` * Defaults to `launchnavigator.LAUNCH_MODE.URI_SCHEME` if not specified. */ launchModeAppleMaps?: string; /** * (Windows only) If false, the plugin will NOT attempt to use the geolocation plugin to determine the current device position when the start location parameter is omitted. Defaults to true. */ enableGeolocation?: boolean; /** * (Android and iOS only) If true, and input location type(s) doesn't match those required by the app, use geocoding to obtain the address/coords as required. Defaults to true. */ enableGeocoding?: boolean; /** * options related to the default native actionsheet picker which enables user to select which navigation app to launch if `app` is not specified. */ appSelection?: AppSelectionOptions; } export interface UserChoice{ /** * Indicates whether a user choice exists for a preferred navigator app. * @param callback - function to pass result to: will receive a boolean argument. */ exists: (callback: (exists: boolean) => void) => void; /** * Returns current user choice of preferred navigator app. * @param callback - function to pass result to: will receive a string argument indicating the app, which is a constant in `launchnavigator.APP`. */ get: (callback: (app: string) => void) => void; /** * Sets the current user choice of preferred navigator app. * @param app - app to set as preferred choice as a constant in `launchnavigator.APP`. * @param callback - function to call once operation is complete. */ set: (app: string, callback: () => void) => void; /** * Clears the current user choice of preferred navigator app. * @param callback - function to call once operation is complete. */ clear: (callback: () => void) => void; } export interface UserPrompted{ /** * Indicates whether user has already been prompted whether to remember their choice a preferred navigator app. * @param callback - function to pass result to: will receive a boolean argument. */ get: (callback: (exists: boolean) => void) => void; /** * Sets flag indicating user has already been prompted whether to remember their choice a preferred navigator app. * @param callback - function to call once operation is complete. */ set: ( callback: () => void) => void; /** * Clears flag which indicates if user has already been prompted whether to remember their choice a preferred navigator app. * @param callback - function to call once operation is complete. */ clear: ( callback: () => void) => void; } export interface AppSelection{ userChoice: UserChoice; userPrompted: UserPrompted; } export interface LaunchNavigator { /** * Supported platforms */ PLATFORM: any; /** * string constants, used to identify apps in native code */ APP: any; /** * All possible transport modes */ TRANSPORT_MODE: any; /** * Launch modes supported by Google Maps on Android */ LAUNCH_MODE: any; /** * Enables debug log output from the plugin to the JS and native consoles. By default debug is disabled. * @param enabled {boolean} */ enableDebug: ( enabled: boolean, successCallback: (success: any) => void, errorCallback?: (error: string) => void ) => void; /** * Launches navigator app * @param destination {string|number[]} Location name or coordinates (as string or array) * Either: * - a {string} containing the address. e.g. "Buckingham Palace, London" * - a {string} containing a latitude/longitude coordinate. e.g. "50.1. -4.0" * - an {array}, where the first element is the latitude and the second element is a longitude, as decimal numbers. e.g. [50.1, -4.0] * @param options {LaunchNavigatorOptions} * @returns {Promise} */ navigate: ( destination: string | number[], options?: LaunchNavigatorOptions ) => void; logEvent: (name: string, params?: any, valueToSum?: number) => void; /** * Determines if the given app is installed and available on the current device. * @param app {string} */ isAppAvailable: ( app: string, successCallback: (isAvailable: boolean) => void, errorCallback?: (error: string) => void ) => void; /** * Returns a list indicating which apps are installed and available on the current device. * @return string[] */ availableApps: ( successCallback: (apps: any ) => void, errorCallback?: (error: string) => void ) => void; /** * Returns the display name of the specified app. * @param {string} app - specified as a constant in `launchnavigator.APP`. e.g. `launchnavigator.APP.GOOGLE_MAPS`. * @return {string} - app display name. e.g. "Google Maps". */ getAppDisplayName: (app: string) => string; /** * Returns list of supported apps on a given platform. * @param {string} platform - specified as a constant in `launchnavigator.PLATFORM`. e.g. `launchnavigator.PLATFORM.IOS`. * @return {array} - apps supported on specified platform as a list of `launchnavigator.APP` constants. */ getAppsForPlatform: (platform: string) => string[]; /** * Indicates if an app on a given platform supports specification of transport mode. * @param {string} app - specified as a constant in `launchnavigator.APP`. e.g. `launchnavigator.APP.GOOGLE_MAPS`. * @param {string} platform - specified as a constant in `launchnavigator.PLATFORM`. e.g. `launchnavigator.PLATFORM.IOS`. * @return {boolean} - true if app/platform combination supports specification of transport mode. */ supportsTransportMode: ( app: string, platform: string ) => boolean; /** * Returns the list of transport modes supported by an app on a given platform. * @param {string} app - specified as a constant in `launchnavigator.APP`. e.g. `launchnavigator.APP.GOOGLE_MAPS`. * @param {string} platform - specified as a constant in `launchnavigator.PLATFORM`. e.g. `launchnavigator.PLATFORM.IOS`. * @return {array} - list of transports modes as constants in `launchnavigator.TRANSPORT_MODE`. * If app/platform combination doesn't support specification of transport mode, the list will be empty; */ getTransportModes: ( app: string, platform: string ) => string[]; /** * Indicates if an app on a given platform supports specification of launch mode. * Note that currently only Google Maps on Android does. * @param {string} app - specified as a constant in `launchnavigator.APP`. e.g. `launchnavigator.APP.GOOGLE_MAPS`. * @param {string} platform - specified as a constant in `launchnavigator.PLATFORM`. e.g. `launchnavigator.PLATFORM.ANDROID`. * @return {boolean} - true if app/platform combination supports specification of transport mode. */ supportsLaunchMode: ( app: string, platform: string ) => boolean; /** * Indicates if an app on a given platform supports specification of start location. * @param {string} app - specified as a constant in `launchnavigator.APP`. e.g. `launchnavigator.APP.GOOGLE_MAPS`. * @param {string} platform - specified as a constant in `launchnavigator.PLATFORM`. e.g. `launchnavigator.PLATFORM.IOS`. * @return {boolean} - true if app/platform combination supports specification of start location. */ supportsStart: ( app: string, platform: string ) => boolean; /** * Indicates if an app on a given platform supports specification of a custom nickname for start location. * @param {string} app - specified as a constant in `launchnavigator.APP`. e.g. `launchnavigator.APP.GOOGLE_MAPS`. * @param {string} platform - specified as a constant in `launchnavigator.PLATFORM`. e.g. `launchnavigator.PLATFORM.IOS`. * @return {boolean} - true if app/platform combination supports specification of start location. */ supportsStartName: ( app: string, platform: string ) => boolean; /** * Indicates if an app on a given platform supports specification of a custom nickname for destination location. * @param {string} app - specified as a constant in `launchnavigator.APP`. e.g. `launchnavigator.APP.GOOGLE_MAPS`. * @param {string} platform - specified as a constant in `launchnavigator.PLATFORM`. e.g. `launchnavigator.PLATFORM.IOS`. * @return {boolean} - true if app/platform combination supports specification of destination location. */ supportsDestName: ( app: string, platform: string ) => boolean; /** * Triggers the native dialog picker for user to choose wich app to use. * @param {string/number[]} destination (required) - destination location to use for navigation - see launchnavigator.navigate() * @param {object} options (optional) - optional parameters - see launchnavigator.navigate() * @param {Function} successCallback (optional) - optional callback to be invoked on success * @param {Function} errorCallback (optional) - optional callback to be invoked on error */ userSelect: ( destination: string | number[], options: LaunchNavigatorOptions ) => void; appSelection: AppSelection; } declare var launchnavigator: LaunchNavigator;