discourse/test/javascripts/helpers/select-box-kit-helper.js

147 lines
4.7 KiB
JavaScript
Raw Normal View History

function checkSelectBoxIsNotExpanded(selectBoxSelector) {
if (find(selectBoxSelector).hasClass('is-expanded')) {
throw 'You expected select-box to be collapsed but it is expanded.';
}
}
function checkSelectBoxIsNotCollapsed(selectBoxSelector) {
if (!find(selectBoxSelector).hasClass('is-expanded')) {
throw 'You expected select-box to be expanded but it is collapsed.';
}
}
2017-11-09 13:57:53 -05:00
Ember.Test.registerAsyncHelper('expandSelectBoxKit', function(app, selectBoxSelector) {
2017-10-19 15:51:08 -04:00
selectBoxSelector = selectBoxSelector || '.select-box-kit';
checkSelectBoxIsNotExpanded(selectBoxSelector);
2017-10-19 15:51:08 -04:00
click(selectBoxSelector + ' .select-box-kit-header');
});
2017-11-09 13:57:53 -05:00
Ember.Test.registerAsyncHelper('collapseSelectBoxKit', function(app, selectBoxSelector) {
2017-10-19 15:51:08 -04:00
selectBoxSelector = selectBoxSelector || '.select-box-kit';
checkSelectBoxIsNotCollapsed(selectBoxSelector);
2017-10-19 15:51:08 -04:00
click(selectBoxSelector + ' .select-box-kit-header');
});
2017-11-09 13:57:53 -05:00
Ember.Test.registerAsyncHelper('selectBoxKitSelectRow', function(app, rowValue, options) {
options = options || {};
2017-10-19 15:51:08 -04:00
options.selector = options.selector || '.select-box-kit';
checkSelectBoxIsNotCollapsed(options.selector);
2017-10-19 15:51:08 -04:00
click(options.selector + " .select-box-kit-row[data-value='" + rowValue + "']");
});
2017-11-09 13:57:53 -05:00
Ember.Test.registerAsyncHelper('selectBoxKitSelectNoneRow', function(app, options) {
2017-10-19 15:51:08 -04:00
options = options || {};
options.selector = options.selector || '.select-box-kit';
checkSelectBoxIsNotCollapsed(options.selector);
click(options.selector + " .select-box-kit-row.none");
});
2017-11-09 13:57:53 -05:00
Ember.Test.registerAsyncHelper('selectBoxKitFillInFilter', function(app, filter, options) {
options = options || {};
2017-10-19 15:51:08 -04:00
options.selector = options.selector || '.select-box-kit';
checkSelectBoxIsNotCollapsed(options.selector);
2017-10-19 15:51:08 -04:00
var filterQuerySelector = options.selector + ' .select-box-kit-filter-input';
fillIn(filterQuerySelector, filter);
});
function selectBox(selector) { // eslint-disable-line no-unused-vars
2017-10-19 15:51:08 -04:00
selector = selector || '.select-box-kit';
function rowHelper(row) {
return {
2017-10-19 15:51:08 -04:00
name: function() { return row.attr('data-name'); },
icon: function() { return row.find('.d-icon'); },
title: function() { return row.attr('title'); },
2017-10-19 15:51:08 -04:00
value: function() { return row.attr('data-value'); },
el: row
};
}
function headerHelper(header) {
return {
2017-10-19 15:51:08 -04:00
name: function() {
return header.attr('data-name');
},
icon: function() { return header.find('.icon'); },
title: function() { return header.attr('title'); },
el: header
};
}
function filterHelper(filter) {
return {
icon: function() { return filter.find('.d-icon'); },
exists: function() { return exists(filter); },
el: filter
};
}
function keyboardHelper() {
2017-11-09 13:57:53 -05:00
function createEvent(target, keyCode, options) {
2017-10-19 15:51:08 -04:00
target = target || ".select-box-kit-filter-input";
selector = find(selector).find(target);
andThen(function() {
2017-11-09 13:57:53 -05:00
var event = jQuery.Event(options.type);
event.keyCode = keyCode;
2017-11-09 13:57:53 -05:00
if (options && options.metaKey === true) { event.metaKey = true; }
find(selector).trigger(event);
});
}
return {
2017-11-09 13:57:53 -05:00
down: function(target) { createEvent(target, 40, {type: 'keydown'}); },
up: function(target) { createEvent(target, 38, {type: 'keydown'}); },
escape: function(target) { createEvent(target, 27, {type: 'keydown'}); },
enter: function(target) { createEvent(target, 13, {type: 'keypress'}); },
tab: function(target) { createEvent(target, 9, {type: 'keydown'}); },
backspace: function(target) { createEvent(target, 8, {type: 'keydown'}); },
selectAll: function(target) { createEvent(target, 65, {metaKey: true, type: 'keydown'}); },
};
}
return {
keyboard: keyboardHelper(),
isExpanded: find(selector).hasClass('is-expanded'),
isHidden: find(selector).hasClass('is-hidden'),
2017-10-19 15:51:08 -04:00
header: headerHelper(find(selector).find('.select-box-kit-header')),
2017-10-19 15:51:08 -04:00
filter: filterHelper(find(selector).find('.select-box-kit-filter')),
2017-10-19 15:51:08 -04:00
rows: find(selector).find('.select-box-kit-row'),
2017-10-19 15:51:08 -04:00
rowByValue: function(value) {
return rowHelper(find(selector).find('.select-box-kit-row[data-value="' + value + '"]'));
},
2017-10-19 15:51:08 -04:00
rowByName: function(name) {
return rowHelper(find(selector).find('.select-box-kit-row[data-name="' + name + '"]'));
},
rowByIndex: function(index) {
return rowHelper(find(selector).find('.select-box-kit-row:eq(' + index + ')'));
},
el: find(selector),
noneRow: rowHelper(find(selector).find('.select-box-kit-row.none')),
selectedRow: rowHelper(find(selector).find('.select-box-kit-row.is-selected')),
2017-10-19 15:51:08 -04:00
highlightedRow: rowHelper(find(selector).find('.select-box-kit-row.is-highlighted'))
};
}