読者です 読者をやめる 読者になる 読者になる

まめ畑

ゆるゆると書いていきます

選択した文字を翻訳するJetpack Featureを作ってみた

Jetpack javascript

Jetpackがバージョンアップして、JEPからAudio以外にも取り込まれたものがあります。
Selectionというものなのですが、これはWebサイト上の選択した文字を取得したりする事が出来ます。
凄く簡単なAPIなので、仕様などはLabs/Jetpack/JEP/12 - MozillaWikiをご覧下さい。


文字を選択時に以下の関数が呼び出されます

jetpack.selection.onSelection( callback );

この関数の中に処理を書きます。

選択した文字は

//Textを取得
var textOfSel = jetpack.selection.text;
//タグも取得(タグつきで設定も可能)
var htmlOfSel = jetpack.selection.html;

で取得が出来ます。
このプロパティに代入する事で文字を置換する事も出来ます。

使用しなくなったら

jetpack.selection.onSelection.unbind( callback );

でイベントを外してやる事も可能です。


ふと英語論文を簡単(?)に翻訳するためのツールを作ってみた - あたご型護衛艦日記を読んで、選択した文字の翻訳が便利そうだったので、Selectionを使ってFeatureを作ってみました。
とりあえず「Translate Text mini」という名前で。
Featureのインストールはhttp://userscripts.org/jetpacks/122/から出来ます。

インストールするとステータスバーに

が出てきます。
ここで選択した言語に翻訳します。

後は、気になった文字を選択するだけです
文章の選択も可能です。
以下のようにります。


うまく翻訳出来ない場合もあるのでご了承ください。
Textプロパティから取得設定しているので一気に選択すると、画像が無くなったりレイアウトが崩れる場合もあります。
機能としては選択した文字をAJAX Language APIに渡してるだけなので、場合によってはそこそこ面白い事になるかも。


ソースは

/*
	@author: con_mame
	@url: http://d.hatena.ne.jp/con_mame/
	@title: Translate Text mini
	@description: Translate Selected Word
	@version: 0.2
*/

(function(){
	jetpack.future.import("selection");

	const API_URL = "http://ajax.googleapis.com/ajax/services/language/translate";
	const JAPAN_FLAG = "";
	const USA_FLAG = "";

	var lang = "off";

	jetpack.selection.onSelection(function() {
		if(lang == "off") return;

		var selectedElement = jetpack.selection;
		var langPair = (lang == "ja") ? "en":"ja";
		langPair += "|" + lang;

		$.getJSON(API_URL,{"v": "1.0", "q": selectedElement.text, "langpair": langPair} ,function(result){
			if(result.responseData == null || result.responseData == ""){
				jetpack.notifications.show({
					title: "Not Found",
					body: "Can not Translate"
				});
				return;
			}
			selectedElement.text = result.responseData.translatedText;
		});
	});

	jetpack.statusBar.append({
		html: <>
			<span id="language"><input type="radio" name="language" value="ja" checked="checked"/><img src={JAPAN_FLAG} /><input type="radio" name="language" value="en"/><img src={USA_FLAG} /><input type="radio" name="language" value="off"/><b>OFF</b></span>
		</>,
		onReady: function(doc){
			$("#language", doc).css({
				position: "absolute",
				paddingTop: "3px",
				fontSize: "14px"
			});
			$(":radio", doc).change(function(){
				lang = $(":radio:checked", doc).val();
			});
		},
		width: 150
	});
})();