Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/polidog/nippo
https://github.com/polidog/nippo
esa npm qiita-team slack
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/polidog/nippo
- Owner: polidog
- Created: 2015-11-21T14:09:35.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2017-02-28T13:38:01.000Z (almost 8 years ago)
- Last Synced: 2024-10-01T16:38:15.084Z (3 months ago)
- Topics: esa, npm, qiita-team, slack
- Language: JavaScript
- Size: 692 KB
- Stars: 23
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
nippo
===分報から日報を作り出すためのnpm。
1日分の分報を日報として出力します。input(slack) → 加工 → output(qiita team or esa.io)に出力。
みたいなイメージです。分報?って方はこちらの記事をよんでもらえるとわかるかと思います。
[Slackで簡単に「日報」ならぬ「分報」をチームで実現する3ステップ 〜 Problemが10分で解決するチャットを作ろう](http://c16e.com/1511101558/)v0.2.0現在で対応しているサービスは以下のとおり。
- input
- [slack](https://slack.com/)
- output
- [esa.io](https://esa.io/)
- [qiita team](https://teams.qiita.com/)## 使い方
まずはインストールしましょう。
```
$ npm install nippo
```あとはjsをちょこっと書くだけ
```
var nippo = require("nippo")var config = {
"output": {
"service": "esa",
"team": "your team name",
"token": "your token",
"category": "report/%year%/%month%"
},
"input": {
"service": "slack",
"token": "your token",
"channel": "report"
},
"formatter": {
"service": "default"
}
};nippo(config, 1); // 1を指定することで、1日前の日報を作成します。
// ちなみにこんな事もできます
nippo(config, 1).then(function(outputResponse){
console.log(outputResponse);
});```
### QiitaTeamで使ってみる。
```
var nippo = require("nippo")var config = {
"output": {
"service": "qiitateam",
"team": "hoge", // https://hoge.qiita.com
"token": "your token",
"category": "report/%year%/%month%"
},
"input": {
"service": "slack",
"token": "your token",
"channel": "report"
},
"formatter": {
"service": "default"
}
};nippo(config, 1); // 1を指定することで、1日前の日報を作成します。
// ちなみにこんな事もできます
nippo(config, 1).then(function(outputResponse){
console.log(outputResponse);
});```
## 日報に反映するときのフォーマットを変更する
esa.ioやqiita teamに投稿するドキュメントを加工することも可能です。
まずは適当なディレクトリにフォーマッターを用意します。
```
$ mkdir ./formatter
```次にフォーマッターファイルを用意します。
```
vi ./formatter/my_formatter.jsfunction tsToTimeName(d) {
var hour = ( d.getHours() < 10 ) ? '0' + d.getHours() : d.getHours();
var min = ( d.getMinutes() < 10 ) ? '0' + d.getMinutes() : d.getMinutes();
var sec = ( d.getSeconds() < 10 ) ? '0' + d.getSeconds() : d.getSeconds();
return hour + ":" + min + ":" + sec
}module.exports = function(messages) {
return messages.map(function(message){
var d = message.date;
var text = message.user.name + " 投稿時間 " + tsToTimeName(message.date) + "\n #メッセージ\n\n" + message.messages;
return text;
}).join("\n\n");
}
```最後に、フォーマッターファイルの位置をしていします。
`service`を先ほど作成した`my_formatter.js`にし、`dir`でディレクトリを指定します。
```
var nippo = require("nippo");nippo({
"output": {
"service": "esa",
"team": "polidog",
"token": "access token",
"category": "report/%year%/%month%"
},
"input": {
"service": "slack",
"token": "access token",
"channel": "report"
},
"formatter": {
"service": "my_formatter",
"dir": __dirname + "/formatter"
}
},1);
```これでカスタムのフォーマッターを使うことが出来ます。
## イメージ的なあれ
こんなSlackで投稿したものが
![slack](./screenshot/slack.png)
こんな風にまとめられます。
![esa](./screenshot/esa.png)
![qiita](./screenshot/qiita.png)
## 最後に
コードは糞コードですごめんなさい・・・
テストはこれから頑張って書きます。。