mirror of
https://github.com/EddyVerbruggen/Toast-PhoneGap-Plugin.git
synced 2025-02-24 10:12:53 +08:00
upstream update
This commit is contained in:
commit
cabeea18ed
31
README.md
31
README.md
@ -151,7 +151,7 @@ You can copy-paste these lines of code for a quick test:
|
|||||||
Since 2.1.0 you can add pixels to move the toast up or down.
|
Since 2.1.0 you can add pixels to move the toast up or down.
|
||||||
Note that `showWithOptions` can be used instead of the functions above, but it's not useful unless you want to pass `addPixelsY`.
|
Note that `showWithOptions` can be used instead of the functions above, but it's not useful unless you want to pass `addPixelsY`.
|
||||||
```js
|
```js
|
||||||
function showTop() {
|
function showBottom() {
|
||||||
window.plugins.toast.showWithOptions(
|
window.plugins.toast.showWithOptions(
|
||||||
{
|
{
|
||||||
message: "hey there",
|
message: "hey there",
|
||||||
@ -174,6 +174,33 @@ function hide() {
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Receiving a callback when a Toast is tapped
|
||||||
|
On iOS and Android the success handler of your `show` function will be notified (again) when the toast was tapped.
|
||||||
|
|
||||||
|
So the first time the success handler fires is when the toast is shown, and in case the user taps the toast it will be
|
||||||
|
called again. You can distinguish between those events of course:
|
||||||
|
|
||||||
|
```js
|
||||||
|
window.plugins.toast.showWithOptions(
|
||||||
|
{
|
||||||
|
message: "hey there",
|
||||||
|
duration: "short",
|
||||||
|
position: "bottom",
|
||||||
|
addPixelsY: -40 // added a negative value to move it up a bit (default 0)
|
||||||
|
},
|
||||||
|
// implement the success callback
|
||||||
|
function(result) {
|
||||||
|
if (result && result.event) {
|
||||||
|
console.log("The toast was tapped");
|
||||||
|
console.log("Event: " + result.event); // will be defined, with a value of "touch" when it was tapped by the user
|
||||||
|
console.log("Message: " + result.message); // will be equal to the message you passed in
|
||||||
|
} else {
|
||||||
|
console.log("The toast has been shown");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
```
|
||||||
|
|
||||||
### WP8 quirks
|
### WP8 quirks
|
||||||
The WP8 implementation needs a little more work, but it's perfectly useable when you keep this in mind:
|
The WP8 implementation needs a little more work, but it's perfectly useable when you keep this in mind:
|
||||||
* You can't show two Toasts simultaneously.
|
* You can't show two Toasts simultaneously.
|
||||||
@ -188,6 +215,8 @@ The Android code was entirely created by me.
|
|||||||
For iOS most credits go to this excellent [Toast for iOS project by Charles Scalesse] (https://github.com/scalessec/Toast).
|
For iOS most credits go to this excellent [Toast for iOS project by Charles Scalesse] (https://github.com/scalessec/Toast).
|
||||||
|
|
||||||
## 6. CHANGELOG
|
## 6. CHANGELOG
|
||||||
|
2.3.0: The plugin will now report back to JS if Toasts were tapped by the user.
|
||||||
|
|
||||||
2.0.1: iOS messages are hidden when another one is shown. [Thanks Richie Min!](https://github.com/EddyVerbruggen/Toast-PhoneGap-Plugin/pull/13)
|
2.0.1: iOS messages are hidden when another one is shown. [Thanks Richie Min!](https://github.com/EddyVerbruggen/Toast-PhoneGap-Plugin/pull/13)
|
||||||
|
|
||||||
2.0: WP8 support
|
2.0: WP8 support
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "cordova-plugin-x-toast",
|
"name": "cordova-plugin-x-toast",
|
||||||
"version": "2.2.1",
|
"version": "2.3.0",
|
||||||
"description": "This plugin allows you to show a Toast. A Toast is a little non intrusive buttonless popup which automatically disappears.",
|
"description": "This plugin allows you to show a Toast. A Toast is a little non intrusive buttonless popup which automatically disappears.",
|
||||||
"cordova": {
|
"cordova": {
|
||||||
"id": "cordova-plugin-x-toast",
|
"id": "cordova-plugin-x-toast",
|
||||||
|
@ -1,8 +1,13 @@
|
|||||||
package nl.xservices.plugins;
|
package nl.xservices.plugins;
|
||||||
|
|
||||||
|
import android.os.Build;
|
||||||
import android.view.Gravity;
|
import android.view.Gravity;
|
||||||
|
import android.view.MotionEvent;
|
||||||
|
import android.view.View;
|
||||||
|
|
||||||
import org.apache.cordova.CallbackContext;
|
import org.apache.cordova.CallbackContext;
|
||||||
import org.apache.cordova.CordovaPlugin;
|
import org.apache.cordova.CordovaPlugin;
|
||||||
|
import org.apache.cordova.PluginResult;
|
||||||
import org.json.JSONArray;
|
import org.json.JSONArray;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
@ -24,6 +29,8 @@ public class Toast extends CordovaPlugin {
|
|||||||
|
|
||||||
private android.widget.Toast mostRecentToast;
|
private android.widget.Toast mostRecentToast;
|
||||||
|
|
||||||
|
private static final boolean IS_AT_LEAST_ANDROID5 = Build.VERSION.SDK_INT >= 21;
|
||||||
|
|
||||||
// note that webView.isPaused() is not Xwalk compatible, so tracking it poor-man style
|
// note that webView.isPaused() is not Xwalk compatible, so tracking it poor-man style
|
||||||
private boolean isPaused;
|
private boolean isPaused;
|
||||||
|
|
||||||
@ -52,10 +59,16 @@ public class Toast extends CordovaPlugin {
|
|||||||
cordova.getActivity().runOnUiThread(new Runnable() {
|
cordova.getActivity().runOnUiThread(new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
android.widget.Toast toast = android.widget.Toast.makeText(
|
android.widget.Toast toast = android.widget.Toast.makeText(
|
||||||
cordova.getActivity().getApplicationContext(),
|
IS_AT_LEAST_ANDROID5 ? cordova.getActivity().getWindow().getContext() : cordova.getActivity().getApplicationContext(),
|
||||||
message,
|
message,
|
||||||
"short".equals(duration) ? android.widget.Toast.LENGTH_SHORT : android.widget.Toast.LENGTH_LONG);
|
"short".equals(duration) ? android.widget.Toast.LENGTH_SHORT : android.widget.Toast.LENGTH_LONG);
|
||||||
|
|
||||||
|
// if we want to change the background color some day, we can use this
|
||||||
|
// try {
|
||||||
|
// final Method setTintMethod = Drawable.class.getMethod("setTint", int.class);
|
||||||
|
// setTintMethod.invoke(toast.getView().getBackground(), Color.RED); // default is Color.DKGRAY
|
||||||
|
// } catch (Exception ignore) {
|
||||||
|
// }
|
||||||
if ("top".equals(position)) {
|
if ("top".equals(position)) {
|
||||||
toast.setGravity(Gravity.TOP|Gravity.CENTER_HORIZONTAL, 0, 20 + addPixelsY);
|
toast.setGravity(Gravity.TOP|Gravity.CENTER_HORIZONTAL, 0, 20 + addPixelsY);
|
||||||
} else if ("bottom".equals(position)) {
|
} else if ("bottom".equals(position)) {
|
||||||
@ -67,9 +80,31 @@ public class Toast extends CordovaPlugin {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
toast.getView().setOnTouchListener(new View.OnTouchListener() {
|
||||||
|
@Override
|
||||||
|
public boolean onTouch(View view, MotionEvent motionEvent) {
|
||||||
|
if (motionEvent.getAction() == MotionEvent.ACTION_DOWN) {
|
||||||
|
JSONObject json = new JSONObject();
|
||||||
|
try {
|
||||||
|
json.put("event", "touch");
|
||||||
|
json.put("message", message);
|
||||||
|
} catch (JSONException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
callbackContext.success(json);
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
toast.show();
|
toast.show();
|
||||||
mostRecentToast = toast;
|
mostRecentToast = toast;
|
||||||
callbackContext.success();
|
|
||||||
|
PluginResult pr = new PluginResult(PluginResult.Status.OK);
|
||||||
|
pr.setKeepCallback(true);
|
||||||
|
callbackContext.sendPluginResult(pr);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
#import <Foundation/Foundation.h>
|
#import <Foundation/Foundation.h>
|
||||||
|
#import <Cordova/CDV.h>
|
||||||
|
|
||||||
@interface UIView (Toast)
|
@interface UIView (Toast)
|
||||||
|
|
||||||
// each makeToast method creates a view and displays it as toast
|
// each makeToast method creates a view and displays it as toast
|
||||||
- (void)makeToast:(NSString *)message;
|
- (void)makeToast:(NSString *)message;
|
||||||
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position;
|
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position;
|
||||||
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)duration position:(id)position addPixelsY:(int)addPixelsY;
|
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)duration position:(id)position addPixelsY:(int)addPixelsY commandDelegate:(id <CDVCommandDelegate>)commandDelegate callbackId:(NSString *)callbackId;
|
||||||
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position image:(UIImage *)image;
|
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position image:(UIImage *)image;
|
||||||
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position title:(NSString *)title;
|
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position title:(NSString *)title;
|
||||||
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position title:(NSString *)title image:(UIImage *)image;
|
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)interval position:(id)position title:(NSString *)title image:(UIImage *)image;
|
||||||
|
@ -48,6 +48,11 @@ static const NSString * CSToastActivityViewKey = @"CSToastActivityViewKey";
|
|||||||
|
|
||||||
static UIView *prevToast = NULL;
|
static UIView *prevToast = NULL;
|
||||||
|
|
||||||
|
// doesn't matter these are static
|
||||||
|
static id commandDelegate;
|
||||||
|
static id callbackId;
|
||||||
|
static id msg;
|
||||||
|
|
||||||
@interface UIView (ToastPrivate)
|
@interface UIView (ToastPrivate)
|
||||||
|
|
||||||
- (void)hideToast:(UIView *)toast;
|
- (void)hideToast:(UIView *)toast;
|
||||||
@ -56,7 +61,6 @@ static UIView *prevToast = NULL;
|
|||||||
- (CGPoint)centerPointForPosition:(id)position withToast:(UIView *)toast withAddedPixelsY:(int) addPixelsY;
|
- (CGPoint)centerPointForPosition:(id)position withToast:(UIView *)toast withAddedPixelsY:(int) addPixelsY;
|
||||||
- (UIView *)viewForMessage:(NSString *)message title:(NSString *)title image:(UIImage *)image;
|
- (UIView *)viewForMessage:(NSString *)message title:(NSString *)title image:(UIImage *)image;
|
||||||
- (CGSize)sizeForString:(NSString *)string font:(UIFont *)font constrainedToSize:(CGSize)constrainedSize lineBreakMode:(NSLineBreakMode)lineBreakMode;
|
- (CGSize)sizeForString:(NSString *)string font:(UIFont *)font constrainedToSize:(CGSize)constrainedSize lineBreakMode:(NSLineBreakMode)lineBreakMode;
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
||||||
@ -73,7 +77,10 @@ static UIView *prevToast = NULL;
|
|||||||
[self showToast:toast duration:duration position:position];
|
[self showToast:toast duration:duration position:position];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)duration position:(id)position addPixelsY:(int)addPixelsY {
|
- (void)makeToast:(NSString *)message duration:(NSTimeInterval)duration position:(id)position addPixelsY:(int)addPixelsY commandDelegate:(id <CDVCommandDelegate>)_commandDelegate callbackId:(NSString *)_callbackId {
|
||||||
|
commandDelegate = _commandDelegate;
|
||||||
|
callbackId = _callbackId;
|
||||||
|
msg = message;
|
||||||
UIView *toast = [self viewForMessage:message title:nil image:nil];
|
UIView *toast = [self viewForMessage:message title:nil image:nil];
|
||||||
[self showToast:toast duration:duration position:position addedPixelsY:addPixelsY];
|
[self showToast:toast duration:duration position:position addedPixelsY:addPixelsY];
|
||||||
}
|
}
|
||||||
@ -101,12 +108,13 @@ static UIView *prevToast = NULL;
|
|||||||
[self showToast:toast duration:CSToastDefaultDuration position:CSToastDefaultPosition addedPixelsY:0];
|
[self showToast:toast duration:CSToastDefaultDuration position:CSToastDefaultPosition addedPixelsY:0];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)showToast:(UIView *)toast duration:(NSTimeInterval)duration position:(id)point addedPixelsY:(int) addPixelsY {
|
- (void)showToast:(UIView *)toast duration:(NSTimeInterval)duration position:(id)point addedPixelsY:(int) addPixelsY {
|
||||||
[self hideToast];
|
[self hideToast];
|
||||||
prevToast = toast;
|
prevToast = toast;
|
||||||
toast.center = [self centerPointForPosition:point withToast:toast withAddedPixelsY:addPixelsY];
|
toast.center = [self centerPointForPosition:point withToast:toast withAddedPixelsY:addPixelsY];
|
||||||
toast.alpha = 0.0;
|
toast.alpha = 0.0;
|
||||||
|
|
||||||
|
// note that we changed this to be always true
|
||||||
if (CSToastHidesOnTap) {
|
if (CSToastHidesOnTap) {
|
||||||
UITapGestureRecognizer *recognizer = [[UITapGestureRecognizer alloc] initWithTarget:toast action:@selector(handleToastTapped:)];
|
UITapGestureRecognizer *recognizer = [[UITapGestureRecognizer alloc] initWithTarget:toast action:@selector(handleToastTapped:)];
|
||||||
[toast addGestureRecognizer:recognizer];
|
[toast addGestureRecognizer:recognizer];
|
||||||
@ -168,6 +176,11 @@ static UIView *prevToast = NULL;
|
|||||||
[timer invalidate];
|
[timer invalidate];
|
||||||
|
|
||||||
[self hideToast:recognizer.view];
|
[self hideToast:recognizer.view];
|
||||||
|
|
||||||
|
// also send an event back to JS
|
||||||
|
NSDictionary *dict = [[NSDictionary alloc] initWithObjectsAndKeys:msg, @"message", @"touch", @"event", nil];
|
||||||
|
CDVPluginResult* pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK messageAsDictionary:dict];
|
||||||
|
[commandDelegate sendPluginResult:pluginResult callbackId:callbackId];
|
||||||
}
|
}
|
||||||
|
|
||||||
#pragma mark - Toast Activity Methods
|
#pragma mark - Toast Activity Methods
|
||||||
|
@ -30,9 +30,15 @@
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
[self.webView makeToast:message duration:durationInt position:position addPixelsY:addPixelsY == nil ? 0 : [addPixelsY intValue]];
|
[self.webView makeToast:message
|
||||||
|
duration:durationInt
|
||||||
|
position:position
|
||||||
|
addPixelsY:addPixelsY == nil ? 0 : [addPixelsY intValue]
|
||||||
|
commandDelegate:self.commandDelegate
|
||||||
|
callbackId:command.callbackId];
|
||||||
|
|
||||||
CDVPluginResult* pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK];
|
CDVPluginResult* pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK];
|
||||||
|
pluginResult.keepCallback = [NSNumber numberWithBool:YES];
|
||||||
[self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
|
[self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user