何を作ったか
- chrome上で、ひらがなしかまだ読めない子供がポケモン図鑑を調べられるようになるものを作りました
- https://zukan.pokemon.co.jp/ こちらの公式サイトで、カタカナで書かれたポケモンの名前の上にひらがなでルビが振られます。
- 以下が、使用前と使用後の動作の違いです
なぜ作ろうと思ったか
- 子供がポケモンに興味を持って毎日図鑑を見てくれるのはいいのですが、毎日、「このポケモンの名前はなに?」って聞かれてくる
- ポケモンの名前をひたすら読まされるのはとても大変(本当に大変なんですよ、、、。)
- しかし子供は、ひらがなは読める、だが図鑑のポケモンの名前はカタカナ
- だったら、カタカナにひらながでルビを振ってあげたら解決するんじゃ!閃きました
- まずどうしたら他者の作ったページを手元だけで変えられるか考えた結果、chromeアドオンに何かあればいいなと思い
- 早速chromeのアドオンを調べてるとそういった類のものはなし、じゃあ自分で作ってやろうというところから開発することに決めました。
どのように実現したか
- 実際に作成したコードはこちらにソースをあげてあります。 https://github.com/zukaishi/pokemon_zukan_ruby
- chrome_package配下参照
- 僕の場合typescriptを書いてから変換させましたが、JS変換してもほとんど変化ありません
ファイル構成
chrome_package
┗ index.ts
┗ manifest.json
src
┗ index.ts
tsconfig.json
README.md
chrome_package/index.js
"use strict";
['name', 'subname', 'name__loadItem', 'label__detail-features-type js-btn-resetPage'].forEach(function (value) { return elementReplace(document.getElementsByClassName(value)); });
function elementReplace(element) {
for (var i = 0; i < element.length; i++) {
var str = element[i].innerHTML;
element[i].innerHTML =
'<ruby>' +
str +
'<rt>' +
katakanaToHiragana(str) +
'</rt></ruby>';
}
}
function katakanaToHiragana(str) {
return str.replace(/[\u30a1-\u30f6]/g, function (match) {
var chr = match.charCodeAt(0) - 0x60;
return String.fromCharCode(chr);
});
}
chrome_package/manifest.json
{
"manifest_version": 2,
"description" : "pokemon zukan ruby",
"name": "write ruby on pokemon zukan",
"version": "1.0",
"content_scripts": [
{
"matches": ["https://zukan.pokemon.co.jp/*"],
"js": ["index.js"]
}
]
}
- ローカルに落としてtypescirptからコードをいじる場合は、カレントディレクトリ上で下記を実行してください。
- ここではtsconfig.jsonの中身は触れませんが、実行することで、src/の中身を、typescript -> javascirptへ変換し、chrome_packageディレクトリへ出力するということだけ記載してあります。
> tsc
使い方
1.調べたいポケモンページにアクセス(ここではフシギダネ)
https://zukan.pokemon.co.jp/detail/001
2.以下からコードをおとしてくる
3.chrome から chrome://extensions/ を起動
chrome -> 「環境設定」 -> 「拡張機能」 右上部にある、「デベロッパーモード」をONにする
「パッケージ化されていない拡張期のを読み込む」で、落としてきたコード内にある、chrome_pakageディレクトリを選択
4.再度、フシギダネのページでブラウザリロード https://zukan.pokemon.co.jp/detail/001
結果どうなったか
- 子供は一人でポケモンを調べることができ、僕はその時間で別のことができるようになって
- 子供は前よりポケモンに興味が湧いて、今度はしりとりをやろうということになって
- 結果、しりとりに時間を割かれることになりました。(泣
- 子育てにおいて、同じ悩みを持たれている方がいらっしゃいましたらぜひ活用してみてください。
- 一つの課題をクリアすると、次の課題が湧いてくることを実感できると思います。
参考
https://qiita.com/mimoe/items/855c112625d39b066c9a
https://qiita.com/hibikikudo/items/dd9936cdd8108dc446d4
以上です。
よろしくお願い致します。