danielebarchiesi@0: //This pack implemets: keyboard shortcuts, file sorting, resize bars, and inline thumbnail preview. danielebarchiesi@0: danielebarchiesi@0: (function($) { danielebarchiesi@0: danielebarchiesi@0: // add scale calculator for resizing. danielebarchiesi@0: imce.hooks.load.push(function () { danielebarchiesi@0: $('#edit-width, #edit-height').focus(function () { danielebarchiesi@0: var fid, r, w, isW, val; danielebarchiesi@0: if (fid = imce.vars.prvfid) { danielebarchiesi@0: isW = this.id == 'edit-width', val = imce.el(isW ? 'edit-height' : 'edit-width').value*1; danielebarchiesi@0: if (val && (w = imce.isImage(fid)) && (r = imce.fids[fid].cells[3].innerHTML*1 / w)) danielebarchiesi@0: this.value = Math.round(isW ? val/r : val*r); danielebarchiesi@0: } danielebarchiesi@0: }); danielebarchiesi@0: }); danielebarchiesi@0: danielebarchiesi@0: // Shortcuts danielebarchiesi@0: var F = null; danielebarchiesi@0: imce.initiateShortcuts = function () { danielebarchiesi@0: $(imce.NW).attr('tabindex', '0').keydown(function (e) { danielebarchiesi@0: if (F = imce.dirKeys['k'+ e.keyCode]) return F(e); danielebarchiesi@0: }); danielebarchiesi@0: $(imce.FLW).attr('tabindex', '0').keydown(function (e) { danielebarchiesi@0: if (F = imce.fileKeys['k'+ e.keyCode]) return F(e); danielebarchiesi@0: }).focus(); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //shortcut key-function pairs for directories danielebarchiesi@0: imce.dirKeys = { danielebarchiesi@0: k35: function (e) {//end-home. select first or last dir danielebarchiesi@0: var L = imce.tree['.'].li; danielebarchiesi@0: if (e.keyCode == 35) while (imce.hasC(L, 'expanded')) L = L.lastChild.lastChild; danielebarchiesi@0: $(L.childNodes[1]).click().focus(); danielebarchiesi@0: }, danielebarchiesi@0: k37: function (e) {//left-right. collapse-expand directories.(right may also move focus on files) danielebarchiesi@0: var L, B = imce.tree[imce.conf.dir], right = e.keyCode == 39; danielebarchiesi@0: if (B.ul && (right ^ imce.hasC(L = B.li, 'expanded')) ) $(L.firstChild).click(); danielebarchiesi@0: else if (right) $(imce.FLW).focus(); danielebarchiesi@0: }, danielebarchiesi@0: k38: function (e) {//up. select the previous directory danielebarchiesi@0: var B = imce.tree[imce.conf.dir]; danielebarchiesi@0: if (L = B.li.previousSibling) { danielebarchiesi@0: while (imce.hasC(L, 'expanded')) L = L.lastChild.lastChild; danielebarchiesi@0: $(L.childNodes[1]).click().focus(); danielebarchiesi@0: } danielebarchiesi@0: else if ((L = B.li.parentNode.parentNode) && L.tagName == 'LI') $(L.childNodes[1]).click().focus(); danielebarchiesi@0: }, danielebarchiesi@0: k40: function (e) {//down. select the next directory danielebarchiesi@0: var B = imce.tree[imce.conf.dir], L = B.li, U = B.ul; danielebarchiesi@0: if (U && imce.hasC(L, 'expanded')) $(U.firstChild.childNodes[1]).click().focus(); danielebarchiesi@0: else do {if (L.nextSibling) return $(L.nextSibling.childNodes[1]).click().focus(); danielebarchiesi@0: }while ((L = L.parentNode.parentNode).tagName == 'LI'); danielebarchiesi@0: } danielebarchiesi@0: }; danielebarchiesi@0: //add equal keys danielebarchiesi@0: imce.dirKeys.k36 = imce.dirKeys.k35; danielebarchiesi@0: imce.dirKeys.k39 = imce.dirKeys.k37; danielebarchiesi@0: danielebarchiesi@0: //shortcut key-function pairs for files danielebarchiesi@0: imce.fileKeys = { danielebarchiesi@0: k38: function (e) {//up-down. select previous-next row danielebarchiesi@0: var fid = imce.lastFid(), i = fid ? imce.fids[fid].rowIndex+e.keyCode-39 : 0; danielebarchiesi@0: imce.fileClick(imce.findex[i], e.ctrlKey, e.shiftKey); danielebarchiesi@0: }, danielebarchiesi@0: k35: function (e) {//end-home. select first or last row danielebarchiesi@0: imce.fileClick(imce.findex[e.keyCode == 35 ? imce.findex.length-1 : 0], e.ctrlKey, e.shiftKey); danielebarchiesi@0: }, danielebarchiesi@0: k13: function (e) {//enter-insert. send file to external app. danielebarchiesi@0: imce.send(imce.vars.prvfid); danielebarchiesi@0: return false; danielebarchiesi@0: }, danielebarchiesi@0: k37: function (e) {//left. focus on directories danielebarchiesi@0: $(imce.tree[imce.conf.dir].a).focus(); danielebarchiesi@0: }, danielebarchiesi@0: k65: function (e) {//ctrl+A to select all danielebarchiesi@0: if (e.ctrlKey && imce.findex.length) { danielebarchiesi@0: var fid = imce.findex[0].id; danielebarchiesi@0: imce.selected[fid] ? (imce.vars.lastfid = fid) : imce.fileClick(fid);//select first row danielebarchiesi@0: imce.fileClick(imce.findex[imce.findex.length-1], false, true);//shift+click last row danielebarchiesi@0: return false; danielebarchiesi@0: } danielebarchiesi@0: } danielebarchiesi@0: }; danielebarchiesi@0: //add equal keys danielebarchiesi@0: imce.fileKeys.k40 = imce.fileKeys.k38; danielebarchiesi@0: imce.fileKeys.k36 = imce.fileKeys.k35; danielebarchiesi@0: imce.fileKeys.k45 = imce.fileKeys.k13; danielebarchiesi@0: //add default operation keys. delete, R(esize), T(humbnails), U(pload) danielebarchiesi@0: $.each({k46: 'delete', k82: 'resize', k84: 'thumb', k85: 'upload'}, function (k, op) { danielebarchiesi@0: imce.fileKeys[k] = function (e) { danielebarchiesi@0: if (imce.ops[op] && !imce.ops[op].disabled) imce.opClick(op); danielebarchiesi@0: }; danielebarchiesi@0: }); danielebarchiesi@0: danielebarchiesi@0: //prepare column sorting danielebarchiesi@0: imce.initiateSorting = function() { danielebarchiesi@0: //add cache hook. cache the old directory's sort settings before the new one replaces it. danielebarchiesi@0: imce.hooks.cache.push(function (cache, newdir) { danielebarchiesi@0: cache.cid = imce.vars.cid, cache.dsc = imce.vars.dsc; danielebarchiesi@0: }); danielebarchiesi@0: //add navigation hook. refresh sorting after the new directory content is loaded. danielebarchiesi@0: imce.hooks.navigate.push(function (data, olddir, cached) { danielebarchiesi@0: cached ? imce.updateSortState(data.cid, data.dsc) : imce.firstSort(); danielebarchiesi@0: }); danielebarchiesi@0: imce.vars.cid = imce.cookie('imcecid') * 1; danielebarchiesi@0: imce.vars.dsc = imce.cookie('imcedsc') * 1; danielebarchiesi@0: imce.cols = imce.el('file-header').rows[0].cells; danielebarchiesi@0: $(imce.cols).click(function () {imce.columnSort(this.cellIndex, imce.hasC(this, 'asc'));}); danielebarchiesi@0: imce.firstSort(); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //sort the list for the first time danielebarchiesi@0: imce.firstSort = function() { danielebarchiesi@0: imce.columnSort(imce.vars.cid, imce.vars.dsc); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //sort file list according to column index. danielebarchiesi@0: imce.columnSort = function(cid, dsc) { danielebarchiesi@0: if (imce.findex.length < 2) return; danielebarchiesi@0: var func = 'sort'+ (cid == 0 ? 'Str' : 'Num') + (dsc ? 'Dsc' : 'Asc'); danielebarchiesi@0: var prop = cid == 2 || cid == 3 ? 'innerHTML' : 'id'; danielebarchiesi@0: //sort rows danielebarchiesi@0: 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: //insert sorted rows danielebarchiesi@0: for (var row, i=0; row = imce.findex[i]; i++) { danielebarchiesi@0: imce.tbody.appendChild(row); danielebarchiesi@0: } danielebarchiesi@0: imce.updateSortState(cid, dsc); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //update column states danielebarchiesi@0: imce.updateSortState = function(cid, dsc) { danielebarchiesi@0: $(imce.cols[imce.vars.cid]).removeClass(imce.vars.dsc ? 'desc' : 'asc'); danielebarchiesi@0: $(imce.cols[cid]).addClass(dsc ? 'desc' : 'asc'); danielebarchiesi@0: imce.vars.cid != cid && imce.cookie('imcecid', imce.vars.cid = cid); danielebarchiesi@0: imce.vars.dsc != dsc && imce.cookie('imcedsc', (imce.vars.dsc = dsc) ? 1 : 0); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //sorters danielebarchiesi@0: imce.sortStrAsc = function(a, b) {return a.toLowerCase() < b.toLowerCase() ? -1 : 1;}; danielebarchiesi@0: imce.sortStrDsc = function(a, b) {return imce.sortStrAsc(b, a);}; danielebarchiesi@0: imce.sortNumAsc = function(a, b) {return a-b;}; danielebarchiesi@0: imce.sortNumDsc = function(a, b) {return b-a}; danielebarchiesi@0: danielebarchiesi@0: //set resizers for resizable areas and recall previous dimensions danielebarchiesi@0: imce.initiateResizeBars = function () { danielebarchiesi@0: imce.setResizer('#navigation-resizer', 'X', imce.NW, null, 1, function(p1, p2, m) { danielebarchiesi@0: p1 != p2 && imce.cookie('imcenww', p2); danielebarchiesi@0: }); danielebarchiesi@0: imce.setResizer('#browse-resizer', 'Y', imce.BW, imce.PW, 50, function(p1, p2, m) { danielebarchiesi@0: p1 != p2 && imce.cookie('imcebwh', p2); danielebarchiesi@0: }); danielebarchiesi@0: imce.recallDimensions(); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //set a resize bar danielebarchiesi@0: imce.setResizer = function (resizer, axis, area1, area2, Min, callback) { danielebarchiesi@0: var opt = axis == 'X' ? {pos: 'pageX', func: 'width'} : {pos: 'pageY', func: 'height'}; danielebarchiesi@0: var Min = Min || 0; danielebarchiesi@0: var $area1 = $(area1), $area2 = area2 ? $(area2) : null, $doc = $(document); danielebarchiesi@0: $(resizer).mousedown(function(e) { danielebarchiesi@0: var pos = e[opt.pos]; danielebarchiesi@0: var end = start = $area1[opt.func](); danielebarchiesi@0: var Max = $area2 ? start + $area2[opt.func]() : 1200; danielebarchiesi@0: var drag = function(e) { danielebarchiesi@0: end = Math.min(Max - Min, Math.max(start + e[opt.pos] - pos, Min)); danielebarchiesi@0: $area1[opt.func](end); danielebarchiesi@0: $area2 && $area2[opt.func](Max - end); danielebarchiesi@0: return false; danielebarchiesi@0: }; danielebarchiesi@0: var undrag = function(e) { danielebarchiesi@0: $doc.unbind('mousemove', drag).unbind('mouseup', undrag); danielebarchiesi@0: callback && callback(start, end, Max); danielebarchiesi@0: }; danielebarchiesi@0: $doc.mousemove(drag).mouseup(undrag); danielebarchiesi@0: return false; danielebarchiesi@0: }); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //get&set area dimensions of the last session from the cookie danielebarchiesi@0: imce.recallDimensions = function() { danielebarchiesi@0: var $body = $(document.body); danielebarchiesi@0: if (!$body.is('.imce')) return; danielebarchiesi@0: //row heights danielebarchiesi@0: imce.recallHeights(imce.cookie('imcebwh') * 1); danielebarchiesi@0: $(window).resize(function(){imce.recallHeights()}); danielebarchiesi@0: //navigation wrapper danielebarchiesi@0: var nwOldWidth = imce.cookie('imcenww') * 1; danielebarchiesi@0: nwOldWidth && $(imce.NW).width(Math.min(nwOldWidth, $body.width() - 10)); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //set row heights with respect to window height danielebarchiesi@0: imce.recallHeights = function(bwFixedHeight) { danielebarchiesi@0: //window & body dimensions danielebarchiesi@0: var winHeight = $.browser.opera ? window.innerHeight : $(window).height(); danielebarchiesi@0: var bodyHeight = $(document.body).outerHeight(true); danielebarchiesi@0: var diff = winHeight - bodyHeight; danielebarchiesi@0: var bwHeight = $(imce.BW).height(), pwHeight = $(imce.PW).height(); danielebarchiesi@0: if (bwFixedHeight) { danielebarchiesi@0: //row heights danielebarchiesi@0: diff -= bwFixedHeight - bwHeight; danielebarchiesi@0: bwHeight = bwFixedHeight; danielebarchiesi@0: pwHeight += diff; danielebarchiesi@0: } danielebarchiesi@0: else { danielebarchiesi@0: diff = parseInt(diff/2); danielebarchiesi@0: bwHeight += diff; danielebarchiesi@0: pwHeight += diff; danielebarchiesi@0: } danielebarchiesi@0: $(imce.BW).height(bwHeight); danielebarchiesi@0: $(imce.PW).height(pwHeight); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //cookie get & set danielebarchiesi@0: imce.cookie = function (name, value) { danielebarchiesi@0: if (typeof(value) == 'undefined') {//get danielebarchiesi@0: return unescape((document.cookie.match(new RegExp('(^|;) *'+ name +'=([^;]*)(;|$)')) || ['', '', ''])[2]); danielebarchiesi@0: } danielebarchiesi@0: document.cookie = name +'='+ escape(value) +'; expires='+ (new Date(new Date() * 1 + 15 * 86400000)).toGMTString() +'; path=' + Drupal.settings.basePath + 'imce';//set danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //view thumbnails(smaller than tMaxW x tMaxH) inside the rows. danielebarchiesi@0: //Large images can also be previewed by setting imce.vars.prvstyle to a valid image style(imagecache preset) danielebarchiesi@0: imce.thumbRow = function (row) { danielebarchiesi@0: var w = row.cells[2].innerHTML * 1; danielebarchiesi@0: if (!w) return; danielebarchiesi@0: var h = row.cells[3].innerHTML * 1; danielebarchiesi@0: if (imce.vars.tMaxW < w || imce.vars.tMaxH < h) { danielebarchiesi@0: if (!imce.vars.prvstyle || imce.conf.dir.indexOf('styles') == 0) return; danielebarchiesi@0: var img = new Image(); danielebarchiesi@0: img.src = imce.imagestyleURL(imce.getURL(row.id), imce.vars.prvstyle); danielebarchiesi@0: img.className = 'imagestyle-' + imce.vars.prvstyle; danielebarchiesi@0: } danielebarchiesi@0: else { danielebarchiesi@0: var prvH = h, prvW = w; danielebarchiesi@0: if (imce.vars.prvW < w || imce.vars.prvH < h) { danielebarchiesi@0: if (h < w) { danielebarchiesi@0: prvW = imce.vars.prvW; danielebarchiesi@0: prvH = prvW*h/w; danielebarchiesi@0: } danielebarchiesi@0: else { danielebarchiesi@0: prvH = imce.vars.prvH; danielebarchiesi@0: prvW = prvH*w/h; danielebarchiesi@0: } danielebarchiesi@0: } danielebarchiesi@0: var img = new Image(prvW, prvH); danielebarchiesi@0: img.src = imce.getURL(row.id); danielebarchiesi@0: } danielebarchiesi@0: var cell = row.cells[0]; danielebarchiesi@0: cell.insertBefore(img, cell.firstChild); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: //convert a file URL returned by imce.getURL() to an image style(imagecache preset) URL danielebarchiesi@0: imce.imagestyleURL = function (url, stylename) { danielebarchiesi@0: var len = imce.conf.furl.length - 1; danielebarchiesi@0: return url.substr(0, len) + '/styles/' + stylename + '/' + imce.conf.scheme + url.substr(len); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: // replace table view with box view for file list danielebarchiesi@0: imce.boxView = function () { danielebarchiesi@0: var w = imce.vars.boxW, h = imce.vars.boxH; danielebarchiesi@0: if (!w || !h || $.browser.msie && parseFloat($.browser.version) < 8) return; danielebarchiesi@0: var $body = $(document.body); danielebarchiesi@0: var toggle = function() { danielebarchiesi@0: $body.toggleClass('box-view'); danielebarchiesi@0: // refresh dom. required by all except FF. danielebarchiesi@0: !$.browser.mozilla && $('#file-list').appendTo(imce.FW).appendTo(imce.FLW); danielebarchiesi@0: }; danielebarchiesi@0: $body.append(''); danielebarchiesi@0: imce.hooks.load.push(function() { danielebarchiesi@0: toggle(); danielebarchiesi@0: imce.SBW.scrollTop = 0; danielebarchiesi@0: imce.opAdd({name: 'changeview', title: Drupal.t('Change view'), func: toggle}); danielebarchiesi@0: }); danielebarchiesi@0: imce.hooks.list.push(imce.boxViewRow); danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: // process a row for box view. include all data in box title. danielebarchiesi@0: imce.boxViewRow = function (row) { danielebarchiesi@0: var s = ' | ', w = row.cells[2].innerHTML * 1, dim = w ? s + w + 'x' + row.cells[3].innerHTML * 1 : ''; danielebarchiesi@0: row.cells[0].title = imce.decode(row.id) + s + row.cells[1].innerHTML + (dim) + s + row.cells[4].innerHTML; danielebarchiesi@0: }; danielebarchiesi@0: danielebarchiesi@0: })(jQuery);