ts-migration

A typesafe bidirectional migration facilitator

Usage no npm install needed!

<script type="module">
  import tsMigration from 'https://cdn.skypack.dev/ts-migration';
</script>

README

TypescriptMigration

A typesafe bidirectional migration facilitator.

Installation

npm i ts-migration

Usage

import CompileMigration from 'ts-migration'

// Consider the following object structure we desire
type MyObjectType = {
  MyNiceString: string
  MyNiceNumber: number
  MyNiceBoolean: boolean
}
const MyObject: MyObjectType = {
  MyNiceString: 'Test',
  MyNiceNumber: 10,
  MyNiceBoolean: false,
}

// Given a less-desireable object structure
type OtherUglyObjectType = {
  my_ugly_object: string,
  my_ugly_boolean: boolean,
}
const OtherUglyObject: OtherUglyObjectType = {
  my_ugly_object: 'Test_10',
  my_ugly_boolean: false,
}

// Design a migration
const MyMigration = CompileMigration(
  MyObject, OtherUglyObject,
  ({left, right}) => ({
    // Bidirectional 1-1
    [left.MyNiceBoolean]: right.my_ugly_boolean,
    // Unidirectional left -> right
    [left.MyNiceString]: (right: OtherUglyObjectType) => right.my_ugly_object.split('_')[0],
    [left.MyNiceNumber]: (right: OtherUglyObjectType) => Number(right.my_ugly_object.split('_')[1]),
    // Unidirectional right -> left
    [right.my_ugly_object]: (left: MyObjectType) => left.MyNiceString + '_' + left.MyNiceNumber,
  })
)

assert.deepEqual(
  MyMigration.forward(MyObject),
  OtherUglyObject
)

assert.deepEqual(
  MyMigration.reverse(OtherUglyObject),
  MyObject
)

// Any new object of MyObjectType or OtherUglyObjectType will always be convertable two and from