【Google Apps Script】ES6を使ったGoogle Apps Scriptの開発

作成日: 2017-05-03 /

記事を書こうと思った理由

  • ある日、GAS での開発をしていたとき、
    • 自分「レビュー提出しました」
    • 上司「ES6 のほうがわかりやすいから、そっちで書いてみようぜ」
    • 自分「え、GAS って、ES6 対応しているのかな...」
  • こうして、少しググってみて、あまり情報源がないことを知ったため、記事にまとめようと思いました。

準備するもの

  • npm でライブラリをインストールできる環境。
    • Node.js は、ndenv でインストールするのがおすすめ。
  • GAS ファイル。

今回使うプログラムの例

  • 簡単にセルの背景の色を変更する GAS ファイル。
    • 毎日決められた色の中で、ランダムにセルの背景の色を変更する。
ChangeColor.js
class ChangeColor{
    constructor(color){
        this.parent_sheet = SpreadsheetApp.openById(親シートのID);
        this.source_sheet = this.parent_sheet.getSheetByName(子シートの名前);
        this.color = color;
    }

    changeBackgroundColor(){
        let range = this.source_sheet.getRange("A1:A3");
        range.setBackgroundColor(this.color);
    }
}

// GASファイルのトリガーにセットする関数です。
function trigger(){
    let  color_array = ['red', 'blue', 'green'];
    let random_number = [Math.floor(Math.random()*color_array.length)];
    let trigger = new ChangeColor(color_array[random_number]);
    trigger.changeBackgroundColor();
}

JS でクラスがかけるようになったのは、本当に魅力的で、感動です...。 しかし、案の定 GAS ファイルは、ES6 に対応せず、上の書き方だとエラーを起こしてしまいます...。 そこで、上のファイルをクラスを用いた方法で書かれていない JS に変換する必要があります。 今から、それを書いていきます。

ファイル変換環境準備

npm の必要なライブラリのインストール ローカルに作業ディレクトリを作成し、そのなかで、下のコマンドを入力し、必要なライブラリをインストールしてください。

$ npm install --save-dev babel-cli babel-preset-latest browserify babelify gasify

次に、.babelrc という設定ファイルに下の1行を入れます。

$ echo '{ "presets": ["latest"] }' > .babelrc

これで、環境の準備は整いました。

ES6からGASファイルに変換

そして、ファイルを変更。ここを一番に気をつけて欲しく、クラスとトリガーにセットする関数で、ファイルを分けていただきたいです。

ChangeColor.js
export class ChangeColor{
    constructor(color){
        this.parent_sheet = SpreadsheetApp.openById(親シートのID);
        this.source_sheet = this.parent_sheet.getSheetByName(子シートの名前);
        this.color = color;
    }

    changeBackgroundColor(){
        let range = this.source_sheet.getRange("A1:A3");
        range.setBackgroundColor(this.color);
    }
}
trigger.js
// fromのあとには、ChangeColorファイルのパスを書いてください
import {ChangeColor} from './ChangeColor';

global.trigger = function() {
    let color_array = ['red', 'blue', 'green'];
    let random_number = [Math.floor(Math.random()*color_array.length)];
    let trigger = new ChangeColor(color_array[random_number]);
    trigger.changeBackgroundColor();
};

最後に、下のコマンドで、上の ChangeColor.js を変換。

$ browserify -t babelify -p gasify trigger.jsのパス -o 変換後のコードを書き込むファイルへのパス

変換後

trigger.js
var global = this;function trigger() {
}(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
'use strict';

Object.defineProperty(exports, "__esModule", {
    value: true
});

var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

var ChangeColor = exports.ChangeColor = function () {
    function ChangeColor(color) {
        _classCallCheck(this, ChangeColor);

        this.parent_sheet = SpreadsheetApp.openById(親シートのID);
        this.source_sheet = this.parent_sheet.getSheetByName('src');
        this.color = color;
    }

    _createClass(ChangeColor, [{
        key: 'changeBackgroundColor',
        value: function changeBackgroundColor() {
            var range = this.source_sheet.getRange("A1:A3");
            range.setBackgroundColor(this.color);
        }
    }]);

    return ChangeColor;
}();

},{}],2:[function(require,module,exports){
(function (global){
'use strict';

var _ChangeColor = require('./ChangeColor');

global.trigger = function () {
    var color_array = ['red', 'blue', 'green'];
    var random_number = [Math.floor(Math.random() * color_array.length)];
    var trigger = new _ChangeColor.ChangeColor(color_array[random_number]);
    trigger.changeBackgroundColor();
};

}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
},{"./ChangeColor":1}]},{},[2]);

これで、es6 で書いたファイルでも、GAS で読み込んでくれるファイルの完成です。上の変換後のファイルを GAS ファイルにペーストし、trigger 関数を動かせば、セルの色は、変化していきます。

HAPPY GAS LIFE