From 4c09cbb7ac1ccc33cd1539e76e53191e000e08ce Mon Sep 17 00:00:00 2001 From: Simon Kornblith Date: Wed, 6 May 2009 07:58:28 +0000 Subject: [PATCH] - fix progress window issues with lookup and scraping - prevent multiple lookups and fix error dialog --- chrome/content/zotero/lookup.js | 16 ++++++++++++---- chrome/content/zotero/lookup.xul | 4 ++-- chrome/content/zotero/xpcom/progressWindow.js | 2 +- chrome/content/zotero/xpcom/translate.js | 2 ++ 4 files changed, 17 insertions(+), 7 deletions(-) diff --git a/chrome/content/zotero/lookup.js b/chrome/content/zotero/lookup.js index 7efa58333d..7f7a9c5a64 100644 --- a/chrome/content/zotero/lookup.js +++ b/chrome/content/zotero/lookup.js @@ -1,6 +1,7 @@ const Zotero_Lookup = new function () { this.accept = function() { document.getElementById("progress").setAttribute("status", "animate"); + document.getElementById("accept-button").disabled = true; var identifier = document.getElementById("lookup-textbox").value; if(identifier.substr(0, 3) == "10.") { // DOI @@ -17,16 +18,18 @@ const Zotero_Lookup = new function () { } } - translate = new Zotero.Translate("search", true, false); + var translate = new Zotero.Translate("search", true, false); translate.setSearch(item); + // be lenient about translators var translators = translate.getTranslators(); - Zotero.debug(translators[0].label); translate.setTranslator(translators); + translate.setHandler("done", function(translate, success) { if(success) { window.close(); } else { + document.getElementById("accept-button").disabled = undefined; document.getElementById("progress").setAttribute("status", "error"); var prompts = Components.classes["@mozilla.org/embedcomp/prompt-service;1"] .getService(Components.interfaces.nsIPromptService); @@ -34,10 +37,15 @@ const Zotero_Lookup = new function () { Zotero.getString("lookup.failure.description")); } }); + + var saveLocation = false; try { - var saveLocation = window.opener.ZoteroPane.getSelectedCollection(); + saveLocation = window.opener.ZoteroPane.getSelectedCollection(); } catch(e) {} - translate.setHandler("itemDone", function(obj, item) { window.opener.Zotero_Browser.itemDone(obj, item, saveLocation) }); + translate.setHandler("itemDone", function(obj, item) { + if(saveLocation) saveLocation.addItem(item.getID()); + }); + translate.translate(); return false; } diff --git a/chrome/content/zotero/lookup.xul b/chrome/content/zotero/lookup.xul index c284eed8f3..6e1ebef950 100644 --- a/chrome/content/zotero/lookup.xul +++ b/chrome/content/zotero/lookup.xul @@ -20,7 +20,7 @@ -