annotate sites/all/modules/imce/js/imce_extras.js @ 0:ff03f76ab3fe

initial version
author danieleb <danielebarchiesi@me.com>
date Wed, 21 Aug 2013 18:51:11 +0100
parents
children
rev   line source
danielebarchiesi@0 1 //This pack implemets: keyboard shortcuts, file sorting, resize bars, and inline thumbnail preview.
danielebarchiesi@0 2
danielebarchiesi@0 3 (function($) {
danielebarchiesi@0 4
danielebarchiesi@0 5 // add scale calculator for resizing.
danielebarchiesi@0 6 imce.hooks.load.push(function () {
danielebarchiesi@0 7 $('#edit-width, #edit-height').focus(function () {
danielebarchiesi@0 8 var fid, r, w, isW, val;
danielebarchiesi@0 9 if (fid = imce.vars.prvfid) {
danielebarchiesi@0 10 isW = this.id == 'edit-width', val = imce.el(isW ? 'edit-height' : 'edit-width').value*1;
danielebarchiesi@0 11 if (val && (w = imce.isImage(fid)) && (r = imce.fids[fid].cells[3].innerHTML*1 / w))
danielebarchiesi@0 12 this.value = Math.round(isW ? val/r : val*r);
danielebarchiesi@0 13 }
danielebarchiesi@0 14 });
danielebarchiesi@0 15 });
danielebarchiesi@0 16
danielebarchiesi@0 17 // Shortcuts
danielebarchiesi@0 18 var F = null;
danielebarchiesi@0 19 imce.initiateShortcuts = function () {
danielebarchiesi@0 20 $(imce.NW).attr('tabindex', '0').keydown(function (e) {
danielebarchiesi@0 21 if (F = imce.dirKeys['k'+ e.keyCode]) return F(e);
danielebarchiesi@0 22 });
danielebarchiesi@0 23 $(imce.FLW).attr('tabindex', '0').keydown(function (e) {
danielebarchiesi@0 24 if (F = imce.fileKeys['k'+ e.keyCode]) return F(e);
danielebarchiesi@0 25 }).focus();
danielebarchiesi@0 26 };
danielebarchiesi@0 27
danielebarchiesi@0 28 //shortcut key-function pairs for directories
danielebarchiesi@0 29 imce.dirKeys = {
danielebarchiesi@0 30 k35: function (e) {//end-home. select first or last dir
danielebarchiesi@0 31 var L = imce.tree['.'].li;
danielebarchiesi@0 32 if (e.keyCode == 35) while (imce.hasC(L, 'expanded')) L = L.lastChild.lastChild;
danielebarchiesi@0 33 $(L.childNodes[1]).click().focus();
danielebarchiesi@0 34 },
danielebarchiesi@0 35 k37: function (e) {//left-right. collapse-expand directories.(right may also move focus on files)
danielebarchiesi@0 36 var L, B = imce.tree[imce.conf.dir], right = e.keyCode == 39;
danielebarchiesi@0 37 if (B.ul && (right ^ imce.hasC(L = B.li, 'expanded')) ) $(L.firstChild).click();
danielebarchiesi@0 38 else if (right) $(imce.FLW).focus();
danielebarchiesi@0 39 },
danielebarchiesi@0 40 k38: function (e) {//up. select the previous directory
danielebarchiesi@0 41 var B = imce.tree[imce.conf.dir];
danielebarchiesi@0 42 if (L = B.li.previousSibling) {
danielebarchiesi@0 43 while (imce.hasC(L, 'expanded')) L = L.lastChild.lastChild;
danielebarchiesi@0 44 $(L.childNodes[1]).click().focus();
danielebarchiesi@0 45 }
danielebarchiesi@0 46 else if ((L = B.li.parentNode.parentNode) && L.tagName == 'LI') $(L.childNodes[1]).click().focus();
danielebarchiesi@0 47 },
danielebarchiesi@0 48 k40: function (e) {//down. select the next directory
danielebarchiesi@0 49 var B = imce.tree[imce.conf.dir], L = B.li, U = B.ul;
danielebarchiesi@0 50 if (U && imce.hasC(L, 'expanded')) $(U.firstChild.childNodes[1]).click().focus();
danielebarchiesi@0 51 else do {if (L.nextSibling) return $(L.nextSibling.childNodes[1]).click().focus();
danielebarchiesi@0 52 }while ((L = L.parentNode.parentNode).tagName == 'LI');
danielebarchiesi@0 53 }
danielebarchiesi@0 54 };
danielebarchiesi@0 55 //add equal keys
danielebarchiesi@0 56 imce.dirKeys.k36 = imce.dirKeys.k35;
danielebarchiesi@0 57 imce.dirKeys.k39 = imce.dirKeys.k37;
danielebarchiesi@0 58
danielebarchiesi@0 59 //shortcut key-function pairs for files
danielebarchiesi@0 60 imce.fileKeys = {
danielebarchiesi@0 61 k38: function (e) {//up-down. select previous-next row
danielebarchiesi@0 62 var fid = imce.lastFid(), i = fid ? imce.fids[fid].rowIndex+e.keyCode-39 : 0;
danielebarchiesi@0 63 imce.fileClick(imce.findex[i], e.ctrlKey, e.shiftKey);
danielebarchiesi@0 64 },
danielebarchiesi@0 65 k35: function (e) {//end-home. select first or last row
danielebarchiesi@0 66 imce.fileClick(imce.findex[e.keyCode == 35 ? imce.findex.length-1 : 0], e.ctrlKey, e.shiftKey);
danielebarchiesi@0 67 },
danielebarchiesi@0 68 k13: function (e) {//enter-insert. send file to external app.
danielebarchiesi@0 69 imce.send(imce.vars.prvfid);
danielebarchiesi@0 70 return false;
danielebarchiesi@0 71 },
danielebarchiesi@0 72 k37: function (e) {//left. focus on directories
danielebarchiesi@0 73 $(imce.tree[imce.conf.dir].a).focus();
danielebarchiesi@0 74 },
danielebarchiesi@0 75 k65: function (e) {//ctrl+A to select all
danielebarchiesi@0 76 if (e.ctrlKey && imce.findex.length) {
danielebarchiesi@0 77 var fid = imce.findex[0].id;
danielebarchiesi@0 78 imce.selected[fid] ? (imce.vars.lastfid = fid) : imce.fileClick(fid);//select first row
danielebarchiesi@0 79 imce.fileClick(imce.findex[imce.findex.length-1], false, true);//shift+click last row
danielebarchiesi@0 80 return false;
danielebarchiesi@0 81 }
danielebarchiesi@0 82 }
danielebarchiesi@0 83 };
danielebarchiesi@0 84 //add equal keys
danielebarchiesi@0 85 imce.fileKeys.k40 = imce.fileKeys.k38;
danielebarchiesi@0 86 imce.fileKeys.k36 = imce.fileKeys.k35;
danielebarchiesi@0 87 imce.fileKeys.k45 = imce.fileKeys.k13;
danielebarchiesi@0 88 //add default operation keys. delete, R(esize), T(humbnails), U(pload)
danielebarchiesi@0 89 $.each({k46: 'delete', k82: 'resize', k84: 'thumb', k85: 'upload'}, function (k, op) {
danielebarchiesi@0 90 imce.fileKeys[k] = function (e) {
danielebarchiesi@0 91 if (imce.ops[op] && !imce.ops[op].disabled) imce.opClick(op);
danielebarchiesi@0 92 };
danielebarchiesi@0 93 });
danielebarchiesi@0 94
danielebarchiesi@0 95 //prepare column sorting
danielebarchiesi@0 96 imce.initiateSorting = function() {
danielebarchiesi@0 97 //add cache hook. cache the old directory's sort settings before the new one replaces it.
danielebarchiesi@0 98 imce.hooks.cache.push(function (cache, newdir) {
danielebarchiesi@0 99 cache.cid = imce.vars.cid, cache.dsc = imce.vars.dsc;
danielebarchiesi@0 100 });
danielebarchiesi@0 101 //add navigation hook. refresh sorting after the new directory content is loaded.
danielebarchiesi@0 102 imce.hooks.navigate.push(function (data, olddir, cached) {
danielebarchiesi@0 103 cached ? imce.updateSortState(data.cid, data.dsc) : imce.firstSort();
danielebarchiesi@0 104 });
danielebarchiesi@0 105 imce.vars.cid = imce.cookie('imcecid') * 1;
danielebarchiesi@0 106 imce.vars.dsc = imce.cookie('imcedsc') * 1;
danielebarchiesi@0 107 imce.cols = imce.el('file-header').rows[0].cells;
danielebarchiesi@0 108 $(imce.cols).click(function () {imce.columnSort(this.cellIndex, imce.hasC(this, 'asc'));});
danielebarchiesi@0 109 imce.firstSort();
danielebarchiesi@0 110 };
danielebarchiesi@0 111
danielebarchiesi@0 112 //sort the list for the first time
danielebarchiesi@0 113 imce.firstSort = function() {
danielebarchiesi@0 114 imce.columnSort(imce.vars.cid, imce.vars.dsc);
danielebarchiesi@0 115 };
danielebarchiesi@0 116
danielebarchiesi@0 117 //sort file list according to column index.
danielebarchiesi@0 118 imce.columnSort = function(cid, dsc) {
danielebarchiesi@0 119 if (imce.findex.length < 2) return;
danielebarchiesi@0 120 var func = 'sort'+ (cid == 0 ? 'Str' : 'Num') + (dsc ? 'Dsc' : 'Asc');
danielebarchiesi@0 121 var prop = cid == 2 || cid == 3 ? 'innerHTML' : 'id';
danielebarchiesi@0 122 //sort rows
danielebarchiesi@0 123 imce.findex.sort(cid ? function(r1, r2) {return imce[func](r1.cells[cid][prop], r2.cells[cid][prop])} : function(r1, r2) {return imce[func](r1.id, r2.id)});
danielebarchiesi@0 124 //insert sorted rows
danielebarchiesi@0 125 for (var row, i=0; row = imce.findex[i]; i++) {
danielebarchiesi@0 126 imce.tbody.appendChild(row);
danielebarchiesi@0 127 }
danielebarchiesi@0 128 imce.updateSortState(cid, dsc);
danielebarchiesi@0 129 };
danielebarchiesi@0 130
danielebarchiesi@0 131 //update column states
danielebarchiesi@0 132 imce.updateSortState = function(cid, dsc) {
danielebarchiesi@0 133 $(imce.cols[imce.vars.cid]).removeClass(imce.vars.dsc ? 'desc' : 'asc');
danielebarchiesi@0 134 $(imce.cols[cid]).addClass(dsc ? 'desc' : 'asc');
danielebarchiesi@0 135 imce.vars.cid != cid && imce.cookie('imcecid', imce.vars.cid = cid);
danielebarchiesi@0 136 imce.vars.dsc != dsc && imce.cookie('imcedsc', (imce.vars.dsc = dsc) ? 1 : 0);
danielebarchiesi@0 137 };
danielebarchiesi@0 138
danielebarchiesi@0 139 //sorters
danielebarchiesi@0 140 imce.sortStrAsc = function(a, b) {return a.toLowerCase() < b.toLowerCase() ? -1 : 1;};
danielebarchiesi@0 141 imce.sortStrDsc = function(a, b) {return imce.sortStrAsc(b, a);};
danielebarchiesi@0 142 imce.sortNumAsc = function(a, b) {return a-b;};
danielebarchiesi@0 143 imce.sortNumDsc = function(a, b) {return b-a};
danielebarchiesi@0 144
danielebarchiesi@0 145 //set resizers for resizable areas and recall previous dimensions
danielebarchiesi@0 146 imce.initiateResizeBars = function () {
danielebarchiesi@0 147 imce.setResizer('#navigation-resizer', 'X', imce.NW, null, 1, function(p1, p2, m) {
danielebarchiesi@0 148 p1 != p2 && imce.cookie('imcenww', p2);
danielebarchiesi@0 149 });
danielebarchiesi@0 150 imce.setResizer('#browse-resizer', 'Y', imce.BW, imce.PW, 50, function(p1, p2, m) {
danielebarchiesi@0 151 p1 != p2 && imce.cookie('imcebwh', p2);
danielebarchiesi@0 152 });
danielebarchiesi@0 153 imce.recallDimensions();
danielebarchiesi@0 154 };
danielebarchiesi@0 155
danielebarchiesi@0 156 //set a resize bar
danielebarchiesi@0 157 imce.setResizer = function (resizer, axis, area1, area2, Min, callback) {
danielebarchiesi@0 158 var opt = axis == 'X' ? {pos: 'pageX', func: 'width'} : {pos: 'pageY', func: 'height'};
danielebarchiesi@0 159 var Min = Min || 0;
danielebarchiesi@0 160 var $area1 = $(area1), $area2 = area2 ? $(area2) : null, $doc = $(document);
danielebarchiesi@0 161 $(resizer).mousedown(function(e) {
danielebarchiesi@0 162 var pos = e[opt.pos];
danielebarchiesi@0 163 var end = start = $area1[opt.func]();
danielebarchiesi@0 164 var Max = $area2 ? start + $area2[opt.func]() : 1200;
danielebarchiesi@0 165 var drag = function(e) {
danielebarchiesi@0 166 end = Math.min(Max - Min, Math.max(start + e[opt.pos] - pos, Min));
danielebarchiesi@0 167 $area1[opt.func](end);
danielebarchiesi@0 168 $area2 && $area2[opt.func](Max - end);
danielebarchiesi@0 169 return false;
danielebarchiesi@0 170 };
danielebarchiesi@0 171 var undrag = function(e) {
danielebarchiesi@0 172 $doc.unbind('mousemove', drag).unbind('mouseup', undrag);
danielebarchiesi@0 173 callback && callback(start, end, Max);
danielebarchiesi@0 174 };
danielebarchiesi@0 175 $doc.mousemove(drag).mouseup(undrag);
danielebarchiesi@0 176 return false;
danielebarchiesi@0 177 });
danielebarchiesi@0 178 };
danielebarchiesi@0 179
danielebarchiesi@0 180 //get&set area dimensions of the last session from the cookie
danielebarchiesi@0 181 imce.recallDimensions = function() {
danielebarchiesi@0 182 var $body = $(document.body);
danielebarchiesi@0 183 if (!$body.is('.imce')) return;
danielebarchiesi@0 184 //row heights
danielebarchiesi@0 185 imce.recallHeights(imce.cookie('imcebwh') * 1);
danielebarchiesi@0 186 $(window).resize(function(){imce.recallHeights()});
danielebarchiesi@0 187 //navigation wrapper
danielebarchiesi@0 188 var nwOldWidth = imce.cookie('imcenww') * 1;
danielebarchiesi@0 189 nwOldWidth && $(imce.NW).width(Math.min(nwOldWidth, $body.width() - 10));
danielebarchiesi@0 190 };
danielebarchiesi@0 191
danielebarchiesi@0 192 //set row heights with respect to window height
danielebarchiesi@0 193 imce.recallHeights = function(bwFixedHeight) {
danielebarchiesi@0 194 //window & body dimensions
danielebarchiesi@0 195 var winHeight = $.browser.opera ? window.innerHeight : $(window).height();
danielebarchiesi@0 196 var bodyHeight = $(document.body).outerHeight(true);
danielebarchiesi@0 197 var diff = winHeight - bodyHeight;
danielebarchiesi@0 198 var bwHeight = $(imce.BW).height(), pwHeight = $(imce.PW).height();
danielebarchiesi@0 199 if (bwFixedHeight) {
danielebarchiesi@0 200 //row heights
danielebarchiesi@0 201 diff -= bwFixedHeight - bwHeight;
danielebarchiesi@0 202 bwHeight = bwFixedHeight;
danielebarchiesi@0 203 pwHeight += diff;
danielebarchiesi@0 204 }
danielebarchiesi@0 205 else {
danielebarchiesi@0 206 diff = parseInt(diff/2);
danielebarchiesi@0 207 bwHeight += diff;
danielebarchiesi@0 208 pwHeight += diff;
danielebarchiesi@0 209 }
danielebarchiesi@0 210 $(imce.BW).height(bwHeight);
danielebarchiesi@0 211 $(imce.PW).height(pwHeight);
danielebarchiesi@0 212 };
danielebarchiesi@0 213
danielebarchiesi@0 214 //cookie get & set
danielebarchiesi@0 215 imce.cookie = function (name, value) {
danielebarchiesi@0 216 if (typeof(value) == 'undefined') {//get
danielebarchiesi@0 217 return unescape((document.cookie.match(new RegExp('(^|;) *'+ name +'=([^;]*)(;|$)')) || ['', '', ''])[2]);
danielebarchiesi@0 218 }
danielebarchiesi@0 219 document.cookie = name +'='+ escape(value) +'; expires='+ (new Date(new Date() * 1 + 15 * 86400000)).toGMTString() +'; path=' + Drupal.settings.basePath + 'imce';//set
danielebarchiesi@0 220 };
danielebarchiesi@0 221
danielebarchiesi@0 222 //view thumbnails(smaller than tMaxW x tMaxH) inside the rows.
danielebarchiesi@0 223 //Large images can also be previewed by setting imce.vars.prvstyle to a valid image style(imagecache preset)
danielebarchiesi@0 224 imce.thumbRow = function (row) {
danielebarchiesi@0 225 var w = row.cells[2].innerHTML * 1;
danielebarchiesi@0 226 if (!w) return;
danielebarchiesi@0 227 var h = row.cells[3].innerHTML * 1;
danielebarchiesi@0 228 if (imce.vars.tMaxW < w || imce.vars.tMaxH < h) {
danielebarchiesi@0 229 if (!imce.vars.prvstyle || imce.conf.dir.indexOf('styles') == 0) return;
danielebarchiesi@0 230 var img = new Image();
danielebarchiesi@0 231 img.src = imce.imagestyleURL(imce.getURL(row.id), imce.vars.prvstyle);
danielebarchiesi@0 232 img.className = 'imagestyle-' + imce.vars.prvstyle;
danielebarchiesi@0 233 }
danielebarchiesi@0 234 else {
danielebarchiesi@0 235 var prvH = h, prvW = w;
danielebarchiesi@0 236 if (imce.vars.prvW < w || imce.vars.prvH < h) {
danielebarchiesi@0 237 if (h < w) {
danielebarchiesi@0 238 prvW = imce.vars.prvW;
danielebarchiesi@0 239 prvH = prvW*h/w;
danielebarchiesi@0 240 }
danielebarchiesi@0 241 else {
danielebarchiesi@0 242 prvH = imce.vars.prvH;
danielebarchiesi@0 243 prvW = prvH*w/h;
danielebarchiesi@0 244 }
danielebarchiesi@0 245 }
danielebarchiesi@0 246 var img = new Image(prvW, prvH);
danielebarchiesi@0 247 img.src = imce.getURL(row.id);
danielebarchiesi@0 248 }
danielebarchiesi@0 249 var cell = row.cells[0];
danielebarchiesi@0 250 cell.insertBefore(img, cell.firstChild);
danielebarchiesi@0 251 };
danielebarchiesi@0 252
danielebarchiesi@0 253 //convert a file URL returned by imce.getURL() to an image style(imagecache preset) URL
danielebarchiesi@0 254 imce.imagestyleURL = function (url, stylename) {
danielebarchiesi@0 255 var len = imce.conf.furl.length - 1;
danielebarchiesi@0 256 return url.substr(0, len) + '/styles/' + stylename + '/' + imce.conf.scheme + url.substr(len);
danielebarchiesi@0 257 };
danielebarchiesi@0 258
danielebarchiesi@0 259 // replace table view with box view for file list
danielebarchiesi@0 260 imce.boxView = function () {
danielebarchiesi@0 261 var w = imce.vars.boxW, h = imce.vars.boxH;
danielebarchiesi@0 262 if (!w || !h || $.browser.msie && parseFloat($.browser.version) < 8) return;
danielebarchiesi@0 263 var $body = $(document.body);
danielebarchiesi@0 264 var toggle = function() {
danielebarchiesi@0 265 $body.toggleClass('box-view');
danielebarchiesi@0 266 // refresh dom. required by all except FF.
danielebarchiesi@0 267 !$.browser.mozilla && $('#file-list').appendTo(imce.FW).appendTo(imce.FLW);
danielebarchiesi@0 268 };
danielebarchiesi@0 269 $body.append('<style type="text/css">.box-view #file-list td.name {width: ' + w + 'px;height: ' + h + 'px;} .box-view #file-list td.name span {width: ' + w + 'px;word-wrap: normal;text-overflow: ellipsis;}</style>');
danielebarchiesi@0 270 imce.hooks.load.push(function() {
danielebarchiesi@0 271 toggle();
danielebarchiesi@0 272 imce.SBW.scrollTop = 0;
danielebarchiesi@0 273 imce.opAdd({name: 'changeview', title: Drupal.t('Change view'), func: toggle});
danielebarchiesi@0 274 });
danielebarchiesi@0 275 imce.hooks.list.push(imce.boxViewRow);
danielebarchiesi@0 276 };
danielebarchiesi@0 277
danielebarchiesi@0 278 // process a row for box view. include all data in box title.
danielebarchiesi@0 279 imce.boxViewRow = function (row) {
danielebarchiesi@0 280 var s = ' | ', w = row.cells[2].innerHTML * 1, dim = w ? s + w + 'x' + row.cells[3].innerHTML * 1 : '';
danielebarchiesi@0 281 row.cells[0].title = imce.decode(row.id) + s + row.cells[1].innerHTML + (dim) + s + row.cells[4].innerHTML;
danielebarchiesi@0 282 };
danielebarchiesi@0 283
danielebarchiesi@0 284 })(jQuery);