spatie/typescript-transformer

Transform your PHP structures to TypeScript types

2.1.8 2022-04-29 14:37 UTC

This package is auto-updated.

Last update: 2022-05-29 14:50:33 UTC


README

68747470733a2f2f6769746875622d6164732e73332e65752d63656e7472616c2d312e616d617a6f6e6177732e636f6d2f737570706f72742d756b7261696e652e7376673f743d31

Transform PHP types to TypeScript

Latest Version on Packagist Tests Styling Psalm Total Downloads

This package allows you to convert PHP classes to TypeScript.

This class...

/** @typescript */
class User
{
    public int $id;
    public string $name;
    public ?string $address;
}

... will be converted to this TypeScript type:

export type User = {
    id: number;
    name: string;
    address: string | null;
}

Here's another example.

class Languages extends Enum
{
    const TYPESCRIPT = 'typescript';
    const PHP = 'php';
}

The Languages enum will be converted to:

export type Languages = 'typescript' | 'php';

You can find the full documentation here.

Support us

68747470733a2f2f6769746875622d6164732e73332e65752d63656e7472616c2d312e616d617a6f6e6177732e636f6d2f747970657363726970742d7472616e73666f726d65722e6a70673f743d31

We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products.

We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall.

Installation

You can install this package via composer:

composer require spatie/typescript-transformer

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you've found a bug regarding security please mail security@spatie.be instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.