0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-03-31 22:51:25 -05:00

feat(console): cloud congrats page (#3125)

This commit is contained in:
Xiao Yijun 2023-02-16 18:05:09 +08:00 committed by GitHub
parent 951ea0de6d
commit 4c384a7715
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
20 changed files with 283 additions and 7 deletions

View file

@ -53,6 +53,7 @@ import ApiResourcePermissions from './pages/ApiResourceDetails/ApiResourcePermis
import ApiResourceSettings from './pages/ApiResourceDetails/ApiResourceSettings';
import Cloud from './pages/Cloud';
import CloudAboutUser from './pages/Cloud/pages/About';
import CloudCongrats from './pages/Cloud/pages/Congrats';
import CloudWelcome from './pages/Cloud/pages/Welcome';
import { CloudPage } from './pages/Cloud/types';
import Profile from './pages/Profile';
@ -87,6 +88,8 @@ const Main = () => {
<Route index element={<Navigate replace to={CloudPage.Welcome} />} />
<Route path={CloudPage.Welcome} element={<CloudWelcome />} />
<Route path={CloudPage.AboutUser} element={<CloudAboutUser />} />
<Route path={CloudPage.Congrats} element={<CloudCongrats />} />
<Route path="*" element={<NotFound />} />
</Route>
<Route element={<AppContent />}>
<Route path="*" element={<NotFound />} />

View file

@ -0,0 +1,3 @@
<svg width="21" height="20" viewBox="0 0 21 20" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M11.1917 11.2083C11.1155 11.0949 11.0126 11.002 10.8919 10.9377C10.7713 10.8734 10.6368 10.8398 10.5001 10.8398C10.3634 10.8398 10.2288 10.8734 10.1082 10.9377C9.9876 11.002 9.88464 11.0949 9.80841 11.2083L6.47508 16.2083C6.40194 16.335 6.36344 16.4787 6.36344 16.625C6.36344 16.7713 6.40194 16.915 6.47508 17.0417C6.54029 17.1718 6.63846 17.2826 6.75982 17.363C6.88117 17.4435 7.02147 17.4907 7.16675 17.5H13.8334C13.9842 17.4996 14.132 17.4583 14.2611 17.3805C14.3903 17.3028 14.4959 17.1914 14.5667 17.0583C14.6337 16.928 14.665 16.7824 14.6577 16.6361C14.6504 16.4898 14.6047 16.348 14.5251 16.225L11.1917 11.2083ZM8.72508 15.8333L10.5001 13.1667L12.2751 15.8333H8.72508ZM16.3334 2.5H4.66675C4.00371 2.5 3.36782 2.76339 2.89898 3.23223C2.43014 3.70107 2.16675 4.33696 2.16675 5V12.5C2.16675 13.163 2.43014 13.7989 2.89898 14.2678C3.36782 14.7366 4.00371 15 4.66675 15H5.37508C5.5961 15 5.80806 14.9122 5.96434 14.7559C6.12062 14.5996 6.20842 14.3877 6.20842 14.1667C6.20842 13.9457 6.12062 13.7337 5.96434 13.5774C5.80806 13.4211 5.5961 13.3333 5.37508 13.3333H4.66675C4.44573 13.3333 4.23377 13.2455 4.07749 13.0893C3.92121 12.933 3.83341 12.721 3.83341 12.5V5C3.83341 4.77899 3.92121 4.56702 4.07749 4.41074C4.23377 4.25446 4.44573 4.16667 4.66675 4.16667H16.3334C16.5544 4.16667 16.7664 4.25446 16.9227 4.41074C17.079 4.56702 17.1667 4.77899 17.1667 5V12.5C17.1667 12.721 17.079 12.933 16.9227 13.0893C16.7664 13.2455 16.5544 13.3333 16.3334 13.3333H15.6251C15.4041 13.3333 15.1921 13.4211 15.0358 13.5774C14.8795 13.7337 14.7917 13.9457 14.7917 14.1667C14.7917 14.3877 14.8795 14.5996 15.0358 14.7559C15.1921 14.9122 15.4041 15 15.6251 15H16.3334C16.9965 15 17.6323 14.7366 18.1012 14.2678C18.57 13.7989 18.8334 13.163 18.8334 12.5V5C18.8334 4.33696 18.57 3.70107 18.1012 3.23223C17.6323 2.76339 16.9965 2.5 16.3334 2.5Z" fill="currentColor"/>
</svg>

After

Width:  |  Height:  |  Size: 1.9 KiB

View file

@ -0,0 +1,6 @@
<svg width="36" height="36" viewBox="0 0 36 36" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M28.8149 4H30.8109V5H28.8149V4Z" fill="#66757F"/>
<path d="M2 9V29.8333C2 32.1344 3.791 34 6 34H30C32.209 34 34 32.1344 34 29.8333V9H2Z" fill="#C9C5D0"/>
<path d="M30 2H6C3.791 2 2 3.393 2 5.11111V9H34V5.11111C34 3.393 32.209 2 30 2Z" fill="#DD3730"/>
<path d="M11 13C11 12.4477 11.4477 12 12 12H14C14.5523 12 15 12.4477 15 13V15C15 15.5523 14.5523 16 14 16H12C11.4477 16 11 15.5523 11 15V13ZM16 13C16 12.4477 16.4477 12 17 12H19C19.5523 12 20 12.4477 20 13V15C20 15.5523 19.5523 16 19 16H17C16.4477 16 16 15.5523 16 15V13ZM21 13C21 12.4477 21.4477 12 22 12H24C24.5523 12 25 12.4477 25 13V15C25 15.5523 24.5523 16 24 16H22C21.4477 16 21 15.5523 21 15V13ZM26 13C26 12.4477 26.4477 12 27 12H29C29.5523 12 30 12.4477 30 13V15C30 15.5523 29.5523 16 29 16H27C26.4477 16 26 15.5523 26 15V13ZM6 18C6 17.4477 6.44772 17 7 17H9C9.55228 17 10 17.4477 10 18V20C10 20.5523 9.55228 21 9 21H7C6.44772 21 6 20.5523 6 20V18ZM11 18C11 17.4477 11.4477 17 12 17H14C14.5523 17 15 17.4477 15 18V20C15 20.5523 14.5523 21 14 21H12C11.4477 21 11 20.5523 11 20V18ZM16 18C16 17.4477 16.4477 17 17 17H19C19.5523 17 20 17.4477 20 18V20C20 20.5523 19.5523 21 19 21H17C16.4477 21 16 20.5523 16 20V18ZM21 18C21 17.4477 21.4477 17 22 17H24C24.5523 17 25 17.4477 25 18V20C25 20.5523 24.5523 21 24 21H22C21.4477 21 21 20.5523 21 20V18ZM26 18C26 17.4477 26.4477 17 27 17H29C29.5523 17 30 17.4477 30 18V20C30 20.5523 29.5523 21 29 21H27C26.4477 21 26 20.5523 26 20V18ZM6 23C6 22.4477 6.44772 22 7 22H9C9.55228 22 10 22.4477 10 23V25C10 25.5523 9.55228 26 9 26H7C6.44772 26 6 25.5523 6 25V23ZM11 23C11 22.4477 11.4477 22 12 22H14C14.5523 22 15 22.4477 15 23V25C15 25.5523 14.5523 26 14 26H12C11.4477 26 11 25.5523 11 25V23ZM16 23C16 22.4477 16.4477 22 17 22H19C19.5523 22 20 22.4477 20 23V25C20 25.5523 19.5523 26 19 26H17C16.4477 26 16 25.5523 16 25V23ZM21 23C21 22.4477 21.4477 22 22 22H24C24.5523 22 25 22.4477 25 23V25C25 25.5523 24.5523 26 24 26H22C21.4477 26 21 25.5523 21 25V23ZM26 23C26 22.4477 26.4477 22 27 22H29C29.5523 22 30 22.4477 30 23V25C30 25.5523 29.5523 26 29 26H27C26.4477 26 26 25.5523 26 25V23ZM6 28C6 27.4477 6.44772 27 7 27H9C9.55228 27 10 27.4477 10 28V30C10 30.5523 9.55228 31 9 31H7C6.44772 31 6 30.5523 6 30V28ZM11 28C11 27.4477 11.4477 27 12 27H14C14.5523 27 15 27.4477 15 28V30C15 30.5523 14.5523 31 14 31H12C11.4477 31 11 30.5523 11 30V28ZM16 28C16 27.4477 16.4477 27 17 27H19C19.5523 27 20 27.4477 20 28V30C20 30.5523 19.5523 31 19 31H17C16.4477 31 16 30.5523 16 30V28Z" fill="white"/>
</svg>

After

Width:  |  Height:  |  Size: 2.5 KiB

View file

@ -0,0 +1,17 @@
<svg width="100" height="100" viewBox="0 0 100 100" fill="none" xmlns="http://www.w3.org/2000/svg">
<rect x="25" y="12.5" width="41.6667" height="75" rx="4" fill="url(#paint0_linear_272_72834)"/>
<path d="M49.5001 79.1667C49.5001 81.1917 47.8585 82.8333 45.8334 82.8333C43.8084 82.8333 42.1667 81.1917 42.1667 79.1667C42.1667 77.1416 43.8084 75.5 45.8334 75.5C47.8585 75.5 49.5001 77.1416 49.5001 79.1667Z" stroke="#CABEFF"/>
<path d="M39.5833 18.7501C39.5833 17.5995 40.516 16.6667 41.6666 16.6667H49.9999C51.1505 16.6667 52.0833 17.5995 52.0833 18.7501C52.0833 19.9007 51.1505 20.8334 49.9999 20.8334H41.6666C40.516 20.8334 39.5833 19.9007 39.5833 18.7501Z" fill="#302F38"/>
<path opacity="0.64" d="M87.5 50.0001C87.5 53.1931 76.3071 64.5834 62.5 64.5834C48.6929 64.5834 37.5 53.1931 37.5 50.0001C37.5 46.807 48.6929 35.4167 62.5 35.4167C65.2587 35.4167 67.9131 35.8715 70.3947 36.6247C72.8088 37.3574 75.0593 38.3726 77.0833 39.5264C83.392 43.1227 87.5 48.0657 87.5 50.0001Z" fill="#FAABFF"/>
<ellipse cx="62.5001" cy="50.0001" rx="8.33333" ry="8.33333" fill="#302F38"/>
<ellipse cx="68.7499" cy="49.9999" rx="4.16666" ry="4.16667" fill="#F07EFF"/>
<rect x="62.5" y="22.9167" width="2.08334" height="8.33333" rx="1.04167" fill="#FFFBF7"/>
<rect x="76.1677" y="25.4841" width="2.08333" height="8.33333" rx="1.04167" transform="rotate(45 76.1677 25.4841)" fill="#F07EFF"/>
<rect width="2.08333" height="8.33333" rx="1.04167" transform="matrix(0.707107 -0.707107 -0.707107 -0.707107 55.3345 32.8501)" fill="#FFFBF7"/>
<defs>
<linearGradient id="paint0_linear_272_72834" x1="32.1615" y1="77.3437" x2="76.5242" y2="50.9783" gradientUnits="userSpaceOnUse">
<stop stop-color="#5D34F2"/>
<stop offset="1" stop-color="#FAABFF"/>
</linearGradient>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 1.7 KiB

View file

@ -0,0 +1,4 @@
.divider {
height: 0;
border-bottom: 1px solid var(--color-divider);
}

View file

@ -0,0 +1,11 @@
import classNames from 'classnames';
import * as styles from './index.module.scss';
type Props = {
className?: string;
};
const Divider = ({ className }: Props) => <div className={classNames(styles.divider, className)} />;
export default Divider;

View file

@ -75,8 +75,3 @@
margin-left: _.unit(6);
}
}
.divider {
height: 0;
border-bottom: 1px solid var(--color-divider);
}

View file

@ -11,6 +11,7 @@ import Globe from '@/assets/images/globe.svg';
import Palette from '@/assets/images/palette.svg';
import Profile from '@/assets/images/profile.svg';
import SignOut from '@/assets/images/sign-out.svg';
import Divider from '@/components/Divider';
import Dropdown, { DropdownItem } from '@/components/Dropdown';
import Spacer from '@/components/Spacer';
import { Ring as Spinner } from '@/components/Spinner';
@ -22,8 +23,6 @@ import SubMenu from '../SubMenu';
import UserInfoSkeleton from '../UserInfoSkeleton';
import * as styles from './index.module.scss';
const Divider = () => <div className={styles.divider} />;
const UserInfo = () => {
const { isAuthenticated, getIdTokenClaims, signOut } = useLogto();
const navigate = useNavigate();

View file

@ -0,0 +1,55 @@
@use '@/scss/underscore' as _;
.content {
align-items: center;
}
.title {
margin-top: _.unit(6);
font: var(--font-title-2);
text-align: center;
}
.description {
margin: _.unit(1) 0 _.unit(6) 0;
font: var(--font-body-2);
color: var(--color-text-secondary);
}
.buttonIcon {
opacity: 70%;
}
.divider {
width: 100%;
margin: _.unit(8) 0;
}
.reservation {
width: 100%;
padding: _.unit(3) _.unit(4);
border: 1px solid var(--color-divider);
border-radius: 8px;
display: flex;
align-items: center;
justify-content: space-between;
.reservationInfo {
display: flex;
align-items: center;
.reservationIcon {
margin-right: _.unit(4);
flex-shrink: 0;
}
.reservationTitle {
font: var(--font-title-3);
}
.reservationDescription {
font: var(--font-body-2);
color: var(--color-text-secondary);
}
}
}

View file

@ -0,0 +1,85 @@
import classNames from 'classnames';
import { useTranslation } from 'react-i18next';
import { useNavigate } from 'react-router-dom';
import AirPlay from '@/assets/images/air-play.svg';
import Calendar from '@/assets/images/calendar.svg';
import GetStarted from '@/assets/images/get-started.svg';
import Button from '@/components/Button';
import Divider from '@/components/Divider';
import OverlayScrollbar from '@/components/OverlayScrollbar';
import * as pageLayout from '@/pages/Cloud/layout.module.scss';
import { buildUrl } from '@/utils/url';
import ActionBar from '../../components/ActionBar';
import { CloudPage } from '../../types';
import { getCloudPagePathname } from '../../utils';
import * as styles from './index.module.scss';
const Congrats = () => {
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
const navigate = useNavigate();
const enterAdminConsole = () => {
navigate('/');
};
const handleBack = () => {
navigate(getCloudPagePathname(CloudPage.SignInExperience));
};
return (
<div className={pageLayout.page}>
<OverlayScrollbar className={pageLayout.contentContainer}>
<div className={classNames(pageLayout.content, styles.content)}>
<GetStarted />
<div className={styles.title}>{t('cloud.congrats.title')}</div>
<div className={styles.description}>{t('cloud.congrats.description')}</div>
<Button
type="primary"
size="large"
title="cloud.congrats.check_out_button"
icon={<AirPlay className={styles.buttonIcon} />}
onClick={() => {
window.open('/demo-app', '_blank');
}}
/>
<Divider className={styles.divider} />
<div className={styles.reservation}>
<div className={styles.reservationInfo}>
<Calendar className={styles.reservationIcon} />
<div>
<div className={styles.reservationTitle}>{t('cloud.congrats.reserve_title')}</div>
<div className={styles.reservationDescription}>
{t('cloud.congrats.reserve_description')}
</div>
</div>
</div>
<Button
type="outline"
title="cloud.congrats.book_button"
onClick={() => {
const bookLink = buildUrl('https://calendly.com/logto/30min', {
// Note: month format is YYYY-MM
month: new Date().toISOString().slice(0, 7),
});
window.open(bookLink, '_blank');
}}
/>
</div>
</div>
</OverlayScrollbar>
<ActionBar>
<Button
type="primary"
title="cloud.congrats.enter_admin_console"
onClick={enterAdminConsole}
/>
<Button title="general.back" onClick={handleBack} />
</ActionBar>
</div>
);
};
export default Congrats;

View file

@ -12,6 +12,7 @@
.title {
margin-top: _.unit(6);
font: var(--font-title-1);
text-align: center;
}
.description {

View file

@ -2,6 +2,7 @@ export enum CloudPage {
Welcome = 'welcome',
AboutUser = 'about-user',
SignInExperience = 'sign-in-experience',
Congrats = 'congrats',
}
export enum Project {

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others', // UNTRANSLATED
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience', // UNTRANSLATED
description: 'Check out the live preview and get through end to end flow', // UNTRANSLATED
check_out_button: 'Check out the live preview', // UNTRANSLATED
reserve_title: 'Reserve your time with Logto team', // UNTRANSLATED
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.', // UNTRANSLATED
book_button: 'Book', // UNTRANSLATED
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.', // UNTRANSLATED
discord_link: 'discord channel', // UNTRANSLATED
enter_admin_console: 'Enter Admin Console', // UNTRANSLATED
},
};
export default cloud;

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others',
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience',
description: 'Check out the live preview and get through end to end flow',
check_out_button: 'Check out the live preview',
reserve_title: 'Reserve your time with Logto team',
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.',
book_button: 'Book',
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.',
discord_link: 'discord channel',
enter_admin_console: 'Enter Admin Console',
},
};
export default cloud;

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others', // UNTRANSLATED
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience', // UNTRANSLATED
description: 'Check out the live preview and get through end to end flow', // UNTRANSLATED
check_out_button: 'Check out the live preview', // UNTRANSLATED
reserve_title: 'Reserve your time with Logto team', // UNTRANSLATED
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.', // UNTRANSLATED
book_button: 'Book', // UNTRANSLATED
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.', // UNTRANSLATED
discord_link: 'discord channel', // UNTRANSLATED
enter_admin_console: 'Enter Admin Console', // UNTRANSLATED
},
};
export default cloud;

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others', // UNTRANSLATED
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience', // UNTRANSLATED
description: 'Check out the live preview and get through end to end flow', // UNTRANSLATED
check_out_button: 'Check out the live preview', // UNTRANSLATED
reserve_title: 'Reserve your time with Logto team', // UNTRANSLATED
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.', // UNTRANSLATED
book_button: 'Book', // UNTRANSLATED
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.', // UNTRANSLATED
discord_link: 'discord channel', // UNTRANSLATED
enter_admin_console: 'Enter Admin Console', // UNTRANSLATED
},
};
export default cloud;

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others', // UNTRANSLATED
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience', // UNTRANSLATED
description: 'Check out the live preview and get through end to end flow', // UNTRANSLATED
check_out_button: 'Check out the live preview', // UNTRANSLATED
reserve_title: 'Reserve your time with Logto team', // UNTRANSLATED
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.', // UNTRANSLATED
book_button: 'Book', // UNTRANSLATED
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.', // UNTRANSLATED
discord_link: 'discord channel', // UNTRANSLATED
enter_admin_console: 'Enter Admin Console', // UNTRANSLATED
},
};
export default cloud;

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others', // UNTRANSLATED
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience', // UNTRANSLATED
description: 'Check out the live preview and get through end to end flow', // UNTRANSLATED
check_out_button: 'Check out the live preview', // UNTRANSLATED
reserve_title: 'Reserve your time with Logto team', // UNTRANSLATED
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.', // UNTRANSLATED
book_button: 'Book', // UNTRANSLATED
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.', // UNTRANSLATED
discord_link: 'discord channel', // UNTRANSLATED
enter_admin_console: 'Enter Admin Console', // UNTRANSLATED
},
};
export default cloud;

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others', // UNTRANSLATED
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience', // UNTRANSLATED
description: 'Check out the live preview and get through end to end flow', // UNTRANSLATED
check_out_button: 'Check out the live preview', // UNTRANSLATED
reserve_title: 'Reserve your time with Logto team', // UNTRANSLATED
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.', // UNTRANSLATED
book_button: 'Book', // UNTRANSLATED
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.', // UNTRANSLATED
discord_link: 'discord channel', // UNTRANSLATED
enter_admin_console: 'Enter Admin Console', // UNTRANSLATED
},
};
export default cloud;

View file

@ -47,6 +47,18 @@ const cloud = {
others: 'Others', // UNTRANSLATED
},
},
congrats: {
title: 'Congratulations! Youve customized and built your own sign-in experience', // UNTRANSLATED
description: 'Check out the live preview and get through end to end flow', // UNTRANSLATED
check_out_button: 'Check out the live preview', // UNTRANSLATED
reserve_title: 'Reserve your time with Logto team', // UNTRANSLATED
reserve_description:
'Book a one-on-one session with our team for SaaS early credit and use case sharing.', // UNTRANSLATED
book_button: 'Book', // UNTRANSLATED
join_description: 'Join our public <a>{{link}}</a> to connect and chat with other developers.', // UNTRANSLATED
discord_link: 'discord channel', // UNTRANSLATED
enter_admin_console: 'Enter Admin Console', // UNTRANSLATED
},
};
export default cloud;