JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 344904
  • Score
    100M100P100Q170987F
  • License ISC

A library of composable functions for the type-level! Transform your TypeScript types in any way you want using functions you already know.

Package Exports

  • hotscript
  • hotscript/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 (hotscript) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Higher-Order TypeScript (HOTScript)

A library of composable functions for the type level!

Transform your TypeScript types in any way you want using functions you already know.

image

Features

  • Type-level higher-order functions (Tuples.Map, Tuples.Filter, Objects.MapValues, etc).
  • Type-level pattern matching with Match.
  • Performant math operations (Numbers.Add, Numbers.Sub, Numbers.Mul, Numbers.Div, etc).
  • Custom "lambda" functions.

🚧 work in progress 🚧

Installation

You can find HotScript on npm:

npm install -D hotscript

HotScript is a work-in-progress library, so expect breaking changes in its API.

Examples

Transforming a list

Run this as a TypeScript Playground

import { Pipe, Tuples, Strings, Numbers } from "hotscript";

type res1 = Pipe<
  //  ^? 62
  [1, 2, 3, 4],
  [
    Tuples.Map<Numbers.Add<3>>,       // [4, 5, 6, 7]
    Tuples.Join<".">,                 // "4.5.6.7"
    Strings.Split<".">,               // ["4", "5", "6", "7"]
    Tuples.Map<Strings.Prepend<"1">>, // ["14", "15", "16", "17"]
    Tuples.Map<Strings.ToNumber>,     // [14, 15, 16, 17]
    Tuples.Sum                        // 62
  ]
>;

Defining a first-class function

Run this as a TypeScript Playground

import { Call, Fn, Tuples } from "hotscript";

// This is a type-level "lambda"!
interface Duplicate extends Fn {
  return: [this["arg0"], this["arg0"]];
}

type result1 = Call<Tuples.Map<Duplicate>, [1, 2, 3, 4]>;
//     ^? [[1, 1], [2, 2], [3, 3], [4, 4]]

type result2 = Call<Tuples.FlatMap<Duplicate>, [1, 2, 3, 4]>;
//     ^? [1, 1, 2, 2, 3, 3, 4, 4]

Transforming an object type

Run this as a TypeScript Playground

import { Pipe, Objects, Booleans } from "hotscript";

// Let's compose some functions to transform an object type:
type ToAPIPayload<T> = Pipe<
  T,
  [
    Objects.OmitBy<Booleans.Equals<symbol>>,
    Objects.Assign<{ metadata: { newUser: true } }>,
    Objects.SnakeCaseDeep,
    Objects.Assign<{ id: string }>
  ]
>;
type T = ToAPIPayload<{
  id: symbol;
  firstName: string;
  lastName: string;
}>;
// Returns:
type T = {
  id: string;
  metadata: { new_user: true };
  first_name: string;
  last_name: string;
};

Parsing a route path

Run this as a TypeScript Playground

https://user-images.githubusercontent.com/2315749/222081717-96217cd2-ac89-4e06-a942-17fbda717cd2.mp4

import { Pipe, Objects, Strings, ComposeLeft, Tuples, Match } from "hotscript";

type res5 = Pipe<
  //    ^? { id: string, index: number }
  "/users/<id:string>/posts/<index:number>",
  [
    Strings.Split<"/">,
    Tuples.Filter<Strings.StartsWith<"<">>,
    Tuples.Map<ComposeLeft<[Strings.Trim<"<" | ">">, Strings.Split<":">]>>,
    Tuples.ToUnion,
    Objects.FromEntries,
    Objects.MapValues<
      Match<[Match.With<"string", string>, Match.With<"number", number>]>
    >
  ]
>;

