Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: CSS vars updater package #801

Open
wants to merge 21 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
ed78998
refactor(tokenLists): change location, use Sets
adamviktora Nov 6, 2024
64544ac
refactor(classNameUpdater utils): move to a shared helpers folder
adamviktora Nov 6, 2024
ce6121a
refactor(codemods): update to use new tokenLists structure
adamviktora Nov 6, 2024
16324fb
feat: add new css-vars-updater package
adamviktora Nov 6, 2024
a33e15d
update yarn.lock
adamviktora Nov 6, 2024
2b02879
refactor: move tokenLists
adamviktora Nov 8, 2024
93e110d
revert mapping paths for helpers from baseUrl
adamviktora Nov 8, 2024
aa86311
update paths in package.json files to reflect new dist folder structure
adamviktora Nov 8, 2024
ac04c82
refactor: create shared-helpers package
adamviktora Nov 12, 2024
1f97fe7
chore: update shared-helpers package to use index.ts
adamviktora Nov 13, 2024
426bfb7
chore: update yarn classic to [email protected]
adamviktora Nov 13, 2024
4760579
chore: update yarn.lock
adamviktora Nov 13, 2024
59d15f4
chore: update github action
adamviktora Nov 13, 2024
c516618
chore: include dependencies in lerna build
adamviktora Nov 13, 2024
b657da2
docs: update README example
adamviktora Nov 13, 2024
7b2478c
Merge branch 'main' into css-vars-updater
adamviktora Nov 18, 2024
ed0ed7b
update test file
adamviktora Nov 13, 2024
c3e96db
feat: print diff messages
adamviktora Nov 18, 2024
7d3ebbc
chore(shared-helpers): make package private
adamviktora Nov 27, 2024
9d44df4
chore: renamed shared-helpers to @patternfly/shared-codemod-helpers a…
adamviktora Jan 14, 2025
e284347
chore: add "typescript" dev dependency
adamviktora Jan 15, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ jobs:
- uses: actions/setup-node@v1
with:
node-version: '18'
- run: corepack enable
- run: corepack prepare [email protected] --activate
- uses: actions/cache@v2
id: yarn-cache
name: Cache npm deps
Expand Down Expand Up @@ -48,6 +50,8 @@ jobs:
- uses: actions/setup-node@v1
with:
node-version: '18'
- run: corepack enable
- run: corepack prepare [email protected] --activate
- uses: actions/cache@v2
id: yarn-cache
name: Cache npm deps
Expand Down Expand Up @@ -78,6 +82,8 @@ jobs:
- uses: actions/setup-node@v1
with:
node-version: '18'
- run: corepack enable
- run: corepack prepare [email protected] --activate
- uses: actions/cache@v2
id: yarn-cache
name: Cache npm deps
Expand Down
9 changes: 9 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,14 @@ test/packages/*
.DS_Store
dist

# Yarn modern
.pnp.*
.yarn/*
!.yarn/patches
!.yarn/plugins
!.yarn/releases
!.yarn/sdks
!.yarn/versions

# IDE - VSCode
.history
1 change: 1 addition & 0 deletions .yarnrc.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
nodeLinker: node-modules
4 changes: 3 additions & 1 deletion lerna.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,9 @@
"packages": [
"packages/eslint-plugin-pf-codemods",
"packages/pf-codemods",
"packages/class-name-updater"
"packages/class-name-updater",
"packages/css-vars-updater",
"packages/shared-codemod-helpers"
],
"version": "independent"
}
15 changes: 9 additions & 6 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
"build": "lerna run build",
"build:generators": "tsc --build --verbose generators/tsconfig.cjs.json",
"build:readme": "lerna run build:readme",
"build:classnames": "lerna run build --scope=@patternfly/class-name-updater",
"build:classnames": "lerna run build --scope=@patternfly/class-name-updater --include-dependencies",
"clean": "lerna run clean"
},
"repository": {
Expand All @@ -41,13 +41,16 @@
"packages/*"
],
"devDependencies": {
"lerna": "^3.22.0",
"@types/fs-extra": "^11.0.4",
"@types/node": "^22.10.6",
"case-anything": "^2.1.13",
"fs-extra": "^11.2.0",
"lerna": "^8.1.9",
"mocha": "^7.2.0",
"plop": "^3.1.2",
"rimraf": "^6.0.1",
"ts-node": "^10.9.2",
"case-anything": "^2.1.13",
"fs-extra": "^11.2.0",
"@types/fs-extra": "^11.0.4"
"typescript": "^5.4.2"
},
"packageManager": "yarn@1.22.22+sha512.a6b2f7906b721bba3d67d4aff083df04dad64c399707841b7acf00f6b133b7ac24255f2652fa22ae3534329dc6180534e98d17432037ff6fd140556e2bb3137e"
"packageManager": "yarn@4.5.1"
}
5 changes: 2 additions & 3 deletions packages/class-name-updater/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,7 @@
"description": "Utility to update class names with Patternfly version numbers",
"author": "Red Hat",
"license": "MIT",
"bin": {
"class-name-updater": "./dist/cli.js"
},
"bin": "./dist/cli.js",
"engines": {
"node": ">=18"
},
Expand All @@ -21,6 +19,7 @@
"test:v6": "node ./dist/cli.js test --exclude test/largeFile.js --v6"
},
"dependencies": {
"@patternfly/shared-codemod-helpers": "workspace:^",
"colors": "^1.4.0",
"commander": "^5.1.0",
"diff": "^5.1.0",
Expand Down
3 changes: 1 addition & 2 deletions packages/class-name-updater/src/classNameUpdate.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
import { sync } from "glob";
import { readFileSync, writeFileSync } from "fs";
import { isAbsolute, join } from "path";
import { isDir } from "./utils";
import { printDiff } from "./printDiff";
import { isDir, printDiff } from "@patternfly/shared-codemod-helpers";

export async function classNameUpdate(
globTarget: string,
Expand Down
2 changes: 1 addition & 1 deletion packages/class-name-updater/src/cli.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { join } from "path";
import { Command } from "commander";
const program = new Command();

import { isDir } from "./utils";
import { isDir } from "@patternfly/shared-codemod-helpers";
import { classNameUpdate } from "./classNameUpdate";

program
Expand Down
106 changes: 106 additions & 0 deletions packages/css-vars-updater/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
# css-vars-updater

This utility automatically identifies Patternfly CSS variables in v5 that need to be updated after the introduction of new [global tokens in Patternfly v6](https://www.patternfly.org/tokens/about-tokens).

## Usage

Requires Node.js >= 10.

```sh
npx @patternfly/css-vars-updater ./path-to-src
```

Running this command will use default options, if you want a finer control over the updates, use an `-i` (or `--interactive`) option. It will start an interactive interface, where you can setup what files should be fixed and what tokens should be replaced:
```
npx @patternfly/css-vars-updater ./path-to-src -i

--> Enter file extensions to update (comma-separated): (scss,css,less,md)
--> Do you want to exclude any files? (y/N)
yes --> Enter files to exclude (comma-separated, relative paths)
--> Do you want to run the fixer? (Y/n)
--> Do you want to replace color variables with a temporary hot pink color variable? (Y/n)
--> Do you want to replace other global variables with a matching token? (Y/n)
--> Do you want to fix directional styles and how? E.g. PaddingLeft -> PaddingInlineStart (Use arrow keys)
❯ Fix in left-to-right manner (English)
Fix in right-to-left manner
Fix in top-to-bottom manner
Don’t fix
```

Giving node more RAM can help for large codebases.

```sh
NODE_OPTIONS=--max-old-space-size=4096 npx @patternfly/css-vars-updater ./path-to-src
```

### Options

```sh
Usage: @patternfly/css-vars-updater <path> [otherPaths...]

Options:
-V, --version output the version number
-i, --interactive starts an interactive interface for finer control over the updates
--fix whether to run fixer
-h, --help display help for command
```

### Example

Using default options:

In:

```css
.custom-class {
/* Global non-color variables */
border-radius: var(--pf-v5-global--BorderRadius--lg);
row-gap: var(--pf-v5-global--spacer--md);
width: var(--pf-v5-global--arrow--width);

