みなさんこんにちは!GASおじさんです。
前々回の記事では「スプレッドシート画面上でGASを実行する方法4選」をご紹介しました。
この記事の中で、
サイドバーから実行する
という方法をご紹介したのですが、
今回はこちらの実装方法について解説していきたいと思います。
Youtubeでも解説していますので動画で見たい人は以下からどうぞ!
サンプル出勤表
今回は以下のサンプルを使って説明していきます。必要に応じてコピーしてご利用ください。
スプレッドシート画面にサイドバーを表示する方法
それでは本題です。
今回のゴールは、スプレッドシート画面の右側に、以下のようなサイドバーを作ることです。
data:image/s3,"s3://crabby-images/ce8f4/ce8f49c65454bf0d7b1f098c65211302fc4942c9" alt=""
スクリプトファイルを作成してコードをコピペ
まずは、「拡張機能」から「Apps Script」を開いてください。
data:image/s3,"s3://crabby-images/1f0e2/1f0e277c7062c07d715a0b7a8a806447c9e6e9af" alt=""
すると、以下のようなスクリプト画面が開かれます。
data:image/s3,"s3://crabby-images/0db3c/0db3c1f5d57a366d7df86e9a2c6bd61f41d912c9" alt=""
GASファイル(サイドバー.gs)の作成
次に新しいファイルを作成します。左上の「+」ボタンから「スクリプト」を選択してください。
data:image/s3,"s3://crabby-images/79275/792757998167d078ca8d714e03f7eba65ee35bce" alt=""
ファイル名は「サイドバー.gs」とでもしておきましょう。
data:image/s3,"s3://crabby-images/ea23b/ea23b19bfed718a9b7d8215b65291ef9284b7428" alt=""
作成した「サイドバー.gs」に、以下のコードをコピペしてください。
function openSidebar() {
const ui = SpreadsheetApp.getUi();
const template = HtmlService.createTemplateFromFile('sidebar');
const htmlOutput = template.evaluate();
htmlOutput.setTitle('サイドバーだよ');
ui.showSidebar(htmlOutput);
}
上記のコードをコピーしてエディタに貼り付けてください。
data:image/s3,"s3://crabby-images/779c4/779c418fec914417f7582102e08227f7cbc051dd" alt=""
HTMLファイル(sidebar.html)の作成
次に、左上の「+」ボタンから、「HTML」を選択して新しいHTMLファイルを作成してください。
data:image/s3,"s3://crabby-images/a64e4/a64e45567f9161f67bd8a70d2d6e9a9cf3fec339" alt=""
ファイル名は「sidebar.html」としておきましょう。
data:image/s3,"s3://crabby-images/c3f34/c3f34d84af808a51f1363e3d6cfa92b2e1b82f69" alt=""
作成した「sidebar.html」に、以下のコードをコピペしてください。
<!DOCTYPE html>
<html>
<head>
<base target="_top">
<link rel="stylesheet" href="https://ssl.gstatic.com/docs/script/css/add-ons1.css">
</head>
<body>
<div class="sidebar branding-below">
<p>▼並べ替えボタン</p>
<div class="block">
<button class="blue" onclick="sortByEntryTime()">出勤順に並べ替え</button>
<button class="blue" onclick="sortByExitTime()">退勤順に並べ替え</button>
</div>
<div class="block">
<span id="footnote"></span>
</div>
</div>
<div class="sidebar bottom">
<span class="gray" id="bottom-text">並べ替えプログラム by GASおじさん</span>
</div>
<?!= HtmlService.createHtmlOutputFromFile('sidebar.js').getContent(); ?>
</body>
</html>
上記のコードをコピーしてエディタに貼り付けてください。
data:image/s3,"s3://crabby-images/b0cc2/b0cc2c7e405f84e91b8f6a30968b98b8b527387e" alt=""
JavaScriptファイル(sidebar.js.html)の作成
次に、左上の「+」ボタンから、「HTML」を選択して新しいHTMLファイルを作成してください。
ファイル名は「sidebar.js」としておきます。
data:image/s3,"s3://crabby-images/167b4/167b4347d0682ba93f8803c7e8ade2d38e497101" alt=""
※ファイル名を確定すると「sidebar.js.html」となりますが気にせずそのまま進めて構いません。
作成した「sidebar.js.html」に、以下のコードをコピペしてください。
<script>
function updateFootNote() {
document.getElementById("footnote").innerHTML = '';
}
function sortByEntryTime(){
document.getElementById("footnote").innerHTML = 'スクリプト実行中...';
google.script.run.withSuccessHandler(updateFootNote).sortByEntryTime();
}
function sortByExitTime(){
document.getElementById("footnote").innerHTML = 'スクリプト実行中...';
google.script.run.withSuccessHandler(updateFootNote).sortByExitTime();
}
</script>
上記のコードをコピーしてエディタに貼り付けてください。
data:image/s3,"s3://crabby-images/4c9b6/4c9b61b694ca969f6d286b0764c102b174ba0908" alt=""
openSidebar関数を実行
コードのコピペができたら、ファイルを保存して、サイドバー.gsのopenSIdebar関数を実行してください。
data:image/s3,"s3://crabby-images/94165/9416571e48d3904f9c61aaee06afe345a517e54b" alt=""
すると…
data:image/s3,"s3://crabby-images/7daa2/7daa20c3332d140122b7866c418a2dad2e831776" alt=""
スプレッドシート画面にサイドバーが表示されました!
サイドバーの中には、「出勤順に並べ替え」と「退勤順に並べ替え」のボタンがあります。
それぞれをクリックしてみると、sortByEntryTime関数とsortByExitTime関数が実行できることが確認できるかと思います。
コードの解説
今回追加した「サイドバー.gs」「sidebar.html」「sidebar.js.html」それぞれのコードについて解説します。
サイドバー.gs
まずは以下のサイドバー.gsについてです。
function openSidebar() {
const ui = SpreadsheetApp.getUi();
const template = HtmlService.createTemplateFromFile('sidebar');
const htmlOutput = template.evaluate();
htmlOutput.setTitle('サイドバーだよ');
ui.showSidebar(htmlOutput);
}
まず以下のコードでUIオブジェクトを取得します。
const ui = SpreadsheetApp.getUi();
次に「sidebar.html」を読み込むためのコードを記述します。
const template = HtmlService.createTemplateFromFile('sidebar');
const htmlOutput = template.evaluate();
htmlOutput.setTitle('サイドバーだよ');
この際、createTemplateFromFileメソッドに与える引数が、読み込むHTMLファイル名と合致するようにしましょう。また、htmlOutputに対してsetTitleメソッドを使うことで、サイドバーのタイトルを指定することができます。
最後にUIオブジェクトに対して、showSidebarメソッドを使います。その際引数に生成したhtmlOutputを与えます。
ui.showSidebar(htmlOutput);
あらためて、完成形のコードはこちら。
function openSidebar() {
const ui = SpreadsheetApp.getUi();
const template = HtmlService.createTemplateFromFile('sidebar');
const htmlOutput = template.evaluate();
htmlOutput.setTitle('サイドバーだよ');
ui.showSidebar(htmlOutput);
}
sidebar.html
次にsidebar.htmlについてです。
<!DOCTYPE html>
<html>
<head>
<base target="_top">
<link rel="stylesheet" href="https://ssl.gstatic.com/docs/script/css/add-ons1.css">
</head>
<body>
<div class="sidebar branding-below">
<p>▼並べ替えボタン</p>
<div class="block">
<button class="blue" onclick="sortByEntryTime()">出勤順に並べ替え</button>
<button class="blue" onclick="sortByExitTime()">退勤順に並べ替え</button>
</div>
<div class="block">
<span id="footnote"></span>
</div>
</div>
<div class="sidebar bottom">
<span class="gray" id="bottom-text">並べ替えプログラム by GASおじさん</span>
</div>
<?!= HtmlService.createHtmlOutputFromFile('sidebar.js').getContent(); ?>
</body>
</html>
今回特に大事なポイントは、次の1行です。
<?!= HtmlService.createHtmlOutputFromFile('sidebar.js').getContent(); ?>
この1行があることによって、別ファイルの「sidebar.js.html」を読み込むことができます。
また、次のbuttonタグで並べ替えボタンを実装しているのですが、
<button class="blue" onclick="sortByEntryTime()">出勤順に並べ替え</button>
<button class="blue" onclick="sortByExitTime()">退勤順に並べ替え</button>
onclick属性の中に実行したい関数名を記述しています。この関数については、次のsidebar.js.htmlで定義することになります。
sidebar.js.html
最後にsidebar.js.htmlについてです。
<script>
function updateFootNote() {
document.getElementById("footnote").innerHTML = '';
}
function sortByEntryTime(){
document.getElementById("footnote").innerHTML = 'スクリプト実行中...';
google.script.run.withSuccessHandler(updateFootNote).sortByEntryTime();
}
function sortByExitTime(){
document.getElementById("footnote").innerHTML = 'スクリプト実行中...';
google.script.run.withSuccessHandler(updateFootNote).sortByExitTime();
}
</script>
sidebar.htmlで記述した関数は、こちらのファイルで定義することになります。
注意点としては、ここで定義する関数と、サイドバー.gsファイルで定義する関数は別物ということです。
サイドバー.gsにおいても、sortByEntryTime関数とsortByExitTime関数というのを定義していましたが、
サイドバー.gsファイルで定義された関数は、Googleのサーバー内で動くファイルである一方で、sidebar.js.htmlで定義する関数は、ブラウザ上で動く関数です。
2つのファイルは似て非なるものなので、いろいろコードをいじってみて、仕組みを理解していきましょう!
連載目次
- スプレッドシート画面上でGASを実行する方法4選
- スプレッドシートにカスタムメニューを追加する方法
- スプレッドシートにサイドバーを表示する方法(←イマココ)
コメント
サイドバーを作る練習として使用させていただき、つまづくことなく上手くできました。ありがとうございました!
嬉しいコメントありがとうございます!お役に立ててよかったです✨