Make useOwnAccount return an object

This commit is contained in:
Alex Gleason 2023-06-25 12:35:09 -05:00
parent a8459ced75
commit d4eaf1e27a
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
53 changed files with 62 additions and 64 deletions

View file

@ -6,7 +6,7 @@ import type { Group } from 'soapbox/schemas';
function useCancelMembershipRequest(group: Group) {
const api = useApi();
const me = useOwnAccount();
const { account: me } = useOwnAccount();
const { createEntity, isSubmitting } = useCreateEntity(
[Entities.GROUP_RELATIONSHIPS],

View file

@ -24,7 +24,7 @@ const SidebarNavigation = () => {
const features = useFeatures();
const settings = useSettings();
const account = useOwnAccount();
const { account } = useOwnAccount();
const groupsPath = useGroupsPath();
const notificationCount = useAppSelector((state) => state.notifications.unread);

View file

@ -123,7 +123,7 @@ const StatusActionBar: React.FC<IStatusActionBar> = ({
const { allowedEmoji } = soapboxConfig;
const account = useOwnAccount();
const { account } = useOwnAccount();
const isStaff = account ? account.staff : false;
const isAdmin = account ? account.admin : false;

View file

@ -15,7 +15,7 @@ interface IStatusReactionWrapper {
/** Provides emoji reaction functionality to the underlying button component */
const StatusReactionWrapper: React.FC<IStatusReactionWrapper> = ({ statusId, children }): JSX.Element | null => {
const dispatch = useAppDispatch();
const ownAccount = useOwnAccount();
const { account: ownAccount } = useOwnAccount();
const status = useAppSelector(state => state.statuses.get(statusId));
const soapboxConfig = useSoapboxConfig();

View file

@ -35,7 +35,7 @@ interface ISensitiveContentOverlay {
const SensitiveContentOverlay = React.forwardRef<HTMLDivElement, ISensitiveContentOverlay>((props, ref) => {
const { onToggleVisibility, status } = props;
const account = useOwnAccount();
const { account } = useOwnAccount();
const dispatch = useAppDispatch();
const intl = useIntl();
const settings = useSettings();

View file

@ -6,7 +6,7 @@ import { useStatContext } from 'soapbox/contexts/stat-context';
import { useAppSelector, useFeatures, useGroupsPath, useOwnAccount } from 'soapbox/hooks';
const ThumbNavigation: React.FC = (): JSX.Element => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const features = useFeatures();
const groupsPath = useGroupsPath();

View file

@ -91,7 +91,7 @@ const SoapboxMount = () => {
const me = useAppSelector(state => state.me);
const instance = useInstance();
const account = useOwnAccount();
const { account } = useOwnAccount();
const soapboxConfig = useSoapboxConfig();
const features = useFeatures();
const { pepeEnabled } = useRegistrationStatus();
@ -217,7 +217,7 @@ const SoapboxLoad: React.FC<ISoapboxLoad> = ({ children }) => {
const dispatch = useAppDispatch();
const me = useAppSelector(state => state.me);
const account = useOwnAccount();
const { account } = useOwnAccount();
const swUpdating = useAppSelector(state => state.meta.swUpdating);
const { locale } = useLocale();

View file

@ -27,7 +27,7 @@ const ChatProvider: React.FC<IChatProvider> = ({ children }) => {
const history = useHistory();
const dispatch = useAppDispatch();
const settings = useSettings();
const account = useOwnAccount();
const { account } = useOwnAccount();
const path = history.location.pathname;
const isUsingMainChatPage = Boolean(path.match(/^\/chats/));

View file

@ -87,7 +87,7 @@ const Header: React.FC<IHeader> = ({ account }) => {
const dispatch = useAppDispatch();
const features = useFeatures();
const ownAccount = useOwnAccount();
const { account: ownAccount } = useOwnAccount();
const { follow } = useFollow();
const { software } = useAppSelector((state) => parseVersion(state.instance.version));

View file

@ -16,7 +16,7 @@ const messages = defineMessages({
const Admin: React.FC = () => {
const intl = useIntl();
const account = useOwnAccount();
const { account } = useOwnAccount();
if (!account) return null;

View file

@ -18,7 +18,7 @@ const Dashboard: React.FC = () => {
const history = useHistory();
const instance = useInstance();
const features = useFeatures();
const account = useOwnAccount();
const { account } = useOwnAccount();
const handleSubscribersClick: React.MouseEventHandler = e => {
dispatch(getSubscribersCsv()).then(({ data }) => {

View file

@ -23,7 +23,7 @@ const Aliases = () => {
const intl = useIntl();
const dispatch = useAppDispatch();
const features = useFeatures();
const account = useOwnAccount();
const { account } = useOwnAccount();
const aliases = useAppSelector((state) => {
if (features.accountMoving) {

View file

@ -26,7 +26,7 @@ const AuthLayout = () => {
const history = useHistory();
const { search } = useLocation();
const account = useOwnAccount();
const { account } = useOwnAccount();
const instance = useInstance();
const { isOpen } = useRegistrationStatus();
const isLoginPage = history.location.pathname === '/login';

View file

@ -69,7 +69,7 @@ interface IChatMessageList {
/** Scrollable list of chat messages. */
const ChatMessageList: React.FC<IChatMessageList> = ({ chat }) => {
const intl = useIntl();
const account = useOwnAccount();
const { account } = useOwnAccount();
const myLastReadMessageDateString = chat.latest_read_message_by_account?.find((latest) => latest.id === account?.id)?.date;
const myLastReadMessageTimestamp = myLastReadMessageDateString ? new Date(myLastReadMessageDateString) : null;

View file

@ -16,7 +16,7 @@ interface IChatPage {
}
const ChatPage: React.FC<IChatPage> = ({ chatId }) => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const history = useHistory();
const isOnboarded = account?.source?.chats_onboarded ?? true;

View file

@ -24,7 +24,7 @@ const messages = defineMessages({
});
const ChatPageSettings = () => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const intl = useIntl();
const history = useHistory();
const dispatch = useAppDispatch();

View file

@ -20,7 +20,7 @@ const messages = defineMessages({
});
const Welcome = () => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const intl = useIntl();
const updateCredentials = useUpdateCredentials();

View file

@ -7,7 +7,7 @@ import { useOwnAccount } from 'soapbox/hooks';
import ChatPane from '../chat-pane/chat-pane';
const ChatWidget = () => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const history = useHistory();
const path = history.location.pathname;

View file

@ -25,7 +25,7 @@ type Params = typeof BLANK_PARAMS;
const CreateApp: React.FC = () => {
const intl = useIntl();
const dispatch = useAppDispatch();
const account = useOwnAccount();
const { account } = useOwnAccount();
const [app, setApp] = useState<Record<string, any> | null>(null);
const [token, setToken] = useState<string | null>(null);

View file

@ -177,7 +177,7 @@ const EditProfile: React.FC = () => {
const dispatch = useAppDispatch();
const instance = useInstance();
const account = useOwnAccount();
const { account } = useOwnAccount();
const features = useFeatures();
const maxFields = instance.pleroma.getIn(['metadata', 'fields_limits', 'max_fields'], 4) as number;

View file

@ -73,7 +73,7 @@ const EventHeader: React.FC<IEventHeader> = ({ status }) => {
const features = useFeatures();
const settings = useSettings();
const ownAccount = useOwnAccount();
const { account: ownAccount } = useOwnAccount();
const isStaff = ownAccount ? ownAccount.staff : false;
const isAdmin = ownAccount ? ownAccount.admin : false;

View file

@ -26,7 +26,7 @@ const Favourites: React.FC<IFavourites> = ({ params }) => {
const intl = useIntl();
const dispatch = useAppDispatch();
const features = useFeatures();
const ownAccount = useOwnAccount();
const { account: ownAccount } = useOwnAccount();
const { account } = useAccount(params?.username, { withRelationship: true });
const username = params?.username || '';

View file

@ -31,7 +31,7 @@ const Followers: React.FC<IFollowers> = (props) => {
const intl = useIntl();
const dispatch = useAppDispatch();
const features = useFeatures();
const ownAccount = useOwnAccount();
const { account: ownAccount } = useOwnAccount();
const [loading, setLoading] = useState(true);

View file

@ -31,7 +31,7 @@ const Following: React.FC<IFollowing> = (props) => {
const intl = useIntl();
const dispatch = useAppDispatch();
const features = useFeatures();
const ownAccount = useOwnAccount();
const { account: ownAccount } = useOwnAccount();
const [loading, setLoading] = useState(true);

View file

@ -31,7 +31,7 @@ const messages = defineMessages({
const GroupActionButton = ({ group }: IGroupActionButton) => {
const dispatch = useAppDispatch();
const intl = useIntl();
const account = useOwnAccount();
const { account } = useOwnAccount();
const joinGroup = useJoinGroup(group);
const leaveGroup = useLeaveGroup(group);

View file

@ -27,7 +27,7 @@ interface IGroupActionButton {
}
const GroupOptionsButton = ({ group }: IGroupActionButton) => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const dispatch = useAppDispatch();
const intl = useIntl();
const leaveGroup = useLeaveGroup(group);

View file

@ -24,7 +24,7 @@ const getStatusIds = makeGetStatusIds();
const GroupTimeline: React.FC<IGroupTimeline> = (props) => {
const intl = useIntl();
const account = useOwnAccount();
const { account } = useOwnAccount();
const dispatch = useAppDispatch();
const composer = useRef<HTMLDivElement>(null);

View file

@ -14,7 +14,7 @@ interface Props {
export default (props: Props) => {
const { onSelect } = props;
const me = useOwnAccount();
const { account: me } = useOwnAccount();
const [recentSearches, setRecentSearches] = useState<string[]>(groupSearchHistory.get(me?.id as string) || []);

View file

@ -19,7 +19,7 @@ interface Props {
export default (props: Props) => {
const { onSelect, searchValue } = props;
const me = useOwnAccount();
const { account: me } = useOwnAccount();
const debounce = useDebounce;
const debouncedValue = debounce(searchValue as string, 300);

View file

@ -17,7 +17,7 @@ const messages = defineMessages({
const AvatarSelectionStep = ({ onNext }: { onNext: () => void }) => {
const dispatch = useAppDispatch();
const account = useOwnAccount();
const { account } = useOwnAccount();
const fileInput = React.useRef<HTMLInputElement>(null);
const [selectedFile, setSelectedFile] = React.useState<string | null>();

View file

@ -17,7 +17,7 @@ const BioStep = ({ onNext }: { onNext: () => void }) => {
const intl = useIntl();
const dispatch = useAppDispatch();
const account = useOwnAccount();
const { account } = useOwnAccount();
const [value, setValue] = React.useState<string>(account?.source?.note ?? '');
const [isSubmitting, setSubmitting] = React.useState<boolean>(false);
const [errors, setErrors] = React.useState<string[]>([]);

View file

@ -20,7 +20,7 @@ const messages = defineMessages({
const CoverPhotoSelectionStep = ({ onNext }: { onNext: () => void }) => {
const intl = useIntl();
const dispatch = useAppDispatch();
const account = useOwnAccount();
const { account } = useOwnAccount();
const fileInput = React.useRef<HTMLInputElement>(null);
const [selectedFile, setSelectedFile] = React.useState<string | null>();

View file

@ -17,7 +17,7 @@ const DisplayNameStep = ({ onNext }: { onNext: () => void }) => {
const intl = useIntl();
const dispatch = useAppDispatch();
const account = useOwnAccount();
const { account } = useOwnAccount();
const [value, setValue] = React.useState<string>(account?.display_name || '');
const [isSubmitting, setSubmitting] = React.useState<boolean>(false);
const [errors, setErrors] = React.useState<string[]>([]);

View file

@ -5,10 +5,8 @@ import Account from 'soapbox/components/account';
import { Button, Card, CardBody, Icon, Stack, Text } from 'soapbox/components/ui';
import { useInstance, useOwnAccount } from 'soapbox/hooks';
import type { Account as AccountEntity } from 'soapbox/types/entities';
const FediverseStep = ({ onNext }: { onNext: () => void }) => {
const account = useOwnAccount() as AccountEntity;
const { account } = useOwnAccount();
const instance = useInstance();
return (
@ -49,9 +47,11 @@ const FediverseStep = ({ onNext }: { onNext: () => void }) => {
</Stack>
</div>
<div className='rounded-lg bg-primary-50 p-4 text-center dark:bg-gray-800'>
<Account account={account} />
</div>
{account && (
<div className='rounded-lg bg-primary-50 p-4 text-center dark:bg-gray-800'>
<Account account={account} />
</div>
)}
<Text theme='muted'>
<FormattedMessage

View file

@ -29,7 +29,7 @@ const Header = () => {
const intl = useIntl();
const features = useFeatures();
const account = useOwnAccount();
const { account } = useOwnAccount();
const soapboxConfig = useSoapboxConfig();
const { isOpen } = useRegistrationStatus();
const { links } = soapboxConfig;

View file

@ -11,7 +11,7 @@ const messages = defineMessages({
});
const MessagesSettings = () => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const intl = useIntl();
const updateCredentials = useUpdateCredentials();

View file

@ -40,7 +40,7 @@ const Settings = () => {
const mfa = useAppSelector((state) => state.security.get('mfa'));
const features = useFeatures();
const account = useOwnAccount();
const { account } = useOwnAccount();
const navigateToChangeEmail = () => history.push('/settings/email');
const navigateToChangePassword = () => history.push('/settings/password');

View file

@ -97,7 +97,7 @@ const Thread = (props: IThread) => {
const dispatch = useAppDispatch();
const history = useHistory();
const intl = useIntl();
const me = useOwnAccount();
const { account: me } = useOwnAccount();
const settings = useSettings();
const displayMedia = settings.get('displayMedia') as DisplayMedia;

View file

@ -26,7 +26,7 @@ const InstanceModerationPanel: React.FC<IInstanceModerationPanel> = ({ host }) =
const intl = useIntl();
const dispatch = useAppDispatch();
const account = useOwnAccount();
const { account } = useOwnAccount();
const remoteInstance = useAppSelector(state => getRemoteInstance(state, host));
const handleEditFederation = () => {

View file

@ -25,7 +25,7 @@ const FooterLink: React.FC<IFooterLink> = ({ children, className, ...rest }): JS
};
const LinkFooter: React.FC = (): JSX.Element => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const features = useFeatures();
const soapboxConfig = useSoapboxConfig();

View file

@ -45,7 +45,7 @@ const AccountModerationModal: React.FC<IAccountModerationModal> = ({ onClose, ac
const intl = useIntl();
const dispatch = useAppDispatch();
const ownAccount = useOwnAccount();
const { account: ownAccount } = useOwnAccount();
const features = useFeatures();
const { account } = useAccount(accountId);

View file

@ -28,7 +28,7 @@ const Navbar = () => {
const intl = useIntl();
const features = useFeatures();
const { isOpen } = useRegistrationStatus();
const account = useOwnAccount();
const { account } = useOwnAccount();
const node = useRef(null);
const [isLoading, setLoading] = useState<boolean>(false);

View file

@ -399,7 +399,7 @@ const UI: React.FC<IUI> = ({ children }) => {
const hotkeys = useRef<HTMLDivElement | null>(null);
const me = useAppSelector(state => state.me);
const account = useOwnAccount();
const { account } = useOwnAccount();
const features = useFeatures();
const vapidKey = useAppSelector(state => getVapidKey(state));

View file

@ -42,7 +42,7 @@ const WrappedRoute: React.FC<IWrappedRoute> = ({
}) => {
const history = useHistory();
const account = useOwnAccount();
const { account } = useOwnAccount();
const settings = useSettings();
const renderComponent = ({ match }: RouteComponentProps) => {

View file

@ -13,7 +13,7 @@ const WaitlistPage = () => {
const dispatch = useAppDispatch();
const instance = useInstance();
const me = useOwnAccount();
const { account: me } = useOwnAccount();
const isSmsVerified = me?.source?.sms_verified ?? true;
const onClickLogOut: React.MouseEventHandler = (event) => {

View file

@ -3,19 +3,17 @@ import { useCallback } from 'react';
import { useAppSelector } from 'soapbox/hooks';
import { makeGetAccount } from 'soapbox/selectors';
import type { Account } from 'soapbox/types/entities';
/** Get the logged-in account from the store, if any. */
export const useOwnAccount = (): Account | null => {
export const useOwnAccount = () => {
const getAccount = useCallback(makeGetAccount(), []);
return useAppSelector((state) => {
const account = useAppSelector((state) => {
const { me } = state;
if (typeof me === 'string') {
return getAccount(state, me);
} else {
return null;
}
});
return { account: account || undefined };
};

View file

@ -96,7 +96,7 @@ const GroupPage: React.FC<IGroupPage> = ({ params, children }) => {
const intl = useIntl();
const features = useFeatures();
const match = useRouteMatch();
const me = useOwnAccount();
const { account: me } = useOwnAccount();
const id = params?.groupId || '';

View file

@ -32,7 +32,7 @@ const HomePage: React.FC<IHomePage> = ({ children }) => {
const dispatch = useAppDispatch();
const me = useAppSelector(state => state.me);
const account = useOwnAccount();
const { account } = useOwnAccount();
const features = useFeatures();
const soapboxConfig = useSoapboxConfig();

View file

@ -23,7 +23,7 @@ interface IRemoteInstancePage {
const RemoteInstancePage: React.FC<IRemoteInstancePage> = ({ children, params }) => {
const host = params?.instance;
const account = useOwnAccount();
const { account } = useOwnAccount();
const disclosed = useAppSelector(federationRestrictionsDisclosed);
return (

View file

@ -35,7 +35,7 @@ type UpdateCredentialsData = {
}
const useUpdateCredentials = () => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const api = useApi();
const dispatch = useAppDispatch();

View file

@ -200,7 +200,7 @@ const useChat = (chatId?: string) => {
};
const useChatActions = (chatId: string) => {
const account = useOwnAccount();
const { account } = useOwnAccount();
const api = useApi();
// const dispatch = useAppDispatch();

View file

@ -48,7 +48,7 @@ const useGroupsApi = () => {
const usePendingGroups = () => {
const features = useFeatures();
const account = useOwnAccount();
const { account } = useOwnAccount();
const { fetchGroups } = useGroupsApi();
const getGroups = async (pageParam?: any): Promise<PaginatedResult<Group>> => {

View file

@ -14,7 +14,7 @@ const PolicyKeys = {
function usePendingPolicy() {
const api = useApi();
const account = useOwnAccount();
const { account } = useOwnAccount();
const features = useFeatures();
const getPolicy = async() => {