fix(core): adjust ai onboarding copywriting and local onboarding actions (#6834)

This commit is contained in:
CatsJuice
2024-05-08 09:18:17 +00:00
parent 8d8bd49600
commit 301cc188ca
6 changed files with 54 additions and 21 deletions

View File

@@ -60,7 +60,7 @@ export const title = style({
color: cssVar('textPrimaryColor'),
});
export const description = style({
fontSize: cssVar('fontBase'),
fontSize: cssVar('fontSm'),
lineHeight: '24px',
minHeight: 48,
fontWeight: 400,
@@ -94,7 +94,7 @@ export const privacyLink = style({
export const footer = style({
width: '100%',
padding: '20px 28px',
padding: '20px 28px 20px 24px',
gap: 12,
display: 'flex',
justifyContent: 'space-between',

View File

@@ -215,6 +215,7 @@ export const AIOnboardingGeneral = ({
activeIndex={index}
itemRenderer={descriptionRenderer}
transitionDuration={500}
preload={5}
/>
</main>

View File

@@ -1,5 +1,5 @@
import { cssVar } from '@toeverything/theme';
import { style } from '@vanilla-extract/css';
import { globalStyle, style } from '@vanilla-extract/css';
export const card = style({
borderRadius: 12,
@@ -34,7 +34,15 @@ export const footerActions = style({
marginTop: 8,
});
globalStyle(`${footerActions} > *, ${footerActions}`, {
color: `${cssVar('textSecondaryColor')} !important`,
});
globalStyle(`${footerActions} > *:last-child`, {
color: `${cssVar('textPrimaryColor')} !important`,
});
export const actionButton = style({
fontSize: cssVar('fontSm'),
padding: '0 2px',
color: 'inherit !important',
});

View File

@@ -1,4 +1,9 @@
import { Button, notify } from '@affine/component';
import {
RouteLogic,
useNavigateHelper,
} from '@affine/core/hooks/use-navigate-helper';
import { AuthService } from '@affine/core/modules/cloud';
import { WorkspaceFlavour } from '@affine/env/workspace';
import { useAFFiNEI18N } from '@affine/i18n/hooks';
import { AiIcon } from '@blocksuite/icons';
@@ -27,20 +32,30 @@ const LocalOnboardingAnimation = () => {
const FooterActions = ({ onDismiss }: { onDismiss: () => void }) => {
const t = useAFFiNEI18N();
const authService = useService(AuthService);
const loginStatus = useLiveData(authService.session.status$);
const loggedIn = loginStatus === 'authenticated';
const { jumpToSignIn } = useNavigateHelper();
return (
<div className={styles.footerActions}>
<Button onClick={onDismiss} type="plain" className={styles.actionButton}>
<span style={{ color: cssVar('textSecondaryColor') }}>
{t['com.affine.ai-onboarding.local.action-dismiss']()}
</span>
</Button>
<a href="https://ai.affine.pro" target="_blank" rel="noreferrer">
<Button className={styles.actionButton} type="plain">
<span style={{ color: cssVar('textPrimaryColor') }}>
{t['com.affine.ai-onboarding.local.action-learn-more']()}
</span>
{t['com.affine.ai-onboarding.local.action-learn-more']()}
</Button>
</a>
{loggedIn ? null : (
<Button
className={styles.actionButton}
type="plain"
onClick={() => {
onDismiss();
jumpToSignIn('/', RouteLogic.REPLACE, {}, { initCloud: 'true' });
}}
>
{t['com.affine.ai-onboarding.local.action-get-started']()}
</Button>
)}
</div>
);
};

View File

@@ -139,13 +139,22 @@ export function useNavigateHelper() {
(
redirectUri?: string,
logic: RouteLogic = RouteLogic.PUSH,
otherOptions?: Omit<NavigateOptions, 'replace'>
otherOptions?: Omit<NavigateOptions, 'replace'>,
params?: Record<string, string>
) => {
const searchParams = new URLSearchParams();
if (redirectUri) {
searchParams.set('redirect_uri', encodeURIComponent(redirectUri));
}
if (params) {
for (const key in params) searchParams.set(key, params[key]);
}
return navigate(
'/signIn' +
(redirectUri
? `?redirect_uri=${encodeURIComponent(redirectUri)}`
: ''),
(searchParams.toString() ? '?' + searchParams.toString() : ''),
{
replace: logic === RouteLogic.REPLACE,
...otherOptions,