Change image buttons from using a child image widget to using the img node as the button's DOM node

This commit is contained in:
Nathan Gray 2012-03-08 17:10:26 +00:00
parent 2df89f73ab
commit 96271ea210
2 changed files with 33 additions and 21 deletions

View File

@ -50,6 +50,13 @@ var et2_button = et2_baseWidget.extend([et2_IInput, et2_IDetachedDOM], {
this.btn = null; this.btn = null;
this.image = null; this.image = null;
if (this.options.image)
{
this.image = jQuery(document.createElement("img"))
.addClass("et2_button et2_button_icon");
this.setDOMNode(this.image[0]);
return;
}
if (!this.options.readonly) if (!this.options.readonly)
{ {
this.btn = $j(document.createElement("button")) this.btn = $j(document.createElement("button"))
@ -59,28 +66,25 @@ var et2_button = et2_baseWidget.extend([et2_IInput, et2_IDetachedDOM], {
}, },
set_image: function(_image) { set_image: function(_image) {
if(!this.isInTree()) return; if(!this.isInTree() || this.image == null) return;
this.options.image = _image; this.options.image = _image;
var found_image = false; var found_image = false;
if(this.options.image != "") if(this.options.image != "")
{ {
if(!this.image) var src = this.egw().image(_image);
if(src)
{ {
this.image = et2_createWidget("image", this.image.attr("src", src);
found_image = true;
}
// allow url's too
else if (_image[0] == '/' || _image.substr(0,4) == 'http')
{ {
label: this.options.label this.image.attr('src', _image);
}, this); found_image = true;
} }
found_image = this.image.set_src(this.options.image);
if(found_image) {
// No label if there's an image
this.set_label("");
this.btn.removeClass("et2_button_text").addClass("et2_button_icon");
}
jQuery(this.image.getDOMNode()).appendTo(this.btn);
//this.addChild(this.image);
} }
if(!found_image) if(!found_image)
{ {
@ -89,7 +93,7 @@ var et2_button = et2_baseWidget.extend([et2_IInput, et2_IDetachedDOM], {
}, },
getDOMNode: function() { getDOMNode: function() {
return this.btn ? this.btn[0] : null; return this.btn ? this.btn[0] : (this.image ? this.image[0] : null);
}, },
onclick: function(_node) { onclick: function(_node) {
@ -119,6 +123,10 @@ var et2_button = et2_baseWidget.extend([et2_IInput, et2_IDetachedDOM], {
this.btn.text(_value); this.btn.text(_value);
} }
if(this.image)
{
this.image.attr("alt", _value).attr("title",_value);
}
}, },
@ -157,12 +165,17 @@ var et2_button = et2_baseWidget.extend([et2_IInput, et2_IDetachedDOM], {
getDetachedNodes: function() getDetachedNodes: function()
{ {
return [this.getDOMNode()]; return [
this.btn != null ? this.btn[0] : null,
this.image != null ? this.image[0] : null
];
}, },
setDetachedAttributes: function(_nodes, _values) setDetachedAttributes: function(_nodes, _values)
{ {
this.btn = jQuery(_nodes[0]); // Datagrid puts in the row for null
this.btn = _nodes[0].nodeName == 'button' ? jQuery(_nodes[0]) : null;
this.image = jQuery(_nodes[1]);
if (typeof _values["id"] != "undefined") if (typeof _values["id"] != "undefined")
{ {
@ -177,7 +190,6 @@ var et2_button = et2_baseWidget.extend([et2_IInput, et2_IDetachedDOM], {
} }
if (typeof _values["image"] != "undefined") if (typeof _values["image"] != "undefined")
{ {
this.image = null;
this.set_image(_values["image"]); this.set_image(_values["image"]);
} }
@ -190,7 +202,7 @@ var et2_button = et2_baseWidget.extend([et2_IInput, et2_IDetachedDOM], {
{ {
this.options.onclick = _values["onclick"]; this.options.onclick = _values["onclick"];
} }
this.btn.bind("click.et2_baseWidget", this, function(e) { jQuery(this.getDOMNode()).bind("click.et2_baseWidget", this, function(e) {
e.data.set_id(_values["id"]); e.data.set_id(_values["id"]);
return e.data.click.call(e.data,e); return e.data.click.call(e.data,e);
}); });

View File

@ -123,7 +123,7 @@ a.et2_url.url {
background-image: url(gfx/url.png); background-image: url(gfx/url.png);
} }
button.et2_button { .et2_button {
cursor: pointer; cursor: pointer;
text-align: center; text-align: center;
@ -131,7 +131,7 @@ button.et2_button {
text-shadow: 1px 1px #E0E0E0; text-shadow: 1px 1px #E0E0E0;
} }
button.et2_button_text { .et2_button_text {
background-color: #E0E0E0; background-color: #E0E0E0;
background-image: url(gfx/gradient01.png); background-image: url(gfx/gradient01.png);
background-position: center; background-position: center;
@ -143,7 +143,7 @@ button.et2_button_text {
border: 1px solid silver; border: 1px solid silver;
color: #101010; color: #101010;
} }
button.et2_button_icon { .et2_button_icon {
border: none; border: none;
background: transparent; background: transparent;
} }