diff --git a/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.md b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.md new file mode 100644 index 00000000..cd90d988 --- /dev/null +++ b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.md @@ -0,0 +1,19 @@ +### chartsImport-moved [(#11091)](https://github.com/patternfly/patternfly-react/pull/11091) + +In order to support multiple chart libraries, Victory based charts have moved. This rule will update import paths to our victory directory. + +Additionally, Victory has become a peer dependency. + +#### Examples + +In: + +```jsx +%inputExample% +``` + +Out: + +```jsx +%outputExample% +``` diff --git a/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.test.ts b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.test.ts new file mode 100644 index 00000000..53402f03 --- /dev/null +++ b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.test.ts @@ -0,0 +1,106 @@ +const ruleTester = require("../../ruletester"); +import * as rule from "./chartsImport-moved"; +import { + ValidTests, + InvalidTests, + createValidTest, + createInvalidTest, +} from "../../helpers/testHelpers"; + +const specifiersToMove = [ + 'Chart', + 'ChartArea', + 'ChartAxis', + 'ChartBar', + 'ChartBoxPlot', + 'ChartBullet', + 'ChartBulletComparativeErrorMeasure', + 'ChartBulletComparativeMeasure', + 'ChartBulletComparativeWarningMeasure', + 'ChartBulletPrimaryDotMeasure', + 'ChartBulletPrimarySegmentedMeasure', + 'ChartBulletQualitativeRange', + 'ChartContainer', + 'ChartCursorContainer', + 'ChartCursorTooltip', + 'ChartCursorFlyout', + 'ChartDonut', + 'ChartDonutThreshold', + 'ChartDonutUtilization', + 'ChartGroup', + 'ChartLabel', + 'ChartLegend', + 'ChartLegendTooltip', + 'ChartLegendTooltipContent', + 'ChartLegendTooltipLabel', + 'ChartLine', + 'ChartPie', + 'ChartPoint', + 'ChartScatter', + 'ChartStack', + 'ChartTheme', + 'ChartThemeColor', + 'ChartThreshold', + 'ChartTooltip', + 'ChartVoronoiContainer', + 'createContainer', + 'getInteractiveLegendEvents', + 'getInteractiveLegendItemStyles', + 'getCustomTheme', + 'getTheme', + 'getThemeColors' +]; + +const validTests: ValidTests = []; +const invalidTests: InvalidTests = []; + +specifiersToMove.forEach((specifier) => { + validTests.push(createValidTest(`<${specifier} />`)); + validTests.push( + createValidTest( + `import { ${specifier} } from '@patternfly/react-charts/victory';` + ) + ); + + const errorMessage = `${specifier} has been moved. This rule will update import paths.`; + invalidTests.push( + createInvalidTest( + `import { ${specifier} } from '@patternfly/react-charts';`, + `import {\n\t${specifier}\n} from '@patternfly/react-charts/victory';`, + [{ message: errorMessage, type: "ImportDeclaration" }] + ) + ); + invalidTests.push( + createInvalidTest( + `import { ${specifier} as CustomSpecifier } from '@patternfly/react-charts';`, + `import {\n\t${specifier} as CustomSpecifier\n} from '@patternfly/react-charts/victory';`, + [{ message: errorMessage, type: "ImportDeclaration" }] + ) + ); + invalidTests.push( + createInvalidTest( + `import { ${specifier} } from '@patternfly/react-charts/dist/esm/components/index.js';`, + `import {\n\t${specifier}\n} from '@patternfly/react-charts/dist/esm/victory/components/index.js';`, + [{ message: errorMessage, type: "ImportDeclaration" }] + ) + ); + invalidTests.push( + createInvalidTest( + `import { ${specifier} } from '@patternfly/react-charts/dist/js/components/index.js';`, + `import {\n\t${specifier}\n} from '@patternfly/react-charts/dist/js/victory/components/index.js';`, + [{ message: errorMessage, type: "ImportDeclaration" }] + ) + ); + invalidTests.push( + createInvalidTest( + `import { ${specifier} } from '@patternfly/react-charts/dist/dynamic/components/index.js';`, + `import {\n\t${specifier}\n} from '@patternfly/react-charts/dist/dynamic/victory/components/index.js';`, + [{ message: errorMessage, type: "ImportDeclaration" }] + ) + ); +}); + +ruleTester.run("chartImport-moved", rule, { + valid: validTests, + invalid: invalidTests, +}); diff --git a/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.ts b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.ts new file mode 100644 index 00000000..b0fa43d5 --- /dev/null +++ b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImport-moved.ts @@ -0,0 +1,62 @@ +import { moveSpecifiers } from "../../helpers"; + +// https://github.com/patternfly/patternfly-react/pull/11091 + +const specifiersToMove = [ +'Chart', +'ChartArea', +'ChartAxis', +'ChartBar', +'ChartBoxPlot', +'ChartBullet', +'ChartBulletComparativeErrorMeasure', +'ChartBulletComparativeMeasure', +'ChartBulletComparativeWarningMeasure', +'ChartBulletPrimaryDotMeasure', +'ChartBulletPrimarySegmentedMeasure', +'ChartBulletQualitativeRange', +'ChartContainer', +'ChartCursorContainer', +'ChartCursorTooltip', +'ChartCursorFlyout', +'ChartDonut', +'ChartDonutThreshold', +'ChartDonutUtilization', +'ChartGroup', +'ChartLabel', +'ChartLegend', +'ChartLegendTooltip', +'ChartLegendTooltipContent', +'ChartLegendTooltipLabel', +'ChartLine', +'ChartPie', +'ChartPoint', +'ChartScatter', +'ChartStack', +'ChartTheme', +'ChartThemeColor', +'ChartThreshold', +'ChartTooltip', +'ChartVoronoiContainer', +'createContainer', +'getInteractiveLegendEvents', +'getInteractiveLegendItemStyles', +'getCustomTheme', +'getTheme', +'getThemeColors' +]; + +const fromPackage = "@patternfly/react-charts"; +const toPackage = "@patternfly/react-charts/victory"; +const messageAfterImportNameChange = + "been moved. This rule will update import paths."; + +module.exports = { + meta: { fixable: "code" }, + create: moveSpecifiers( + specifiersToMove, + fromPackage, + toPackage, + messageAfterImportNameChange + ), +}; diff --git a/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImportMovedInput.tsx b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImportMovedInput.tsx new file mode 100644 index 00000000..8a176f5b --- /dev/null +++ b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImportMovedInput.tsx @@ -0,0 +1 @@ +import { Chart } from "@patternfly/react-charts"; diff --git a/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImportMovedOutput.tsx b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImportMovedOutput.tsx new file mode 100644 index 00000000..f04de5fc --- /dev/null +++ b/packages/eslint-plugin-pf-codemods/src/rules/v6/chartsImportMoved/chartsImportMovedOutput.tsx @@ -0,0 +1,3 @@ +import { + Chart +} from '@patternfly/react-charts/victory'; diff --git a/packages/pf-codemods/README.md b/packages/pf-codemods/README.md index ff3b08ed..19d54188 100644 --- a/packages/pf-codemods/README.md +++ b/packages/pf-codemods/README.md @@ -368,6 +368,26 @@ export const CardUpdatedClickableMarkupInput = () => { }; ``` +### chartsVictory-promoted [(#11091)](https://github.com/patternfly/patternfly-react/pull/11091) + +In order to support multiple chart libraries, Victory based charts have moved. This rule will update import paths to our victory directory. + +Additionally, Victory has become a peer dependency. + +#### Examples + +In: + +```jsx +import { Chart } from "@patternfly/react-charts"; +``` + +Out: + +```jsx +import { Chart } from '@patternfly/react-charts/victory'; +``` + ### checkbox-radio-replace-isLabelBeforeButton [(#10016)](https://github.com/patternfly/patternfly-react/pull/10016) The `isLabelBeforeButton` prop in Checkbox and Radio has been replaced with `labelPosition="start"`