Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add JSDoc @export tag #60831

Open
6 tasks done
remcohaszing opened this issue Dec 20, 2024 · 2 comments
Open
6 tasks done

Add JSDoc @export tag #60831

remcohaszing opened this issue Dec 20, 2024 · 2 comments
Labels
Awaiting More Feedback This means we'd like to hear from more people who would be helped by this feature Domain: JSDoc Relates to JSDoc parsing and type generation Suggestion An idea for TypeScript

Comments

@remcohaszing
Copy link

🔍 Search Terms

jsdoc @export

✅ Viability Checklist

⭐ Suggestion

TypeScript 5.5 added the @import JSDoc tag which can be used for type-only imports. It would be useful to add an analogous @export tag for type-only exports.

📃 Motivating Example

Let’s say you maintain a library that contains the following file:

// types.js
/**
 * @typedef {string} Username
 */

/**
 * @typedef {number} UserId
 */

Maybe you want to expose these types in the main entry point. You can now do this with the JSDoc @export tag. It works the same as type-only exports in TypeScript files.

// index.js
/**
 * @import { Username } from './types.js'
 */

/**
 * @export { Username }
 * @export { UserId } from './types.js'
 */

💻 Use Cases

This is useful to have full control over exports in a library. Also this is just parity between JSDoc based types and TypeScript files.

I can think of 3 workarounds, all of which are not great.

  1. Define a new type in the index file using @typedef

    // index.js
    /**
     * @typedef {import('./types.js').Username} Username
     * @typedef {import('./types.js').UserId} UserId
     */

    Pros:

    • It works

    Cons:

  2. In addition to index.js, create a TypeScript file, e.g. exports.ts. Then in exports.ts write something along the lines of:

    export { someValue, anotherValue } from './index.js'
    export { Username, UserId } from './types.js'

    and in package.json, write something like:

    {
      "types": "./types/exports.d.ts",
      "exports": {
        "types": "./types/exports.d.ts",
        "default": "./lib/index.js",
      }
    }

    Pros:

    • It works
    • No new types are defined, but actual exports
    • Hover information is preserved
    • Type parameters are preserved

    Cons:

    • Exports from index.js need to be synced to exports.ts manually.
    • You’re essentially tricking TypeScript into thinking exports.ts is the main entry, whereas in reality it’s index.js
  3. Manually write the declaration file.

    Pros:

    • It works
    • No new types are defined

    Cons:

    • You need to author the declaration files manually.
@MartinJohns
Copy link
Contributor

Duplicate of #22126. Used search terms: export tag in:title

@remcohaszing
Copy link
Author

No, it’s not a duplicate. That issue also proposes a JSDoc tag named @export, but behaves different. The two issues conflict even.

Somehow I didn’t find that issue though, so good find.

@RyanCavanaugh RyanCavanaugh added Suggestion An idea for TypeScript Awaiting More Feedback This means we'd like to hear from more people who would be helped by this feature Domain: JSDoc Relates to JSDoc parsing and type generation labels Jan 3, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Awaiting More Feedback This means we'd like to hear from more people who would be helped by this feature Domain: JSDoc Relates to JSDoc parsing and type generation Suggestion An idea for TypeScript
Projects
None yet
Development

No branches or pull requests

3 participants