Improved aligning post lists to their containers
This commit is contained in:
parent
c7f077d89a
commit
aa20251ee5
7 changed files with 118 additions and 109 deletions
|
@ -39,8 +39,8 @@ postsPerPage=20
|
||||||
logsPerPage=250
|
logsPerPage=250
|
||||||
tagsPerPage=100
|
tagsPerPage=100
|
||||||
tagsRelated=15
|
tagsRelated=15
|
||||||
thumbnailWidth=150
|
thumbnailWidth=175
|
||||||
thumbnailHeight=150
|
thumbnailHeight=175
|
||||||
thumbnailStyle=outside
|
thumbnailStyle=outside
|
||||||
endlessScrollingDefault=1
|
endlessScrollingDefault=1
|
||||||
showPostTagTitlesDefault=0
|
showPostTagTitlesDefault=0
|
||||||
|
|
|
@ -1,3 +1,8 @@
|
||||||
|
.post .thumb {
|
||||||
|
width: 150px;
|
||||||
|
height: 150px;
|
||||||
|
}
|
||||||
|
|
||||||
.comment-group .post-wrapper {
|
.comment-group .post-wrapper {
|
||||||
float: left;
|
float: left;
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,10 +17,13 @@
|
||||||
.post-type-3gp:after,
|
.post-type-3gp:after,
|
||||||
.post-type-flv:after {
|
.post-type-flv:after {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
right: 1px; /* border */
|
/* border */
|
||||||
top: 1px; /* border */
|
right: 1px;
|
||||||
width: 150px;
|
top: 1px;
|
||||||
height: 150px;
|
bottom: 1px;
|
||||||
|
left: 1px;
|
||||||
|
background-size: contain;
|
||||||
|
background-repeat: no-repeat;
|
||||||
content: ' ';
|
content: ' ';
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
}
|
}
|
||||||
|
@ -33,13 +36,13 @@
|
||||||
.post-type-flv {
|
.post-type-flv {
|
||||||
border-color: red;
|
border-color: red;
|
||||||
}
|
}
|
||||||
.post-type-swf:after { background: url('../img/thumb-overlay-swf.png'); }
|
.post-type-swf:after { background-image: url('../img/thumb-overlay-swf.png'); }
|
||||||
.post-type-youtube:after { background: url('../img/thumb-overlay-yt.png'); }
|
.post-type-youtube:after { background-image: url('../img/thumb-overlay-yt.png'); }
|
||||||
.post-type-mp4:after { background: url('../img/thumb-overlay-mp4.png'); }
|
.post-type-mp4:after { background-image: url('../img/thumb-overlay-mp4.png'); }
|
||||||
.post-type-webm:after { background: url('../img/thumb-overlay-webm.png'); }
|
.post-type-webm:after { background-image: url('../img/thumb-overlay-webm.png'); }
|
||||||
.post-type-ogg:after { background: url('../img/thumb-overlay-ogg.png'); }
|
.post-type-ogg:after { background-image: url('../img/thumb-overlay-ogg.png'); }
|
||||||
.post-type-3gp:after { background: url('../img/thumb-overlay-3gp.png'); }
|
.post-type-3gp:after { background-image: url('../img/thumb-overlay-3gp.png'); }
|
||||||
.post-type-flv:after { background: url('../img/thumb-overlay-flv.png'); }
|
.post-type-flv:after { background-image: url('../img/thumb-overlay-flv.png'); }
|
||||||
|
|
||||||
|
|
||||||
.post .toggle-tag {
|
.post .toggle-tag {
|
||||||
|
@ -86,8 +89,6 @@
|
||||||
}
|
}
|
||||||
.post img.thumb {
|
.post img.thumb {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
width: 150px;
|
|
||||||
height: 150px;
|
|
||||||
vertical-align: top;
|
vertical-align: top;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -204,32 +204,11 @@ $(function()
|
||||||
{
|
{
|
||||||
$(window).resize(function()
|
$(window).resize(function()
|
||||||
{
|
{
|
||||||
fixSize();
|
|
||||||
if ($('body').width() == $('body').data('last-width'))
|
|
||||||
return;
|
|
||||||
$('body').data('last-width', $('body').width());
|
|
||||||
$('body').trigger('dom-update');
|
$('body').trigger('dom-update');
|
||||||
});
|
});
|
||||||
$('body').bind('dom-update', processSidebar);
|
$('body').bind('dom-update', processSidebar);
|
||||||
fixSize();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
var fixedEvenOnce = false;
|
|
||||||
function fixSize()
|
|
||||||
{
|
|
||||||
if ($('#small-screen').is(':visible'))
|
|
||||||
return;
|
|
||||||
var multiply = 168;
|
|
||||||
var oldWidth = $('.main-wrapper:eq(0)').width();
|
|
||||||
$('.main-wrapper:eq(0)').width('');
|
|
||||||
var newWidth = $('.main-wrapper:eq(0)').width();
|
|
||||||
if (oldWidth != newWidth || !fixedEvenOnce)
|
|
||||||
{
|
|
||||||
$('.main-wrapper').width(multiply * Math.floor(newWidth / multiply));
|
|
||||||
fixedEvenOnce = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//autocomplete
|
//autocomplete
|
||||||
|
@ -416,40 +395,40 @@ Mousetrap.bind = function(key, func, args)
|
||||||
$(function()
|
$(function()
|
||||||
{
|
{
|
||||||
Mousetrap.bind('q', function()
|
Mousetrap.bind('q', function()
|
||||||
{
|
{
|
||||||
$('#top-nav input').focus();
|
$('#top-nav input').focus();
|
||||||
return false;
|
return false;
|
||||||
}, 'keyup');
|
}, 'keyup');
|
||||||
|
|
||||||
Mousetrap.bind('w', function()
|
Mousetrap.bind('w', function()
|
||||||
{
|
{
|
||||||
$('body,html').animate({scrollTop: '-=150px'}, 200);
|
$('body,html').animate({scrollTop: '-=150px'}, 200);
|
||||||
});
|
});
|
||||||
|
|
||||||
Mousetrap.bind('s', function()
|
Mousetrap.bind('s', function()
|
||||||
{
|
{
|
||||||
$('body,html').animate({scrollTop: '+=150px'}, 200);
|
$('body,html').animate({scrollTop: '+=150px'}, 200);
|
||||||
});
|
});
|
||||||
|
|
||||||
Mousetrap.bind('a', function()
|
Mousetrap.bind('a', function()
|
||||||
{
|
{
|
||||||
var url = $('.paginator:visible .prev:not(.disabled) a').attr('href');
|
var url = $('.paginator:visible .prev:not(.disabled) a').attr('href');
|
||||||
if (typeof url !== 'undefined')
|
if (typeof url !== 'undefined')
|
||||||
window.location.href = url;
|
window.location.href = url;
|
||||||
}, 'keyup');
|
}, 'keyup');
|
||||||
|
|
||||||
Mousetrap.bind('d', function()
|
Mousetrap.bind('d', function()
|
||||||
{
|
{
|
||||||
var url = $('.paginator:visible .next:not(.disabled) a').attr('href');
|
var url = $('.paginator:visible .next:not(.disabled) a').attr('href');
|
||||||
if (typeof url !== 'undefined')
|
if (typeof url !== 'undefined')
|
||||||
window.location.href = url;
|
window.location.href = url;
|
||||||
}, 'keyup');
|
}, 'keyup');
|
||||||
|
|
||||||
Mousetrap.bind('p', function()
|
Mousetrap.bind('p', function()
|
||||||
{
|
{
|
||||||
$('.post a').eq(0).focus();
|
$('.post a').eq(0).focus();
|
||||||
return false;
|
return false;
|
||||||
}, 'keyup');
|
}, 'keyup');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,35 +1,57 @@
|
||||||
|
function bindToggleTag()
|
||||||
|
{
|
||||||
|
$('.post a.toggle-tag').bindOnce('toggle-tag', 'click', toggleTagEventHandler);
|
||||||
|
}
|
||||||
|
|
||||||
|
function toggleTagEventHandler(e)
|
||||||
|
{
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
var aDom = $(this);
|
||||||
|
if (aDom.hasClass('inactive'))
|
||||||
|
return;
|
||||||
|
aDom.addClass('inactive');
|
||||||
|
|
||||||
|
var enable = !aDom.parents('.post').hasClass('tagged');
|
||||||
|
var url = $(this).attr('href');
|
||||||
|
url = url.replace(/\/[01]\/?$/, '/' + (enable ? '1' : '0'));
|
||||||
|
postJSON({ url: url }).success(function(data)
|
||||||
|
{
|
||||||
|
aDom.removeClass('inactive');
|
||||||
|
aDom.parents('.post').removeClass('tagged');
|
||||||
|
if (enable)
|
||||||
|
aDom.parents('.post').addClass('tagged');
|
||||||
|
aDom.text(enable
|
||||||
|
? aDom.attr('data-text-tagged')
|
||||||
|
: aDom.attr('data-text-untagged'));
|
||||||
|
}).error(function(xhr)
|
||||||
|
{
|
||||||
|
alert(xhr.responseJSON
|
||||||
|
? xhr.responseJSON.message
|
||||||
|
: 'Fatal error');
|
||||||
|
aDom.removeClass('inactive');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function alignPosts()
|
||||||
|
{
|
||||||
|
var samplePost = $('.posts .post:last-child');
|
||||||
|
var container = $('.posts');
|
||||||
|
samplePost.find('.thumb').css('width', thumbnailWidth + 'px');
|
||||||
|
var containerWidth = container.width();
|
||||||
|
var thumbnailOuterWidth = samplePost.outerWidth(true);
|
||||||
|
var thumbnailInnerWidth = samplePost.find('.thumb').outerWidth();
|
||||||
|
var margin = thumbnailOuterWidth - thumbnailInnerWidth;
|
||||||
|
var numberOfThumbnailsToFitInRow = Math.ceil(containerWidth / thumbnailOuterWidth);
|
||||||
|
var newThumbnailWidth = Math.floor(containerWidth / numberOfThumbnailsToFitInRow) - margin;
|
||||||
|
container.find('.thumb').css('width', newThumbnailWidth + 'px');
|
||||||
|
}
|
||||||
|
|
||||||
$(function()
|
$(function()
|
||||||
{
|
{
|
||||||
$('body').bind('dom-update', function()
|
$('body').bind('dom-update', function()
|
||||||
{
|
{
|
||||||
$('.post a.toggle-tag').bindOnce('toggle-tag', 'click', function(e)
|
bindToggleTag();
|
||||||
{
|
alignPosts();
|
||||||
e.preventDefault();
|
|
||||||
|
|
||||||
var aDom = $(this);
|
|
||||||
if (aDom.hasClass('inactive'))
|
|
||||||
return;
|
|
||||||
aDom.addClass('inactive');
|
|
||||||
|
|
||||||
var enable = !aDom.parents('.post').hasClass('tagged');
|
|
||||||
var url = $(this).attr('href');
|
|
||||||
url = url.replace(/\/[01]\/?$/, '/' + (enable ? '1' : '0'));
|
|
||||||
postJSON({ url: url }).success(function(data)
|
|
||||||
{
|
|
||||||
aDom.removeClass('inactive');
|
|
||||||
aDom.parents('.post').removeClass('tagged');
|
|
||||||
if (enable)
|
|
||||||
aDom.parents('.post').addClass('tagged');
|
|
||||||
aDom.text(enable
|
|
||||||
? aDom.attr('data-text-tagged')
|
|
||||||
: aDom.attr('data-text-untagged'));
|
|
||||||
}).error(function(xhr)
|
|
||||||
{
|
|
||||||
alert(xhr.responseJSON
|
|
||||||
? xhr.responseJSON.message
|
|
||||||
: 'Fatal error');
|
|
||||||
aDom.removeClass('inactive');
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -135,30 +135,30 @@ $(function()
|
||||||
});
|
});
|
||||||
|
|
||||||
Mousetrap.bind('a', function()
|
Mousetrap.bind('a', function()
|
||||||
|
{
|
||||||
|
var a = $('#sidebar .left a');
|
||||||
|
var url = a.attr('href');
|
||||||
|
if (typeof url !== 'undefined')
|
||||||
{
|
{
|
||||||
var a = $('#sidebar .left a');
|
a.click();
|
||||||
var url = a.attr('href');
|
window.location.href = url;
|
||||||
if (typeof url !== 'undefined')
|
}
|
||||||
{
|
}, 'keyup');
|
||||||
a.click();
|
|
||||||
window.location.href = url;
|
|
||||||
}
|
|
||||||
}, 'keyup');
|
|
||||||
|
|
||||||
Mousetrap.bind('d', function()
|
Mousetrap.bind('d', function()
|
||||||
|
{
|
||||||
|
var a = $('#sidebar .right a');
|
||||||
|
var url = a.attr('href');
|
||||||
|
if (typeof url !== 'undefined')
|
||||||
{
|
{
|
||||||
var a = $('#sidebar .right a');
|
a.click();
|
||||||
var url = a.attr('href');
|
window.location.href = url;
|
||||||
if (typeof url !== 'undefined')
|
}
|
||||||
{
|
}, 'keyup');
|
||||||
a.click();
|
|
||||||
window.location.href = url;
|
|
||||||
}
|
|
||||||
}, 'keyup');
|
|
||||||
|
|
||||||
Mousetrap.bind('e', function()
|
Mousetrap.bind('e', function()
|
||||||
{
|
{
|
||||||
$('a.edit-post').trigger('click');
|
$('a.edit-post').trigger('click');
|
||||||
return false;
|
return false;
|
||||||
}, 'keyup');
|
}, 'keyup');
|
||||||
});
|
});
|
||||||
|
|
|
@ -31,6 +31,8 @@ if (!empty(Core::getConfig()->appearance->extraStylesheets))
|
||||||
isset($this->context->transport->lastSearchQuery)
|
isset($this->context->transport->lastSearchQuery)
|
||||||
? $this->context->transport->lastSearchQuery
|
? $this->context->transport->lastSearchQuery
|
||||||
:'') ?>;
|
:'') ?>;
|
||||||
|
var thumbnailWidth = <?= Core::getConfig()->browsing->thumbnailWidth ?>;
|
||||||
|
var thumbnailHeight = <?= Core::getConfig()->browsing->thumbnailHeight ?>;
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<nav id="top-nav">
|
<nav id="top-nav">
|
||||||
|
|
Loading…
Reference in a new issue