aboutsummaryrefslogtreecommitdiffstats
path: root/ui
diff options
context:
space:
mode:
authorScott González <scott.gonzalez@gmail.com>2009-08-03 14:28:54 +0000
committerScott González <scott.gonzalez@gmail.com>2009-08-03 14:28:54 +0000
commitd6385b039b603aa898c2e412c442dd064fdbe446 (patch)
tree6d0263e8214bede5b5a9f608d47cbfed248e78ae /ui
parent52ca5251123f62c48030115fbaa58fb4827dd413 (diff)
downloadjquery-ui-d6385b039b603aa898c2e412c442dd064fdbe446.tar.gz
jquery-ui-d6385b039b603aa898c2e412c442dd064fdbe446.zip
Dialog: Support hash, array, string for cursorAt option. Use position plugin. Partial fix for #2525 - Standardised way to pass coordinates to plugins.
Diffstat (limited to 'ui')
-rw-r--r--ui/ui.dialog.js85
1 files changed, 40 insertions, 45 deletions
diff --git a/ui/ui.dialog.js b/ui/ui.dialog.js
index 2815e4968..e0955664b 100644
--- a/ui/ui.dialog.js
+++ b/ui/ui.dialog.js
@@ -10,6 +10,7 @@
* Depends:
* ui.core.js
* ui.draggable.js
+ * ui.position.js
* ui.resizable.js
*/
(function($) {
@@ -376,56 +377,50 @@ $.widget("ui.dialog", {
: Math.min(options.minHeight, options.height));
},
- _position: function(pos) {
- var wnd = $(window), doc = $(document),
- pTop = doc.scrollTop(), pLeft = doc.scrollLeft(),
- minTop = pTop,
- uiDialog = this.uiDialog;
-
- if ($.inArray(pos, ['center','top','right','bottom','left']) >= 0) {
- pos = [
- pos == 'right' || pos == 'left' ? pos : 'center',
- pos == 'top' || pos == 'bottom' ? pos : 'middle'
- ];
- }
- if (pos.constructor != Array) {
- pos = ['center', 'middle'];
- }
- if (pos[0].constructor == Number) {
- pLeft += pos[0];
- } else {
- switch (pos[0]) {
- case 'left':
- pLeft += 0;
- break;
- case 'right':
- pLeft += wnd.width() - uiDialog.outerWidth();
- break;
- default:
- case 'center':
- pLeft += (wnd.width() - uiDialog.outerWidth()) / 2;
+ _position: function(position) {
+ var myAt = [],
+ offset = [0, 0];
+
+ // deep extending converts arrays to objects in jQuery <= 1.3.2 :-(
+// if (typeof position == 'string' || $.isArray(position)) {
+// myAt = $.isArray(position) ? position : position.split(' ');
+ if (typeof position == 'string' || '0' in position) {
+ myAt = position.split ? position.split(' ') : [position[0], position[1]];
+ if (myAt.length == 1) {
+ myAt[1] = myAt[0];
}
- }
- if (pos[1].constructor == Number) {
- pTop += pos[1];
+
+ $.each(['left', 'top'], function(i, offsetPosition) {
+ if (+myAt[i] == myAt[i]) {
+ offset[i] = myAt[i];
+ myAt[i] = offsetPosition;
+ }
+ });
} else {
- switch (pos[1]) {
- case 'top':
- pTop += 0;
- break;
- case 'bottom':
- pTop += wnd.height() - uiDialog.outerHeight();
- break;
- default:
- case 'middle':
- pTop += (wnd.height() - uiDialog.outerHeight()) / 2;
+ if ('left' in position) {
+ myAt[0] = 'left';
+ offset[0] = position.left;
+ } else if ('right' in position) {
+ myAt[0] = 'right';
+ offset[0] = -position.right;
+ }
+
+ if ('top' in position) {
+ myAt[1] = 'top';
+ offset[1] = position.top;
+ } else if ('bottom' in position) {
+ myAt[1] = 'bottom';
+ offset[1] = -position.bottom;
}
}
- // prevent the dialog from being too high (make sure the titlebar
- // is accessible)
- pTop = Math.max(pTop, minTop);
- uiDialog.css({top: pTop, left: pLeft});
+ this.uiDialog.position({
+ my: myAt.join(' '),
+ at: myAt.join(' '),
+ offset: offset.join(' '),
+ of: window,
+ collision: 'fit'
+ });
},
_setData: function(key, value){