Recently, I wanted to try something for one of „my“ streamers and since she streams on Facebook, that would require tools to access Facebook.
Developer Facebook offers a variety of SDKs for different environments that allow easy (?) access to their API, to login etc.
Facebook doesn’t have a specific Angular package you can install via npm or other helpful tools, but they have a JS SDK that does work with Angular, if you manage to integrate it – which is the part that proved to be a bit tricky. I found different more or less helpful pages, but following them, I still was greeted by errors that basically made it impossible to use the SDK.
And Facebook themselves do not help there either, they only have a small part of their documentation about adding their JavaScript to AngularJS, which is slightly outdated.
To get started with a Facebook app, you have to create one on the developer’s page. Any app created receives a unique ID that is used to identify it and that you will need to initialise. You will probably create the app as a web app and Facebook will give you the <script> to insert what you need into your page.
Since this is about Angular, it is not really what we want; we would like to add and initialise on our Script file, not in the HTML file.
If you put the code into your component.ts or service.ts, like in the following example, it will give you an error, as FB is not defined (and window as well).
The trick that I finally found working was to add window and FB as vars to the component or service, for example something like this:
This way, the code doesn’t crash around FB or window. You will not get code completion on the calls to FB.<function>, but the calls will work, and that is what counts, right?
As you can see, the code plugin doesn’t really do what I would like it to do, so I’ll have to do some research on that topic as well ^^