MovableTypeにTwitter Badgeを使ってTwitterタブを用意した
Posted on | 2009/8/5 18:20:58
以前、MovableTypeにTumblr APIを使ってTumblrタブを用意したというのをやりましたが、それのTwitter版です。Twitter APIでやろうとしましたが、Twitter Badgeというのがあるので、そちらをカスタマイズすればいいやということに。
20件表示するように設定して、ソースをコピー。で余計なソースを削りつつ、タブパネルに組み込みます。で、ちょっとデザインのカスタマイズもしたいので、blogger.jsをダウンロードしてきて、ちと改変しうちのサーバにアップ。
<div class="TabbedPanelsContent">
<ul id="twitter_update_list"></ul>
<script src="<$MTBlogURL$>js/twitter.js" type="text/javascript"></script>
<script type="text/javascript" src="http://twitter.com/statuses/user_timeline/kosuk.json?callback=twitterCallback2&count=20"></script>
</div>
twitter.jsの中身はこちら。太字が変えたところ。
function twitterCallback2(twitters) {
var statusHTML = [];
for (var i=0; i<twitters.length; i++){
var username = twitters[i].user.screen_name;
var status = twitters[i].text.replace(/((https?|s?ftp|ssh)\:\/\/[^"\s\<\>]*[^.,;'">\:\s\<\>\)\]\!])/g, function(url) {
return ‘<a href="’+url+’">’+url+’</a>’;
}).replace(/\B@([_a-z0-9]+)/ig, function(reply) {
return reply.charAt(0)+’<a href="http://twitter.com/’+reply.substring(1)+’">’+reply.substring(1)+’</a>’;
});
statusHTML.push(‘<a href="http://twitter.com/kosuk"><img src="http://www.kosukekato.com/js/sml.jpg" style="float:left;margin:0px 10px 10px 0px;" /></a><li><span>’+status+’</span> <a style="font-size:85%" href="http://twitter.com/’+username+’/statuses/’+twitters[i].id+’">’+relative_time(twitters[i].created_at)+’</a><br clear="all" /></li>’);
}
document.getElementById(‘twitter_update_list’).innerHTML = statusHTML.join(”);
}function relative_time(time_value) {
var values = time_value.split(" ");
time_value = values[1] + " " + values[2] + ", " + values[5] + " " + values[3];
var parsed_date = Date.parse(time_value);
var relative_to = (arguments.length > 1) ? arguments[1] : new Date();
var delta = parseInt((relative_to.getTime() – parsed_date) / 1000);
delta = delta + (relative_to.getTimezoneOffset() * 60);if (delta < 60) {
return ‘less than a minute ago’;
} else if(delta < 120) {
return ‘about a minute ago’;
} else if(delta < (60*60)) {
return (parseInt(delta / 60)).toString() + ‘ minutes ago’;
} else if(delta < (120*60)) {
return ‘about an hour ago’;
} else if(delta < (24*60*60)) {
return ‘about ‘ + (parseInt(delta / 3600)).toString() + ‘ hours ago’;
} else if(delta < (48*60*60)) {
return ’1 day ago’;
} else {
return (parseInt(delta / 86400)).toString() + ‘ days ago’;
}
}
というわけです。


意外と知らない、「ヒトリシゴト」。案外、愉快で、楽しいです。気軽に読める、ビジネスエッセイ。

プランナー、加藤康祐のブログ、kosukekato.com : the idea espressoに掲載したコラム、2006/7/20「歴史は作られている」から2010/5/23「行為が流通するプラットフォームに新しい時代を感じる」を一冊の本にしました。

今話題のInstagramを使った写真集です!あなたもInstagramするきっかけになれば!68点の写真を収録。
- blog.daichisakota.com - ちょっと考えられないくらい美味かった「いわもと Q 」(麹町)
- TechCrunch Japanese - Instagramのファウンダのガールフレンドが自作のWebアプリをバレンタインデーギフトに
- TechCrunch Japanese - アメリカの世帯でケーブルTVの解約増加―視聴方法は大幅に多様化(Nielsen調べ)
- TechCrunch Japanese - Foursquare、モバイルアプリケーション版でも「探索」を充実して「地域検索エンジン」機能を強化
- TechCrunch Japanese - LinkedIn、ウォール街予測を上回る。Q4売上は105%増の1.677億ドル
- ハッカー集団、シマンテック「pcAnywhere」のソースコード公開 - CNET Japan
- blog.daichisakota.com - フリーランスになって一週間が経ちました












