Go to file
erroneousboat ceb13292ac Merge branch 'v0.3.0'
* v0.3.0: (25 commits)
  Update readme
  Update readme and reset defaults
  Fix MarkAsRead
  Make search more robust
  Remove RankFind
  Start with improved search
  Implement theming for several components
  Start with theming functionality
  Start with adding colors for messages
  Fix notification for channels
  Fix input component overflow runewidth > 1
  Refactor to get service reference out of components
  Add support for double width runes
  Fix Chat component border labels
  Speed up Channels component
  Add profiling endpoints
  Add overflow functionality Input component
  Update Debug component
  Update Debug component
  Refactor to create more loose coupling
  ...
2017-12-22 14:23:42 +01:00
components Merge branch 'improved-search' into v0.3.0 2017-12-17 14:31:58 +01:00
config Update readme and reset defaults 2017-12-22 13:48:36 +01:00
context Start with theming functionality 2017-12-16 22:54:00 +01:00
handlers Fix MarkAsRead 2017-12-18 21:53:27 +01:00
service Fix MarkAsRead 2017-12-18 21:53:27 +01:00
vendor Start with improved search 2017-12-17 13:48:39 +01:00
views Implement theming for several components 2017-12-17 12:23:55 +01:00
.gitignore Update .gitignore to add vendor folder to project 2017-08-26 10:50:39 +02:00
LICENSE Make project public 2016-10-02 16:08:59 +02:00
main.go Update readme and reset defaults 2017-12-22 13:48:36 +01:00
Makefile Move authTest before creation of RTM 2016-10-21 14:05:36 +02:00
README.md Update readme 2017-12-22 14:17:03 +01:00
screenshot.png Update screenshot 2017-07-30 15:33:18 +02:00

Slack-Term

A Slack client for your terminal.

Screenshot

Installation

Binary installation

Download a compatible binary for your system. For convenience, place slack-term in a directory where you can access it from the command line. Usually this is /usr/local/bin.

$ mv slack-term /usr/local/bin

Via Go

If you want you can also get slack-term via Go:

$ go get -u github.com/erroneousboat/slack-term

Setup

  1. Get a slack token, click here

  2. Create a slack-term.json file, place it in your home directory. Below is an an example file, you can leave out the OPTIONAL parts, you are only required to specify a slack_token. Remember that your file should be a valid json file so don't forget to remove the comments.

{
    "slack_token": "yourslacktokenhere",

    // OPTIONAL: set the width of the sidebar (between 1 and 11), default is 1
    "sidebar_width": 3,

    // OPTIONAL: define custom key mappings, defaults are:
    "key_map": {
        "command": {
            "i": "mode-insert",
            "k": "channel-up",
            "j": "channel-down",
            "g": "channel-top",
            "G": "channel-bottom",
            "<previous>": "chat-up",
            "C-b": "chat-up",
            "C-u": "chat-up",
            "<next>": "chat-down",
            "C-f": "chat-down",
            "C-d": "chat-down",
            "n": "channel-search-next",
            "N": "channel-search-previous",
            "q": "quit",
            "<f1>": "help"
        },
        "insert": {
            "<left>": "cursor-left",
            "<right>": "cursor-right",
            "<enter>": "send",
            "<escape>": "mode-command",
            "<backspace>": "backspace",
            "C-8": "backspace",
            "<delete>": "delete",
            "<space>": "space"
        },
        "search": {
            "<left>": "cursor-left",
            "<right>": "cursor-right",
            "<escape>": "clear-input",
            "<enter>": "clear-input",
            "<backspace>": "backspace",
            "C-8": "backspace",
            "<delete>": "delete",
            "<space>": "space"
        }
    },

    // OPTIONAL: override the default theme (see wiki for more information),
    // defaults are:
    "theme": {
        "view": {
            "fg": "white",
            "bg": "default",
            "border_fg": "white",
            "border_bg": "white",
            "par_fg": "white",
            "par_label_fg": "white"
        },
        "channel": {
            "prefix": "",
            "icon": "",
            "text": ""
        },
        "message": {
            "time": "",
            "name": "",
            "text": ""
        }
    }
}

Usage

When everything is setup correctly you can run slack-term with the following command:

$ slack-term

You can also specify the location of the config file, this will give you the possibility to run several instances of slack-term with different accounts.

$ slack-term -config [path-to-config-file]

Default Key Mapping

Below are the default key-mapping for slack-term, you can change them in your slack-term.json file.

mode key action
command i insert mode
command / search mode
command k move channel cursor up
command j move channel cursor down
command g move channel cursor top
command G move channel cursor bottom
command pg-up scroll chat pane up
command ctrl-b scroll chat pane up
command ctrl-u scroll chat pane up
command pg-down scroll chat pane down
command ctrl-f scroll chat pane down
command ctrl-d scroll chat pane down
command n next search match
command N previous search match
command q quit
command f1 help
insert left move input cursor left
insert right move input cursor right
insert enter send message
insert esc command mode
search esc command mode
search enter command mode