2022-08-09 15:45:01 -07:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import Status, { IStatus } from 'soapbox/components/status';
|
|
|
|
import { useAppSelector } from 'soapbox/hooks';
|
|
|
|
import { makeGetStatus } from 'soapbox/selectors';
|
|
|
|
|
2022-08-13 08:27:12 -07:00
|
|
|
interface IStatusContainer extends Omit<IStatus, 'status'> {
|
2022-08-09 15:45:01 -07:00
|
|
|
id: string,
|
|
|
|
/** @deprecated Unused. */
|
|
|
|
contextType?: any,
|
|
|
|
/** @deprecated Unused. */
|
|
|
|
otherAccounts?: any,
|
|
|
|
/** @deprecated Unused. */
|
|
|
|
getScrollPosition?: any,
|
|
|
|
/** @deprecated Unused. */
|
|
|
|
updateScrollBottom?: any,
|
|
|
|
}
|
|
|
|
|
|
|
|
const getStatus = makeGetStatus();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Legacy Status wrapper accepting a status ID instead of the full entity.
|
|
|
|
* @deprecated Use the Status component directly.
|
|
|
|
*/
|
2022-08-13 08:27:12 -07:00
|
|
|
const StatusContainer: React.FC<IStatusContainer> = ({ id, onMoveUp, onMoveDown, withDismiss }) => {
|
2022-08-09 15:45:01 -07:00
|
|
|
const status = useAppSelector(state => getStatus(state, { id }));
|
|
|
|
|
|
|
|
if (status) {
|
2022-08-13 08:27:12 -07:00
|
|
|
return (
|
|
|
|
<Status
|
|
|
|
status={status}
|
|
|
|
onMoveUp={onMoveUp}
|
|
|
|
onMoveDown={onMoveDown}
|
|
|
|
withDismiss={withDismiss}
|
|
|
|
/>
|
|
|
|
);
|
2022-08-09 15:45:01 -07:00
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export default StatusContainer;
|