pf-codemods
v1.2.1
Published
Codemods for v4 breaking change release 2020.07
Downloads
38
Readme
pf-codemods
Hey PatternFly-React devs! pf-codemods
is an eslint wrapper to update @patternfly/[email protected] code to 4.x.x.
I hope these rules and their autofixers will help you more quickly adopt our breaking changes. These rules are not designed to fix all build errors, but they can help to fix easy ones.
Usage
Simple case
Requires Node.js >= 10.
npx pf-codemods ./src
Giving node more RAM can help for large codebases.
NODE_OPTIONS=--max-old-space-size=4096 npx pf-codemods ./path-to-src
Options
Usage: pf-codemods [options] <path> [otherPaths...]
Run codemods on path using eslint.
Options:
-V, --version output the version number
--only <rules> Comma-seperated list of rules to run
--exclude <rules> Run recommended rules EXCLUDING this comma-seperated list
--fix Whether to run fixer
--format <format> What eslint report format to use (default: "stylish")
-h, --help display help for command
Rules
These rules are based off the breaking change notes for React. Each rule links the breaking change patternfly-react PR in case you want to better understand the change. Also, each rule makes sure you're using a PatternFly component before running.
accordion-remove-noBoxShadow (#4022)
Removed prop noBoxShadow
per https://github.com/patternfly/patternfly/pull/2760. If a shadow is needed, the accordion can be placed in a card, or a shadow can be applied either using CSS or a box-shadow utility class.
Examples
In:
<Accordion noBoxShadow />
Out:
<Accordion />
alert-new-action (#4190)
We've replaced the action
prop with actionClose
or actionLinks
for better styling.
Examples
In:
<Alert action={<AlertActionCloseButton>Close</AlertActionCloseButton>
<Alert action={<SomethingThatIncludesLink>Close</SomethingThatIncludesLink>} />
Out:
<Alert actionClose={<AlertActionCloseButton>Close</AlertActionCloseButton>
<Alert actionLinks={<AlertActionLink>Close</AlertActionLink>} />
application-launcher-rename-dropdownItems (#3929)
We've removed the deprecated dropdownItems
prop in favor of items
.
Examples
In:
<ApplicationLauncher dropdownItems={[1,2,3]} />
Out:
<ApplicationLauncher items={[1,2,3]} />
aria-props (#3924)
We've renamed and removed many of our aria labels.
- AboutModalContainer
- 'ariaLabelledbyId': 'aboutModalBoxHeaderId',
- 'ariaDescribedById': 'aboutModalBoxContentId'
- ChipButton 'ariaLabel': 'aria-label'
- DropdownToggle
- 'ariaHasPopup': 'aria-haspopup'
- LoginForm
- 'rememberMeAriaLabel': ''
- Modal
- 'ariaDescribedById': 'modalContentAriaDescribedById'
- ModalContent
- 'ariaDescribedById': 'modalBoxAriaDescribedById'
- OptionsMenu
- 'ariaLabelMenu': ''
- OptionsMenuItemGroup
- 'ariaLabel': 'aria-label'
- OptionsMenuToggleWithText
- 'ariaHasPopup': 'aria-haspopup'
- ProgressBar
- 'ariaProps': 'progressBarAriaProps'
- ProgressContainer
- 'ariaProps': 'progressBarAriaProps'
- Select
- 'ariaLabelledBy': 'aria-labelledby',
- 'ariaLabelTypeAhead': 'typeAheadAriaLabel',
- 'ariaLabelClear': 'clearSelectionsAriaLabel',
- 'ariaLabelToggle': 'toggleAriaLabel',
- 'ariaLabelRemove': 'removeSelectionAriaLabel'
- SelectToggle
- 'ariaLabelledBy': 'aria-labelledby',
- 'ariaLabelToggle': 'aria-label'
- Wizard
- 'ariaLabelNav': 'navAriaLabel',
- 'ariaLabelCloseButton': 'closeButtonAriaLabel'
- WizardHeader
- 'ariaLabelCloseButton': 'closeButtonAriaLabel'
- WizardNav
- 'ariaLabel': 'aria-label'
Examples
In:
<AboutModalContainer ariaLabelledbyId="123" />
<WizardNav ariaLabel="123" />
<LoginForm rememberMeAriaLabel="123" />
Out:
<AboutModalContainer aboutModalBoxHeaderId="123" />
<WizardNav aria-label="123" />
<LoginForm />
background-image-src-enum (#3886)
We've replaced [BackgroundImageSrc.{sm,xs2x,sm,sm2x,lg}]
with strings 'sm' | 'xs2x' | 'sm' | 'sm2x' | 'lg'
for better readability. The always ignored [BackgroundImageSrc.filter]
attribute has been removed. To add a filter, use the new prop filter?: ReactNode
.
Examples
In:
const images = {
[BackgroundImageSrc.lg]: '/assets/images/pfbg_1200.jpg',
[BackgroundImageSrc.sm]: '/assets/images/pfbg_768.jpg',
[BackgroundImageSrc.sm2x]: '/assets/images/[email protected]',
[BackgroundImageSrc.xs]: '/assets/images/pfbg_576.jpg',
[BackgroundImageSrc.xs2x]: '/assets/images/[email protected]',
[BackgroundImageSrc.filter]: '/assets/images/background-filter.svg' ,
};
<BackgroundImage src={images} />
Out:
const images = {
lg: '/assets/images/pfbg_1200.jpg',
sm: '/assets/images/pfbg_768.jpg',
sm2x: '/assets/images/[email protected]',
xs: '/assets/images/pfbg_576.jpg',
xs2x: '/assets/images/[email protected]',
};
<BackgroundImage src={images} />
card-rename-components (#4170)
The order of this might be tricky since CardHead should only become CardHeader after existing CardHeaders have become CardTitle. Maybe an in-between temporary name can be used to swap these since we can't control the order in which rules are run.
- Rename CardHeader to CardTitle
- Rename CardHeadMain to CardHeaderMain
- Rename CardHead to CardHeader
Examples
We add an extra data-codemods="true"
attribute since CardHeader
is a valid element before and after the rename. This can safely be removed but running the rule again will transform CardHeader
-> CardTitle
which is not intended.
In:
<Card>
<CardHead>
<CardHeadMain>Header</CardHeadMain>
</CardHead>
<CardHeader>
Title
</CardHeader>
</Card>
Out:
<Card>
<CardHeader data-codemods="true">
<CardHeaderMain>Header</CardHeaderMain>
</CardHeader>
<CardTitle>
Title
</CardTitle>
</Card>
chipgroup-remove-chipbutton (#4246)
This component has been removed. Use a normal Button instead.
Examples
In:
<ChipButton>button</ChipButton>
Out:
<Button>button</Button>
chipgroup-remove-chipgrouptoolbaritem (#4246)
This component has been removed. To Create a ChipGroup with a category, add the categoryName
prop to <ChipGroup>
. All props that were on the <ChipGroupToolbarItem>
have been added to <ChipGroup>
. So to convert to new API, move move all you props up to <ChipGroup>
and remove <ChipGroupToolbarItem>
.
Examples
In:
<ChipGroup>
<ChipGroupToolbarItem prop1="ab" prop2="bc">
Item
<Chip>
Another item
</Chip>
</ChipGroupToolbarItem>
</ChipGroup>
Out:
<ChipGroup prop1="ab" prop2="bc">
Item
<Chip>
Another item
</Chip>
</ChipGroup>
chipgroup-remove-props (#4246)
- ChipGroup:
withToolbar
prop has been removed. Add thecategoryName
prop instead to add a chip group with a category. - ChipGroup:
headingLevel
prop has been removed. The category name has internally been switched to a<span>
Examples
In:
<ChipGroup withToolbar>button</ChipGroup>
<ChipGroup headingLevel="123">button</ChipGroup>
Out:
<ChipGroup categoryName="pf-codemod-category">button</ChipGroup>
<ChipGroup >button</ChipGroup>
dropdown-rename-icon (#4147)
- Removed dropdownItemIcon in favor of
<DropdownItem icon={<Icon />} />
- Removed variant prop from DropdownItem. If you were using variant="icon" before, use the new icon prop instead. (might need to split this into new rule)
Examples
In:
<DropdownItem icon={<CogIcon />} key="action" component="button" />
Out:
<DropdownItem key="action" component="button" variant="icon">
<DropdownItemIcon>
<CogIcon />
</DropdownItemIcon>
</DropdownItem>
dropdown-toggle-rename-iconComponent (#4038)
We've renamed the iconComponent
prop in DropdownToggle
to toggleIndicator
.
Examples
In:
<DropdownToggle iconComponent={CaretDownIcon} />
Out:
<DropdownToggle toggleIndicator={CaretDownIcon} />
empty-state-icon-removed-props (#4065)
We've removed the deprecated size
and title
props from EmptyStateIcon.
Examples
In:
<EmptyStateIcon size="sm" title="title" />
Out:
<EmptyStateIcon />
form-fix-isValid (#3975)
We've removed the isValid?: boolean
prop from 'TextInput', 'TextArea', 'FormSelect', 'FormGroup' in favor of a new validated?: string
prop. To set a the input to invalid, set validated
prop to 'default' | 'error' | 'success'
.
Examples
In:
<FormGroup isValid={true} />
<FormGroup isValid={false} />
<FormGroup isValid={condition} />
Out:
<FormGroup validated="default" />
<FormGroup validated="error" />
<FormGroup validated={(cond) ? 'default' : 'error'} />
global-background-color (#4022)
The tokens global_BackgroundColor_150
and global_BackgroundColor_300
have been removed (see associated Core PR). Consider using global_BackgroundColor_200
with its new value #f0f0f0
instead.
Examples
In:
import { global_background_color_300 } from '@patternfly/react-tokens'
Out:
import { global_background_color_200 as global_background_color_300 } from '@patternfly/react-tokens'
In:
import { global_background_color_150 } from '@patternfly/react-tokens'
Out:
import { global_background_color_200 as global_background_color_150 } from '@patternfly/react-tokens'
label-remove-isCompact (#4116)
We've changed label styling and labels are now compact by default.
Examples
In:
<Label isCompact>Label</Label>
Out:
<Label >Label</Label>
modal-remove-props (#4017)
- Removed props
isFooterLeftAligned
andisFooterLeftAligned
from Modal and ModalBoxFooter. - Removed prop
hideTitle
from Modal. To hide the Modal header, do not pass a title prop, a description prop, or a header prop. If there is no title or header passed, please provide an aria-label prop to the Modal component to make it accessible.
Examples
In:
<Modal isFooterLeftAligned hideTitle />
Out:
<Modal />
modal-variant (#3920)
We've collapsed the isLarge
and isSmall
properties into a single variant="small"
or variant="large"
property. To maintain the current behavior, set the variant
property to "large"
or "small"
.
Examples
Note: This rule will produce broken fixes if you set isLarge={condition}
and/or isSmall={condition}
.
In:
<Modal isLarge />
Out:
<Modal variant="large" />
nav-list-variant (#4225)
variant
prop has been removed from NavList
. Pass variant={horizontal
| tertiary
} to Nav
instead. Additionally the enum NavListVariants
has been removed.
Examples
In:
<Nav>
<NavList variant={NavListVariants.tertiary}>
some item
</NavList>
</Nav>
Out:
<Nav variant="tertiary">
<NavList >
some item
</NavList>
</Nav>
no-experimental-imports (#4029) (#4176)
We've done away with @patternfly/react-core/dist/esm/experimental
. Import from just @patternfly/react-core
instead.
Examples
In:
import { Divider } from '@patternfly/react-core/dist/esm/experimental';
Out:
import { Divider } from '@patternfly/react-core';
page-header-move-avatar (#4246)
This rule tries to move the PageHeader avatar prop value into the headerTools prop. If it can't it will comment the avatar prop and value out.
It depends on the rename-toolbar-components
and page-header-prop-rename
props to be run first.
Examples
In:
<PageHeader avatar={<Avatar />} />
<PageHeader avatar={<Avatar />} headerTools={<PageHeaderTools></PageHeaderTools>} />
Out:
<PageHeader /*TODO: move to PageHeaderTools - avatar={<Avatar />}*/ />
<PageHeader headerTools={<PageHeaderTools><Avatar /></PageHeaderTools>} />
page-header-prop-rename (#4246)
Renames the PageHeader toolbar
prop to headerTools
Examples
In:
<PageHeader toolbar="tools" />
Out:
<PageHeader headerTools="tools" />
pagination-removed-variant (#4202)
Removed obsolete 'left' and 'right' variants. These can be replaced with 'top' (default) or 'bottom' if needed.
Examples
In:
<Pagination variant="left" />
<Pagination variant={PaginationVariant.right} />
Out:
<Pagination />
<Pagination />
progress-remove-info-variant (#3886)
Removed deprecated ProgressVariant.info
that adds no styling. Do not pass this prop or pass null
instead.
Examples
In:
<Progress variant={ProgressVariant.info} />
Out:
<Progress />
In:
<Progress variant="info" />
Out:
<Progress />
remove-gutter-size (#4014)
Gallery, Grid, Level, Split, and Stack: Removed prop gutter
(it has effectively been a boolean value for over a year). The prop hasGutter
should be used instead.
Examples
In:
<Gallery gutter="sm" />
Out:
<Gallery hasGutter />
remove-isPseudo-props (#4116)
- Button: Removed isHover and isFocus props
- Chip: Removed isReadOnly prop
- Dropdown: Removed isHover and isFocus props from Toggle, KebabToggle, and DropdownToggle
- Select:
- Removed isFocus prop from SelectOption
- Removed isFocus and isHovered props from SelectToggle
- Expandable:
- Removed isFocus and isHovered props from ExpandableSection
- Label: Removed isCompact prop from Label
- Options menu: Removed isFocused and isHovered prop from OptionsMenuToggle and OptionsMenuToggleWithText
- Context selector: Removed isHover prop from ContextSelectorItem. Removed isHovered and isFocused props from ContextSelectorToggle
Examples
In:
<Button isHover isFocus />
<Chip isReadOnly />
Out:
<Button />
<Chip />
remove-prop-types (#4076)
This rule is not yet implemented
- Removed
AnyPatternFlyImport.PropTypes
since we no longer definepropTypes
for our components. Consider using our Typescript types under each packages'dist/js
folder instead.
Examples
In:
Out:
no-unused-imports
This rule is meant to be run after all other rules to remove unneeded imports added or no longer necessary such as:
- 'NavVariants', Use the variant prop on the Nav component with one of these values: 'default' | 'horizontal' | 'tertiary'
- 'CardHead', See card-rename-components rule for more info
- 'CardHeadMain', See card-rename-components rule for more info
- 'BackgroundImgSrc', See background-image-src-enum rule for more info
- 'ChipButton', See chipgroup-remove-chipbutton rule for more info
- 'ChipGroupToolbarItem' See chipgroup-remove-chipgrouptoolbaritem rule for more info
Examples
In:
import { Nav, NavVariants } from '@patternfly/react-core'; <Nav variant="default" />
Out:
import { Nav } from '@patternfly/react-core'; <Nav variant="default" />
rename-noPadding (#4133)
We've renamed noPadding
to hasNoPadding
for DataListContent, DrawerHead, DrawerPanelBody, and PageSection components.
If you wish to add padding at different breakpoints, we added props hasPaddingOn
and hasNoPaddingOn
to PageSection.
Examples
In:
<DataListContent noPadding />
<DrawerHead noPadding />
<DrawerPanelBody noPadding />
<PageSection noPadding />
Out:
<DataListContent hasNoPadding />
<DrawerHead hasNoPadding />
<DrawerPanelBody hasNoPadding />
<PageSection hasNoPadding />
rename-toolbar-components (#4246)
Renames the Toolbar
related imports and components to PageHeader
related imports and components.
Note: This rule WILL NOT RUN if you do not have a PageHeader import in the same file since it cannot discern whether your Toolbar was used in a PageHeader.
Note: The PageHeader toolbar
prop is renamed in the page-header-prop-rename
rule.
Examples
In:
import { Page, PageHeader, Toolbar, ToolbarGroup, ToolbarItem } from '@patternfly/react-core';
<Page>
<PageHeader toolbar={
<Toolbar>
<ToolbarGroup>
<ToolbarItem />
</ToolbarGroup>
</Toolbar>
}
/>
</Page>
Out:
import { Page, PageHeader, PageHeaderTools, PageHeaderToolsGroup, PageHeaderToolsItem } from '@patternfly/react-core';
<Page>
<PageHeader toolbar={
<PageHeaderTools>
<PageHeaderToolsGroup>
<PageHeaderToolsItem />
</PageHeaderToolsGroup>
</PageHeaderTools>
}
/>
</Page>
react-icons-remove-icon (#3978)
This rule is not yet implemented
- Removed
OutlinedFontAwesomeLogoFullIcon
. Import it from @fortawesome instead.
Examples
In:
Out:
react-styles-remove-emotion (#3886)
This rule is not yet implemented
- Removed all non
css
imports from '@patternfly/react-styles'
Examples
In:
Out:
refactor-breakpointmods (#4116)
We've removed the breakpointMods
prop from Flex, FlexItem, PageSection, ToolbarItem, and ToolbarToggleGroup in favor of a new API.
Examples
In:
<Flex breakpointMods={[
{modifier: FlexModifiers.column},
{modifier: FlexModifiers["align-self-stretch"]},
{modifier: 'spacer-none'},
{modifier: 'row', breakpoint: 'sm'}
]}>
Flex
</Flex>
Out:
<Flex direction={{"default":"column","sm":"row"}} alignSelf={{"default":"alignSelfStretch"}} spacer={{"default":"spacerNone"}} >
Flex
</Flex>
select-rename-checkbox (#3945)
We've removed the deprecated CheckboxSelect
and CheckboxSelectOption
components in favor of Select variant="checkbox"
and SelectOption
.
Examples
In:
<CheckboxSelect>
<CheckboxSelectOption>option1</CheckboxSelectOption>
<CheckboxSelectOption>option2</CheckboxSelectOption>
</CheckboxSelect>
Out:
<Select variant="checkbox">
<SelectOption>option1</SelectOption>
<SelectOption>option2</SelectOption>
</Select>
select-rename-isExpanded (#3945)
We've renamed the isExpanded
prop to isOpen
.
Examples
In:
<Select isExpanded />
Out:
<Select isOpen />
skip-to-content-remove-component (#4116)
We've removed the component
prop in favor of always using an anchor tag.
Examples
In:
<SkipToContent component="h1" />
Out:
<SkipToContent />
tab-rename-variant (#4146)
We've renamed the variant
prop to component
and the TabVariant
enum to TabComponent
Examples
In:
<Tabs variant={TabsVariant.nav} />
Out:
<Tabs component={TabsComponent.nav} />
tab-title-text (#4146)
The title should be wrapped with <TabTitleText>
for proper styling. If you would like to place an Icon in the Tab, it should be wrapped with <TabTitleIcon>
for proper styling.
title="string"
->title={<TabTitleText>Users</TabTitleText>}
title={<SomeReactIcon/>}
->title={<TabTitleIcon><SomeReactIcon/></TabTitleIcon>}
Examples
In:
<Tab title="Title">Content</Tab>
Out:
<Tab title={<TabTitleText>Title</TabTitleText>}>Content</Tab>
In:
<Tab title={<SomethingThatIncludesIcon />}>Content</Tab>
Out:
<Tab title={<TabTitleIcon><SomethingThatIncludesIcon /></TabTitleIcon>}>Content</Tab>
In:
<Tab title={<div>a title</div>}>Content</Tab>
Out:
<Tab title={<TabTitleText><div>a title</div></TabTitleText>}>Content</Tab>
table-removed-transforms (#4170)
- Removed
cellHeightAuto
transformer. It is no longer needed. cellWidth('max')
has been replaced withcellWidth(100)
Examples
In:
<Table rows={['Row 1']} cells={[{
title: 'Last Commit',
transforms: [cellWidth('max'), cellHeightAuto()]
}]}>
<TableHeader />
<TableBody />
</Table>
Out:
<Table rows={['Row 1']} cells={[{
title: 'Last Commit',
transforms: [cellWidth(100)]
}]}>
<TableHeader />
<TableBody />
</Table>
title-require-heading-level (#3922)
headingLevel
is now a required prop. Update any existing usage ofTitle
to supply a string value for headingLevel of h1-h6.
Examples
In:
<Title size="lg">MyTitle</Title>
Out:
<Title headingLevel="h2" size="lg">MyTitle</Title>
title-size (#3922)
Replace size={ TitleSize | [xs|sm|md|lg|xl|2xl|3xl|4xl] }
with strings md|lg|xl|2xl|3xl|4xl
. Sizes xs|sm
are no longer supported by Core.
Examples
In:
<Title size={TitleSize.xl}>MyTitle</Title>
Out:
<Title size="xl">MyTitle</Title>
In:
<Title size="sm">MyTitle</Title>
Out:
<Title size="md">MyTitle</Title>
upgrade-react (#4144)
This rule is not yet implemented
Our packages now can possibly use hooks, which requires react@^16.8.0
instead of react@^16.4.0
. We recommend upgrading your version of React if it is below 16.8.0.
Examples
In:
Out:
wizard-remove-props (#4142)
- WizardNav: Removed prop
isCompactNav
. This prop is no longer used. - Wizard: Removed inPage prop. By default the Wizard will be displayed in page, filling its parent container. If the consumer passes a managed
isOpen
flag, then the Wizard will be displayed in a modal. - Wizard: Removed isFullHeight and isFullWidth props, (#4116)
Examples
In:
<Wizard isCompactNav={false} inPage={true} isFullHeight isFullWidth />
Out:
<Wizard />
wizard-rename-hasBodyPadding (#4136)
Rename hasBodyPadding
to hasNoBodyPadding
for Wizard and WizardBody.
Examples
In:
<Wizard hasBodyPadding />
Out:
<Wizard />
(The default is hasNoBodyPadding = false
)
In:
<Wizard hasBodyPadding={false} />
Out:
<Wizard hasNoBodyPadding />
wizard-rename-text (#4063)
WizardNavItem
: Renamed prop text
to content
. The type of the prop has been changed to React.ReactNode to allow for flexibility.
Examples
In:
<WizardNavItem text="sm" />
Out:
<WizardNavItem content="sm" />
chart-remove-allowZoom (#4278)
- Chart: Remove
allowZoom
property. - Chart: Add
containerComponent={<VictoryZoomContainer />}
property. - ChartGroup: Remove
allowZoom
property - Add Import:
import { VictoryZoomContainer } from 'victory-zoom-container';
Examples
In:
<Chart allowZoom>
<ChartAxis />
<ChartGroup allowZoom offset={11} horizontal>
"some-chart"
<ChartGroup/>
<Chart />
Out:
import { VictoryZoomContainer } from 'victory-zoom-container';
<Chart containerComponent={<VictoryZoomContainer />}>
<ChartAxis />
<ChartGroup offset={11} horizontal>
"some-chart"
<ChartGroup/>
<Chart />