rm skins
This commit is contained in:
59
skins/timeline/article-list.ftl
Normal file
59
skins/timeline/article-list.ftl
Normal file
@@ -0,0 +1,59 @@
|
||||
<div class="wrapper">
|
||||
<div class="articles container">
|
||||
<div class="vertical"></div>
|
||||
<#list articles as article>
|
||||
<article>
|
||||
<div class="module">
|
||||
<div class="dot"></div>
|
||||
<div class="arrow"></div>
|
||||
<time class="article-time">
|
||||
<span>
|
||||
${article.articleCreateDate?string("yy-MM-dd HH:mm")}
|
||||
</span>
|
||||
</time>
|
||||
<h3 class="article-title">
|
||||
<a rel="bookmark" href="${servePath}${article.articlePermalink}">
|
||||
${article.articleTitle}
|
||||
</a>
|
||||
<#if article.hasUpdated>
|
||||
<sup>
|
||||
${updatedLabel}
|
||||
</sup>
|
||||
</#if>
|
||||
<#if article.articlePutTop>
|
||||
<sup>
|
||||
${topArticleLabel}
|
||||
</sup>
|
||||
</#if>
|
||||
</h3>
|
||||
<div class="article-body">
|
||||
${article.articleAbstract}
|
||||
</div>
|
||||
<span class="ico-tags ico" title="${tagLabel}">
|
||||
<#list article.articleTags?split(",") as articleTag><a rel="category tag" href="${servePath}/tags/${articleTag?url('UTF-8')}">${articleTag}</a><#if articleTag_has_next>,</#if></#list>
|
||||
</span>
|
||||
<span class="ico-author ico" title="${authorLabel}">
|
||||
<a rel="author" href="${servePath}/authors/${article.authorId}">${article.authorName}</a>
|
||||
</span>
|
||||
<span class="ico-comment ico" title="${commentLabel}">
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}#comments">
|
||||
<#if article.articleCommentCount == 0>
|
||||
${noCommentLabel}
|
||||
<#else>
|
||||
${article.articleCommentCount}
|
||||
</#if>
|
||||
</a>
|
||||
</span>
|
||||
<span class="ico-view ico" title="${viewLabel}">
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}">
|
||||
${article.articleViewCount}
|
||||
</a>
|
||||
</span>
|
||||
</div>
|
||||
</article>
|
||||
</#list>
|
||||
<#if paginationCurrentPageNum != paginationPageCount && 0 != paginationPageCount>
|
||||
<div class="article-more" onclick="timeline.getNextPage(this)" data-page="${paginationCurrentPageNum}">${moreLabel}</div>
|
||||
</#if>
|
||||
</div>
|
||||
</div>
|
||||
109
skins/timeline/article.ftl
Normal file
109
skins/timeline/article.ftl
Normal file
@@ -0,0 +1,109 @@
|
||||
<#include "macro-head.ftl">
|
||||
<#include "macro-comments.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${article.articleTitle} - ${blogTitle}">
|
||||
<meta name="keywords" content="${article.articleTags}" />
|
||||
<meta name="description" content="${article.articleAbstract?html}" />
|
||||
</@head>
|
||||
<#if previousArticlePermalink??>
|
||||
<link rel="prev" title="${previousArticleTitle}" href="${servePath}${previousArticlePermalink}">
|
||||
</#if>
|
||||
<#if nextArticlePermalink??>
|
||||
<link rel="next" title="${nextArticleTitle}" href="${servePath}${nextArticlePermalink}">
|
||||
</#if>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<div class="wrapper">
|
||||
<div class="container">
|
||||
<div class="module">
|
||||
<article class="article">
|
||||
<time class="article-time">
|
||||
<span>
|
||||
<#if article.hasUpdated>
|
||||
${article.articleUpdateDate?string("yy-MM-dd HH:mm")}
|
||||
<#else>
|
||||
${article.articleCreateDate?string("yy-MM-dd HH:mm")}
|
||||
</#if>
|
||||
</span>
|
||||
</time>
|
||||
<h2 class="article-title">
|
||||
<a href="${servePath}${article.articlePermalink}">
|
||||
${article.articleTitle}
|
||||
</a>
|
||||
<#if article.hasUpdated>
|
||||
<sup>
|
||||
${updatedLabel}
|
||||
</sup>
|
||||
</#if>
|
||||
<#if article.articlePutTop>
|
||||
<sup>
|
||||
${topArticleLabel}
|
||||
</sup>
|
||||
</#if>
|
||||
</h2>
|
||||
<div class="article-body">
|
||||
${article.articleContent}
|
||||
</div>
|
||||
<#if "" != article.articleSign.signHTML?trim>
|
||||
<p>
|
||||
${article.articleSign.signHTML}
|
||||
</p>
|
||||
</#if>
|
||||
<span class="ico-tags ico" title="${tagLabel}">
|
||||
<#list article.articleTags?split(",") as articleTag><a rel="tag" href="${servePath}/tags/${articleTag?url('UTF-8')}">${articleTag}</a><#if articleTag_has_next>,</#if></#list>
|
||||
</span>
|
||||
<span class="ico-author ico" title="${authorLabel}">
|
||||
<a rel="author" href="${servePath}/authors/${article.authorId}">${article.authorName}</a>
|
||||
</span>
|
||||
<span class="ico-comment ico" title="${commentLabel}">
|
||||
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}#comments">
|
||||
<#if article.articleCommentCount == 0>
|
||||
${noCommentLabel}
|
||||
<#else>
|
||||
${article.articleCommentCount}
|
||||
</#if>
|
||||
</a>
|
||||
</span>
|
||||
<span class="ico-view ico" title="${viewLabel}">
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}">
|
||||
${article.articleViewCount}
|
||||
</a>
|
||||
</span>
|
||||
</article>
|
||||
<div class="fn-clear" style="margin-top: 30px;">
|
||||
<#if nextArticlePermalink??>
|
||||
<div class="left">
|
||||
<a href="${servePath}${nextArticlePermalink}">
|
||||
<span class="ico-pre">«</span>
|
||||
<span class="ft-pre">${nextArticleTitle}</span>
|
||||
</a>
|
||||
</div>
|
||||
</#if>
|
||||
<#if previousArticlePermalink??>
|
||||
<div class="right">
|
||||
<a href="${servePath}${previousArticlePermalink}">
|
||||
<span class="left ft-next">${previousArticleTitle}</span>
|
||||
<span class="ico-next">»</span>
|
||||
</a>
|
||||
</div>
|
||||
</#if>
|
||||
</div>
|
||||
<div id="externalRelevantArticles"></div>
|
||||
<@comments commentList=articleComments article=article></@comments>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<#include "footer.ftl">
|
||||
<@comment_script oId=article.oId>
|
||||
page.tips.externalRelevantArticlesDisplayCount = "${externalRelevantArticlesDisplayCount}";
|
||||
<#if 0 != externalRelevantArticlesDisplayCount>
|
||||
page.loadExternalRelevantArticles("<#list article.articleTags?split(",") as articleTag>${articleTag}<#if articleTag_has_next>,</#if></#list>");
|
||||
</#if>
|
||||
</@comment_script>
|
||||
</body>
|
||||
</html>
|
||||
21
skins/timeline/author-articles.ftl
Normal file
21
skins/timeline/author-articles.ftl
Normal file
@@ -0,0 +1,21 @@
|
||||
<#include "macro-head.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${authorName} - ${blogTitle}">
|
||||
<meta name="keywords" content="${metaKeywords},${authorName}"/>
|
||||
<meta name="description" content="<#list articles as article>${article.articleTitle}<#if article_has_next>,</#if></#list>"/>
|
||||
</@head>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<h3 class="nav-abs" id="author">
|
||||
<img style="border-radius: 45px;" width="90" title="${authorName}" src="${authorThumbnailURL}"/>
|
||||
<br/>
|
||||
${authorName}
|
||||
</h3>
|
||||
<#include "article-list.ftl">
|
||||
<#include "footer.ftl">
|
||||
</body>
|
||||
</html>
|
||||
21
skins/timeline/category-articles.ftl
Normal file
21
skins/timeline/category-articles.ftl
Normal file
@@ -0,0 +1,21 @@
|
||||
<#include "macro-head.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${category.categoryTitle} - ${blogTitle}">
|
||||
<meta name="keywords" content="${metaKeywords},${category.categoryTitle}"/>
|
||||
<meta name="description" content="<#list articles as article>${article.articleTitle}<#if article_has_next>,</#if></#list>"/>
|
||||
</@head>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<h3 id="category" class="nav-abs">
|
||||
${categoryLabel}:
|
||||
${category.categoryTitle}
|
||||
(${category.categoryTagCnt})<small> ${category.categoryDescription}</small>
|
||||
</h3>
|
||||
<#include "article-list.ftl">
|
||||
<#include "footer.ftl">
|
||||
</body>
|
||||
</html>
|
||||
25
skins/timeline/common-comment.ftl
Normal file
25
skins/timeline/common-comment.ftl
Normal file
@@ -0,0 +1,25 @@
|
||||
<li id="${comment.oId}">
|
||||
<img title="${comment.commentName}"
|
||||
alt="${comment.commentName}" src="${comment.commentThumbnailURL}"/>
|
||||
<div>
|
||||
<span class="author">
|
||||
<#if "http://" == comment.commentURL>
|
||||
<a>${comment.commentName}</a>
|
||||
<#else>
|
||||
<a href="${comment.commentURL}" target="_blank">${comment.commentName}</a>
|
||||
</#if>
|
||||
<#if comment.isReply>@
|
||||
<a href="${servePath}${article.permalink}#${comment.commentOriginalCommentId}"
|
||||
onmouseover="page.showComment(this, '${comment.commentOriginalCommentId}', 20);"
|
||||
onmouseout="page.hideComment('${comment.commentOriginalCommentId}')">${comment.commentOriginalCommentName}</a>
|
||||
</#if>
|
||||
</span>
|
||||
<small><b> ${comment.commentDate2?string("yy-MM-dd HH:mm")}</b></small>
|
||||
<#if article.commentable>
|
||||
<span class="ico-reply ico right">
|
||||
<a rel="nofollow" href="javascript:replyTo('${comment.oId}');">${replyLabel}</a>
|
||||
</span>
|
||||
</#if>
|
||||
<div class="article-body">${comment.commentContent}</div>
|
||||
</div>
|
||||
</li>
|
||||
990
skins/timeline/css/timeline.css
Normal file
990
skins/timeline/css/timeline.css
Normal file
@@ -0,0 +1,990 @@
|
||||
/**
|
||||
* Copyright (c) 2010-2017, b3log.org & hacpai.com
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
/*
|
||||
* timeline skin style.
|
||||
*
|
||||
* @author <a href="mailto:LLY219@gmail.com">Liyuan Li</a>
|
||||
* @version 1.1.0.0, Sep 21, 2017
|
||||
*/
|
||||
/* start reset */
|
||||
html, body {
|
||||
-webkit-text-size-adjust: 100%;
|
||||
-ms-text-size-adjust: 100%;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
body {
|
||||
font: 0.81em Verdana, arial, '\5fae\8f6f\96c5\9ed1';
|
||||
color: #666666;
|
||||
background-color: #363A3D;
|
||||
overflow-y: scroll;
|
||||
}
|
||||
|
||||
button,
|
||||
input,
|
||||
select,
|
||||
textarea {
|
||||
margin: 0;
|
||||
font-size: 100%;
|
||||
vertical-align: middle;
|
||||
font-family: Verdana, arial,'\5fae\8f6f\96c5\9ed1';
|
||||
outline: none;
|
||||
}
|
||||
|
||||
a {
|
||||
color: #6599C6;
|
||||
outline: medium none;
|
||||
text-decoration: none;
|
||||
transition: color 1s ease 0s;
|
||||
}
|
||||
|
||||
a:hover {
|
||||
color: #000;
|
||||
}
|
||||
|
||||
img {
|
||||
max-width: 100%;
|
||||
border: 0;
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
::selection {
|
||||
background-color: #D5D5D5;
|
||||
color: #FCFCFC;
|
||||
}
|
||||
|
||||
::-moz-selection {
|
||||
background-color: #D5D5D5;
|
||||
color: #FCFCFC;
|
||||
}
|
||||
/* end reset */
|
||||
|
||||
/* start function */
|
||||
.left {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.right {
|
||||
float: right;
|
||||
}
|
||||
|
||||
.clear {
|
||||
background-color: transparent;
|
||||
border: 0;
|
||||
clear: both;
|
||||
display: block;
|
||||
font-size: 0;
|
||||
height: 0;
|
||||
line-height: 0;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.none {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.fn-clear:before,
|
||||
.fn-clear:after {
|
||||
display: table;
|
||||
content: "";
|
||||
}
|
||||
|
||||
.fn-clear:after {
|
||||
clear: both;
|
||||
}
|
||||
/* end function */
|
||||
|
||||
/* start common */
|
||||
.em00, .em01, .em02, .em03, .em04, .em05, .em06, .em07, .em08, .em09,
|
||||
.em10, .em11, .em12, .em13, .em14 {
|
||||
cursor: pointer;
|
||||
background-image: url("../../../images/emotions/emotions.png");
|
||||
background-size: 120px;
|
||||
float: left;
|
||||
height: 24px;
|
||||
margin-right: 5px;
|
||||
width: 24px;
|
||||
transition: all .2s ease-out;
|
||||
-webkit-transition: all .2s ease-out;
|
||||
-moz-transition: all .2s ease-out;
|
||||
}
|
||||
|
||||
#emotions span:hover {
|
||||
transform: scale(1.2) rotate(360deg);
|
||||
-webkit-transform: scale(1.2) rotate(360deg);
|
||||
-moz-transform: scale(1.2) rotate(360deg);
|
||||
}
|
||||
|
||||
.em01 {
|
||||
background-position: -24px 0;
|
||||
}
|
||||
.em02 {
|
||||
background-position: -48px 0;
|
||||
}
|
||||
.em03 {
|
||||
background-position: -72px 0;
|
||||
}
|
||||
.em04 {
|
||||
background-position: -96px 1px;
|
||||
}
|
||||
.em05 {
|
||||
background-position: 0 -24px;
|
||||
}
|
||||
.em06 {
|
||||
background-position: -24px -24px;
|
||||
}
|
||||
.em07 {
|
||||
background-position: -48px -24px;
|
||||
}
|
||||
.em08 {
|
||||
background-position: -72px -24px;
|
||||
}
|
||||
.em09 {
|
||||
background-position: -96px -24px;
|
||||
}
|
||||
.em10 {
|
||||
background-position: 0 -48px;
|
||||
}
|
||||
.em11 {
|
||||
background-position: -24px -48px ;
|
||||
}
|
||||
.em12 {
|
||||
background-position: -48px -48px;
|
||||
}
|
||||
.em13 {
|
||||
background-position: -72px -48px;
|
||||
}
|
||||
.em14 {
|
||||
background-position: -96px -48px;
|
||||
}
|
||||
|
||||
.tags {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.tags li {
|
||||
float: left;
|
||||
list-style-type: none;
|
||||
height: 45px;
|
||||
}
|
||||
|
||||
.tags a {
|
||||
background-color: #FCFCFC;
|
||||
box-shadow: 0 0 2px #D5D5D5;
|
||||
display: block;
|
||||
margin: 5px 10px;
|
||||
padding: 5px 10px;
|
||||
}
|
||||
|
||||
.tags a:hover {
|
||||
text-shadow: 0 0 2px;
|
||||
text-decoration: none;
|
||||
box-shadow: 0 0 4px #D5D5D5;
|
||||
}
|
||||
|
||||
.tags b {
|
||||
font-size: 70%;
|
||||
opacity: 0.6;
|
||||
filter: alpha(opacity=60);
|
||||
}
|
||||
|
||||
.tags1, .tags1:visited {
|
||||
font-size: 12px;
|
||||
color: #a7a7a7;
|
||||
}
|
||||
|
||||
.tags2, .tags2:visited {
|
||||
font-size: 14px;
|
||||
color: #808080;
|
||||
}
|
||||
|
||||
.tags3, .tags3:visited {
|
||||
font-size: 16px;
|
||||
color: #595959;
|
||||
}
|
||||
|
||||
.tags4, .tags4:visited {
|
||||
font-size: 18px;
|
||||
color: #323232;
|
||||
}
|
||||
|
||||
.tags5, .tags5:visited {
|
||||
font-size: 20px;
|
||||
color: #0a0a0a;
|
||||
}
|
||||
|
||||
.module {
|
||||
background-color: #FFFFFF;
|
||||
border: 1px solid #BEC3C7;
|
||||
border-radius: 5px 5px 5px 5px;
|
||||
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
|
||||
margin-bottom: 30px;
|
||||
padding: 15px;
|
||||
word-wrap: break-word;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.module > h3.title {
|
||||
margin: 0 0 10px 0;
|
||||
color: #444;
|
||||
}
|
||||
|
||||
.module > ul.list {
|
||||
list-style-type: none;
|
||||
padding-left: 0;
|
||||
margin: 0;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.module > ul.list > li {
|
||||
border-top: 1px solid #EEEEEE;
|
||||
padding: 6px 0;
|
||||
}
|
||||
/* end common */
|
||||
|
||||
/* start icon */
|
||||
.articles .arrow,
|
||||
.ico-author,
|
||||
.ico-tags,
|
||||
.ico-comment,
|
||||
.ico-top,
|
||||
.ico-view,
|
||||
.ico-reply,
|
||||
.ico-translate,
|
||||
#search {
|
||||
background-repeat: no-repeat;
|
||||
background-image: url("../../timeline/images/icons.png");
|
||||
}
|
||||
|
||||
.ico-author,
|
||||
.ico-tags,
|
||||
.ico-comment,
|
||||
.ico-view,
|
||||
.ico-reply {
|
||||
padding-left: 20px;
|
||||
background-position: -1px -63px;
|
||||
margin-right: 10px;
|
||||
}
|
||||
|
||||
.ico-tags {
|
||||
background-position: -1px -83px;
|
||||
}
|
||||
|
||||
.ico-comment {
|
||||
background-position: -1px -41px;
|
||||
}
|
||||
|
||||
.ico-view {
|
||||
background-position: 0 -122px;
|
||||
}
|
||||
|
||||
.ico-reply {
|
||||
background-position: 0 -162px;
|
||||
}
|
||||
|
||||
.ico-translate {
|
||||
background-position: 0 -186px;
|
||||
cursor: pointer;
|
||||
float: right;
|
||||
height: 16px;
|
||||
margin-left: 10px;
|
||||
width: 16px;
|
||||
}
|
||||
|
||||
#search {
|
||||
background-position: 5px -138px;
|
||||
border: medium none;
|
||||
border-radius: 12px 12px 12px 12px;
|
||||
box-shadow: 0 1px 0 rgba(0, 0, 0, 0.4) inset, 0 1px 0 rgba(255, 255, 255, 0.1);
|
||||
color: #A5A099;
|
||||
height: 22px;
|
||||
margin-top: 13px;
|
||||
margin-bottom: 10px;
|
||||
padding-left: 25px;
|
||||
transition: width 0.7s ease 0s;
|
||||
width: 60px;
|
||||
}
|
||||
|
||||
#search:focus {
|
||||
color: #333;
|
||||
width: 140px;
|
||||
}
|
||||
|
||||
.ico-top {
|
||||
background-color: #363A3D;
|
||||
background-position: 4px -100px;
|
||||
border-radius: 20em 20em 20em 20em;
|
||||
bottom: 60px;
|
||||
box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.3) inset, 0 1px 0 rgba(255, 255, 255, 0.15);
|
||||
height: 25px;
|
||||
position: fixed;
|
||||
left: 90%;
|
||||
width: 25px;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.ico-next,
|
||||
.ico-pre {
|
||||
background-color: #6599C6;
|
||||
border-radius: 10em 10em 10em 10em;
|
||||
color: #FFFFFF;
|
||||
display: block;
|
||||
float: left;
|
||||
font: 20px/100% "Times New Roman",Times,serif;
|
||||
height: 28px;
|
||||
margin: -8px 10px 0 0;
|
||||
padding: 4px 0 0;
|
||||
text-align: center;
|
||||
transition: background 1s ease 0s;
|
||||
width: 32px;
|
||||
}
|
||||
|
||||
.ico-next {
|
||||
float: right;
|
||||
margin: -8px 0 0 10px;
|
||||
}
|
||||
|
||||
a:hover > .ico-next,
|
||||
a:hover > .ico-pre {
|
||||
background-color: #000;
|
||||
}
|
||||
/* end icon */
|
||||
|
||||
/* start framework */
|
||||
.wrapper {
|
||||
min-width: 400px;
|
||||
padding: 50px 0;
|
||||
background: url("../../timeline/images/bg.png") repeat scroll 0 0 #DEE4EA;
|
||||
}
|
||||
|
||||
.header {
|
||||
background-color: #BFBFBF;
|
||||
background-image: url("../../timeline/images/nav-bg.png"), linear-gradient(#CCCCCC, #A9A9A9);
|
||||
background-image: url("../../timeline/images/nav-bg.png"), -ms-linear-gradient(#CCCCCC, #A9A9A9);
|
||||
background-image: url("../../timeline/images/nav-bg.png"), -o-linear-gradient(#CCCCCC, #A9A9A9);
|
||||
background-image: url("../../timeline/images/nav-bg.png"), -webkit-linear-gradient(#CCCCCC, #A9A9A9);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#CCCCCC', endColorstr='#A9A9A9');
|
||||
border-bottom: 1px solid #898989;
|
||||
box-shadow: 0 -1px 0 rgba(255, 255, 255, 0.3) inset, 0 1px 1px rgba(0, 0, 0, 0.2);
|
||||
}
|
||||
|
||||
.container {
|
||||
width: 80%;
|
||||
margin: 0 auto;
|
||||
}
|
||||
|
||||
.footer {
|
||||
border-top: 1px solid #232323;
|
||||
padding: 20px 0;
|
||||
color: #ddd;
|
||||
font-size: 80%;
|
||||
}
|
||||
|
||||
.footer a {
|
||||
color: #9CC0DE;
|
||||
}
|
||||
|
||||
.footer a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
/* end framework */
|
||||
|
||||
/* start header */
|
||||
.header .title {
|
||||
font-size: 150%;
|
||||
margin: 3px 0 0;
|
||||
}
|
||||
|
||||
.header .title a {
|
||||
color: #414141;
|
||||
text-shadow: 0 1px 0 rgba(255, 255, 255, 0.7);
|
||||
}
|
||||
|
||||
.header .sub-title {
|
||||
float: left;
|
||||
max-width: 574px;
|
||||
white-space: normal;
|
||||
word-wrap: break-word;
|
||||
}
|
||||
|
||||
.header li a {
|
||||
color: #444;
|
||||
padding: 17px;
|
||||
line-height: 20px;
|
||||
text-shadow: 0 1px 0 rgba(255, 255, 255, 0.7);
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.header li a.current {
|
||||
border-bottom: 2px solid #D26911;
|
||||
}
|
||||
|
||||
.header a:hover {
|
||||
color: #000;
|
||||
}
|
||||
|
||||
.header li {
|
||||
float: left;
|
||||
list-style-type: none;
|
||||
}
|
||||
|
||||
.header > .container > ul,
|
||||
.header > .container > form {
|
||||
height: auto;
|
||||
overflow: visible;
|
||||
}
|
||||
|
||||
.header .page-icon {
|
||||
height: 14px;
|
||||
width: 14px;
|
||||
margin: -1px 5px 0 0;
|
||||
}
|
||||
/* end header */
|
||||
|
||||
/* start article list */
|
||||
.articles {
|
||||
position: relative;
|
||||
margin-top: 11px;
|
||||
}
|
||||
|
||||
.articles > div.fn-clear {
|
||||
position: relative;
|
||||
margin-bottom: 50px;
|
||||
}
|
||||
|
||||
.articles > div.fn-clear > h2 {
|
||||
margin: 0;
|
||||
text-align: center;
|
||||
height: 28px;
|
||||
}
|
||||
|
||||
.articles > .vertical {
|
||||
background-color: #9EB5C6;
|
||||
border-radius: 20em 20em 20em 20em;
|
||||
box-shadow: 0 0 1px 0 rgba(0, 0, 0, 0.5) inset, 0 0 1px 0 rgba(255, 255, 255, 0.6);
|
||||
height: 100%;
|
||||
left: 50%;
|
||||
margin-left: -3px;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
width: 6px
|
||||
}
|
||||
|
||||
.articles article {
|
||||
width: 50%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.articles article.l > div.module {
|
||||
margin-right: 30px;
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.articles article.r {
|
||||
left: 50%;
|
||||
}
|
||||
|
||||
.articles article.r > div {
|
||||
margin-left: 30px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.articles .dot {
|
||||
background-color: #FFFFFF;
|
||||
border: 3px solid #60829F;
|
||||
border-radius: 20em 20em 20em 20em;
|
||||
height: 6px;
|
||||
position: absolute;
|
||||
right: -37px;
|
||||
top: 22px;
|
||||
width: 6px;
|
||||
}
|
||||
|
||||
.articles .r .dot {
|
||||
left: -37px;
|
||||
right: inherit;
|
||||
}
|
||||
|
||||
.articles .arrow {
|
||||
height: 15px;
|
||||
position: absolute;
|
||||
right: -9px;
|
||||
top: 21px;
|
||||
width: 9px;
|
||||
}
|
||||
|
||||
.articles .r .arrow {
|
||||
background-position: 0 -22px;
|
||||
left: -9px;
|
||||
right: inherit
|
||||
}
|
||||
|
||||
.articles pre {
|
||||
background-color: #F5F5F5;
|
||||
border: 1px solid #ddd;
|
||||
border-radius: 4px 4px 4px 4px;
|
||||
padding: 9.5px;
|
||||
white-space: pre-wrap;
|
||||
word-wrap: break-word;
|
||||
}
|
||||
|
||||
time.article-time {
|
||||
top: -8px;
|
||||
left: 50%;
|
||||
position: absolute;
|
||||
}
|
||||
|
||||
time.article-time > span {
|
||||
background-color: #FFFFFF;
|
||||
border: 1px solid #A8A9A9;
|
||||
border-radius: 20em 20em 20em 20em;
|
||||
font-size: 80%;
|
||||
margin-left: -56px;
|
||||
padding: 5px 10px;
|
||||
}
|
||||
|
||||
article .article-title {
|
||||
margin: 10px 0 0 0;
|
||||
}
|
||||
|
||||
article .article-title > sup {
|
||||
color: #6599C6;
|
||||
font-size: 70%;
|
||||
}
|
||||
|
||||
article .article-title a {
|
||||
color: #000;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.ico > a {
|
||||
color: #999999;
|
||||
font-size: 80%;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.ico > a:hover {
|
||||
color: #000;
|
||||
}
|
||||
|
||||
.article-more {
|
||||
background-color: #60829F;
|
||||
border-radius: 20em 20em 20em 20em;
|
||||
box-shadow: 0 1px 0 rgba(0, 0, 0, 0.2) inset, 0 1px 0 rgba(255, 255, 255, 0.6);
|
||||
color: #FFFFFF;
|
||||
cursor: pointer;
|
||||
font-weight: bold;
|
||||
height: 19px;
|
||||
left: 50%;
|
||||
margin-left: -38px;
|
||||
padding: 5px 20px;
|
||||
position: absolute;
|
||||
text-align: center;
|
||||
top: 100%;
|
||||
width: 36px;
|
||||
}
|
||||
|
||||
.article-archive {
|
||||
background-color: #60829F;
|
||||
border-radius: 20em 20em 20em 20em;
|
||||
box-shadow: 0 1px 0 rgba(0, 0, 0, 0.2) inset, 0 1px 0 rgba(255, 255, 255, 0.6);
|
||||
color: #FFFFFF;
|
||||
font-size: 80%;
|
||||
font-weight: normal;
|
||||
padding: 5px 20px;
|
||||
}
|
||||
/* end article list */
|
||||
|
||||
/* start dynamic */
|
||||
.dynamic-l {
|
||||
float: left;
|
||||
width: 70%;
|
||||
}
|
||||
|
||||
.dynamic-l > div {
|
||||
margin-right: 30px;
|
||||
}
|
||||
|
||||
.dynamic-r {
|
||||
float: right;
|
||||
width: 30%;
|
||||
}
|
||||
|
||||
.dynamic-r .tags a,
|
||||
.links a {
|
||||
line-height: 24px;
|
||||
}
|
||||
/* end dynamic */
|
||||
|
||||
/* start comments */
|
||||
#comments {
|
||||
margin: 30px 0 50px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.comments > li > img {
|
||||
height: 60px;
|
||||
width: 60px;
|
||||
border-radius: 30px;
|
||||
float: left;
|
||||
margin-right: 15px;
|
||||
}
|
||||
|
||||
.comments .author {
|
||||
font-size: 130%;
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
.comments > li > div > div.article-body {
|
||||
padding-left: 75px;
|
||||
margin: 12px 0;
|
||||
}
|
||||
|
||||
.module > ul > li.comment-body-ref {
|
||||
background-color: #FFFFFF;
|
||||
border: 1px solid #ddd;
|
||||
left: 76px;
|
||||
opacity: 0.8;
|
||||
filter: alpha(opacity=80);
|
||||
padding: 10px;
|
||||
position: absolute;
|
||||
width: 74%;
|
||||
border-radius: 10px;
|
||||
}
|
||||
|
||||
.comment-body-ref .ico-reply {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.comment-form {
|
||||
width: 100%;
|
||||
margin: 30px 0;
|
||||
}
|
||||
|
||||
#commentForm {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
.comment-form input[type='text'],
|
||||
.comment-form textarea {
|
||||
background: url("../../timeline/images/bg.png") repeat scroll 0 0 #E5E8EA;
|
||||
border: 1px solid #BCBDBE;
|
||||
border-radius: 5px 5px 5px 5px;
|
||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) inset;
|
||||
margin: 5px 5px 5px 0;
|
||||
padding: 6px;
|
||||
}
|
||||
|
||||
.comment-form input[type='text']:focus,
|
||||
.comment-form textarea:focus {
|
||||
background-color: #EFEFEF;
|
||||
outline: medium none;
|
||||
}
|
||||
|
||||
#submitCommentButton,
|
||||
#submitCommentButtonReply {
|
||||
background: none repeat scroll 0 0 #868889;
|
||||
border: 1px solid #5D6265;
|
||||
border-radius: 10em 10em 10em 10em;
|
||||
box-shadow: 0 1px 0 rgba(255, 255, 255, 0.3) inset, 0 1px 1px rgba(0, 0, 0, 0.3);
|
||||
color: #FFFFFF;
|
||||
cursor: pointer;
|
||||
padding: 5px 20px;
|
||||
text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.3);
|
||||
}
|
||||
|
||||
#submitCommentButton:hover,
|
||||
#submitCommentButtonReply:hover {
|
||||
color: #fff;
|
||||
background-color: #444;
|
||||
}
|
||||
/* end comments */
|
||||
|
||||
/* start others */
|
||||
.nav-abs {
|
||||
background-color: #6B6B6B;
|
||||
border: 1px solid #898989;
|
||||
border-radius: 5px 5px 5px 5px;
|
||||
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4) inset, 0 1px 0 rgba(255, 255, 255, 0.7), 0 -1px 0 rgba(255, 255, 255, 0.6);
|
||||
color: #CCCCCC;
|
||||
padding: 5px 10px;
|
||||
position: absolute;
|
||||
right: 30px;
|
||||
top: 61px;
|
||||
z-index: 1;
|
||||
text-align: center;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.index-nav-abs {
|
||||
padding: 0;
|
||||
position: fixed;
|
||||
max-width: 160px;
|
||||
}
|
||||
|
||||
.nav-abs li {
|
||||
background-color: #DEDDDD;
|
||||
border: 1px solid #6B6B6B;
|
||||
color: #616161;
|
||||
cursor: pointer;
|
||||
float: left;
|
||||
height: 20px;
|
||||
list-style-type: none;
|
||||
padding: 3px 5px;
|
||||
width: 28px;
|
||||
}
|
||||
|
||||
.nav-abs li.year {
|
||||
background-color: #6B6B6B;
|
||||
clear: both;
|
||||
color: #CCCCCC;
|
||||
float: none;
|
||||
text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.5);
|
||||
width: auto;
|
||||
border-width: 0;
|
||||
}
|
||||
|
||||
.nav-abs li:hover {
|
||||
background-color: #EFEEEE;
|
||||
color: #000;
|
||||
}
|
||||
|
||||
.nav-abs li.year:hover, .nav-abs li.open {
|
||||
background-color: #353535;
|
||||
color: #fff;
|
||||
}
|
||||
/* end others */
|
||||
|
||||
/* start responsive */
|
||||
@media (max-width: 650px) {
|
||||
.wrapper {
|
||||
min-width: 200px;
|
||||
}
|
||||
|
||||
#top > .left {
|
||||
display: block;
|
||||
float: none;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
#top > a {
|
||||
display: block;
|
||||
float: none !important;
|
||||
}
|
||||
|
||||
#hideTop {
|
||||
position: absolute;
|
||||
right: 0;
|
||||
top: 0;
|
||||
}
|
||||
|
||||
#admin {
|
||||
display: block;
|
||||
float: none
|
||||
}
|
||||
|
||||
#admin > a {
|
||||
border-right-width: 0 !important;
|
||||
display: block;
|
||||
float: none !important;
|
||||
line-height: 26px !important;
|
||||
margin: 0 !important;
|
||||
}
|
||||
|
||||
.container {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.header .title {
|
||||
height: 26px;
|
||||
max-width: 72%;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.header > .container > div.left {
|
||||
float: none;
|
||||
height: 50px;
|
||||
margin-left: 10px;
|
||||
}
|
||||
|
||||
.header > .container > ul {
|
||||
float: none;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.header > .container li {
|
||||
float: none;
|
||||
padding: 3px 10px;
|
||||
}
|
||||
|
||||
.header > .container li > a {
|
||||
padding: 0;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.header > .container li:hover {
|
||||
background-color: #FFFFFF;
|
||||
background-image: linear-gradient(#FFFFFF,#E5E5E5);
|
||||
background-image: -ms-linear-gradient(#FFFFFF,#E5E5E5);
|
||||
background-image: -o-linear-gradient(#FFFFFF,#E5E5E5);
|
||||
background-image: -webkit-linear-gradient(#FFFFFF,#E5E5E5);
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#FFFFFF', endColorstr='#E5E5E5');
|
||||
}
|
||||
|
||||
.header > .container > form {
|
||||
float: none;
|
||||
margin: 10px;
|
||||
}
|
||||
|
||||
#search {
|
||||
margin: 5px 0 10px 10px;
|
||||
}
|
||||
|
||||
#search:focus {
|
||||
width: 92%;
|
||||
}
|
||||
|
||||
.ico-list {
|
||||
background-color: #FCFCFC;
|
||||
background-image: url("../../timeline/images/icons.png");
|
||||
background-position: 4px -206px;
|
||||
background-repeat: no-repeat;
|
||||
border-radius: 1px 0 3px 3px;
|
||||
cursor: pointer;
|
||||
float: right;
|
||||
height: 25px;
|
||||
margin-right: 35px;
|
||||
margin-top: -29px;
|
||||
width: 25px;
|
||||
}
|
||||
|
||||
.ico-list:hover {
|
||||
background-color: #FFF;
|
||||
}
|
||||
|
||||
.footer > .container > .right {
|
||||
float: none;
|
||||
padding: 0 10px;
|
||||
line-height: 19px;
|
||||
}
|
||||
|
||||
.footer > .container > .right > .left {
|
||||
float: none;
|
||||
}
|
||||
|
||||
.nav-abs {
|
||||
position: inherit !important;
|
||||
padding: 0;
|
||||
background-color: transparent;
|
||||
box-shadow: none;
|
||||
border-width: 0;
|
||||
max-width: none !important;
|
||||
}
|
||||
|
||||
.index-nav-abs {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.nav-abs li {
|
||||
float: none;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.author,
|
||||
.ico-reply {
|
||||
margin-left: 75px;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.comments > li > div > div.article-body {
|
||||
padding-left: 0;
|
||||
}
|
||||
|
||||
.dynamic-l,
|
||||
.dynamic-r {
|
||||
float: none;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.dynamic-l > div {
|
||||
margin-right: 0;
|
||||
}
|
||||
|
||||
.articles .arrow,
|
||||
.articles .dot,
|
||||
#admin > span,
|
||||
.ft-next,
|
||||
.ft-pre,
|
||||
.footer > .container > .left {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.header > .container > ul,
|
||||
.header > .container > form {
|
||||
height: 0;
|
||||
overflow: hidden;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.articles {
|
||||
padding-bottom: 10px;
|
||||
}
|
||||
|
||||
.articles article {
|
||||
float: none;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.articles > div.fn-clear > h2 {
|
||||
margin-bottom: 40px;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@media (max-width: 360px) {
|
||||
.ico {
|
||||
display: block;
|
||||
float: none;
|
||||
line-height: 19px;
|
||||
}
|
||||
|
||||
.dynamic-r .ico {
|
||||
float: right;
|
||||
}
|
||||
|
||||
#commentForm label,
|
||||
#replyForm label {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.footer > .container > .right > .left > span {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.ico-translate {
|
||||
display: block;
|
||||
float: none;
|
||||
margin-left: 0;
|
||||
}
|
||||
|
||||
.ico-top {
|
||||
bottom: 114px;
|
||||
}
|
||||
}
|
||||
/* end responsive */
|
||||
16
skins/timeline/css/timeline.min.css
vendored
Normal file
16
skins/timeline/css/timeline.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
137
skins/timeline/dynamic.ftl
Normal file
137
skins/timeline/dynamic.ftl
Normal file
@@ -0,0 +1,137 @@
|
||||
<#include "macro-head.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${blogTitle}">
|
||||
<meta name="keywords" content="${metaKeywords},${dynamicLabel}"/>
|
||||
<meta name="description" content="${metaDescription},${dynamicLabel}"/>
|
||||
</@head>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<div class="wrapper">
|
||||
<div class="container">
|
||||
<div class="fn-clear">
|
||||
<div class="dynamic-l">
|
||||
<#if "" != noticeBoard>
|
||||
<div class="module">
|
||||
${noticeBoard}
|
||||
</div>
|
||||
</#if>
|
||||
<#if 0 != recentComments?size>
|
||||
<div class="module">
|
||||
<h3 class="title">${recentCommentsLabel}</h3>
|
||||
<ul class="comments list">
|
||||
<#list recentComments as comment>
|
||||
<li>
|
||||
<img
|
||||
alt='${comment.commentName}'
|
||||
src='${comment.commentThumbnailURL}'/>
|
||||
<div>
|
||||
<span class="author">
|
||||
<#if "http://" == comment.commentURL>
|
||||
${comment.commentName}
|
||||
<#else>
|
||||
<a target="_blank" href="${comment.commentURL}">${comment.commentName}</a>
|
||||
</#if>
|
||||
</span>
|
||||
<small><b>${comment.commentDate?string("yyyy-MM-dd HH:mm")}</b></small>
|
||||
<span class="ico ico-view right">
|
||||
<a rel="nofollow" href="${servePath}${comment.commentSharpURL}">
|
||||
${viewLabel}
|
||||
</a>
|
||||
</span>
|
||||
<div class="article-body">
|
||||
${comment.commentContent}
|
||||
</div>
|
||||
</div>
|
||||
</li>
|
||||
</#list>
|
||||
</ul>
|
||||
</div>
|
||||
</#if>
|
||||
</div>
|
||||
<div class="dynamic-r">
|
||||
<#if 0 != mostCommentArticles?size>
|
||||
<div class="module">
|
||||
<h3 class="title">${mostCommentArticlesLabel}</h3>
|
||||
<ul class="list">
|
||||
<#list mostCommentArticles as article>
|
||||
<li class="fn-clear">
|
||||
<a class="left" rel="nofollow" title="${article.articleTitle}"
|
||||
href="${servePath}${article.articlePermalink}">
|
||||
${article.articleTitle}
|
||||
</a>
|
||||
<span class="ico ico-comment right" title="${commentLabel}">
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}#comments">
|
||||
<#if article.articleCommentCount == 0>
|
||||
${noCommentLabel}
|
||||
<#else>
|
||||
${article.articleCommentCount}
|
||||
</#if>
|
||||
</a>
|
||||
</span>
|
||||
</li>
|
||||
</#list>
|
||||
</ul>
|
||||
</div>
|
||||
</#if>
|
||||
<#if 0 != mostViewCountArticles?size>
|
||||
<div class="module">
|
||||
<h3 class="title">${mostViewCountArticlesLabel}</h3>
|
||||
<ul class="list">
|
||||
<#list mostViewCountArticles as article>
|
||||
<li class="fn-clear">
|
||||
<a rel="nofollow" class="left" title="${article.articleTitle}" href="${servePath}${article.articlePermalink}">
|
||||
${article.articleTitle}
|
||||
</a>
|
||||
<span class="ico ico-view right" title="${viewLabel}">
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}">
|
||||
${article.articleViewCount}
|
||||
</a>
|
||||
</span>
|
||||
</li>
|
||||
</#list>
|
||||
</ul>
|
||||
</div>
|
||||
</#if>
|
||||
<#if 0 != mostUsedTags?size>
|
||||
<div class="module tags">
|
||||
<h3 class="title">${popTagsLabel}</h3>
|
||||
<#list mostUsedTags as tag>
|
||||
<a rel="tag" href="${servePath}/tags/${tag.tagTitle?url('UTF-8')}"
|
||||
title="${tag.tagTitle}(${tag.tagPublishedRefCount})">
|
||||
${tag.tagTitle}
|
||||
</a>
|
||||
</#list>
|
||||
</ul>
|
||||
</div>
|
||||
</#if>
|
||||
</div>
|
||||
</div>
|
||||
<#if 0 != links?size>
|
||||
<div class="module links">
|
||||
<h3 class="title">${linkLabel}</h3>
|
||||
<#list links as link>
|
||||
<span>
|
||||
<a rel="friend" href="${link.linkAddress}" alt="${link.linkTitle}" target="_blank">
|
||||
<img alt="${link.linkTitle}"
|
||||
src="${faviconAPI}<#list link.linkAddress?split('/') as x><#if x_index=2>${x}<#break></#if></#list>" width="16" height="16" /></a>
|
||||
<a rel="friend" href="${link.linkAddress}" title="${link.linkDescription}" target="_blank">
|
||||
${link.linkTitle}
|
||||
</a>
|
||||
</span>
|
||||
</#list>
|
||||
</div>
|
||||
</#if>
|
||||
</div>
|
||||
</div>
|
||||
<#include "footer.ftl">
|
||||
<script>
|
||||
$(".comments > li > div > p").each(function () {
|
||||
this.innerHTML = Util.replaceEmString($(this).html());
|
||||
});
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
74
skins/timeline/footer.ftl
Normal file
74
skins/timeline/footer.ftl
Normal file
@@ -0,0 +1,74 @@
|
||||
<div class="footer">
|
||||
<div class="container fn-clear">
|
||||
<div class="left">
|
||||
<span>© ${year}</span> - <a href="${servePath}">${blogTitle}</a>${footerContent}
|
||||
Powered by <a href="http://b3log.org" target="_blank">B3log 开源</a> • <a href="https://hacpai.com/tag/Solo" target="_blank">Solo</a> ${version}
|
||||
Theme by <a rel="friend" target="_blank" href="http://themify.me/demo/themes/postline/">Postline</a> & <a rel="friend" href="http://vanessa.b3log.org" target="_blank">Vanessa</a>.
|
||||
</div>
|
||||
<div class="right fn-clear">
|
||||
<span class="left">
|
||||
<span>
|
||||
${viewCount1Label}
|
||||
${statistic.statisticBlogViewCount}
|
||||
|
||||
</span>
|
||||
<span>
|
||||
${articleCount1Label}
|
||||
${statistic.statisticPublishedBlogArticleCount}
|
||||
|
||||
</span>
|
||||
<span>
|
||||
${commentCount1Label}
|
||||
${statistic.statisticPublishedBlogCommentCount}
|
||||
</span>
|
||||
</span>
|
||||
<span class="ico-translate" onclick="timeline.translate()"></span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="ico-top none" onclick="Util.goTop()" title="TOP"></div>
|
||||
<script type="text/javascript">
|
||||
var latkeConfig = {
|
||||
"servePath": "${servePath}",
|
||||
"staticServePath": "${staticServePath}"
|
||||
};
|
||||
|
||||
var Label = {
|
||||
"tagLabel": "${tagLabel}",
|
||||
"viewLabel": "${viewLabel}",
|
||||
"commentLabel": "${commentLabel}",
|
||||
"noCommentLabel": "${noCommentLabel}",
|
||||
"topArticleLabel": "${topArticleLabel}",
|
||||
"authorLabel": "${authorLabel}",
|
||||
"updatedLabel": "${updatedLabel}",
|
||||
"contentLabel": "${contentLabel}",
|
||||
"abstractLabel": "${abstractLabel}",
|
||||
"moreLabel": "${moreLabel}",
|
||||
"adminLabel": "${adminLabel}",
|
||||
"logoutLabel": "${logoutLabel}",
|
||||
"skinDirName": "${skinDirName}",
|
||||
"loginLabel": "${loginLabel}",
|
||||
"em00Label": "${em00Label}",
|
||||
"em01Label": "${em01Label}",
|
||||
"em02Label": "${em02Label}",
|
||||
"em03Label": "${em03Label}",
|
||||
"em04Label": "${em04Label}",
|
||||
"em05Label": "${em05Label}",
|
||||
"em06Label": "${em06Label}",
|
||||
"em07Label": "${em07Label}",
|
||||
"em08Label": "${em08Label}",
|
||||
"em09Label": "${em09Label}",
|
||||
"em10Label": "${em10Label}",
|
||||
"em11Label": "${em11Label}",
|
||||
"em12Label": "${em12Label}",
|
||||
"em13Label": "${em13Label}",
|
||||
"em14Label": "${em14Label}",
|
||||
"localeString": "${localeString}",
|
||||
"yearLabel": "${yearLabel}",
|
||||
"monthLabel": "${monthLabel}"
|
||||
};
|
||||
</script>
|
||||
<script type="text/javascript" src="${staticServePath}/js/lib/jquery/jquery.min.js" charset="utf-8"></script>
|
||||
<script type="text/javascript" src="${staticServePath}/js/common${miniPostfix}.js?${staticResourceVersion}" charset="utf-8"></script>
|
||||
<script type="text/javascript" src="${staticServePath}/skins/${skinDirName}/js/${skinDirName}${miniPostfix}.js?${staticResourceVersion}" charset="utf-8"></script>
|
||||
${plugins}
|
||||
43
skins/timeline/header.ftl
Normal file
43
skins/timeline/header.ftl
Normal file
@@ -0,0 +1,43 @@
|
||||
<!--[if lt IE 9]>
|
||||
<script type="text/javascript">
|
||||
(function () {
|
||||
var element = ['time', 'article'];
|
||||
for (var i = 0; i < element.length; i++) {
|
||||
document.createElement(element[i]);
|
||||
}
|
||||
})();
|
||||
</script>
|
||||
<![endif]-->
|
||||
<div class="header">
|
||||
<div class="container fn-clear">
|
||||
<div class="left">
|
||||
<h1 class="title">
|
||||
<a href="${servePath}">
|
||||
${blogTitle}
|
||||
</a>
|
||||
</h1>
|
||||
<span class="sub-title">${blogSubtitle}</span>
|
||||
<span class="ico-list"></span>
|
||||
</div>
|
||||
<ul class="left">
|
||||
<#list pageNavigations as page>
|
||||
<li>
|
||||
<a href="${page.pagePermalink}" target="${page.pageOpenTarget}"><#if page.pageIcon != ''><img class="page-icon" src="${page.pageIcon}"></#if>${page.pageTitle}</a>
|
||||
</li>
|
||||
</#list>
|
||||
<li>
|
||||
<a href="${servePath}/dynamic.html">${dynamicLabel}</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="${servePath}/tags.html">${allTagsLabel}</a>
|
||||
</li>
|
||||
<li>
|
||||
<a rel="alternate" href="${servePath}/blog-articles-rss.do">RSS <img src="${staticServePath}/images/feed.png" alt="RSS"/></a>
|
||||
</li>
|
||||
</ul>
|
||||
<form class="right" action="${servePath}/search">
|
||||
<input placeholder="${searchLabel}" id="search" type="text" name="keyword" />
|
||||
<input type="submit" value="" class="none" />
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
BIN
skins/timeline/images/ajax-loader.gif
Normal file
BIN
skins/timeline/images/ajax-loader.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 9.2 KiB |
BIN
skins/timeline/images/bg.png
Normal file
BIN
skins/timeline/images/bg.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 6.6 KiB |
BIN
skins/timeline/images/icons.png
Normal file
BIN
skins/timeline/images/icons.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 3.3 KiB |
BIN
skins/timeline/images/nav-bg.png
Normal file
BIN
skins/timeline/images/nav-bg.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 6.6 KiB |
105
skins/timeline/index.ftl
Normal file
105
skins/timeline/index.ftl
Normal file
@@ -0,0 +1,105 @@
|
||||
<#include "macro-head.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${blogTitle}">
|
||||
<#if metaKeywords??>
|
||||
<meta name="keywords" content="${metaKeywords}"/>
|
||||
</#if>
|
||||
<#if metaDescription??>
|
||||
<meta name="description" content="${metaDescription}"/>
|
||||
</#if>
|
||||
</@head>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<ul class="nav-abs index-nav-abs">
|
||||
<#list archiveDates as archiveDate>
|
||||
<li data-year="${archiveDate.archiveDateYear}" title="${archiveDate.archiveDatePublishedArticleCount}"
|
||||
onclick="timeline.getArchive('${archiveDate.archiveDateYear}', '${archiveDate.archiveDateMonth}'<#if "en" == localeString?substring(0, 2)>, '${archiveDate.monthName}'</#if>)">
|
||||
<#if "en" == localeString?substring(0, 2)>
|
||||
${archiveDate.monthName}
|
||||
<#else>
|
||||
${archiveDate.archiveDateMonth}
|
||||
</#if>
|
||||
</li>
|
||||
</#list>
|
||||
</ul>
|
||||
<div class="wrapper">
|
||||
<div class="articles container" style="margin-top: 0">
|
||||
<div class="vertical"></div>
|
||||
<#list archiveDates as archiveDate>
|
||||
<div class="fn-clear" id="${archiveDate.archiveDateYear}${archiveDate.archiveDateMonth}" data-count="${archiveDate.archiveDatePublishedArticleCount}">
|
||||
<h2>
|
||||
<span class="article-archive">
|
||||
<#if "en" == localeString?substring(0, 2)>
|
||||
${archiveDate.monthName} ${archiveDate.archiveDateYear}
|
||||
<#else>
|
||||
${archiveDate.archiveDateYear} ${yearLabel} ${archiveDate.archiveDateMonth} ${monthLabel}
|
||||
</#if>
|
||||
</span>
|
||||
</h2>
|
||||
<#list articles1 as article>
|
||||
<#if article.articleCreateDate?string("yyyy/MM") == "${archiveDate.archiveDateYear}/${archiveDate.archiveDateMonth}">
|
||||
<article>
|
||||
<div class="module">
|
||||
<div class="dot"></div>
|
||||
<div class="arrow"></div>
|
||||
<time class="article-time">
|
||||
<span>
|
||||
${article.articleCreateDate?string("yy-MM-dd HH:mm")}
|
||||
</span>
|
||||
</time>
|
||||
<h3 class="article-title">
|
||||
<a rel="bookmark" href="${servePath}${article.articlePermalink}">
|
||||
${article.articleTitle}
|
||||
</a>
|
||||
<#if article.hasUpdated>
|
||||
<sup>
|
||||
${updatedLabel}
|
||||
</sup>
|
||||
</#if>
|
||||
<#if article.articlePutTop>
|
||||
<sup>
|
||||
${topArticleLabel}
|
||||
</sup>
|
||||
</#if>
|
||||
</h3>
|
||||
<div class="article-body">
|
||||
${article.articleAbstract}
|
||||
</div>
|
||||
<span class="ico-tags ico" title="${tagLabel}">
|
||||
<#list article.articleTags?split(",") as articleTag><a rel="category tag" href="${servePath}/tags/${articleTag?url('UTF-8')}">${articleTag}</a><#if articleTag_has_next>,</#if></#list>
|
||||
</span>
|
||||
<span class="ico-author ico" title="${authorLabel}">
|
||||
<a rel="author" href="${servePath}/authors/${article.authorId}">${article.authorName}</a>
|
||||
</span>
|
||||
<span class="ico-comment ico" title="${commentLabel}">
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}#comments">
|
||||
<#if article.articleCommentCount == 0>
|
||||
${noCommentLabel}
|
||||
<#else>
|
||||
${article.articleCommentCount}
|
||||
</#if>
|
||||
</a>
|
||||
</span>
|
||||
<span class="ico-view ico" title="${viewLabel}">
|
||||
<a rel="nofollow" href="${servePath}${article.articlePermalink}">
|
||||
${article.articleViewCount}
|
||||
</a>
|
||||
</span>
|
||||
</div>
|
||||
</article>
|
||||
<#if paginationCurrentPageNum != paginationPageCount && 0 != paginationPageCount && !article_has_next>
|
||||
<div class="article-more" onclick="timeline.getNextPage(this, '${article.articleCreateDate?string("yyyy/MM")}')" data-page="${paginationCurrentPageNum}">${moreLabel}</div>
|
||||
</#if>
|
||||
</#if>
|
||||
</#list>
|
||||
</div>
|
||||
</#list>
|
||||
</div>
|
||||
</div>
|
||||
<#include "footer.ftl">
|
||||
</body>
|
||||
</html>
|
||||
454
skins/timeline/js/timeline.js
Normal file
454
skins/timeline/js/timeline.js
Normal file
@@ -0,0 +1,454 @@
|
||||
/*
|
||||
* Copyright (c) 2010-2017, b3log.org & hacpai.com
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
/**
|
||||
* @fileoverview timeline js.
|
||||
*
|
||||
* @author <a href="mailto:LLY219@gmail.com">Liyuan Li</a>
|
||||
* @version 1.0.1.2, Jun 6, 2013
|
||||
*/
|
||||
var timeline = {
|
||||
_COLHA: 0,
|
||||
_COLHB: 20,
|
||||
_initArticleList: function() {
|
||||
var $articles = $(".articles");
|
||||
if ($articles.length === 0 || $(".articles > .fn-clear").length > 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
$(window).resize(function() {
|
||||
if ($("#hideTop").css("top") === "auto") {
|
||||
var colH = [timeline._COLHA, timeline._COLHB];
|
||||
$articles.find("article").each(function() {
|
||||
var $it = $(this),
|
||||
isLeft = colH[1] > colH[0],
|
||||
top = isLeft ? colH[0] : colH[1];
|
||||
if (parseInt($it.css("top")) !== top || top === 0) {
|
||||
$it.css({
|
||||
"top": top + "px",
|
||||
"position": "absolute"
|
||||
});
|
||||
|
||||
if (isLeft) {
|
||||
this.className = "l";
|
||||
} else {
|
||||
this.className = "r";
|
||||
}
|
||||
}
|
||||
colH[(isLeft ? '0' : '1')] += parseInt($it.outerHeight(true));
|
||||
});
|
||||
|
||||
$articles.height(colH[0] > colH[1] ? colH[0] : colH[1]);
|
||||
} else {
|
||||
$articles.find("article").each(function() {
|
||||
$(this).css({
|
||||
"position": "inherit",
|
||||
"top": "auto"
|
||||
}).removeClass("r l");
|
||||
});
|
||||
$articles.css("height", "auto");
|
||||
}
|
||||
});
|
||||
|
||||
$(window).resize();
|
||||
$(".module img").imagesLoaded(function() {
|
||||
$(window).resize();
|
||||
});
|
||||
},
|
||||
_initIndexList: function() {
|
||||
var $archives = $(".articles > .fn-clear");
|
||||
if ($archives.length === 0) {
|
||||
return;
|
||||
}
|
||||
|
||||
// 如果为 index 页面,重构 archives 结构,使其可收缩
|
||||
var year = 0;
|
||||
$(".nav-abs li").each(function(i) {
|
||||
var $this = $(this);
|
||||
$this.hide();
|
||||
if (year !== $this.data("year")) {
|
||||
year = $this.data("year");
|
||||
$this.before("<li class='close year' onclick='timeline.toggleArchives(this, " +
|
||||
year + ")'>" + year + "</li>");
|
||||
}
|
||||
});
|
||||
|
||||
// 首次加载时,当没有下一页时,使用 js 隐藏"更多"按钮
|
||||
if ($(".article-more").parent().data("count") <= $(".article-more").parent().find("article").length) {
|
||||
$(".article-more").remove();
|
||||
}
|
||||
|
||||
$(window).resize(function() {
|
||||
$archives.each(function() {
|
||||
if ($("#hideTop").css("top") === "auto") {
|
||||
var colH = [timeline._COLHA + 60, timeline._COLHB * 4];
|
||||
|
||||
var $articles = $(this).find("article");
|
||||
if ($articles.length === 0) {
|
||||
$(this).find("h2").remove();
|
||||
$(this).css("margin-bottom", 0);
|
||||
} else {
|
||||
$articles.each(function() {
|
||||
var $it = $(this),
|
||||
isLeft = colH[1] > colH[0],
|
||||
top = isLeft ? colH[0] : colH[1];
|
||||
|
||||
if (parseInt($it.css("top")) !== top || top === 0) {
|
||||
$it.css({
|
||||
"top": top + "px",
|
||||
"position": "absolute"
|
||||
});
|
||||
|
||||
if (isLeft) {
|
||||
this.className = "l";
|
||||
} else {
|
||||
this.className = "r";
|
||||
}
|
||||
}
|
||||
colH[(isLeft ? '0' : '1')] += parseInt($it.outerHeight(true));
|
||||
});
|
||||
$(this).height(colH[0] > colH[1] ? colH[0] : colH[1]);
|
||||
}
|
||||
} else {
|
||||
var $articles = $(this).find("article");
|
||||
if ($articles.length === 0) {
|
||||
$(this).find("h2").remove();
|
||||
$(this).css("margin-bottom", 0);
|
||||
} else {
|
||||
$articles.each(function() {
|
||||
$(this).css({
|
||||
"position": "inherit",
|
||||
"top": "auto"
|
||||
}).removeClass("r l");
|
||||
});
|
||||
$(this).css("height", "auto");
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
$(window).resize();
|
||||
$(".module img").imagesLoaded(function() {
|
||||
$(window).resize();
|
||||
});
|
||||
},
|
||||
_setNavCurrent: function() {
|
||||
$(".header li a").each(function() {
|
||||
if ($(this).prop("href") === location.href.split("#")[0]) {
|
||||
this.className = "current";
|
||||
} else {
|
||||
this.className = "";
|
||||
}
|
||||
})
|
||||
},
|
||||
init: function() {
|
||||
$(window).scroll(function() {
|
||||
if ($(window).scrollTop() > 60) {
|
||||
$(".ico-top").show();
|
||||
} else {
|
||||
$(".ico-top").hide();
|
||||
}
|
||||
});
|
||||
timeline._initIndexList();
|
||||
timeline._initArticleList();
|
||||
timeline._setNavCurrent();
|
||||
|
||||
// init header list
|
||||
$(".ico-list").click(function() {
|
||||
if ($(".header > .container > form").css("height") === "0px") {
|
||||
$(".header > .container > ul, .header > .container > form").css({
|
||||
"height": "auto"
|
||||
});
|
||||
} else {
|
||||
$(".header > .container > ul, .header > .container > form").animate({
|
||||
"height": "0px"
|
||||
});
|
||||
}
|
||||
});
|
||||
},
|
||||
translate: function() {
|
||||
window.open("http://translate.google.com/translate?sl=auto&tl=auto&u=" + location.href);
|
||||
},
|
||||
getArchive: function(year, month, monthName) {
|
||||
var archiveDate = year + month,
|
||||
archive = year + "/" + month;
|
||||
window.location.hash = "#" + archiveDate;
|
||||
if ($("#" + archiveDate + " > article").length === 0) {
|
||||
var archiveDataTitle = year + " " + Label.yearLabel + " " + month + " " + Label.monthLabel;
|
||||
if (Label.localeString.substring(0, 2) === "en") {
|
||||
archiveDataTitle = monthName + " " + year;
|
||||
}
|
||||
var archiveHTML = '<h2><span class="article-archive">' + archiveDataTitle + '</span></h2>'
|
||||
+ '<div class="article-more" onclick="timeline.getNextPage(this, \''
|
||||
+ archive + '\')" data-page="0">' + Label.moreLabel + '</div>';
|
||||
|
||||
$("#" + archiveDate).html(archiveHTML).css("margin-bottom", "50px");
|
||||
timeline.getNextPage($("#" + archiveDate).find(".article-more")[0], archive);
|
||||
}
|
||||
},
|
||||
getNextPage: function(it, archive) {
|
||||
var $more = $(it),
|
||||
currentPage = $more.data("page") + 1,
|
||||
path = "/articles/";
|
||||
if ($("#tag").length === 1) {
|
||||
var pathnames = location.pathname.split("/");
|
||||
path = "/articles/tags/" + pathnames[pathnames.length - 1] + "/";
|
||||
} else if ($("#author").length === 1) {
|
||||
var pathnames = location.pathname.split("/");
|
||||
path = "/articles/authors/" + pathnames[pathnames.length - 1] + "/";
|
||||
} else if (archive) {
|
||||
path = "/articles/archives/" + archive + "/";
|
||||
}
|
||||
$.ajax({
|
||||
url: latkeConfig.servePath + path + currentPage,
|
||||
type: "GET",
|
||||
beforeSend: function() {
|
||||
$more.css("background",
|
||||
"url(" + latkeConfig.staticServePath
|
||||
+ "/skins/timeline/images/ajax-loader.gif) no-repeat scroll center center #60829F").text("");
|
||||
},
|
||||
success: function(result, textStatus) {
|
||||
if (!result.sc) {
|
||||
$more.css("background", "none #60829F").text("Error");
|
||||
return;
|
||||
}
|
||||
|
||||
if (result.rslts.articles.length === 0) {
|
||||
$more.remove();
|
||||
return;
|
||||
}
|
||||
|
||||
var articlesHTML = "",
|
||||
pagination = result.rslts.pagination;
|
||||
|
||||
// append articles
|
||||
for (var i = 0; i < result.rslts.articles.length; i++) {
|
||||
var article = result.rslts.articles[i];
|
||||
|
||||
articlesHTML += '<article><div class="module"><div class="dot"></div>'
|
||||
+ '<div class="arrow"></div><time class="article-time"><span>'
|
||||
+ Util.toDate(article.articleCreateTime, 'yy-MM-dd HH:mm')
|
||||
+ '</span></time><h3 class="article-title"><a rel="bookmark" href="'
|
||||
+ latkeConfig.servePath + article.articlePermalink + '">'
|
||||
+ article.articleTitle + '</a>';
|
||||
|
||||
if (article.hasUpdated) {
|
||||
articlesHTML += '<sup>' + Label.updatedLabel + '</sup>';
|
||||
}
|
||||
|
||||
if (article.articlePutTop) {
|
||||
articlesHTML += '<sup>' + Label.topArticleLabel + '</sup>';
|
||||
}
|
||||
|
||||
articlesHTML += '</h3><p>' + article.articleAbstract + '</p>'
|
||||
+ '<span class="ico-tags ico" title="' + Label.tagLabel + '">';
|
||||
|
||||
var articleTags = article.articleTags.split(",");
|
||||
for (var j = 0; j < articleTags.length; j++) {
|
||||
articlesHTML += '<a rel="category tag" href="' + latkeConfig.servePath
|
||||
+ '/tags/' + encodeURIComponent(articleTags[j]) + '">' + articleTags[j] + '</a>';
|
||||
|
||||
if (j < articleTags.length - 1) {
|
||||
articlesHTML += ",";
|
||||
}
|
||||
}
|
||||
|
||||
articlesHTML += '</span> <span class="ico-author ico" title="' + Label.authorLabel + '">'
|
||||
+ '<a rel="author" href="' + latkeConfig.servePath + '/authors/' + article.authorId + '">'
|
||||
+ article.authorName + '</a></span> <span class="ico-comment ico" title="'
|
||||
+ Label.commentLabel + '"><a rel="nofollow" href="' + latkeConfig.servePath + article.articlePermalink
|
||||
+ '#comments">' + (article.articleCommentCount === 0 ? Label.noCommentLabel : article.articleCommentCount)
|
||||
+ '</a></span> <span class="ico-view ico" title="' + Label.viewLabel + '">'
|
||||
+ '<a rel="nofollow" href="${servePath}${article.articlePermalink}">' + article.articleViewCount
|
||||
+ '</a></span></div></article>';
|
||||
}
|
||||
|
||||
$more.before(articlesHTML).data("page", currentPage);
|
||||
// 最后一页处理
|
||||
if (pagination.paginationPageCount <= currentPage) {
|
||||
$more.remove();
|
||||
} else {
|
||||
$more.css("background", "none #60829F").text(Label.moreLabel);
|
||||
}
|
||||
|
||||
$(window).resize();
|
||||
$(".module img").imagesLoaded(function() {
|
||||
$(window).resize();
|
||||
});
|
||||
}
|
||||
});
|
||||
},
|
||||
toggleArchives: function(it, year) {
|
||||
$(".nav-abs li").each(function(i) {
|
||||
var $it = $(this);
|
||||
if (!$it.hasClass("year")) {
|
||||
$it.hide();
|
||||
if (year === $it.data("year") && $(it).hasClass("close")) {
|
||||
$it.show();
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
$(".nav-abs li.year").each(function() {
|
||||
if (parseInt($(this).text()) === year) {
|
||||
if ($(it).hasClass("close")) {
|
||||
it.className = "year open";
|
||||
} else {
|
||||
it.className = "year close";
|
||||
}
|
||||
} else {
|
||||
this.className = "year close";
|
||||
}
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
/*!
|
||||
* jQuery imagesLoaded plugin v2.1.1
|
||||
* http://github.com/desandro/imagesloaded
|
||||
*
|
||||
* MIT License. by Paul Irish et al.
|
||||
*/
|
||||
|
||||
/*jshint curly: true, eqeqeq: true, noempty: true, strict: true, undef: true, browser: true */
|
||||
/*global jQuery: false */
|
||||
|
||||
;
|
||||
(function($, undefined) {
|
||||
'use strict';
|
||||
|
||||
// blank image data-uri bypasses webkit log warning (thx doug jones)
|
||||
var BLANK = 'data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ywAAAAAAQABAAACAUwAOw==';
|
||||
|
||||
$.fn.imagesLoaded = function(callback) {
|
||||
var $this = this,
|
||||
deferred = $.isFunction($.Deferred) ? $.Deferred() : 0,
|
||||
hasNotify = $.isFunction(deferred.notify),
|
||||
$images = $this.find('img').add($this.filter('img')),
|
||||
loaded = [],
|
||||
proper = [],
|
||||
broken = [];
|
||||
|
||||
// Register deferred callbacks
|
||||
if ($.isPlainObject(callback)) {
|
||||
$.each(callback, function(key, value) {
|
||||
if (key === 'callback') {
|
||||
callback = value;
|
||||
} else if (deferred) {
|
||||
deferred[key](value);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
function doneLoading() {
|
||||
var $proper = $(proper),
|
||||
$broken = $(broken);
|
||||
|
||||
if (deferred) {
|
||||
if (broken.length) {
|
||||
deferred.reject($images, $proper, $broken);
|
||||
} else {
|
||||
deferred.resolve($images);
|
||||
}
|
||||
}
|
||||
|
||||
if ($.isFunction(callback)) {
|
||||
callback.call($this, $images, $proper, $broken);
|
||||
}
|
||||
}
|
||||
|
||||
function imgLoadedHandler(event) {
|
||||
imgLoaded(event.target, event.type === 'error');
|
||||
}
|
||||
|
||||
function imgLoaded(img, isBroken) {
|
||||
// don't proceed if BLANK image, or image is already loaded
|
||||
if (img.src === BLANK || $.inArray(img, loaded) !== -1) {
|
||||
return;
|
||||
}
|
||||
|
||||
// store element in loaded images array
|
||||
loaded.push(img);
|
||||
|
||||
// keep track of broken and properly loaded images
|
||||
if (isBroken) {
|
||||
broken.push(img);
|
||||
} else {
|
||||
proper.push(img);
|
||||
}
|
||||
|
||||
// cache image and its state for future calls
|
||||
$.data(img, 'imagesLoaded', {
|
||||
isBroken: isBroken,
|
||||
src: img.src
|
||||
});
|
||||
|
||||
// trigger deferred progress method if present
|
||||
if (hasNotify) {
|
||||
deferred.notifyWith($(img), [isBroken, $images, $(proper), $(broken)]);
|
||||
}
|
||||
|
||||
// call doneLoading and clean listeners if all images are loaded
|
||||
if ($images.length === loaded.length) {
|
||||
setTimeout(doneLoading);
|
||||
$images.unbind('.imagesLoaded', imgLoadedHandler);
|
||||
}
|
||||
}
|
||||
|
||||
// if no images, trigger immediately
|
||||
if (!$images.length) {
|
||||
doneLoading();
|
||||
} else {
|
||||
$images.bind('load.imagesLoaded error.imagesLoaded', imgLoadedHandler)
|
||||
.each(function(i, el) {
|
||||
var src = el.src;
|
||||
|
||||
// find out if this image has been already checked for status
|
||||
// if it was, and src has not changed, call imgLoaded on it
|
||||
var cached = $.data(el, 'imagesLoaded');
|
||||
if (cached && cached.src === src) {
|
||||
imgLoaded(el, cached.isBroken);
|
||||
return;
|
||||
}
|
||||
|
||||
// if complete is true and browser supports natural sizes, try
|
||||
// to check for image status manually
|
||||
if (el.complete && el.naturalWidth !== undefined) {
|
||||
imgLoaded(el, el.naturalWidth === 0 || el.naturalHeight === 0);
|
||||
return;
|
||||
}
|
||||
|
||||
// cached images don't fire load sometimes, so we reset src, but only when
|
||||
// dealing with IE, or image is complete (loaded) and failed manual check
|
||||
// webkit hack from http://groups.google.com/group/jquery-dev/browse_thread/thread/eee6ab7b2da50e1f
|
||||
if (el.readyState || el.complete) {
|
||||
el.src = BLANK;
|
||||
el.src = src;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
return deferred ? deferred.promise($this) : $this;
|
||||
};
|
||||
|
||||
})(jQuery);
|
||||
|
||||
(function() {
|
||||
Util.init();
|
||||
Util.replaceSideEm($(".comments .article-body"));
|
||||
Util.buildTags("tagsSide");
|
||||
|
||||
timeline.init();
|
||||
})();
|
||||
16
skins/timeline/js/timeline.min.js
vendored
Normal file
16
skins/timeline/js/timeline.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
78
skins/timeline/lang/lang_en_US.properties
Normal file
78
skins/timeline/lang/lang_en_US.properties
Normal file
@@ -0,0 +1,78 @@
|
||||
#
|
||||
# Copyright (c) 2010-2017, b3log.org & hacpai.com
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
#
|
||||
|
||||
#
|
||||
# Description: Language configurations(en_US) for skin "timeline".
|
||||
# Version: 1.0.0.6, Jul 31, 2016
|
||||
# Author: Liyuan Li
|
||||
#
|
||||
searchLabel=Search
|
||||
dynamicLabel=Dynamic
|
||||
moreLabel=More
|
||||
contentLabel=More...
|
||||
abstractLabel=Abstract
|
||||
viewCount1Label=View Count:
|
||||
articleCount1Label=Article Count:
|
||||
commentCount1Label=Comment Count:
|
||||
allTagsLabel=Tags
|
||||
archiveLabel=Archive
|
||||
yearLabel=
|
||||
monthLabel=
|
||||
recentArticlesLabel=Recent Articles
|
||||
recentCommentsLabel=Recent Comments
|
||||
mostCommentArticlesLabel=Most Comment Articles
|
||||
mostViewCountArticlesLabel=Most View Articles
|
||||
popTagsLabel=Popular Tags
|
||||
linkLabel=Friend Links
|
||||
indexLabel=Home
|
||||
sumLabel=
|
||||
pageLabel=Page
|
||||
adminLabel=Admin
|
||||
logoutLabel=Logout
|
||||
loginLabel=Login
|
||||
commentLabel=Comment
|
||||
noCommentLabel=No Comment
|
||||
viewLabel=View
|
||||
authorLabel=Author
|
||||
previousPageLabel=Previous Page
|
||||
nextPagePabel=Next Page
|
||||
firstPageLabel=First Page
|
||||
lastPageLabel=Last Page
|
||||
archive1Label=Archive:
|
||||
author1Label=Author:
|
||||
tagLabel=Tags
|
||||
sorryLabel=Sorry!
|
||||
notFoundLabel=Not Found!
|
||||
returnTo1Label=Return:
|
||||
updatedLabel=Updated!
|
||||
topArticleLabel=Top!
|
||||
replyLabel=Reply
|
||||
commentNameLabel=Name
|
||||
commentEmailLabel=Email
|
||||
commentURLLabel=URL
|
||||
submmitCommentLabel=Commit Comment
|
||||
nameTooLongLabel=Sorry, your username must be between 2 and 20 characters long!
|
||||
mailCannotEmptyLabel=Mail is empty!
|
||||
mailInvalidLabel=Mail is invalid!
|
||||
commentContentCannotEmptyLabel=Sorry, your content must be between 2 and 500 characters long!
|
||||
captchaCannotEmptyLabel=Captcha is empty!
|
||||
loadingLabel=loading....
|
||||
relevantArticlesLabel=Relevant Articles
|
||||
randomArticlesLabel=Random Articles
|
||||
externalRelevantArticlesLabel=External Relevant Articles:
|
||||
captchaErrorLabel=Captcha Error
|
||||
b3logLabel=<span style="color: orange;">B</span><span style="color: blue;"><sup>3</sup></span><span style="color: green;">L</span><span style="color: red;">O</span><span style="color: blue;">G</span>
|
||||
killBrowserLabel=<h2>Let's kill outdated and insecure browser!</h2><p>Let's kill outdated and insecure browser for browser evolution, human progress and better experience.</p><p>You can download</p><ul><li><a href="http://www.mozilla.com/" target="_blank">Firefox</a></li><li><a href="http://www.google.com/chrome" target="_blank">Chrome</a></li><li><a href="http://windows.microsoft.com/en-US/internet-explorer/downloads/ie" target="_blank">IE8 / IE9</a></li><li><a href="http://www.maxthon.com/" target="_blank">Maxthon</a> and <a href="http://www.google.com" target="_blank">so on</a>.</li></ul>
|
||||
78
skins/timeline/lang/lang_zh_CN.properties
Normal file
78
skins/timeline/lang/lang_zh_CN.properties
Normal file
@@ -0,0 +1,78 @@
|
||||
#
|
||||
# Copyright (c) 2010-2017, b3log.org & hacpai.com
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
#
|
||||
|
||||
#
|
||||
# Description: Language configurations(zh_CN) for skin "timeline".
|
||||
# Version: 1.0.0.6, Jul 31, 2016
|
||||
# Author: Liyuan Li
|
||||
#
|
||||
searchLabel=\u641C\u7D22
|
||||
dynamicLabel=\u52A8\u6001
|
||||
moreLabel=\u66F4\u591A
|
||||
contentLabel=\u5168\u6587
|
||||
abstractLabel=\u6458\u8981
|
||||
viewCount1Label=\u6D4F\u89C8\u6B21\u6570\uFF1A
|
||||
articleCount1Label=\u6587\u7AE0\u603B\u6570\uFF1A
|
||||
commentCount1Label=\u8BC4\u8BBA\u603B\u6570\uFF1A
|
||||
allTagsLabel=\u6807\u7B7E\u5899
|
||||
updatedLabel=\u6709\u66F4\u65B0\uFF01
|
||||
topArticleLabel=\u7F6E\u9876\uFF01
|
||||
archiveLabel=\u5B58\u6863
|
||||
yearLabel=\u5E74
|
||||
monthLabel=\u6708
|
||||
recentArticlesLabel=\u6700\u65B0\u6587\u7AE0
|
||||
recentCommentsLabel=\u6700\u65B0\u8BC4\u8BBA
|
||||
mostCommentArticlesLabel=\u8BC4\u8BBA\u6700\u591A\u7684\u6587\u7AE0
|
||||
mostViewCountArticlesLabel=\u8BBF\u95EE\u6700\u591A\u7684\u6587\u7AE0
|
||||
popTagsLabel=\u5206\u7C7B\u6807\u7B7E
|
||||
linkLabel=\u53CB\u60C5\u94FE\u63A5
|
||||
indexLabel=\u9996\u9875
|
||||
sumLabel=\u5171
|
||||
pageLabel=\u9875
|
||||
adminLabel=\u7BA1\u7406
|
||||
logoutLabel=\u767B\u51FA
|
||||
loginLabel=\u767B\u5F55
|
||||
commentLabel=\u8BC4\u8BBA
|
||||
noCommentLabel=\u65E0\u8BC4\u8BBA
|
||||
viewLabel=\u6D4F\u89C8
|
||||
authorLabel=\u4F5C\u8005
|
||||
previousPageLabel=\u4E0A\u4E00\u9875
|
||||
nextPagePabel=\u4E0B\u4E00\u9875
|
||||
firstPageLabel=\u7B2C\u4E00\u9875
|
||||
lastPageLabel=\u6700\u540E\u4E00\u9875
|
||||
archive1Label=\u5B58\u6863\uFF1A
|
||||
author1Label=\u4F5C\u8005\uFF1A
|
||||
tagLabel=\u6807\u7B7E
|
||||
sorryLabel=\u5BF9\u4E0D\u8D77\uFF01
|
||||
notFoundLabel=\u627E\u4E0D\u5230\uFF01
|
||||
returnTo1Label=\u8FD4\u56DE\uFF1A
|
||||
replyLabel=\u56DE\u590D
|
||||
commentNameLabel=\u59D3\u540D
|
||||
commentEmailLabel=\u90AE\u7BB1
|
||||
commentURLLabel=URL
|
||||
submmitCommentLabel=\u63D0\u4EA4\u8BC4\u8BBA
|
||||
nameTooLongLabel=\u59D3\u540D\u53EA\u80FD\u4E3A 2 \u5230 20 \u4E2A\u5B57\u7B26\uFF01
|
||||
mailCannotEmptyLabel=\u90AE\u7BB1\u4E0D\u80FD\u4E3A\u7A7A\uFF01
|
||||
mailInvalidLabel=\u90AE\u7BB1\u683C\u5F0F\u4E0D\u6B63\u786E\uFF01
|
||||
commentContentCannotEmptyLabel=\u8BC4\u8BBA\u5185\u5BB9\u53EA\u80FD\u4E3A 2 \u5230 500 \u4E2A\u5B57\u7B26\uFF01
|
||||
captchaCannotEmptyLabel=\u9A8C\u8BC1\u7801\u4E0D\u80FD\u4E3A\u7A7A\uFF01
|
||||
loadingLabel=\u8F7D\u5165\u4E2D....
|
||||
relevantArticlesLabel=\u76F8\u5173\u9605\u8BFB
|
||||
randomArticlesLabel=\u968F\u673A\u9605\u8BFB
|
||||
externalRelevantArticlesLabel=\u7AD9\u5916\u76F8\u5173\u9605\u8BFB
|
||||
captchaErrorLabel=\u9A8C\u8BC1\u7801\u9519\u8BEF
|
||||
b3logLabel=<span style="color: orange;">B</span><span style="color: blue;"><sup>3</sup></span><span style="color: green;">L</span><span style="color: red;">O</span><span style="color: blue;">G</span>
|
||||
killBrowserLabel=<h2>\u8BA9\u6211\u4EEC\u653E\u5F03\u4F7F\u7528\u90A3\u4E9B\u8FC7\u65F6\u3001\u4E0D\u5B89\u5168\u7684\u6D4F\u89C8\u5668\u5427\uFF01</h2><p>\u4E3A\u4E86\u8BA9\u6D4F\u89C8\u5668\u66F4\u597D\u7684\u53D1\u5C55\uFF0C\u4EBA\u7C7B\u66F4\u52A0\u7684\u8FDB\u6B65\uFF0C\u62E5\u6709\u66F4\u597D\u7684\u4F53\u9A8C\uFF0C\u8BA9\u6211\u4EEC\u653E\u5F03\u4F7F\u7528\u90A3\u4E9B\u8FC7\u65F6\u3001\u4E0D\u5B89\u5168\u7684\u6D4F\u89C8\u5668\u3002</p>\u60A8\u53EF\u4EE5\u4E0B\u8F7D<ul><li><a href="http://www.mozilla.com/" target="_blank">\u706B\u72D0</a></li><li><a href="http://www.google.com/chrome" target="_blank">\u8C37\u6B4C\u6D4F\u89C8\u5668</a></li><li><a href="http://windows.microsoft.com/en-US/internet-explorer/downloads/ie" target="_blank">IE8 / IE9</a></li><li><a href="http://www.maxthon.com/" target="_blank">\u9068\u6E38</a>\u6216\u8005<a href="http://www.google.com" target="_blank">\u5176\u5B83\u6D4F\u89C8\u5668</a>.</li></ul>
|
||||
111
skins/timeline/macro-comments.ftl
Normal file
111
skins/timeline/macro-comments.ftl
Normal file
@@ -0,0 +1,111 @@
|
||||
<#macro comments commentList article>
|
||||
<ul id="comments" class="comments list">
|
||||
<#list commentList as comment>
|
||||
<#include "common-comment.ftl"/>
|
||||
</#list>
|
||||
</ul>
|
||||
<#if article.commentable>
|
||||
<h3>${commentLabel}</h3>
|
||||
<table class="comment-form" id="commentForm">
|
||||
<tbody>
|
||||
<#if !isLoggedIn>
|
||||
<tr>
|
||||
<td>
|
||||
<label for="commentName"> * ${commentNameLabel}</label>
|
||||
<input type="text" id="commentName"/>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td colspan="2">
|
||||
<label for="commentEmail"> * ${commentEmailLabel}</label>
|
||||
<input type="text" id="commentEmail"/>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label for="commentURL"> ${commentURLLabel} </label>
|
||||
<input type="text" id="commentURL"/>
|
||||
</td>
|
||||
</tr>
|
||||
</#if>
|
||||
<tr>
|
||||
<td id="emotions">
|
||||
<span class="em00" title="${em00Label}"></span>
|
||||
<span class="em01" title="${em01Label}"></span>
|
||||
<span class="em02" title="${em02Label}"></span>
|
||||
<span class="em03" title="${em03Label}"></span>
|
||||
<span class="em04" title="${em04Label}"></span>
|
||||
<span class="em05" title="${em05Label}"></span>
|
||||
<span class="em06" title="${em06Label}"></span>
|
||||
<span class="em07" title="${em07Label}"></span>
|
||||
<span class="em08" title="${em08Label}"></span>
|
||||
<span class="em09" title="${em09Label}"></span>
|
||||
<span class="em10" title="${em10Label}"></span>
|
||||
<span class="em11" title="${em11Label}"></span>
|
||||
<span class="em12" title="${em12Label}"></span>
|
||||
<span class="em13" title="${em13Label}"></span>
|
||||
<span class="em14" title="${em14Label}"></span>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<textarea style="width:96%" rows="10" id="comment"></textarea>
|
||||
</td>
|
||||
</tr>
|
||||
<#if !isLoggedIn>
|
||||
<tr>
|
||||
<td>
|
||||
<input type="text" id="commentValidate"/>
|
||||
<img id="captcha" alt="validate" src="${servePath}/captcha.do" />
|
||||
</td>
|
||||
</tr>
|
||||
</#if>
|
||||
<tr>
|
||||
<td>
|
||||
<button id="submitCommentButton" onclick="page.submitComment();">${submmitCommentLabel}</button>
|
||||
<span id="commentErrorTip"></span>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<#if externalRelevantArticlesDisplayCount?? && 0 != externalRelevantArticlesDisplayCount>
|
||||
<div id="externalRelevantArticles"></div>
|
||||
</#if>
|
||||
</#if>
|
||||
</#macro>
|
||||
|
||||
<#macro comment_script oId>
|
||||
<script type="text/javascript" src="${staticServePath}/js/page${miniPostfix}.js?${staticResourceVersion}" charset="utf-8"></script>
|
||||
<script type="text/javascript">
|
||||
var page = new Page({
|
||||
"nameTooLongLabel": "${nameTooLongLabel}",
|
||||
"mailCannotEmptyLabel": "${mailCannotEmptyLabel}",
|
||||
"mailInvalidLabel": "${mailInvalidLabel}",
|
||||
"commentContentCannotEmptyLabel": "${commentContentCannotEmptyLabel}",
|
||||
"captchaCannotEmptyLabel": "${captchaCannotEmptyLabel}",
|
||||
"captchaErrorLabel": "${captchaErrorLabel}",
|
||||
"loadingLabel": "${loadingLabel}",
|
||||
"oId": "${oId}",
|
||||
"skinDirName": "${skinDirName}",
|
||||
"blogHost": "${blogHost}",
|
||||
"randomArticles1Label": "${randomArticlesLabel}",
|
||||
"externalRelevantArticles1Label": "${externalRelevantArticlesLabel}"
|
||||
});
|
||||
|
||||
var replyTo = function(id) {
|
||||
var commentFormHTML = "<table class='comment-form' id='replyForm'>";
|
||||
page.addReplyForm(id, commentFormHTML);
|
||||
$("#replyForm label").each(function() {
|
||||
$this = $(this);
|
||||
$this.attr("for", $this.attr("for") + "Reply");
|
||||
});
|
||||
};
|
||||
|
||||
$(document).ready(function() {
|
||||
page.load();
|
||||
// emotions
|
||||
page.replaceCommentsEm("#comments li .article-body");
|
||||
<#nested>
|
||||
});
|
||||
</script>
|
||||
</#macro>
|
||||
15
skins/timeline/macro-head.ftl
Normal file
15
skins/timeline/macro-head.ftl
Normal file
@@ -0,0 +1,15 @@
|
||||
<#macro head title>
|
||||
<meta charset="utf-8" />
|
||||
<title>${title}</title>
|
||||
<#nested>
|
||||
<meta name="author" content="${blogTitle?html}" />
|
||||
<meta name="generator" content="Solo" />
|
||||
<meta name="owner" content="B3log Team" />
|
||||
<meta name="revised" content="${blogTitle?html}, ${year}" />
|
||||
<meta name="copyright" content="B3log" />
|
||||
<meta http-equiv="Window-target" content="_top" />
|
||||
<link type="text/css" rel="stylesheet" href="${staticServePath}/skins/${skinDirName}/css/${skinDirName}${miniPostfix}.css?${staticResourceVersion}" charset="utf-8" />
|
||||
<link href="${servePath}/blog-articles-rss.do" title="RSS" type="application/rss+xml" rel="alternate" />
|
||||
<link rel="icon" type="image/png" href="${servePath}/favicon.png" />
|
||||
${htmlHead}
|
||||
</#macro>
|
||||
27
skins/timeline/page.ftl
Normal file
27
skins/timeline/page.ftl
Normal file
@@ -0,0 +1,27 @@
|
||||
<#include "macro-head.ftl">
|
||||
<#include "macro-comments.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${page.pageTitle} - ${blogTitle}">
|
||||
<meta name="keywords" content="${metaKeywords},${page.pageTitle}" />
|
||||
<meta name="description" content="${metaDescription}" />
|
||||
</@head>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<div class="wrapper">
|
||||
<div class="container">
|
||||
<div class="module">
|
||||
<div class="article-body">
|
||||
${page.pageContent}
|
||||
</div>
|
||||
<@comments commentList=pageComments article=page></@comments>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<#include "footer.ftl">
|
||||
<@comment_script oId=page.oId></@comment_script>
|
||||
</body>
|
||||
</html>
|
||||
BIN
skins/timeline/preview.png
Normal file
BIN
skins/timeline/preview.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 39 KiB |
25
skins/timeline/skin.properties
Normal file
25
skins/timeline/skin.properties
Normal file
@@ -0,0 +1,25 @@
|
||||
#
|
||||
# Copyright (c) 2010-2017, b3log.org & hacpai.com
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
#
|
||||
|
||||
#
|
||||
# Description: timeline skin.
|
||||
# Version: 1.0.0.1, Jan 7, 2013
|
||||
# Author: Liyuan Li
|
||||
#
|
||||
|
||||
name=timeline
|
||||
memo=\u65f6\u5149\u6d41\u901d
|
||||
note=\u6b64\u76ae\u80a4\u5ffd\u7565\u66f4\u65b0\u3001\u7f6e\u9876\u6392\u5e8f
|
||||
22
skins/timeline/tag-articles.ftl
Normal file
22
skins/timeline/tag-articles.ftl
Normal file
@@ -0,0 +1,22 @@
|
||||
<#include "macro-head.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${tag.tagTitle} - ${blogTitle}">
|
||||
<meta name="keywords" content="${metaKeywords},${tag.tagTitle}"/>
|
||||
<meta name="description" content="<#list articles as article>${article.articleTitle}<#if article_has_next>,</#if></#list>"/>
|
||||
</@head>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<h3 id="tag" style="cursor: pointer" class="nav-abs"
|
||||
onclick="window.location.href='${servePath}/tag-articles-rss.do?oId=${tag.oId}'">
|
||||
${tag.tagTitle}
|
||||
(${tag.tagPublishedRefCount})
|
||||
<img src="${staticServePath}/images/feed.png" alt="RSS"/>
|
||||
</h3>
|
||||
<#include "article-list.ftl">
|
||||
<#include "footer.ftl">
|
||||
</body>
|
||||
</html>
|
||||
48
skins/timeline/tags.ftl
Normal file
48
skins/timeline/tags.ftl
Normal file
@@ -0,0 +1,48 @@
|
||||
<#include "macro-head.ftl">
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<@head title="${allTagsLabel} - ${blogTitle}">
|
||||
<meta name="keywords" content="${metaKeywords},${allTagsLabel}"/>
|
||||
<meta name="description" content="<#list tags as tag>${tag.tagTitle}<#if tag_has_next>,</#if></#list>"/>
|
||||
</@head>
|
||||
</head>
|
||||
<body>
|
||||
${topBarReplacement}
|
||||
<#include "header.ftl">
|
||||
<div class="wrapper">
|
||||
<div class="container">
|
||||
<#if 0 != mostUsedCategories?size>
|
||||
<h2>${categoryLabel}</h2>
|
||||
<ul class="module fn-clear tags">
|
||||
<#list mostUsedCategories as category>
|
||||
<li>
|
||||
<a href="${servePath}/category/${category.categoryURI}">
|
||||
<span>${category.categoryTitle}</span>
|
||||
(<b>${category.categoryTagCnt}</b>)
|
||||
</a>
|
||||
</li>
|
||||
</#list>
|
||||
</ul>
|
||||
</#if>
|
||||
|
||||
<h2>${tagsLabel}</h2>
|
||||
<ul id="tags" class="tags module fn-clear">
|
||||
<#list tags as tag>
|
||||
<li>
|
||||
<a rel="tag" data-count="${tag.tagPublishedRefCount}"
|
||||
href="${servePath}/tags/${tag.tagTitle?url('UTF-8')}" title="${tag.tagTitle}">
|
||||
<span>${tag.tagTitle}</span>
|
||||
(<b>${tag.tagPublishedRefCount}</b>)
|
||||
</a>
|
||||
</li>
|
||||
</#list>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
<#include "footer.ftl">
|
||||
<script type="text/javascript">
|
||||
Util.buildTags();
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
Reference in New Issue
Block a user