@lnear/marco - CSS Utilities Library
This is a lightweight (and low level) CSS utilities library aimed at simplifying and standardizing common CSS patterns. It provides a utility function for generating CSS properties and values dynamically.
Installation
You can install this library via npm:
Usage
This will generate the following CSS string:
More docs coming soon…
Patterns
The below are the predefined patterns that can be used with the replace
function. It is not an exhaustive list and intutive patterns are implemented as needed.
For example, only “saturate-(0, 50, 100, 150, 200)” are documented here, but any value can be used with the “saturate” pattern. (saturate-x where x is a number will be replaced with “filter: saturate({x / 100});“)
View Patterns
drop-shadow
drop-shadow-sm
drop-shadow-md
drop-shadow-lg
drop-shadow-xl
drop-shadow-2xl
drop-shadow-none
backdrop-hue-rotate-0
backdrop-hue-rotate-15
backdrop-hue-rotate-16
backdrop-hue-rotate-30
backdrop-hue-rotate-60
backdrop-hue-rotate-90
backdrop-hue-rotate-180
hue-rotate-0
hue-rotate-15
hue-rotate-30
hue-rotate-60
hue-rotate-90
hue-rotate-180
grayscale-0
grayscale
invert-0
invert
sepia-0
sepia
backdrop-grayscale-0
backdrop-grayscale
saturate-0
saturate-50
saturate-100
saturate-150
saturate-200
backdrop-blur
backdrop-blur-none
backdrop-blur-sm
backdrop-blur-md
backdrop-blur-lg
backdrop-blur-xl
backdrop-blur-2xl
backdrop-blur-3xl
blur
blur-none
blur-sm
blur-md
blur-lg
blur-xl
blur-2xl
blur-3xl
backdrop-brightness-0
backdrop-brightness-50
backdrop-brightness-75
backdrop-brightness-90
backdrop-brightness-95
backdrop-brightness-100
backdrop-brightness-105
backdrop-brightness-110
backdrop-brightness-125
backdrop-brightness-150
backdrop-brightness-200
brightness-0
brightness-50
brightness-75
brightness-90
brightness-95
brightness-100
brightness-105
brightness-110
brightness-125
brightness-150
brightness-200
contrast-0
contrast-50
contrast-75
contrast-100
contrast-125
contrast-150
contrast-200
backdrop-contrast-0
backdrop-contrast-50
backdrop-contrast-75
backdrop-contrast-100
backdrop-contrast-125
backdrop-contrast-150
backdrop-contrast-200
ease-linear
ease-in
ease-out
ease-in-out
timing-linear
timing-in
timing-out
timing-in-out
transition-colors
transition-opacity
transition-all
transition-shadow
transition-none
float-start
float-end
float-right
float-left
float-none
clear-start
clear-end
clear-right
clear-left
clear-both
clear-none
inline-block
inline-flex
inline-table
block
inline
hidden
table
table-caption
table-cell
table-column
table-column-group
table-footer-group
table-header-group
table-row-group
table-row
flow-root
grid
inline-grid
contents
list-item
bg-inherit
bg-transparent
bg-auto
bg-cover
bg-contain
bg-fixed
bg-local
bg-scroll
bg-center
bg-top
bg-right-top
bg-right
bg-right-bottom
bg-bottom
bg-left-bottom
bg-left
bg-left-top
bg-repeat
bg-no-repeat
bg-repeat-x
bg-repeat-y
bg-round
bg-space
bg-none
pointer-events-none
pointer-events-auto
place-content-center
place-content-start
place-content-end
place-content-between
place-content-around
place-content-evenly
place-content-baseline
place-content-stretch
place-items-center
place-items-start
place-items-end
place-items-baseline
place-items-stretch
inset-auto
start-auto
end-auto
top-auto
right-auto
bottom-auto
left-auto
isolate
isolation-auto
z-auto
order-first
order-last
order-none
col-auto
col-span-full
col-start-auto
col-end-auto
row-auto
row-span-full
row-start-auto
row-end-auto
box-border
box-content
aspect-auto
aspect-square
aspect-video
flex-auto
flex-initial
flex-none
basis-auto
basis-full
table-auto
table-fixed
caption-top
caption-bottom
border-collapse
border-separate
origin-center
origin-top
origin-top-right
origin-right
origin-bottom-right
origin-bottom
origin-bottom-left
origin-left
origin-top-left
perspective-origin-center
perspective-origin-top
perspective-origin-top-right
perspective-origin-right
perspective-origin-bottom-right
perspective-origin-bottom
perspective-origin-bottom-left
perspective-origin-left
perspective-origin-top-left
perspective-none
translate-none
transform-none
transform-flat
transform-3d
transform-content
transform-border
transform-fill
transform-stroke
transform-view
backface-visible
backface-hidden
resize-none
resize-both
resize-x
resize-y
snap-none
snap-align-none
snap-start
snap-end
snap-center
snap-normal
snap-always
list-inside
list-outside
list-none
list-disc
list-decimal
list-image-none
appearance-none
appearance-auto
columns-auto
grid-flow-row
grid-flow-col
grid-flow-dense
grid-flow-row-dense
grid-flow-col-dense
auto-cols-auto
auto-cols-min
auto-cols-max
auto-cols-fr
auto-rows-auto
auto-rows-min
auto-rows-max
auto-rows-fr
grid-cols-none
grid-cols-subgrid
grid-rows-none
grid-rows-subgrid
flex-row
flex-row-reverse
flex-col
flex-col-reverse
flex-wrap
flex-nowrap
flex-wrap-reverse
content-normal
content-center
content-start
content-end
content-between
content-around
content-evenly
content-baseline
content-stretch
items-center
items-start
items-end
items-baseline
items-stretch
justify-normal
justify-center
justify-start
justify-end
justify-between
justify-around
justify-evenly
justify-baseline
justify-stretch
justify-items-normal
justify-items-center
justify-items-start
justify-items-end
justify-items-stretch
place-self-auto
place-self-start
place-self-end
place-self-center
place-self-stretch
self-auto
self-start
self-end
self-center
self-stretch
self-baseline
justify-self-auto
justify-self-start
justify-self-end
justify-self-center
justify-self-stretch
scroll-auto
scroll-smooth
text-ellipsis
text-clip
whitespace-normal
whitespace-nowrap
whitespace-pre
whitespace-pre-line
whitespace-pre-wrap
whitespace-break-spaces
text-wrap
text-nowrap
text-balance
text-pretty
break-words
break-all
break-keep
via-none
bg-clip-text
bg-clip-border
bg-clip-padding
bg-clip-content
bg-origin-border
bg-origin-padding
bg-origin-content
mix-blend-plus-darker
mix-blend-plus-lighter
stroke-none
object-contain
object-cover
object-fill
object-none
object-scale-down
object-bottom
object-center
object-left
object-left-bottom
object-left-top
object-right
object-right-bottom
object-right-top
object-top
text-left
text-center
text-right
text-justify
text-start
text-end
align-baseline
align-top
align-middle
align-bottom
align-text-top
align-text-bottom
align-sub
align-super
uppercase
lowercase
capitalize
normal-case
italic
not-italic
underline
overline
line-through
no-underline
font-stretch-normal
font-stretch-ultra-condensed
font-stretch-extra-condensed
font-stretch-condensed
font-stretch-semi-condensed
font-stretch-semi-expanded
font-stretch-expanded
font-stretch-extra-expanded
font-stretch-ultra-expanded
decoration-solid
decoration-double
decoration-dotted
decoration-dashed
decoration-wavy
decoration-auto
decoration-from-font
animate-none
will-change-auto
will-change-scroll
will-change-contents
will-change-transform
contain-none
contain-content
contain-strict
forced-color-adjust-none
forced-color-adjust-auto
normal-nums
underline-offset-auto
touch-none
touch-auto
touch-pan-x
cursor-auto
cursor-default
select-none
select-text
rotate-0
rotate-90
border-inherit
border-current
border-transparent
border-x-black
border-black
border-white
border-slate-50
border-slate-100
border-slate-200
border-slate-300
border-slate-400
border-slate-500
border-slate-600
border-slate-700
border-slate-800
border-slate-900
border-slate-950
border-gray-50
border-gray-100
border-gray-200
border-gray-300
border-gray-400
border-gray-500
border-gray-600
border-gray-700
border-gray-800
border-gray-900
border-gray-950
border-zinc-50
border-zinc-100
border-zinc-200
border-zinc-300
border-zinc-400
border-zinc-500
border-zinc-600
border-zinc-700
border-zinc-800
border-zinc-900
border-zinc-950
border-neutral-50
border-neutral-100
border-neutral-200
border-neutral-300
border-neutral-400
border-neutral-500
border-neutral-600
border-neutral-700
border-neutral-800
border-neutral-900
border-neutral-950
border-stone-50
border-stone-100
border-stone-200
border-stone-300
border-stone-400
border-stone-500
border-stone-600
border-stone-700
border-stone-800
border-stone-900
border-stone-950
border-red-50
border-red-100
border-red-200
border-red-300
border-red-400
border-red-500
border-red-600
border-red-700
border-red-800
border-red-900
border-red-950
border-orange-50
border-orange-100
border-orange-200
border-orange-300
border-orange-400
border-orange-500
border-orange-600
border-orange-700
border-orange-800
border-orange-900
border-orange-950
border-amber-50
border-amber-100
border-amber-200
border-amber-300
border-amber-400
border-amber-500
border-amber-600
border-amber-700
border-amber-800
border-amber-900
border-amber-950
border-yellow-50
border-yellow-100
border-yellow-200
border-yellow-300
border-yellow-400
border-yellow-500
border-yellow-600
border-yellow-700
border-yellow-800
border-yellow-900
border-yellow-950
border-lime-50
border-lime-100
border-lime-200
border-lime-300
border-lime-400
border-lime-500
border-lime-600
border-lime-700
border-lime-800
border-lime-900
border-lime-950
border-green-50
border-green-100
border-green-200
border-green-300
border-green-400
border-green-500
border-green-600
border-green-700
border-green-800
border-green-900
border-green-950
border-emerald-50
border-emerald-100
border-emerald-200
border-emerald-300
border-emerald-400
border-emerald-500
border-emerald-600
border-emerald-700
border-emerald-800
border-emerald-900
border-emerald-950
border-teal-50
border-teal-100
border-teal-200
border-teal-300
border-teal-400
border-teal-500
border-teal-600
border-teal-700
border-teal-800
border-teal-900
border-teal-950
border-cyan-50
border-cyan-100
border-cyan-200
border-cyan-300
border-cyan-400
border-cyan-500
border-cyan-600
border-cyan-700
border-cyan-800
border-cyan-900
border-cyan-950
border-sky-50
border-sky-100
border-sky-200
border-sky-300
border-sky-400
border-sky-500
border-sky-600
border-sky-700
border-sky-800
border-sky-900
border-sky-950
border-blue-50
border-blue-100
border-blue-200
border-blue-300
border-blue-400
border-blue-500
border-blue-600
border-blue-700
border-blue-800
border-blue-900
border-blue-950
border-indigo-50
border-indigo-100
border-indigo-200
border-indigo-300
border-indigo-400
border-indigo-500
border-indigo-600
border-indigo-700
border-indigo-800
border-indigo-900
border-indigo-950
border-violet-50
border-violet-100
border-violet-200
border-violet-300
border-violet-400
border-violet-500
border-violet-600
border-violet-700
border-violet-800
border-violet-900
border-violet-950
border-purple-50
border-purple-100
border-purple-200
border-purple-300
border-purple-400
border-purple-500
border-purple-600
border-purple-700
border-purple-800
border-purple-900
border-purple-950
border-fuchsia-50
border-fuchsia-100
border-fuchsia-200
border-fuchsia-300
border-fuchsia-400
border-fuchsia-500
border-fuchsia-600
border-fuchsia-700
border-fuchsia-800
border-fuchsia-900
border-fuchsia-950
border-pink-50
border-pink-100
border-pink-200
border-pink-300
border-pink-400
border-pink-500
border-pink-600
border-pink-700
border-pink-800
border-pink-900
border-pink-950
border-rose-50
border-rose-100
border-rose-200
border-rose-300
border-rose-400
border-rose-500
border-rose-600
border-rose-700
border-rose-800
border-rose-900
border-rose-950
Colors
View Colors
inherit
current
transparent
black
white
slate-50
slate-100
slate-200
slate-300
slate-400
slate-500
slate-600
slate-700
slate-800
slate-900
slate-950
gray-50
gray-100
gray-200
gray-300
gray-400
gray-500
gray-600
gray-700
gray-800
gray-900
gray-950
zinc-50
zinc-100
zinc-200
zinc-300
zinc-400
zinc-500
zinc-600
zinc-700
zinc-800
zinc-900
zinc-950
neutral-50
neutral-100
neutral-200
neutral-300
neutral-400
neutral-500
neutral-600
neutral-700
neutral-800
neutral-900
neutral-950
stone-50
stone-100
stone-200
stone-300
stone-400
stone-500
stone-600
stone-700
stone-800
stone-900
stone-950
red-50
red-100
red-200
red-300
red-400
red-500
red-600
red-700
red-800
red-900
red-950
orange-50
orange-100
orange-200
orange-300
orange-400
orange-500
orange-600
orange-700
orange-800
orange-900
orange-950
amber-50
amber-100
amber-200
amber-300
amber-400
amber-500
amber-600
amber-700
amber-800
amber-900
amber-950
yellow-50
yellow-100
yellow-200
yellow-300
yellow-400
yellow-500
yellow-600
yellow-700
yellow-800
yellow-900
yellow-950
lime-50
lime-100
lime-200
lime-300
lime-400
lime-500
lime-600
lime-700
lime-800
lime-900
lime-950
green-50
green-100
green-200
green-300
green-400
green-500
green-600
green-700
green-800
green-900
green-950
emerald-50
emerald-100
emerald-200
emerald-300
emerald-400
emerald-500
emerald-600
emerald-700
emerald-800
emerald-900
emerald-950
teal-50
teal-100
teal-200
teal-300
teal-400
teal-500
teal-600
teal-700
teal-800
teal-900
teal-950
cyan-50
cyan-100
cyan-200
cyan-300
cyan-400
cyan-500
cyan-600
cyan-700
cyan-800
cyan-900
cyan-950
sky-50
sky-100
sky-200
sky-300
sky-400
sky-500
sky-600
sky-700
sky-800
sky-900
sky-950
blue-50
blue-100
blue-200
blue-300
blue-400
blue-500
blue-600
blue-700
blue-800
blue-900
blue-950
indigo-50
indigo-100
indigo-200
indigo-300
indigo-400
indigo-500
indigo-600
indigo-700
indigo-800
indigo-900
indigo-950
violet-50
violet-100
violet-200
violet-300
violet-400
violet-500
violet-600
violet-700
violet-800
violet-900
violet-950
purple-50
purple-100
purple-200
purple-300
purple-400
purple-500
purple-600
purple-700
purple-800
purple-900
purple-950
fuchsia-50
fuchsia-100
fuchsia-200
fuchsia-300
fuchsia-400
fuchsia-500
fuchsia-600
fuchsia-700
fuchsia-800
fuchsia-900
fuchsia-950
pink-50
pink-100
pink-200
pink-300
pink-400
pink-500
pink-600
pink-700
pink-800
pink-900
pink-950
rose-50
rose-100
rose-200
rose-300
rose-400
rose-500
rose-600
rose-700
rose-800
rose-900
rose-950