h5ai/src/_h5ai/client/js/inc/view/viewmode.js
2012-10-19 23:52:18 +02:00

73 lines
1.8 KiB
JavaScript

modulejs.define('view/viewmode', ['_', '$', 'core/settings', 'core/resource', 'core/store'], function (_, $, allsettings, resource, store) {
var modes = ['details', 'list', 'grid', 'icons'],
settings = _.extend({}, {
modes: modes
}, allsettings.view),
storekey = 'viewmode',
template = '<li id="view-[MODE]" class="view">' +
'<a href="#">' +
'<img src="' + resource.image('view-[MODE]') + '" alt="view-[MODE]"/>' +
'<span class="l10n-[MODE]"/>' +
'</a>' +
'</li>',
adjustSpacing = function () {
var contentWidth = $('#content').width(),
$extended = $('#extended'),
itemWidth = ($extended.hasClass('view-icons') || $extended.hasClass('view-grid')) ? ($extended.find('.entry').eq(0).width() || 1) : 1;
$extended.width(Math.floor(contentWidth / itemWidth) * itemWidth);
},
update = function (viewmode) {
var $extended = $('#extended');
viewmode = _.indexOf(settings.modes, viewmode) >= 0 ? viewmode : settings.modes[0];
store.put(storekey, viewmode);
_.each(modes, function (mode) {
if (mode === viewmode) {
$('#view-' + mode).addClass('current');
$extended.addClass('view-' + mode).show();
} else {
$('#view-' + mode).removeClass('current');
$extended.removeClass('view-' + mode);
}
});
adjustSpacing();
},
init = function () {
var $navbar = $('#navbar');
settings.modes = _.intersection(settings.modes, modes);
if (settings.modes.length > 1) {
_.each(modes.reverse(), function (mode) {
if (_.indexOf(settings.modes, mode) >= 0) {
$(template.replace(/\[MODE\]/g, mode))
.appendTo($navbar)
.on('click', 'a', function (event) {
update(mode);
event.preventDefault();
});
}
});
}
update(store.get(storekey));
$(window).on('resize', adjustSpacing);
};
init();
});