定制 wovosoft/laravel-typescript 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

wovosoft/laravel-typescript

最新稳定版本:v1.1.2

Composer 安装命令:

composer require wovosoft/laravel-typescript

包简介

Transforms Laravel Models to Typescript Interfaces/Types

README 文档

README

Latest Version on Packagist Total Downloads Build Status StyleCI

Transforms Laravel Models to Typescript Interfaces/Types

Precautions

This packages instantiates Models to retrieve it's casts, attributes, relations in some cases. So, if your models have some sensitive actions inside __constructor method, please be aware of using this package.

Installation

Via Composer

composer require --dev wovosoft/laravel-typescript

Publish Configuration

Run the command given below. This will publish laravel-typescript.php config file.

php artisan vendor:publish --provider="Wovosoft\LaravelTypescript\LaravelTypescriptServiceProvider"

Configure the configurations

return [
    'output_path'       => resource_path('js/types/models.d.ts'),
    'source_dir'        => app_path('Models'),
    /**
     * Custom attributes should have return types defined.
     * But if it is not, then the return type should be this type.
     * And this value should be php supported return types.
     * like primitive types or any other classes
     */
    "custom_attributes" => [
        "fallback_return_type" => "string"
    ]
];

Usage

Run the command given below to generate typescript types.

php artisan laravel-typescript:transform

Generated contents will be written in configured location.

Advanced Usage

Sometimes Models can be stored in different locations, like in some packages, some directories etc., in that case, please check the source of ./src/LaravelTypescript.php

You can just instantiate this class, and generate types for models in some other directories.

use Wovosoft\LaravelTypescript\Facades\LaravelTypescript;


$dirs = [
    "models"               => app_path("Models"),
    "hrmPerson"            => base_path("packages/wovosoft/hrms-person/src/Models"),
];

foreach ($dirs as $name => $dir) {
    LaravelTypescript::generate(
        sourceDir : $dir,
        outputPath: resource_path("js/types/$name.d.ts")
    );
    
    echo "Generated $name.d.ts";
}

Note on New Model Attributes

For new Model Attributes, return type of the Closure function should be defined, otherwise, it will generate value of config('laravel-typescript.custom_attributes.fallback_return_type') type for the related property.

use \Illuminate\Database\Eloquent\Model;
use \Illuminate\Database\Eloquent\Casts\Attribute;

class User extends Model{
    public function isActive() : Attribute 
    {
        return Attribute::get(fn(): bool =>$this->status==='active');
    }
    
    public function getIsInactiveAttribute():bool
    {
        return $this->status==="inactive";
    }
}

Change log

Please see the changelog for more information on what has changed recently.

Contributing

Please see contributing.md for details and a todolist.

Security

If you discover any security related issues, please create issues in Issues Tracker

Credits

License

MIT. Please see the license file for more information.

统计信息

  • 总下载量: 1.99k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 13
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 13
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-07-02