- Breaking change: Locale now formatted as export - Breaking change: Moved out remaining modular i18n (imagelib) to own folder - Breaking change: Drop `executeAfterLoads` (and getJSPDF/getCanvg) - Breaking change: `RGBColor` must accept `new` - Breaking change: canvg - `stackBlurCanvasRGBA` must be set now by function (`setStackBlurCanvasRGBA`) rather than global; `canvg` now a named export - Breaking change: Avoid passing `canvg`/`buildCanvgCallback` to extensions (have them import) - Fix: i18nize imaglib more deeply - Fix: Positioning of Document Properties dialog (Fixes #246) - Fix (regression): PDF Export (Fixes #249) - Fix (regression): Add polyfill for `ChildNode`/`ParentNode` (and use further) - Fix (regression): Apply Babel universally to dependencies - Fix (regression): Ordering of `uaPrefix` function in `svgEditor.js` - Fix (regression): Embedded API - Fix (embedded editor): Fix backspace key in Firefox so it doesn't navigate out of frame - Fix: Alert if no exportWindow for PDF (e.g., if blocked) - Refactoring( RGBColor) `RGBColor` as class, without rebuilding constants, optimize string replacement, move methods to prototype, use templates and object literals, use `Object.keys` - Refactoring (canvg) Use classes more internally, use shorthand objects; array extras, return to lazy-loading - Refactoring: Use Promises in place of `$.getScript`; always return Promises in case deciding to await resolving - Refactoring: Avoid importing `RGBColor` into `svgutils.js` (jsPDF imports it itself) - Refactoring: Arrow functions, destructuring, shorter property references - Refactoring: Fix `lang` and `dir` for locales (though not in use currently anyways) - Refactoring: Provide path config for canvg, jspdf
58 lines
2.1 KiB
JavaScript
58 lines
2.1 KiB
JavaScript
/* globals jQuery */
|
|
/*
|
|
* ext-server_moinsave.js
|
|
*
|
|
* Licensed under the MIT License
|
|
*
|
|
* Copyright(c) 2010 Alexis Deveria
|
|
* 2011 MoinMoin:ReimarBauer
|
|
* adopted for moinmoins item storage. it sends in one post png and svg data
|
|
* (I agree to dual license my work to additional GPLv2 or later)
|
|
*
|
|
*/
|
|
import {canvg} from '../canvg/canvg.js';
|
|
|
|
export default {
|
|
name: 'server_opensave',
|
|
callback ({encode64}) {
|
|
const svgEditor = this;
|
|
const $ = jQuery;
|
|
const svgCanvas = svgEditor.canvas;
|
|
const saveSvgAction = '/+modify';
|
|
|
|
// Create upload target (hidden iframe)
|
|
/* const target = */ $('<iframe name="output_frame" src="#"/>').hide().appendTo('body');
|
|
|
|
svgEditor.setCustomHandlers({
|
|
async save (win, data) {
|
|
const svg = '<?xml version="1.0"?>\n' + data;
|
|
const qstr = $.param.querystring();
|
|
const name = qstr.substr(9).split('/+get/')[1];
|
|
const svgData = encode64(svg);
|
|
if (!$('#export_canvas').length) {
|
|
$('<canvas>', {id: 'export_canvas'}).hide().appendTo('body');
|
|
}
|
|
const c = $('#export_canvas')[0];
|
|
c.width = svgCanvas.contentW;
|
|
c.height = svgCanvas.contentH;
|
|
await canvg(c, svg);
|
|
const datauri = c.toDataURL('image/png');
|
|
// const {uiStrings} = svgEditor;
|
|
const pngData = encode64(datauri); // Brett: This encoding seems unnecessary
|
|
/* const form = */ $('<form>').attr({
|
|
method: 'post',
|
|
action: saveSvgAction + '/' + name,
|
|
target: 'output_frame'
|
|
}).append('<input type="hidden" name="png_data" value="' + pngData + '">')
|
|
.append('<input type="hidden" name="filepath" value="' + svgData + '">')
|
|
.append('<input type="hidden" name="filename" value="' + 'drawing.svg">')
|
|
.append('<input type="hidden" name="contenttype" value="application/x-svgdraw">')
|
|
.appendTo('body')
|
|
.submit().remove();
|
|
alert('Saved! Return to Item View!');
|
|
top.window.location = '/' + name;
|
|
}
|
|
});
|
|
}
|
|
};
|