TL;DR;
The current inconsistent import behavior in different module mode (system or commonjs) would cause .d.ts to break (1.8 included).
Potential Solution
- Add a "module {system,commonjs}" directive and so that the
.d.ts file will be processed correctly
- Unify the import/export syntax and behavior
.d.ts uses a module agnostic import/export syntax
Context
The context of this problem is about module mapping (such as what jspm and typings supports).
Basically saying any module can be referenced by a different name to avoid module name collision. e.g. in a project that use two versions of jquery, one would be imported normally (import $ from 'jquery'), one would be imported with a different name (import $old from 'jquery@1.6').
In 1.8, with the support of allowSyntheticDefaultImports enables the behavior become similar (but if the user set it to false could still diverge). However the behavior of import * as A from 'abc'; and import dr = require('domready'); are still different.
Problem
The current (1.8) module support is working fine when creating package in TypeScript and distributing it as .js.
However it does not work if the package is distributed in .ts or with .d.ts.
The reason is that when distributing in the compiled form, the module mode used by the package author is captured in the .js file. When distributing .ts and .d.ts it relies on the consumer to use the same module mode as the package author intended.
This means if the package authors (including all typings authors) create the package using one module mode, and the consuming application/package use a different module mode, the system will fail.
It is worse if the consuming application/package uses multiple packages with disagreeing module mode.
Here are the original discussion:
typings/typings#149
This is closely related to:
#7125
Please let me know if there are any confusion or missing information / context.
TL;DR;
The current inconsistent import behavior in different module mode (
systemorcommonjs) would cause.d.tsto break (1.8 included).Potential Solution
.d.tsfile will be processed correctly.d.tsuses a module agnostic import/export syntaxContext
The context of this problem is about module mapping (such as what
jspmandtypingssupports).Basically saying any module can be referenced by a different name to avoid module name collision. e.g. in a project that use two versions of
jquery, one would be imported normally (import $ from 'jquery'), one would be imported with a different name (import $old from 'jquery@1.6').In
1.8, with the support ofallowSyntheticDefaultImportsenables the behavior become similar (but if the user set it tofalsecould still diverge). However the behavior ofimport * as A from 'abc';andimport dr = require('domready');are still different.Problem
The current (1.8)
modulesupport is working fine when creating package in TypeScript and distributing it as.js.However it does not work if the package is distributed in
.tsor with.d.ts.The reason is that when distributing in the compiled form, the
modulemode used by the package author is captured in the.jsfile. When distributing.tsand.d.tsit relies on the consumer to use the samemodulemode as the package author intended.This means if the package authors (including all typings authors) create the package using one
modulemode, and the consuming application/package use a differentmodulemode, the system will fail.It is worse if the consuming application/package uses multiple packages with disagreeing
modulemode.Here are the original discussion:
typings/typings#149
This is closely related to:
#7125
Please let me know if there are any confusion or missing information / context.