禁用帐户选择器 FirebaseUI React
Disable account chooser FirebaseUI React
我正在为一些看似小菜一碟的事情苦苦挣扎,但我仍然无法找到解决方案。
我正在使用 reactjs 和 firebaseUI web react. Everything is just fine, except the fact that when I try to login using email/password, it takes me to accountchooser 实施 firebase 身份验证过程,这是我不想要的行为。
我搜索了文档、github 问题等...但我发现的只是在 uiConfig
对象中添加以下行:
credentialHelper: firebaseui.auth.CredentialHelper.NONE
问题是 react 抛出一个错误,抱怨 firebaseui 没有被定义,我想这很正常,因为我从来没有导入它。
我在浏览时发现了一个提示,告诉我要将 uiCallback
prop 传递给组件,但我无法理解。
到目前为止,这是我的代码:
import React, { Component } from 'react';
import '../App.css';
import StyledFirebaseAuth from 'react-firebaseui/StyledFirebaseAuth';
import * as firebase from 'firebase'
const uiConfig = {
signInFlow: 'popup',
signInSuccessUrl: '/signedIn',
signInOptions: [
firebase.auth.GoogleAuthProvider.PROVIDER_ID,
firebase.auth.FacebookAuthProvider.PROVIDER_ID,
firebase.auth.EmailAuthProvider.PROVIDER_ID,
],
};
export default class SignInScreen extends Component {
render() {
return (
<div>
<h1>My App</h1>
<p>Please sign-in:</p>
<StyledFirebaseAuth uiConfig={uiConfig} firebaseAuth={firebase.auth()}/>
</div>
);
}
}
我什至不知道我是否正在尝试正确的事情。任何帮助将不胜感激。
尝试将 uiConfig
设为 SignInScreen class
的 属性,然后在将回调传递给组件时使用 this.uiConfig
引用回调
import React, { Component } from 'react';
import '../App.css';
import StyledFirebaseAuth from 'react-firebaseui/StyledFirebaseAuth';
import * as firebase from 'firebase'
export default class SignInScreen extends Component {
uiConfig = {
signInFlow: 'popup',
signInSuccessUrl: '/signedIn',
signInOptions: [
firebase.auth.GoogleAuthProvider.PROVIDER_ID,
firebase.auth.FacebookAuthProvider.PROVIDER_ID,
firebase.auth.EmailAuthProvider.PROVIDER_ID,
],
'credentialHelper': firebaseui.auth.CredentialHelper.NONE
};
render() {
return (
<div>
<h1>My App</h1>
<p>Please sign-in:</p>
<StyledFirebaseAuth uiConfig={this.uiConfig} firebaseAuth={firebase.auth()}/>
</div>
);
}
}
这基于提供的示例 here
好吧,对于那些可能有帮助的人,我找到了解决该问题的方法。
yarn add firebaseui
import firebaseui from 'firebaseui'
- 在 uiConfig 对象中设置
credentialHelper: firebaseui.auth.CredentialHelper.NONE
。
我不知道在 firebaseUI web react 上安装 firebaseui 是否好,但它解决了我的问题。
谢谢拉菲克!几个小时以来,我一直在寻找解决方案。
事实证明 firebaseui.auth.CredentialHelper.NONE
=== 'none',所以我使用它而不是导入额外的 firebaseui。
我都不喜欢任何一种解决方案(导入额外的东西或使用常量的基础值),我当然希望他们在 react-firebaseui 中包含该常量。
这对我有用:根据上面的评论,在 uiConfig 中的 signInOptions 数组下添加 credentialHelper。完整代码如下:
import React, { Component } from 'react';
import '../App.css';
import StyledFirebaseAuth from 'react-firebaseui/StyledFirebaseAuth';
import * as firebase from 'firebase'
const uiConfig = {
signInFlow: 'popup',
signInSuccessUrl: '/signedIn',
signInOptions: [
firebase.auth.GoogleAuthProvider.PROVIDER_ID,
firebase.auth.FacebookAuthProvider.PROVIDER_ID,
firebase.auth.EmailAuthProvider.PROVIDER_ID,
],
credentialHelper: 'none'
};
export default class SignInScreen extends Component {
render() {
return (
<div>
<h1>My App</h1>
<p>Please sign-in:</p>
<StyledFirebaseAuth uiConfig={uiConfig} firebaseAuth={firebase.auth()}/>
</div>
);
}
}
我正在为一些看似小菜一碟的事情苦苦挣扎,但我仍然无法找到解决方案。
我正在使用 reactjs 和 firebaseUI web react. Everything is just fine, except the fact that when I try to login using email/password, it takes me to accountchooser 实施 firebase 身份验证过程,这是我不想要的行为。
我搜索了文档、github 问题等...但我发现的只是在 uiConfig
对象中添加以下行:
credentialHelper: firebaseui.auth.CredentialHelper.NONE
问题是 react 抛出一个错误,抱怨 firebaseui 没有被定义,我想这很正常,因为我从来没有导入它。
我在浏览时发现了一个提示,告诉我要将 uiCallback
prop 传递给组件,但我无法理解。
到目前为止,这是我的代码:
import React, { Component } from 'react';
import '../App.css';
import StyledFirebaseAuth from 'react-firebaseui/StyledFirebaseAuth';
import * as firebase from 'firebase'
const uiConfig = {
signInFlow: 'popup',
signInSuccessUrl: '/signedIn',
signInOptions: [
firebase.auth.GoogleAuthProvider.PROVIDER_ID,
firebase.auth.FacebookAuthProvider.PROVIDER_ID,
firebase.auth.EmailAuthProvider.PROVIDER_ID,
],
};
export default class SignInScreen extends Component {
render() {
return (
<div>
<h1>My App</h1>
<p>Please sign-in:</p>
<StyledFirebaseAuth uiConfig={uiConfig} firebaseAuth={firebase.auth()}/>
</div>
);
}
}
我什至不知道我是否正在尝试正确的事情。任何帮助将不胜感激。
尝试将 uiConfig
设为 SignInScreen class
的 属性,然后在将回调传递给组件时使用 this.uiConfig
引用回调
import React, { Component } from 'react';
import '../App.css';
import StyledFirebaseAuth from 'react-firebaseui/StyledFirebaseAuth';
import * as firebase from 'firebase'
export default class SignInScreen extends Component {
uiConfig = {
signInFlow: 'popup',
signInSuccessUrl: '/signedIn',
signInOptions: [
firebase.auth.GoogleAuthProvider.PROVIDER_ID,
firebase.auth.FacebookAuthProvider.PROVIDER_ID,
firebase.auth.EmailAuthProvider.PROVIDER_ID,
],
'credentialHelper': firebaseui.auth.CredentialHelper.NONE
};
render() {
return (
<div>
<h1>My App</h1>
<p>Please sign-in:</p>
<StyledFirebaseAuth uiConfig={this.uiConfig} firebaseAuth={firebase.auth()}/>
</div>
);
}
}
这基于提供的示例 here
好吧,对于那些可能有帮助的人,我找到了解决该问题的方法。
yarn add firebaseui
import firebaseui from 'firebaseui'
- 在 uiConfig 对象中设置
credentialHelper: firebaseui.auth.CredentialHelper.NONE
。
我不知道在 firebaseUI web react 上安装 firebaseui 是否好,但它解决了我的问题。
谢谢拉菲克!几个小时以来,我一直在寻找解决方案。
事实证明 firebaseui.auth.CredentialHelper.NONE
=== 'none',所以我使用它而不是导入额外的 firebaseui。
我都不喜欢任何一种解决方案(导入额外的东西或使用常量的基础值),我当然希望他们在 react-firebaseui 中包含该常量。
这对我有用:根据上面的评论,在 uiConfig 中的 signInOptions 数组下添加 credentialHelper。完整代码如下:
import React, { Component } from 'react';
import '../App.css';
import StyledFirebaseAuth from 'react-firebaseui/StyledFirebaseAuth';
import * as firebase from 'firebase'
const uiConfig = {
signInFlow: 'popup',
signInSuccessUrl: '/signedIn',
signInOptions: [
firebase.auth.GoogleAuthProvider.PROVIDER_ID,
firebase.auth.FacebookAuthProvider.PROVIDER_ID,
firebase.auth.EmailAuthProvider.PROVIDER_ID,
],
credentialHelper: 'none'
};
export default class SignInScreen extends Component {
render() {
return (
<div>
<h1>My App</h1>
<p>Please sign-in:</p>
<StyledFirebaseAuth uiConfig={uiConfig} firebaseAuth={firebase.auth()}/>
</div>
);
}
}