Skip to content

Commit

Permalink
Support member access on function calls (#218)
Browse files Browse the repository at this point in the history
* Refactor

* Fix test script

* Support member access on function calls

* Update changelog
  • Loading branch information
thecrypticace authored Oct 3, 2023
1 parent b300077 commit 047d591
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 6 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Fixed

- Sort classes inside `className` in Astro ([#215](https://github.com/tailwindlabs/prettier-plugin-tailwindcss/pull/215))
- Support member access on function calls ([#218](https://github.com/tailwindlabs/prettier-plugin-tailwindcss/pull/218))

## [0.5.4] - 2023-08-31

Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
"predev": "npm run _pre",
"dev": "npm run _esbuild -- --watch",
"pretest": "node scripts/install-fixture-deps.js",
"test": "jest",
"test": "NODE_OPTIONS=--experimental-vm-modules jest",
"prepublishOnly": "npm run build && node scripts/copy-licenses.js",
"format": "prettier \"src/**/*.js\" \"scripts/**/*.js\" \"tests/test.js\" --write --print-width 100 --single-quote --no-semi --plugin-search-dir ./tests",
"release-channel": "node ./scripts/release-channel.js",
Expand Down
37 changes: 32 additions & 5 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -460,6 +460,37 @@ function isSortableTemplateExpression(node, functions) {
return false
}

/**
*
* @param {import('@babel/types').CallExpression | import('ast-types').namedTypes.CallExpression} node
* @param {Set<string>} functions
* @returns {boolean}
*/
function isSortableCallExpression(node, functions) {
if (!node.arguments?.length) {
return false
}

if (node.callee.type === 'Identifier') {
return functions.has(node.callee.name)
}

if (node.callee.type === 'MemberExpression') {
let expr = node.callee.object

// If the tag is a MemberExpression we should traverse all MemberExpression's until we find the leading Identifier
while (expr.type === 'MemberExpression') {
expr = expr.object
}

if (expr.type === 'Identifier') {
return functions.has(expr.name)
}
}

return false
}

/**
* @param {import('@babel/types').Node} ast
* @param {TransformerContext} param1
Expand Down Expand Up @@ -502,11 +533,7 @@ function transformJavaScript(ast, { env }) {

/** @param {import('@babel/types').CallExpression} node */
CallExpression(node) {
if (!node.arguments?.length) {
return
}

if (!functions.has(node.callee?.name ?? '')) {
if (!isSortableCallExpression(node, functions)) {
return
}

Expand Down
4 changes: 4 additions & 0 deletions tests/fixtures.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,10 @@ const f = tw.foo\`p-2 sm:p-1\`;
const g = tw.foo.bar\`p-2 sm:p-1\`;
const h = no.foo\`sm:p-1 p-2\`;
const i = no.tw\`sm:p-1 p-2\`;
const k = tw.foo("p-2 sm:p-1");
const l = tw.foo.bar("p-2 sm:p-1");
const m = no.foo("sm:p-1 p-2");
const n = no.tw("sm:p-1 p-2");
const A = (props) => <div className={props.sortMe} />;
const B = () => <A sortMe="p-2 sm:p-1" dontSort="sm:p-1 p-2" />;`,
Expand Down
4 changes: 4 additions & 0 deletions tests/fixtures/custom-jsx/index.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,10 @@ const f = tw.foo`sm:p-1 p-2`;
const g = tw.foo.bar`sm:p-1 p-2`;
const h = no.foo`sm:p-1 p-2`;
const i = no.tw`sm:p-1 p-2`;
const k = tw.foo('sm:p-1 p-2');
const l = tw.foo.bar('sm:p-1 p-2');
const m = no.foo('sm:p-1 p-2');
const n = no.tw('sm:p-1 p-2');

const A = (props) => <div className={props.sortMe} />;
const B = () => <A sortMe="sm:p-1 p-2" dontSort="sm:p-1 p-2" />;

0 comments on commit 047d591

Please sign in to comment.