Convert your python types to typescript
Project description
Petit ts
A Library to easly convert your python types to typescript types.
It's a part of the petite_stack (not released yet, as not mature enough).
Example
from petit_ts import TSTypeStore, Name
store = TSTypeStore()
class Jeb(Enum):
A = 'R'
# if you want an union to be named and not inlined
UserType = Named(Literal['admin', 'user'])
TestUnion = Named(Union[str, int])
class CreateUserDto(BaseModel):
username: str
# will be inlined
password: Union[str, Jeb]
# won't be inlined
role: UserType
# won't be inlined
jeb: TestUnion
store.add_type(CreateUserDto)
res = store.get_repr(CreateUserDto)
print(res)
# >>> "CreateUserDto"
# Here you notice that we have the name instead of the body, so that you can use it
# in another function easly
# here we need to do this in order, to get all the required deps into our ts file
not_inlined = store.get_all_not_inlined()
print(not_inlined)
# >>> "type CreateUserDto = {
# username: string;
# password: string | Jeb;
# role: UserType;
# jeb: TestUnion;
# };
# export enum Jeb {
# A = "R",
# };
# type UserType = "admin" | "user";
# type TestUnion = string | number /*int*/"
with open('res.ts', 'w') as f :
# write what you need to the file
final = f'export a = function (a: any): {store.get_repr(CreateUserDto)};'
final += store.get_all_not_inlined()
f.write(final)
Supported types:
- None
- bool
- str
- int
- float
- Dict[K, V]
- List[T]
- List, list
- Dict, dict
- @dataclass, generic @dataclass
- Optional[T]
- Union[A, B, ...], Named(Union[A, B, ...])
- Literal[values], Named(Literal[1, 2, '3']) with values = Union[int, str]
Add support for a custom type
Example for the BaseModel type:
from typing import Tuple, Optional, Dict, Any, get_type_hints
from petit_ts import ClassHandler, TSTypeStore
from pydantic import BaseModel
store = TSTypeStore()
class BaseModelHandler(ClassHandler):
@staticmethod
def is_mapping() -> bool:
return True
@staticmethod
def should_handle(cls, store, origin, args) -> bool:
return issubclass(cls, BaseModel)
@staticmethod
def build(cls: BaseModel, store, origin, args) -> Tuple[Optional[str], Dict[str, Any]]:
name = cls.__name__
fields = get_type_hints(cls)
return name, fields
store.add_class_handler(BaseModelHandler)
You have to implement for the ClassHandler
:
- is_mapping
- should_handle
- build
If this is a mapping, you should return the fields, a Dict[str, Any]
else you should return a string
For the BasicHandler :
- build
- should_handle
If you have any problem, don't hesitate to open an issue on github !
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
petit_ts-0.1.5.tar.gz
(12.2 kB
view details)
Built Distribution
File details
Details for the file petit_ts-0.1.5.tar.gz
.
File metadata
- Download URL: petit_ts-0.1.5.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6202baa2ad8decbb220efd4a1c52735390d8ce67c754ba15896022bbac68584f |
|
MD5 | adbc04fa66ba62353f1dd5e8ddf7fd56 |
|
BLAKE2b-256 | e8bcac95ccc5244474a49e68eedddbe369b9f517a5e2f8d40babac8ede25ef05 |
File details
Details for the file petit_ts-0.1.5-py2.py3-none-any.whl
.
File metadata
- Download URL: petit_ts-0.1.5-py2.py3-none-any.whl
- Upload date:
- Size: 13.3 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1559634d114064ed16cf7ace2c6327aa9f69e9e805aa486ea22c5794f543f2c1 |
|
MD5 | c4afb67b97164a1ffbaae79ffd8da1ee |
|
BLAKE2b-256 | 4d312b9280b6e41a779ee975e05d0f42f80d4efd2a02bd416601ea66fd074b4e |