-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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
Smart crates / save and recall search queries #5575
Comments
Commented by: borfo It would be useful if smart crates ran their queries once at the start of the mixxx session, and cached the results for the duration of the session, rather than running the crate-construction query every time you open the crate - I have a very large music collection, and searches of the whole collection aren't very fast - if these smart crates cached their contents somehow, that would really speed up searches within the crates, since I would only be searching a subset of my library. |
Commented by: rryan I'd suggest something slightly different -- that they are cached but only update when tracks in the Mixxx library change. This way if you had a crate that was like [playcount>5] and you played a track in the same session bumping its playcount from 5 to 6 then it would appear in the crate. |
Commented by: borfo That works for me. |
Commented by: naught101 Just noting that both Zotero and Thunderbird do this quite well, if anyone is looking for UI inspiration. Also, it would be really useful to have a couple of default smart crates - particularly "Songs not in a crate", and "Never played songs". They'd be really helpful for organising a library initially. |
Commented by: uklotzde More ideas on (and beyond) the 'smart crates' feature. Dynamic content
Customizable column configuration
Mixxx query syntax: Add crate containment property
Mixxx query syntax: Add new operators
|
Commented by: ferranpujolcamins A filter that evaluates to true for songs that are in a particular crate and multi-parent crates are essentially the same (A child crate is a crate that selects tracks that match its query AND its parents query). They both present a problem when cross-referencing crates, e.g: This cannot be evaluated. Did you thought about this when you came up with this ideas? How could we solve this in a way that is efficient and is easy for the user to understand why he/she can't configure a crate the way he/she wanted? Some users might get confused about why their crate doesn't work. In fact this would introduce the users with the task of "debugging" a smart crate expression, as some complicated ones could lead to this kind of evaluation cycles. If we limit the crates structure to be a tree (just one parent per crate), we can easily prevent this issues. In fact, in this case the only problematic operation would be to move a crate down one of its child branches. This can be managed just by breaking all the child relations of that create before moving it down one of its branches. We could keep the “is in crate” filter if we don't support it on smart crates queries but just in the search field and as a library column. So, is it really worth to support multiple parent crates? What are the use cases that would benefit from that and which couldn't be achieved in a reasonably easy way with a tree-like crate structure? |
Commented by: daschuer I am not sure if I get the issue correct, but I think it would be the best to separate the crates and smart crates. Think of crates in terms of file system folders containing symlinks to the original files, manually setup by the user. Smart crates are for me sticky filtered filtered views of the library. They do not need to be applied on other filtered views. A related aspect of this bug is the hierarchical view of the library. We have some bugs that propose different nature of such a hierarchical tree. For me, a complete solution will feature this:
|
Commented by: ferranpujolcamins Hi Daniel! Let me focus on the crates, which is what I'm working on :) I agree with you that if this is implemented then we don't that kind of parent child relation of crates I described (child crates only match tracks that are in its parent). Not to confuse this with crates folders which are just a display feature, i.e. they don't change the behavior nor the content of the crates. It is a feature common to both smart and regular crates. As a bonus, selecting a folder could show in the library all the tracks of its sub-folders together, but for this to be useful, smart crates and regular crates should not be in separate sections of the browser (I don't see a problem in that, provided that smart crates have a distinctive icon). But my main concern now is the "member of crate/playlist" filter: |
Commented by: daschuer
Focusing on a doable topic is a good idea and a requirement for a GSoC projekt. All these crates natures are confusing. I hope we can clarify that somehow. "Crates" are for me it is just a place where the user can collect manually some tracks. In the bug title we have "Smart Crates". We may replace it a more more significant term like "Filter" or "Dynamic ... " And a third term we have the fixed library "hierarchy". This might be an auto generated set of filters descending into the natural library structure. At a "Crate", the user is responsible for each single track in the content. We may merge all this together, but IMHO it is a good Idea to keep it separate. For me there is no need to have a filter on "Smart Crates". The user might wish to search for a track in a "smart crate", but such add-hock searches, basically extend the filter phrase of the original saved filter. The "member of crate/playlist" feature can be limited to "crates". If we wish to allow to filter for "member of smart crate", this will just merge the two filter phrases of both smart crates. "Smart playlists": I think we do not need them, since we have already the Auto-DJ crates and the Add Random feature. |
Commented by: ferranpujolcamins Hi Daniel, I agree in almost every point. Thank you for clarifying the concepts, I'll use your terminology from now on. Regarding the member of crate/playlist filter, I'm sorry to keep insisting on the same thing but my concerns are about the user experience. If users want to use this filter with a smart crate and we don't allow it, they might wonder why they can't. Sure we can inform of that in the manual or even show an info pop-up if they try to do this, but they might feel frustrated. On the other hand, if we allow the filter to match smart crates, the issue gets even more difficult. As soon as an user tries to do some smart crate configuration that would lead to the reference cycle situation, we should warn him/her and let him/her know which smart crates are affected. I asked if someone had any idea on how to handle this. |
Commented by: daschuer If users want to use this filter with a smart crate ... I think we can allow it. The interface can be similar to the crate filter, but the backend will be different, since we will probably have no association table for a smart crate. |
Commented by: naught101 Are you sure you posted the right pull request there Be? It doesn't really discuss filtering/searching/smart crates other than filtering in relation to AutoDJ... Daniel: re filtering on smart crates. I think this would be very useful. For example, if I have a "genre:dubstep" smart crate, I would like to be able to filter on key:Am. It doesn't make sense to have 12 key smart-crates for each genre though.
This could probably be done just as easily by having a search-bar history feature, which would operate similarly to a web-browser's form/address bar auto-fill functions (where it provides a drop-down with matches from previous entries). |
Commented by: Be-ing Yes, saving and restoring search queries accomplishes the same thing but doesn't use the same terminology or interface as other software like Serato. IMO it is better because it could potentially be operated easily from the keyboard. The "filter macro" idea seems really useful. I have been thinking it would be useful to be able to name saved search queries so typing those user-defined names would be a shorthand for the full query. So instead of using your mouse to open the menu of saved queries, looking for the one you want, then clicking it, you could just focus the search bar (Ctrl + F with en_US locale, not sure about other locales) and type "midtempo", potentially as part of a larger query. We may want to add a new syntax for invoking saved queries to clearly distinguish them from doing a plain text search, for example maybe "query: midtempo" or "q: midtempo". Keeping a history for queries and autofilling queries are good ideas too! I think making the search query functionality similar to what users are already familiar with from web browsers is a good idea and could make all these functionalities quite intuitive. I don't think we should constrain the design to resembling web browsers because the purpose is not quite the same, but drawing that comparison and taking inspiration from the design of web browsers is a good idea. |
Commented by: ywwg what's the status of this feature / gsoc project? Is it still alive? |
Commented by: ywwg is there any way to break that huge PR into smaller pieces that can be committed one at a time? ~17000 line change is ... a lot |
Commented by: ywwg or can we make it so the library is a runtime or compile-time selectable option? That way the new code can live in the tree but we don't lose the working one |
Fwiw, I think saved searches/smart crates could still be useful to support in a more structured way, e.g. as a node in the sidebar or under crates/playlists. For example: Say I regularly play House tracks in a certain BPM range. In that case it would be nice to be able to add the search to the library, perhaps even with a custom name. Search history feels too ephemeral to me to really serve this use case well, especially if I e.g. want to go back to tweak the query. Personally I use iTunes smart playlists for this, but it would be nice to have a Mixxx-native solution, especially since iTunes doesn't have good support for filtering by key. |
Yep, that's why this bug is still open : ) |
I think most of this can be done with Mixxx filters (incl. OR operator and special BPM filtering in Mixxx 2.5+), just Mixxx has no GUI for this. |
Just drafting up an idea I had, haven't looked at #14182 in detail enough to see whether that covers it: It would be pretty cool if searches could be saved to a smart crate and then edited both in text form and in a structured way (e.g. GUI) in a way that changes are reflected both ways. The search syntax is pretty neat for quickly drafting up a query, but GUIs are nice for making detailed changes, so having both representations would be pretty awesome1. What I'm having in mind is something along the lines of this2:
Footnotes |
Thank you for your input. Please try it out. |
Not trying to bikeshed here, but IMO we should come up with a different name than "Smarties". "Smart Crate" and "Saved Search", for example, sound more professional/polished and would be consistent with existing naming conventions |
Yeah that's a good point, we'd need a 1:1 mapping between search operators and criteria. On the other hand, maybe that would also force us to keep them in sync when adding new criteria?
Yes, only brainstorming here, not sure if the search string is actually a good underlying representation for the query in the database. Aside from being able to recall/edit it directly from the UI, one advantage I see is that we could easily add new operators without changing the schema. It does go a bit against classic database design practice, which discourages non-atomic values, but we already deviate from that principle in ofher placed (e.g. beatmaps). Also, practice has shown that editing the schema is generally rather inconvenient and risks introducing backwards-incompatibilities, so a "more stringly-typed" solution might actually be useful here. Would love to hear some thoughts from the other devs on this though. |
If the name's your only remark, I'l be dancing in the moonlight 'till the break of down 😃 Did you experiment in the meantime? |
Reported by: rryan
Date: 2010-10-15T20:48:14Z
Status: Confirmed
Importance: Wishlist
Launchpad Issue: lp661460
Tags: library
Provide a way to save a current search query as a Smart Playlist/Crate that updates based on that query. Will be more useful once we have search operators. I actually think this only makes sense to do a Smart Crate because a Smart Playlist is essentially a crate.
The text was updated successfully, but these errors were encountered: