-
-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathtabbed-toc.js
153 lines (137 loc) · 7.36 KB
/
tabbed-toc.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
/*!
* Blogger Tabbed Style Table of Content Widget by Taufik Nurrohman
* Free for change but keep the original attribution.
* URL: https://plus.google.com/108949996304093815163/about
*/
(function(win, doc) {
var hash = (new Date()).getTime(),
defaults = {
blogUrl: "http://dte-feed.blogspot.com", // Blog URL
containerId: "tabbed-toc", // Container ID
activeTab: 1, // The default active tab index (default: the first tab)
showDates: false, // true to show the post date
showSummaries: false, // true to show the posts summaries
numChars: 200, // Number of summary chars
showThumbnails: false, // true to show the posts thumbnails (Not recommended)
thumbSize: 40, // Thumbnail size
noThumb: "", // No thumbnail URL
monthNames: [ // Array of month names
"Januari",
"Februari",
"Maret",
"April",
"Mei",
"Juni",
"Juli",
"Agustus",
"September",
"Oktober",
"November",
"Desember"
],
newTabLink: true, // Open link in new window?
maxResults: 99999, // Maximum posts result
preload: 0, // Load the feed after 0 seconds (option => time in milliseconds || "onload")
sortAlphabetically: true, // `false` to sort posts by date
showNew: false, // `false` to hide the "New!" mark in most recent posts, or define how many recent posts are to be marked
newText: ' – <em style="color:red;">Baru!</em>' // HTML for the "New!" text
};
if (typeof tabbedTOC === "undefined") {
tabbedTOC = defaults;
} else {
for (var i in defaults) {
defaults[i] = typeof tabbedTOC[i] !== "undefined" ? tabbedTOC[i] : defaults[i];
}
}
win['clickTabs_' + hash] = function(pos) {
var a = document.getElementById(defaults.containerId),
b = a.getElementsByTagName('ol'),
c = a.getElementsByTagName('ul')[0],
d = c.getElementsByTagName('a');
for (var t = 0, ten = b.length; t < ten; ++t) {
b[t].style.display = "none";
b[parseInt(pos, 10)].style.display = "block";
}
for (var u = 0, uen = d.length; u < uen; ++u) {
d[u].className = "";
d[parseInt(pos, 10)].className = "active-tab";
}
};
win['showTabs_' + hash] = function(json) {
var total = parseInt(json.feed.openSearch$totalResults.$t, 10),
c = defaults,
entry = json.feed.entry,
category = json.feed.category,
skeleton = "",
newPosts = [];
for (var g = 0; g < (c.showNew === true ? 5 : c.showNew); ++g) {
if (g === entry.length) break;
entry[g].title.$t = entry[g].title.$t + (c.showNew !== false ? c.newText : "");
}
entry = c.sortAlphabetically ? entry.sort(function(a, b) {
return a.title.$t.localeCompare(b.title.$t);
}) : entry;
category = c.sortAlphabetically ? category.sort(function(a, b) {
return a.term.localeCompare(b.term);
}) : category;
// Build the tabs skeleton
skeleton = '<span class="toc-line"></span><ul class="toc-tabs">';
for (var h = 0, cen = category.length; h < cen; ++h) {
skeleton += '<li class="toc-tab-item-' + h + '"><a onclick="clickTabs_' + hash + '(' + h + ');return false;" onmousedown="return false;" href="javascript:;">' + category[h].term + '</a></li>';
}
skeleton += '</ul>';
// Bulid the tabs contents skeleton
skeleton += '<div class="toc-content">';
for (var i = 0, cen = category.length; i < cen; ++i) {
skeleton += '<ol class="panel" data-category="' + category[i].term + '"';
skeleton += (i != (c.activeTab-1)) ? ' style="display:none;"' : '';
skeleton += '>';
for (var j = 0; j < total; ++j) {
if (j === entry.length) break;
var link, entries = entry[j],
pub = entries.published.$t, // Get the post date
month = c.monthNames, // Month array from the configuration
title = entries.title.$t, // Get the post title
summary = ("summary" in entries && c.showSummaries === true) ? entries.summary.$t.replace(/<br *\/?>/g," ").replace(/<.*?>/g,"").replace(/[<>]/g,"").substring(0, c.numChars) + '…' : "", // Get the post summary
img = ("media$thumbnail" in entries && c.showThumbnails === true) ? '<img class="thumbnail" style="width:' + c.thumbSize + 'px;height:' + c.thumbSize + 'px;" alt="" src="' + entries.media$thumbnail.url.replace(/\/s\d(\-c)?\//,"/s" + c.thumbSize + "-c/") + '"/>' : '<img class="thumbnail" style="width:' + c.thumbSize + 'px;height:' + c.thumbSize + 'px;" alt="" src="' + c.noThumb.replace(/\/s\d(\-c)?\//,"/s" + c.thumbSize + "-c/") + '"/>', // Get the post thumbnail
cat = entries.category || [], // Post categories
date = c.showDates ? '<time datetime="' + pub + '" title="' + pub + '">' + pub.substring(8, 10) + ' ' + month[parseInt(pub.substring(5, 7), 10) - 1] + ' ' + pub.substring(0, 4) + '</time>' : ""; // Formated published date
for (var k = 0, ken = entries.link.length; k < ken; ++k) {
if (entries.link[k].rel === "alternate") {
link = entries.link[k].href; // Get the post URL
break;
}
}
for (var l = 0, check = cat.length; l < check; ++l) {
var target = c.newTabLink ? ' target="_blank"' : ""; // Open link in new window?
// Write the list skeleton only if at least one of the post...
// ... has the same category term with one of the current categories term list
if (cat[l].term === category[i].term) {
skeleton += '<li title="' + cat[l].term + '"';
skeleton += c.showSummaries ? ' class="bold"' : "";
skeleton += '><a href="' + link + '"' + target + '>' + title + date + '</a>';
skeleton += c.showSummaries ? '<span class="summary">' + img + summary + '<span style="display:block;clear:both;"></span></span>' : "";
skeleton += '</li>';
}
}
}
skeleton += '</ol>';
}
skeleton += '</div>';
skeleton += '<div style="clear:both;"></div>';
doc.getElementById(c.containerId).innerHTML = skeleton;
win['clickTabs_' + hash](c.activeTab - 1);
};
var h = doc.getElementsByTagName('head')[0],
s = doc.createElement('script');
s.src = defaults.blogUrl.replace(/\/+$|[\?&#].*$/g, "") + '/feeds/posts/summary?alt=json-in-script&max-results=' + defaults.maxResults + '&orderby=published&callback=showTabs_' + hash;
if (defaults.preload !== "onload") {
win.setTimeout(function() {
h.appendChild(s);
}, defaults.preload);
} else {
win.onload = function() {
h.appendChild(s);
};
}
})(window, document);