Remove jquery button usage and unify button code

https://fedorahosted.org/freeipa/ticket/3904
This commit is contained in:
Petr Vobornik 2013-10-17 10:28:47 +02:00 committed by Martin Kosek
parent 1aeb2bb11d
commit 7adb034e02
2 changed files with 63 additions and 61 deletions

View File

@ -3449,7 +3449,7 @@ IPA.link_widget = function(spec) {
}; };
/** /**
* Create link which behaves as button * Create button
* *
* @method * @method
* @member IPA * @member IPA
@ -3469,16 +3469,54 @@ IPA.link_widget = function(spec) {
*/ */
IPA.action_button = function(spec) { IPA.action_button = function(spec) {
spec = $.extend({}, spec);
spec.element = spec.element || '<a/>';
spec.button_class = spec.button_class || 'button action-button';
var button = IPA.button(spec);
button.prop('href', spec.href || '#');
return button;
};
/**
* Create button
*
* Has different styling than action button.
*
* @method
* @member IPA
*
* @param {Object} spec
* @param {string} [spec.name]
* @param {string} [spec.label] button text
* @param {string} [spec.title=label] button title
* @param {string} [spec.icon] icon name (class)
* @param {string} [spec.id]
* @param {string} [spec.style] css style
* @param {string} [spec.class]
* @param {string} [spec.button_class]
* @param {string} [spec.element]
* @param {string} [spec.type]
* @param {Function} [spec.click] click handler
* @param {boolean} [spec.focusable] button is focusable
* @param {Function} [spec.blur] blur handler
*/
IPA.button = function(spec) {
spec = spec || {}; spec = spec || {};
var button = $('<a/>', { var el = spec.element || '<button/>';
var button_class = spec.button_class || 'btn';
var button = $(el, {
id: spec.id, id: spec.id,
name: spec.name, name: spec.name,
href: spec.href || '#' + (spec.name || 'button'),
title: text.get(spec.title || spec.label), title: text.get(spec.title || spec.label),
'class': 'button action-button', 'class': button_class,
style: spec.style, style: spec.style,
click: spec.click, click: spec.click,
type: spec.type || 'button',
blur: spec.blur blur: spec.blur
}); });
@ -3488,6 +3526,8 @@ IPA.action_button = function(spec) {
if (spec['class']) button.addClass(spec['class']); if (spec['class']) button.addClass(spec['class']);
if (spec.type) button.addClass(spec.type);
if (spec.icon) { if (spec.icon) {
$('<span/>', { $('<span/>', {
'class': 'icon '+spec.icon 'class': 'icon '+spec.icon
@ -3504,48 +3544,6 @@ IPA.action_button = function(spec) {
return button; return button;
}; };
/**
* Create button
*
* Has different styling than action button.
*
* @method
* @member IPA
*
* @param {Object} spec
* @param {string} [spec.name]
* @param {string} [spec.label] button text
* @param {string} [spec.title=label] button title
* @param {string} [spec.icon] icon name (class)
* @param {string} [spec.id]
* @param {string} [spec.href]
* @param {string} [spec.style] css style
* @param {string} [spec.class]
* @param {Function} [spec.click] click handler
*/
IPA.button = function(spec) {
spec = spec || {};
var button = $('<a/>', {
id: spec.id,
name: spec.name,
href: spec.href || '#' + (spec.name || 'button')
});
var icons = { primary: spec.icon };
var label = text.get(spec.label);
button.button({
icons: icons,
label: label
});
button.click(spec.click);
return button;
};
/** /**
* Widget encapsulating an `IPA.button` * Widget encapsulating an `IPA.button`
* *
@ -3558,16 +3556,22 @@ IPA.button_widget = function(spec) {
var that = IPA.widget(spec); var that = IPA.widget(spec);
/** Displayed link */ /**
that.href = spec.href; * Additional CSS style
/** CSS style */ * @property
*/
that.style = spec.style; that.style = spec.style;
/** Click handler */ /**
* Click handler
* @property {Function}
*/
that.click = spec.click; that.click = spec.click;
/** CSS class */
/**
* Additional CSS class(es)
* @property {String}
*/
that['class'] = spec['class']; that['class'] = spec['class'];
/** CSS class for disabled button */
that.disabled_class = 'button-disabled';
/** /**
* Widget click handler. * Widget click handler.
@ -3587,7 +3591,6 @@ IPA.button_widget = function(spec) {
that.button = IPA.button({ that.button = IPA.button({
id: that.id, id: that.id,
name: that.name, name: that.name,
href: that.href,
title: that.tooltip, title: that.tooltip,
label: that.label, label: that.label,
'class': that['class'], 'class': that['class'],
@ -3603,11 +3606,7 @@ IPA.button_widget = function(spec) {
that.widget_set_enabled(enabled); that.widget_set_enabled(enabled);
if (that.button) { if (that.button) {
if (enabled) { that.button.prop('disabled', !enabled);
that.button.removeClass(that.disabled_class);
} else {
that.button.addClass(that.disabled_class);
}
} }
}; };

View File

@ -583,12 +583,15 @@ class UI_driver(object):
if not parent: if not parent:
parent = self.get_form() parent = self.get_form()
s = "a[name='%s'].ui-button" % name s = "[name='%s'].btn" % name
self._button_click(s, parent, name) self._button_click(s, parent, name)
def _button_click(self, selector, parent, name=''): def _button_click(self, selector, parent, name=''):
btn = self.find(selector, By.CSS_SELECTOR, parent, strict=True) btn = self.find(selector, By.CSS_SELECTOR, parent, strict=True)
disabled = 'ui-state-disabled' in btn.get_attribute("class").split()
disabled = 'ui-state-disabled' in btn.get_attribute("class").split() or \
btn.get_attribute("disabled")
assert btn.is_displayed(), 'Button is not displayed: %s' % name assert btn.is_displayed(), 'Button is not displayed: %s' % name
assert not disabled, 'Invalid button state: disabled. Button: %s' % name assert not disabled, 'Invalid button state: disabled. Button: %s' % name
btn.click() btn.click()