0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Added empty state

ref https://linear.app/tryghost/issue/MOM-246/add-empty-state-design
This commit is contained in:
Djordje Vlaisavljevic 2024-06-24 17:39:29 +01:00
parent b81839f2fe
commit 79bc84c545
2 changed files with 35 additions and 13 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

View file

@ -1,4 +1,5 @@
// import NiceModal from '@ebay/nice-modal-react'; // import NiceModal from '@ebay/nice-modal-react';
// import ActivityPubWelcomeImage from '../assets/images/ap-welcome.png';
import React, {useState} from 'react'; import React, {useState} from 'react';
import articleBodyStyles from './articleBodyStyles'; import articleBodyStyles from './articleBodyStyles';
import getUsername from '../utils/get-username'; import getUsername from '../utils/get-username';
@ -40,12 +41,20 @@ const ActivityPubComponent: React.FC = () => {
title: 'Inbox', title: 'Inbox',
contents: <div className='grid grid-cols-6 items-start gap-8'> contents: <div className='grid grid-cols-6 items-start gap-8'>
<ul className='order-2 col-span-6 flex flex-col lg:order-1 lg:col-span-4'> <ul className='order-2 col-span-6 flex flex-col lg:order-1 lg:col-span-4'>
{activities && activities.slice().reverse().map(activity => ( {activities && activities.some(activity => activity.type === 'Create' && activity.object.type === 'Article') ? (activities.slice().reverse().map(activity => (
activity.type === 'Create' && activity.object.type === 'Article' && activity.type === 'Create' && activity.object.type === 'Article' &&
<li key={activity.id} data-test-view-article onClick={() => handleViewContent(activity.object, activity.actor)}> <li key={activity.id} data-test-view-article onClick={() => handleViewContent(activity.object, activity.actor)}>
<ObjectContentDisplay actor={activity.actor} object={activity.object}/> <ObjectContentDisplay actor={activity.actor} object={activity.object}/>
</li> </li>
))} ))) : <div className='flex items-center justify-center text-center'>
<div className='flex max-w-[32em] flex-col items-center justify-center gap-4'>
{/* <img alt='Ghost site logos' className='w-[220px]' src={ActivityPubWelcomeImage}/> */}
<Heading className='text-balance' level={2}>Welcome to ActivityPub</Heading>
<p className='text-pretty text-grey-800'>Were so glad to have you on board! At the moment, you can follow other Ghost sites and enjoy their content right here inside Ghost.</p>
<p className='text-pretty text-grey-800'>You can see all of the users on the rightfind your favorite ones and give them a follow.</p>
<Button color='green' label='Learn more' link={true}/>
</div>
</div>}
</ul> </ul>
<Sidebar followersCount={followersCount} followingCount={followingCount} updateRoute={updateRoute} /> <Sidebar followersCount={followersCount} followingCount={followingCount} updateRoute={updateRoute} />
</div> </div>
@ -108,7 +117,8 @@ const ActivityPubComponent: React.FC = () => {
}; };
const Sidebar: React.FC<{followingCount: number, followersCount: number, updateRoute: (route: string) => void}> = ({followingCount, followersCount, updateRoute}) => ( const Sidebar: React.FC<{followingCount: number, followersCount: number, updateRoute: (route: string) => void}> = ({followingCount, followersCount, updateRoute}) => (
<div className='order-1 col-span-6 rounded-xl bg-grey-50 p-6 lg:order-2 lg:col-span-2' id="ap-sidebar"> <div className='order-1 col-span-6 flex flex-col gap-5 lg:order-2 lg:col-span-2'>
<div className='rounded-xl bg-grey-50 p-6' id="ap-sidebar">
<div className='mb-4 border-b border-b-grey-200 pb-4'><SettingValue key={'your-username'} heading={'Your username'} value={'@index@localplaceholder.com'}/></div> <div className='mb-4 border-b border-b-grey-200 pb-4'><SettingValue key={'your-username'} heading={'Your username'} value={'@index@localplaceholder.com'}/></div>
<div className='grid grid-cols-2 gap-4'> <div className='grid grid-cols-2 gap-4'>
<div className='group/stat flex cursor-pointer flex-col gap-1' onClick={() => updateRoute('/view-following')}> <div className='group/stat flex cursor-pointer flex-col gap-1' onClick={() => updateRoute('/view-following')}>
@ -121,6 +131,18 @@ const Sidebar: React.FC<{followingCount: number, followersCount: number, updateR
</div> </div>
</div> </div>
</div> </div>
<div className='rounded-xl bg-grey-50 p-6'>
<header className='flex items-center justify-between'>
<Heading level={5}>Explore</Heading>
<Button label='View all' link={true}/>
</header>
<List>
<ListItem detail='829 followers' title='404 Media' />
<ListItem detail='829 followers' title='404 Media' />
<ListItem detail='829 followers' title='404 Media' />
</List>
</div>
</div>
); );
const ArticleBody: React.FC<{heading: string, image: string|undefined, html: string}> = ({heading, image, html}) => { const ArticleBody: React.FC<{heading: string, image: string|undefined, html: string}> = ({heading, image, html}) => {
@ -241,7 +263,7 @@ const ViewArticle: React.FC<ViewArticleProps> = ({object, onBackToList}) => {
</div> </div>
<div className='flex items-center justify-between'> <div className='flex items-center justify-between'>
</div> </div>
<div className='flex justify-end'> <div className='flex items-center justify-end gap-2'>
<div className='flex flex-row-reverse items-center gap-3'> <div className='flex flex-row-reverse items-center gap-3'>
<Button className={`self-start text-grey-500 transition-all hover:text-grey-800 ${isClicked ? 'bump' : ''} ${isLiked ? 'ap-red-heart text-red *:!fill-red hover:text-red' : ''}`} hideLabel={true} icon='heart' id="like" size='md' unstyled={true} onClick={handleLikeClick}/> <Button className={`self-start text-grey-500 transition-all hover:text-grey-800 ${isClicked ? 'bump' : ''} ${isLiked ? 'ap-red-heart text-red *:!fill-red hover:text-red' : ''}`} hideLabel={true} icon='heart' id="like" size='md' unstyled={true} onClick={handleLikeClick}/>
<span className={`text-grey-800 ${isLiked ? 'opacity-100' : 'opacity-0'}`}>1</span> <span className={`text-grey-800 ${isLiked ? 'opacity-100' : 'opacity-0'}`}>1</span>