I'm writing the type definitions for a library I'm using. One function in the library identifies the mouse button clicked by an integer:
//index.d.ts
export as namespace myLib;
// activates the library listening for a specific mouse button
function activate(button : number ) : void
I introduced an enum to make this nicer:
//index.d.ts
export as namespace myLib;
export enum MouseButton {
LEFT = 1,
MIDDLE = 2,
RIGHT = 4
}
export function activate(button : MouseButton ) : void;
Now, when I import this function and use it, everything compiles but I guess the enum is stripped and undefined when executed in the browser. The error message says Cannot read property 'LEFT' of undefined
.
Therefore I rearranged the files like so:
//MouseButton.ts
export enum MouseButton {
LEFT = 1,
MIDDLE = 2,
RIGHT = 4
}
//index.d.ts
export as namespace myLib;
import {MouseButton} from MouseButton;
export {MouseButton} from MouseButton;
export function activate(button : MouseButton ) : void;
Now I can import {MouseButton} from "myLib/MouseButton"; import * as myLib from "myLib"
. But this requires two imports. Referencing myLib.MouseButton
still compiles but doesn't run.
Is there any way to import and reference the MouseButton
enum via the myLib
imported via the import * as myLib
statement? I'm not only looking for an answer explaining how to do it but for one explaining why my solution doesn't work or why it isn't possible. Hints to resources explaining what's wrong are also appreciated
PS: I also tried the syntax suggested here re-export Typescript enum from namespace? but that didn't work either.
PPS: The module in question is a UMD module from the cornerstone project (https://github.com/cornerstonejs/cornerstone) used in an angular 6 project.
Cannot read property 'LEFT' of undefined
occurred? – UpheaveMouseButton
as a reverse map :MouseButton[button]
? If not, I don't know why this pure TypeScript thing is leaking to JavaScript, unless a JaveScript bundle issue with the modules. – UpheavemyLib.activate(MouseButton.LEFT);
(with the two-imports version). but I would like it to be myLib.activate(myLib.MouseButton.LEFT)`. What do you mean by "leaking"? should it be compiled away and replaced by the enum's value? – Slaton