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

Added type definitions to make it Typescript compatible #176

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

shibulijack
Copy link

No description provided.

Copy link

@dantman dantman left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you're going to add TypeScript definitions, could you add some testing code to validate that they are correct. IIRC we have CI and it would be preferable to have the CI make sure no-one breaks the typedefs.

src/fb.d.ts Outdated

setAccessToken(accessToken: string): void;

withAccessToken(accessToken: string): any;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should also be Facebook

src/fb.d.ts Outdated

napi(...args): Promise<any>;

options(keyOrOptions: FBOptions): FBOptions;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This needs overloading for the other ways it can be called.

keyof may be useful here.

src/fb.d.ts Outdated

getLoginUrl(): string;

napi(...args): Promise<any>;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

napi does not return a promise, it accepts a node style callback.

src/fb.d.ts Outdated
export class Facebook {
constructor(options: FBOptions);

api(...args): Promise<any>;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This does not look like valid TypeScript.

Also even though DefinitelyTyped discourages it, we might want to consider using a generic here instead of any.

src/fb.d.ts Outdated Show resolved Hide resolved
src/fb.d.ts Outdated Show resolved Hide resolved
src/fb.d.ts Outdated

export const version: string;

export function FacebookApiException(res: Response): void;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Where is Response defined? void also is wrong, this is a subclass of Error.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Response is from TypeScript lib.dom.d.ts.


export function FacebookApiException(res: Response): void;

export const FB: Facebook;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is also a default export.

src/fb.d.ts Show resolved Hide resolved
package.json Outdated
@@ -9,7 +9,8 @@
],
"author": "Thuzi LLC <pshrestha@thuzi.com> (https://github.com/Thuzi)",
"contributors": [
"Daniel Friesen <d@danf.ca> (http://danf.ca)"
"Daniel Friesen <d@danf.ca> (http://danf.ca)",
"Shibu Lijack <shibulijack@gmail.com> (https://github.com/shibulijack"
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Missing ), if you're going to make yourself the only one of the many people who has submitted PRs to this library attributed here.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry but I don't understand. I'll fix the missing parenthesis but am I missing anything else here?

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, I was just noting that there are 16 other people who have contributed code to this library and none of them are credited in the contributors list. It's really only listing me because I took over as maintainer.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Alright. I'll remove myself from the contributor list.
Just curious though, shouldn't all the 16 people be included in the contributor list?

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps, but in general I think most npm packages bother adding everyone to the contributors list. I sometimes see a CONTRIBUTORS file. But the contributors list is usually kept short, presumably because it's downloaded by everyone that installs the library.

src/fb.d.ts Outdated

napi(arguments: FBAPIInterface): void;

options(keyOrOptions: keyof FBKeyOrOptions): any;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, this needs overloading, not another interface type.

Something like:

options(): FBOptions
options(key: K): ... // (I'm not sure which to use here but there should be a way to use keyof and also get TS to automatically infer the correct return type
options(options: FBOptions): void

src/fb.d.ts Outdated
export class Facebook {
constructor(options?: FBOptions);

api(arguments: FBAPIInterface): Promise<any>;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

api and napi args are not a single arguments object, they're separate ordered arguments.

You'll need overloading here as well to differentiate between path, cb and path, params, cb, etc and also to differentiate between the callback form and the form without the callback that returns a promise.

src/fb.d.ts Outdated

export const version: string;

export function FacebookApiException(res: Response): Error;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

res is not a fetch Response instance. It's an object returned by the Facebook API in the format that Facebook specifies for error responses.

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also I'm pretty sure Error extensions are implemented using class and extends instead of functions.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants