Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor card wrapper top bar #13655

Merged
merged 1 commit into from
Mar 31, 2025
Merged

Conversation

domlander
Copy link
Contributor

@domlander domlander commented Mar 20, 2025

What does this change?

We have a couple of props showTopBarMobile and showTopBarDesktop that we pass into the CardWrapper component. The former works as you'd expect: if true, a horizontal line will be shown above the card on mobile screen sizes. However, the latter does not work as you'd expect. A top bar is shown at all device sizes if this prop is true. This PR refactors this behaviour so that if showTopBarDesktop is true, a horizontal line will be shown above the card on desktop screen sizes.

Why?

Code health.

@domlander domlander self-assigned this Mar 20, 2025
@domlander domlander added run_chromatic Runs chromatic when label is applied fronts + curation and removed dotcom-rendering labels Mar 20, 2025
@github-actions github-actions bot removed the run_chromatic Runs chromatic when label is applied label Mar 20, 2025
Copy link

github-actions bot commented Mar 20, 2025

Size Change: -4 B (0%)

Total Size: 910 kB

ℹ️ View Unchanged
Filename Size Change
dotcom-rendering/dist/1254.client.web.********************.js 3.69 kB 0 B
dotcom-rendering/dist/1262.client.web.********************.js 4.49 kB 0 B
dotcom-rendering/dist/1401.client.web.********************.js 441 B 0 B
dotcom-rendering/dist/1477.client.web.********************.js 3.03 kB 0 B
dotcom-rendering/dist/1543.client.web.********************.js 2.51 kB 0 B
dotcom-rendering/dist/1714.client.web.********************.js 2.87 kB 0 B
dotcom-rendering/dist/1965.client.web.********************.js 2.81 kB 0 B
dotcom-rendering/dist/2425.client.web.********************.js 2.67 kB 0 B
dotcom-rendering/dist/2482.client.web.********************.js 44.8 kB 0 B
dotcom-rendering/dist/2505.client.web.********************.js 2.86 kB 0 B
dotcom-rendering/dist/2619.client.web.********************.js 3.59 kB 0 B
dotcom-rendering/dist/280.client.web.********************.js 531 B 0 B
dotcom-rendering/dist/2960.client.web.********************.js 14.7 kB 0 B
dotcom-rendering/dist/3051.client.web.********************.js 2.11 kB 0 B
dotcom-rendering/dist/316.client.web.********************.js 3.4 kB 0 B
dotcom-rendering/dist/3186.client.web.********************.js 4.49 kB 0 B
dotcom-rendering/dist/3389.client.web.********************.js 2.84 kB 0 B
dotcom-rendering/dist/342.client.web.********************.js 4.17 kB 0 B
dotcom-rendering/dist/344.client.web.********************.js 2.95 kB 0 B
dotcom-rendering/dist/3769.client.web.********************.js 22.7 kB 0 B
dotcom-rendering/dist/39.client.web.********************.js 3.07 kB 0 B
dotcom-rendering/dist/3937.client.web.********************.js 3.88 kB 0 B
dotcom-rendering/dist/4170.client.web.********************.js 16.3 kB 0 B
dotcom-rendering/dist/4337.client.web.********************.js 15.1 kB -6 B (-0.04%)
dotcom-rendering/dist/4501.client.web.********************.js 4.29 kB 0 B
dotcom-rendering/dist/4753.client.web.********************.js 4.94 kB 0 B
dotcom-rendering/dist/4793.client.web.********************.js 5.03 kB 0 B
dotcom-rendering/dist/5598.client.web.********************.js 4.5 kB 0 B
dotcom-rendering/dist/5819.client.web.********************.js 3.54 kB 0 B
dotcom-rendering/dist/5866.client.web.********************.js 4.79 kB 0 B
dotcom-rendering/dist/5948.client.web.********************.js 3.76 kB 0 B
dotcom-rendering/dist/6010.client.web.********************.js 5.41 kB 0 B
dotcom-rendering/dist/6021.client.web.********************.js 11.4 kB 0 B
dotcom-rendering/dist/6061.client.web.********************.js 3.63 kB 0 B
dotcom-rendering/dist/6110.client.web.********************.js 3.54 kB 0 B
dotcom-rendering/dist/6244.client.web.********************.js 3.92 kB 0 B
dotcom-rendering/dist/6251.client.web.********************.js 3.52 kB 0 B
dotcom-rendering/dist/6627.client.web.********************.js 10.4 kB 0 B
dotcom-rendering/dist/6640.client.web.********************.js 2.72 kB 0 B
dotcom-rendering/dist/677.client.web.********************.js 3.39 kB 0 B
dotcom-rendering/dist/6931.client.web.********************.js 2.63 kB 0 B
dotcom-rendering/dist/6940.client.web.********************.js 526 B 0 B
dotcom-rendering/dist/7094.client.web.********************.js 156 B 0 B
dotcom-rendering/dist/7116.client.web.********************.js 23 kB 0 B
dotcom-rendering/dist/7350.client.web.********************.js 3.31 kB 0 B
dotcom-rendering/dist/7540.client.web.********************.js 2.73 kB 0 B
dotcom-rendering/dist/7544.client.web.********************.js 4.77 kB 0 B
dotcom-rendering/dist/7546.client.web.********************.js 7.76 kB 0 B
dotcom-rendering/dist/7670.client.web.********************.js 3.17 kB 0 B
dotcom-rendering/dist/7730.client.web.********************.js 3.64 kB 0 B
dotcom-rendering/dist/7765.client.web.********************.js 17.6 kB 0 B
dotcom-rendering/dist/7797.client.web.********************.js 3.75 kB 0 B
dotcom-rendering/dist/7861.client.web.********************.js 617 B 0 B
dotcom-rendering/dist/7975.client.web.********************.js 4.49 kB 0 B
dotcom-rendering/dist/8030.client.web.********************.js 4.31 kB 0 B
dotcom-rendering/dist/8039.client.web.********************.js 7.89 kB 0 B
dotcom-rendering/dist/8229.client.web.********************.js 2.68 kB 0 B
dotcom-rendering/dist/8877.client.web.********************.js 3.53 kB 0 B
dotcom-rendering/dist/8918.client.web.********************.js 20.4 kB 0 B
dotcom-rendering/dist/8964.client.web.********************.js 7.42 kB 0 B
dotcom-rendering/dist/9242.client.web.********************.js 3.76 kB 0 B
dotcom-rendering/dist/9294.client.web.********************.js 3.27 kB 0 B
dotcom-rendering/dist/943.client.web.********************.js 3.08 kB 0 B
dotcom-rendering/dist/9558.client.web.********************.js 3.53 kB 0 B
dotcom-rendering/dist/9665.client.web.********************.js 4.14 kB 0 B
dotcom-rendering/dist/9734.client.web.********************.js 3.63 kB 0 B
dotcom-rendering/dist/9977.client.web.********************.js 3.42 kB 0 B
dotcom-rendering/dist/Accessibility-importable.client.web.********************.js 7 kB 0 B
dotcom-rendering/dist/AdBlockAsk-importable.client.web.********************.js 2.99 kB 0 B
dotcom-rendering/dist/AdPortals-importable.client.web.********************.js 4.76 kB 0 B
dotcom-rendering/dist/AlreadyVisited-importable.client.web.********************.js 423 B 0 B
dotcom-rendering/dist/AppsEpic-importable.client.web.********************.js 3.63 kB 0 B
dotcom-rendering/dist/AppsFooter-importable.client.web.********************.js 2.7 kB 0 B
dotcom-rendering/dist/AppsLightboxImage-importable.client.web.********************.js 2.66 kB 0 B
dotcom-rendering/dist/AppsLightboxImageStore-importable.client.web.********************.js 2.58 kB 0 B
dotcom-rendering/dist/AudioAtomWrapper-importable.client.web.********************.js 2.76 kB 0 B
dotcom-rendering/dist/AudioPlayerWrapper-importable.client.web.********************.js 6.61 kB 0 B
dotcom-rendering/dist/AustralianTerritorySwitcher-importable.client.web.********************.js 2.01 kB 0 B
dotcom-rendering/dist/Branding-importable.client.web.********************.js 2.88 kB 0 B
dotcom-rendering/dist/braze-web-sdk-core.client.web.********************.js 37.2 kB 0 B
dotcom-rendering/dist/BrazeMessaging-importable.client.web.********************.js 1.68 kB 0 B
dotcom-rendering/dist/CalloutBlockComponent-importable.client.web.********************.js 6.75 kB 0 B
dotcom-rendering/dist/CalloutEmbedBlockComponent-importable.client.web.********************.js 5.77 kB 0 B
dotcom-rendering/dist/CardCommentCount-importable.client.web.********************.js 2.66 kB 0 B
dotcom-rendering/dist/Carousel-importable.client.web.********************.js 6.67 kB +1 B (+0.01%)
dotcom-rendering/dist/CarouselForNewsletters-importable.client.web.********************.js 5.17 kB 0 B
dotcom-rendering/dist/ChartAtom-importable.client.web.********************.js 538 B 0 B
dotcom-rendering/dist/CommentCount-importable.client.web.********************.js 2.29 kB 0 B
dotcom-rendering/dist/CrosswordComponent-importable.client.web.********************.js 2.67 kB 0 B
dotcom-rendering/dist/DiscussionApps-importable.client.web.********************.js 1.07 kB 0 B
dotcom-rendering/dist/DiscussionMeta-importable.client.web.********************.js 2.4 kB 0 B
dotcom-rendering/dist/DiscussionWeb-importable.client.web.********************.js 3.45 kB 0 B
dotcom-rendering/dist/DocumentBlockComponent-importable.client.web.********************.js 2.81 kB 0 B
dotcom-rendering/dist/Dropdown-importable.client.web.********************.js 1.72 kB 0 B
dotcom-rendering/dist/EditionSwitcherBanner-importable.client.web.********************.js 4.43 kB 0 B
dotcom-rendering/dist/EmbedBlockComponent-importable.client.web.********************.js 3.94 kB 0 B
dotcom-rendering/dist/EnhancePinnedPost-importable.client.web.********************.js 2.02 kB 0 B
dotcom-rendering/dist/FetchOnwardsData-importable.client.web.********************.js 1.94 kB 0 B
dotcom-rendering/dist/FilterKeyEventsToggle-importable.client.web.********************.js 3.71 kB 0 B
dotcom-rendering/dist/FocusStyles-importable.client.web.********************.js 618 B 0 B
dotcom-rendering/dist/FollowWrapper-importable.client.web.********************.js 2.52 kB 0 B
dotcom-rendering/dist/FootballMatchesPageWrapper-importable.client.web.********************.js 6.76 kB 0 B
dotcom-rendering/dist/FooterLabel-importable.client.web.********************.js 343 B 0 B
dotcom-rendering/dist/FooterReaderRevenueLinks-importable.client.web.********************.js 3.43 kB 0 B
dotcom-rendering/dist/frameworks.client.web.********************.js 20.9 kB 0 B
dotcom-rendering/dist/FrontSubNav-importable.client.web.********************.js 7.47 kB 0 B
dotcom-rendering/dist/GetCricketScoreboard-importable.client.web.********************.js 6.28 kB 0 B
dotcom-rendering/dist/GetMatchNav-importable.client.web.********************.js 11.5 kB 0 B
dotcom-rendering/dist/GetMatchStats-importable.client.web.********************.js 8 kB 0 B
dotcom-rendering/dist/GetMatchTabs-importable.client.web.********************.js 2.58 kB 0 B
dotcom-rendering/dist/guardian-braze-components-banner.client.web.********************.js 15.8 kB 0 B
dotcom-rendering/dist/guardian-braze-components-end-of-article.client.web.********************.js 10.2 kB 0 B
dotcom-rendering/dist/GuideAtomWrapper-importable.client.web.********************.js 783 B 0 B
dotcom-rendering/dist/index.client.web.********************.js 46.3 kB +1 B (0%)
dotcom-rendering/dist/InstagramBlockComponent-importable.client.web.********************.js 2.9 kB 0 B
dotcom-rendering/dist/InteractiveAtomMessenger-importable.client.web.********************.js 852 B 0 B
dotcom-rendering/dist/InteractiveBlockComponent-importable.client.web.********************.js 8.73 kB 0 B
dotcom-rendering/dist/InteractiveContentsBlockComponent-importable.client.web.********************.js 3.77 kB 0 B
dotcom-rendering/dist/KeyEventsCarousel-importable.client.web.********************.js 5.71 kB 0 B
dotcom-rendering/dist/KnowledgeQuizAtom-importable.client.web.********************.js 3.55 kB 0 B
dotcom-rendering/dist/LatestLinks-importable.client.web.********************.js 6.41 kB 0 B
dotcom-rendering/dist/LightboxHash-importable.client.web.********************.js 434 B 0 B
dotcom-rendering/dist/LightboxLayout-importable.client.web.********************.js 6.54 kB 0 B
dotcom-rendering/dist/LiveBlogEpic-importable.client.web.********************.js 3.6 kB 0 B
dotcom-rendering/dist/LiveblogGutterAskWrapper-importable.client.web.********************.js 2.51 kB 0 B
dotcom-rendering/dist/LiveblogNotifications-importable.client.web.********************.js 4.81 kB 0 B
dotcom-rendering/dist/Liveness-importable.client.web.********************.js 4.72 kB 0 B
dotcom-rendering/dist/ManyNewsletterSignUp-importable.client.web.********************.js 7.68 kB 0 B
dotcom-rendering/dist/MapEmbedBlockComponent-importable.client.web.********************.js 5.96 kB 0 B
dotcom-rendering/dist/Metrics-importable.client.web.********************.js 2.69 kB 0 B
dotcom-rendering/dist/MostViewedFooter-importable.client.web.********************.js 4.01 kB 0 B
dotcom-rendering/dist/MostViewedFooterData-importable.client.web.********************.js 6.11 kB 0 B
dotcom-rendering/dist/MostViewedRightWithAd-importable.client.web.********************.js 5.26 kB 0 B
dotcom-rendering/dist/OnwardsUpper-importable.client.web.********************.js 5.39 kB 0 B
dotcom-rendering/dist/PersonalityQuizAtom-importable.client.web.********************.js 3.72 kB 0 B
dotcom-rendering/dist/ProfileAtom-importable.client.web.********************.js 543 B 0 B
dotcom-rendering/dist/ProfileAtomWrapper-importable.client.web.********************.js 802 B 0 B
dotcom-rendering/dist/PulsingDot-importable.client.web.********************.js 750 B 0 B
dotcom-rendering/dist/QandaAtom-importable.client.web.********************.js 543 B 0 B
dotcom-rendering/dist/ReaderRevenueDev-importable.client.web.********************.js 468 B 0 B
dotcom-rendering/dist/readerRevenueDevUtils.client.web.********************.js 1.69 kB 0 B
dotcom-rendering/dist/RelativeTime-importable.client.web.********************.js 2.55 kB 0 B
dotcom-rendering/dist/RichLinkComponent-importable.client.web.********************.js 6.11 kB 0 B
dotcom-rendering/dist/ScrollableFeature-importable.client.web.********************.js 6.41 kB 0 B
dotcom-rendering/dist/ScrollableHighlights-importable.client.web.********************.js 5.83 kB 0 B
dotcom-rendering/dist/ScrollableMedium-importable.client.web.********************.js 2.1 kB 0 B
dotcom-rendering/dist/ScrollableSmall-importable.client.web.********************.js 2.07 kB 0 B
dotcom-rendering/dist/SecureSignup-importable.client.web.********************.js 3.76 kB 0 B
dotcom-rendering/dist/SendTargetingParams-importable.client.web.********************.js 2.22 kB 0 B
dotcom-rendering/dist/sentry.client.web.********************.js 805 B 0 B
dotcom-rendering/dist/SetABTests-importable.client.web.********************.js 3.92 kB 0 B
dotcom-rendering/dist/SetAdTargeting-importable.client.web.********************.js 486 B 0 B
dotcom-rendering/dist/ShareButton-importable.client.web.********************.js 917 B 0 B
dotcom-rendering/dist/shimport.client.web.********************.js 2.8 kB 0 B
dotcom-rendering/dist/ShowHideContainers-importable.client.web.********************.js 894 B 0 B
dotcom-rendering/dist/ShowMore-importable.client.web.********************.js 2.1 kB 0 B
dotcom-rendering/dist/SignInGateMain.client.web.********************.js 4.38 kB 0 B
dotcom-rendering/dist/SignInGateMainCheckoutComplete.client.web.********************.js 5.48 kB 0 B
dotcom-rendering/dist/SignInGateSelector-importable.client.web.********************.js 8.54 kB 0 B
dotcom-rendering/dist/SlideshowCarousel-importable.client.web.********************.js 4.46 kB 0 B
dotcom-rendering/dist/SlotBodyEnd-importable.client.web.********************.js 4.78 kB 0 B
dotcom-rendering/dist/SpotifyBlockComponent-importable.client.web.********************.js 5.78 kB 0 B
dotcom-rendering/dist/StickyBottomBanner-importable.client.web.********************.js 6.03 kB 0 B
dotcom-rendering/dist/SubNav-importable.client.web.********************.js 2.43 kB 0 B
dotcom-rendering/dist/TableOfContents-importable.client.web.********************.js 3.51 kB 0 B
dotcom-rendering/dist/TimelineAtom-importable.client.web.********************.js 1.23 kB 0 B
dotcom-rendering/dist/Titlepiece-importable.client.web.********************.js 13.6 kB 0 B
dotcom-rendering/dist/TopBar-importable.client.web.********************.js 8.8 kB 0 B
dotcom-rendering/dist/TopBarSupport-importable.client.web.********************.js 2.51 kB 0 B
dotcom-rendering/dist/TweetBlockComponent-importable.client.web.********************.js 1.14 kB 0 B
dotcom-rendering/dist/UnsafeEmbedBlockComponent-importable.client.web.********************.js 2.91 kB 0 B
dotcom-rendering/dist/VideoFacebookBlockComponent-importable.client.web.********************.js 5.97 kB 0 B
dotcom-rendering/dist/VineBlockComponent-importable.client.web.********************.js 2.78 kB 0 B
dotcom-rendering/dist/YoutubeBlockComponent-importable.client.web.********************.js 1.37 kB 0 B

