2022-08-31 02:35:06 -07:00
|
|
|
import classNames from 'clsx';
|
2022-11-25 09:04:11 -08:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import { HStack } from 'soapbox/components/ui';
|
2022-03-21 11:09:01 -07:00
|
|
|
|
2022-11-15 11:00:40 -08:00
|
|
|
import PlaceholderAvatar from './placeholder-avatar';
|
|
|
|
import PlaceholderDisplayName from './placeholder-display-name';
|
|
|
|
import PlaceholderStatusContent from './placeholder-status-content';
|
2022-03-21 11:09:01 -07:00
|
|
|
|
|
|
|
interface IPlaceholderStatus {
|
|
|
|
thread?: boolean
|
|
|
|
}
|
|
|
|
|
2022-05-01 10:53:53 -07:00
|
|
|
/** Fake status to display while data is loading. */
|
|
|
|
const PlaceholderStatus: React.FC<IPlaceholderStatus> = ({ thread = false }) => (
|
2022-03-21 11:09:01 -07:00
|
|
|
<div
|
|
|
|
className={classNames({
|
2022-07-22 10:30:16 -07:00
|
|
|
'status-placeholder bg-white dark:bg-primary-900': true,
|
|
|
|
'shadow-xl dark:shadow-none sm:rounded-xl px-4 py-6 sm:p-5': !thread,
|
2022-03-21 11:09:01 -07:00
|
|
|
})}
|
|
|
|
>
|
|
|
|
<div className='w-full animate-pulse overflow-hidden'>
|
|
|
|
<div>
|
2022-11-25 09:04:11 -08:00
|
|
|
<HStack space={3} alignItems='center'>
|
2022-03-21 11:09:01 -07:00
|
|
|
<div className='flex-shrink-0'>
|
|
|
|
<PlaceholderAvatar size={42} />
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className='min-w-0 flex-1'>
|
|
|
|
<PlaceholderDisplayName minLength={3} maxLength={25} />
|
|
|
|
</div>
|
2022-11-25 09:04:11 -08:00
|
|
|
</HStack>
|
2022-03-21 11:09:01 -07:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className='mt-4 status__content-wrapper'>
|
|
|
|
<PlaceholderStatusContent minLength={5} maxLength={120} />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
|
|
|
|
export default React.memo(PlaceholderStatus);
|