Skip to content

Commit

Permalink
feat(progress-tracker): add disabled and readonly features
Browse files Browse the repository at this point in the history
  • Loading branch information
soykje committed Dec 6, 2023
1 parent 1e07cbb commit 3253646
Show file tree
Hide file tree
Showing 7 changed files with 74 additions and 25 deletions.
12 changes: 8 additions & 4 deletions packages/components/progress-tracker/src/ProgressTracker.doc.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,14 @@ import { ProgressTracker } from '@spark-ui/progress-tracker'

Use `readOnly` prop to indicate that the component is not interactive.

<Canvas of={stories.Readonly} />

### Disabled

Use `disabled` prop on a step to disable it.

<Canvas of={stories.Disabled} />

### Sizes

Use `size` prop to set the size of the progress indicators. Smallest size doesn't get any content.
Expand All @@ -61,10 +69,6 @@ Use `intent` prop to set the color.

Use `design` prop to set the look and feel.

### Disabled

Use `disabled` prop on a step to disable it.

### Orientation

Use `orientation` prop to set `horizontal|vertical` orientation.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,21 +14,37 @@ const sizes: ProgressTrackerProps['size'][] = ['sm', 'md', 'lg']

export const Default: StoryFn = _args => (
<ProgressTracker stepIndex={1} onStepClick={id => console.log('Clicked on', id)}>
<ProgressTracker.Step label="Etape 1" />
<ProgressTracker.Step label="Etape 2" />
<ProgressTracker.Step label="Etape 3" />
<ProgressTracker.Step label="Build" />
<ProgressTracker.Step label="Deploy" />
<ProgressTracker.Step label="Iterate" />
</ProgressTracker>
)

export const Disabled: StoryFn = _args => (
<ProgressTracker stepIndex={1} onStepClick={id => console.log('Clicked on', id)}>
<ProgressTracker.Step label="Build" />
<ProgressTracker.Step label="Deploy" />
<ProgressTracker.Step label="Iterate" disabled />
</ProgressTracker>
)

export const Readonly: StoryFn = _args => (
<ProgressTracker stepIndex={1} readOnly>
<ProgressTracker.Step label="Build" />
<ProgressTracker.Step label="Deploy" />
<ProgressTracker.Step label="Iterate" />
</ProgressTracker>
)

export const Size: StoryFn = _args => (
<div className="flex flex-wrap items-center gap-md">
<div className="flex flex-wrap items-center gap-lg">
{sizes.map(size => (
<div key={size}>
<StoryLabel>{`${size}${size === 'lg' ? ' (default)' : ''}`}</StoryLabel>
<ProgressTracker size={size as ProgressTrackerProps['size']}>
<ProgressTracker.Step label="Etape 1" />
<ProgressTracker.Step label="Etape 2" />
<ProgressTracker.Step label="Etape 3" />
<ProgressTracker stepIndex={1} size={size as ProgressTrackerProps['size']}>
<ProgressTracker.Step label="Build" />
<ProgressTracker.Step label="Deploy" />
<ProgressTracker.Step label="Iterate" />
</ProgressTracker>
</div>
))}
Expand Down
Empty file.
11 changes: 9 additions & 2 deletions packages/components/progress-tracker/src/ProgressTracker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,15 @@ export const ProgressTracker = forwardRef<HTMLDivElement, PropsWithChildren<Prog
const Component = readOnly ? 'div' : 'nav'

return (
<ProgressTrackerContext.Provider value={{ stepIndex, onStepClick, steps, setSteps, size }}>
<Component ref={ref} className={cx('inline-flex', className)} {...rest}>
<ProgressTrackerContext.Provider
value={{ stepIndex, onStepClick, steps, setSteps, size, readOnly }}
>
<Component
ref={ref}
aria-label="progress"
className={cx('inline-flex', className)}
{...rest}
>
<ol className="flex w-full flex-nowrap" style={{ counterReset: 'step' }}>
{children}
</ol>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { createContext, type Dispatch, type SetStateAction, useContext } from 'r
import type { ProgressTrackerProps } from './ProgressTracker'

export type ProgressTrackerContextInterface = Required<
Pick<ProgressTrackerProps, 'stepIndex' | 'onStepClick' | 'size'>
Pick<ProgressTrackerProps, 'stepIndex' | 'onStepClick' | 'size' | 'readOnly'>
> & {
steps: Set<string>
setSteps: Dispatch<SetStateAction<Set<string>>>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,13 @@ export const stepItemVariant = cva(
'before:right-[calc(50%+20px)] after:left-[calc(50%+20px)]',
],
},
disabled: {
true: 'before:opacity-dim-3 after:opacity-dim-3',
false: '',
},
},
defaultVariants: {
disabled: false,
size: 'lg',
},
}
Expand Down Expand Up @@ -59,21 +64,34 @@ export const stepButtonVariant = cva(
true: [
'before:content-[url()]',
'before:inline-flex before:leading-none',
'hover:before:bg-basic/dim-5',
],
false: '',
},
active: {
true: ['before:bg-basic-container', 'hover:before:bg-basic/dim-5'],
true: ['before:bg-basic-container', 'cursor-default'],
false: '',
},
disabled: {
true: 'opacity-dim-3',
true: 'before:opacity-dim-3',
false: '',
},
readOnly: {
true: ['cursor-default'],
false: '',
},
},
compoundVariants: [
{
readOnly: false,
disabled: false,
active: false,
complete: [true, false],
class: 'hover:before:bg-basic/dim-5',
},
],
defaultVariants: {
disabled: false,
readOnly: false,
active: false,
complete: false,
size: 'lg',
Expand Down
18 changes: 11 additions & 7 deletions packages/components/progress-tracker/src/ProgressTrackerStep.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,13 @@ export const ProgressTrackerStep = forwardRef<HTMLLIElement, ProgressTrackerStep
onStepClick,
setSteps,
size,
readOnly,
} = useProgressTrackerContext()

const ID = useId()
const stepId = `step-${ID}`

const [progressState, setProgressState] = useState<
'active' | 'complete' | 'disabled' | undefined
>(() => (disabled ? 'disabled' : undefined))
const [progressState, setProgressState] = useState<'active' | 'complete' | undefined>()

useEffect(() => setSteps(steps => steps.add(stepId)), [])

Check warning on line 27 in packages/components/progress-tracker/src/ProgressTrackerStep.tsx

View workflow job for this annotation

GitHub Actions / Lint

React Hook useEffect has missing dependencies: 'setSteps' and 'stepId'. Either include them or remove the dependency array

Expand All @@ -42,17 +41,22 @@ export const ProgressTrackerStep = forwardRef<HTMLLIElement, ProgressTrackerStep
id={stepId}
ref={ref}
data-state={progressState}
className={stepItemVariant({ size })}
aria-current={progressState === 'active'}
className={stepItemVariant({ size, disabled })}
{...rest}
>
<button
type="button"
onClick={() => onStepClick(stepId)}
disabled={progressState === 'disabled'}
{...(!['disabled', 'active'].includes(`${progressState}`) &&
!readOnly && {
onClick: () => onStepClick(stepId),
})}
disabled={disabled}
className={stepButtonVariant({
complete: progressState === 'complete',
active: progressState === 'active',
disabled: progressState === 'disabled',
disabled,
readOnly,
size,
className,
})}
Expand Down

0 comments on commit 3253646

Please sign in to comment.