Package Exports
- @doist/todoist-api-typescript
- @doist/todoist-api-typescript/dist/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@doist/todoist-api-typescript) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Todoist API TypeScript Client
This is the official TypeScript API client for the Todoist REST API.
Installation
npm install @doist/todoist-api-typescriptUsage
An example of initializing the API client and fetching a user's tasks:
import { TodoistApi } from '@doist/todoist-api-typescript'
const api = new TodoistApi('YOURTOKEN')
api.getTasks()
    .then((tasks) => console.log(tasks))
    .catch((error) => console.log(error))Documentation
For more detailed reference documentation, have a look at the Todoist API v1 Documentation.
Migration Guide
If you're migrating from an older version of the Todoist API (v9), please refer to the official migration guide for detailed information about the changes and breaking updates.
Key changes in v1 include:
- Updated endpoint structure
- New pagination system
- Unified error response format
- Object renames (e.g., items → tasks, notes → comments)
- URL renames and endpoint signature changes
Development and Testing
Instead of having an example app in the repository to assist development and testing, we have included ts-node as a dev dependency. This allows us to have a scratch file locally that can import and utilize the API while developing or reviewing pull requests without having to manage a separate app project.
- npm install
- Add a file named scratch.tsin thesrcfolder.
- Configure your IDE to run the scratch file with ts-node(instructions for VSCode, WebStorm), or you can optionally run ts-node in a terminal using instructions here (npx ts-node ./src/scratch.tsshould be enough).
- Import and call the relevant modules and run the scratch file.
Example scratch.ts file:
/* eslint-disable no-console */
import { TodoistApi } from './TodoistApi'
const token = 'YOURTOKEN'
const api = new TodoistApi(token)
api.getProjects()
    .then((projects) => {
        console.log(projects)
    })
    .catch((error) => console.error(error))Releases
A new version is published to the NPM Registry whenever a new release on GitHub is created.
The version in both package.json and package-lock.json is updated with:
npm version <major|minor|patch> --no-git-tag-version
Once these changes have been pushed and merged, a release should be created, and a GitHub Action will automatically perform all the necessary steps and will release the version number that's specified inside the package.json file's version field.
Users of the API client can then update to this version in their package.json.
Feedback
Any feedback, such as bugs, questions, comments, etc. can be reported as Issues in this repository, and will be handled by us in Todoist.
Contributions
We would also love contributions in the form of Pull requests in this repository.