/* Global color variables */
color: var(--pf-v5-global--Color--100);
background-color: var(--pf-v5-global--BackgroundColor--200);

/* Variables removed from v6 */
max-width: var(--pf-v5-c-accordion__toggle-text--MaxWidth);

/* Variables staying in v6 */
height: var(--pf-v5-c-about-modal-box--Height);
box-shadow: var(--pf-v5-c-alert--BoxShadow);

/* Variables with direction updates */
padding-inline-start: var(--pf-v5-c-about-modal-box__brand--PaddingLeft);
padding-inline-end: var(--pf-v5-c-about-modal-box__brand--PaddingRight);
padding-block-start: var(--pf-v5-c-about-modal-box__brand--PaddingTop);
padding-block-end: var(--pf-v5-c-about-modal-box__brand--PaddingBottom);
}
```

Out:

```css
.custom-class {
/* Global non-color variables */
border-radius: var(--pf-t--global--border--radius--large);
row-gap: var(--pf-t--global--spacer--md);
width: var(--pf-v5-global--arrow--width);

/* Global color variables */
color: var(--pf-t--temp--dev--tbd /* CODEMODS: original v5 color was:--pf-v5-global--Color--100 */);
background-color: var(--pf-t--temp--dev--tbd /* CODEMODS: original v5 color was:--pf-v5-global--BackgroundColor--200 */);

/* Variables removed from v6 */
max-width: var(--pf-v5-c-accordion__toggle-text--MaxWidth);

/* Variables staying in v6 */
height: var(--pf-v6-c-about-modal-box--Height);
box-shadow: var(--pf-v6-c-alert--BoxShadow);

/* Variables with direction updates */
padding-inline-start: var(--pf-v6-c-about-modal-box__brand--PaddingInlineStart);
padding-inline-end: var(--pf-v6-c-about-modal-box__brand--PaddingInlineEnd);
padding-block-start: var(--pf-v6-c-about-modal-box__brand--PaddingBlockStart);
padding-block-end: var(--pf-v6-c-about-modal-box__brand--PaddingBlockEnd);
}
```
31 changes: 31 additions & 0 deletions packages/css-vars-updater/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
{
"name": "@patternfly/css-vars-updater",
"version": "1.0.0",
"description": "Utility to update Patternfly CSS variables when migrating from V5 to a new design token system in V6",
"author": "Red Hat",
"license": "MIT",
"bin": "./dist/cli.js",
"engines": {
"node": ">=18"
},
"publishConfig": {
"access": "public"
},
"scripts": {
"build": "tsc --build --verbose ./tsconfig.json",
"clean": "rimraf ./dist"
},
"dependencies": {
"@patternfly/shared-codemod-helpers": "workspace:^",
"colors": "^1.4.0",
"commander": "^5.1.0",
"diff": "^5.1.0",
"glob": "^10.2.6",
"inquirer": "^12.3.2"
},
"devDependencies": {
"@types/diff": "^5.0.9",
"@types/node": "^22.10.6",
"typescript": "^5.4.2"
}
}
9 changes: 9 additions & 0 deletions packages/css-vars-updater/src/answers.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
export type Answers = {
fileExtensions: string;
shouldExcludeFiles: boolean;
filesToExclude?: string;
fix: boolean;
replaceGlobalColorsWithPink: boolean;
replaceGlobalVars: boolean;
direction: "ltr" | "rtl" | "ttb" | "none";
};
117 changes: 117 additions & 0 deletions packages/css-vars-updater/src/cli.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
#!/usr/bin/env node
import { join } from "path";
import { Command } from "commander";
const program = new Command();
import inquirer from "inquirer";

import { isDir } from "@patternfly/shared-codemod-helpers";
import { cssVarsUpdate } from "./cssVarsUpdate";
import { Answers } from "./answers";

program
.version(require("../package.json").version)
.description("Update css variables from v5 to v6")
.arguments("<path> [otherPaths...]")
.option(
"-i, --interactive",
"Starts an interactive interface for better control over the updates"
)
.option("--fix", "Whether to run fixer")
.action(runCssVarsUpdate);

async function runCssVarsUpdate(
path: string,
otherPaths: string,
options: { interactive: boolean; fix: boolean }
) {
const defaultAnswers: Answers = {
fileExtensions: "",
shouldExcludeFiles: false,
fix: options.fix,
replaceGlobalColorsWithPink: true,
replaceGlobalVars: true,
direction: "ltr",
};

const answers: Answers = options.interactive
? await inquirer.prompt([
{
type: "input",
name: "fileExtensions",
message: "Enter file extensions to update (comma-separated):",
default: "scss,css,less,md",
},
{
type: "confirm",
name: "shouldExcludeFiles",
message: "Do you want to exclude any files?",
default: false,
},
{
type: "input",
name: "filesToExclude",
message: "Enter files to exclude (comma-separated, relative paths):",
when: (answers) => answers.shouldExcludeFiles === true,
},
{
type: "confirm",
name: "fix",
message: "Do you want to run the fixer?",
when: !options.fix,
},
{
type: "confirm",
name: "replaceGlobalColorsWithPink",
message:
"Do you want to replace color variables with a temporary hot pink color variable?",
},
{
type: "confirm",
name: "replaceGlobalVars",
message:
"Do you want to replace other global variables with a matching token?",
},
{
type: "list",
name: "direction",
message:
"Do you want to fix directional styles and how? E.g. PaddingLeft -> PaddingInlineStart",
choices: [
{
name: "Fix in left-to-right manner (English)",
value: "ltr",
},
{
name: "Fix in right-to-left manner",
value: "rtl",
},
{
name: "Fix in top-to-bottom manner",
value: "ttb",
},
{
name: "Don’t fix",
value: "none",
},
],
},
])
: defaultAnswers;

let allPaths = [path, ...otherPaths];

// if all paths are resolved to be directories assume that they want to run on all contents of those directories
const onlyDirs = await Promise.all(allPaths.map((path) => isDir(path))).then(
(responses) => responses.every((isDirResult) => !!isDirResult)
);

if (onlyDirs) {
allPaths = allPaths.map((path) => join(path, "**", "*"));
}

allPaths.forEach(async (path) => {
await cssVarsUpdate(path, answers);
});
}

program.parse(process.argv);
Loading
Loading