mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-11 00:31:56 -06:00
Remove jquery button usage and unify button code
https://fedorahosted.org/freeipa/ticket/3904
This commit is contained in:
parent
1aeb2bb11d
commit
7adb034e02
@ -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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -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()
|
||||||
|
Loading…
Reference in New Issue
Block a user