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

yatts-typescript

v1.1.1

Published

Keep your typescript version synchronized with a patched version that exposes internal definitions and some private methods for type checking.

Downloads

13

Readme

yatts-typescript

Keep your typescript version synchronized with a patched version that exposes internal definitions and some private methods for type checking.

How does it work?

When you run pnpm yatts-typescript-sync, it will look for your installed version of typescript, make a copy in its own location, apply the patches and re-export the patched version. So you can import yatts-typescript and enjoy your patched version of typescript while keeping your original version intact.

What does it add/remove?

  1. Removes all @internal tags which allows you to access internal types, classes, properties and methods with their declarations.

  2. Export some very useful private methods from the TypeChecker:

    function isTypeSubtypeOf(source: Type, target: Type): boolean;
    function isTypeIdenticalTo(source: Type, target: Type): boolean;
    function isTypeDerivedFrom(source: Type, target: Type): boolean;
    function isTypeAssignableTo(source: Type, target: Type): boolean;
    function isTypeComparableTo(source: Type, target: Type): boolean;
    function areTypesComparable(source: Type, target: Type): boolean;

Installation

pnpm add typescript yatts-typescript

Keep yatts-typescript in sync with each installation/update of typescript

Add an postinstall or prepare field in your package.json with pnpm yatts-typescript-sync in it.

{
  "postinstall": "pnpm yatts-typescript-sync"
}

Usage

import ts from 'yatts-typescript';

// Use ts as usual.

Programmatic API

import { patch } from 'yatts-typescript/patch';

const { error, success, modulePath } = patch(options);

Options

  • typescriptModuleId: string | undefined - Default to typescript.
  • outputDirectory: string | undefined - Default to node_modules/yatts-typescript/lib.
  • patchRules: [PatchRule, ...PatchRule[]] | undefined - Default to undefined.
  • additionalPatchRules: PatchRule[] | undefined - Default to undefined.

Alternatives

yatts-typescript is a combination of the alternatives listed below. But instead of maintaining an up-to-date build of typescript we use your locally installed version.

Remove @internal tags

  • byots Bring your own TypeScript with more internal definitions
  • ts-expose-internals Expose TypeScript internal types by simply adding a development dependency

Expose TypeChecker methods

Remove @internal tags and expose TypeChecker methods

  • unleashed-typescript TypeScript with exposed internal definitions and some private methods for type checking.

Scaffolded with @skarab/skaffold