Package Exports
- mxcn
Readme
mxcn
Utility function to use both `clsx` and `tailwind-merge` in one go. Where class merging becomes a seamless dance, leaving style conflicts in the dust!
Install
npm i mxcn
Usage
// Use ESM `import` statement syntax for ESM lib.
import cn from 'mxcn';
import { cn } from 'mxcn'; // Or named import.
// OR use CommonJS `require` syntax for CommonJS lib.
const cn = require('mxcn');
// Basic usage in React.
<div className={cn('custom class or tailwind px-2 py-3 flex')} />
// Example: Combined, any example of tailwind-merge or clsx works.
cn('px-2 py-1 bg-red hover:bg-dark-red', null, true && 'p-3 bg-[#B91C1C]')
//=> 'hover:bg-dark-red p-3 bg-[#B91C1C]'
// Example: tailwind-merge
cn('px-2 py-1 bg-red hover:bg-dark-red', 'p-3 bg-[#B91C1C]')
//=> 'hover:bg-dark-red p-3 bg-[#B91C1C]'
// Why? px-2 and py-1 are removed because of p-3 that came afterwards.
// Example: clsx
// Strings (variadic)
cn('foo', true && 'bar', 'baz')
//=> 'foo bar baz'
// Objects
cn({ foo:true, bar:false, baz:isTrue() })
//=> 'foo baz'
// Objects (variadic)
cn({ foo:true }, { bar:false }, null, { '--foobar':'hello' })
//=> 'foo --foobar'
// Arrays
cn(['foo', 0, false, 'bar'])
//=> 'foo bar'
// Arrays (variadic)
cn(['foo'], ['', 0, false, 'bar'], [['baz', [['hello'], 'there']]])
//=> 'foo bar baz hello there'
// Kitchen sink (with nesting)
cn('foo', [1 && 'bar', { baz:false, bat:null }, ['hello', ['world']]], 'cya')
//=> 'foo bar hello world cya'
Changelog
⯠Read the changelog here ā
KEY: š¦ NEW
, š IMPROVE
, š FIX
, š DOC
, š RELEASE
, and š¤ TEST
I use Emoji-log, you should try it and simplify your git commits.
License & Conduct
- MIT Ā© Ahmad Awais
- Code of Conduct
Connect
(follow) To get #OneDevMinute development tips
(connect) On LinkedIn, you know what to do here
(subscribe) Tech talks & #OneDevMinute videos
(read) In-depth & long-form technical articles
Course Recommendation
NodeCLI.com ā Learn to build Node.js CLI Automation
Node CLI Automation development ā without wasting a thousand hours
After building hundreds of developer automation tools used by millions of developers, I am teaching exactly how you can do it yourself with minimum effective effort. Learn to build Node.js & JavaScript-based CLI (Command Line Interface) apps & npm packages. Automate the grunt work, do more in less time, impress your manager, make more salary, and help the community. I'm sharing it all in this step-by-step 100-videos course.
Sponsor
I (Ahmad Awais) and my incredible wife (Maedah Batool) are two engineers who fell in love with open source and then with each other. You can read more about me here. If you or your company use any of my projects or like what Iām doing then consider backing me. I'm in this for the long run. An open-source developer advocate.
āÆāÆ Professional Development Courses ā