fx115: Changes for word processor plugin support

This commit is contained in:
Adomas Venčkauskas 2024-03-28 10:45:18 +02:00 committed by Dan Stillman
parent 7276b8c50d
commit dca7dcccab
3 changed files with 27 additions and 30 deletions

View file

@ -49,7 +49,7 @@
<vbox id="zotero-bibliography-container">
<groupbox>
<label><html:h2>&zotero.bibliography.style.label;</html:h2></label>
<richlistbox id="style-listbox" onselect="Zotero_File_Interface_Bibliography.styleChanged()" flex="1"/>
<richlistbox id="style-listbox" onselect="Zotero_File_Interface_Bibliography.styleChanged()"/>
<hbox align="right">
<label id="manage-styles" class="text-link"
onclick="Zotero_File_Interface_Bibliography.manageStyles()">&zotero.bibliography.manageStyles;</label>

View file

@ -71,6 +71,12 @@ const TEMPLATE_VERSIONS = {
const MENDELEY_URI_RE = /^http:\/\/www\.mendeley\.com\/documents\/\?uuid=(.*)/;
const PLUGIN_PATHS = {
LibreOffice: 'chrome://zotero-libreoffice-integration-components/content/zoteroLibreOfficeIntegration.mjs',
WinWord: 'chrome://zotero-winword-integration/content/zoteroWinWordIntegration.mjs',
MacWord: 'chrome://zotero-macword-integration/content/zoteroMacWordIntegration.mjs'
};
Zotero.Integration = new function() {
Components.utils.import("resource://gre/modules/Services.jsm");
@ -84,20 +90,18 @@ Zotero.Integration = new function() {
* Initialize LibreOffice, Word for Mac and Word for Windows plugin components.
*/
this.init = function () {
// TEMP
return;
if (Zotero.test) return;
let classNames = ["@zotero.org/Zotero/integration/initializer?agent=LibreOffice;1"];
let entryPoints = [PLUGIN_PATHS.LibreOffice];
if (Zotero.isMac) {
classNames.push("@zotero.org/Zotero/integration/installer?agent=MacWord;1")
} else if (Zotero.isWindows) {
classNames.push("@zotero.org/Zotero/integration/initializer?agent=WinWord;1");
entryPoints.push(PLUGIN_PATHS.MacWord);
}
for (let className of classNames) {
else if (Zotero.isWindows) {
entryPoints.push(PLUGIN_PATHS.WinWord);
}
for (let entryPoint of entryPoints) {
try {
Components.classes[className]
.getService(Components.interfaces.nsISupports);
const { init } = ChromeUtils.importESModule(entryPoint);
init();
}
catch (e) {
Zotero.logError(e);
@ -221,23 +225,20 @@ Zotero.Integration = new function() {
}
});
this.getApplication = function(agent, command, docId) {
this.getApplication = function (agent, command, docId) {
if (agent == 'http') {
return new Zotero.HTTPIntegrationClient.Application();
}
// Try to load the appropriate Zotero component; otherwise display an error
var component
try {
var componentClass = "@zotero.org/Zotero/integration/application?agent="+agent+";1";
Zotero.debug("Integration: Instantiating "+componentClass+" for command "+command+(docId ? " with doc "+docId : ""));
try {
return Components.classes[componentClass]
.getService(Components.interfaces.zoteroIntegrationApplication);
} catch (e) {
return Components.classes[componentClass]
.getService(Components.interfaces.nsISupports).wrappedJSObject;
// Replace MacWord2016 and MacWord16 with just MacWord.
agent = agent.startsWith('MacWord') ? 'MacWord' : agent;
var entryPoint = PLUGIN_PATHS[agent];
Zotero.debug("Integration: Instantiating "+agent+" plugin handler for command "+command+(docId ? " with doc "+docId : ""));
const { Application } = ChromeUtils.importESModule(entryPoint);
return new Application();
}
} catch(e) {
catch (e) {
throw new Zotero.Exception.Alert("integration.error.notInstalled",
[], "integration.error.title");
}

View file

@ -29,11 +29,7 @@
var EXPORTED_SYMBOLS = ["ZoteroPluginInstaller"];
var Zotero = Components.classes["@zotero.org/Zotero;1"]
// Currently uses only nsISupports
//.getService(Components.interfaces.chnmIZoteroService).
.getService(Components.interfaces.nsISupports)
.wrappedJSObject;
var { Zotero } = ChromeUtils.importESModule("chrome://zotero/content/zotero.mjs");
Components.utils.import("resource://gre/modules/Services.jsm");