-
Notifications
You must be signed in to change notification settings - Fork 82
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
"server side search" and "Async reactive data-source" demos don't work locally #81
Comments
I too am seeing an issue locally with server side search. If I have some data cached in an array and feed it to the callback, it works fine. If it comes from the server, it doesn't. It makes me wonder if it's a timing issue, but I can't confirm it. Template.foo.helpers({
server: function(q, cb) {
Meteor.call('serverSearch', q, function(err, res) {
if (err) {
console.log('ERROR: ' + err);
return;
}
cb( res.map(function(v) {
return {value: v.name};
}));
});
},
local: function(q, cb) {
//filter only the values that start with the query
var regex = new RegExp("^" + q);
cb(_.filter(local_array, function(o) {
return regex.exec(o.value) !== null;
}));
}
}) My server calls are making outbound http requests to a separate server for info and returning the data. They can take 2-3 seconds to return to the callback in some cases. E.g.: |
I've tried just wrapping the callback inside a |
I'm having the same issue as @dpankros , it works for local data but not server data. I was able to determine that the callback function in the helper is getting called and has the correct data but no changes are being made to the DOM. |
@thinkcontext I should have mentioned that. The server method gets called and returns the correct information to the client. I am confident the data is getting passed to the callback correctly but it never displays. |
I got it to work after downgrading |
@thinkcontext Can you elaborate on what you downgraded and to what version? Thanks! |
|
@thinkcontext Thanks for looking into it. Downgrading this package to 10.5_14 worked for me too. |
This issue is related to update to latest typeahead.js to v0.11.1 (see #78). Now async data source functions must have three arguments (query, sync, async). I found in typeahead.js repository only this commit where the API was changed without relevant issue. |
In reference to this issue, I am getting Whenever I start typing in the search box, I am using the following helper function params:
Using sergeyt:[email protected]_3 will try to downgrade, and re-test |
I don't think downgrading will fix this. 11.1_3 is working fine for me. My helper looks like: Template.foo.helpers({
typeaheadHelper: function(query, sync, callback) {
Meteor.call('serverSearchMethod', query, function(err, res) {
if (err) {
console.log(err);
return;
}
callback(res.map(function(v) { return {value: v.name}; }));
});
}
}); have you tried adding |
Downgraded to meteor add sergeyt:typeahead@=0.10.5_14 and still getting the following error. Below is my .events function, any thoughts what I might be doing wrong / missing here? Thanks
|
Which line is 76? |
@dpankros Exactly, just tried console.log(JSON.stringify(callback)); returns undefined |
@mahmoudkm Look at the productsSerial definition. You're missing sync between query and callback. E.g. you have: function(query, callback) but it should be function(query, sync, callback) |
@dpankros I've tested it with and without sync, through the latest and newest releases...same error. |
@mahmoudkm Try removing kadira debug. kadirahq/meteor-debug#11 and #86. |
@dpankros ooh! Thanks a lot, this instantly solved the undefined param error problem, sincerely appreciate your help :) On a minor note, unfortunately the moment the undefined param error were gone a new problem hatched, where the search box stopped showing the filtered results panel. This behavior happens only when I am using the function with params as shown below. Any thoughts what I could be missing here? Thanks again A. This works smoothly yet it doesn't help me filter results as needed
B. This filter records as displayed in console.log but the filtered results panel is not shown under the search box
|
@mahmoudkm I'm not sure why you're not getting results displayed. I would try changing your code to return an object. So, I would try changing: for (var i = 0, l = productDoc.serial.length; i < l; i++) {
matches.push(productDoc.serial[i].number);
} to for (var i = 0, l = productDoc.serial.length; i < l; i++) {
matches.push({value: productDoc.serial[i].number});
} Do you know that productDoc.serial[i].number is a string? If not, just to be sure, convert it to one. |
@dpankros Thanks, I've tried converting returned data to objects as mentioned in your previous reply but I still can't see the filtered list. I am also so confused why I am not getting results displayed, ironically if I am using the no param function with just return Products.find().fetch().map(function(it){ return it.name; }); it displays without any issues! Note: Yes I am sure that productDoc.serial[i].number is a string. |
@mahmoudkm Can you confirm that your helper gets called each time you type a letter/number? (It should.) |
@dpankros Thanks for your reply,
|
@dpankros I finally managed to get it working, by moving the productsSerial: function code to a server method then calling the callback function with the returned result :) Thanks a lot for your help and time, appreciate it. |
Hi, for some reason when I run the demo locally, the "server side search" and "async reactive data-source" demos don't work while all the other ones work. I was wondering if anyone knows why this might be happening?
Specifically, the
callback
for thefunction(query, callback)
is not being called for either example:However, it works on MeteorPad: http://meteorpad.com/pad/xX6kEQeAj6bqN9FdE/Typeahead
Has anyone else run into this problem before?
The text was updated successfully, but these errors were encountered: