1
|
|
2
|
|
3
|
(function($) {
|
4
|
|
5
|
|
6
|
imce.hooks.load.push(function () {
|
7
|
$('#edit-width, #edit-height').focus(function () {
|
8
|
var fid, r, w, isW, val;
|
9
|
if (fid = imce.vars.prvfid) {
|
10
|
isW = this.id == 'edit-width', val = imce.el(isW ? 'edit-height' : 'edit-width').value*1;
|
11
|
if (val && (w = imce.isImage(fid)) && (r = imce.fids[fid].cells[3].innerHTML*1 / w))
|
12
|
this.value = Math.round(isW ? val/r : val*r);
|
13
|
}
|
14
|
});
|
15
|
});
|
16
|
|
17
|
|
18
|
var F = null;
|
19
|
imce.initiateShortcuts = function () {
|
20
|
$(imce.NW).attr('tabindex', '0').keydown(function (e) {
|
21
|
if (F = imce.dirKeys['k'+ e.keyCode]) return F(e);
|
22
|
});
|
23
|
$(imce.FLW).attr('tabindex', '0').keydown(function (e) {
|
24
|
if (F = imce.fileKeys['k'+ e.keyCode]) return F(e);
|
25
|
}).focus();
|
26
|
};
|
27
|
|
28
|
|
29
|
imce.dirKeys = {
|
30
|
k35: function (e) {
|
31
|
var L = imce.tree['.'].li;
|
32
|
if (e.keyCode == 35) while (imce.hasC(L, 'expanded')) L = L.lastChild.lastChild;
|
33
|
$(L.childNodes[1]).click().focus();
|
34
|
},
|
35
|
k37: function (e) {
|
36
|
var L, B = imce.tree[imce.conf.dir], right = e.keyCode == 39;
|
37
|
if (B.ul && (right ^ imce.hasC(L = B.li, 'expanded')) ) $(L.firstChild).click();
|
38
|
else if (right) $(imce.FLW).focus();
|
39
|
},
|
40
|
k38: function (e) {
|
41
|
var B = imce.tree[imce.conf.dir];
|
42
|
if (L = B.li.previousSibling) {
|
43
|
while (imce.hasC(L, 'expanded')) L = L.lastChild.lastChild;
|
44
|
$(L.childNodes[1]).click().focus();
|
45
|
}
|
46
|
else if ((L = B.li.parentNode.parentNode) && L.tagName == 'LI') $(L.childNodes[1]).click().focus();
|
47
|
},
|
48
|
k40: function (e) {
|
49
|
var B = imce.tree[imce.conf.dir], L = B.li, U = B.ul;
|
50
|
if (U && imce.hasC(L, 'expanded')) $(U.firstChild.childNodes[1]).click().focus();
|
51
|
else do {if (L.nextSibling) return $(L.nextSibling.childNodes[1]).click().focus();
|
52
|
}while ((L = L.parentNode.parentNode).tagName == 'LI');
|
53
|
}
|
54
|
};
|
55
|
|
56
|
imce.dirKeys.k36 = imce.dirKeys.k35;
|
57
|
imce.dirKeys.k39 = imce.dirKeys.k37;
|
58
|
|
59
|
|
60
|
imce.fileKeys = {
|
61
|
k38: function (e) {
|
62
|
var fid = imce.lastFid(), i = fid ? imce.fids[fid].rowIndex+e.keyCode-39 : 0;
|
63
|
imce.fileClick(imce.findex[i], e.ctrlKey, e.shiftKey);
|
64
|
},
|
65
|
k35: function (e) {
|
66
|
imce.fileClick(imce.findex[e.keyCode == 35 ? imce.findex.length-1 : 0], e.ctrlKey, e.shiftKey);
|
67
|
},
|
68
|
k13: function (e) {
|
69
|
imce.send(imce.vars.prvfid);
|
70
|
return false;
|
71
|
},
|
72
|
k37: function (e) {
|
73
|
$(imce.tree[imce.conf.dir].a).focus();
|
74
|
},
|
75
|
k65: function (e) {
|
76
|
if (e.ctrlKey && imce.findex.length) {
|
77
|
var fid = imce.findex[0].id;
|
78
|
imce.selected[fid] ? (imce.vars.lastfid = fid) : imce.fileClick(fid);
|
79
|
imce.fileClick(imce.findex[imce.findex.length-1], false, true);
|
80
|
return false;
|
81
|
}
|
82
|
}
|
83
|
};
|
84
|
|
85
|
imce.fileKeys.k40 = imce.fileKeys.k38;
|
86
|
imce.fileKeys.k36 = imce.fileKeys.k35;
|
87
|
imce.fileKeys.k45 = imce.fileKeys.k13;
|
88
|
|
89
|
$.each({k46: 'delete', k82: 'resize', k84: 'thumb', k85: 'upload'}, function (k, op) {
|
90
|
imce.fileKeys[k] = function (e) {
|
91
|
if (imce.ops[op] && !imce.ops[op].disabled) imce.opClick(op);
|
92
|
};
|
93
|
});
|
94
|
|
95
|
|
96
|
imce.initiateSorting = function() {
|
97
|
|
98
|
imce.hooks.cache.push(function (cache, newdir) {
|
99
|
cache.cid = imce.vars.cid, cache.dsc = imce.vars.dsc;
|
100
|
});
|
101
|
|
102
|
imce.hooks.navigate.push(function (data, olddir, cached) {
|
103
|
cached ? imce.updateSortState(data.cid, data.dsc) : imce.firstSort();
|
104
|
});
|
105
|
imce.vars.cid = imce.cookie('imcecid') * 1;
|
106
|
imce.vars.dsc = imce.cookie('imcedsc') * 1;
|
107
|
imce.cols = imce.el('file-header').rows[0].cells;
|
108
|
$(imce.cols).click(function () {imce.columnSort(this.cellIndex, imce.hasC(this, 'asc'));});
|
109
|
imce.firstSort();
|
110
|
};
|
111
|
|
112
|
|
113
|
imce.firstSort = function() {
|
114
|
imce.columnSort(imce.vars.cid, imce.vars.dsc);
|
115
|
};
|
116
|
|
117
|
|
118
|
imce.columnSort = function(cid, dsc) {
|
119
|
if (imce.findex.length < 2) return;
|
120
|
var func = 'sort'+ (cid == 0 ? 'Str' : 'Num') + (dsc ? 'Dsc' : 'Asc');
|
121
|
var prop = cid == 2 || cid == 3 ? 'innerHTML' : 'id';
|
122
|
|
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)});
|
124
|
|
125
|
for (var row, i=0; row = imce.findex[i]; i++) {
|
126
|
imce.tbody.appendChild(row);
|
127
|
}
|
128
|
imce.updateSortState(cid, dsc);
|
129
|
};
|
130
|
|
131
|
|
132
|
imce.updateSortState = function(cid, dsc) {
|
133
|
$(imce.cols[imce.vars.cid]).removeClass(imce.vars.dsc ? 'desc' : 'asc');
|
134
|
$(imce.cols[cid]).addClass(dsc ? 'desc' : 'asc');
|
135
|
imce.vars.cid != cid && imce.cookie('imcecid', imce.vars.cid = cid);
|
136
|
imce.vars.dsc != dsc && imce.cookie('imcedsc', (imce.vars.dsc = dsc) ? 1 : 0);
|
137
|
};
|
138
|
|
139
|
|
140
|
imce.sortStrAsc = function(a, b) {return a.toLowerCase() < b.toLowerCase() ? -1 : 1;};
|
141
|
imce.sortStrDsc = function(a, b) {return imce.sortStrAsc(b, a);};
|
142
|
imce.sortNumAsc = function(a, b) {return a-b;};
|
143
|
imce.sortNumDsc = function(a, b) {return b-a};
|
144
|
|
145
|
|
146
|
imce.initiateResizeBars = function () {
|
147
|
imce.setResizer('#navigation-resizer', 'X', imce.NW, null, 1, function(p1, p2, m) {
|
148
|
p1 != p2 && imce.cookie('imcenww', p2);
|
149
|
});
|
150
|
imce.setResizer('#browse-resizer', 'Y', imce.BW, imce.PW, 50, function(p1, p2, m) {
|
151
|
p1 != p2 && imce.cookie('imcebwh', p2);
|
152
|
});
|
153
|
imce.recallDimensions();
|
154
|
};
|
155
|
|
156
|
|
157
|
imce.setResizer = function (resizer, axis, area1, area2, Min, callback) {
|
158
|
var opt = axis == 'X' ? {pos: 'pageX', func: 'width'} : {pos: 'pageY', func: 'height'};
|
159
|
var Min = Min || 0;
|
160
|
var $area1 = $(area1), $area2 = area2 ? $(area2) : null, $doc = $(document);
|
161
|
$(resizer).mousedown(function(e) {
|
162
|
var pos = e[opt.pos];
|
163
|
var end = start = $area1[opt.func]();
|
164
|
var Max = $area2 ? start + $area2[opt.func]() : 1200;
|
165
|
var drag = function(e) {
|
166
|
end = Math.min(Max - Min, Math.max(start + e[opt.pos] - pos, Min));
|
167
|
$area1[opt.func](end);
|
168
|
$area2 && $area2[opt.func](Max - end);
|
169
|
return false;
|
170
|
};
|
171
|
var undrag = function(e) {
|
172
|
$doc.unbind('mousemove', drag).unbind('mouseup', undrag);
|
173
|
callback && callback(start, end, Max);
|
174
|
};
|
175
|
$doc.mousemove(drag).mouseup(undrag);
|
176
|
return false;
|
177
|
});
|
178
|
};
|
179
|
|
180
|
|
181
|
imce.recallDimensions = function() {
|
182
|
var $body = $(document.body);
|
183
|
if (!$body.hasClass('imce')) return;
|
184
|
|
185
|
imce.recallHeights(imce.cookie('imcebwh') * 1);
|
186
|
$(window).resize(function(){imce.recallHeights()});
|
187
|
|
188
|
var nwOldWidth = imce.cookie('imcenww') * 1;
|
189
|
nwOldWidth && $(imce.NW).width(Math.min(nwOldWidth, $body.width() - 10));
|
190
|
};
|
191
|
|
192
|
|
193
|
imce.recallHeights = function(bwFixedHeight) {
|
194
|
|
195
|
var winHeight = window.opera ? window.innerHeight : $(window).height();
|
196
|
var bodyHeight = $(document.body).outerHeight(true);
|
197
|
var diff = winHeight - bodyHeight;
|
198
|
var bwHeight = $(imce.BW).height(), pwHeight = $(imce.PW).height();
|
199
|
if (bwFixedHeight) {
|
200
|
|
201
|
diff -= bwFixedHeight - bwHeight;
|
202
|
bwHeight = bwFixedHeight;
|
203
|
pwHeight += diff;
|
204
|
}
|
205
|
else {
|
206
|
diff = parseInt(diff/2);
|
207
|
bwHeight += diff;
|
208
|
pwHeight += diff;
|
209
|
}
|
210
|
$(imce.BW).height(bwHeight);
|
211
|
$(imce.PW).height(pwHeight);
|
212
|
};
|
213
|
|
214
|
|
215
|
imce.cookie = function (name, value) {
|
216
|
if (typeof(value) == 'undefined') {
|
217
|
return document.cookie ? imce.decode((document.cookie.match(new RegExp('(?:^|;) *' + name + '=([^;]*)(?:;|$)')) || ['', ''])[1].replace(/\+/g, '%20')) : '';
|
218
|
}
|
219
|
document.cookie = name +'='+ encodeURIComponent(value) +'; expires='+ (new Date(new Date() * 1 + 15 * 86400000)).toUTCString() +'; path=' + Drupal.settings.basePath + 'imce';
|
220
|
};
|
221
|
|
222
|
|
223
|
|
224
|
imce.thumbRow = function (row) {
|
225
|
var w = row.cells[2].innerHTML * 1;
|
226
|
if (!w) return;
|
227
|
var h = row.cells[3].innerHTML * 1;
|
228
|
if (imce.vars.tMaxW < w || imce.vars.tMaxH < h) {
|
229
|
if (!imce.vars.prvstyle || imce.conf.dir.indexOf('styles') == 0) return;
|
230
|
var img = new Image();
|
231
|
img.src = imce.imagestyleURL(imce.getURL(row.id), imce.vars.prvstyle);
|
232
|
img.className = 'imagestyle-' + imce.vars.prvstyle;
|
233
|
}
|
234
|
else {
|
235
|
var prvH = h, prvW = w;
|
236
|
if (imce.vars.prvW < w || imce.vars.prvH < h) {
|
237
|
if (h < w) {
|
238
|
prvW = imce.vars.prvW;
|
239
|
prvH = prvW*h/w;
|
240
|
}
|
241
|
else {
|
242
|
prvH = imce.vars.prvH;
|
243
|
prvW = prvH*w/h;
|
244
|
}
|
245
|
}
|
246
|
var img = new Image(prvW, prvH);
|
247
|
img.src = imce.getURL(row.id);
|
248
|
}
|
249
|
var cell = row.cells[0];
|
250
|
cell.insertBefore(img, cell.firstChild);
|
251
|
};
|
252
|
|
253
|
|
254
|
imce.imagestyleURL = function (url, stylename) {
|
255
|
var len = imce.conf.furl.length - 1;
|
256
|
return url.substr(0, len) + '/styles/' + stylename + '/' + imce.conf.scheme + url.substr(len);
|
257
|
};
|
258
|
|
259
|
|
260
|
imce.boxView = function () {
|
261
|
var w = imce.vars.boxW, h = imce.vars.boxH;
|
262
|
if (!w || !h || imce.ie && imce.ie < 8) return;
|
263
|
var $body = $(document.body);
|
264
|
var toggle = function() {
|
265
|
$body.toggleClass('box-view');
|
266
|
|
267
|
$('#file-list').appendTo(imce.FW).appendTo(imce.FLW);
|
268
|
};
|
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>');
|
270
|
imce.hooks.load.push(function() {
|
271
|
toggle();
|
272
|
imce.SBW.scrollTop = 0;
|
273
|
imce.opAdd({name: 'changeview', title: Drupal.t('Change view'), func: toggle});
|
274
|
});
|
275
|
imce.hooks.list.push(imce.boxViewRow);
|
276
|
};
|
277
|
|
278
|
|
279
|
imce.boxViewRow = function (row) {
|
280
|
var s = ' | ', w = row.cells[2].innerHTML * 1, dim = w ? s + w + 'x' + row.cells[3].innerHTML * 1 : '';
|
281
|
row.cells[0].title = imce.decode(row.id) + s + row.cells[1].innerHTML + (dim) + s + row.cells[4].innerHTML;
|
282
|
};
|
283
|
|
284
|
})(jQuery);
|