{"id":18032670,"url":"https://github.com/mikkopaderes/ember-firebaseui","last_synced_at":"2025-03-27T05:31:16.322Z","repository":{"id":57223770,"uuid":"101973570","full_name":"mikkopaderes/ember-firebaseui","owner":"mikkopaderes","description":"Ember implementation of FirebaseUI for Web","archived":false,"fork":false,"pushed_at":"2018-05-13T14:12:10.000Z","size":239,"stargazers_count":5,"open_issues_count":1,"forks_count":2,"subscribers_count":0,"default_branch":"master","last_synced_at":"2025-03-23T04:51:14.029Z","etag":null,"topics":["ember-addon","firebase"],"latest_commit_sha":null,"homepage":null,"language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/mikkopaderes.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.md","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2017-08-31T07:40:01.000Z","updated_at":"2018-07-24T16:48:05.000Z","dependencies_parsed_at":"2022-09-04T07:40:42.814Z","dependency_job_id":null,"html_url":"https://github.com/mikkopaderes/ember-firebaseui","commit_stats":null,"previous_names":["rmmmp/ember-firebaseui"],"tags_count":7,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mikkopaderes%2Fember-firebaseui","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mikkopaderes%2Fember-firebaseui/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mikkopaderes%2Fember-firebaseui/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/mikkopaderes%2Fember-firebaseui/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/mikkopaderes","download_url":"https://codeload.github.com/mikkopaderes/ember-firebaseui/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245791440,"owners_count":20672665,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["ember-addon","firebase"],"created_at":"2024-10-30T10:15:26.036Z","updated_at":"2025-03-27T05:31:15.610Z","avatar_url":"https://github.com/mikkopaderes.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"ember-firebaseui\n==============================================================================\n\nEmber implementation of FirebaseUI for Web\n\nInstallation\n------------------------------------------------------------------------------\n\n```\nnpm install firebase@5.x --save-dev\nember install ember-firebaseui\n```\n\n### Configuration\n\nAdd a `firebase` and `torii` property in your `config/environment.js`.\n\n```javascript\nlet ENV = {\n  ...\n\n  firebase: {\n    apiKey: '\u003capi_key\u003e',\n    authDomain: '\u003cauth_domain\u003e',\n    databaseURL: '\u003cdatabase_url\u003e',\n    projectId: '\u003cproject_id\u003e',\n    storageBucket: '\u003cstorage_bucket\u003e',\n    messagingSenderId: '\u003cmessaging_sender_id\u003e'\n  },\n  torii: { sessionServiceName: 'session' },\n\n  ...\n}\n```\n\nUsage\n------------------------------------------------------------------------------\n\n### Auth\n\n#### Torii\n\nAuthentication will make use of [Torii](https://github.com/Vestorly/torii) to manage our session.\n\nCreate a Torii adapter file in `app/torii-adapters/application.js`. It should contain the following codes.\n\n```javascript\nimport ToriiFirebaseUiAdapter from 'ember-firebaseui/torii-adapters/firebaseui';\n\nexport default ToriiFirebaseUiAdapter.extend({\n});\n```\n\n#### `{{firebaseui-auth}}`\n\n`{{firebaseui-auth}}` component is provided for rendering FirebaseUI Auth. Here's how:\n\nFirst setup your `uiConfig` which is exactly the same with [FirebaseUI Auth](https://github.com/firebase/firebaseui-web).\n\n```javascript\nimport { inject } from '@ember/service';\nimport Component from '@ember/component';\n\nimport firebase from 'firebase';\nimport firebaseui from 'firebaseui';\n\nexport default Component.extend({\n  session: inject(),\n\n  init(...args) {\n    this._super(...args);\n\n    const uiConfig = {\n      credentialHelper: firebaseui.auth.CredentialHelper.NONE,\n      callbacks: {\n        signInSuccessWithAuthResult: () =\u003e {\n          this.get('session').fetch();\n        },\n      },\n      signInOptions: [\n        firebase.auth.GoogleAuthProvider.PROVIDER_ID,\n        firebase.auth.FacebookAuthProvider.PROVIDER_ID,\n        firebase.auth.TwitterAuthProvider.PROVIDER_ID,\n        firebase.auth.GithubAuthProvider.PROVIDER_ID,\n        firebase.auth.EmailAuthProvider.PROVIDER_ID\n      ]\n    };\n\n    this.set('uiConfig', uiConfig);\n  }\n});\n```\n\nThen pass that `uiConfig` into the `{{firebaseui-auth}}` component.\n\n```javascript\n{{firebaseui-auth uiConfig=uiConfig}}\n```\n\nIn our application route, we can setup our session if the user's already signed in by calling `this.get('session').fetch()` in the `beforeModel()` hook.\n\n```javascript\nimport { inject } from '@ember/service';\nimport Route from '@ember/routing/route';\n\nexport default Route.extend({\n  session: inject(),\n\n  beforeModel() {\n    return this.get('session').fetch().catch(() =\u003e {});\n  }\n});\n```\n\nContributing\n------------------------------------------------------------------------------\n\n### Installation\n\n* `git clone \u003crepository-url\u003e`\n* `cd ember-firebaseui`\n* `npm install`\n\n### Linting\n\n* `npm run lint:js`\n* `npm run lint:js -- --fix`\n\n### Running tests\n\n* `ember test` – Runs the test suite on the current Ember version\n* `ember test --server` – Runs the test suite in \"watch mode\"\n* `npm test` – Runs `ember try:each` to test your addon against multiple Ember versions\n\n### Running the dummy application\n\n* `ember serve`\n* Visit the dummy application at [http://localhost:4200](http://localhost:4200).\n\nFor more information on using ember-cli, visit [https://ember-cli.com/](https://ember-cli.com/).\n\nLicense\n------------------------------------------------------------------------------\n\nThis project is licensed under the [MIT License](LICENSE.md).\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmikkopaderes%2Fember-firebaseui","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmikkopaderes%2Fember-firebaseui","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmikkopaderes%2Fember-firebaseui/lists"}