tygoja is a small helper library for generating TypeScript declarations from Go code.
The generated typings are intended to be used as import helpers to provide ambient TypeScript declarations (aka. .d.ts
) for goja bindings.
⚠️ Don't use it directly in production! It is not tagged and may change without notice.
It was created to semi-automate the documentation of the goja integration for PocketBase.
Use it only as a reference or as a non-critical step in your dev pipeline.
tygoja is a heavily modified fork of tygo and extends its scope with:
PackageConfig.WithPackageFunctions
)Note that by default the generated typings are not generated with export
since the intended usage is to map them to your custom goja bindings.
This mapping could be defined in the Config.Heading
field usually with the declare
keyword (eg. declare let someGojaProp: app.Cache
).
package main
import (
"log"
"os"
"github.com/pocketbase/tygoja"
)
func main() {
gen := tygoja.New(tygoja.Config{
Packages: map[string][]string{
"github.com/pocketbase/tygoja/test/a": {"*"},
"github.com/pocketbase/tygoja/test/b": {"*"},
"github.com/pocketbase/tygoja/test/c": {"Example2", "Handler"},
},
Heading: `declare var $app: c.Handler; // bind other fields `,
WithPackageFunctions: true,
})
result, err := gen.Generate()
if err != nil {
log.Fatal(err)
}
if err := os.WriteFile("./types.d.ts", []byte(result), 0644); err != nil {
log.Fatal(err)
}
}
You can also combine it with typedoc to create HTML/JSON docs from the generated declaration(s).
See the package /test
directory for example output.
For a more detailed example you can also explore the PocketBase's jsvm plugin.
_in()
).