npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

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 the categoryName 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 and isFooterLeftAligned 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 define propTypes 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 with cellWidth(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 of Title 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 />