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

[WEB-3397] - Mobile Responsiveness V1 #1505

Merged
merged 102 commits into from
Feb 12, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
102 commits
Select commit Hold shift + click to select a range
88d5cd9
remove mobil check from isSupportedBrowser()
henry-tp Jan 23, 2025
4d253cb
initial setup for mobile/desktop navbar
henry-tp Jan 24, 2025
0a4a482
backdrop on mobile nav popover
henry-tp Jan 24, 2025
e02793f
add initial menu option rows
henry-tp Jan 24, 2025
000576e
abstract application logic out of navbar component
henry-tp Jan 24, 2025
edbf0a8
abstract out navbar functions to custom hook
henry-tp Jan 24, 2025
91f45ac
bind mobile dropdown to useNavbar callbacks
henry-tp Jan 24, 2025
d28fdb3
hide chart below breakpoint
henry-tp Jan 24, 2025
1d584e4
remove chart navigation on mobile
henry-tp Jan 24, 2025
529df9e
fix devices menu not showing
henry-tp Jan 24, 2025
cf3765f
initial functionality of settings chart button
henry-tp Jan 24, 2025
e2188aa
pull getters out of custom hook
henry-tp Jan 26, 2025
16ef391
fix demographic info bug
henry-tp Jan 26, 2025
bc29597
prevent clinicians from accessing mobile navbar for v1
henry-tp Jan 26, 2025
aa08eb6
use a setter in redux for navbarChartTypeForTitle
henry-tp Jan 26, 2025
6ebe49e
hide navpatientheader on mobile
henry-tp Jan 26, 2025
19d00b5
fix navpatientheader breakpoint
henry-tp Jan 26, 2025
dda188e
initial header titles with icon
henry-tp Jan 26, 2025
2d2cf15
hide patient menu options when lacking patient context
henry-tp Jan 27, 2025
53ff470
allow update of chart via queryParams
henry-tp Jan 27, 2025
0fa7c24
incremental visual improvement on header styles
henry-tp Jan 27, 2025
d1922f3
add tidepool mobile icon
henry-tp Jan 27, 2025
d5c7907
dropdown background on click
henry-tp Jan 27, 2025
df3e597
fix css typo
henry-tp Jan 27, 2025
d0b017f
remove accidental console.log
henry-tp Jan 27, 2025
68f8c0e
dialog content
henry-tp Jan 27, 2025
d8891db
mobile styles for share page
henry-tp Jan 27, 2025
b4e2e49
close button for dropdown
henry-tp Jan 27, 2025
7a32305
exception with welcome message
henry-tp Jan 27, 2025
50da716
Merge branch 'develop' into WEB-3397-mobile-views
henry-tp Jan 27, 2025
3585af1
use dark-on-light theming for stats title bar
henry-tp Jan 27, 2025
edea64d
Merge branch 'WEB-3397-mobile-views' of github.com:tidepool-org/blip …
henry-tp Jan 27, 2025
3a10904
incremental mobile navbar styling and refactor
henry-tp Jan 27, 2025
da65a71
use user object to determine browser-warning reqs
henry-tp Jan 28, 2025
c382ee3
fix routing bug and patients list page
henry-tp Jan 28, 2025
c8e1b06
fix patient accounts page
henry-tp Jan 28, 2025
05d5be8
fix basics chart
henry-tp Jan 28, 2025
3ebfc26
chart date selector
henry-tp Jan 28, 2025
5e33a06
fix /patients route redirecting
henry-tp Jan 28, 2025
1577a4a
maintain patient context when visiting /patients and light refactor
henry-tp Jan 29, 2025
79c49ba
do not clear patient from view when visiting Private Workspace
henry-tp Jan 29, 2025
5dae4d8
fix bgLog chart error
henry-tp Jan 29, 2025
4297290
fix daily chart error
henry-tp Jan 29, 2025
454f563
make modal full expansion occur by default on mobile
henry-tp Jan 29, 2025
818661e
fix NavPatientHeader tests
henry-tp Jan 29, 2025
c91a42f
fix useNavigation rewire issue
henry-tp Jan 29, 2025
06644af
move NavbarChartTypeSetter up to PatientData child level
henry-tp Jan 29, 2025
9cfb712
fix visual regression - subnav has wrong color
henry-tp Jan 29, 2025
7baa92a
fix test for patientdata - stub out NavbarChartTypeSetter
henry-tp Jan 29, 2025
df8cbac
fix Desktop and Mobile test directory
henry-tp Jan 29, 2025
637869c
fix patients component test
henry-tp Jan 29, 2025
e804a59
fix NavigationMenu tests
henry-tp Jan 29, 2025
36c2686
fix navigationmenu tests
henry-tp Jan 29, 2025
d83712f
add mobile-only share data card
henry-tp Jan 29, 2025
3f0c372
card fills height
henry-tp Jan 29, 2025
ea74eaf
add devices icon and apply color filter
henry-tp Jan 29, 2025
68e232d
add jsdoc for navutils
henry-tp Jan 29, 2025
e1af8f3
add tests for mobile navbar
henry-tp Jan 29, 2025
9ca63ca
tests for useNavigation
henry-tp Jan 29, 2025
48b5b3c
use DesktopOnly and MobileOnly in header
henry-tp Jan 30, 2025
c96e66e
JSDoc for MediaQueries
henry-tp Jan 30, 2025
b720c8f
remove patient from DesktopNavbar proptypes
henry-tp Jan 30, 2025
94bec1b
move trackMetric function to useNavigation
henry-tp Jan 30, 2025
a7cf589
use DesktopOnly to conditionally show NavPatientHeader
henry-tp Jan 30, 2025
2835768
use DesktopOnly for AccessManagement
henry-tp Jan 30, 2025
1854f82
fix wrong nav target bug
henry-tp Jan 30, 2025
9788e80
use DesktopOnly in ChartDateRangeModal
henry-tp Jan 30, 2025
84cc459
fix JSDoc args
henry-tp Jan 30, 2025
585a0c6
hide PatientDetails on DataConnectionsModal on mobile
henry-tp Jan 30, 2025
54271e5
replace devices icon with updated one
henry-tp Jan 30, 2025
47e2d5d
add new metric for View Devices
henry-tp Jan 31, 2025
e5a231a
fix JSDoc for useNavigation
henry-tp Jan 31, 2025
ecdf6ca
fix first run state
henry-tp Jan 31, 2025
b579529
implement imported selector pattern
henry-tp Jan 31, 2025
d607d23
border radius around cards
henry-tp Jan 31, 2025
59b3596
fix useragent sniffer to accept CriOS
henry-tp Jan 31, 2025
cc802af
fix tests due to switch to pulling from redux
henry-tp Jan 31, 2025
7e56073
code comments
henry-tp Jan 31, 2025
5f4db0d
update query param history when chart changes
henry-tp Jan 31, 2025
8eeb751
add logout case to navbarChartType reducer
henry-tp Jan 31, 2025
cb40b15
missing newlines
henry-tp Jan 31, 2025
877208f
missing newline
henry-tp Jan 31, 2025
f9a1d5e
fix text descriptions
henry-tp Feb 1, 2025
1456692
clear patient before fetching
henry-tp Feb 1, 2025
12a4285
Revert "clear patient before fetching"
henry-tp Feb 1, 2025
3aa75b8
clear out currentPatientInView when fetching patient
henry-tp Feb 1, 2025
54eb2a2
fix tests related to queryParams updates
henry-tp Feb 3, 2025
3b7af11
fix tests for clearing patient on fetch patient
henry-tp Feb 3, 2025
5a970f4
hide upload button and therapy settings on mobile
henry-tp Feb 3, 2025
00e12ee
trigger CI
henry-tp Feb 3, 2025
96b087f
WEB-3397 increase loader size in patientdata
henry-tp Feb 5, 2025
9bc33ff
WEB-3397 share page padding
henry-tp Feb 5, 2025
73ee8c2
WEB-3397 increase input font size on mobile
henry-tp Feb 5, 2025
573ac62
WEB-3397 fix share data missing title state
henry-tp Feb 5, 2025
c74ef54
Merge branch 'develop' into WEB-3397-mobile-views
henry-tp Feb 5, 2025
9a6c122
Merge branch 'WEB-3397-mobile-views' of github.com:tidepool-org/blip …
henry-tp Feb 5, 2025
d33a07d
WEB-3397 hide Devices menu option for non-PwD
henry-tp Feb 5, 2025
940a7a8
WEB-3397 revert to clear patient on private workspace
henry-tp Feb 6, 2025
e8e2eb7
Revert "fix tests for clearing patient on fetch patient"
henry-tp Feb 7, 2025
ed8395a
remove erroneous box-1 identifier
henry-tp Feb 7, 2025
09696f4
Merge branch 'develop' into WEB-3397-mobile-views
henry-tp Feb 10, 2025
d68affc
WEB-3397 add back in removed tests
henry-tp Feb 12, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 11 additions & 3 deletions app/components/ChartDateRangeModal.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,13 @@ import {
} from './elements/Dialog';
import { MediumTitle, Caption, Body1 } from './elements/FontStyles';
import i18next from '../core/language';
import { breakpoints } from '../themes/baseTheme';
import { DesktopOnly } from './mediaqueries';

