2019-09-05 13:08:42 +02:00
|
|
|
# @mojoio/slack
|
|
|
|
slack api abstraction for the mojo.io ecosystem
|
2018-09-15 22:23:05 +02:00
|
|
|
|
2019-09-05 13:08:42 +02:00
|
|
|
## Availabililty and Links
|
|
|
|
* [npmjs.org (npm package)](https://www.npmjs.com/package/@mojoio/slack)
|
|
|
|
* [gitlab.com (source)](https://gitlab.com/mojoio/slack)
|
|
|
|
* [github.com (source mirror)](https://github.com/mojoio/slack)
|
|
|
|
* [docs (typedoc)](https://mojoio.gitlab.io/slack/)
|
2017-09-14 07:20:26 +02:00
|
|
|
|
|
|
|
## Status for master
|
2019-09-05 13:08:42 +02:00
|
|
|
[data:image/s3,"s3://crabby-images/f8909/f8909afbb781254e93e02495c80ac5067844e2d1" alt="build status"](https://gitlab.com/mojoio/slack/commits/master)
|
|
|
|
[data:image/s3,"s3://crabby-images/d53fc/d53fc571726b2fa002ddbf8a3ef0aaf599def2b6" alt="coverage report"](https://gitlab.com/mojoio/slack/commits/master)
|
|
|
|
[data:image/s3,"s3://crabby-images/077be/077be8cb80492a3794197b25455a427864ac0a7e" alt="npm downloads per month"](https://www.npmjs.com/package/@mojoio/slack)
|
|
|
|
[data:image/s3,"s3://crabby-images/9ebc5/9ebc520255dbd6c8ab4125fd2e18cb4897b0a5b3" alt="Known Vulnerabilities"](https://snyk.io/test/npm/@mojoio/slack)
|
|
|
|
[data:image/s3,"s3://crabby-images/07f85/07f857bf66bf5c9cc877156a7ef5ea84cd18397f" alt="TypeScript"](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
|
|
|
[data:image/s3,"s3://crabby-images/6df3f/6df3f8616ef4a84add4f6a28c84f5582348b03fb" alt="node"](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
|
|
|
[data:image/s3,"s3://crabby-images/82e80/82e80c3a644c4f5bb451b9674dbcff5360402a51" alt="JavaScript Style Guide"](https://prettier.io/)
|
2017-09-14 07:20:26 +02:00
|
|
|
|
|
|
|
## Usage
|
2018-09-15 22:23:05 +02:00
|
|
|
|
2017-09-14 07:20:26 +02:00
|
|
|
Use TypeScript for best in class instellisense.
|
|
|
|
|
2018-01-10 21:45:25 +01:00
|
|
|
```javascript
|
|
|
|
import * as slackme from 'slackme'
|
|
|
|
|
|
|
|
// First setup the hook
|
|
|
|
const mySlackme = new Slackme('https://some.slack.webhook.url')
|
|
|
|
mySlackme.sendMessage:{{
|
|
|
|
// MessageOptions here
|
|
|
|
}, 'myAwesomeChannel'}
|
|
|
|
```
|
|
|
|
|
2018-01-10 22:17:30 +01:00
|
|
|
The message interface follows [Slack's docs (click here)](https://api.slack.com/docs/message-formatting) and looks like this:
|
2018-01-10 21:45:25 +01:00
|
|
|
|
|
|
|
```javascript
|
|
|
|
interface IAttachmentField {
|
|
|
|
title: string
|
|
|
|
value: string
|
|
|
|
short?: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
interface IMessageOptions {
|
|
|
|
/**
|
|
|
|
* "Required plain-text summary of the attachment."
|
|
|
|
*/
|
|
|
|
fallback?: string,
|
|
|
|
/**
|
|
|
|
* a side color
|
|
|
|
*/
|
|
|
|
color?: string,
|
|
|
|
/**
|
|
|
|
* a message to show above
|
|
|
|
*/
|
|
|
|
pretext?: string,
|
|
|
|
/**
|
|
|
|
* author name of the attachment
|
|
|
|
*/
|
|
|
|
author_name?: string,
|
|
|
|
/**
|
|
|
|
* a link to the author
|
|
|
|
*/
|
|
|
|
author_link?: string,
|
|
|
|
/**
|
|
|
|
* a string to the author
|
|
|
|
*/
|
|
|
|
author_icon?: string,
|
|
|
|
/**
|
|
|
|
* a title for the attachment
|
|
|
|
*/
|
|
|
|
title?: string,
|
|
|
|
/**
|
|
|
|
* a link for the title
|
|
|
|
*/
|
|
|
|
title_link?: string,
|
|
|
|
/**
|
|
|
|
* the main text of the message
|
|
|
|
*/
|
|
|
|
text?: string,
|
|
|
|
fields?: IAttachmentField[],
|
|
|
|
image_url?: string,
|
|
|
|
thumb_url?: string,
|
|
|
|
footer?: string,
|
|
|
|
footer_icon?: string,
|
|
|
|
/**
|
|
|
|
* timestamp as epoch time
|
|
|
|
*/
|
|
|
|
ts?: number
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Alternatively, there is the option of specifying a SlackMessage class
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
const mySlackMessage = new SlackMessage({ /* message options here } */, mySlackme)
|
|
|
|
mySlackMessage.title = 'new Title' // modify message options
|
|
|
|
mySlackMessage.sendToRoom('general')
|
|
|
|
mySlackMessage.title = 'another Title'
|
|
|
|
mySlackMessage.sendToRoom('anotherroom')
|
|
|
|
```
|
|
|
|
|
2019-09-05 13:08:42 +02:00
|
|
|
For further information read the linked docs at the top of this readme.
|
2017-09-14 07:20:26 +02:00
|
|
|
|
|
|
|
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
2019-09-05 13:09:13 +02:00
|
|
|
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
|
2017-09-14 07:20:26 +02:00
|
|
|
|
2019-09-05 13:09:13 +02:00
|
|
|
[data:image/s3,"s3://crabby-images/4b3c1/4b3c1c488eac1fa44843cd245bf0fb9e34225791" alt="repo-footer"](https://maintainedby.lossless.com)
|