|
- // Generated by CoffeeScript 1.9.0
-
- /*
- paste.js is an interface to read data ( text / image ) from clipboard in different browsers. It also contains several hacks.
- https://github.com/layerssss/paste.js
- */
-
- (function() {
- var $, Paste, createHiddenEditable, dataURLtoBlob;
-
- $ = window.jQuery;
-
- $.paste = function(pasteContainer) {
- var pm;
- if (typeof console !== "undefined" && console !== null) {
- console.log("DEPRECATED: This method is deprecated. Please use $.fn.pastableNonInputable() instead.");
- }
- pm = Paste.mountNonInputable(pasteContainer);
- return pm._container;
- };
-
- $.fn.pastableNonInputable = function() {
- var el, _i, _len;
- for (_i = 0, _len = this.length; _i < _len; _i++) {
- el = this[_i];
- Paste.mountNonInputable(el);
- }
- return this;
- };
-
- $.fn.pastableTextarea = function() {
- var el, _i, _len;
- for (_i = 0, _len = this.length; _i < _len; _i++) {
- el = this[_i];
- Paste.mountTextarea(el);
- }
- return this;
- };
-
- $.fn.pastableContenteditable = function() {
- var el, _i, _len;
- for (_i = 0, _len = this.length; _i < _len; _i++) {
- el = this[_i];
- Paste.mountContenteditable(el);
- }
- return this;
- };
-
- dataURLtoBlob = function(dataURL, sliceSize) {
- var b64Data, byteArray, byteArrays, byteCharacters, byteNumbers, contentType, i, m, offset, slice, _ref;
- if (sliceSize == null) {
- sliceSize = 512;
- }
- if (!(m = dataURL.match(/^data\:([^\;]+)\;base64\,(.+)$/))) {
- return null;
- }
- _ref = m, m = _ref[0], contentType = _ref[1], b64Data = _ref[2];
- byteCharacters = atob(b64Data);
- byteArrays = [];
- offset = 0;
- while (offset < byteCharacters.length) {
- slice = byteCharacters.slice(offset, offset + sliceSize);
- byteNumbers = new Array(slice.length);
- i = 0;
- while (i < slice.length) {
- byteNumbers[i] = slice.charCodeAt(i);
- i++;
- }
- byteArray = new Uint8Array(byteNumbers);
- byteArrays.push(byteArray);
- offset += sliceSize;
- }
- return new Blob(byteArrays, {
- type: contentType
- });
- };
-
- createHiddenEditable = function() {
- return $(document.createElement('div')).attr('contenteditable', true).css({
- width: 1,
- height: 1,
- position: 'fixed',
- left: -100,
- overflow: 'hidden'
- });
- };
-
- Paste = (function() {
- Paste.prototype._target = null;
-
- Paste.prototype._container = null;
-
- Paste.mountNonInputable = function(nonInputable) {
- var paste;
- paste = new Paste(createHiddenEditable().appendTo(nonInputable), nonInputable);
- $(nonInputable).on('click', (function(_this) {
- return function() {
- return paste._container.focus();
- };
- })(this));
- paste._container.on('focus', (function(_this) {
- return function() {
- return $(nonInputable).addClass('pastable-focus');
- };
- })(this));
- return paste._container.on('blur', (function(_this) {
- return function() {
- return $(nonInputable).removeClass('pastable-focus');
- };
- })(this));
- };
-
- Paste.mountTextarea = function(textarea) {
- var ctlDown, paste;
- if (-1 !== navigator.userAgent.toLowerCase().indexOf('chrome')) {
- return this.mountContenteditable(textarea);
- }
- paste = new Paste(createHiddenEditable().insertBefore(textarea), textarea);
- ctlDown = false;
- $(textarea).on('keyup', function(ev) {
- var _ref;
- if ((_ref = ev.keyCode) === 17 || _ref === 224) {
- return ctlDown = false;
- }
- });
- $(textarea).on('keydown', function(ev) {
- var _ref;
- if ((_ref = ev.keyCode) === 17 || _ref === 224) {
- ctlDown = true;
- }
- if (ctlDown && ev.keyCode === 86) {
- return paste._container.focus();
- }
- });
- $(paste._target).on('pasteImage', (function(_this) {
- return function() {
- return $(textarea).focus();
- };
- })(this));
- $(paste._target).on('pasteText', (function(_this) {
- return function() {
- return $(textarea).focus();
- };
- })(this));
- $(textarea).on('focus', (function(_this) {
- return function() {
- return $(textarea).addClass('pastable-focus');
- };
- })(this));
- return $(textarea).on('blur', (function(_this) {
- return function() {
- return $(textarea).removeClass('pastable-focus');
- };
- })(this));
- };
-
- Paste.mountContenteditable = function(contenteditable) {
- var paste;
- paste = new Paste(contenteditable, contenteditable);
- $(contenteditable).on('focus', (function(_this) {
- return function() {
- return $(contenteditable).addClass('pastable-focus');
- };
- })(this));
- return $(contenteditable).on('blur', (function(_this) {
- return function() {
- return $(contenteditable).removeClass('pastable-focus');
- };
- })(this));
- };
-
- function Paste(_at__container, _at__target) {
- this._container = _at__container;
- this._target = _at__target;
- this._container = $(this._container);
- this._target = $(this._target).addClass('pastable');
- this._container.on('paste', (function(_this) {
- return function(ev) {
- var clipboardData, file, item, reader, text, _i, _j, _len, _len1, _ref, _ref1, _ref2, _ref3, _results;
- if (((_ref = ev.originalEvent) != null ? _ref.clipboardData : void 0) != null) {
- clipboardData = ev.originalEvent.clipboardData;
- if (clipboardData.items) {
- _ref1 = clipboardData.items;
- for (_i = 0, _len = _ref1.length; _i < _len; _i++) {
- item = _ref1[_i];
- if (item.type.match(/^image\//)) {
- reader = new FileReader();
- reader.onload = function(event) {
- return _this._handleImage(event.target.result);
- };
- reader.readAsDataURL(item.getAsFile());
- }
- if (item.type === 'text/plain') {
- item.getAsString(function(string) {
- return _this._target.trigger('pasteText', {
- text: string
- });
- });
- }
- }
- } else {
- if (-1 !== Array.prototype.indexOf.call(clipboardData.types, 'text/plain')) {
- text = clipboardData.getData('Text');
- _this._target.trigger('pasteText', {
- text: text
- });
- }
- _this._checkImagesInContainer(function(src) {
- return _this._handleImage(src);
- });
- }
- }
- if (clipboardData = window.clipboardData) {
- if ((_ref2 = (text = clipboardData.getData('Text'))) != null ? _ref2.length : void 0) {
- return _this._target.trigger('pasteText', {
- text: text
- });
- } else {
- _ref3 = clipboardData.files;
- _results = [];
- for (_j = 0, _len1 = _ref3.length; _j < _len1; _j++) {
- file = _ref3[_j];
- _this._handleImage(URL.createObjectURL(file));
- _results.push(_this._checkImagesInContainer(function() {}));
- }
- return _results;
- }
- }
- };
- })(this));
- }
-
- Paste.prototype._handleImage = function(src) {
- var loader;
- loader = new Image();
- loader.onload = (function(_this) {
- return function() {
- var blob, canvas, ctx, dataURL;
- canvas = document.createElement('canvas');
- canvas.width = loader.width;
- canvas.height = loader.height;
- ctx = canvas.getContext('2d');
- ctx.drawImage(loader, 0, 0, canvas.width, canvas.height);
- dataURL = null;
- try {
- dataURL = canvas.toDataURL('image/png');
- blob = dataURLtoBlob(dataURL);
- } catch (_error) {}
- if (dataURL) {
- return _this._target.trigger('pasteImage', {
- blob: blob,
- dataURL: dataURL,
- width: loader.width,
- height: loader.height
- });
- }
- };
- })(this);
- return loader.src = src;
- };
-
- Paste.prototype._checkImagesInContainer = function(cb) {
- var img, timespan, _i, _len, _ref;
- timespan = Math.floor(1000 * Math.random());
- _ref = this._container.find('img');
- for (_i = 0, _len = _ref.length; _i < _len; _i++) {
- img = _ref[_i];
- img["_paste_marked_" + timespan] = true;
- }
- return setTimeout((function(_this) {
- return function() {
- var _j, _len1, _ref1, _results;
- _ref1 = _this._container.find('img');
- _results = [];
- for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) {
- img = _ref1[_j];
- if (!img["_paste_marked_" + timespan]) {
- cb(img.src);
- }
- //firefox问题处理,因为采用了 pastableContenteditable 模式,故只需要删除默认的粘贴
- if ($(img).attr('src').startsWith('data:image/')) {
- _results.push($(img).remove());
- };
- }
- return _results;
- };
- })(this), 1);
- };
-
- return Paste;
-
- })();
-
- }).call(this);
-
- KindEditor.plugin('paste', function(K) {
- var editor = this,
- name = 'paste';
- if(editor.edit == undefined || editor.edit.iframe == undefined){
- return;
- }
- var contentWindow = editor.edit.iframe[0].contentWindow;
- //var contentWindow = editor.iframeDoc;
- //var contentWindow = document.getElementsByTagName('iframe')[0].contentWindow;
- var nodeBody = contentWindow.document.getElementsByTagName('body')[0];
- console.log(nodeBody);
- $(nodeBody).pastableContenteditable();
-
- dataURItoBlob = function(dataURI) {
- // convert base64/URLEncoded data component to raw binary data held in a string
- var byteString;
- if (dataURI.split(',')[0].indexOf('base64') >= 0)
- byteString = atob(dataURI.split(',')[1]);
- else
- byteString = unescape(dataURI.split(',')[1]);
-
- // separate out the mime component
- var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];
-
- // write the bytes of the string to a typed array
- var ia = new Uint8Array(byteString.length);
- for (var i = 0; i < byteString.length; i++) {
- ia[i] = byteString.charCodeAt(i);
- }
-
- return new Blob([ia], {type:mimeString});
- };
-
- $(nodeBody).on('pasteImage', function(ev, data) {
- console.log('pasteImage');
- console.log("dataURL: " + data.dataURL);
- console.log("width: " + data.width);
- console.log("height: " + data.height);
- var blob = dataURItoBlob(data.dataURL);
- if (data.blob !== null) {
- var data = new FormData();
- // data.append("imgFile",blob, "imageFilename.png");
- data.append("file",blob, "imageFilename.png");
- console.log(data);
- $.ajax({
- url: '/kindeditor/upload?dir=image',
- url: '/api/attachments.json',
- contentType: false,
- type: 'POST',
- data: data,
- processData: false,
- success: function(data) {
- console.log(data);
- // editor.exec('insertimage', JSON.parse(data).url);
-
- // /api/attachments/227362
- editor.exec('insertimage', '/api/attachments/' + data.id);
- }
- });
- }
-
- });
- return;
-
- });
-
|