Skip to content

Commit

Permalink
tailwindcss ui: Add tailwindcss prettier rules
Browse files Browse the repository at this point in the history
  • Loading branch information
Morishiri committed Jun 28, 2022
1 parent 8d31358 commit d325d41
Showing 1 changed file with 77 additions and 1 deletion.
78 changes: 77 additions & 1 deletion packages/cli/src/commands/setup/ui/libraries/tailwindcss.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,13 @@ const tailwindImportsAndNotes = [
export const handler = async ({ force, install }) => {
const rwPaths = getPaths()

const packages = ['postcss', 'postcss-loader', 'tailwindcss', 'autoprefixer']
const packages = [
'postcss',
'postcss-loader',
'tailwindcss',
'autoprefixer',
'prettier-plugin-tailwindcss',
]

const recommendedVSCodeExtensions = [
'csstools.postcss',
Expand Down Expand Up @@ -189,6 +195,76 @@ export const handler = async ({ force, install }) => {
}
},
},
{
title: 'Adding tailwind config entry in prettier...',
task: async (_ctx) => {
const prettierConfigPath = path.join(rwPaths.base, 'prettier.config.js')
// Add tailwindcss ordering plugin to prettier
const prettierConfig = fs.readFileSync(prettierConfigPath, 'utf-8')
const tailwindConfigPath = path.relative(
rwPaths.base,
path.join(rwPaths.web.config, 'tailwind.config.js')
)

let newPrettierConfig = prettierConfig
if (newPrettierConfig.includes('tailwindConfig: ')) {
if (force) {
newPrettierConfig = newPrettierConfig.replace(
/tailwindConfig: .*(,)?/,
`tailwindConfig: './${tailwindConfigPath}',`
)
} else {
throw new Error(
'tailwindConfig setting already exists in prettier configuration.\nUse --force to override existing config.'
)
}
} else {
newPrettierConfig = newPrettierConfig.replace(
/,(\n\s*)(\}\n?)$/,
`,\n tailwindConfig: './${tailwindConfigPath}',$1$2`
)
}

fs.writeFileSync(prettierConfigPath, newPrettierConfig)
},
},
{
title: 'Adding tailwind prettier plugin...',
task: async (_ctx, task) => {
const prettierConfigPath = path.join(rwPaths.base, 'prettier.config.js')
// Add tailwindcss ordering plugin to prettier
const prettierConfig = fs.readFileSync(prettierConfigPath, 'utf-8')

let newPrettierConfig = prettierConfig
if (newPrettierConfig.includes('plugins: [')) {
const pluginsMatch = newPrettierConfig.match(
/plugins: \[[\sa-z\(\)'\-,]*]/
)

const matched = pluginsMatch && pluginsMatch[0]

if (
matched &&
(matched.includes("require('prettier-plugin-tailwindcss')") ||
matched.includes('require("prettier-plugin-tailwindcss")'))
) {
task.skip('tailwindcss-plugin-prettier already required in plugins')
} else {
newPrettierConfig = newPrettierConfig.replace(
/plugins: \[(\n\s+)*/,
`plugins: [$1require('prettier-plugin-tailwindcss'),$1`
)
}
} else {
newPrettierConfig = newPrettierConfig.replace(
/,(\n\s*)(\}\n?)$/,
`,\n plugins: [require('prettier-plugin-tailwindcss')],$1$2`
)
}

fs.writeFileSync(prettierConfigPath, newPrettierConfig)
},
},
])

try {
Expand Down

0 comments on commit d325d41

Please sign in to comment.