-
Notifications
You must be signed in to change notification settings - Fork 115
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
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this 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; |
There was a problem hiding this comment.
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; |
There was a problem hiding this comment.
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>; |
There was a problem hiding this comment.
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>; |
There was a problem hiding this comment.
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
|
||
export const version: string; | ||
|
||
export function FacebookApiException(res: Response): void; |
There was a problem hiding this comment.
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
.
There was a problem hiding this comment.
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; |
There was a problem hiding this comment.
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.
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" |
There was a problem hiding this comment.
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.
There was a problem hiding this comment.
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?
There was a problem hiding this comment.
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.
There was a problem hiding this comment.
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?
There was a problem hiding this comment.
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; |
There was a problem hiding this comment.
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>; |
There was a problem hiding this comment.
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; |
There was a problem hiding this comment.
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.
There was a problem hiding this comment.
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.
No description provided.