Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to create toast in phonegap?

How to create toast in android application using phonegap / cordova?

Thanx!

like image 348
Pradip Kharbuja Avatar asked Feb 06 '13 07:02

Pradip Kharbuja


3 Answers

PhoneGap-Toast is an open source (MIT-Licensed) bridge for PhoneGap that allows you to do this.

like image 28
smw Avatar answered Oct 28 '22 19:10

smw


First create a ToastPlugin.java

package com.company.plugins;

import org.apache.cordova.api.CallbackContext;
import org.apache.cordova.api.CordovaPlugin;
import org.json.JSONArray;
import org.json.JSONException;

import android.util.Log;
import android.widget.Toast;

public class ToastPlugin extends CordovaPlugin {
    @Override
    public boolean execute(String action, JSONArray args,
            CallbackContext callbackContext) throws JSONException {

        String message = args.getString(0);

        // used to log the text and can be seen in LogCat
        Log.d("Toast Plugin", "Calling the Toast...");
        Log.d("Toast Plugin", message);

        if (action.equals("shortToast")) {          
            this.shortToast(message, callbackContext);
            return true;
        } else if (action.equals("longToast")) {
            this.longToast(message, callbackContext);
            return true;
        }
        return false;
    }

    private void shortToast(String message, CallbackContext callbackContext) {
        if (message != null && message.length() > 0) {
            Toast.makeText(cordova.getActivity().getApplicationContext(),
                    message, Toast.LENGTH_SHORT).show();
            callbackContext.success(message);
        } else {
            callbackContext.error("Expected one non-empty string argument.");
        }
    }

    private void longToast(String message, CallbackContext callbackContext) {
        if (message != null && message.length() > 0) {
            Toast.makeText(cordova.getActivity().getApplicationContext(),
                    message, Toast.LENGTH_LONG).show();
            callbackContext.success(message);
        } else {
            callbackContext.error("Expected one non-empty string argument.");
        }
    }
}


Then create a toastPlugin.js

//Plugin file should be always after cordova.js
//There is always better way to create, but this also works

window.shortToast = function(str, callback) {   
    cordova.exec(callback, function(err) {
        callback('Nothing to echo.');
    }, "ToastPlugin", "shortToast", [ str ]);
};

window.longToast = function(str, callback) {
    cordova.exec(callback, function(err) {
        callback('Nothing to echo.');
    }, "ToastPlugin", "longToast", [ str ]);
};


Link these files in your project, now you can call in JavaScript as :

  • shortToast("Short Toast Message Here...");
  • longToast("Long Toast Message Here...");
like image 155
Pradip Kharbuja Avatar answered Oct 28 '22 19:10

Pradip Kharbuja


Looking for a universal iOS/Android/WP8 Toast plugin, checkout this one: http://www.x-services.nl/phonegap-toast-plugin/796

like image 26
Eddy Verbruggen Avatar answered Oct 28 '22 19:10

Eddy Verbruggen