Skip to content

Commit

Permalink
show proper auth modal
Browse files Browse the repository at this point in the history
  • Loading branch information
Robinnnnn committed Apr 25, 2024
1 parent 9e5d88e commit 4db8ffc
Show file tree
Hide file tree
Showing 6 changed files with 49 additions and 61 deletions.
15 changes: 4 additions & 11 deletions apps/web/src/components/Feed/Socialize/AdmireButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,9 @@ import { useCallback } from 'react';
import { useFragment } from 'react-relay';
import { graphql } from 'relay-runtime';

import { useModalActions } from '~/contexts/modal/ModalContext';
import { AdmireButtonFragment$key } from '~/generated/AdmireButtonFragment.graphql';
import { AdmireButtonQueryFragment$key } from '~/generated/AdmireButtonQueryFragment.graphql';
import { AuthModal } from '~/hooks/useAuthModal';
import useUniversalAuthModal from '~/hooks/useUniversalAuthModal';
import { AdmireIcon } from '~/icons/SocializeIcons';
import { contexts } from '~/shared/analytics/constants';
import { useTrack } from '~/shared/contexts/AnalyticsContext';
Expand Down Expand Up @@ -53,13 +52,11 @@ export function AdmireButton({ eventRef, queryRef, onAdmire, onRemoveAdmire }: A
viewer {
__typename
}
...useAuthModalFragment
}
`,
queryRef
);
const { showModal } = useModalActions();
const showAuthModal = useUniversalAuthModal();

const track = useTrack();

Expand All @@ -78,16 +75,12 @@ export function AdmireButton({ eventRef, queryRef, onAdmire, onRemoveAdmire }: A
});

if (query.viewer?.__typename !== 'Viewer') {
showModal({
content: <AuthModal queryRef={query} />,
headerText: 'Sign In',
});

showAuthModal();
return;
}

onAdmire();
}, [query, track, onAdmire, showModal]);
}, [track, query.viewer?.__typename, onAdmire, showAuthModal]);

const hasViewerAdmiredEvent = Boolean(feedItem.viewerAdmire);

Expand Down
14 changes: 4 additions & 10 deletions apps/web/src/components/Feed/Socialize/AdmireLine.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,9 @@ import styled from 'styled-components';
import { HStack } from '~/components/core/Spacer/Stack';
import { BaseM, TitleDiatypeM } from '~/components/core/Text/Text';
import { ProfilePictureStack } from '~/components/ProfilePicture/ProfilePictureStack';
import { useModalActions } from '~/contexts/modal/ModalContext';
import { AdmireLineFragment$key } from '~/generated/AdmireLineFragment.graphql';
import { AdmireLineQueryFragment$key } from '~/generated/AdmireLineQueryFragment.graphql';
import { AuthModal } from '~/hooks/useAuthModal';
import useUniversalAuthModal from '~/hooks/useUniversalAuthModal';
import { useTrack } from '~/shared/contexts/AnalyticsContext';
import { removeNullValues } from '~/shared/relay/removeNullValues';

Expand Down Expand Up @@ -82,7 +81,6 @@ export function AdmireLine({ eventRef, queryRef, onAdmire }: CommentLineProps) {
}
}
...useAdmireModalQueryFragment
...useAuthModalFragment
}
`,
queryRef
Expand Down Expand Up @@ -126,22 +124,18 @@ export function AdmireLine({ eventRef, queryRef, onAdmire }: CommentLineProps) {

const totalAdmires = event.previewAdmires?.pageInfo.total ?? 0;

const { showModal } = useModalActions();
const showAuthModal = useUniversalAuthModal();
const track = useTrack();

const handleAdmire = useCallback(async () => {
if (query.viewer?.__typename !== 'Viewer') {
showModal({
content: <AuthModal queryRef={query} />,
headerText: 'Sign In',
});

showAuthModal();
return;
}

track('Admire Click');
onAdmire();
}, [onAdmire, query, showModal, track]);
}, [onAdmire, query.viewer?.__typename, showAuthModal, track]);

