- Breaking change: Treat callbacks to `editor.ready` as Promises, only resolving after all resolve - Breaking change: Make `editor.runCallbacks` return a `Promise` which resolves upon all callbacks resolving - Breaking change: Require `npx` (used with `babel-node`) to allow Node files for HTML building and JSDoc type checking to be expressed as ESM. - Breaking change: `addExtension` now throws upon a repeated attempt to add an already-added extension - Breaking change (storage preference cookies): Namespace the cookie as "svgeditstore" instead of just "store" - Breaking change (API): Remove `svgCanvas.rasterExport` fourth (callback) argument, collapsing fifth (options) to fourth - Breaking change (API): Remove `svgCanvas.exportPDF` third (callback) argument - Breaking change (API): `editor/contextmenu.js` `add` now throws instead of giving a console error only upon detecting a bad menuitem or preexisting context menu - Breaking change (API): Remove `svgCanvas.embedImage` second (callback) argument - Breaking change (API): Make `getHelpXML` a class instead of instance method of `RGBColor` - Breaking change (internal API): Refactor `dbox` (and `alert`/`confirm`/`process`/`prompt`/`select`) to avoid a callback argument in favor of return a Promise - Fix: Avoid running in extension `langReady` multiple times or serially - Enhancement (API): Add svgCanvas.runExtension to run just one extension and add `nameFilter` callback to `runExtensions` - Enhancement (API): Supply `$` (our wrapped jQuery) to extensions so can use its plugins, e.g., dbox with its `alert` - Enhancement: Use alert dialog in place of `alert` in webappfind - Enhancement: `editor.ready` now returns a Promise resolving when all callbacks have resolved - Enhancement: Allow `noAlert` option as part of second argument to `loadSvgString` (and `loadFromURL` and `loadFromDataURI`) to avoid UI alert (and trigger promise rejection) - Enhancement: Make `dbox` as a separate module for alert, prompt, etc. dialogs - Refactoring: Internal `PaintBox` as class; other misc. tweaks; no bitwise in canvg - Linting (ESLint): Further linting changes (for editor); rename `.eslintrc` -> `.eslintrc.json` per recommendation - Optimization: Recompress images (imageoptim-cli updated) - npm: Update devDeps - npm: Bump to 4.0.0
107 lines
3.3 KiB
JavaScript
107 lines
3.3 KiB
JavaScript
/**
|
|
* Depends on Firefox add-on and executables from {@link https://github.com/brettz9/webappfind}
|
|
* @author Brett Zamir
|
|
* @license MIT
|
|
* @todo See WebAppFind Readme for SVG-related todos
|
|
*/
|
|
|
|
export default {
|
|
name: 'webappfind',
|
|
async init ({importLocale, $}) {
|
|
const strings = await importLocale();
|
|
const svgEditor = this;
|
|
const saveMessage = 'save',
|
|
readMessage = 'read',
|
|
excludedMessages = [readMessage, saveMessage];
|
|
|
|
let pathID;
|
|
this.canvas.bind(
|
|
'message',
|
|
/**
|
|
* @param {external:Window} win
|
|
* @param {module:svgcanvas.SvgCanvas#event:message} data
|
|
* @listens module:svgcanvas.SvgCanvas#event:message
|
|
* @throws {Error} Unexpected event type
|
|
* @returns {undefined}
|
|
*/
|
|
(win, {data, origin}) => { // eslint-disable-line no-shadow
|
|
// console.log('data, origin', data, origin);
|
|
let type, content;
|
|
try {
|
|
({type, pathID, content} = data.webappfind); // May throw if data is not an object
|
|
if (origin !== location.origin || // We are only interested in a message sent as though within this URL by our browser add-on
|
|
excludedMessages.includes(type) // Avoid our post below (other messages might be possible in the future which may also need to be excluded if your subsequent code makes assumptions on the type of message this is)
|
|
) {
|
|
return;
|
|
}
|
|
} catch (err) {
|
|
return;
|
|
}
|
|
|
|
switch (type) {
|
|
case 'view':
|
|
// Populate the contents
|
|
svgEditor.loadFromString(content);
|
|
|
|
/* if ($('#tool_save_file')) {
|
|
$('#tool_save_file').disabled = false;
|
|
} */
|
|
break;
|
|
case 'save-end':
|
|
$.alert(`save complete for pathID ${pathID}!`);
|
|
break;
|
|
default:
|
|
throw new Error('Unexpected WebAppFind event type');
|
|
}
|
|
}
|
|
);
|
|
|
|
/*
|
|
window.postMessage({
|
|
webappfind: {
|
|
type: readMessage
|
|
}
|
|
}, window.location.origin === 'null'
|
|
// Avoid "null" string error for `file:` protocol (even though
|
|
// file protocol not currently supported by Firefox)
|
|
? '*'
|
|
: window.location.origin
|
|
);
|
|
*/
|
|
const buttons = [{
|
|
id: 'webappfind_save', //
|
|
icon: svgEditor.curConfig.extIconsPath + 'webappfind.png',
|
|
type: 'app_menu',
|
|
position: 4, // Before 0-based index position 4 (after the regular "Save Image (S)")
|
|
events: {
|
|
click () {
|
|
if (!pathID) { // Not ready yet as haven't received first payload
|
|
return;
|
|
}
|
|
window.postMessage(
|
|
{
|
|
webappfind: {
|
|
type: saveMessage,
|
|
pathID,
|
|
content: svgEditor.canvas.getSvgString()
|
|
}
|
|
}, window.location.origin === 'null'
|
|
// Avoid "null" string error for `file:` protocol (even
|
|
// though file protocol not currently supported by add-on)
|
|
? '*'
|
|
: window.location.origin
|
|
);
|
|
}
|
|
}
|
|
}];
|
|
|
|
return {
|
|
name: strings.name,
|
|
svgicons: svgEditor.curConfig.extIconsPath + 'webappfind-icon.svg',
|
|
buttons: strings.buttons.map((button, i) => {
|
|
return Object.assign(buttons[i], button);
|
|
})
|
|
};
|
|
}
|
|
};
|