Skip to content

Add option to always inline .json type import #61614

Open
@maxpatiiuk

Description

@maxpatiiuk

πŸ” Search Terms

json type import inline library resolveJsonModule

βœ… Viability Checklist

⭐ Suggestion

Add a tsconfig.json option to force .json type imports to inline the inferred .json type, rather than preserve .json import inside emitted .d.ts

or always inline without introducing a new option

or enable #resolveJsonModule by default

πŸ“ƒ Motivating Example

JSON type imports are a very convenient feature for getting a type of localization strings to get intellisense when dealing with translation strings:

// The .json for correct locale will be loaded at runtime - but we need a type at compile time
import type T9nStrings from "../assets/t9n/messages.en.json";

However, as a library author, that presents two issues because TypeScript may preserve the above type import in the .d.ts file:

  • Unless every consumer has #resolveJsonModule enabled, their typescript will error out when trying to resolve the .json type import from my .d.ts
  • I need to make sure the above .json file is also accessible relative to the final .d.ts file I distribute in dist/

πŸ’» Use Cases

  1. What do you want to use this for?
    • I want to use .json type imports for getting types of translation files and configuration files
  2. What shortcomings exist with current approaches?
    • the .json type import is inlined some of the time only. when not inlined, it can break my consumers
  3. What workarounds are you using in the meantime?
    • the following hack seems to trigger typescript to always inline the .json file rather than preserve the type import:
import type T9nStrings from "./assets/t9n/messages.en.json";
const identity = <T>(value: T): T => value;
const messages = identity<typeof T9nStrings>;
type Messages = ReturnType<typeof messages>;

related issues:

Metadata

Metadata

Assignees

No one assigned

    Labels

    Awaiting More FeedbackThis means we'd like to hear from more people who would be helped by this featureSuggestionAn idea for TypeScript

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions