Skip to content

Conversation

@danitt
Copy link

@danitt danitt commented Sep 8, 2025

Changes

Adds support (via optional flag) for generating TS Enums only where there is relevant metadata.

TS Enums can provide useful mappings in specific circumstances:

enum ThingId {
  Variant1: 'f49c3b85-5cfe-473a-8ce7-f876788d211a',
  Variant2: '50f5ddfc-217c-4507-a875-165a5bbf5a41',
  Variant3: '41b85275-8018-4398-9c4f-379dbf198fc8',
}

but is also entirely redundant in many others:

enum Status {
  ok: 'ok',
  pending: 'pending',
  error: 'error',
}

This PR provides an optional --conditional-enums flag to only create TS Enums where relevant mapping metadata has been explicitly added:

components:
  schemas:
    Foo:
      type: string
      enum: [pending, active, done]
    Bar:
      type: string
      enum: [pending, active, done]
      x-enum-varnames: [Pending, Active, Done]
      x-enum-descriptions: [
        "The task is pending",
        "The task is active",
        "The task is done",
      ]

Converts to

export type Foo = 'pending' | 'active' | 'done';
export enum Bar {
  // The task is pending
  Pending: 'pending',
  // The task is active
  Active: 'active',
  // The task is done
  Done: 'done',
}

The particular use case I am targeting is for established code bases that rely 95% on simple type unions, but may occasionally wish to store enum mappings in OAPI where appropriate.

This feature would assist in cases such as #941 and #2366.

How to Review

  1. Prepare an OAPI schema with two kinds of enums, one with metadata and one without (see above Status / StatusEnum example).

  2. Test generating typings with the enum flag enabled, and then toggle the conditionalEnums to compare the differences in result.

Checklist

  • Unit tests updated
  • docs/ updated (if necessary)
  • pnpm run update:examples run (only applicable for openapi-typescript)

@danitt danitt requested a review from a team as a code owner September 8, 2025 04:43
@danitt danitt requested a review from htunnicliff September 8, 2025 04:43
@changeset-bot
Copy link

changeset-bot bot commented Sep 8, 2025

🦋 Changeset detected

Latest commit: ad43b6a

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 2 packages
Name Type
openapi-typescript Minor
swr-openapi Major

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@netlify
Copy link

netlify bot commented Sep 8, 2025

Deploy Preview for openapi-ts failed.

Name Link
🔨 Latest commit ad43b6a
🔍 Latest deploy log https://app.netlify.com/projects/openapi-ts/deploys/68be7112db63ff0008dca7a9

@danitt danitt marked this pull request as draft September 8, 2025 04:46
@danitt danitt marked this pull request as ready for review September 8, 2025 06:06
@danitt
Copy link
Author

danitt commented Sep 11, 2025

hi @htunnicliff it seems the build failures are due to an issue fetching a particular github contributor:

did you want me to amend the logic in update-contributors.js to fail gracefully if a user can't be resolved? I'm just cautious of over-extending the scope on this PR

@danitt
Copy link
Author

danitt commented Sep 17, 2025

hi @drwpow I don't suppose you could take a look please?

@gzm0 gzm0 added the openapi-ts Relevant to the openapi-typescript library label Oct 2, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

openapi-ts Relevant to the openapi-typescript library

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants