Mangane/app/soapbox/features/placeholder/components/placeholder_status.tsx

40 lines
1.1 KiB
TypeScript

import classNames from 'classnames';
import * as React from 'react';
import PlaceholderAvatar from './placeholder_avatar';
import PlaceholderDisplayName from './placeholder_display_name';
import PlaceholderStatusContent from './placeholder_status_content';
interface IPlaceholderStatus {
thread?: boolean
}
const PlaceholderStatus = ({ thread = false }: IPlaceholderStatus) => (
<div
className={classNames({
'status-placeholder bg-white dark:bg-slate-800': true,
'sm:shadow-xl dark:sm:shadow-inset sm:rounded-xl px-4 py-6 sm:p-6': !thread,
})}
>
<div className='w-full animate-pulse overflow-hidden'>
<div>
<div className='flex space-x-3 items-center'>
<div className='flex-shrink-0'>
<PlaceholderAvatar size={42} />
</div>
<div className='min-w-0 flex-1'>
<PlaceholderDisplayName minLength={3} maxLength={25} />
</div>
</div>
</div>
<div className='mt-4 status__content-wrapper'>
<PlaceholderStatusContent minLength={5} maxLength={120} />
</div>
</div>
</div>
);
export default React.memo(PlaceholderStatus);