【ISSUE】初めてChromeExtension(Chrome拡張機能)を作ってみた

0

2024年12月23日 17:28

はじめに

今回、初めてChrome拡張機能を作ってみて、Chromeウェブストアへ公開するというところまでやってみたので、
ログとして残しておきたいと思います。

今回作ったもの

https://github.com/nomunomu0504/smart-pull-request

無事、Chromeウェブストアへ公開されました!

https://chrome.google.com/webstore/detail/smartpullrequest/goojodnccenoinjjpfiajflilecakcbp

何を作ったか

Githubでプロジェクトを進めて行くと、必ずコードレビューが発生してきます。

このとき、1PRで修正されたファイルが少なければ特に問題ないのですが、自動生成ファイルなどが含まれる、大量差分のPRを見るときに大変なのがこちら。
image.png
そう。Filesタブにある大量のファイルリストです。

Diff表示の方は個別表示/非表示や、一括表示/非表示を行うことができますが、サイドメニューにあるリストはできないのです。

:::note info
Diff表示の一括表示/非表示は 「alt(macならoption)+diff表示/非表示ボタン」でできます。
:::

そこで、サイドメニューのファイルリスト + Diff表示部分の一括表示/非表示を行う専用ボタンを表示させる、拡張機能を作ってみました。

実装紹介

拡張機能用のディレクトリ構成とかは、特になさそうだったので、自分は以下のようにしておきました。
img

重要なのは manifest.json と実際に処理を書く index.js です。

今回の拡張機能では、拡張機能を実装する上で使える機能のごくごく一部分しか使えていないので、もっと詳しいことを知りたい方は、公式サイトをご覧ください。

https://developer.chrome.com/docs/extensions/mv3/getstarted/

manifest.jsonの中身はこんな感じ。正しいか正しくないかは分からないですが、テストして拡張機能自体は動いてたから問題ないのかなと...
img
manifest_versionv3 を使うと、審査時間も短縮されるみたいです。公式がそう言ってるので間違いないはず。
image.png

ざっと重要な項目だけ触れておくと

  • permissions
  • content_scripts
  • web_accessible_resources

は抑えておきたいところですね。

permissions

これはその名の通り、拡張機能に付与する権限を指定します。権限を要求できるリストは以下にまとまっています。

https://developer.chrome.com/docs/extensions/reference/permissions/

今回の拡張機能では、特にユーザーから権限を貰う必要がなかったため、空配列となっています。

content_scripts

このセクションでは、どのファイルに記述された機能(処理)をどのサイト・どのタイミングで実行するか。などの、拡張機能根幹の設定を行います。

https://developer.chrome.com/docs/extensions/mv3/content_scripts/

私の場合はjQueryを使いたかったので、documentの読み込みが始まった時点で先にloadしておき、documentの読み込みが終わった時点で、拡張機能本体を読み込ませるようにしました。

web_accessible_resources

そう。一番こいつに時間を取られました。このセクションでは、拡張機能側から自前のhtmlやimgなどのリソースを読み込むために、設定を記述するセクションです。

https://developer.chrome.com/docs/extensions/mv3/manifest/web_accessible_resources/

index.js で画面にinjectしたいhtmlが書かれているファイルをloadしてきて、突っ込むという処理です。

なんの設定もしなくても、普通に読み込めるだろうと思ってたら全く読み込めず、こいつの存在を知るまで時間を溶かしてました。気をつけましょう。
img

で、なんやかんやありましたが、無事申請中です。こうやってみんな作ってるんだなと知ることができました。

Tips

開発中の拡張機能をどうテストするかですが、まずはじめにChromeの拡張機能画面を開いて、デベロッパーモードを「ON」にする必要があります。
image.png

ONにすると、上からにゅっとメニューバーが表示されるので、「パッケージ化されていない拡張機能を読み込む」を選択します。
image.png

そうすると、フォルダ選択するウィンドウが開くので、manifest.json が置かれているフォルダを選択します。

:::note warn
実際にテストする際には、manifest.jsonが必要なので、先に作成しておきましょう。
:::

すると、拡張機能のところに今作ってる拡張機能が表示されます。
image.png

パッケージ化されていない拡張機能を読み込むメリットは、わざわざ更新したものをパッケージ化して、再読み込みさせる必要がないというところです。

参照しているフォルダの処理を書き換え保存したら、読み込んだ拡張機能カードに表示されている、ローディングボタンをクリックします。
image.png

そうすると、参照しているフォルダの最新情報で拡張機能が更新されます。これを繰り返すことで開発を簡単に行うことができます。

おわり

簡単な拡張機能を試しで作ってみて、ぜひGithubに公開してみましょう!
[cv:issue_marketplace_engineer]

0

診断を受けるとあなたの現在の業務委託単価を算出します。今後副業やフリーランスで単価を交渉する際の参考になります。また次の単価レンジに到達するためのヒントも確認できます。