Created
June 27, 2012 16:18
-
-
Save skyblue/3005158 to your computer and use it in GitHub Desktop.
jquery.paste_image_reader.js
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| // trigger me onclick | |
| function share(){ | |
| try { | |
| var img = canvas.toDataURL('image/jpeg', 0.9).split(',')[1]; | |
| } catch(e) { | |
| var img = canvas.toDataURL().split(',')[1]; | |
| } | |
| // open the popup in the click handler so it will not be blocked | |
| var w = window.open(); | |
| w.document.write('Uploading...'); | |
| // upload to imgur using jquery/CORS | |
| // https://developer.mozilla.org/En/HTTP_access_control | |
| $.ajax({ | |
| url: 'http://api.imgur.com/2/upload.json', | |
| type: 'POST', | |
| data: { | |
| type: 'base64', | |
| // get your key here, quick and fast http://imgur.com/register/api_anon | |
| key: 'YOUR-API-KEY', | |
| name: 'neon.jpg', | |
| title: 'test title', | |
| caption: 'test caption', | |
| image: img | |
| }, | |
| dataType: 'json' | |
| }).success(function(data) { | |
| w.location.href = data['upload']['links']['imgur_page']; | |
| }).error(function() { | |
| alert('Could not reach api.imgur.com. Sorry :('); | |
| w.close(); | |
| }); | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| // Created by STRd6 | |
| // MIT License | |
| // jquery.paste_image_reader.js | |
| (function($) { | |
| var defaults; | |
| $.event.fix = (function(originalFix) { | |
| return function(event) { | |
| event = originalFix.apply(this, arguments); | |
| if (event.type.indexOf('copy') === 0 || event.type.indexOf('paste') === 0) { | |
| event.clipboardData = event.originalEvent.clipboardData; | |
| } | |
| return event; | |
| }; | |
| })($.event.fix); | |
| defaults = { | |
| callback: $.noop, | |
| matchType: /image.*/ | |
| }; | |
| return $.fn.pasteImageReader = function(options) { | |
| if (typeof options === "function") { | |
| options = { | |
| callback: options | |
| }; | |
| } | |
| options = $.extend({}, defaults, options); | |
| return this.each(function() { | |
| var $this, element; | |
| element = this; | |
| $this = $(this); | |
| return $this.bind('paste', function(event) { | |
| var clipboardData, found; | |
| found = false; | |
| clipboardData = event.clipboardData; | |
| return Array.prototype.forEach.call(clipboardData.types, function(type, i) { | |
| var file, reader; | |
| if (found) { | |
| return; | |
| } | |
| if (type.match(options.matchType) || clipboardData.items[i].type.match(options.matchType)) { | |
| file = clipboardData.items[i].getAsFile(); | |
| reader = new FileReader(); | |
| reader.onload = function(evt) { | |
| return options.callback.call(element, { | |
| dataURL: evt.target.result, | |
| event: evt, | |
| file: file, | |
| name: file.name | |
| }); | |
| }; | |
| reader.readAsDataURL(file); | |
| return found = true; | |
| } | |
| }); | |
| }); | |
| }); | |
| }; | |
| })(jQuery); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment