From 31255761f23313677230ca0400aee8130ea42e41 Mon Sep 17 00:00:00 2001 From: German Lena Date: Mon, 17 Oct 2016 15:04:10 -0300 Subject: [PATCH 1/8] added support for custom oauth2 connections --- css/social_icons.css | 6 ++++++ src/connection/social/index.js | 7 +++++++ src/core/client/index.js | 2 ++ src/core/index.js | 6 ++++-- src/field/social/social_buttons_pane.jsx | 23 +++++++++++++++++------ src/ui/button/auth_button.jsx | 24 ++++++++++++++++++++---- 6 files changed, 56 insertions(+), 12 deletions(-) diff --git a/css/social_icons.css b/css/social_icons.css index 8b10d580d..0d3261e2d 100644 --- a/css/social_icons.css +++ b/css/social_icons.css @@ -36,6 +36,9 @@ .auth0-lock-social-button[data-provider="github"] { background-color: #333; } +.auth0-lock-social-button[data-provider="oauth2"] { + background-color: #eb5424; +} .auth0-lock-social-button[data-provider="paypal"] { background-color: #009cde; } @@ -156,6 +159,9 @@ .auth0-lock-social-button[data-provider^=miicard] .auth0-lock-social-button-icon { background-image: url(""); } +.auth0-lock-social-button[data-provider^=oauth2] .auth0-lock-social-button-icon { + background-image: url(""); +} .auth0-lock-social-button[data-provider^=paypal] .auth0-lock-social-button-icon { background-image: url(""); } diff --git a/src/connection/social/index.js b/src/connection/social/index.js index c97fb1ec9..9a305bf97 100644 --- a/src/connection/social/index.js +++ b/src/connection/social/index.js @@ -52,6 +52,9 @@ export function initSocial(m, options) { } export function displayName(connection) { + if ("oauth2" === connection.get("strategy")) { + return connection.get("name"); + } return STRATEGIES[connection.get("strategy")]; } @@ -71,6 +74,10 @@ export function socialConnections(m) { return l.connections(m, "social"); } +export function socialButtonsTheme(m) { + return l.ui.socialButtonsTheme(m); +} + export function useBigButtons(m, notFoundLimit) { const style = get(m, "socialButtonStyle"); return style diff --git a/src/core/client/index.js b/src/core/client/index.js index e05f5addf..b952ddcea 100644 --- a/src/core/client/index.js +++ b/src/core/client/index.js @@ -39,6 +39,8 @@ function strategyNameToConnectionType(str) { return "social"; } else if (ENTERPRISE_STRATEGIES[str]) { return "enterprise"; + } else if (str === "oauth2") { + return "social"; } else { return "unknown"; } diff --git a/src/core/index.js b/src/core/index.js index aebfca98c..65186180b 100644 --- a/src/core/index.js +++ b/src/core/index.js @@ -102,7 +102,7 @@ export function stopRendering(m) { function extractUIOptions(id, options) { const closable = options.container ? false : undefined === options.closable ? true : !!options.closable; const theme = options.theme || {}; - const { labeledSubmitButton, logo, primaryColor } = theme; + const { labeledSubmitButton, logo, primaryColor, socialButtons } = theme; const avatar = options.avatar !== null; const customAvatarProvider = options.avatar @@ -127,7 +127,8 @@ function extractUIOptions(id, options) { mobile: undefined === options.mobile ? false : !!options.mobile, popupOptions: undefined === options.popupOptions ? {} : options.popupOptions, primaryColor: typeof primaryColor === "string" ? primaryColor : undefined, - rememberLastLogin: undefined === options.rememberLastLogin ? true : !!options.rememberLastLogin + rememberLastLogin: undefined === options.rememberLastLogin ? true : !!options.rememberLastLogin, + socialButtonsTheme: typeof socialButtons === "object" ? socialButtons : {} }); } @@ -149,6 +150,7 @@ export const ui = { mobile: lock => getUIAttribute(lock, "mobile"), popupOptions: lock => getUIAttribute(lock, "popupOptions"), primaryColor: lock => getUIAttribute(lock, "primaryColor"), + socialButtonsTheme: lock => getUIAttribute(lock, "socialButtonsTheme"), rememberLastLogin: m => tget( m, "rememberLastLogin", diff --git a/src/field/social/social_buttons_pane.jsx b/src/field/social/social_buttons_pane.jsx index 5caad5857..d5a56b2a0 100644 --- a/src/field/social/social_buttons_pane.jsx +++ b/src/field/social/social_buttons_pane.jsx @@ -2,7 +2,7 @@ import React from 'react'; import AuthButton from '../../ui/button/auth_button'; import * as l from '../../core/index'; import { logIn } from '../../quick-auth/actions'; -import { displayName, socialConnections } from '../../connection/social/index'; +import { displayName, socialConnections, socialButtonsTheme } from '../../connection/social/index'; export default class SocialButtonsPane extends React.Component { @@ -21,15 +21,26 @@ export default class SocialButtonsPane extends React.Component { const headerText = instructions || null; const header = headerText &&

{headerText}

; - const buttons = socialConnections(lock).map(x => ( - { + const buttonTheme = theme.get(x.get("name")); + const connectionName = buttonTheme && buttonTheme.get("displayName"); + const primaryColor = buttonTheme && buttonTheme.get("primaryColor"); + const foregroundColor = buttonTheme && buttonTheme.get("foregroundColor"); + const icon = buttonTheme && buttonTheme.get("icon"); + + return( logIn(l.id(lock), x)} strategy={x.get("strategy")} - /> - )); + primaryColor={primaryColor} + foregroundColor={foregroundColor} + icon={icon} + />) + }); const loading = showLoading &&
diff --git a/src/ui/button/auth_button.jsx b/src/ui/button/auth_button.jsx index 250914e80..f800d8c41 100644 --- a/src/ui/button/auth_button.jsx +++ b/src/ui/button/auth_button.jsx @@ -1,21 +1,35 @@ import React from 'react'; const AuthButton = (props) => { - const { disabled, isBig, label, onClick, strategy } = props; + const { + disabled, + isBig, + label, + onClick, + strategy, + icon, + primaryColor, + foregroundColor + } = props; let className = "auth0-lock-social-button"; if (isBig) className += " auth0-lock-social-big-button"; + const backgroundStyle = primaryColor ? { backgroundColor: primaryColor } : {}; + const foregroundStyle = foregroundColor ? { color: foregroundColor } : {}; + const iconStyle = icon ? { backgroundImage: icon } : {}; + return ( @@ -27,7 +41,9 @@ AuthButton.propTypes = { isBig: React.PropTypes.bool.isRequired, label: React.PropTypes.string.isRequired, onClick: React.PropTypes.func.isRequired, - strategy: React.PropTypes.string.isRequired + strategy: React.PropTypes.string.isRequired, + icon: React.PropTypes.string, + background: React.PropTypes.string }; AuthButton.defaultProps = { From ceb2f98e989850af37e288b218efc16d72e4315c Mon Sep 17 00:00:00 2001 From: German Lena Date: Mon, 17 Oct 2016 15:18:55 -0300 Subject: [PATCH 2/8] added info to the readme --- README.md | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index b89952f5e..330ca02e5 100644 --- a/README.md +++ b/README.md @@ -154,7 +154,15 @@ var options = { theme: { labeledSubmitButton: false, logo: "https://example.com/assets/logo.png", - primaryColor: "green" + primaryColor: "green", + socialButtons: { + connectionName: { + displayName: "...", + primaryColor: "...", + foregroundColor: "...", + icon: "url(...)" + } + } } }; ``` @@ -162,6 +170,11 @@ var options = { - **labeledSubmitButton {Boolean}**: Indicates whether or not the submit button should have a label. Defaults to `true`. When set to `false` a icon will be shown. The labels can be customized through the `languageDictionary`. - **logo {String}**: Url for an image that will be placed in the Lock's header. Defaults to Auth0's logo. - **primaryColor {String}**: Defines the primary color of the Lock, all colors used in the widget will be calculated from it. This option is useful when providing a custom `logo` to ensure all colors go well together with the logo's color palette. Defaults to `"#ea5323"`. +- **socialButtons {Object}**: Allows the customization of the custom oauth2 login buttons. + + **displayName {String}**: The name to show instead of the connection name. + + **primaryColor {String}**: The button's background color. Defaults to `"#eb5424"`. + + **foregroundColor {String}**: The button's text color. Defaults to `"#FFFFFF"`. + + **icon {String}**: The connection's icon. It should be a valid CSS `background-image` value. For example:`"url(http://site.com/logo.png)"`. #### Authentication options From 1ba46dfbd6ee1fe205ac021485ea7354441582ec Mon Sep 17 00:00:00 2001 From: German Lena Date: Mon, 17 Oct 2016 15:30:35 -0300 Subject: [PATCH 3/8] custom scopes should use the conn name instead of strategy --- src/quick-auth/actions.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/quick-auth/actions.js b/src/quick-auth/actions.js index 312352eda..885185d10 100644 --- a/src/quick-auth/actions.js +++ b/src/quick-auth/actions.js @@ -10,7 +10,7 @@ export function skipQuickAuth(id) { export function logIn(id, connection, loginHint) { const m = read(getEntity, "lock", id); const connectionScopes = l.auth.connectionScopes(m); - const scopes = connectionScopes.get(connection.get("strategy")); + const scopes = connectionScopes.get(connection.get("name")); const params = { connection: connection.get("name"), connection_scope: scopes ? scopes.toJS() : [] From 5bfd6f17d70bf97e38280b8ed060772103083be0 Mon Sep 17 00:00:00 2001 From: German Lena Date: Tue, 18 Oct 2016 15:33:12 -0300 Subject: [PATCH 4/8] fixed propt types --- src/ui/button/auth_button.jsx | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/ui/button/auth_button.jsx b/src/ui/button/auth_button.jsx index f800d8c41..120141116 100644 --- a/src/ui/button/auth_button.jsx +++ b/src/ui/button/auth_button.jsx @@ -43,7 +43,8 @@ AuthButton.propTypes = { onClick: React.PropTypes.func.isRequired, strategy: React.PropTypes.string.isRequired, icon: React.PropTypes.string, - background: React.PropTypes.string + primaryColor: React.PropTypes.string, + foregroundColor: React.PropTypes.string }; AuthButton.defaultProps = { From f115730890bdfcf644c99b92e4e4ed85b2d4bbdf Mon Sep 17 00:00:00 2001 From: German Lena Date: Tue, 18 Oct 2016 16:06:53 -0300 Subject: [PATCH 5/8] support oauth1 + rename configuration --- README.md | 2 +- src/connection/social/index.js | 6 +++--- src/core/index.js | 6 +++--- src/field/social/social_buttons_pane.jsx | 6 +++--- 4 files changed, 10 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index 330ca02e5..7d3cd3a42 100644 --- a/README.md +++ b/README.md @@ -155,7 +155,7 @@ var options = { labeledSubmitButton: false, logo: "https://example.com/assets/logo.png", primaryColor: "green", - socialButtons: { + authButtons: { connectionName: { displayName: "...", primaryColor: "...", diff --git a/src/connection/social/index.js b/src/connection/social/index.js index 9a305bf97..505825894 100644 --- a/src/connection/social/index.js +++ b/src/connection/social/index.js @@ -52,7 +52,7 @@ export function initSocial(m, options) { } export function displayName(connection) { - if ("oauth2" === connection.get("strategy")) { + if (["oauth1", "oauth2"].indexOf(connection.get("strategy")) !== -1) { return connection.get("name"); } return STRATEGIES[connection.get("strategy")]; @@ -74,8 +74,8 @@ export function socialConnections(m) { return l.connections(m, "social"); } -export function socialButtonsTheme(m) { - return l.ui.socialButtonsTheme(m); +export function authButtonsTheme(m) { + return l.ui.authButtonsTheme(m); } export function useBigButtons(m, notFoundLimit) { diff --git a/src/core/index.js b/src/core/index.js index 65186180b..75fd63317 100644 --- a/src/core/index.js +++ b/src/core/index.js @@ -102,7 +102,7 @@ export function stopRendering(m) { function extractUIOptions(id, options) { const closable = options.container ? false : undefined === options.closable ? true : !!options.closable; const theme = options.theme || {}; - const { labeledSubmitButton, logo, primaryColor, socialButtons } = theme; + const { labeledSubmitButton, logo, primaryColor, authButtons } = theme; const avatar = options.avatar !== null; const customAvatarProvider = options.avatar @@ -128,7 +128,7 @@ function extractUIOptions(id, options) { popupOptions: undefined === options.popupOptions ? {} : options.popupOptions, primaryColor: typeof primaryColor === "string" ? primaryColor : undefined, rememberLastLogin: undefined === options.rememberLastLogin ? true : !!options.rememberLastLogin, - socialButtonsTheme: typeof socialButtons === "object" ? socialButtons : {} + authButtonsTheme: typeof authButtons === "object" ? authButtons : {} }); } @@ -150,7 +150,7 @@ export const ui = { mobile: lock => getUIAttribute(lock, "mobile"), popupOptions: lock => getUIAttribute(lock, "popupOptions"), primaryColor: lock => getUIAttribute(lock, "primaryColor"), - socialButtonsTheme: lock => getUIAttribute(lock, "socialButtonsTheme"), + authButtonsTheme: lock => getUIAttribute(lock, "authButtonsTheme"), rememberLastLogin: m => tget( m, "rememberLastLogin", diff --git a/src/field/social/social_buttons_pane.jsx b/src/field/social/social_buttons_pane.jsx index d5a56b2a0..026fa8c3f 100644 --- a/src/field/social/social_buttons_pane.jsx +++ b/src/field/social/social_buttons_pane.jsx @@ -2,7 +2,7 @@ import React from 'react'; import AuthButton from '../../ui/button/auth_button'; import * as l from '../../core/index'; import { logIn } from '../../quick-auth/actions'; -import { displayName, socialConnections, socialButtonsTheme } from '../../connection/social/index'; +import { displayName, socialConnections, authButtonsTheme } from '../../connection/social/index'; export default class SocialButtonsPane extends React.Component { @@ -21,10 +21,10 @@ export default class SocialButtonsPane extends React.Component { const headerText = instructions || null; const header = headerText &&

{headerText}

; - const theme = socialButtonsTheme(lock); + const themes = authButtonsTheme(lock); const buttons = socialConnections(lock).map(x => { - const buttonTheme = theme.get(x.get("name")); + const buttonTheme = themes.get(x.get("name")); const connectionName = buttonTheme && buttonTheme.get("displayName"); const primaryColor = buttonTheme && buttonTheme.get("primaryColor"); const foregroundColor = buttonTheme && buttonTheme.get("foregroundColor"); From 228c4543c82f92d339f3b835d759390a950c90b1 Mon Sep 17 00:00:00 2001 From: German Lena Date: Tue, 18 Oct 2016 16:07:57 -0300 Subject: [PATCH 6/8] =?UTF-8?q?forgot=20the=20that=20mention=20?= =?UTF-8?q?=F0=9F=90=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 7d3cd3a42..4ae8605cc 100644 --- a/README.md +++ b/README.md @@ -170,7 +170,7 @@ var options = { - **labeledSubmitButton {Boolean}**: Indicates whether or not the submit button should have a label. Defaults to `true`. When set to `false` a icon will be shown. The labels can be customized through the `languageDictionary`. - **logo {String}**: Url for an image that will be placed in the Lock's header. Defaults to Auth0's logo. - **primaryColor {String}**: Defines the primary color of the Lock, all colors used in the widget will be calculated from it. This option is useful when providing a custom `logo` to ensure all colors go well together with the logo's color palette. Defaults to `"#ea5323"`. -- **socialButtons {Object}**: Allows the customization of the custom oauth2 login buttons. +- **authButtons {Object}**: Allows the customization of the custom oauth2 login buttons. + **displayName {String}**: The name to show instead of the connection name. + **primaryColor {String}**: The button's background color. Defaults to `"#eb5424"`. + **foregroundColor {String}**: The button's text color. Defaults to `"#FFFFFF"`. From a4681ba0f65bd3314ea8527d6a0d21884f41017f Mon Sep 17 00:00:00 2001 From: German Lena Date: Tue, 18 Oct 2016 16:10:49 -0300 Subject: [PATCH 7/8] check the strategy to group --- src/core/client/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core/client/index.js b/src/core/client/index.js index b952ddcea..da66edaee 100644 --- a/src/core/client/index.js +++ b/src/core/client/index.js @@ -39,7 +39,7 @@ function strategyNameToConnectionType(str) { return "social"; } else if (ENTERPRISE_STRATEGIES[str]) { return "enterprise"; - } else if (str === "oauth2") { + } else if (["oauth1", "oauth2"].indexOf(str) !== -1) { return "social"; } else { return "unknown"; From cec5d6d5dbae60d069194282157fbaa86541e34a Mon Sep 17 00:00:00 2001 From: German Lena Date: Tue, 18 Oct 2016 16:27:07 -0300 Subject: [PATCH 8/8] forced the icon to be a url --- README.md | 4 ++-- src/ui/button/auth_button.jsx | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 4ae8605cc..f991d2c81 100644 --- a/README.md +++ b/README.md @@ -160,7 +160,7 @@ var options = { displayName: "...", primaryColor: "...", foregroundColor: "...", - icon: "url(...)" + icon: "http://.../logo.png" } } } @@ -174,7 +174,7 @@ var options = { + **displayName {String}**: The name to show instead of the connection name. + **primaryColor {String}**: The button's background color. Defaults to `"#eb5424"`. + **foregroundColor {String}**: The button's text color. Defaults to `"#FFFFFF"`. - + **icon {String}**: The connection's icon. It should be a valid CSS `background-image` value. For example:`"url(http://site.com/logo.png)"`. + + **icon {String}**: The icon's url for the connection. For example:`"http://site.com/logo.png"`. #### Authentication options diff --git a/src/ui/button/auth_button.jsx b/src/ui/button/auth_button.jsx index 120141116..5b480cbfe 100644 --- a/src/ui/button/auth_button.jsx +++ b/src/ui/button/auth_button.jsx @@ -17,7 +17,7 @@ const AuthButton = (props) => { const backgroundStyle = primaryColor ? { backgroundColor: primaryColor } : {}; const foregroundStyle = foregroundColor ? { color: foregroundColor } : {}; - const iconStyle = icon ? { backgroundImage: icon } : {}; + const iconStyle = icon ? { backgroundImage: `url('${icon}')` } : {}; return (