API

  • Core
    • Pipe<Input, Fn[]>
    • PipeRight<Fn[], Input>
    • Call<Fn, ...Arg>
    • Apply<Fn, Arg[]>
    • PartialApply<Fn, Arg[]>
    • Compose<Fn[]>
    • ComposeLeft<Fn[]>
  • Function
    • ReturnType<Fn>
    • Parameters<Fn>
    • Parameter<N, Fn>
    • MapReturnType<Fn, FunctionType>
    • MapParameters<Fn, FunctionType>
  • Tuples
    • Create<X> -> [X]
    • Partition<Tuple>
    • IsEmpty<Tuple>
    • Zip<...Tuple[]>
    • ZipWith<Fn, ...Tuple[]>
    • Sort<Tuple>
    • Head<Tuple>
    • Tail<Tuple>
    • At<N, Tuple>
    • Last<Tuple>
    • FlatMap<Fn, Tuple>
    • Find<Fn, Tuple>
    • Drop<N, Tuple>
    • Take<N, Tuple>
    • TakeWhile<Fn, Tuple>
    • GroupBy<Fn, Tuple>
    • Join<Str, Tuple>
    • Map<Fn, Tuple>
    • Filter<Fn, Tuple>
    • Reduce<Fn, Init, Tuple>
    • ReduceRight<Fn, Init, Tuple>
    • Reverse<Tuple>
    • Every<Fn, Tuple>
    • Some<Fn, Tuple>
    • SplitAt<N, Tuple>
    • ToUnion<Tuple>
    • ToIntersection<Tuple>
    • Prepend<X, Tuple>
    • Append<X, Tuple>
    • Concat<T1, T2>
    • Min<Tuple>
    • Max<Tuple>
    • Sum<Tuple>
  • Object
    • Readonly<Obj>
    • Mutable<Obj>
    • Required<Obj>
    • Partial<Obj>
    • ReadonlyDeep<Obj>
    • MutableDeep<Obj>
    • RequiredDeep<Obj>
    • PartialDeep<Obj>
    • Update<Path, Fn | V, Obj>
    • Record<Key, Value>
    • Keys<Obj>
    • Values<Obj>
    • AllPaths<Obj>
    • Create<Pattern, X>
    • Get<Path, Obj>
    • FromEntries<[Key, Value]>
    • Entries<Obj>
    • MapValues<Fn, Obj>
    • MapKeys<Fn, Obj>
    • Assign<...Obj>
    • Pick<Key, Obj>
    • PickBy<Fn, Obj>
    • Omit<Key, Obj>
    • OmitBy<Fn, Obj>
    • CamelCase<Obj>
    • CamelCaseDeep<Obj>
    • SnakeCase<Obj>
    • SnakeCaseDeep<Obj>
    • KebabCase<Obj>
    • KebabCaseDeep<Obj>
  • Union
    • Map<Fn, U>
    • Extract<T, U>
    • ExtractBy<Fn, U>
    • Exclude<T, U>
    • ExcludeBy<Fn, U>
    • NonNullable<U>
    • ToTuple<U>
    • ToIntersection<U>
  • String
    • Length<Str>
    • TrimLeft<Str>
    • TrimRight<Str>
    • Trim<Str>
    • Join<Sep, Str>
    • Replace<From, To, Str>
    • Slice<Start, End, Str>
    • Split<Sep, Str>
    • Repeat<N, Str>
    • StartsWith<S, Str>
    • EndsWith<E, Str>
    • ToTuple<Str>
    • ToNumber<Str>
    • ToString<Str>
    • Prepend<Start, Str>
    • Append<End, Str>
    • Uppercase<Str>
    • Lowercase<Str>
    • Capitalize<Str>
    • Uncapitalize<Str>
    • SnakeCase<Str>
    • CamelCase<Str>
    • KebabCase<Str>
    • Compare<Str, Str>
    • Equal<Str, Str>
    • NotEqual<Str, Str>
    • LessThan<Str, Str>
    • LessThanOrEqual<Str, Str>
    • GreaterThan<Str, Str>
    • GreaterThanOrEqual<Str, Str>
  • Number
    • Add<N, M>
    • Multiply<N, M>
    • Subtract<N, M>
    • Negate<N>
    • Power<N, M>
    • Div<N, M>
    • Mod<N, M>
    • Abs<N>
    • Compare<N, M>
    • GreaterThan<N, M>
    • GreaterThanOrEqual<N, M>
    • LessThan<N, M>
    • LessThanOrEqual<N, M>
  • Boolean
    • And<Bool, Bool>
    • Or<Bool, Bool>
    • XOr<Bool, Bool>
    • Not<Bool>
    • Extends<A, B>
    • Equals<A, B>
    • DoesNotExtend<A, B>