/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is mozilla.org code. * * The Initial Developer of the Original Code is * Netscape Communications Corporation. * Portions created by the Initial Developer are Copyright (C) 1998 * the Initial Developer. All Rights Reserved. * * Contributor(s): * Alec Flett * Ben Goodger * Mike Pinkerton * Blake Ross * * Alternatively, the contents of this file may be used under the terms of * either of the GNU General Public License Version 2 or later (the "GPL"), * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ /* * - [ Dependencies ] --------------------------------------------------------- * utilityOverlay.js: * - gatherTextUnder */ var pref = null; pref = Components.classes["@mozilla.org/preferences-service;1"] .getService(Components.interfaces.nsIPrefBranch); // Prefill a single text field function prefillTextBox(target) { // obtain values to be used for prefilling var walletService = Components.classes["@mozilla.org/wallet/wallet-service;1"].getService(Components.interfaces.nsIWalletService); var value = walletService.WALLET_PrefillOneElement(window.content, target); if (value) { // result is a linear sequence of values, each preceded by a separator character // convert linear sequence of values into an array of values var separator = value[0]; var valueList = value.substring(1, value.length).split(separator); target.value = valueList[0]; /* * Following code is a replacement for above line. In the case of multiple values, it * presents the user with a dialog containing a list from which he can select the value * he wants. However it is being commented out for now because of several problems, namely * * 1. There is no easy way to put localizable strings for the title and message of * the dialog without introducing a .properties file which currently doesn't exist * 2. Using blank title and messages as shown below have a problem because a zero-length * title is being displayed as some garbage characters (which is why the code below * has a title of " " instead of ""). This is a separate bug which will have to be * investigated further. * 3. The current wallet tables present alternate values for items such as shipping * address -- namely billing address and home address. Up until now, these alternate * values have never been a problem because the preferred value is always first and is * all the user sees when doing a prefill. However now he will be presented with a * list showing all these values and asking him to pick one, even though the wallet * code was clearly able to determine that he meant shipping address and not billing * address. * 4. There is a relatively long delay before the dialog come up whereas values are * filled in quickly when no dialog is involved. * * Once this feature is checked in, a separate bug will be opened asking that the above * problems be examined and this dialog turned on if (valueList.length == 1) { // only one value, use it for prefilling target.value = valueList[0]; } else { // more than one value, have user select the one he wants var promptService = Components.classes["@mozilla.org/embedcomp/prompt-service;1"].getService(); promptService = promptService.QueryInterface(Components.interfaces.nsIPromptService); var position = {}; var title = " "; var message = ""; var ok = promptService.select (window, title, message, valueList.length, valueList, position) if (ok) { target.value = valueList[position.value]; } } * End of commented out code */ } } function hrefForClickEvent(event) { var target = event.target; var linkNode; var local_name = target.localName; if (local_name) { local_name = local_name.toLowerCase(); } var isKeyPress = (event.type == "keypress"); switch (local_name) { case "a": case "area": case "link": if (target.hasAttribute("href")) linkNode = target; break; case "input": if ((event.target.type == "text") // text field && !isKeyPress // not a key event && event.detail == 2 // double click && event.button == 0 // left mouse button && event.target.value.length == 0) { // no text has been entered prefillTextBox(target); // prefill the empty text field if possible } break; default: linkNode = findParentNode(event.originalTarget, "a"); // cannot be nested. So if we find an anchor without an // href, there is no useful around the target if (linkNode && !linkNode.hasAttribute("href")) linkNode = null; break; } var href; if (linkNode) { href = new XPCNativeWrapper(linkNode, "href").href; } else { // Try simple XLink linkNode = target; while (linkNode) { if (linkNode.nodeType == Node.ELEMENT_NODE) { var wrapper = new XPCNativeWrapper(linkNode, "getAttributeNS()"); href = wrapper.getAttributeNS("http://www.w3.org/1999/xlink", "href"); break; } linkNode = linkNode.parentNode; } if (href && href != "") { var baseURI = new XPCNativeWrapper(linkNode, "baseURI").baseURI; href = makeURLAbsolute(baseURI, href); } } return href; } // Called whenever the user clicks in the content area, // except when left-clicking on links (special case) // should always return true for click to go through function contentAreaClick(event) { var isKeyPress = (event.type == "keypress"); var href = hrefForClickEvent(event); if (href) { if (isKeyPress) { openNewTabWith(href, true, event.shiftKey); event.preventBubble(); } else { handleLinkClick(event, href, null); } return true; } if (pref && !isKeyPress && event.button == 1 && !event.getPreventDefault() && !findParentNode(event.originalTarget, "scrollbar") && pref.getBoolPref("middlemouse.contentLoadURL")) { if (middleMousePaste(event)) { event.preventBubble(); } } return true; } function openNewTabOrWindow(event, href, sendReferrer) { // should we open it in a new tab? if (pref && pref.getBoolPref("browser.tabs.opentabfor.middleclick")) { openNewTabWith(href, sendReferrer, event.shiftKey); event.preventBubble(); return true; } // should we open it in a new window? if (pref && pref.getBoolPref("middlemouse.openNewWindow")) { openNewWindowWith(href, sendReferrer); event.preventBubble(); return true; } // let someone else deal with it return false; } function handleLinkClick(event, href, linkNode) { // Make sure we are allowed to open this URL urlSecurityCheck(href, document); switch (event.button) { case 0: // if left button clicked if (event.metaKey || event.ctrlKey) { // and meta or ctrl are down if (openNewTabOrWindow(event, href, true)) return true; } var saveModifier = true; if (pref) { try { saveModifier = pref.getBoolPref("ui.key.saveLink.shift"); } catch(ex) { } } saveModifier = saveModifier ? event.shiftKey : event.altKey; if (saveModifier) { // if saveModifier is down saveURL(href, linkNode ? gatherTextUnder(linkNode) : ""); return true; } if (event.altKey) // if alt is down return true; // do nothing return false; case 1: // if middle button clicked if (openNewTabOrWindow(event, href, true)) return true; break; } return false; } function middleMousePaste( event ) { var url = readFromClipboard(); if (!url) return false; url = getShortcutOrURI(url); // On ctrl-middleclick, open in new window or tab. Do not send referrer. if (event.ctrlKey) { // fix up our pasted URI in case it is malformed. const nsIURIFixup = Components.interfaces.nsIURIFixup; if (!gURIFixup) gURIFixup = Components.classes["@mozilla.org/docshell/urifixup;1"] .getService(nsIURIFixup); url = gURIFixup.createFixupURI(url, nsIURIFixup.FIXUP_FLAGS_MAKE_ALTERNATE_URI).spec; return openNewTabOrWindow(event, url, false); } // If ctrl wasn't down, then just load the url in the current win/tab. if (url != "about:blank") { gURLBar.value = url; } loadURI(url); event.preventBubble(); return true; } function makeURLAbsolute( base, url ) { // Construct nsIURL. var ioService = Components.classes["@mozilla.org/network/io-service;1"] .getService(Components.interfaces.nsIIOService); var baseURI = ioService.newURI(base, null, null); return ioService.newURI(baseURI.resolve(url), null, null).spec; }