-
Notifications
You must be signed in to change notification settings - Fork 34
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
get reactive data. #21
Comments
+1 to this issue. The readme says "You can get the reactive data source with the PackageSearch.getData api" but when I use that, the data on the client side doesn't automatically reflect my updated documents. |
+1 |
I'm getting reactive data with this package. Make sure your event handler is properly configured so your search works. For me, it was as simple as changing |
I'm having the same issue, it's not updating when it's changed. If I search for the document, it shows me the updated name, however if I press escape or backspace, it shows me the name it used to be. |
+1 Has anyone figured out any workaround for this? |
+1 |
same solution as @petermikitsh. once changed from onChange to onKeyUp, all is reactive now. this is a non-issue. |
i had fun getting this to work in react. while it was very simple, it was tough to figure out as im still new to reactive programming. hope this helps someone:
|
ok -- this seems to only work locally, but not with any latency involved. actually, if you watch state and add a record to the database, |
This is in fact a non-issue. I was not setup to listen to reactive data sources in React. Here is the correct config if anyone wants to see it:
Then you listen to |
+1 Template.tpl.onRendered(function() {
ExercisesSearch.search(' ');
});
Template.tpl.events({
'keyup #searchExercises': _.throttle(function(event) {
var text = $(event.target).val().trim();
ExercisesSearch.search(text);
}, 200)
}); search.js server SearchSource.defineSource('exercises', function(searchText, options) {
//var options = {sort: {isoScore: -1}, limit: 20};
if(searchText) {
var regExp = buildRegExp(searchText);
//var selector = {exerciseName: regExp, createdBy: Meteor.userId(), isDeleted: false};
var selector = {
exerciseName: regExp,
$or: [{
createdBy: Meteor.userId(),
isPrivate: true
}, {
isPrivate: false
}],
$and: [{
isDeleted: false
}]};
return Exercises.find(selector, {sort: {isoScore: -1}, limit: 20}).fetch();
} else {
return Exercises.find({
$or: [{
createdBy: Meteor.userId(),
isPrivate: true
}, {
isPrivate: false
}],
$and: [{
isDeleted: false
}]
}).fetch();
}
}); search.js client var options = {
keepHistory: 1000 * 60 * 5,
localSearch: true
};
var exerciseFields = ['exerciseName'];
ExercisesSearch = new SearchSource('exercises', exerciseFields, options); page.html <div class="row">
<div class="col-lg-12">
<div class="hpanel">
<div class="panel-body">
<div class="input-group">
<input class="form-control" id="searchExercises" type="text" placeholder="Search..">
</div>
</div>
</div>
</div>
</div>
...
{{#each exercisesList}}
<div class="row">
<div class="col-sm-12">
<div class="hpanel filter-item">
<div class="panel-body" name="exercise" id="{{_id}}">
<a href="{{pathFor 'exercise'}}"><h4 class="m-b-xs">{{exerciseName}}</h4></a>
<div class="container-fluid">
<p class="small">{{{substrVar exerciseDesc "500"}}}</p>
</div><br>
</div>
</div>
</div>
</div>
{{/each}} tpl_helper.js Template.tpl.helpers({
exercisesList: function() {
return ExercisesSearch.getData({
transform: function(matchText, regExp) {
return matchText;
},
sort: {isoScore: -1}
});
}
}); I can repeat search query in browser console and "hidden" on the page item present in result. |
Having the same issue here also, updating values on an entry to the db are not reactively rendered |
+1 |
1 similar comment
+1 |
"Having the same issue here also, updating values on an entry to the db are not reactively rendered" I am experiencing the same as you. |
Definitely is not a "real reactive" package. It only takes a "snapshot" from the results returned by the query... I hope in next update it will be solved because the package works great. |
+1 |
Tried to implement one approach to this problem. Take a look #54 . |
@bompi88 well patch, but the performance is an issue |
@bompi88 Thanks for sharing your patch. I like your idea. Also, your patch may clarify things for those contributing confusion by saying it's a "non-issue" etc. Looking closely at your patch, it appears to me that while it does react to changes to documents in the search results, it doesn't react to documents which may have been inserted (added), 'externally'. Can you please confirm that? |
@steinitz That's true. If that should be supported, I think this package should be more module-based, |
Thanks for your thoughtful reply. You wrote:
Maybe so. Rest-based might be a step backwards though.
That might be true in theory, but, for example, getData() currently uses hard-coded Mongo selectors.
Good question. I'll be interested to see how Meteor handles reactivity with other databases. In any case, your clever solution brings us closer to having a truly reactive fast search. I'd be interested to hear about any inspiration you might have about reacting to newly-created docs. My only idea at present, a crude one, is a way to force SearchSource to 'start over' - MyCollectionSearchSource.reset(), maybe, which the app calls when it creates a new document. Ugh. You can see why I'm poking around for a real solution. Thanks again for your thoughts and for sharing your work. |
Package does not return reactive data. I've forked your example app, searched for a particular package, edited the 'packageName' in mongo. The data in the app will not update until I re-query the search.
Please advise.
The text was updated successfully, but these errors were encountered: