Files
formipay/node_modules/@wordpress/eslint-plugin/rules/i18n-no-flanking-whitespace.js
dwindown e8fbfb14c1 fix: prevent asset conflicts between React and Grid.js versions
Add coexistence checks to all enqueue methods to prevent loading
both React and Grid.js assets simultaneously.

Changes:
- ReactAdmin.php: Only enqueue React assets when ?react=1
- Init.php: Skip Grid.js when React active on admin pages
- Form.php, Coupon.php, Access.php: Restore classic assets when ?react=0
- Customer.php, Product.php, License.php: Add coexistence checks

Now the toggle between Classic and React versions works correctly.

Co-authored-by: Claude Opus 4.7 <noreply@anthropic.com>
2026-04-18 17:02:14 +07:00

91 lines
1.7 KiB
JavaScript

/**
* Internal dependencies
*/
const {
TRANSLATION_FUNCTIONS,
getTextContentFromNode,
getTranslateFunctionName,
getTranslateFunctionArgs,
} = require( '../utils' );
const PROBLEMS_BY_CHAR_CODE = {
9: '\\t',
10: '\\n',
13: '\\r',
32: 'whitespace',
};
function makeFixerFunction( arg ) {
return ( fixer ) => {
switch ( arg.type ) {
case 'Literal':
return [ fixer.replaceText( arg, `'${ arg.value.trim() }'` ) ];
case 'BinaryExpression':
return [
...makeFixerFunction( arg.left )( fixer ),
...makeFixerFunction( arg.right )( fixer ),
];
}
};
}
module.exports = {
meta: {
type: 'problem',
schema: [],
messages: {
noFlankingWhitespace:
'Translations should not contain flanking whitespace{{problem}}',
},
fixable: 'code',
},
create( context ) {
return {
CallExpression( node ) {
const { callee, arguments: args } = node;
const functionName = getTranslateFunctionName( callee );
if ( ! TRANSLATION_FUNCTIONS.has( functionName ) ) {
return;
}
const candidates = getTranslateFunctionArgs(
functionName,
args
);
for ( const arg of candidates ) {
const argumentString = getTextContentFromNode( arg );
if ( ! argumentString ) {
continue;
}
const trimmableWhitespace =
argumentString.match( /^\s|\s$/ );
if ( ! trimmableWhitespace ) {
continue;
}
const problem =
PROBLEMS_BY_CHAR_CODE[
trimmableWhitespace[ 0 ].charCodeAt( 0 )
];
const problemString = problem ? ` (${ problem })` : '';
context.report( {
node,
messageId: 'noFlankingWhitespace',
data: {
problem: problemString,
},
fix: makeFixerFunction( arg ),
} );
}
},
};
},
};