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
これで、環境の準備は整いました。
そして、ファイルを変更。ここを一番に気をつけて欲しく、クラスとトリガーにセットする関数で、ファイルを分けていただきたいです。
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);
}
}
// 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 変換後のコードを書き込むファイルへのパス
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