Skip to content

Releases: gjsify/ts-for-gir

v3.2.8

17 Feb 06:43
Compare
Choose a tag to compare

What's Changed

  • Upgrade dependencies
  • Update examples and removed deprecated function calls like byteArray.toString()
  • Add dom.js, ambient.js and node-ambient.js to allow importing there type definitions in the codebase with a bundler
  • Update TSDoc documentation for system
  • node-gtk: Add new gtk-4-application example
  • node-gtk: Uses snake_case for property names at constructor, fixes #131

Breaking Changes

  • Removed support for additional underscore properties (next to lowerCamelCase) in the generated types, if this causes problems please let us know, then we will undo it again

Full Changelog: v3.2.7...v3.2.8

v3.2.7

01 Jan 19:19
e96433c
Compare
Choose a tag to compare

3.2.7

  • Upgrade dependencies
  • Add type for import.meta.url, see #142
  • C type const is readonly in typescript
  • Constants are not nullable, fixes #141

3.2.6

  • Upgrade dependencies
  • Generate camel cased property accessors, see #138
  • Add runAsync override for GLib.MainLoop, see #130

3.2.5

  • Upgrade dependencies
  • Allow ambient modules without version for NPM packages, see #139
  • Add information about ESM and CommonJS modules to README.md for NPM packages

3.2.4

  • Upgrade dependencies
  • Add instruction to install GnomeBluetooth-3.0.gir on Fedora
  • Add more *.gir files to ./girs directory

3.2.3

  • Upgrade dependencies
  • Upgrade gir files

3.2.1

  • TypeDoc: Only include main entry point
  • Upgrade dependencies

New Contributors

Full Changelog: v3.2.0...v3.2.7

v3.2.0

23 Jun 16:54
Compare
Choose a tag to compare
  • Improved TypeDoc support for TypeDoc 0.24.x of the generated NPM packages
  • Upgrade dependencies
  • Upgrade gir files

v3.1.0

12 Jun 08:54
Compare
Choose a tag to compare
  • Upgrade dependencies
  • Move conflicting global GJS types to dom.d.ts for optional import

Breaking Changes

Move conflicting global GJS types to dom.d.ts, allowing you to optionally import them in your project. By doing so, you have the flexibility to choose whether or not to include these types based on your specific needs. This resolves the conflict between the GJS and DOM types and provides you with more control over managing the type definitions.

To use the previous behavior and include the conflicting GJS types, you can import both ./@types/gjs.d.ts and ./@types/dom.d.ts in your code.

Alternatively, if you are using the NPM packages, you can import the following:

  • @girs/gjs: This package provides the GJS types.
  • @girs/gjs/dom: This package provides the conflicting DOM types.

Please update your imports accordingly based on your chosen approach.

v3.0.4

05 Jun 14:01
Compare
Choose a tag to compare
  • Update badges on README template files
  • Node-gtk: Readd gobject signal method, fixes #126

v3.0.3

04 Jun 19:47
Compare
Choose a tag to compare
  • NPM package Yarn workspace support is optional now, see #124
  • Upgrade all dependencies (except xml2js, see #125)
  • Parse app version from package.json
  • Moved templates, packages.xml, package-data-parser.ts and template-processor.ts from @ts-for-gir/lib to @ts-for-gir/generator-typescript
  • Cleanup yarn scripts in ./package.json

v3.0.1

22 May 18:32
Compare
Choose a tag to compare

Add missing packages.xml to @ts-for-gir/lib

v3.0.0

22 May 18:00
d5822e5
Compare
Choose a tag to compare

🎉 ts-for-gir v3.0.0 is here! 🚀

This stable release brings exciting new features and improvements to ts-for-gir.

Highlights

  • Support for generating NPM packages for each module, making it easier to manage and use the type definitions.
  • New CLI options to generate NPM packages and customize the package scope name.
  • Improved documentation with detailed explanations of the new CLI options.
  • Enhanced package structure with separate folders for each package, along with individual package.json files.
  • Compatibility updates for GNOME Shell extensions, including a dedicated NPM package for GNOME Shell types.
  • Expanded support for ambient modules.
  • Generation of both CommonJS and ESM modules.
  • Breaking changes to improve file naming conventions and folder structure.
  • The pre-generated NPM packages can be found on gjsify/types

Changelog

  • Add support to generate a package for each type we can publish on NPM, see #106
  • Add a new CLI option to generate NPM packages
  • Add a new CLI option to change the NPM package scope name
  • Documentation for the new CLI options
  • Generate a package.json for each package
  • One folder for each package
  • New example
  • Add dependencies to each package.json
  • Package names in lower case
  • Separate package names for node-gtk types
  • Package directory and file names in lower case
  • Parse library versions
  • Add a README.md for each NPM package
  • Different README.md for node-gtk NPM packages
  • Add an test to CI
  • Fix tsconfig.alias.json
  • Add support for ambient modules
  • Documentation for ambient modules
  • Generate both CJS and ESM modules
  • Add node-gtk to the peer dependencies to the node-gtk NPM packages
  • Remove destination environment directory
  • Separate README.md for the main NPM packages (@gir/gjs and @gir/node-gtk)
  • Generate and publish the new NPM packages
  • Provide system and gettext as ESM, see #114
  • Include only desired types (instead of all existing ones)
  • Add repository and homepage to package.json
  • Updated Documentation for the new NPM packages
  • Move the GNOME Shell type definitions to a NPM package and make use of the new generated NPM packages

v3.0.0-beta.12

14 Mar 14:01
Compare
Choose a tag to compare
  • UTF-8 string pointers are handled as nullable now, see #108
  • Extract default GIR directories from XDG_DATA_DIRS environment variable, this fixes ts-for-gir on NixOS. See #107 by @samdroid-apps

Breaking Changes

  • More parameters and returned UTF-8 strings are nullable now, so maybe you need to update your code to check if the string is not null. Please give us feedback about this change

v3.0.0-beta.11

21 Feb 08:24
Compare
Choose a tag to compare
  • Split this project into more submodules: cli, lib, generator-base, generator-typescript and generator-html-doc
  • Fix node bin path for ts-for-gir execution
  • Upgrade dependencies