From e4e3fd409e329f6f508f0f8449e95cd03352dcbc Mon Sep 17 00:00:00 2001 From: simeng-li Date: Fri, 22 Apr 2022 09:54:08 +0800 Subject: [PATCH] refactor(ui): load branding info from settings (#608) * refactor(ui): load branding info from settings load branding info from settings * fix(ui): cr fix typo fix typo --- packages/phrases/src/locales/en.ts | 4 +++- packages/phrases/src/locales/zh-cn.ts | 4 +++- .../ui/src/pages/Consent/index.module.scss | 15 +++++++++++++++ packages/ui/src/pages/Consent/index.tsx | 18 ++++++++++++++++-- packages/ui/src/pages/SignIn/index.test.tsx | 1 - packages/ui/src/pages/SignIn/index.tsx | 11 ++++++++--- 6 files changed, 45 insertions(+), 8 deletions(-) create mode 100644 packages/ui/src/pages/Consent/index.module.scss diff --git a/packages/phrases/src/locales/en.ts b/packages/phrases/src/locales/en.ts index 8ab54f25e..26e74007e 100644 --- a/packages/phrases/src/locales/en.ts +++ b/packages/phrases/src/locales/en.ts @@ -34,9 +34,11 @@ const translation = { cancel: 'Cancel', }, description: { + loading: 'Loading...', + redirecting: 'Redirecting...', agree_with_terms: 'I have read and agree to the ', terms_of_use: 'Terms of Use', - creat_account: 'Create Account', + create_account: 'Create Account', forgot_password: 'Forgot Password?', or: 'Or', enter_passcode: 'The passcode has been sent to {{address}}', diff --git a/packages/phrases/src/locales/zh-cn.ts b/packages/phrases/src/locales/zh-cn.ts index 880d4ac25..28b17f6e8 100644 --- a/packages/phrases/src/locales/zh-cn.ts +++ b/packages/phrases/src/locales/zh-cn.ts @@ -36,9 +36,11 @@ const translation = { confirm: '确认', }, description: { + loading: '读取中...', + redirecting: '页面跳转中...', agree_with_terms: '我已阅读并同意 ', terms_of_use: '使用条款', - creat_account: '创建账号', + create_account: '创建账号', forgot_password: '忘记密码?', or: '或', enter_passcode: '验证码已经发送至 {{ address }}', diff --git a/packages/ui/src/pages/Consent/index.module.scss b/packages/ui/src/pages/Consent/index.module.scss new file mode 100644 index 000000000..f2c8114e5 --- /dev/null +++ b/packages/ui/src/pages/Consent/index.module.scss @@ -0,0 +1,15 @@ +@use '@/scss/underscore' as _; + +.wrapper { + position: relative; + padding: _.unit(8) _.unit(5); + @include _.flex-column; + + .header { + margin: _.unit(30) 0; + } + + .content { + @include _.text-hint; + } +} diff --git a/packages/ui/src/pages/Consent/index.tsx b/packages/ui/src/pages/Consent/index.tsx index 2935d54ff..b754dc963 100644 --- a/packages/ui/src/pages/Consent/index.tsx +++ b/packages/ui/src/pages/Consent/index.tsx @@ -1,11 +1,20 @@ -import React, { useEffect } from 'react'; +import React, { useEffect, useContext } from 'react'; +import { useTranslation } from 'react-i18next'; import { consent } from '@/apis/consent'; +import BrandingHeader from '@/components/BrandingHeader'; import useApi from '@/hooks/use-api'; +import { PageContext } from '@/hooks/use-page-context'; + +import * as styles from './index.module.scss'; const Consent = () => { + const { experienceSettings } = useContext(PageContext); + const { logoUrl = '' } = experienceSettings?.branding ?? {}; const { result, run: asyncConsent } = useApi(consent); + const { t } = useTranslation(undefined, { keyPrefix: 'main_flow' }); + useEffect(() => { void asyncConsent(); }, [asyncConsent]); @@ -16,7 +25,12 @@ const Consent = () => { } }, [result]); - return
loading...
; + return ( +
+ +
{t('description.loading')}
+
+ ); }; export default Consent; diff --git a/packages/ui/src/pages/SignIn/index.test.tsx b/packages/ui/src/pages/SignIn/index.test.tsx index b4598f976..679f708e5 100644 --- a/packages/ui/src/pages/SignIn/index.test.tsx +++ b/packages/ui/src/pages/SignIn/index.test.tsx @@ -6,7 +6,6 @@ import SignIn from '@/pages/SignIn'; describe('', () => { test('renders without exploding', async () => { const { queryByText } = render(); - expect(queryByText('Welcome to Logto')).not.toBeNull(); expect(queryByText('action.sign_in')).not.toBeNull(); }); }); diff --git a/packages/ui/src/pages/SignIn/index.tsx b/packages/ui/src/pages/SignIn/index.tsx index 890113acc..6c1666e12 100644 --- a/packages/ui/src/pages/SignIn/index.tsx +++ b/packages/ui/src/pages/SignIn/index.tsx @@ -1,20 +1,25 @@ +import { BrandingStyle } from '@logto/schemas'; import classNames from 'classnames'; -import React from 'react'; +import React, { useContext } from 'react'; import BrandingHeader from '@/components/BrandingHeader'; import TextLink from '@/components/TextLink'; import UsernameSignin from '@/containers/UsernameSignin'; +import { PageContext } from '@/hooks/use-page-context'; import * as styles from './index.module.scss'; const SignIn = () => { + const { experienceSettings } = useContext(PageContext); + const { slogan, logoUrl = '', style } = experienceSettings?.branding ?? {}; + return (
{/* TODO: load content from sign-in experience */}