if (totalAdmires === 0) {
return (
Expand Down
20 changes: 7 additions & 13 deletions apps/web/src/components/Feed/Socialize/CommentBox/CommentBox.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,10 @@ import { BaseM, BODY_FONT_FAMILY } from '~/components/core/Text/Text';
import { SendButton } from '~/components/Feed/Socialize/SendButton';
import { FloatingCard } from '~/components/Mention/FloatingCard';
import { MentionModal } from '~/components/Mention/MentionModal';
import { useModalActions } from '~/contexts/modal/ModalContext';
import { useToastActions } from '~/contexts/toast/ToastContext';
import { CommentBoxQueryFragment$key } from '~/generated/CommentBoxQueryFragment.graphql';
import { MentionInput } from '~/generated/useCommentOnPostMutation.graphql';
import { AuthModal } from '~/hooks/useAuthModal';
import useUniversalAuthModal from '~/hooks/useUniversalAuthModal';
import { contexts } from '~/shared/analytics/constants';
import { useTrack } from '~/shared/contexts/AnalyticsContext';
import { MentionType, useMentionableMessage } from '~/shared/hooks/useMentionableMessage';
Expand All @@ -45,7 +44,6 @@ export function CommentBox({ queryRef, onSubmitComment, isSubmittingComment, rep
viewer {
__typename
}
...useAuthModalFragment
}
`,
queryRef
Expand Down Expand Up @@ -80,7 +78,7 @@ export function CommentBox({ queryRef, onSubmitComment, isSubmittingComment, rep
const { pushToast } = useToastActions();

const track = useTrack();
const { showModal } = useModalActions();
const showAuthModal = useUniversalAuthModal();

useEffect(() => {
textareaRef.current?.focus();
Expand All @@ -105,11 +103,7 @@ export function CommentBox({ queryRef, onSubmitComment, isSubmittingComment, rep

const handleSubmit = useCallback(async () => {
if (query.viewer?.__typename !== 'Viewer') {
showModal({
content: <AuthModal queryRef={query} />,
headerText: 'Sign In',
});

showAuthModal();
return;
}

Expand All @@ -131,16 +125,16 @@ export function CommentBox({ queryRef, onSubmitComment, isSubmittingComment, rep
}
resetInputState();
}, [
query,
query.viewer?.__typename,
isSubmittingComment,
mentions,
message,
track,
resetInputState,
showModal,
showAuthModal,
onSubmitComment,
pushErrorToast,
mentions,
replyToId,
pushErrorToast,
]);

const handleInputKeyDown = useCallback<KeyboardEventHandler>(
Expand Down
26 changes: 15 additions & 11 deletions apps/web/src/components/NftPreview/NftPreviewBookmarkLabel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,11 @@ import { useTrack } from 'shared/contexts/AnalyticsContext';
import colors from 'shared/theme/colors';
import styled from 'styled-components';

import { useModalActions } from '~/contexts/modal/ModalContext';
import { NftPreviewBookmarkLabelFragment$key } from '~/generated/NftPreviewBookmarkLabelFragment.graphql';
import { NftPreviewBookmarkLabelQueryFragment$key } from '~/generated/NftPreviewBookmarkLabelQueryFragment.graphql';
import useAdmireToken from '~/hooks/api/posts/useAdmireToken';
import useRemoveTokenAdmire from '~/hooks/api/posts/useRemoveTokenAdmire';
import { AuthModal } from '~/hooks/useAuthModal';
import useUniversalAuthModal from '~/hooks/useUniversalAuthModal';
import BookmarkIcon from '~/icons/BookmarkIcon';
import unescape from '~/shared/utils/unescape';
import useOptimisticUserInfo from '~/utils/useOptimisticUserInfo';
Expand Down Expand Up @@ -52,7 +51,6 @@ export default function NftPreviewBookmarkLabel({ tokenRef, queryRef }: Props) {
}
}
...useOptimisticUserInfoFragment
...useAuthModalFragment
}
`,
queryRef
Expand All @@ -73,20 +71,16 @@ export default function NftPreviewBookmarkLabel({ tokenRef, queryRef }: Props) {
return null;
}, [token.definition.name]);

const { showModal } = useModalActions();

const [admireToken] = useAdmireToken();
const [removeTokenAdmire] = useRemoveTokenAdmire();
const track = useTrack();
const { route } = useRouter();

const showAuthModal = useUniversalAuthModal();

const handleAddBookmark = useCallback(() => {
if (query.viewer?.__typename !== 'Viewer') {
showModal({
content: <AuthModal queryRef={query} />,
headerText: 'Sign In',
});

showAuthModal();
return;
}

Expand All @@ -97,7 +91,17 @@ export default function NftPreviewBookmarkLabel({ tokenRef, queryRef }: Props) {
});

admireToken(token.id, token.dbid, info, decodedTokenName);
}, [admireToken, decodedTokenName, info, query, route, showModal, token.dbid, token.id, track]);
}, [
admireToken,
decodedTokenName,
info,
query.viewer?.__typename,
route,
showAuthModal,
token.dbid,
token.id,
track,
]);

