npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

tw-beta

v0.2.0

Published

Teamwork Projects CLI and git integration.

Downloads

3

Readme

Teamwork CLI and API Interface

This is the home of the Teamwork CLI tool source and a Javascript API interface.

Getting started

tw

To get started with tw, you must have Node.js installed on your machine the install tw via npm:

$ npm install -g tw-beta

Once tw is installed, you must now log in and pick your installation:

$ tw login
Email: <email>
Password: *******
Successfully logged in to <installation>. Welcome back John.

Done! You're all setup to integrate and automate your Teamwork Projects workflow into the command line.

Teamwork API

tw also doubles as a promise based Teamwork API interface for Node. To get started, simple require tw:

var tw = require("tw");

tw.login("<username>", "<passwor>", "<installation>").then(function(api) {
    return [api, api.getProjects()]; 
}).spread(function(api, projects) {
    var sampleProject = projects[0];

    return api.getLogs(sampleProjects);
}).then(function(timeLogs) {
    // ... 
});

Commands

tw has a plethora of commands to help your day to day usage of Teamwork Projects more integrated into your CLI workflow. Teamwork CLI tool was loosely inspired by git in

tw-projects, tw-tasklists, tw-tasks

These commands let you select your current project, tasklist or tasks. The current selection is used when you omit any project, tasklist or task in your commands.

  • -l, --list - Display the items in a static list instead of an interactive selection.

For example, if we have select a project with tw projects:

$ tw projects 
Projects: [#48792] API

Now, when we attempt to log time to a project, the current project is selected because we omitted the [project]:

$ tw log --project 1h -m "Chatting with Mike to smooth over some API specs."

This works wherever you see a [task], [tasklist] or [project]. If they are omitted, the current item is selected.

tw-status

View the current state of the tool. This command is similiar to git-status, it allows you get to grips with whos logged in and what tasks, projects and tasklists they're currently working on (i.e. current items).

$ tw status 

tw-log [task] <duration>

Log time to a task or project. This is an incredibly useful tool for quickly logging time on what task your currently working on. It's powerful with flexible options such as --fill, which will grab the time since your last log and log it to a task.

  • -p, --project [project] - Log the time to a project instead of a task.
  • -m, --message <message> - Log time with a message. If this option is omitted, you will be prompted for a message.
  • -e, --editor - Open your $EDITOR to write the message.
  • --silent - Log time without a message.
  • -F, --fill - Log the time since your last time log today (from 8:00am).
  • -t, --time <time> - Specify the start time of the log. Defaults to now - duration.
  • -d, --date <date> - Specify the date of the duration. Defaults to today.

Examples: Log two hours to task #214974:

$ tw log #214974 2h -m "Old code cleaned up."
Logged 2 hours to [#214974] Clean up old code.

Log the time since your last time log today (which was at 3:40pm, it's not 4:30pm) to the current project:

$ tw log --fill --project
Message: Meeting with Peter.
Logged 50 minutes to [#1421] Web Event.

Whoops, you forgot to log your time debugging yesterday:

$ tw log #172836 1h --date yesterday --time 16:00
Message: Debugging issue with Chat app.
Logged 1 hour to [#172836] Chat app not working on Linux.

Units

task

A task can either be in the form of an ID or URL. For example #2684930 and http://mycompany.teamwork.com/tasks/2684930 are equivelant and both target the task with ID 2684930.

duration

A duration is a length of time with a minimum unit of one minute. It's pretty simple notation where h denotes the hour and m denotes the minute in that order. Either one can be omitted but at least one must be present. Examples: 5m, 1h, 8h24m

time

A time unit is like you would see on a 24 hour digital clock, with a colon separating the hour and minute. Examples: 13:20 is 1:30pm, 09:15 is 9:15am.

date

A date unit is in the form of dd/mm/yyyy. Examples: 31/03/1994 is 31st March 1994. Other date strings accepted are yesterday and today.

Git Integration

Packaged with tw is git integration and to install, it's just one command. Navigate to your git repository and run git-install-hooks.

$ cd my-git-repository/
$ tw install-hooks
Copying hooks into the current git repository.
> commit-msg
$ chmod 0755 .git/hooks/commit-msg
> post-commit
$ chmod 0755 .git/hooks/post-commit

Git integration works by looking at your commit messages and allows you to some cool interactions with Teamwork Projects. It will expand task IDs right in the commit to give some context and updates Teamwork accordingly. So far, you can log time but updating progress and closing tasks is in the pipeline. Some example commit messages:

Log 2h30m to #12312421

Completed 30m to http://digitalcrew.teamwork.com/tasks/472997.