const t = i18next.t.bind(i18next);

const MOBILE_BREAKPOINT_QUERY = `@media screen and (max-width: ${breakpoints[1]})`;

export const ChartDateRangeModal = (props) => {
const {
chartType,
Expand Down Expand Up @@ -157,9 +161,13 @@ export const ChartDateRangeModal = (props) => {
<Box px={3}>
<Box mb={5}>
<Body1 mb={2}>{t('Number of days (most recent)')}</Body1>
<Flex id="days-chart">
<Flex
id="days-chart"
sx={{ [MOBILE_BREAKPOINT_QUERY]: { flexDirection: 'column' } }}
>
{map(presetDaysOptions, (days, i) => (
<Button
sx={{ [MOBILE_BREAKPOINT_QUERY]: { padding: '16px 0', marginBottom: '8px' }, }}
mr={2}
variant="chip"
id={`days-chart-${i}`}
Expand All @@ -174,7 +182,7 @@ export const ChartDateRangeModal = (props) => {
))}
</Flex>
</Box>
<Box mb={3}>
<DesktopOnly sx={{ marginBottom: 3 }}>
<Body1 mb={2}>{t('Or select a custom date range ({{maxDays}} days max)', { maxDays })}</Body1>
<DateRangePicker
startDate={dates.startDate}
Expand All @@ -196,7 +204,7 @@ export const ChartDateRangeModal = (props) => {
},
}}
/>
</Box>
</DesktopOnly>
{errors && (
<Caption mt={2} sx={{ color: 'feedback.danger' }} id="chart-dates-error">
{errors}
Expand Down
10 changes: 8 additions & 2 deletions app/components/chart/basics.js
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,12 @@ class Basics extends Component {
return '';
}

const endpointsRange = _.get(props, 'data.data.current.endpoints.range', []);

if (endpointsRange[0] <= 0 || endpointsRange[1] <= 0) {
return '';
}

const timePrefs = _.get(props, 'data.timePrefs', {});
let timezone;
if (!timePrefs.timezoneAware) {
Expand All @@ -210,8 +216,8 @@ class Basics extends Component {
}

const dtMask = t('MMM D, YYYY');
return sundial.formatInTimezone(_.get(props, 'data.data.current.endpoints.range', [])[0], timezone, dtMask) +
' - ' + sundial.formatInTimezone(_.get(props, 'data.data.current.endpoints.range', [])[1] - 1, timezone, dtMask);
return sundial.formatInTimezone(endpointsRange[0], timezone, dtMask) +
' - ' + sundial.formatInTimezone(endpointsRange[1] - 1, timezone, dtMask);
}

isMissingBasics = (props = this.props) => {
Expand Down
5 changes: 5 additions & 0 deletions app/components/chart/bgLog.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,11 @@ class BgLogChart extends Component {

mountChart = (node, props = {}) => {
this.log('Mounting...');

// When on mobile, the chart will be hidden and therefore have zero width and height.
// This safety check prevents an error from occurring in tideline due to the zeroes.
if (!node?.offsetHeight || !node?.offsetWidth) return;

this.chart = chartBgLogFactory(node, props);
this.chart.node = node;
this.bindEvents();
Expand Down
9 changes: 8 additions & 1 deletion app/components/chart/daily.js
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,14 @@ const DailyChart = withTranslation(null, { withRef: true })(class DailyChart ext

mountChart = (props = this.props) => {
this.log('Mounting...');
this.chart = chartDailyFactory(ReactDOM.findDOMNode(this), _.pick(props, this.chartOpts))

const node = ReactDOM.findDOMNode(this);

// When on mobile, the chart will be hidden and therefore have zero width and height.
// This safety check prevents an error from occurring in tideline due to the zeroes.
if (!node?.offsetHeight || !node?.offsetWidth) return;

this.chart = chartDailyFactory(node, _.pick(props, this.chartOpts))
.setupPools();
this.bindEvents();
};
Expand Down
64 changes: 45 additions & 19 deletions app/components/chart/header.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import { withTranslation } from 'react-i18next';
import DateRangeRoundedIcon from '@material-ui/icons/DateRangeRounded';
import PrintRoundedIcon from '@material-ui/icons/PrintRounded';
import colorPalette from '../../themes/colorPalette';
import Button from '../elements/Button';
import { DesktopOnly, MobileOnly } from '../mediaqueries';

import Icon from '../elements/Icon';
import { Box } from 'theme-ui';
Expand Down Expand Up @@ -121,8 +123,10 @@ const Header = withTranslation()(class Header extends Component {
'patient-data-subnav-hidden': this.props.chartType === 'no-data',
});

const canSelectDateRange = _.includes(['basics', 'daily'], this.props.chartType);
Copy link
Contributor Author

@henry-tp henry-tp Jan 30, 2025

Choose a reason for hiding this comment

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

If you have insight on why only these two chart types are able to launch the chart range modal, I'm curious to know. Sharon and Bill were unsure as well (discussion thread). I have duplicated this restriction for the mobile view.

Copy link
Member

Choose a reason for hiding this comment

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

I can't recall all the details, but it would have been a product decision many years ago. Likely, the addition of selectable data ranges were added one at a time, (basics first, then daily, IIRC). It was probably due to just trying to get features developed and tested quickly. Most of blips early years took a much more MVP approach to development, and new features were not added hastily.

Now, it would be trivial to add it to BG log at some point, but likely no request ever came in for it. For trends, it has it's own unique date range select UI built in, so I think product and design needed to give more thought as to whether or not it made sense to add a secondary date selection means to Trends, or replace what we have.


return (
<Box sx={{ gap: 2 }} className="grid patient-data-subnav">
<Box sx={{ gap: 2 }} className="grid patient-data-subnav" data-chart-type={this.props.chartType}>
<div className="app-no-print patient-data-subnav-left">
<a href="" className={basicsLinkClass} onClick={this.props.onClickBasics}>{t('Basics')}</a>
<a href="" className={dayLinkClass} onClick={this.props.onClickOneDay}>{t('Daily')}</a>
Expand All @@ -132,24 +136,46 @@ const Header = withTranslation()(class Header extends Component {
</div>
<div className="patient-data-subnav-center" id="tidelineLabel">
{this.renderNavButton(backClass, this.props.onClickBack, this.props.iconBack)}
<div className={dateLinkClass}>
{this.props.title}
{_.includes(['basics', 'daily'], this.props.chartType) && (
<Icon
variant="default"
sx={{
ml: 2,
mt: -1,
color: colorPalette.primary.bluePrimary00,
outline: 'none',
'&:hover': { color: 'grays.6' },
}}
label="Choose custom date range"
icon={DateRangeRoundedIcon}
onClick={this.props.onClickChartDates}
/>
)}
</div>
<DesktopOnly>
<div className={dateLinkClass}>
<span>{this.props.title}</span>
{canSelectDateRange && (
<Icon
variant="default"
sx={{
ml: 2,
mt: -1,
color: colorPalette.primary.bluePrimary00,
outline: 'none',
'&:hover': { color: 'grays.6' },
}}
label="Choose custom date range"
icon={DateRangeRoundedIcon}
onClick={this.props.onClickChartDates}
/>
)}
</div>
</DesktopOnly>
<MobileOnly>
<div className={dateLinkClass}>
{
canSelectDateRange
? <Button
onClick={this.props.onClickChartDates}
sx={{
backgroundColor: colorPalette.neutrals.white,
color: colorPalette.primary.blueGreyDark,
border: `1px solid ${colorPalette.primary.blueGreyDark}`,
padding: '8px 48px',
margin: '16px 0',
}}
>
{this.props.title}
</Button>
: <Box my={3} sx={{ fontSize: 1 }}>{this.props.title}</Box>
}
</div>
</MobileOnly>
{this.renderNavButton(nextClass, this.props.onClickNext, this.props.iconNext)}
{this.renderNavButton(mostRecentClass, this.props.onClickMostRecent, this.props.iconMostRecent)}
</div>
Expand Down
22 changes: 13 additions & 9 deletions app/components/chart/settings.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import KeyboardArrowDownRoundedIcon from '@material-ui/icons/KeyboardArrowDownRo
import DateRangeRoundedIcon from '@material-ui/icons/DateRangeRounded';
import AddRoundedIcon from '@material-ui/icons/AddRounded';
import launchCustomProtocol from 'custom-protocol-detection';
import { DesktopOnly } from '../mediaqueries';

import {
bindPopover,
Expand Down Expand Up @@ -658,15 +659,18 @@ const Settings = ({
{patientData?.dataSources?.length > 0 ? renderDataConnections() : renderDeviceConnectionCard()}
</Box>
)}
<Divider my={4} />
<MediumTitle mb={2} sx={{ color: 'black' }}>{t('Therapy Settings')}</MediumTitle>

{selectedSettingsId ? (
<>
{renderDeviceSettingsSelectionUI()}
{renderChart()}
</>
) : renderMissingSettingsMessage()}

<DesktopOnly>
<Divider my={4} />
<MediumTitle mb={2} sx={{ color: 'black' }}>{t('Therapy Settings')}</MediumTitle>

{selectedSettingsId ? (
<>
{renderDeviceSettingsSelectionUI()}
{renderChart()}
</>
) : renderMissingSettingsMessage()}
</DesktopOnly>
</Box>

<Button
Expand Down
5 changes: 4 additions & 1 deletion app/components/datasources/DataConnectionsModal.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import { useIsFirstRender, usePrevious } from '../../core/hooks';
import i18next from '../../core/language';
import { URL_TIDEPOOL_EXTERNAL_DATA_CONNECTIONS, URL_UPLOADER_DOWNLOAD_PAGE } from '../../core/constants';
import PatientEmailModal from './PatientEmailModal';
import { DesktopOnly } from '../mediaqueries';

const t = i18next.t.bind(i18next);

Expand Down Expand Up @@ -129,7 +130,9 @@ export const DataConnectionsModal = (props) => {
</DialogTitle>

<DialogContent>
<PatientDetails mb={3} patient={patientData} />
<DesktopOnly>
<PatientDetails mb={3} patient={patientData} />
</DesktopOnly>
<Subheading sx={{ fontWeight: 'bold'}}>{t('Connect a Device Account')}</Subheading>

<Box mb={3}>
Expand Down
Binary file added app/components/elements/Card/Banners/Share.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions app/components/elements/Card/Card.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ export function Card(props) {
<Box
onClick={onClick}
variant={variant}
sx={{ height: '100%' }}
>
{bannerImage && (
<Flex className="card-banner-image">
Expand Down
28 changes: 27 additions & 1 deletion app/components/elements/Dialog.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,14 @@ const t = i18next.t.bind(i18next);

import {
borders,
breakpoints,
radii,
space,
shadows,
} from '../../themes/baseTheme';

const MOBILE_BREAKPOINT = breakpoints[1];

/* Dialog Title Start */
export function DialogTitle(props) {
const {
Expand Down Expand Up @@ -101,12 +104,21 @@ const StyledDialogContent = styled(Box)`
}

overflow-y: auto;

@media screen and (max-width: ${MOBILE_BREAKPOINT}) {
// The (A) title bar and (B) actions footer are each 64px in height
min-height: calc(100% - 64px - 64px);
}
`;

export function DialogContent({ sx = {}, ...props }) {
return <StyledDialogContent
p={4}
sx={{ borderBottom: props.divider ? borders.divider : 'unset', ...sx }}
sx={{
borderBottom: props.divider ? borders.divider : 'unset',
[`@media screen and (max-width: ${breakpoints[1]})`]: { minWidth: '100vw' },
...sx,
}}
{...props}
/>;
}
Expand All @@ -123,8 +135,16 @@ DialogContent.defaultProps = {

/* Dialog Actions Start */
const StyledDialogActions = styled(Flex)`
@media screen and (max-width: ${MOBILE_BREAKPOINT}) {
gap: 16px;
}

button {
margin-left: ${space[2]}px;

@media screen and (max-width: ${MOBILE_BREAKPOINT}) {
margin: 0;
}
}

margin-top: 0;
Expand Down Expand Up @@ -159,6 +179,12 @@ const StyledDialog = styled(MuiDialog)`
border: ${borders.modal};
box-shadow: ${shadows.large};
border-radius: ${radii.default}px;

@media screen and (max-width: ${MOBILE_BREAKPOINT}) {
margin: 0;
height: 100%;
max-height: 100%;
}
}
`;

Expand Down
10 changes: 9 additions & 1 deletion app/components/elements/TextInput.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,21 @@ import cx from 'classnames';

import { Caption } from './FontStyles';
import { Icon } from './Icon';
import { fontWeights, shadows } from '../../themes/baseTheme';
import { fontWeights, shadows, breakpoints } from '../../themes/baseTheme';

const MOBILE_BREAKPOINT = breakpoints[1];

const StyledWrapper = styled(Flex)`
position: relative;
align-items: center;

> input {
flex: 1;

// Below 16px, iOS will zoom in when focusing an input field, which is unwanted behaviour
@media screen and (max-width: ${MOBILE_BREAKPOINT}) {
font-size: 16px;
}
}

.MuiSvgIcon-root {
Expand Down Expand Up @@ -53,6 +60,7 @@ export function TextInput(props) {
required,
warning: !error && warning,
});

return (
<Box sx={{ width, ...sx }} {...themeProps}>
{label && (
Expand Down
3 changes: 2 additions & 1 deletion app/components/invitation/invitation.less
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,8 @@

.invitations {
list-style-type: none;
width: 700px;
width: 100%;
max-width: 700px;
margin: 0 auto;
padding: 0px;
}
Expand Down
35 changes: 35 additions & 0 deletions app/components/mediaqueries/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import React from 'react';

import styled from '@emotion/styled';
import { breakpoints } from '../../themes/baseTheme';
import { Box } from 'theme-ui';

const DEFAULT_MOBILE_BREAKPOINT = breakpoints[1];

/**
* Renders the children only if the viewport width exceeds the specified breakpoint
*
* @param {String} [breakpoint] Viewport width below which any children will be hidden (e.g. '512px')
* @param {Object} [sx] sx prop from theme-ui
*/
export const DesktopOnly = styled(Box)`
display: block;
@media screen and (max-width: ${props => (props.breakpoint || DEFAULT_MOBILE_BREAKPOINT)}) {
display: none;
}
`;

/**
* Renders the children only if the viewport width is below the specified breakpoint
*
* @param {String} [breakpoint] Viewport width above which any children will be hidden (e.g. '512px')
* @param {Object} [sx] sx prop from theme-ui
*/
export const MobileOnly = styled(Box)`
display: none;
@media screen and (max-width: ${props => (props.breakpoint || DEFAULT_MOBILE_BREAKPOINT)}) {
display: block;
}
`;

export default { DesktopOnly, MobileOnly };
Loading