Skip to content

Commit

Permalink
feat(Tooltip): fix dynamic width
Browse files Browse the repository at this point in the history
  • Loading branch information
alexbrillant committed Mar 22, 2024
1 parent 9c9502a commit b7d91cc
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 2 deletions.
4 changes: 4 additions & 0 deletions packages/react/src/components/tooltip/tooltip.test.tsx.snap
Original file line number Diff line number Diff line change
Expand Up @@ -220,6 +220,7 @@ exports[`Tooltip Has default desktop styles (defaultOpen) 1`] = `
data-testid="tooltip-content-container"
id="uuid1"
isMobile={false}
key="1"
role="tooltip"
style={
{
Expand Down Expand Up @@ -492,6 +493,7 @@ exports[`Tooltip Has default desktop styles 1`] = `
data-testid="tooltip-content-container"
id="uuid1"
isMobile={false}
key="1"
role="tooltip"
style={
{
Expand Down Expand Up @@ -768,6 +770,7 @@ exports[`Tooltip Has mobile styles (defaultOpen) 1`] = `
data-testid="tooltip-content-container"
id="uuid1"
isMobile={true}
key="1"
role="tooltip"
style={
{
Expand Down Expand Up @@ -1040,6 +1043,7 @@ exports[`Tooltip Has mobile styles 1`] = `
data-testid="tooltip-content-container"
id="uuid1"
isMobile={true}
key="1"
role="tooltip"
style={
{
Expand Down
6 changes: 6 additions & 0 deletions packages/react/src/components/tooltip/tooltip.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -232,9 +232,14 @@ export const Tooltip: FunctionComponent<PropsWithChildren<TooltipProps>> = ({
const [tooltipTimeout, setTooltipTimeout] = useState<NodeJS.Timeout | undefined>();
const [controlledTooltipOpen, setControlledTooltipOpen] = useState<boolean>();
const [isClicked, setIsClicked] = useState<boolean>(false);
const [tooltipKey, setTooltipKey] = useState<number>(0);
const currentLabel = isClicked ? (confirmationLabel ?? label) : label;
const tooltipVariant = (mode === 'confirm' && isClicked) ? 'success' : 'normal';

useEffect(() => {
setTooltipKey((prevKey) => prevKey + 1);
}, [currentLabel]);

const getTooltipTriggerType = useCallback((): TriggerType | null => {
if (disabled) {
return null;
Expand Down Expand Up @@ -365,6 +370,7 @@ export const Tooltip: FunctionComponent<PropsWithChildren<TooltipProps>> = ({
isMobile={isMobile}
variant={tooltipVariant}
visible={popperTooltip.visible}
key={tooltipKey}
{...popperTooltip.getTooltipProps() /* eslint-disable-line react/jsx-props-no-spreading */}
>
<TooltipArrow
Expand Down
53 changes: 51 additions & 2 deletions packages/storybook/stories/tooltip.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,10 @@ import {
DropdownList,
Tooltip,
TooltipPlacement,
TextInput,
} from '@equisoft/design-elements-react';
import { StoryFn as Story } from '@storybook/react';
import { useState } from 'react';
import { useState, useCallback } from 'react';
import styled from 'styled-components';
import { DesktopDecorator } from './utils/device-context-decorator';
import { rawCodeParameters } from './utils/parameters';
Expand Down Expand Up @@ -132,8 +133,9 @@ export const WithDropdownNavigation: Story = () => {

WithDropdownNavigation.decorators = [RouterDecorator];

const CodeContainer = styled.div`
const CodeContainer = styled.div<{ justifyContent?: string }>`
display: flex;
justify-content: ${({ justifyContent }) => (justifyContent || 'flex-start')};
`;
export const WithConfirmation: Story = () => {
const code = 'JBSW Y3DP EHPK 3PXP';
Expand Down Expand Up @@ -161,3 +163,50 @@ export const WithConfirmation: Story = () => {
</Container>
);
};

export const WithDynamicText: Story = () => {
const [label, setLabel] = useState<string>('Hide password');
const [iconName, setIconName] = useState<'eye' | 'eyeOff'>('eye');
const [inputType, setInputType] = useState<string>('password');
const [password, setPassword] = useState<string>('somePassword');
const handleOnClick = useCallback(() => {
if (label === 'Hide password') {
setLabel('Show password in plain text');
setIconName('eyeOff');
setInputType('password');
} else {
setLabel('Hide password');
setIconName('eye');
setInputType('text');
}
}, [label, setLabel]);
const handleOnPasswordChange = useCallback((newPassword) => {
setPassword(newPassword);
}, [setPassword]);

return (
<Container>
<CodeContainer justifyContent='flex-end'>
<TextInput
required
label="Password"
type={inputType}
value={password}
onChange={handleOnPasswordChange}
validationErrorMessage="This field is required"
/>
<Tooltip
label={label}
desktopPlacement="top"
defaultOpen
>
<IconButton
buttonType='primary'
onClick={handleOnClick}
iconName={iconName}
/>
</Tooltip>
</CodeContainer>
</Container>
);
};

0 comments on commit b7d91cc

Please sign in to comment.