mirror of
https://github.com/meteor/meteor.git
synced 2026-05-02 03:01:46 -04:00
62 lines
2.3 KiB
JavaScript
62 lines
2.3 KiB
JavaScript
// Browser specific code for the OAuth package.
|
|
|
|
// Open a popup window, centered on the screen, and call a callback when it
|
|
// closes.
|
|
//
|
|
// @param url {String} url to show
|
|
// @param callback {Function} Callback function to call on completion. Takes no
|
|
// arguments.
|
|
// @param dimensions {optional Object(width, height)} The dimensions of
|
|
// the popup. If not passed defaults to something sane.
|
|
OAuth.showPopup = function (url, callback, dimensions) {
|
|
// default dimensions that worked well for facebook and google
|
|
var popup = openCenteredPopup(
|
|
url,
|
|
(dimensions && dimensions.width) || 650,
|
|
(dimensions && dimensions.height) || 331
|
|
);
|
|
|
|
var checkPopupOpen = setInterval(function() {
|
|
try {
|
|
// Fix for #328 - added a second test criteria (popup.closed === undefined)
|
|
// to humour this Android quirk:
|
|
// http://code.google.com/p/android/issues/detail?id=21061
|
|
var popupClosed = popup.closed || popup.closed === undefined;
|
|
} catch (e) {
|
|
// For some unknown reason, IE9 (and others?) sometimes (when
|
|
// the popup closes too quickly?) throws "SCRIPT16386: No such
|
|
// interface supported" when trying to read 'popup.closed'. Try
|
|
// again in 100ms.
|
|
return;
|
|
}
|
|
|
|
if (popupClosed) {
|
|
clearInterval(checkPopupOpen);
|
|
callback();
|
|
}
|
|
}, 100);
|
|
};
|
|
|
|
var openCenteredPopup = function(url, width, height) {
|
|
var screenX = typeof window.screenX !== 'undefined'
|
|
? window.screenX : window.screenLeft;
|
|
var screenY = typeof window.screenY !== 'undefined'
|
|
? window.screenY : window.screenTop;
|
|
var outerWidth = typeof window.outerWidth !== 'undefined'
|
|
? window.outerWidth : document.body.clientWidth;
|
|
var outerHeight = typeof window.outerHeight !== 'undefined'
|
|
? window.outerHeight : (document.body.clientHeight - 22);
|
|
// XXX what is the 22?
|
|
|
|
// Use `outerWidth - width` and `outerHeight - height` for help in
|
|
// positioning the popup centered relative to the current window
|
|
var left = screenX + (outerWidth - width) / 2;
|
|
var top = screenY + (outerHeight - height) / 2;
|
|
var features = ('width=' + width + ',height=' + height +
|
|
',left=' + left + ',top=' + top + ',scrollbars=yes');
|
|
|
|
var newwindow = window.open(url, 'Login', features);
|
|
if (newwindow.focus)
|
|
newwindow.focus();
|
|
return newwindow;
|
|
}; |