kintone Webhook × Zapierでレコード内文章を簡単に翻訳&表示してみよう!
はじめに
こんにちは。kintoneをより良くする武井です。
これからの時代はどなた様もダイバーシティ経営が大事になって来ますね。
多言語対応しているkintoneは時代のトレンドに沿っているといえます。
ですが、kintoneにはまだ自動翻訳機能まではありません。
そこで今回は、レコード内にある文章に対して「半自動翻訳」のような機能をつける方法を紹介したいと思います。
完成形サンプル
今回のカスタマイズでできること
- ステータスを変更することで、議事録の内容を別のフィールドへ日英および日中翻訳して表示します。
- 議事録の内容を変更した場合、翻訳内容を空にし、ステータスを未処理状態に戻します。
システム概要図
今回は上図のようにkintoneのWebhook機能を利用します。
Zapierにレコードデータを送信後データを翻訳し、Zapierの機能によってkintoneのレコードを翻訳後のデータに更新します。
準備
kintoneアプリおよびZapierの準備が必要です。
kintoneアプリ
-
以下のフィールドをもつ議事録アプリを作成します。
フィールドコード フィールドタイプ 日付 日付 議題 文字列(1行) 参加者 ユーザー選択 議事録 文字列(複数行) 英語 文字列(複数行) 中国語 文字列(複数行) -
プロセス管理を有効にします。
ステータスは「未処理・翻訳開始・翻訳完了」の3つを作成します。
プロセスは以下のとおり設定します。 -
「アプリの設定 > JavaScript / CSSでカスタマイズ > PC用のJavaScriptファイル」にサンプルコードを設定します。
サンプルコードは、後述の サンプルコード をお手元のエディタにコピーしてください。 ファイル名はtranslation.js
、文字コードをUTF-8
で保存します。
ファイル名は任意ですが、ファイルの拡張子はjs
にしてください。
Zapier
今回はkintoneとのデータ連携を手軽に実現できるZapierを使用します。
なお、今回のカスタマイズでは、3ステップ以上のzap(処理)を作成するため、Zapierのプレミアムプラン契約が必要となります。
-
Zapier にアクセスします。
-
画面上部の「MAKE A ZAP」を選択します。
-
下図のように入力フォームに「webhooks」と入力し、「Webhooks by Zapier」を選択します。
-
「Catch Hook」を選択し、「Continue」を選択します。
-
「Pick Off a Child Key」の入力フォームに次の内容を貼り付け、「Continue」を選択します。
レコードの「議事録」フィールドのデータを取得するためのJSONスキーマとなります。1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
{ "$schema": "http://json-schema.org/draft-04/schema#", "type": "object", "properties": { "record": { "type": "object", "properties": { "議事録": { "type": "object", "properties": { "value": { "type": "string" } } } } } } }
-
下図のように表示されるURLをコピーします。
-
kintoneの議事録アプリに戻り「アプリの設定 > Webhook」からWebhookを追加します。
下図のように設定し、「保存」を選択し、アプリを更新します。
コピー&ペーストする際https://
が重複しないように注意してください。
-
Zapierに戻り「OK, I did this」を選択します。
-
kintoneで適当なレコードを作成し、レコードのステータスを「翻訳開始」にします。
ここは、8. の手順からすばやく行ってください。 -
成功すると下図のような画面が表示されます。ここで「Continue」を選択します。
-
画面左の「+」ボタンを押し、「Filter」を選択します。
-
「Only Continue If...」が選択されているので「Save + Continue」を選択します。
-
下図のように設定し「Continue」を選択します。
-
「Test Filter」を選択後、「Continue」を選択します。
-
初期画面に戻るので、入力フォームに「translate」と入力し、「Translate by Zapier」を選択します。
-
「Translate Text」を選択し、「Save + Continue」を選択します。
-
各項目を下図のように入力し、「Continue」を選択後、「Create & Continue」を選択します。
-
「Add a step」を選択します。
-
初期画面に戻るので、再び入力フォームに「translate」と入力し、「Translate by Zapier」を選択します。
-
「Translate Text」を選択し、「Save + Continue」を選択します。
-
各項目を下図のように入力し、「Continue」を選択後、「Create & Continue」を選択します。
-
「Add a step」を選択します。
-
初期画面に戻るので、入力フォームに「kintone」と入力し、「kintone」選択します。
-
「Update Record By Record ID」を選択し「Save + Continue」を選択します。
-
kintoneアカウントを選択して「Save + Continue」を選択します。
登録しているアカウントがない場合は、新規に登録してください。
-
各項目を下図のように入力し、「Continue」を選択後、「Create & Continue」を選択します。
-
「Add a step」を選択します。
-
初期画面に戻るので、再び入力フォームに「kintone」と入力し、「kintone」選択します。
-
「Update Status」を選択し「Save + Continue」を選択します。
-
kintoneアカウントを選択して「Save + Continue」を選択します。
-
各項目を下図のように設定し「Continue」を選択し、「Skip test & Continue」を選択します。
その後、「Continue」を選択します。 -
下図のように適当なzap名称を入力し、zapをオンにします。
これでZapierの設定は完了です。
サンプルコード
以下のコードを参照し、translation.js
を作成します。
|
|
プログラム解説
上記のサンプルコードを部分的に解説していきます。
|
|
中国語と英語のフィールドは翻訳結果の表示用のためdisabled(入力不可)にしています。
|
|
編集保存した際に議事録の内容が変更された場合は、翻訳結果をブランクに戻しています。
全件取得関数(fetchRecords関数)につきましては
offsetの制限値を考慮したkintoneのレコード一括取得について
を参照してください。
|
|
議事録の内容をブランクにする際、ステータスについても「未処理」状態に戻します。
なお、上記のイベントと同時に行うとレコード更新エラーが出てしまうため、イベントを分けて書いています。
拡張
さらに本プログラムを拡張すれば、以下のようなことも可能です。
- 英語・中国語以外の言語に翻訳する。
- レコードを保存した瞬間に翻訳された文章を表示する。 Microsoft Translator Text API などを使用してコードを書く必要があります。
終わりに
いかがでしたでしょうか。
Webhook機能の便利さの一端を見ることができたように思います。
翻訳の精度がもう少し上がるとさらに使い勝手も高まりそうですが、ここはAI技術の進歩等により時間の問題かと思われます。
皆様のすばらしいkintoneカスタマイズライフの一助となれたら幸いです。