mirror of
https://github.com/vector-im/element-web.git
synced 2024-11-18 06:35:35 +08:00
Workings for future posterity - Can't access iframe content from parent. iframe needs to initiate. Postmessage data up the stack.
This commit is contained in:
parent
3a89b90e57
commit
c9b8aab0e0
@ -468,6 +468,9 @@ module.exports = React.createClass({
|
||||
unsentMessageError: this._getUnsentMessageError(this.state.room),
|
||||
});
|
||||
break;
|
||||
case 'picture_snapshot':
|
||||
this.uploadFile(payload.file);
|
||||
break;
|
||||
case 'notifier_enabled':
|
||||
case 'upload_failed':
|
||||
case 'upload_started':
|
||||
|
@ -32,6 +32,7 @@ import AppWarning from './AppWarning';
|
||||
import MessageSpinner from './MessageSpinner';
|
||||
import WidgetUtils from '../../../WidgetUtils';
|
||||
import dis from '../../../dispatcher';
|
||||
import domtoimage from 'dom-to-image';
|
||||
|
||||
const ALLOWED_APP_URL_SCHEMES = ['https:', 'http:'];
|
||||
|
||||
@ -222,7 +223,14 @@ export default React.createClass({
|
||||
},
|
||||
|
||||
_onSnapshotClick(e) {
|
||||
console.log("Snapshot widget ID ", this.props.id);
|
||||
const iframe = this.refs.appFrame;
|
||||
domtoimage.toPng(iframe).then(function(dataUrl) {
|
||||
console.log("Image data URL:", dataUrl);
|
||||
dis.dispatch({
|
||||
action: 'picture_snapshot',
|
||||
file: dataURLtoBlob(dataUrl),
|
||||
}, true);
|
||||
});
|
||||
},
|
||||
|
||||
/* If user has permission to modify widgets, delete the widget,
|
||||
@ -428,3 +436,15 @@ export default React.createClass({
|
||||
);
|
||||
},
|
||||
});
|
||||
|
||||
function dataURLtoBlob(dataurl) {
|
||||
const arr = dataurl.split(',');
|
||||
const mime = arr[0].match(/:(.*?);/)[1];
|
||||
const bstr = atob(arr[1]);
|
||||
let n = bstr.length;
|
||||
const u8arr = new Uint8Array(n);
|
||||
while (n--) {
|
||||
u8arr[n] = bstr.charCodeAt(n);
|
||||
}
|
||||
return new Blob([u8arr], {type: mime});
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user