WhatIMG: Drag + Drop Files

This script allows you to drag and drop files for an easier upload process.

当前为 2014-05-16 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @id whatimg-drag-drop
  3. // @name WhatIMG: Drag + Drop Files
  4. // @namespace hateradio)))
  5. // @author hateradio
  6. // @version 2.2
  7. // @description This script allows you to drag and drop files for an easier upload process.
  8. // @icon 
  9. // @icon64 
  10. // @include http*://*whatimg.com/
  11. // @match *://*.whatimg.com/
  12. // @since Mar-10-2010
  13. // @date Nov-5-2012
  14. // @grant GM_xmlhttpRequest
  15. // ==/UserScript==
  16.  
  17. // S T O R A G E HANDLE
  18. var strg = {
  19. on:(function(){ try { var s = window.localStorage; if(s.getItem&&s.setItem&&s.removeItem){return true;} } catch(e) {return false;} }()),
  20. read:function(key){ return this.on ? JSON.parse(window.localStorage.getItem(key)) : false; },
  21. save:function(key,dat){ return this.on ? !window.localStorage.setItem(key, JSON.stringify(dat)) : false; },
  22. wipe:function(key){ return this.on ? !window.localStorage.removeItem(key) : false; },
  23. zero:function(o){ var k; for(k in o){ if(o.hasOwnProperty(k)){ return false; } } return true; }
  24. };
  25.  
  26. // U P D A T E HANDLE
  27. var update = {
  28. name:'WhatIMG: Drag + Drop Files',
  29. version:2200,
  30. key:'ujs_WIMG_DRAGDROP',
  31. callback:'wimgddupdt',
  32. urij:'https://dl.dropbox.com/u/14626536/userscripts/updt/wimgdd/wimgdd.json',
  33. uric:'https://dl.dropbox.com/u/14626536/userscripts/updt/wimgdd/wimgdd.js', // If you get "Failed to load source for:" in Firebug, allow dropbox to run scripts.
  34. checkchrome:false,
  35. interval:5,
  36. day:(new Date()).getTime(),
  37. time:function(){return new Date(this.day + (1000*60*60*24*this.interval)).getTime();},
  38. css:function(t){
  39. if(!this.style){this.style = document.createElement('style'); this.style.type = 'text/css'; document.body.appendChild(this.style);} this.style.appendChild(document.createTextNode(t+'\n'));
  40. },
  41. js:function(t){
  42. var j = document.createElement('script'); j.type = 'text/javascript'; /(?:^https?\:\/\/)/i.test(t) ? j.src = t : j.textContent = t; document.body.appendChild(j);
  43. },
  44. notification:function(j){
  45. if(j){if(this.version < j.version){window.localStorage.setItem(this.key,JSON.stringify({date:this.time(),version:j.version,page:j.page}));}else{return true;}}
  46. var a = document.createElement('a'), b = JSON.parse(window.localStorage.getItem(this.key)); a.href = b.page || '#'; a.id = 'userscriptupdater'; a.title = 'Update now.'; a.textContent = 'An update for '+this.name+' is available.'; document.body.appendChild(a); return true;
  47. },
  48. check:function(opt){
  49. if(typeof(GM_updatingEnabled) === 'boolean' || !strg.on){return;}
  50. var stored = strg.read(this.key), J, page;
  51. if(opt || !stored || stored.date < this.day){
  52. page = stored && stored.page ? stored.page : '';
  53. strg.save(this.key,{date:this.time(),version:this.version,page:page});
  54. if(!opt){this.css(this.csstxt);}
  55. if(!opt && typeof(GM_xmlhttpRequest) === 'function' && !this.chrome()){
  56. GM_xmlhttpRequest({method: 'GET', url: update.urij, onload: function(r){ update.notification(JSON.parse(r.responseText));}, onerror: function(){update.check(1);}});
  57. }else{
  58. J = this.notification.toString().replace('function','function '+this.callback).replace('this.version',this.version).replace(/(?:this\.key)/g,"'"+this.key+"'").replace('this.time()',this.time()).replace('this.name','j.name');
  59. this.js(J); this.js(this.uric);
  60. }
  61. }else if(this.version < stored.version){ this.css(this.csstxt); this.notification(); }
  62. },
  63. chrome:function(){
  64. if(this.checkchrome === true && typeof(chrome) === 'object'){ return true; }
  65. },
  66. csstxt:'#userscriptupdater,#userscriptupdater:visited{-moz-box-shadow: 0 0 6px #787878;-webkit-box-shadow: 0 0 6px #787878;box-shadow: 0 0 6px #787878;border: 1px solid #777;-moz-border-radius:4px;border-radius:4px; cursor:pointer;color:#555;font-family: Arial;font-size: 11px;font-weight: bold; text-align: justify;min-height: 45px;padding: 12px 20px 10px 65px;position: fixed; right: 10px;top: 10px;width: 170px;background: #ebebeb url() no-repeat 13px 15px} #userscriptupdater:hover,#userscriptupdater:visited:hover { border-color: #8f8d96; color:#55698c;background-position: 13px -85px }'
  67. };
  68. update.check();
  69.  
  70. var files = {
  71. URL:(function(){
  72. try {
  73. this.url = (window.createObjectURL && window) || (window.URL && URL) || (window.webkitURL && webkitURL);
  74. } finally {
  75. if (this.url && typeof this.url.revokeObjectURL !== 'function') { delete this.url; }
  76. return this.url;
  77. }
  78. }()),
  79. sizes:[],
  80. country:document.getElementById('countrydivcontainer'),
  81. form:document.getElementById('upload_form'),
  82. b:document.createElement('div'),
  83. c:document.createElement('div'),
  84. d:document.createElement('div'),
  85. send:document.createElement('div'),
  86. tab:document.getElementById('countrytabs'),
  87. init:function(){
  88. var that = this, css;
  89. this.bond = function(m){ var c = function(evt){ that[m].call(that,evt); }; return c; };
  90. css = '#upload_form input, #upload_form br, .dropboxhide { display:none; } #normal_upload input {display:inline !important} #dropbox { min-height: 200px; overflow: hidden; padding: 6px; cursor: pointer; position: relative; z-index: 1; background-color: #222; border-radius: 3px; margin: 5px 0px; } #dropbox:hover { background-color: #111} div.dropboxbg { background: url(http://whatimg.com/images/03448758284210266130.png) #222 no-repeat center center; }'
  91. +'\n.previewimgs { float: left; margin: 3px; border: 2px solid #eee; border-radius: 2px; max-width:150px;overflow:hidden;height:100px;background:#eee} .previewimgs img { max-height: 100px; opacity: .8; } .previewimgs:hover img { opacity: 1; /* position: absolute; top: -100px; left: -100px; z-index: 2; height: auto; */ }'
  92. +'\n#dropboxsend { background: #333; width: 50px; text-align: center; cursor: pointer; padding: 3px; border-radius: 2px; margin: auto; color: #eee; } #dropboxsend:hover { background: #111 }'
  93. +'\n#countrydivcontainer { position: relative } #dropboxpercent { position: absolute; top: 45px; right: 25px; color: #eee; z-index: 40; font-size: 24px; text-shadow: 1px 1px 8px #000; background: #333; padding: 0 3px; border-radius: 2px }';
  94. update.css(css);
  95. this.d.id = 'dropbox';
  96. this.d.title = 'Drop images onto me.';
  97. this.d.className = 'dropboxbg';
  98. this.d.addEventListener('dragenter',this.prevent,false);
  99. this.d.addEventListener('dragover',this.prevent,false);
  100. this.d.addEventListener('drop',this.bond('drops'),false);
  101. this.c.className = 'dropboxhide';
  102. this.c.id = 'dropboxpercent';
  103.  
  104. this.send.textContent = 'Send';
  105. this.send.title = 'Send Images';
  106. this.send.id = 'dropboxsend';
  107. this.send.addEventListener('click',this.bond('sender'),false);
  108. this.B = this.bond('mcs');
  109. this.tab.addEventListener('click',this.B,false);
  110. this.country.textContent = '';
  111. this.form.appendChild(this.d);
  112. this.form.appendChild(this.send);
  113. this.form.appendChild(this.b);
  114. this.country.appendChild(this.form);
  115. this.country.appendChild(this.c);
  116. this.ul();
  117. },
  118. mcs:function(){
  119. this.tab.removeEventListener('click',this.B,false);
  120. update.css('#upload_form input { display: inline-block !important }');
  121. },
  122. ul:function(){
  123. var temp = document.createElement('ul'),
  124. li = document.createElement('li'); li.textContent = 'Drop your images above. Double click on an image to remove it.'; temp.appendChild(li);
  125. li = document.createElement('li'); li.textContent = 'Allowed File Extensions: JPEG, JPG, GIF, and PNG'; temp.appendChild(li);
  126. li = document.createElement('li'); li.textContent = 'Max filesize is set at 5 Megabytes per image file.'; temp.appendChild(li);
  127. this.b.appendChild(temp);
  128. },
  129. prevent:function(evt){
  130. evt.stopPropagation();
  131. evt.preventDefault();
  132. },
  133. drops:function(evt){
  134. var dt = evt.dataTransfer;
  135. this.prevent(evt);
  136. this.d.className = 'dropboxnobg';
  137. this.gets(dt.files);
  138. },
  139. gets:function(files){
  140. var i = 0, f;
  141. for(i; i < files.length; i++){
  142. f = files[i]; // console.log(f.type);
  143. if(!f.type.match(/(?:image\/\b(?:jpeg|png|gif)\b)/)) { return false; }
  144. if(f.size > 5242880) { alert('Choose a smaller image!'); return false; }
  145. this.proc(f);
  146. }
  147. this.cls();
  148. },
  149. proc:function(f){
  150. if(this.sizes.indexOf(f.size) === -1){
  151. var D = document.createElement('div'), I = document.createElement('img');
  152. this.sizes.push(f.size);
  153. // console.log(this.sizes);
  154. I.file = f;
  155. I.title = 'Double click to remove';
  156. I.className = 'dropboximg';
  157. I.addEventListener('dblclick', this.bond('destroy'), false);
  158. D.className = 'previewimgs';
  159. D.appendChild(I);
  160. this.d.appendChild(D);
  161. this.img(I, f);
  162. }
  163. },
  164. img:function(i, f){
  165. if (this.URL) {
  166. // console.log('new');
  167. i.onload = this.rem.n;
  168. i.src = this.URL.createObjectURL(f);
  169. } else {
  170. // console.log('old');
  171. var r = new FileReader();
  172. r.onload = this.rem.o(i);
  173. r.readAsDataURL(f);
  174. }
  175. },
  176. rem: {
  177. n : function () {
  178. try {
  179. files.URL.revokeObjectURL(this.src);
  180. } catch (e) {
  181. // console.log('rem'+e);
  182. }
  183. },
  184. o : function (i) {
  185. return function (e) {
  186. i.src = e.target.result;
  187. };
  188. }
  189. },
  190. sender:function(){
  191. var imgs = document.querySelectorAll('.dropboximg'), i, img, xhr = new XMLHttpRequest(), fd = new FormData(this.form);
  192. if(imgs.length === 0){return false;}
  193. this.send.className = 'dropboxhide';
  194. this.c.className = '';
  195. for(i = 0; i < imgs.length; i++){ img = imgs[i]; fd.append('userfile[]', img.file); }
  196. xhr.upload.onprogress = this.bond('percent');
  197. xhr.open('POST', 'upload.php', true);
  198. xhr.onload = this.done;
  199. xhr.send(fd);
  200. },
  201. done:function(){
  202. var p = document.getElementById('page_body'), doc = document.implementation.createHTMLDocument('');
  203. doc.documentElement.innerHTML = this.responseText;
  204. p.innerHTML = doc.getElementById('page_body').innerHTML;
  205. },
  206. percent:function(evt){
  207. if(evt.lengthComputable){
  208. var percentage = Math.round((evt.loaded * 100) / evt.total);
  209. this.c.textContent = percentage +'%';
  210. }
  211. },
  212. destroy:function(evt){
  213. var i = evt.currentTarget, d = i.parentNode, n = this.sizes.indexOf(i.file.size);
  214. this.sizes.splice(n,1);
  215. d.parentNode.removeChild(d);
  216. // console.log(this.sizes);
  217. // console.log(this.sizes.length);
  218. this.cls();
  219. },
  220. cls:function(){
  221. if(this.sizes.length === 0){ this.d.className = 'dropboxbg'; }
  222. }
  223. };
  224. files.init();