Blogger alt yapılı blog sitelerinde, yorum kısmına gelen "Yanıtla/Cevapla" özelliği ile bir çok blogger bunu blogunda ekleyerek bu nimetten faydalandı. Gerçekten de hoş bir özellik olmuş ve olması gereken bir şey idi zaten.
Google'da aratırsanız, "Blogger Yanıtla Özelliği", "Blogger Yorumlarında Cevapla Özelliği" şeklinde bir çok başlık ve anlatım ile karşılaşmanız mümkün.
Herkes Google'da aratıyor aratmasına da... İnternette anlatılan birbirinden farklı o kadar yöntem arasından kimilerinin blogunda bu özellik başarılı bir şekilde çalışır iken, kimilerinde ise çalışmamaktadır. Örneğin; Yanıtla butonu gözükse bile bu aktif olarak çalışmamakta. İşte asıl sorun da buydu bende.
İnternette onlarca anlatım var. Neredeyse hepsini denememe rağmen bir türlü yapamamıştım. Bugün ise yeniden aklıma geldi, yorumlar kısmındaki blogumun bu eksikliği. Yine Google'da arattım fakat hep aynı anlatımlar. Daha sonra ise 3 farklı blogdan aldığım farklı farklı kodları kendi bloguma uyguladıktan sonra ise, sonuca ulaşabildim. Aynı sorunla karşılaşanlar muhakkak vardır diye blogda paylaşayım dedim. Ben direkt olarak kendi yaptıklarımı adım adım ekleyeceğim.
NOT - 1: Kodları eklerken CTRL+F ile kodu bulamadıysanız, bulamadığınız kodun bir kısmını alın ve öyle arayın. Aradaki boşluklardan veya yazım şekillerinden kaynaklı olarak bulunamayabiliyorlar bazen. Ayrıca ne olur ne olmaz diye, adımları uygulamaya başlamadan önce temanızın yedeğini almayı unutmayın. Kodları çok dikkatli ve düzgün bir şekilde eklemeye özen gösterin. Tüm kodları ekledikten sonra sorununuz düzelmediyse yazının en alt kısmında yazdığım ayarları gözden geçirin.
NOT - 2 : Sitedeki kopyala-yapıştır engelinden dolayı Mozilla Firefox kullanmanızı öneririm. Bilgisayarınızda Firefox yüklü olmayanlar için kodları download linki haline getirdim.
Buraya tıklayarak kodları bilgisayarınıza indirebilirsiniz.
1. Adım
<b:include data='post' name='comments'/>
Yukarıdaki gibi olan tüm kodları şu kod ile değiştirin : <b:include data='post' name='threaded_comments'/>
2. Adım :
<b:includable id='threaded_comment_js' var='post'>
kodu dahil olmak üzere bulup </b:includable>
koduna kadar bu kodda dahil olmak üzere hepsini silin ve şu aşağıdaki kodu ekleyin o sildiğiniz kodların yerine :<b:includable id='threaded_comment_js' var='post'>
<script async='async' expr:src='data:post.commentSrc' type='text/javascript'/>
<script type='text/javascript'>
(function() {
var items = <data:post.commentJso/>;
var msgs = <data:post.commentMsgs/>;
var config = <data:post.commentConfig/>;
// <![CDATA[
var cursor = null;
if (items && items.length > 0) {
cursor = parseInt(items[items.length - 1].timestamp) + 1;
}
var bodyFromEntry = function(entry) {
if (entry.gd$extendedProperty) {
for (var k in entry.gd$extendedProperty) {
if (entry.gd$extendedProperty[k].name == 'blogger.contentRemoved') {
return '<span class="deleted-comment">' + entry.content.$t + '</span>';
}
}
}
return entry.content.$t;
}
var parse = function(data) {
cursor = null;
var comments = [];
if (data && data.feed && data.feed.entry) {
for (var i = 0, entry; entry = data.feed.entry[i]; i++) {
var comment = {};
// comment ID, parsed out of the original id format
var id = /blog-(\d+).post-(\d+)/.exec(entry.id.$t);
comment.id = id ? id[2] : null;
comment.body = bodyFromEntry(entry);
comment.timestamp = Date.parse(entry.published.$t) + '';
if (entry.author && entry.author.constructor === Array) {
var auth = entry.author[0];
if (auth) {
comment.author = {
name: (auth.name ? auth.name.$t : undefined),
profileUrl: (auth.uri ? auth.uri.$t : undefined),
avatarUrl: (auth.gd$image ? auth.gd$image.src : undefined)
};
}
}
if (entry.link) {
if (entry.link[2]) {
comment.link = comment.permalink = entry.link[2].href;
}
if (entry.link[3]) {
var pid = /.*comments\/default\/(\d+)\?.*/.exec(entry.link[3].href);
if (pid && pid[1]) {
comment.parentId = pid[1];
}
}
}
comment.deleteclass = 'item-control blog-admin';
if (entry.gd$extendedProperty) {
for (var k in entry.gd$extendedProperty) {
if (entry.gd$extendedProperty[k].name == 'blogger.itemClass') {
comment.deleteclass += ' ' + entry.gd$extendedProperty[k].value;
}
}
}
comments.push(comment);
}
}
return comments;
};
var paginator = function(callback) {
if (hasMore()) {
var url = config.feed + '?alt=json&v=2&orderby=published&reverse=false&max-results=50';
if (cursor) {
url += '&published-min=' + new Date(cursor).toISOString();
}
window.bloggercomments = function(data) {
var parsed = parse(data);
cursor = parsed.length < 50 ? null
: parseInt(parsed[parsed.length - 1].timestamp) + 1
callback(parsed);
window.bloggercomments = null;
}
url += '&callback=bloggercomments';
var script = document.createElement('script');
script.type = 'text/javascript';
script.src = url;
document.getElementsByTagName('head')[0].appendChild(script);
}
};
var hasMore = function() {
return !!cursor;
};
var getMeta = function(key, comment) {
if ('iswriter' == key) {
var matches = !!comment.author
&& comment.author.name == config.authorName
&& comment.author.profileUrl == config.authorUrl;
return matches ? 'true' : '';
} else if ('deletelink' == key) {
return config.baseUri + '/delete-comment.g?blogID='
+ config.blogId + '&postID=' + comment.id;
} else if ('deleteclass' == key) {
return comment.deleteclass;
}
return '';
};
var replybox = null;
var replyUrlParts = null;
var replyParent = undefined;
var onReply = function(commentId, domId) {
if (replybox == null) {
// lazily cache replybox, and adjust to suit this style:
replybox = document.getElementById('comment-editor');
if (replybox != null) {
replybox.height = '250px';
replybox.style.display = 'block';
replyUrlParts = replybox.src.split('#');
}
}
if (replybox && (commentId !== replyParent)) {
document.getElementById(domId).insertBefore(replybox, null);
replybox.src = replyUrlParts[0]
+ (commentId ? '&parentID=' + commentId : '')
+ '#' + replyUrlParts[1];
replyParent = commentId;
}
};
var hash = (window.location.hash || '#').substring(1);
var startThread, targetComment;
if (/^comment-form_/.test(hash)) {
startThread = hash.substring('comment-form_'.length);
} else if (/^c[0-9]+$/.test(hash)) {
targetComment = hash.substring(1);
}
// Configure commenting API:
var configJso = {
'maxDepth': config.maxThreadDepth
};
var provider = {
'id': config.postId,
'data': items,
'loadNext': paginator,
'hasMore': hasMore,
'getMeta': getMeta,
'onReply': onReply,
'rendered': true,
'initComment': targetComment,
'initReplyThread': startThread,
'config': configJso,
'messages': msgs
};
var render = function() {
if (window.goog && window.goog.comments) {
var holder = document.getElementById('comment-holder');
window.goog.comments.render(holder, provider);
}
};
// render now, or queue to render when library loads:
if (window.goog && window.goog.comments) {
render();
} else {
window.goog = window.goog || {};
window.goog.comments = window.goog.comments || {};
window.goog.comments.loadQueue = window.goog.comments.loadQueue || [];
window.goog.comments.loadQueue.push(render);
}http
})();
// ]]>
</script>
</b:includable>
3. Adım
Burada ise yorum kısmımızı biraz görselleştireceğiz. Bu kod da çoğu sitede bulunuyor. Hoş bir görünütüsü var. Ben kod ile biraz oynadım ve admin siteye yorum yazınca, isminin yanında "Admin" yazmasını sağladım. Gayette hoş oldu. Aşağıdaki kodları kodundan hemen önce ekleyin ve işlem tamamdır!<style>
/*------------- Yorum Formu BLOGKAFEM BAS-------------*/
.comments {
clear: both;
margin-top: 10px;
margin-bottom: 0px;
line-height: 1em;
}
.comments .comments-content {
font-size: 12px;
margin-bottom: 16px;
font-weight: normal;
text-align:left;
line-height: 1.4em;
}
.comments .comment .comment-actions a {
display: inline-block;
margin: 0;
padding: 1px 6px;
border: 1px solid #C4C4C4;
border-top-color: #E4E4E4;
border-left-color: #E4E4E4;
color: #424242 !important;
text-align: center;
text-shadow: 0 -1px 0 white;
text-decoration: none;
-webkit-border-radius: 2px;
-moz-border-radius: 2px;
border-radius: 2px;
background: #EDEDED;
background: -webkit-gradient( linear, left top, left bottom, color-stop(.2, white), color-stop(1, #E5E5E5) );
background: -moz-linear-gradient( center top, white 20%, #E5E5E5 100% );
font: 11px/18px sans-serif;
padding:2px 8px; margin-right:10px;
}
.comments .comment .comment-actions a:hover {
text-decoration: none; background:#fff; border:1px solid #5AB1E2;
}
.comments .comments-content .comment-thread ol {
list-style-type: none;
padding: 0;
text-align: none;
}
.comments .comments-content .inline-thread {
padding: 0.5em 1em;
}
.comments .comments-content .comment-thread {
margin: 8px 0px;
}
.comments .comments-content .comment-thread:empty {
display: none;
}
.comments .comments-content .comment-replies {
margin-top: 1em;
margin-left: 40px; font-size:12px; background:#EBF5FE;
}
.comments .comments-content .comment {
margin-bottom:16px;
padding-bottom:8px;
}
.comments .comments-content .comment:first-child {
padding-top:16px;
}
.comments .comments-content .comment:last-child {
border-bottom:0;
padding-bottom:0;
}
.comments .comments-content .comment-body {
position:relative;
}
.comments .comments-content .user {
font-style:normal;
font-weight:bold;
}
.comments .comments-content .user a {
color:#2D5E7B; font-size:14px; font-weight: bold;text-decoration: none;
}
.comments .comments-content .icon.blog-author {
width: 200px;
height: 22px;
}
.blog-author{
background:url(https://i.hizliresim.com/P3WPYN.jpg);
left:20 px;
right:50px;
}
.comments .comments-content .datetime {
color: #999999;
float: right;
font-size: 11px;
text-decoration: none;
}
.comments .comments-content,
.comments .comments-content .comment-content {
margin:0 0 8px;
}
.comment-header {background-color: #F4F4F4;
border: thin solid #E6E6E6;
margin-bottom: 5px;
padding: 5px;
}
.comments .comments-content .comment-content {
text-align:none;
}
.comments .comments-content .owner-actions {
position:absolute;
right:0;
top:0;
}
.comments .comments-replybox {
border: none;
height: 250px;
width: 100%;
}
.comments .comment-replybox-single {
margin-top: 5px;
margin-left: 48px;
}
.comments .comment-replybox-thread {
margin-top: 5px;
}
.comments .comments-content .loadmore a {
display: block;
padding: 10px 16px;
text-align: center;
}
.comments .thread-toggle {
cursor: pointer;
display: inline-block;
}
.comments .continue {
cursor: pointer;
}
.comments .continue a {
display: inline-block;
margin: 0;
padding: 1px 6px;
border: 1px solid #C4C4C4;
border-top-color: #E4E4E4;
border-left-color: #E4E4E4;
color: #424242 !important;
text-align: center;
text-shadow: 0 -1px 0 white;
text-decoration: none;
-webkit-border-radius: 2px;
-moz-border-radius: 2px;
border-radius: 2px;
background: #EDEDED;
background: -webkit-gradient( linear, left top, left bottom, color-stop(.2, white), color-stop(1, #E5E5E5) );
background: -moz-linear-gradient( center top, white 20%, #E5E5E5 100% );
font: 11px/18px sans-serif;
padding:2px 8px; margin-right:10px;
}
.comments .comments-content .loadmore {
cursor: pointer;
max-height: 3em;
margin-top: 3em;
}
.comments .comments-content .loadmore.loaded {
max-height: 0px;
opacity: 0;
overflow: hidden;
}
.comments .thread-chrome.thread-collapsed {
display: none;
}
.comments .thread-toggle {
display: inline-block;
}
.comments .thread-toggle .thread-arrow {
display: inline-block;
height: 6px;
width: 7px;
overflow: visible;
margin: 0.3em;
padding-right: 4px;
}
.comments .thread-expanded .thread-arrow {
background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAc AAAAHCAYAAADEUlfTAAAAG0lEQVR42mNgwAfKy8v/48I4FeA0AacVDFQBAP9wJkE/KhUMAAAAAElFTkSuQmCC") no-repeat scroll 0 0 transparent;
}
.comments .thread-collapsed .thread-arrow {
background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA AcAAAAHCAYAAADEUlfTAAAAJUlEQVR42mNgAILy8vL/DLgASBKnApgkVgXIkhgKiNKJ005s4gDLbCZBiSxfygAAAAB JRU5ErkJggg==") no-repeat scroll 0 0 transparent;
}
.comments .avatar-image-container {background-image: url("https://img846.imageshack.us/img846/7357/unled1oww.jpg");background-position: center center;background-repeat: no-repeat;float: left;width: 36px;max-height: 36px;margin: 0;outline: 1px solid #FFFFFF;padding: 3px;vertical-align: middle;overflow: hidden;
border: 1px solid #DDDDDD;}
.comments .avatar-image-container img {
width: 36px;
}
.comments .comment-block {
margin-left: 48px;
position: relative;
}
/* Responsive styles. */
@media screen and (max-device-width: 480px) {
.comments .comments-content .comment-replies {
margin-left: 0;
}
}
/*------------- YORUM FORMU BLOGKAFEM SON -------------*/
</style>
Ayrıca, Blogger kontrol paneli ayarlarınızdan;
- Ayarlar → Yayınlar ve Yorumlar → Yorum Konumu → Yerleşik
ve
- Ayarlar → Diğer → Blog İçerik Takibine İzin Ver → Tüm
olacak şekilde ayarlanmış olması gerekmektedir. Eğer kodlar çalışmadıysa "Kontrol Paneli"nizdeki "Ayarlar" kısmındaki ayarların bu şekilde ayarlanıp ayarlanmadığını kontrol edin.
Paylaşımlar için teşekkürler..
YanıtlaSilRica ederim. Her zaman beklerim. :)
Silhem sorununu çözümünü buldum hemde :)
YanıtlaSilYorumunuz için teşekkürler.. Sizin adınıza sevindim. Her zaman beklerim. :)
Silhotfile.com kapandı kardeş şu dosyayı farklı siteye yüklesen?
YanıtlaSilLink yenilenmiştir. Kodları rahatlıkla indirebilirsiniz.
SilMerhaba hocam. Tema değiştikten sonra böyle bir sorun olmuştu. Sadece sizin anlattığınızla yapabildim. Çok çok teşekkür ederim emeğinize sağlık..
YanıtlaSilYardımcı olabildiğime sevindim. Değerli ve güzel yorumunuz için teşekkürler...
Silçok teşekkürler sayenizde sorunumu çözdüm :)
YanıtlaSilYardımcı olmak beni de mutlu etti. Bir teşekkürü çok görmeyip, yorum attığınız için de ben size teşekkür ederim. :)
Sileline koluna yüreğine sağlık. çok işime yaradı teşekkür ederim.
YanıtlaSil