mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
* Add Google APIs typings * [gapi.cliebt.* ] Add version as part of typings name and fix gapi.client tslint errors * versions should not get their own folders fixing a few typos using /** syntax so comments show up in editors export only actual (last) version for now * export only actual (last) version for now * merge namespaces and remove unnecessary namespace qualifiers * remove namespace qualifier for gapi.client.Request from nested namespaces and change Request base interface to Promise * disable await-promise rule * fix collision between gapi.client.Request and Request from nested namespace disable no-irregular-whitespace rule * sort properties and namespace resources * remove empty comments sort resources amd methods in tests and readme.md * update 'this is autogenerated file' banner to remove this text from gapi.client namespace hint use multiline comments when comment has several lines * implement no-trailing-whitespace, no-padding, max-line-length, await-promise, no-irregular-whitespace rules * add strictFunctionTypes to tsconfig * fix "Whitespace within parentheses is not allowed" rule * fix ts-lint rules * fixes * remove deprecated replicapool and replicapoolupdater api * fix no-irregular-whitespace * fix no-irregular-whitespace |
||
|---|---|---|
| .. | ||
| gapi.client.firebasedynamiclinks-tests.ts | ||
| index.d.ts | ||
| readme.md | ||
| tsconfig.json | ||
| tslint.json | ||
TypeScript typings for Firebase Dynamic Links API v1
Programmatically creates and manages Firebase Dynamic Links. For detailed description please check documentation.
Installing
Install typings for Firebase Dynamic Links API:
npm install @types/gapi.client.firebasedynamiclinks@v1 --save-dev
Usage
You need to initialize Google API client in your code:
gapi.load("client", () => {
// now we can use gapi.client
// ...
});
Then load api client wrapper:
gapi.client.load('firebasedynamiclinks', 'v1', () => {
// now we can use gapi.client.firebasedynamiclinks
// ...
});
Don't forget to authenticate your client before sending any request to resources:
// declare client_id registered in Google Developers Console
var client_id = '',
scope = [
// View and administer all your Firebase data and settings
'https://www.googleapis.com/auth/firebase',
],
immediate = true;
// ...
gapi.auth.authorize({ client_id: client_id, scope: scope, immediate: immediate }, authResult => {
if (authResult && !authResult.error) {
/* handle succesfull authorization */
} else {
/* handle authorization error */
}
});
After that you can use Firebase Dynamic Links API resources:
/*
Creates a short Dynamic Link given either a valid long Dynamic Link or
details such as Dynamic Link domain, Android and iOS app information.
The created short Dynamic Link will not expire.
Repeated calls with the same long Dynamic Link or Dynamic Link information
will produce the same short Dynamic Link.
The Dynamic Link domain in the request must be owned by requester's
Firebase project.
*/
await gapi.client.shortLinks.create({ });
/*
Fetches analytics stats of a short Dynamic Link for a given
duration. Metrics include number of clicks, redirects, installs,
app first opens, and app reopens.
*/
await gapi.client.v1.getLinkStats({ dynamicLink: "dynamicLink", });
/*
Get iOS strong/weak-match info for post-install attribution.
*/
await gapi.client.v1.installAttribution({ });