const handleRemoveBookmark = useCallback(() => {
if (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import { HStack, VStack } from '~/components/core/Spacer/Stack';
import { BaseM, BODY_FONT_FAMILY } from '~/components/core/Text/Text';
import { useModalActions } from '~/contexts/modal/ModalContext';
import { GlobalAnnouncementPopoverFragment$key } from '~/generated/GlobalAnnouncementPopoverFragment.graphql';
import { AuthModal } from '~/hooks/useAuthModal';
import useUniversalAuthModal from '~/hooks/useUniversalAuthModal';
import { useIsDesktopWindowWidth } from '~/hooks/useWindowSize';
import { contexts } from '~/shared/analytics/constants';
import colors from '~/shared/theme/colors';
Expand Down Expand Up @@ -59,7 +59,6 @@ export default function GlobalAnnouncementPopover({ queryRef }: Props) {
...FeaturedCollectorCardCollectionFragment
}
}
...useAuthModalFragment
...FeaturedCollectorCardFragment
}
`,
Expand All @@ -70,7 +69,8 @@ export default function GlobalAnnouncementPopover({ queryRef }: Props) {
throw new Error('GlobalAnnouncementPopver did not receive gallery of the week winners');
}

const { showModal, hideModal } = useModalActions();
const { hideModal } = useModalActions();
const showAuthModal = useUniversalAuthModal();

const isMobile = !useIsDesktopWindowWidth();

Expand All @@ -86,11 +86,8 @@ export default function GlobalAnnouncementPopover({ queryRef }: Props) {
return;
}

showModal({
content: <AuthModal queryRef={query} />,
headerText: 'Create account',
});
}, [hideModal, isAuthenticated, push, query, showModal]);
showAuthModal();
}, [hideModal, isAuthenticated, push, showAuthModal]);

const handleSecondaryButtonClick = useCallback(() => {
document.getElementById('beautiful-home')?.scrollIntoView({ behavior: 'smooth' });
Expand Down
22 changes: 14 additions & 8 deletions apps/web/src/scenes/NftDetailPage/NftDetailText.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ import { NftDetailTextFragment$key } from '~/generated/NftDetailTextFragment.gra
import { NftDetailTextQueryFragment$key } from '~/generated/NftDetailTextQueryFragment.graphql';
import useAdmireToken from '~/hooks/api/posts/useAdmireToken';
import useRemoveTokenAdmire from '~/hooks/api/posts/useRemoveTokenAdmire';
import { AuthModal } from '~/hooks/useAuthModal';
import useUniversalAuthModal from '~/hooks/useUniversalAuthModal';
import { useBreakpoint, useIsMobileWindowWidth } from '~/hooks/useWindowSize';
import BookmarkIcon from '~/icons/BookmarkIcon';
import ExpandIcon from '~/icons/ExpandIcon';
Expand Down Expand Up @@ -108,7 +108,6 @@ function NftDetailText({ queryRef, tokenRef, authenticatedUserOwnsAsset, toggleL
}
}
...useOptimisticUserInfoFragment
...useAuthModalFragment
}
`,
queryRef
Expand Down Expand Up @@ -136,19 +135,26 @@ function NftDetailText({ queryRef, tokenRef, authenticatedUserOwnsAsset, toggleL
const [admireToken] = useAdmireToken();
const [removeTokenAdmire] = useRemoveTokenAdmire();

const showAuthModal = useUniversalAuthModal();

const handleAdmire = useCallback(async () => {
if (query.viewer?.__typename !== 'Viewer') {
showModal({
content: <AuthModal queryRef={query} />,
headerText: 'Sign In',
});

showAuthModal();
return;
}

track('Admire Token Click');
admireToken(token.id, token.dbid, info, decodedTokenName);
}, [query, track, admireToken, token.id, token.dbid, info, decodedTokenName, showModal]);
}, [
query.viewer?.__typename,
track,
admireToken,
token.id,
token.dbid,
info,
decodedTokenName,
showAuthModal,
]);

const handleRemoveAdmire = useCallback(async () => {
if (
Expand Down

0 comments on commit 4db8ffc

Please sign in to comment.