aboutsummaryrefslogtreecommitdiffstats
path: root/background_scripts/completion.coffee
AgeCommit message (Collapse)Author
2015-05-17For shortened URLs, do not consider case.Stephen Blott
This ensures that URLs which differ only in their case are considered duplicates, hence one is dropped.
2015-05-17TabToOpen: remove console.log.Stephen Blott
2015-05-17TabToOpen: turn off relevancy debugging.Stephen Blott
2015-05-17TabToOpen: more tidy up pre-PR (additional comments).Stephen Blott
2015-05-17TabToOpen: more tidy up pre-PR.Stephen Blott
2015-05-17TabToOpen: tidy up pre-PR.Stephen Blott
2015-05-17TabToOpen: reactivate custom search engines.Stephen Blott
When the user begins editing the inserted text from a custom-search-engine suggestion, we reactivate the original custom-search-engine mode.
2015-05-17TabToOpen: reactivate previous custom search engine.Stephen Blott
Note: There's still an unpleasant flicker when this happens. TBD: Fix this.
2015-05-17TabToOpen: use search-engine description as suggestion type.Stephen Blott
2015-05-17TabToOpen: insert queries for custom search engines.Stephen Blott
2015-05-17TabToOpen: tab to open vomnibar.Stephen Blott
`o` then `Tab` opens the vomnibar completionlist with history completions (the only completions) ranked by recently only. Hence, the most recent requests are at the top. This is a (far) simpler approach than #1662 which catches the most important use case (repeat a search with an edited query).
2015-05-16Apply decodeURI when shortening URLs.Stephen Blott
If the URL contains a query term such as vierwaldstättersee, then we render the URL encoded version in the vomnibar. It looks considerably nicer to render URL-decoded version.
2015-05-16Merge pull request #1663 from ↵Stephen Blott
smblott-github/search-completion-with-regular-relevancy Search completion with regular relevancy calculation
2015-05-16Search completion; tweak comments.Stephen Blott
2015-05-16Refactor query extraction to Utils.extractQuery().Stephen Blott
If we go with this and #1662, then we can share the utility.
2015-05-16Add insertText visual indicator.Stephen Blott
2015-05-16Search completion; reinstate relevancy-score filter.Stephen Blott
See the comment in the diff. This test was in a previous version, but was dropped because with eb0e2964fca5ef2eccc06607944df6b208b2b99f, it was (thought to be) no longer possible to filter by relevancy score since we don't know what the relevancy score will be. The filter is reinstated here because we use the simple idea that, whatever relevancy scores are assigned to completion suggestions, they will be less than the score for a perfect suggestion.
2015-05-16Search completion; alternative relevancy scoring.Stephen Blott
This is an alternative relevancy-scoring scheme for search completion. It attempts to address the "clumping" effect described in #1651 by: - Using the regular relevancy scoring scheme (but based only on the title (so, not the URL). - Weighting relevancy scores (exponentially) by the length the query (so, search suggestions score higher as the length of the query gets longer). - Weighting suggestions (fairly moderately) by their position in the suggestion list as returned by the completion engine. We generally want to retain this ordering. - Applying a calibration fudge factor to roughly calibrate (boost) search-completion suggestions with those from other search engines.
2015-05-15Add a couple more useless Google search parameters.Stephen Blott
2015-05-15Add a couple more useless Google search parameters.Stephen Blott
2015-05-15Use query text as title, if necessary and possible.Stephen Blott
2015-05-15Better explaination of query-term extract.Stephen Blott
2015-05-15Add comment explaining why we use try/catch.Stephen Blott
2015-05-15Add ? to the list of query-term separators.Stephen Blott
2015-05-15Give the vomnibar a (kind of) history (autoSelect).Stephen Blott
If we insert the text of hostory completions into the vomnibar input, then when the completions change, we'll pick up the arbitrary text of whatever happens to be the current selection. So we need to always reset the selection when the vomnibar updates. This eliminates the need for the previous autoSelect logic.
2015-05-15Give the vomnibar a (kind of) history (relevancy).Stephen Blott
2015-05-15Give the vomnibar a (kind of) history.Stephen Blott
2015-05-14Search completion; add additional filtering stage.Stephen Blott
Two things: 1. Do not fire off requests to completion engines if the relevancy score they are assigned wouldn't be enough to be included. 2. Fix off-by-one error in prepareSuggestions.
2015-05-14Add a couple of Google search perameter filters.Stephen Blott
2015-05-14Merge branch 'vomnibar-filter'Stephen Blott
2015-05-14Tweak comments.Stephen Blott
2015-05-14Search completion; remove console.log().Stephen Blott
2015-05-13Search completion; complete rework of UX.Stephen Blott
This is a major reworking of how the search-completion systems works. Previously, the goal had been to emulate roughly how chrome itself handles completions. This has turned out to be a bad idea: - It creates issues around what it means to hit <Enter> in the vomnibar. - And the contents of the vomnibar change asynchronously (because we fetch completions asynchronously), so it creates the possibility that the effect of <Enter> changes depending on how long the user waits before typing <Enter>. All of that is bad. This commit changes things: - In normal omni mode, the vomnibar looks and behaves pretty much like it always has, just with some extra completion suggestions thrown in. - And in custom-search-engine mode it also behaves mostly as it has previously, but (again, possibly) with some extra completion suggestions thrown in, and with many useless suggestions excluded. This is all far more Vimium-like than Chrome-like.
2015-05-13Search completion; ensure wighting fact stays within bounds.Stephen Blott
2015-05-13Search completion; tweak constants.Stephen Blott
2015-05-13Search completion; yet another reworking.Stephen Blott
I'm having difficulty getting all aspects of the UX right for all combinations of modes. This is the latest attempt. The main goal is to mimic Chrome to the greatest extent possible. There will be more to come, but I think this is an improvement.
2015-05-13Domain completer: no completions for "w ".Stephen Blott
If the input is "w ", the user is going for something like "w query terms" (a custom search engine). So the domain completer should not offer completions if the user has finished the first word.
2015-05-13Search completion; rework handling when no selection.Stephen Blott
This makes the behaviour consistent between custom and non-custom searches when there is no selection in the vomnibar (omni-mode only). Approach: - When there is no selection in the vomnibar, we *always* send the query to to background completer (that is, both for default searches and for custom searches) and ask the completer to provide only the primary suggestion. The primary suggestion is just what you get if you append the query terms to the search URL (default or custom). We then immediately open the first response. The round trip for default searches isn't strictly necessary. However, this uniform approach disentangles some nasty logic in the vomnibar when we're trying to handle several cases (default or custom search, with or without prompted text, with or without any suggestions at all). The extra round trip simplifies the logic to such a great extend that it's worth it.
2015-05-12Rework some aspects of search engine completion.Stephen Blott
- We arrange that: - for custom search engines, or - for other searches where there is at least one match that match is at the top of the list (relevancy 1). This top suggestion will the suggestion which will be used to popuplated the promted text in the vomnibar. If we arrange that it's at the top of the list, then it is also the text that we get in the vomnibar if we hit <Tab>. This leaves us in the position where: - If the user wants just the text they've typed, then they hit <Enter>. - If they want all of the text in the input (including the prompted text), then they hit <Tab>, <Enter>. This is a very natural UX. It feels like <Tab> is filling in the prompted text, although all it's really doing is choosing a suggestion (the first one), as it always has done. There is one small catch. We need to avoid a clash with the domain completer, which also likes to force its suggestion to the top of the list. There's a test for that case. Basically, we can apply this trick if it's a custom search, or if the user has finished typing the first query term.
2015-05-12Simplify and filter vomnibar URLs (tweaks).Stephen Blott
2015-05-12Tweak vomnibar for custom search.Stephen Blott
This applies only to custom searches for which we have a completion engine. Status quo: Exclusively offer suggestions generated by this completer. This PR: Also include other suggestions (e.g. history) if their URL and query match this custom search engine.
2015-05-12Simplify and filter vomnibar URLs.Stephen Blott
- Remove various bits of URL fluff (the scheme, trailing URL separators). - Remove various unhelpful Google search parameters. - Filter for duplicates (based on the simplified URL).
2015-05-11Search completion; fix typos and small bugs.Stephen Blott
Bugs: - The serch-engine completer wasn't being configured correctly for the case when we don't have a completion engine. - Handle Control-Shift-Left/Right in vomnibar. Also: better comments.
2015-05-11Search completion; fix relevancy calculation.Stephen Blott
2015-05-11Search completion; add weigthing option.Stephen Blott
2015-05-11Search completion; pre-merge tweaks.Stephen Blott
2015-05-11Merge branch 'search-engine-completion-v2' into search-engine-completion-v5Stephen Blott
Conflicts: background_scripts/completion.coffee
2015-05-11Search completion; more efficient filtering.Stephen Blott
2015-05-11Merge branch 'search-engine-completion-v2' into search-engine-completion-v5Stephen Blott
2015-05-11Domain completer should not complete with trailing whitespace.Stephen Blott