However, it’s still possible to change and replace to the Page Number Navigation, as illustrated in figure by using a CSS and JavaScript hack wrote by Mohamed Rias and recenly js was updated by Abu Farhan.
Thanks to Mohamed Rias and Abu Farhan.
To add the “new” navigation link with Page Number Navigation to Blogger,
follow the guide below:
Login to Blogger account Dashboard.
Click on the Layout link for the blog that you want to modify (if you’re viewing the blog and logged in to Blogger or Google Account, just Click on Customize on the Next Blog toolbar).
Go to Edit HTML tab (there is no need to expand widget templates).
Search for the following line:
]]></b:skin>
Copy the following CSS code and paste or append the code above the line:
.showpageArea {padding: 0 2px;margin-bottom:10px;margin-top:10px;
}
.showpageArea a {border: 1px solid #505050;
color: #000000;font-weight:normal;
padding: 3px 6px !important;
padding: 1px 4px ;margin:0px 4px;
text-decoration: none;
}
.showpageArea a:hover {
font-size:11px;
border: 1px solid #333;
color: #000000;
background-color: #FFFFFF;
}
.showpageNum a {border: 1px solid #505050;
color: #000000;font-weight:normal;
padding: 3px 6px !important;
padding: 1px 4px ;margin:0px 4px;
text-decoration: none;
}
.showpageNum a:hover {
font-size:11px;
border: 1px solid #333;
color: #000000;
background-color: #FFFFFF;
}
.showpagePoint {font-size:11px;
padding: 2px 4px 2px 4px;
margin: 2px;
font-weight: bold;
border: 1px solid #333;
color: #fff;
background-color: #000000;
}
.showpage a:hover {font-size:11px;
border: 1px solid #333;
color: #000000;
background-color: #FFFFFF;
}
.showpageNum a:link,.showpage a:link {
font-size:11px;
padding: 2px 4px 2px 4px;
margin: 2px;
text-decoration: none;
border: 1px solid #0066cc;
color: #0066cc;
background-color: #FFFFFF;
}
.showpageNum a:hover {font-size:11px;
border: 1px solid #333;
color: #000000;
background-color: #FFFFFF;
}
Next, search for the following line of code in the template’s HTML code:
<b:section class=’main’ id=’main’ showaddelement=’no’>
<b:widget id=’Blog1′ locked=’true’ title=’Blog Posts’ type=’Blog’/>
</b:section>
Add and append the following JavaScript code right after the </b:section> line:
<script type=’text/javascript’>
var home_page_url = location.href;
var pageCount=7;
var displayPageNum=5;
var upPageWord =’Previous’;
var downPageWord =’Next’;
function showpageCount(json) {
var thisUrl = home_page_url;
var htmlMap = new Array();
var thisNum = 1;
var postNum=1;
var itemCount = 0;
var fFlag = 0;
var eFlag = 0;
var html= ”;
var upPageHtml =”;
var downPageHtml =”;
for(var i=0, post; post = json.feed.entry[i]; i++) {
var timestamp1 = post.published.$t.substring(0,19)+post.published.$t.substring(23,29);
timestamp = encodeURIComponent(timestamp1);
var title = post.title.$t;
if(title!=”){
if(itemCount==0 (itemCount % pageCount ==(pageCount-1))){
if(thisUrl.indexOf(timestamp)!=-1 ){
thisNum = postNum;
}
if(title!=”) postNum++;
htmlMap[htmlMap.length] = ‘/search?updated-max=’+timestamp+’&max-results=’+pageCount;
}
}
itemCount++;
}
for(var p =0;p< htmlMap.length;p++){
if(p>=(thisNum-displayPageNum-1) && p<(thisNum+displayPageNum)){
if(fFlag ==0 && p == thisNum-2){
if(thisNum==2){
upPageHtml = ‘<span class="showpage"><a href="/">’+ upPageWord +’</a></span>’;
}else{
upPageHtml = ‘<span class="showpage"><a href="’+htmlMap[p]+’">’+ upPageWord +’</a></span>’;
}
fFlag++;
}
if(p==(thisNum-1)){
html += ‘<span class="showpagePoint">’+thisNum+’</span>’;
}else{
if(p==0){
html += ‘<span class="showpageNum"><a href="/">1</a></span>’;
}else{
html += ‘<span class="showpageNum"><a href="’+htmlMap[p]+’">’+ (p+1) +’</a></span>’;
}
}
if(eFlag ==0 && p == thisNum){
downPageHtml = ‘<span class="showpage"> <a href="’+htmlMap[p]+’">’+ downPageWord +’</a></span>’;
eFlag++;
}
}
}
if(thisNum>1){
html = ”+upPageHtml+’ ‘+html +’ ‘;
}
html = ‘<div class="showpageArea"><span style="COLOR: #000;" class="showpageOf"> Pages (‘+(postNum-1)+’)</span>’+html;
if(thisNum<(postNum-1)){
html += downPageHtml;
}
if(postNum==1) postNum++;
html += ‘</div>’;
var pageArea = document.getElementsByName("pageArea");
var blogPager = document.getElementById("blog-pager");
if(postNum <= 2){
html =”;
}
for(var p =0;p< pageArea.length;p++){
pageArea[p].innerHTML = html;
}
if(pageArea&&pageArea.length>0){
html =”;
}
if(blogPager){
blogPager.innerHTML = html;
}
}
function showpageCount2(json) {
var thisUrl = home_page_url;
var htmlMap = new Array();
var isLablePage = thisUrl.indexOf("/search/label/")!=-1;
var thisLable = isLablePage ? thisUrl.substr(thisUrl.indexOf("/search/label/")+14,thisUrl.length) : "";
thisLable = thisLable.indexOf("?")!=-1 ? thisLable.substr(0,thisLable.indexOf("?")) : thisLable;
var thisNum = 1;
var postNum=1;
var itemCount = 0;
var fFlag = 0;
var eFlag = 0;
var html= ”;
var upPageHtml =”;
var downPageHtml =”;
var labelHtml = ‘<span class="showpageNum"><a href="/search/label/’+thisLable+’?&max-results=’+pageCount+’">’;
var thisUrl = home_page_url;
for(var i=0, post; post = json.feed.entry[i]; i++) {
var timestamp1 = post.published.$t.substring(0,19)+post.published.$t.substring(23,29);
timestamp = encodeURIComponent(timestamp1);
var title = post.title.$t;
if(title!=”){
if(itemCount==0 (itemCount % pageCount ==(pageCount-1))){
if(thisUrl.indexOf(timestamp)!=-1 ){
thisNum = postNum;
}
if(title!=”) postNum++;
htmlMap[htmlMap.length] = ‘/search/label/’+thisLable+’?updated-max=’+timestamp+’&max-results=’+pageCount;
}
}
itemCount++;
}
for(var p =0;p< htmlMap.length;p++){
if(p>=(thisNum-displayPageNum-1) && p<(thisNum+displayPageNum)){
if(fFlag ==0 && p == thisNum-2){
if(thisNum==2){
upPageHtml = labelHtml + upPageWord +’</a></span>’;
}else{
upPageHtml = ‘<span class="showpage"><a href="’+htmlMap[p]+’">’+ upPageWord +’</a></span>’;
}
fFlag++;
}
if(p==(thisNum-1)){
html += ‘<span class="showpagePoint">’+thisNum+’</span>’;
}else{
if(p==0){
html = labelHtml+’1</a></span>’;
}else{
html += ‘<span class="showpageNum"><a href="’+htmlMap[p]+’">’+ (p+1) +’</a></span>’;
}
}
if(eFlag ==0 && p == thisNum){
downPageHtml = ‘<span class="showpage"> <a href="’+htmlMap[p]+’">’+ downPageWord +’</a></span>’;
eFlag++;
}
}
}
if(thisNum>1){
if(!isLablePage){
html = ”+upPageHtml+’ ‘+html +’ ‘;
}else{
html = ”+upPageHtml+’ ‘+html +’ ‘;
}
}
html = ‘<div class="showpageArea"><span style="COLOR: #000;" class="showpageOf"> Pages (‘+(postNum-1)+’)</span>’+html;
if(thisNum<(postNum-1)){
html += downPageHtml;
}
if(postNum==1) postNum++;
html += ‘</div>’;
var pageArea = document.getElementsByName("pageArea");
var blogPager = document.getElementById("blog-pager");
if(postNum <= 2){
html =”;
}
for(var p =0;p< pageArea.length;p++){
pageArea[p].innerHTML = html;
}
if(pageArea&&pageArea.length>0){
html =”;
}
if(blogPager){
blogPager.innerHTML = html;
}
}
</script>
<script type=’text/javascript’>
var thisUrl = home_page_url;
if (thisUrl.indexOf("/search/label/")!=-1){
if (thisUrl.indexOf("?updated-max")!=-1){
var lblname1 = thisUrl.substring(thisUrl.indexOf("/search/label/")+14,thisUrl.indexOf("?updated-max"));
}else{
var lblname1 = thisUrl.substring(thisUrl.indexOf("/search/label/")+14,thisUrl.indexOf("?&max"));
}
}
var home_page = "/";
if (thisUrl.indexOf("?q=")==-1 && thisUrl.indexOf(".html")==-1){
if (thisUrl.indexOf("/search/label/")==-1){
document.write(‘<script src="’+home_page+’feeds/posts/summary?alt=json-in-script&callback=showpageCount&max-results=99999" ><\/script>’)
}else{document.write(‘<script src="’+home_page+’feeds/posts/full/-/’+lblname1+’?alt=json-in-script&callback=showpageCount2&max-results=99999" ><\/script>’)
}
}
</script>
In the code above you can edit this line only :
var pageCount=7;
var displayPageNum=5;
1 : var pageCount=7;
The Pagecount represents number of posts to be shown in single page. Change the digit to show as many pages you want.
2 : var displayPageNum=5;
The digit represents number of pages to be listed.
Modification Step for Label :
Add Label Gadget (Layout –> page elements –> Add Gadget –> Select Labels)
From Layout –> Edit HTML . Don’t Forget to backup your template (Download Full Template)
Search this code
<a expr:dir=’data:blog.languageDirection’ expr:href=’data:label.url’><data:label.name/></a>
Change to this code
<script type=’text/javascript’>
var lblname = "<data:label.name/>";
lblname2 = encodeURIComponent(lblname);
var feedlink = '/search/label/' + lblname2+'?&max-results=7';
document.write('<a href="' + feedlink + '">'+lblname+'</a>'); </script>
Click on Preview button to ensure that no code error been found. No effect on the navigation hack can be seen though.
Click on Save Template to save the change.