From a85352f55462cc60d61034ca3aa0fb1dbdadab49 Mon Sep 17 00:00:00 2001 From: Sachin Raja Date: Sun, 20 Jun 2021 14:30:34 -0700 Subject: [PATCH 1/5] Generate plugin list file Removes the importing of all plugins in src/util/resolveConfig to avoid importing CSS. Import the built plugin list file instead. --- .eslintignore | 1 + .gitignore | 3 +++ package-lock.json | 34 ++++++++++++++++++++++------------ package.json | 1 + scripts/create-plugin-list.js | 10 ++++++++++ src/util/resolveConfig.js | 4 ++-- 6 files changed, 39 insertions(+), 14 deletions(-) create mode 100644 scripts/create-plugin-list.js diff --git a/.eslintignore b/.eslintignore index f4d9f8b503b9..d08cfbdb0476 100644 --- a/.eslintignore +++ b/.eslintignore @@ -4,3 +4,4 @@ /peers /tests/fixtures/cli-utils.js /stubs/* +/src/corePluginList.js diff --git a/.gitignore b/.gitignore index 2bfdf621a35a..885a6ecc14bc 100644 --- a/.gitignore +++ b/.gitignore @@ -15,3 +15,6 @@ yarn-error.log # Perf related files isolate*.log + +# Generated files +/src/corePluginList.js \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index 93610005ef02..611c369654ab 100644 --- a/package-lock.json +++ b/package-lock.json @@ -5,7 +5,6 @@ "requires": true, "packages": { "": { - "name": "tailwindcss", "version": "2.2.2", "license": "MIT", "dependencies": { @@ -11873,7 +11872,8 @@ "version": "0.2.1", "resolved": "https://registry.npmjs.org/@tailwindcss/aspect-ratio/-/aspect-ratio-0.2.1.tgz", "integrity": "sha512-aDFi80aHQ3JM3symJ5iKU70lm151ugIGFCI0yRZGpyjgQSDS+Fbe93QwypC1tCEllQE8p0S7TUu20ih1b9IKLA==", - "dev": true + "dev": true, + "requires": {} }, "@tootallnate/once": { "version": "1.1.2", @@ -12030,7 +12030,8 @@ "version": "5.3.1", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.1.tgz", "integrity": "sha512-K0Ptm/47OKfQRpNQ2J/oIN/3QYiK6FwW+eJbILhsdxh2WTLdl+30o8aGdTbm5JbffpFFAg/g+zi1E+jvJha5ng==", - "dev": true + "dev": true, + "requires": {} }, "acorn-node": { "version": "1.8.2", @@ -13031,7 +13032,8 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/cssnano-utils/-/cssnano-utils-2.0.1.tgz", "integrity": "sha512-i8vLRZTnEH9ubIyfdZCAdIdgnHAUeQeByEeQ2I7oTilvP9oHO6RScpeq3GsFUVqeB8uZgOQ9pw8utofNn32hhQ==", - "dev": true + "dev": true, + "requires": {} }, "csso": { "version": "4.2.0", @@ -13513,7 +13515,8 @@ "version": "8.3.0", "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.3.0.tgz", "integrity": "sha512-BgZuLUSeKzvlL/VUjx/Yb787VQ26RU3gGjA3iiFvdsp/2bMfVIWUVP7tjxtjS0e+HP409cPlPvNkQloz8C91ew==", - "dev": true + "dev": true, + "requires": {} }, "eslint-plugin-prettier": { "version": "3.4.0", @@ -15149,7 +15152,8 @@ "version": "1.2.2", "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz", "integrity": "sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w==", - "dev": true + "dev": true, + "requires": {} }, "jest-regex-util": { "version": "27.0.1", @@ -16368,25 +16372,29 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-5.0.1.tgz", "integrity": "sha512-lgZBPTDvWrbAYY1v5GYEv8fEO/WhKOu/hmZqmCYfrpD6eyDWWzAOsl2rF29lpvziKO02Gc5GJQtlpkTmakwOWg==", - "dev": true + "dev": true, + "requires": {} }, "postcss-discard-duplicates": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-5.0.1.tgz", "integrity": "sha512-svx747PWHKOGpAXXQkCc4k/DsWo+6bc5LsVrAsw+OU+Ibi7klFZCyX54gjYzX4TH+f2uzXjRviLARxkMurA2bA==", - "dev": true + "dev": true, + "requires": {} }, "postcss-discard-empty": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-5.0.1.tgz", "integrity": "sha512-vfU8CxAQ6YpMxV2SvMcMIyF2LX1ZzWpy0lqHDsOdaKKLQVQGVP1pzhrI9JlsO65s66uQTfkQBKBD/A5gp9STFw==", - "dev": true + "dev": true, + "requires": {} }, "postcss-discard-overridden": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-5.0.1.tgz", "integrity": "sha512-Y28H7y93L2BpJhrdUR2SR2fnSsT+3TVx1NmVQLbcnZWwIUpJ7mfcTC6Za9M2PG6w8j7UQRfzxqn8jU2VwFxo3Q==", - "dev": true + "dev": true, + "requires": {} }, "postcss-js": { "version": "3.0.3", @@ -16485,7 +16493,8 @@ "version": "5.0.1", "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-5.0.1.tgz", "integrity": "sha512-6J40l6LNYnBdPSk+BHZ8SF+HAkS4q2twe5jnocgd+xWpz/mx/5Sa32m3W1AA8uE8XaXN+eg8trIlfu8V9x61eg==", - "dev": true + "dev": true, + "requires": {} }, "postcss-normalize-display-values": { "version": "5.0.1", @@ -18073,7 +18082,8 @@ "version": "7.4.6", "resolved": "https://registry.npmjs.org/ws/-/ws-7.4.6.tgz", "integrity": "sha512-YmhHDO4MzaDLB+M9ym/mDA5z0naX8j7SIlT8f8z+I0VtzsRbekxEutHSme7NPS2qE8StCYQNUnfWdXta/Yu85A==", - "dev": true + "dev": true, + "requires": {} }, "xml-name-validator": { "version": "3.0.0", diff --git a/package.json b/package.json index 59a8cf1e9f26..cbeba6e61688 100644 --- a/package.json +++ b/package.json @@ -23,6 +23,7 @@ "postbabelify": "ncc build lib/cli-peer-dependencies.js -o peers", "rebuild-fixtures": "npm run babelify && babel-node scripts/rebuildFixtures.js", "prepublishOnly": "npm install --force && npm run babelify && babel-node scripts/build.js && node scripts/build-plugins.js", + "prepare": "babel-node scripts/create-plugin-list.js", "style": "eslint .", "test": "cross-env TAILWIND_MODE=build jest", "test:integrations": "npm run test --prefix ./integrations", diff --git a/scripts/create-plugin-list.js b/scripts/create-plugin-list.js new file mode 100644 index 000000000000..d6363e0114d0 --- /dev/null +++ b/scripts/create-plugin-list.js @@ -0,0 +1,10 @@ +import * as corePlugins from '../src/plugins' +import fs from 'fs' +import path from 'path' + +const corePluginList = Object.keys(corePlugins) + +fs.writeFileSync( + path.join(__dirname, '..', 'src', 'corePluginList.js'), + `export default ${JSON.stringify(corePluginList)}` +) diff --git a/src/util/resolveConfig.js b/src/util/resolveConfig.js index 3892dbc16264..9c14a78ad108 100644 --- a/src/util/resolveConfig.js +++ b/src/util/resolveConfig.js @@ -10,7 +10,7 @@ import toPath from 'lodash/toPath' import head from 'lodash/head' import isPlainObject from 'lodash/isPlainObject' import negateValue from './negateValue' -import * as corePlugins from '../plugins' +import corePluginList from '../corePluginList' import configurePlugins from './configurePlugins' import defaultConfig from '../../stubs/defaultConfig.stub' import colors from '../../colors' @@ -243,7 +243,7 @@ function resolveCorePlugins(corePluginConfigs) { return corePluginConfig({ corePlugins: resolved }) } return configurePlugins(corePluginConfig, resolved) - }, Object.keys(corePlugins)) + }, corePluginList) return result } From b8fca6bb03a773aaf548b0551bf27f2da43af5d6 Mon Sep 17 00:00:00 2001 From: Sachin Raja <58836760+sachinraja@users.noreply.github.com> Date: Sun, 20 Jun 2021 23:11:30 -0700 Subject: [PATCH 2/5] Use `process.cwd()` instead of `__dirname` to resolve path Co-authored-by: Federico Ciardi --- scripts/create-plugin-list.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/scripts/create-plugin-list.js b/scripts/create-plugin-list.js index d6363e0114d0..6ffef67f527c 100644 --- a/scripts/create-plugin-list.js +++ b/scripts/create-plugin-list.js @@ -5,6 +5,6 @@ import path from 'path' const corePluginList = Object.keys(corePlugins) fs.writeFileSync( - path.join(__dirname, '..', 'src', 'corePluginList.js'), + path.join(process.cwd(), 'src', 'corePluginList.js'), `export default ${JSON.stringify(corePluginList)}` ) From 68f15442ca84691e59fb4f8a64709a72d7129abf Mon Sep 17 00:00:00 2001 From: Sachin Raja Date: Mon, 21 Jun 2021 12:29:44 -0700 Subject: [PATCH 3/5] Import core plugin list in resolveConfig test --- tests/resolveConfig.test.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/tests/resolveConfig.test.js b/tests/resolveConfig.test.js index 91561358042b..0be4482fe2db 100644 --- a/tests/resolveConfig.test.js +++ b/tests/resolveConfig.test.js @@ -1,7 +1,5 @@ -import * as corePlugins from '../src/plugins' import resolveConfig from '../src/util/resolveConfig' - -const corePluginList = Object.keys(corePlugins) +import corePluginList from '../src/corePluginList' test('prefix key overrides default prefix', () => { const userConfig = { From c8ea2bd0eaa53f6a11023ee346c0236cb1397666 Mon Sep 17 00:00:00 2001 From: Sachin Raja Date: Mon, 21 Jun 2021 22:59:39 -0700 Subject: [PATCH 4/5] Generate plugin list prebabelify and on install --- package-lock.json | 1 + package.json | 7 ++++--- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/package-lock.json b/package-lock.json index 611c369654ab..b759b86223fe 100644 --- a/package-lock.json +++ b/package-lock.json @@ -6,6 +6,7 @@ "packages": { "": { "version": "2.2.2", + "hasInstallScript": true, "license": "MIT", "dependencies": { "@fullhuman/postcss-purgecss": "^4.0.3", diff --git a/package.json b/package.json index cbeba6e61688..d9343e74cc49 100644 --- a/package.json +++ b/package.json @@ -18,19 +18,20 @@ "David Hemphill " ], "scripts": { - "prebabelify": "rimraf lib", + "prebabelify": "npm run generate:plugin-list && rimraf lib", "babelify": "babel src --out-dir lib --copy-files", "postbabelify": "ncc build lib/cli-peer-dependencies.js -o peers", "rebuild-fixtures": "npm run babelify && babel-node scripts/rebuildFixtures.js", "prepublishOnly": "npm install --force && npm run babelify && babel-node scripts/build.js && node scripts/build-plugins.js", - "prepare": "babel-node scripts/create-plugin-list.js", "style": "eslint .", "test": "cross-env TAILWIND_MODE=build jest", "test:integrations": "npm run test --prefix ./integrations", + "install": "npm run generate:plugin-list", "install:integrations": "node scripts/install-integrations.js", "posttest": "npm run style", "compat": "node scripts/compat.js --prepare", - "compat:restore": "node scripts/compat.js --restore" + "compat:restore": "node scripts/compat.js --restore", + "generate:plugin-list": "babel-node scripts/create-plugin-list.js" }, "files": [ "dist/*.css", From d8ed41a70e215fd9fa9f7a9d0cc1977cc4c7262b Mon Sep 17 00:00:00 2001 From: Sachin Raja Date: Tue, 22 Jun 2021 08:15:58 -0700 Subject: [PATCH 5/5] Move generation from install to postinstall Co-authored-by: Federico Ciardi --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index d9343e74cc49..1ad4bfbb7e2b 100644 --- a/package.json +++ b/package.json @@ -26,7 +26,7 @@ "style": "eslint .", "test": "cross-env TAILWIND_MODE=build jest", "test:integrations": "npm run test --prefix ./integrations", - "install": "npm run generate:plugin-list", + "postinstall": "npm run generate:plugin-list", "install:integrations": "node scripts/install-integrations.js", "posttest": "npm run style", "compat": "node scripts/compat.js --prepare",