From da7573cbf0ed0aea4f8d41ea9b2e1c590de9033b Mon Sep 17 00:00:00 2001 From: Vladislav Zarakovsky Date: Sat, 30 Jan 2016 17:02:18 +0300 Subject: [PATCH] Add item data to awesomplete-select event --- awesomplete.js | 15 +++++++++++---- test/api/selectSpec.js | 1 + 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/awesomplete.js b/awesomplete.js index d7857e7c..4024391f 100644 --- a/awesomplete.js +++ b/awesomplete.js @@ -189,6 +189,7 @@ _.prototype = { if (selected) { var allowed = $.fire(this.input, "awesomplete-select", { text: selected.textContent, + data: this._suggestions[elementSiblingIndex(selected)], origin: origin || selected }); @@ -209,15 +210,15 @@ _.prototype = { // Populate list with options that match this.ul.innerHTML = ""; - this._list + this._suggestions = this._list .filter(function(item) { return me.filter(item, value); }) .sort(this.sort) - .every(function(text, i) { - me.ul.appendChild(me.item(text, value)); + .slice(0, this.maxItems); - return i < me.maxItems - 1; + this._suggestions.forEach(function(text) { + me.ul.appendChild(me.item(text, value)); }); if (this.ul.children.length === 0) { @@ -290,6 +291,12 @@ function configure(instance, properties, o) { } } +function elementSiblingIndex(el) { + /* eslint-disable no-cond-assign */ + for (var i = 0; el = el.previousElementSibling; i++); + return i; +} + // Helpers var slice = Array.prototype.slice; diff --git a/test/api/selectSpec.js b/test/api/selectSpec.js index 8d8a1866..84895b16 100644 --- a/test/api/selectSpec.js +++ b/test/api/selectSpec.js @@ -47,6 +47,7 @@ describe("awesomplete.select", function () { expect(handler).toHaveBeenCalledWith( jasmine.objectContaining({ text: expectedTxt, + data: expectedTxt, origin: this.selectArgument || this.subject.ul.children[0] }) );