承接 vinatis/typescript-generator 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

vinatis/typescript-generator

最新稳定版本:v2.0.4

Composer 安装命令:

composer require vinatis/typescript-generator

包简介

Bundle to generate TypeScript elements based on a Symfony project

README 文档

README

Ce bundle génère des éléments TypeScript basés sur un projet Symfony.

PHP ^8.4 — Symfony ^7.4

Installation

Ce bundle est disponible sur Packagist :

composer require vinatis/typescript-generator

Commandes disponibles

Générer des interfaces

Cette fonctionnalité permet de créer des interfaces TypeScript à partir de classes PHP conçues pour fonctionner comme des entités Doctrine.

Les interfaces sont générées en se basant sur les propriétés de ces classes. Il existe 3 façons d'obtenir le type de chaque propriété :

  • Typage fort de la propriété (disponible depuis PHP 7.4)
    • private int $id;

  • Typage dans le commentaire de la propriété
    • @var int

  • Typage via les annotations ou attributs Doctrine
    • @ORM\Column(type="integer") ou #[ORM\Column(type: 'integer')]

Si aucun type n'est trouvé, l'interface sera générée avec le type unknown.

La génération des interfaces s'effectue avec la commande suivante :

bin/console typescript:generate:interface output-dir [entities-dir]

Ce commande accepte 2 paramètres, dont un obligatoire et un optionnel.

output-dir (Obligatoire) : Répertoire où les interfaces seront créées. entities-dir (Optionnel) : Répertoire des entités à utiliser pour générer les interfaces. Par défaut : src/Entity/.

Pour qu'une entité soit convertie en interface, ajoutez l'attribut #[TypeScriptMe] dans la définition de la classe :

<?php
namespace App\Entity;

use Vinatis\TypeScriptGeneratorBundle\Attribute\TypeScriptMe;

#[TypeScriptMe]
#[ORM\Entity(repositoryClass: UserRepository::class)]
class User
{
    // ...
}

Types personnalisés

Pour forcer un type TypeScript personnalisé sur une propriété, utilisez l'attribut #[TypeScriptCustomType] :

use Vinatis\TypeScriptGeneratorBundle\Attribute\TypeScriptCustomType;

#[TypeScriptCustomType('MyCustomType')]
private string $status;

Types supportés

TypeScript PHP / Doctrine
number int, integer, smallint, bigint, decimal, float
string string, text, guid, date, time, datetime, datetimetz
boolean boolean
Interface Interface liée dans une relation one-to-one
Interface[] Tableau d'interfaces dans une relation one-to-many
unknown Tout autre type non reconnu

Si les annotations Doctrine définissent nullable=true, ou si le typage PHP utilise ? avant le type, la propriété sera marquée comme optionnelle (?) dans l'interface TypeScript générée.

Exemple

Entité PHP :

// src/Entity/User.php
<?php

namespace App\Entity;

use Vinatis\TypeScriptGeneratorBundle\Attribute\TypeScriptMe;

#[TypeScriptMe]
#[ORM\Table(name: 'user')]
class User
{
    #[ORM\Id]
    #[ORM\GeneratedValue]
    #[ORM\Column(type: 'integer')]
    private int $id;

    #[ORM\Column(type: 'string', length: 100)]
    private string $name;

    #[ORM\Column(type: 'string', length: 100, nullable: true)]
    private ?string $lastname;

    #[ORM\OneToMany(targetEntity: Factory::class, mappedBy: 'author')]
    private \Doctrine\Common\Collections\Collection $factories;

    #[ORM\OneToOne(targetEntity: Photo::class, mappedBy: 'user')]
    private ?Photo $photo;

    // ...
}

Interface TypeScript générée :

// interfaces/User.ts

export interface User {
  id: number,
  name: string,
  lastname?: string,
  photo: Photo,
  factories: Factory[]
}

Pour faciliter l'utilisation des interfaces, le fichier models.d.ts est généré automatiquement avec l'export de toutes les interfaces :

// interfaces/models.d.ts

export * from './User';
export * from './Photo';
export * from './Factory';

Générer un package

bin/console typescript:generate:package output-dir [package-name] [version]

Cette commande génère un fichier package.json avec les données de base pour publier dans un dépôt npm privé.

À chaque exécution, la version patch est incrémentée par défaut. Il est possible de passer une version spécifique ou d'indiquer patch, minor ou major.

Exemple de package.json généré :

{
    "name": "@mon-org/mon-projet",
    "version": "0.0.1",
    "description": "typescript interfaces for @mon-org/mon-projet",
    "types": "models.d.ts",
    "keywords": [],
    "author": "",
    "license": "EUPL"
}

Bibliothèque utilisée pour la gestion des versions

Tout générer

bin/console typescript:generate:all output-dir [entities-dir] [package-name] [version]

Exécute les deux commandes précédentes en une seule fois.

Publier dans un dépôt npm privé

Pour publier dans un dépôt privé, il faut avoir préalablement généré le fichier package.json et avoir npm installé.

  1. Se connecter à npm
npm adduser --registry https://npm.exemple.com
  1. Publier / mettre à jour les interfaces
npm publish --registry https://npm.exemple.com

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 10
  • 开发语言: PHP

其他信息

  • 授权协议: EUPL-1.1
  • 更新时间: 2025-04-11

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固