I have a Protractor project which contain such a file:
var FriendCard = function (card) {
var webElement = card;
var menuButton;
var serialNumber;
this.getAsWebElement = function () {
return webElement;
};
this.clickMenuButton = function () {
menuButton.click();
};
this.setSerialNumber = function (numberOfElements) {
serialNumber = numberOfElements + 1;
menuButton = element(by.xpath('.//*[@id=\'mCSB_2_container\']/li[' + serialNumber + ']/ng-include/div/div[2]/i'));
};
this.deleteFriend = function () {
element(by.css('[ng-click="deleteFriend(person);"]')).click();
element(by.css('[ng-click="confirm()"]')).click();
}
};
module.exports = FriendCard;
Path to the file is
./pages/FriendCard.js
I have no problems whith it's import to another file using require() method:
var FriendCard = require('./../pages/FriendCard');
So, I've decided to import this file to the TypeScript file just like that:
import {FriendCard} from './../pages/FriendCard'
I'm using WebStorm, so it tells me, that (TS2305) it has no exported member 'FriendCard'.
Maybe I have to configure tsconfig.json file somehow, but I still don't know how it works. Could you help me?
I'm currently taking some legacy codebases and introducing minimal TypeScript changes to see if it helps our team. Depending on how strict you want to be with TypeScript, this may or may not be an option for you.
The most helpful way for us to get started was to extend our
tsconfig.json
file with this property:This change lets our JS files that have JSDoc type hints get compiled. Also our IDEs (JetBrains IDEs and VS Code) can provide code-completion and Intellisense.
TypeScript Compiler Options
In your second statement
you are telling typescript to import the FriendCard class from the file './pages/FriendCard'
Your FriendCard file is exporting a variable and that variable is referencing the anonymous function.
You have two options here. If you want to do this in a typed way you can refactor your module to be typed (option 1) or you can import the anonymous function and add a d.ts file. See https://github.com/Microsoft/TypeScript/issues/3019 for more details. about why you need to add the file.
Option 1
Refactor the Friend card js file to be typed.
Option 2
You can import the anonymous function
There are a few options for a d.ts file definition. This answer seems to be the most complete: How do you produce a .d.ts "typings" definition file from an existing JavaScript library?
You can import the whole module as follows:
For more details please refer the modules section of Typescript official docs.