Skip to content

artifact-project/css

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

@artifact-project/css

Yet another CSS in J... TS

Features

  • CSS deduplication
  • Smaller Critical CSS
  • Nesting
  • Animation/Keyframes
  • Media Queries (todo)
  • Minimalistic API
  • Polyfills (todo)
import css, {getUsedCSS} from '@artifact-project/css';

const cx = css({
	'main': {
		color: 'red',
		fontSize: 14,
	},
});

console.log(cx.main); // "main-nssjx7" (dev)
console.log(cx.main); // "_rs" (production)

console.log(getUsedCSS());
// {
// 	names: ['nssjx7'],
// 	cssText: '._nssjx7{color:red;font-size:14px;}',
// }

Usage

Add style#__css__ into head and before including @artifact-project/css.

<style id="__css__" data-names="%__USED_CSS_NAMES__%">%__USED_CSS_TEXT__%</style>
<script type="module">
	import css from './node_modules/@artifact-project/css/index.js';

	const cx = css({
		'link': {
			color: '#3c0',

			'&:hover': {
				color: 'red',
			},
		},
	});
</script>

API

  • css(rules): {[name:string]: string}
  • fx(keyframes): (detail: string) => object
  • getUsedCSS(all?: boolean): {names: string[], cssText: string}

Killer-feature

Deduplication & critical css.

import css, {getUsedCSS} from '@artifact-project/css';

const some = css({
	'main': {
		color: '#333',
		fontSize: 14,
	},
});

// Keyframes animation
const colorFx = css.fx({
	from: {color: '#333'},
	to: {color: 'red'},
});

// Some unused fx
const unusedFx = css.fx({
	from: {top: 0},
	to: {top: 300},
});

const link = css({
	'root': {
		color: '#333',
		fontSize: 14,

		'&:hover': {
			animation: colorFx('0.3s'),
		},
	},

	'unused': {
		textAlign: 'center',
	},
});

console.log(some.main); // "_rs" (1)
console.log(link.root); // "_rt" (2)

// and CSS result, wow! (3)
console.log(getUsedCSS().cssText);
//  @keyframes _xsdcv{from:{color:#333}to:{color:red}}
//  ._rs, _rt{color:#333;font-size:14px;}
//  ._rs:hover{animation:_xsdcv 0.3s;}

Configuration

  • process.env.NODE_ENV: 'production' | 'dev'
  • process.env.RUN_AT: 'server' | 'client'

Development