2013年7月31日水曜日

Amazonをより快適にするOpera Extensionが公開されました。

このエントリーをはてなブックマークに追加

Amazonをより快適にするOpera Extensionが公開されました。

https://addons.opera.com/ja/extensions/details/book-support/?display=ja

前の記事で書いたのを、Opera 15ユーザでも体験できるようにした物です。
使ってみてくだしぁ

2013年7月28日日曜日

Amazonを便利にするスクリプト書いた

このエントリーをはてなブックマークに追加

Amazonをより快適にするUserScriptを書きました。

http://userscripts.org/scripts/show/174373

screenshot

Userscriptsにアップするのは久々ですね。
上記の画像から分かる通り、Amazonのリンクに、読書メーターやらなんやらのサービスへのリンクを追加するだけのスクリプトです。
動作確認したのは下記のブラウザです。

  • Opera 12
  • Vimperator 3.7.1(Firefox 22.0)
  • Google Chrome 28

コード

// ==UserScript==
// @name book support
// @namespace http://looxu.blogspot.com/
// @include http://www.amazon.co.jp/*
// @author Arc Cosine
// @version 1.6
// @LICENSE Public Domain
// ==/UserScript==
(function(){
var bookLogList = {
"Bookmater" : {
"url" : "http://book.akahoshitakuya.com/b/{ASIN}/",
"favicon" : "http://book.akahoshitakuya.com/favicon.ico"
},
"booklog" : {
"url" : "http://booklog.jp/item/1/{ASIN}/",
"favicon" : "http://booklog.jp/favicon.ico"
},
"bukkupe" : {
"url" : "http://bukupe.com/book/{ASIN}/",
"favicon" : "http://bukupe.com/favicon.ico"
},
"TwitterSearch" : {
"url" : "https://twitter.com/search?q={ASIN}",
"favicon" : "https://twitter.com/favicon.ico"
},
// Move kinokuniya
"Kinoppy" : {
"url" : "http://www.kinokuniya.co.jp/disp/CSfDispListPage_001.jsp?qs=true&ptk=03&q={ASIN}",
"favicon" : "http://www.kinokuniya.co.jp/favicon.ico",
"option" : function(_self,node){
var ee = document.getElementsByTagName("B"),
i = 0, iz = ee.length,
one = null, asin = "";
for(;i<iz;i++){
one = ee[i];
if( one.innerHTML === "ISBN-13:" ){
asin = one.nextSibling.nodeValue.replace(/[^\d]*(\d+)-(\d+).*/, "$1$2");
break;
}
}
if( asin !== "" ){
node.href = _self.url.replace(/{ASIN}/,asin);
}
}
}
};
function init(){
var target = document.getElementById("btAsinTitle");
if( target ){
var asin = document.getElementById("ASIN").value,
key = "", one = null, img = null, link = null, div = null;
var div = document.getElementById("book-support-div");
if( !div ){
div = document.createElement("div");
div.id = "book-support-div";
}else{
// ForFirefox
return;
}
for( key in bookLogList ){
one = bookLogList[key];
link = div.appendChild(document.createElement("a"));
link.href = one.url.replace(/{ASIN}/,asin);
link.style.margin = "0px 16px 0px 0px";
link.alt = "Go to page";
img = link.appendChild(document.createElement("img"));
img.src = one.favicon;
img.style.width = "16px";
img.style.height= "16px";
// option code.
if( typeof one.option !== "undefined" && typeof one.option === "function" ){
one.option(one,link);
}
}
target.parentNode.insertBefore(div, target);
}
}
init();
document.addEventListener('DOMContentLoaded', init, false );
})();

技術的な解説

今回、user.jsという拡張子でアップロードしてました。その結果、DOMContentLoadedのタイミングが非常に微妙な感じになっています。
Operaの場合、user.jsという拡張子だとDOMContentLoadedが発生しません。
.jsという拡張子だとDOMContentLoadedが発生します
Firefoxの場合、user.jsでDOMContentLoadedが発生します
その為、initが発生したり、しなかったり、2回走ったりみたいな事をしていまいました。
対応策として、initの中に起動してるかどうかを判定するのにbook-support-divというidを持つnodeが存在するかどうかをチェックするようにしています。
まあ、よくあるテクニックの一つですね。
ホントは変数か何かで管理するのが正しいとは思うのですが、メンドーなので、手っ取り早い方法をやりました。
そんな感じです。
皆様のお役に立てれば幸いです。
あ、せっかくなので、Opera拡張も作って申請だしました。レビュー通ったらまた告知しますね。

2013年7月4日木曜日

popInの新サービス

このエントリーをはてなブックマークに追加

popInの新サービスが開始されました

Thumbnail

僕のアルバイト先であるpopInの新サービスがリリースされました。
普段はこういう記事は一切書かないのですが、今回作ったサービスは僕もすごく気に入っていて、たくさんの人に活用していただきたいなと思ったので、ブログを書くことにしました。

ただ、機能を紹介するだけですと面白くないので、ほんの少しだけ、popInと僕の歴史を交えながら読んでいただければ幸いです。

popInと僕

以前から知っているは別として、僕はpopInという会社でアルバイトしています。
僕がpopInでアルバイトするようになったのが2008年からなので実に6年近くになります。
創業のかなり初期からこのすごい企業にコミット出来たのは運が良かったと言えます。当時の僕のスキルは今の10分の1程度でした。Twitterだってろくに知らなかったのです。
そんなド素人の僕でしたが、素人と違う所がありました。技術が好きだったという事と、ブラウザが好きだったという事です。
僕の過去エントリを読んだことがある人なら知っていると思いますが、僕はOperaを愛していて、Vimperatorが大好きで、Google Chromeが好きで、Safariにちょっとだけ憧れていて、IEが大嫌いな開発者でした。
端的に言えば、ブラウザという一点に関して、常軌を逸した情熱を持っていたのです。
そして、そんな情熱に創業者が共感してくれたのです。同い年だったのも何かの「縁」だったのかもしれません。
いずれにせよ、僕はpopInという素晴らしい会社で仕事が出来るという幸せを与えられました。

2013年7月2日火曜日

ブログデザインを変更した

このエントリーをはてなブックマークに追加

ブログデザインを変えた

今までは、気にしていなかったけれど、新デザインにしてから僕のブログは読みにくくなっていた。GEORGIAという英語圏では重宝されてるものの、日本語圏だとクソ汚いMSフォントへ変換されるダメダメフォントがデフォルトで指定されていたので、その他の綺麗なフォントを表示するように修正した。
すごく気持ち良い。お陰で、このブログ自体も読みやすくなったはずだ。

背景も変更

背景も半透明クールな何かが指定されていたけれど、文字を読むという行為を考えた場合、読みづらさの方が先に来てしまうので、変更。今回は珍しいカラーである#ecececを使用してみた。#fffより少し暗めの灰色を選んでみた。多少読みやすくなっているはずだ。

ヘッダとline-heightの修正

ヘッダのデザインがテキトーだったので、フォントサイズと色を変えてみた。色はcolour loversに適当にHEXを入れてヒットしたのを選んだ。#334433という若干緑がかった色だ。これは結構気に入った。
line-heightは1.5だったのを1.7にまで拡張してみた。これで行間を読めるようになったと思われる(^ワ^)

なんでデザインを変えたの

どうしても読んで欲しい記事を書く必要が生じたので。今週中にブラッシュアップしてアップしたいと思います。