Skip to content

Commit

Permalink
after pasting images, upload them if storageType isn't base64
Browse files Browse the repository at this point in the history
  • Loading branch information
webzwo0i committed Nov 16, 2021
1 parent 17e3a5d commit 4f8d188
Show file tree
Hide file tree
Showing 3 changed files with 140 additions and 19 deletions.
66 changes: 65 additions & 1 deletion static/js/contentCollection.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,82 @@
'use strict';

const {_handleNewLines, _isValid} = require('ep_image_upload/static/js/toolbar');

// When an image is detected give it a lineAttribute
// of Image with the URL to the iamge
exports.collectContentImage = (hookName, {node, state: {lineAttributes}, tname}) => {
if (tname === 'div' || tname === 'p') delete lineAttributes.img;
if (tname !== 'img') return;
lineAttributes.img =

const imageData =
// Client-side. This will also be used for server-side HTML imports once jsdom adds support
// for HTMLImageElement.currentSrc.
node.currentSrc ||
// Server-side HTML imports using jsdom v16.6.0 (Etherpad v1.8.15).
node.src ||
// Server-side HTML imports using cheerio (Etherpad <= v1.8.14).
(node.attribs && node.attribs.src);

if (typeof window !== 'undefined' && clientVars.ep_image_upload.storageType !== 'base64') {
delete lineAttributes.img;

const padeditor = require('ep_etherpad-lite/static/js/pad_editor').padeditor;
const formData = new FormData();

const match = imageData.match(/data:(?<mime>[^;]+);base64,(?<data>.*)/);
if (!match || !match.groups.data || !match.groups.mime) return;

// decode from internal base64 rep
const decodedData = Uint8Array.from(window.atob(match.groups.data), c => c.charCodeAt(0));

// check if size is within limits and mime type is supported
if (!_isValid({size: decodedData.length, type: match.groups.mime})) return;

const blob = new Blob([decodedData], {type: match.groups.mime});

// TODO adjust file extension
formData.append('file', blob, 'image.svg');
$('#imageUploadModalLoader').show();
$.ajax({
type: 'POST',
url: `${clientVars.padId}/pluginfw/ep_image_upload/upload`,
xhr: () => {
const myXhr = $.ajaxSettings.xhr();
return myXhr;
},
success: (data) => {
$('#imageUploadModalLoader').hide();
padeditor.ace.callWithAce((ace) => {
const imageLineNr = _handleNewLines(ace);
ace.ace_addImage(imageLineNr, data);
ace.ace_doReturnKey();
}, 'img', true);
},
error: (error) => {
let errorResponse;
try {
errorResponse = JSON.parse(error.responseText.trim());
if (errorResponse.type) {
errorResponse.message = window._(`ep_image_upload.error.${errorResponse.type}`);
}
} catch (err) {
errorResponse = {message: error.responseText};
}

$('#imageUploadModalLoader').hide();
$('#imageUploadModalError .error').html(errorResponse.message);
$('#imageUploadModalError').show();
},
async: true,
data: formData,
cache: false,
contentType: false,
processData: false,
timeout: 20000,
});
} else {
lineAttributes.img = imageData;
}
};

exports.collectContentPre = (name, context) => {
Expand Down
10 changes: 5 additions & 5 deletions static/js/toolbar.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
'use strict';

const _handleNewLines = (ace) => {
exports._handleNewLines = (ace) => {
const rep = ace.ace_getRep();
const lineNumber = rep.selStart[0];
const curLine = rep.lines.atIndex(lineNumber);
Expand All @@ -13,7 +13,7 @@ const _handleNewLines = (ace) => {
return lineNumber;
};

const _isValid = (file) => {
exports._isValid = (file) => {
const mimedb = clientVars.ep_image_upload.mimeTypes;
const mimeType = mimedb[file.type];
let validMime = null;
Expand Down Expand Up @@ -67,7 +67,7 @@ exports.postToolbarInit = (hook, context) => {
}
const file = files[0];

if (!_isValid(file)) {
if (!exports._isValid(file)) {
return;
}
if (clientVars.ep_image_upload.storageType === 'base64') {
Expand All @@ -77,7 +77,7 @@ exports.postToolbarInit = (hook, context) => {
reader.onload = () => {
const data = reader.result;
context.ace.callWithAce((ace) => {
const imageLineNr = _handleNewLines(ace);
const imageLineNr = exports._handleNewLines(ace);
ace.ace_addImage(imageLineNr, data);
ace.ace_doReturnKey();
}, 'img', true);
Expand All @@ -99,7 +99,7 @@ exports.postToolbarInit = (hook, context) => {
success: (data) => {
$('#imageUploadModalLoader').removeClass('popup-show');
context.ace.callWithAce((ace) => {
const imageLineNr = _handleNewLines(ace);
const imageLineNr = exports._handleNewLines(ace);
ace.ace_addImage(imageLineNr, data);
ace.ace_doReturnKey();
}, 'img', true);
Expand Down
83 changes: 70 additions & 13 deletions static/tests/frontend/specs/insert.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 4f8d188

Please sign in to comment.