compressed-size-action

@domlander domlander force-pushed the doml/refactor/card-wrapper-top-bar branch from 762c431 to dcefc55 Compare March 20, 2025 12:13
@domlander domlander added the run_chromatic Runs chromatic when label is applied label Mar 20, 2025
@github-actions github-actions bot added dotcom-rendering and removed run_chromatic Runs chromatic when label is applied labels Mar 20, 2025
@domlander domlander force-pushed the doml/refactor/card-wrapper-top-bar branch from dcefc55 to c47b974 Compare March 20, 2025 12:29
@domlander domlander added the run_chromatic Runs chromatic when label is applied label Mar 20, 2025
@github-actions github-actions bot removed the run_chromatic Runs chromatic when label is applied label Mar 20, 2025
@@ -1505,6 +1506,8 @@ export const WithNoGap = () => {
{...basicCardProps}
imagePositionOnDesktop="left"
isOnwardContent={true}
showTopBarDesktop={false}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Onwards content doesn't have a top bar on mobile or desktop, so adding these props make sense for this story

@@ -407,7 +407,7 @@ export const Card = ({
index = 0,
isFlexSplash,
showTopBarDesktop = true,
showTopBarMobile = false,
showTopBarMobile = true,
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Before this change, a top bar would be shown on mobile if either showTopBarDesktop or showTopBarMobile was true

@@ -752,10 +752,10 @@ export const Card = ({
return (
<CardWrapper
format={format}
showTopBarDesktop={!isOnwardContent && showTopBarDesktop}
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The Carousel calling the card component now specifies that there shouldn't be a top bar at both screen sizes when the card is Onwards Content, so this extra check isn't needed.

@domlander domlander force-pushed the doml/refactor/card-wrapper-top-bar branch from c47b974 to d5151de Compare March 24, 2025 17:21
@domlander domlander added the run_chromatic Runs chromatic when label is applied label Mar 24, 2025
@domlander domlander marked this pull request as ready for review March 24, 2025 17:22
@domlander domlander requested a review from a team as a code owner March 24, 2025 17:22
@github-actions github-actions bot removed the run_chromatic Runs chromatic when label is applied label Mar 24, 2025
Copy link
Contributor

@abeddow91 abeddow91 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good find, thanks for taking the time to do this ✨ 🧹

@domlander domlander merged commit 8f10440 into main Mar 31, 2025
32 checks passed
@domlander domlander deleted the doml/refactor/card-wrapper-top-bar branch March 31, 2025 13:18
@prout-bot
Copy link

Seen on PROD (merged by @domlander 10 minutes and 3 seconds ago) Please check your changes!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants