aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorScott González <scott.gonzalez@gmail.com>2008-06-26 00:55:24 +0000
committerScott González <scott.gonzalez@gmail.com>2008-06-26 00:55:24 +0000
commit93c2dfff7194fe7e45e6bd0bf4863d8604dab0bb (patch)
treee9ce9ae45068db8bf01105ab5b83791fdc93a45c
parent173eddaf46a90f4cca92d747d3a093aef5e0207c (diff)
downloadjquery-ui-93c2dfff7194fe7e45e6bd0bf4863d8604dab0bb.tar.gz
jquery-ui-93c2dfff7194fe7e45e6bd0bf4863d8604dab0bb.zip
Dialog: Restructured button creation and fixed the problem with not being able to change the buttons after instantiation.
-rw-r--r--ui/ui.dialog.js44
1 files changed, 30 insertions, 14 deletions
diff --git a/ui/ui.dialog.js b/ui/ui.dialog.js
index d6a7fb220..120a855e3 100644
--- a/ui/ui.dialog.js
+++ b/ui/ui.dialog.js
@@ -77,7 +77,11 @@ $.widget("ui.dialog", {
})
.mousedown(function() {
self.moveToTop();
- });
+ }),
+
+ uiDialogButtonPane = (this.uiDialogButtonPane = $('<div/>'))
+ .addClass('ui-dialog-buttonpane')
+ .appendTo(uiDialog);
this.uiDialogTitlebarClose = $('.ui-dialog-titlebar-close', uiDialogTitlebar)
.hover(
@@ -96,19 +100,6 @@ $.widget("ui.dialog", {
return false;
});
- var hasButtons = false;
- $.each(options.buttons, function() { return !(hasButtons = true); });
- if (hasButtons) {
- var uiDialogButtonPane = $('<div class="ui-dialog-buttonpane"/>')
- .appendTo(uiDialog);
- $.each(options.buttons, function(name, fn) {
- $('<button/>')
- .text(name)
- .click(function() { fn.apply(self.element[0], arguments); })
- .appendTo(uiDialogButtonPane);
- });
- }
-
if ($.fn.draggable) {
uiDialog.draggable({
helper: options.dragHelper,
@@ -152,6 +143,8 @@ $.widget("ui.dialog", {
(options.resizable || uiDialog.resizable('disable'));
}
+ this.createButtons(options.buttons);
+
(options.bgiframe && $.fn.bgiframe && uiDialog.bgiframe());
(options.autoOpen && this.open());
},
@@ -159,6 +152,9 @@ $.widget("ui.dialog", {
setData: function(key, value){
(setDataSwitch[key] && this.uiDialog.data(setDataSwitch[key], value));
switch (key) {
+ case "buttons":
+ this.createButtons(value);
+ break;
case "draggable":
this.uiDialog.draggable(value ? 'enable' : 'disable');
break;
@@ -296,6 +292,26 @@ $.widget("ui.dialog", {
.removeClass('ui-dialog-content')
.hide().appendTo('body');
this.uiDialog.remove();
+ },
+
+ createButtons: function(buttons) {
+ var self = this,
+ hasButtons = false,
+ uiDialogButtonPane = this.uiDialogButtonPane;
+
+ // remove any existing buttons
+ uiDialogButtonPane.empty().hide();
+
+ $.each(buttons, function() { return !(hasButtons = true); });
+ if (hasButtons) {
+ uiDialogButtonPane.show();
+ $.each(buttons, function(name, fn) {
+ $('<button/>')
+ .text(name)
+ .click(function() { fn.apply(self.element[0], arguments); })
+ .appendTo(uiDialogButtonPane);
+ });
+ }
}
});