Closed
Bug 673157
Opened 14 years ago
Closed 14 years ago
Drag selected text and drop in Firefox will not cause a search
Categories
(Firefox :: General, defect)
Tracking
()
RESOLVED
WONTFIX
People
(Reporter: ebrahim, Assigned: bbondy)
References
Details
Attachments
(2 files, 1 obsolete file)
22.54 KB,
image/png
|
Details | |
11.85 KB,
patch
|
faaborg
:
ui-review-
|
Details | Diff | Splinter Review |
User Agent: Mozilla/5.0 (Windows NT 6.1; rv:8.0a1) Gecko/20110720 Firefox/8.0a1
Build ID: 20110720030844
Steps to reproduce:
I dragged a text from a webpage inside Firefox and dropped that to Firefox tab bar.
Actual results:
Firefox can not detect it is not an URI and is a text and must be searched in my web search engine instead asked from DNS server.
Expected results:
I want dropped text to be searched with my default search engine.
Thanks :)
Assignee | ||
Updated•14 years ago
|
Assignee: nobody → netzen
Assignee | ||
Comment 2•14 years ago
|
||
Description of task:
Now when you drop something that is not a URL on a tab (or at some position in the tabbar to create a new tab), it will do a search with your default search engine.
This behavior is consistent with how the urlbar itself works when something is typed in which is not a URL.
Description of mochitest for task:
- It will simulate a drop of text using all of the different drop types.
- It will add a default search engine so that tests don't get run to google.com and instead go to mochi.test:8888
- For each drop type, it will verify that the loaded page has the right URL (i.e if it is not a URI it should contain the search term info)
- This test fully passes (27 pass) with this patch and fails without this patch applied.
Attachment #549293 -
Flags: review?(mak77)
Assignee | ||
Comment 3•14 years ago
|
||
Had to rebase for mozilla-central changes
Attachment #549293 -
Attachment is obsolete: true
Attachment #549293 -
Flags: review?(mak77)
Attachment #549540 -
Flags: review?(mak77)
Comment 4•14 years ago
|
||
Comment on attachment 549540 [details] [diff] [review]
Rebased patch for drag selected text and drop in Firefox will not cause a search
Review of attachment 549540 [details] [diff] [review]:
-----------------------------------------------------------------
I can give you some feedback but I'm not the best person to review this, gavin is probably the best one considering the code you are touching and the fact I'm not sure if we want to take the privacy implications of passing selected text to a third party without a sort of confirmation (like enter in the locationbar), sure dropping is a clear action but it's easier to wrongly drop something.
This seems to also allow fixup for any other invalid url dropped, that may be unwanted.
::: browser/base/content/tabbrowser.xml
@@ +3855,5 @@
> let dt = event.dataTransfer;
> if (dt.dropEffect != "link")
> return;
>
> + let uri = browserDragAndDrop.drop(event, { });
please avoid changing names or indentation unless it is really necessary, since that is going to:
1. destroy code blame that may be useful
2. increase size of the patch (thus time needed to review it)
Moreover in this case uri makes me think this returns an nsIURI, that it not the case.
@@ +3863,5 @@
> return;
> + }
> +
> + let bgLoad = Services.prefs
> + .getBoolPref("browser.tabs.loadInBackground");
ditto on unneded changes
::: browser/base/content/test/browser_bug673157.js
@@ +41,5 @@
> +var testIndex = -1;
> +// holds the a custom engine which will return results to mochi.test
> +var engine;
> +// Holds the preference service and search service
> +var searchSvc, prefSvc;
you don't need these, use Services shortcuts instead
@@ +53,5 @@
> + function observer(aSubject, aTopic, aData) {
> + switch (aData) {
> + case "engine-added":
> + let engineName = "Bug 673157";
> + gEngine = searchSvc.getEngineByName(engineName);
you don't have any gEngine, you have a global engine var...
@@ +55,5 @@
> + case "engine-added":
> + let engineName = "Bug 673157";
> + gEngine = searchSvc.getEngineByName(engineName);
> + prefSvc = Cc["@mozilla.org/preferences-service;1"]
> + .getService(Ci.nsIPrefBranch);
Use Services.prefs
@@ +56,5 @@
> + let engineName = "Bug 673157";
> + gEngine = searchSvc.getEngineByName(engineName);
> + prefSvc = Cc["@mozilla.org/preferences-service;1"]
> + .getService(Ci.nsIPrefBranch);
> + let pref = "browser.search.defaultenginename";
put this into a const DEFAULT_SEARCHENGINE_PREF
@@ +58,5 @@
> + prefSvc = Cc["@mozilla.org/preferences-service;1"]
> + .getService(Ci.nsIPrefBranch);
> + let pref = "browser.search.defaultenginename";
> + oldDefaultSearch = prefSvc.getCharPref(pref);
> + prefSvc.setCharPref(pref, engineName);
rather here use registerCleanupFunction to restore the original value, you won't need a global variable and if your test timeouts it will ensure next tests won't fail due to this
@@ +69,5 @@
> + }
> +
> + // Obtain the search service and get what the URL bar should contain
> + searchSvc = Components.classes["@mozilla.org/browser/search-service;1"]
> + .getService(Components.interfaces.nsIBrowserSearchService);
Services.search
@@ +73,5 @@
> + .getService(Components.interfaces.nsIBrowserSearchService);
> +
> + // Add an engine that will have search results in the http://mochi.test host
> + Services.obs.addObserver(observer, "browser-search-engine-modified", false);
> + let u = "http://mochi.test:8888/browser/browser/base/content/test/673157.xml";
name variables in some meaningful way... btw this should be a const
@@ +80,5 @@
> +}
> +
> +function test() {
> + waitForExplicitFinish();
> + initSearchEngine(); // will also kick off the tests by calling initTests()
I'd rather add a callback argument so it's invoked like initSearchEngine(initTests);
@@ +89,5 @@
> + // Setup a series of tests for each drag type for dropping on the tab bar
> + var mimeTypes = ["text/plain", "text/unicode", "text/x-moz-url"];
> + var effects = ["move", "copy", "link"];
> + for (e in effects) {
> + for (m in mimeTypes) {
for good code practice, don't use for..in on arrays
@@ +160,5 @@
> + ++testIndex;
> + var currentTest = tests[testIndex];
> + if (!currentTest) {
> + searchSvc.removeEngine(gEngine);
> + let pref = "browser.search.defaultenginename";
you use this twice, a const can't really hurt
@@ +166,5 @@
> + finish();
> + return;
> + }
> +
> + gBrowser.addEventListener("load", validateTest, true);
would be better to wait for load on your specific tab.
@@ +168,5 @@
> + }
> +
> + gBrowser.addEventListener("load", validateTest, true);
> +
> + // Simulate a dorp of the passed in term
typo: dorp
Attachment #549540 -
Flags: review?(mak77) → review?(gavin.sharp)
Assignee | ||
Comment 5•14 years ago
|
||
Thanks for the review comments, I read them over. Before applying them I wait for Gavin's thoughts on the task itself.
How other browsers work:
Chrome12: Supports drop of text and hyperlinks, text goes to default search engine.
IE9: supports drop of hyperlinked URLs but not text URLs nor text.
Safari5.1: Supports dropped hyperlinks and text URLs but not text searches.
Opera11.5: Does not support drag and drop at all on tabs.
Also worth noting, in Firefox, when you drop a URL in the URL bar it loads the site. When you drop text in the URL bar it accepts the text but does not start the search.
For what it's worth, this is a feature I would use, but I understand your concerns.
Assignee | ||
Comment 6•14 years ago
|
||
Just an idea, perhaps we could enable this via a preference that is disabled by default.
Comment 8•14 years ago
|
||
Why having this feature disabled ?
Assignee | ||
Comment 9•14 years ago
|
||
Disabled was just said based on Comment 4. I personally like the feature.
Reporter | ||
Comment 10•14 years ago
|
||
With fix of 673080 (thanks for it!), seems Firefox sometimes accepts drop selected text (not link) from an external application and sometimes not (not for search of course!).
I just want mention that drop text (not link) from an external application (e.g. google talk) must be considered in patches and tests.
Thanks :)
Assignee | ||
Comment 11•14 years ago
|
||
ebraminio, that is the patch provided in this task but it seems there are some privacy implications as per Comment 4 that need approval before we can do this.
Reporter | ||
Comment 12•14 years ago
|
||
Oh, okay, I understand. I just wanted combination of this request and my request on 673080 that together mean, drop texts(not links) from external application to Firefox, considered in tests, nothing more :)
However I can not understand what is difference of making query from DNS Server with from default search engine in view of user privacy..., but not important :)
Thank you :)
Assignee | ||
Comment 13•14 years ago
|
||
New drag and drop stuff in HTML5 allows you to simply drop a file and the page can read the contents of the file even. So I don't think that dropping text to go to default search engine is a big deal personally.
Awaiting your input whenever you get a chance Gavin for want/don't want this as per Comment 0.
Comment 14•14 years ago
|
||
Comment on attachment 549540 [details] [diff] [review]
Rebased patch for drag selected text and drop in Firefox will not cause a search
I'm not really the best person to answer that question - someone from the UX team probably is.
Attachment #549540 -
Flags: ui-review?(faaborg)
Comment 15•14 years ago
|
||
Comment on attachment 549540 [details] [diff] [review]
Rebased patch for drag selected text and drop in Firefox will not cause a search
I'm going to recommend that we go with dragging the text to the search or location bars. The tab strip seems like it is more likely to pick up unintentional drops than intentional ones, and firing the search off without a more explicit action (like the go or google button) could create some unintentional data leakage that user's wouldn't always appreciate.
Attachment #549540 -
Flags: ui-review?(faaborg) → ui-review-
Assignee | ||
Comment 16•14 years ago
|
||
Thanks for the input Alex.
Marking this as WONTFIX based on comment 15.
Status: NEW → RESOLVED
Closed: 14 years ago
Resolution: --- → WONTFIX
Reporter | ||
Comment 17•13 years ago
|
||
Okay. Can we have this as an option in Firefox (in about:config for example) or an add-on?
Thanks :)
Updated•13 years ago
|
Attachment #549540 -
Flags: review?(gavin.sharp)
Assignee | ||
Comment 18•13 years ago
|
||
ebraminio: Not as an option in about:config built in, but someone is free to do an addon for it.
Assignee | ||
Comment 19•13 years ago
|
||
I cannot myself but if you find an extension developer then they can look at the attached obsolte patch as a starting point.
Comment 20•13 years ago
|
||
What about a security confirmation ? In which we could say yes just for this dragging. And we could say yes once and for all in the prefs or in a checkbox of this security confirmation.
You need to log in
before you can comment on or make changes to this bug.
Description
•