-
-
Notifications
You must be signed in to change notification settings - Fork 295
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
26 changed files
with
308 additions
and
206 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -11,7 +11,7 @@ import type Bluebird from 'bluebird' | |
const Ready = Zotero.Promise.defer() | ||
|
||
import { Shim } from './os' | ||
import { is7, isBeta } from './client' | ||
import { is7 } from './client' | ||
const $OS = is7 ? Shim : OS | ||
|
||
if (is7) Components.utils.importGlobalProperties(['FormData', 'indexedDB']) | ||
|
@@ -769,19 +769,15 @@ export class BetterBibTeX { | |
}) | ||
|
||
if (is7) { | ||
if (Zotero.ItemTreeManager.registerColumn && !isBeta) { | ||
log.error('error: registerColumn has landed in release, please migrate') | ||
// const columnDataKey = await Zotero.ItemTreeManager.registerColumn({...}) | ||
} | ||
await Zotero.ItemTreeManager.registerColumns([{ | ||
const columnDataKey = await Zotero.ItemTreeManager.registerColumn({ | ||
dataKey: 'citationKey', | ||
label: l10n.localize('better-bibtex_zotero-pane_column_citekey'), | ||
pluginID: '[email protected]', | ||
dataProvider: (item, _dataKey) => { | ||
const citekey = Zotero.BetterBibTeX.KeyManager.get(item.id) | ||
return citekey ? `${ citekey.citationKey }${ citekey.pinned ? icons.pin : '' }`.trim() : '' | ||
}, | ||
}]) | ||
}) | ||
|
||
const rowID = Zotero.ItemPaneManager.registerInfoRow({ | ||
rowID: 'better-bibtex-citation-key', | ||
|
@@ -803,7 +799,8 @@ export class BetterBibTeX { | |
|
||
Events.on('items-changed', () => { | ||
Zotero.ItemPaneManager.refreshInfoRow(rowID) | ||
// if (!ZoteroPane.itemPane.itemsView._columnPrefs[columnDataKey].hidden) Zotero.ItemTreeManager.refreshColumns() | ||
// eslint-disable-next-line no-underscore-dangle | ||
if (!Zotero.getActiveZoteroPane().itemPane.itemsView._columnPrefs[columnDataKey].hidden) Zotero.ItemTreeManager.refreshColumns() | ||
}) | ||
} | ||
|
||
|
@@ -862,69 +859,6 @@ export class BetterBibTeX { | |
} | ||
|
||
async loadUI(win: Window): Promise<void> { | ||
if (is7 && !isBeta) { | ||
// const show = (item: ZoteroItem): { id: number, type: string, citekey: string } | boolean => item ? { id: item.id, type: Zotero.ItemTypes.getName(item.itemTypeID), citekey: item.getField('citationKey') as string } : false | ||
if (Zotero.ItemPaneManager.registerInfoRow) { | ||
log.error('Zotero.ItemPaneManager.registerInfoRow is GA') | ||
} | ||
else { | ||
let $done: () => void | ||
Zotero.ItemPaneManager.registerSection({ | ||
paneID: 'betterbibtex-section-citationkey', | ||
pluginID: '[email protected]', | ||
header: { | ||
l10nID: 'better-bibtex_item-pane_section_header', | ||
icon: `${ rootURI }content/skin/item-section/header.svg`, | ||
}, | ||
sidenav: { | ||
l10nID: 'better-bibtex_item-pane_section_sidenav', | ||
icon: `${ rootURI }content/skin/item-section/sidenav.svg`, | ||
}, | ||
bodyXHTML: 'Citation Key <html:input type="text" data-itemid="" id="better-bibtex-citation-key" readonly="true" style="flex: 1" xmlns:html="http://www.w3.org/1999/xhtml"/><html:span id="better-bibtex-citation-key-pinned"/>', | ||
// onRender: ({ body, item, editable, tabType }) => { | ||
onRender: ({ body, item, setSectionSummary }) => { | ||
const citekey = Zotero.BetterBibTeX.KeyManager.get(item.id) || { citationKey: '', pinned: false } | ||
const textbox = body.querySelector('#better-bibtex-citation-key') | ||
body.style.display = 'flex' | ||
// const was = textbox.dataset.itemid || '<node>' | ||
textbox.value = citekey.citationKey | ||
textbox.dataset.itemid = citekey.citationKey ? `${ item.id }` : '' | ||
|
||
const pinned = body.querySelector('#better-bibtex-citation-key-pinned') | ||
pinned.textContent = citekey.pinned ? icons.pin : '' | ||
|
||
setSectionSummary(citekey || '') | ||
}, | ||
onInit: ({ body, refresh }) => { | ||
$done = Events.on('items-changed', ({ items }) => { | ||
const textbox = body.querySelector('#better-bibtex-citation-key') | ||
const itemID = textbox.dataset.itemid ? parseInt(textbox.dataset.itemid) : undefined | ||
const displayed: ZoteroItem = textbox.dataset.itemid ? items.find(item => item.id === itemID) : undefined | ||
if (displayed) refresh() | ||
}) | ||
}, | ||
onItemChange: ({ setEnabled, body, item }) => { | ||
const textbox = body.querySelector('#better-bibtex-citation-key') | ||
if (item.isRegularItem() && !item.isFeedItem) { | ||
const citekey = item.getField('citationKey') | ||
// const was = textbox.dataset.itemid | ||
textbox.dataset.itemid = citekey ? `${ item.id }` : '' | ||
textbox.value = citekey || '\u274C' | ||
setEnabled(true) | ||
} | ||
else { | ||
textbox.dataset.itemid = '' | ||
setEnabled(false) | ||
} | ||
}, | ||
onDestroy: () => { | ||
$done?.() | ||
$done = undefined | ||
}, | ||
}) | ||
} | ||
} | ||
|
||
try { | ||
await newZoteroPane(win) | ||
if (!is7) await newZoteroItemPane(win) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
import { log } from './logger/simple' | ||
import { log } from './logger' | ||
|
||
const seconds = 1000 | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,72 +1,109 @@ | ||
/* eslint-disable @typescript-eslint/no-empty-function, no-restricted-syntax */ | ||
/* eslint-disable @typescript-eslint/explicit-module-boundary-types, @typescript-eslint/no-unsafe-return, @typescript-eslint/no-empty-function, no-restricted-syntax */ | ||
|
||
import type { Translators as Translator } from '../typings/translators' | ||
declare const TranslationWorker: { job: Translator.Worker.Job } | ||
import { $dump, run } from './logger/simple' | ||
declare const Zotero: any | ||
|
||
import { stringify } from './stringify' | ||
import { worker } from './client' | ||
import * as client from './client' | ||
const version = require('./../gen/version.js') | ||
export const run = `<${version} ${client.run}>` | ||
|
||
function toString(obj): string { | ||
try { | ||
if (typeof obj === 'string') return obj | ||
return stringify(obj, 0) | ||
} | ||
catch (err) { | ||
return stringify(err, 0) | ||
} | ||
declare const dump: (msg: string) => void | ||
|
||
export const discard = { | ||
log(): void {}, | ||
error(): void {}, | ||
warn(): void {}, | ||
debug(): void {}, | ||
info(): void {}, | ||
clear(): void {}, | ||
dir(): void {}, | ||
table(): void {}, | ||
} | ||
|
||
export const log = new class Logger { | ||
protected timestamp: number | ||
public prefix = '' | ||
function stringifyXPCOM(obj): string { | ||
if (!obj.QueryInterface) return '' | ||
if (obj.message) return `[XPCOM error ${ obj.message }]` | ||
if (obj.name) return `[XPCOM object ${ obj.name }]` | ||
return '[XPCOM object]' | ||
} | ||
|
||
private format({ error = false }, msg) { | ||
if (Array.isArray(msg)) msg = msg.map(toString).join(' ') | ||
function stringifyError(obj) { | ||
if (obj instanceof Error) return `[error: ${ obj.message || '<unspecified error>' }\n${ obj.stack }]` | ||
// guess it is an errorevent | ||
if (obj.error instanceof Error && obj.message) return `[errorevent: ${ obj.message } ${ stringifyError(obj.error) }]` | ||
if (typeof ErrorEvent !== 'undefined' && obj instanceof ErrorEvent) return `[errorevent: ${ obj.message || '<unspecified errorevent>' }]` | ||
return '' | ||
} | ||
|
||
let prefix = '' | ||
if (worker) { | ||
prefix += ' worker' | ||
if (typeof TranslationWorker !== 'undefined') prefix += `:${ TranslationWorker.job.translator }` | ||
function replacer() { | ||
const seen = new WeakSet | ||
return (key, value) => { | ||
if (typeof value === 'object' && value !== null) { | ||
if (seen.has(value)) return '[Circular]' | ||
seen.add(value) | ||
} | ||
|
||
if (error) prefix += ' error:' | ||
if (value === null) return value | ||
if (value instanceof Set) return [...value] | ||
if (value instanceof Map) return Object.fromEntries(value) | ||
|
||
return `{better-bibtex ${run} ${ this.prefix }${ prefix }} ${ msg }` | ||
} | ||
switch (typeof value) { | ||
case 'string': | ||
case 'number': | ||
case 'boolean': | ||
return value | ||
|
||
public get enabled(): boolean { | ||
return ( | ||
(typeof TranslationWorker !== 'undefined' && TranslationWorker.job.debugEnabled) | ||
|| !Zotero | ||
|| Zotero.Debug?.enabled | ||
|| Zotero.Prefs?.get('debug.store') | ||
) as boolean | ||
} | ||
case 'object': | ||
return stringifyXPCOM(value) || stringifyError(value) || value | ||
} | ||
|
||
public debug(...msg) { | ||
Zotero.debug(this.format({}, msg)) | ||
if (Array.isArray(value)) return value | ||
|
||
return undefined | ||
} | ||
} | ||
|
||
public info(msg: string) { | ||
Zotero.debug(this.format({}, msg)) | ||
function to_s(obj: any): string { | ||
if (typeof obj === 'string') return obj | ||
return JSON.stringify(obj, replacer(), 2) | ||
} | ||
|
||
export function format(...msg): void { | ||
msg.map(to_s).join(' ') | ||
} | ||
|
||
export const log = new class { | ||
public prefix = '' | ||
|
||
#prefix(error?: any) { | ||
return `{${ error ? 'error: ' : '' }${ client.worker ? 'worker: ' : '' }${this.prefix}better-bibtex: ${run}} ` | ||
} | ||
|
||
public error(...msg) { | ||
Zotero.debug(this.format({ error: true }, msg)) | ||
public debug(...msg): void { | ||
Zotero.debug(`${this.#prefix()}${format(...msg)}\n`) | ||
} | ||
|
||
public status({ error = false }, ...msg) { | ||
if (error || this.enabled) Zotero.debug(this.format({ error }, msg)) | ||
public info(...msg): void { | ||
Zotero.debug(`${this.#prefix()}${format(...msg)}\n`) | ||
} | ||
|
||
public async timed(msg: string, code: () => void | Promise<void>) { | ||
const start = Date.now() | ||
await code() | ||
this.debug(msg, 'took', Date.now() - start, 'ms') | ||
public error(...msg): void { | ||
Zotero.debug(`${this.#prefix(true)}${format(...msg)}\n`) | ||
} | ||
|
||
public dump(msg: string) { | ||
$dump(msg) | ||
public dump(msg: string, error?: Error): void { | ||
if (error) { | ||
dump(`${this.#prefix(error)}${format(msg, error)}\n`) | ||
} | ||
else { | ||
dump(`${this.#prefix()}${format(msg)}\n`) | ||
} | ||
} | ||
} | ||
|
||
export function $dump(msg: string, error?: Error): void { | ||
log.dump(msg, error) | ||
} | ||
|
||
export function trace(msg: string, mode = ''): void { | ||
dump(`trace${ mode }\t${ Date.now() }\t${ msg }\n`) | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.