mirror of
https://github.com/discourse/discourse.git
synced 2025-01-20 03:52:48 +08:00
216 lines
6.3 KiB
JavaScript
216 lines
6.3 KiB
JavaScript
function checkSelectKitIsNotExpanded(selector) {
|
|
if (find(selector).hasClass('is-expanded')) {
|
|
throw 'You expected select-kit to be collapsed but it is expanded.';
|
|
}
|
|
}
|
|
|
|
function checkSelectKitIsNotCollapsed(selector) {
|
|
if (!find(selector).hasClass('is-expanded')) {
|
|
throw 'You expected select-kit to be expanded but it is collapsed.';
|
|
}
|
|
}
|
|
|
|
Ember.Test.registerAsyncHelper('expandSelectKit', function(app, selector) {
|
|
checkSelectKitIsNotExpanded(selector);
|
|
click(selector + ' .select-kit-header');
|
|
});
|
|
|
|
Ember.Test.registerAsyncHelper('collapseSelectKit', function(app, selector) {
|
|
checkSelectKitIsNotCollapsed(selector);
|
|
click(selector + ' .select-kit-header');
|
|
});
|
|
|
|
Ember.Test.registerAsyncHelper('selectKitFillInFilter', function(app, filter, selector) {
|
|
checkSelectKitIsNotCollapsed(selector);
|
|
fillIn(selector + ' .filter-input', filter);
|
|
});
|
|
|
|
Ember.Test.registerAsyncHelper('selectKitSelectRowByValue', function(app, value, selector) {
|
|
checkSelectKitIsNotCollapsed(selector);
|
|
click(selector + " .select-kit-row[data-value='" + value + "']");
|
|
});
|
|
|
|
Ember.Test.registerAsyncHelper('selectKitSelectRowByName', function(app, name, selector) {
|
|
checkSelectKitIsNotCollapsed(selector);
|
|
click(selector + " .select-kit-row[data-name='" + name + "']");
|
|
});
|
|
|
|
Ember.Test.registerAsyncHelper('selectKitSelectNoneRow', function(app, selector) {
|
|
checkSelectKitIsNotCollapsed(selector);
|
|
click(selector + " .select-kit-row.none");
|
|
});
|
|
|
|
Ember.Test.registerAsyncHelper('selectKitSelectRowByIndex', function(app, index, selector) {
|
|
checkSelectKitIsNotCollapsed(selector);
|
|
click(find(selector + " .select-kit-row").eq(index));
|
|
});
|
|
|
|
function selectKit(selector) { // eslint-disable-line no-unused-vars
|
|
selector = selector || ".select-kit";
|
|
|
|
function rowHelper(row) {
|
|
return {
|
|
name: function() { return row.attr('data-name'); },
|
|
icon: function() { return row.find('.d-icon'); },
|
|
title: function() { return row.attr('title'); },
|
|
value: function() { return row.attr('data-value'); },
|
|
exists: function() { return exists(row); },
|
|
el: function() { return row; }
|
|
};
|
|
}
|
|
|
|
function headerHelper(header) {
|
|
return {
|
|
value: function() { return header.attr('data-value'); },
|
|
name: function() { return header.attr('data-name'); },
|
|
label: function() { return header.text().trim(); },
|
|
icon: function() { return header.find('.icon'); },
|
|
title: function() { return header.attr('title'); },
|
|
el: function() { return header; }
|
|
};
|
|
}
|
|
|
|
function filterHelper(filter) {
|
|
return {
|
|
icon: function() { return filter.find('.d-icon'); },
|
|
exists: function() { return exists(filter); },
|
|
el: function() { return filter; }
|
|
};
|
|
}
|
|
|
|
function keyboardHelper(eventSelector) {
|
|
function createEvent(target, keyCode, options) {
|
|
target = target || ".filter-input";
|
|
eventSelector = find(eventSelector).find(target);
|
|
options = options || {};
|
|
|
|
andThen(function() {
|
|
var type = options.type || 'keydown';
|
|
var event = jQuery.Event(type);
|
|
event.keyCode = keyCode;
|
|
if (options && options.metaKey) { event.metaKey = true; }
|
|
find(eventSelector).trigger(event);
|
|
});
|
|
}
|
|
|
|
return {
|
|
down: function(target) { createEvent(target, 40); },
|
|
up: function(target) { createEvent(target, 38); },
|
|
escape: function(target) { createEvent(target, 27); },
|
|
enter: function(target) { createEvent(target, 13); },
|
|
tab: function(target) { createEvent(target, 9); },
|
|
backspace: function(target) { createEvent(target, 8); },
|
|
selectAll: function(target) { createEvent(target, 65, {metaKey: true}); },
|
|
};
|
|
};
|
|
|
|
return {
|
|
expandAwait: function() {
|
|
return expandSelectKit(selector);
|
|
},
|
|
|
|
expand: function() {
|
|
expandSelectKit(selector);
|
|
return selectKit(selector);
|
|
},
|
|
|
|
collapse: function() {
|
|
collapseSelectKit(selector);
|
|
return selectKit(selector);
|
|
},
|
|
|
|
selectRowByIndex: function(index) {
|
|
selectKitSelectRowByIndex(index, selector);
|
|
return selectKit(selector);
|
|
},
|
|
|
|
selectRowByValueAwait: function(value) {
|
|
return selectKitSelectRowByValue(value, selector);
|
|
},
|
|
|
|
selectRowByValue: function(value) {
|
|
selectKitSelectRowByValue(value, selector);
|
|
return selectKit(selector);
|
|
},
|
|
|
|
selectRowByName: function(name) {
|
|
selectKitSelectRowByValue(name, selector);
|
|
return selectKit(selector);
|
|
},
|
|
|
|
selectNoneRow: function() {
|
|
selectKitSelectNoneRow(selector);
|
|
return selectKit(selector);
|
|
},
|
|
|
|
fillInFilter: function(filter) {
|
|
selectKitFillInFilter(filter, selector);
|
|
return selectKit(selector);
|
|
},
|
|
|
|
keyboard: function() { return keyboardHelper(selector); },
|
|
|
|
isExpanded: function() {
|
|
return find(selector).hasClass('is-expanded');
|
|
},
|
|
|
|
isFocused: function() {
|
|
return find(selector).hasClass('is-focused');
|
|
},
|
|
|
|
isHidden: function() {
|
|
return find(selector).hasClass('is-hidden');
|
|
},
|
|
|
|
header: function() {
|
|
return headerHelper(find(selector).find('.select-kit-header'));
|
|
},
|
|
|
|
filter: function() {
|
|
return filterHelper(find(selector).find('.select-kit-filter'));
|
|
},
|
|
|
|
rows: function() {
|
|
return find(selector).find('.select-kit-row');
|
|
},
|
|
|
|
rowByValue: function(value) {
|
|
return rowHelper(find(selector).find('.select-kit-row[data-value="' + value + '"]'));
|
|
},
|
|
|
|
rowByName: function(name) {
|
|
return rowHelper(find(selector).find('.select-kit-row[data-name="' + name + '"]'));
|
|
},
|
|
|
|
rowByIndex: function(index) {
|
|
return rowHelper(find(selector).find('.select-kit-row:eq(' + index + ')'));
|
|
},
|
|
|
|
el: function() { return find(selector); },
|
|
|
|
noneRow: function() {
|
|
return rowHelper(find(selector).find('.select-kit-row.none'));
|
|
},
|
|
|
|
validationMessage: function() {
|
|
var validationMessage = find(selector).find('.validation-message');
|
|
|
|
if (validationMessage.length) {
|
|
return validationMessage.html().trim();
|
|
} else {
|
|
return null;
|
|
}
|
|
},
|
|
|
|
selectedRow: function() {
|
|
return rowHelper(find(selector).find('.select-kit-row.is-selected'));
|
|
},
|
|
|
|
highlightedRow: function() {
|
|
return rowHelper(find(selector).find('.select-kit-row.is-highlighted'));
|
|
},
|
|
|
|
exists: function() { return exists(selector); }
|
|
};
|
|
}
|