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 🙏

© 2024 – Pkg Stats / Ryan Hefner

@swissquote/crafty-preset-typescript

v1.27.0

Published

<table> <tr><th>Compatible Runners</th><td>

Downloads

697

Readme

Provides ESLint, with full configuration for TypeScript. Based on the same configuration we use in JavaScript.

[TOC]

Description

Microsoft presents TypeScript as "JavaScript that scales". TypeScript is a superset of JavaScript that allows you to type your code. Not everything needs to have a type as the tool is powerful enough to infer most of the types.

TypeScript has types but it also supports the ESNext Specification.

Features

TypeScript being a superset of JavaScript, features supported by our Babel preset apply here.

Or you can check out the TypeScript specific features

Linting

Like any language, TypeScript has best practices and practices that you shouldn't do. With the help of ESLint we check the code for common mistakes and formatting errors.

Read more

Installation

npm install @swissquote/crafty-preset-typescript --save
module.exports = {
  presets: [
    "@swissquote/crafty-preset-typescript",
    "@swissquote/crafty-runner-webpack", // optional
  ],
  js: {
    app: {
      runner: "webpack", // webpack (optional if you have a single runner defined)
      source: "js/app.ts"
    }
  }
};

Usage with Webpack

You have to configure TypeScript with the tsconfig.json file that you put at the root of the project.

Some options can't be auto-configured through the loaders / plugins so that's why you have to do it yourself. Moreover, the integration with your IDE is simplified if you have a complete tsconfig.json in your project.

Usage with Jest

If you include both crafty-preset-typescript and crafty-preset-jest. When running your tests with crafty test this preset will be use to convert all .ts, .tsx, .mts, and .cts files (source and test files)

Type definition files

TypeScript is also able to understand Types on libraries written in pure JavaScript this is done through types definition files.

Some packages come with their own definitions, for the others there are two ways to consume these files.

  1. Use @types scoped packages from NPM
  2. Create your own *.d.ts file

Read more

Getting Started

We have a user guide to get started with TypeScript in your project

Follow the guide

crafty jsLint

Leveraging ESLint, we add configuration to lint TypeScript. You can use that using the same command as for JavaScript.

crafty jsLint src/**

If you pass the --fix flag it will fix all the errors it can and write them directly to the source file.