Git Product home page Git Product logo

thelounge-plugin-shortcuts's Introduction

thelounge-plugin-shortcuts build status npm downloads npm versions licence mit

Simple plugin for the irc client thelounge that allows you to register shortcuts/aliases for commands

Installation

  • If you have installed thelounge via NPM/Yarn:

    thelounge install thelounge-plugin-shortcuts

  • If you have installed thelounge via source:

    node index.js install thelounge-plugin-shortcuts

Usage

Adding a shortcut: /shortcut add <from> <to>, for example /shortcut add j /join.

Note: you do need to add a / to the target, not doing so will just write join in the chat window

Removing a shortcut: /shortcut remove <name>, for example /shortcut remove j.

You may choose to have one shortcut run multiple commands. To do so, just add a second shortcut via /shortcut addnext <from> <to>.

Listing all shortcuts: /shortcut list.

Shortcuts are saved to THELOUNGE_HOME/packages/shortcuts.json

Placeholders

thelounge-plugin-shortcuts supports multiple placeholders:

  • {currentChannel} will be replaced with the name of the channel where the shortcut was executed in
  • {0}, {1}, {n} will be replaced with the first, second or nth argument that was entered after the shortcut
  • {args} will be replaced with all arguments which were entered after the shortcut

Examples

/shortcut add shrug ¯\_(ツ)_/¯ -> /shrug will send ¯_(ツ)_/¯
/shortcut add j /join {args} -> /j is an alias to /join
/shortcut add jc /join #my-cool-channel -> /jc will join a bunch of channels
/shortcut add akick /msg chanserv akick {currentChannel} add {0} !T {1} -> will akick SomeUser for 20 minutes

Development

Currently thelounge doesn't offer a way to install packages from source without npm, thats why you have to do it manually.

The easiest way is installing thelounge locally and adding this plugin as a new package in the THELOUNGE_HOME/packages dir. For that you need to have a package.json in that packages dir that looks kinda like this:

{
    "private": true,
    "description": "Packages for The Lounge. All packages in node_modules directory will be automatically loaded.",
    "dependencies": {
        "thelounge-theme-mininapse": "2.0.15",
        "thelounge-plugin-shortcuts": "1.0.1",
        "thelounge-plugin-giphy": "1.0.1"
     }
}

the important thing in the name here.

You then need to create a folder with that name in the node_modules sub dir. We then need to place our index.js and package.json in that dir. You can either do that manually by just copy pasting it, but that would involve copy pasting it for every change. I would recommend symlinking the files from the project into the packages folder, kinda like this:

ln package.json ../thelounge-home/packages/node_modules/thelounge-plugin-shortcuts/package.json
ln index.js ../thelounge-home/packages/node_modules/thelounge-plugin-shortcuts/index.js

You can then just edit and commit the files in the project dir and restart thelounge on every change you do and the changes will be picked up.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.