vinatis / typescript-generator
Bundle to generate TypeScript elements based on a Symfony project
Package info
github.com/vinatis/typescript-generator-bundle
Type:symfony-bundle
pkg:composer/vinatis/typescript-generator
Requires
- php: ^8.2
- phlak/semver: ^3.0.1
- symfony/config: ^7.0
- symfony/console: ^7.0
- symfony/dependency-injection: ^7.0
- symfony/filesystem: ^7.0
- symfony/finder: ^7.0
- symfony/http-kernel: ^7.0
Requires (Dev)
- roave/security-advisories: dev-latest
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"
}
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é.
- Se connecter à npm
npm adduser --registry https://npm.exemple.com
- Publier / mettre à jour les interfaces
npm publish --registry https://npm.exemple.com