From fc313999554edcfeecd73eaa6f139757de784570 Mon Sep 17 00:00:00 2001 From: Lisa Kim Date: Fri, 19 Jul 2024 17:05:50 -0700 Subject: [PATCH] Web: SlideTabs, prevent click instead of using pointer-events (#44114) --- .../design/src/SlideTabs/SlideTabs.story.tsx | 11 +++++++++++ web/packages/design/src/SlideTabs/SlideTabs.tsx | 17 ++++++++++------- 2 files changed, 21 insertions(+), 7 deletions(-) diff --git a/web/packages/design/src/SlideTabs/SlideTabs.story.tsx b/web/packages/design/src/SlideTabs/SlideTabs.story.tsx index e95877f7ba640..46ff166c5cef7 100644 --- a/web/packages/design/src/SlideTabs/SlideTabs.story.tsx +++ b/web/packages/design/src/SlideTabs/SlideTabs.story.tsx @@ -81,3 +81,14 @@ export const LoadingTab = () => { /> ); }; + +export const DisabledTab = () => { + return ( + null} + activeIndex={1} + disabled={true} + /> + ); +}; diff --git a/web/packages/design/src/SlideTabs/SlideTabs.tsx b/web/packages/design/src/SlideTabs/SlideTabs.tsx index abaf86e0f39d1..191e7b32f1bc5 100644 --- a/web/packages/design/src/SlideTabs/SlideTabs.tsx +++ b/web/packages/design/src/SlideTabs/SlideTabs.tsx @@ -36,14 +36,18 @@ export function SlideTabs({ {tabs.map((tabName, tabIndex) => { const selected = tabIndex === activeIndex; + let onClick; + if (!disabled && !isProcessing) { + onClick = (e: React.MouseEvent) => { + e.preventDefault(); + onChange(tabIndex); + }; + } return ( { - e.preventDefault(); - onChange(tabIndex); - }} + onClick={onClick} itemCount={tabs.length} key={`${tabName}-${tabIndex}`} className={tabIndex === activeIndex && 'selected'} @@ -123,14 +127,13 @@ const TabLabel = styled.label<{ processing?: boolean; disabled?: boolean; }>` - cursor: pointer; + cursor: ${p => (p.processing || p.disabled ? 'default' : 'pointer')}; display: flex; justify-content: center; padding: 10px; width: ${props => 100 / props.itemCount}%; z-index: 1; /* Ensures that the label is above the background slider. */ - opacity: ${p => (p.processing ? 0.5 : 1)}; - pointer-events: ${p => (p.processing || p.disabled ? 'none' : 'auto')}; + opacity: ${p => (p.processing || p.disabled ? 0.5 : 1)}; `; const TabInput = styled.input`