npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@studiokeywi/chic

v0.4.10

Published

Easily apply CSS styles to your browser console output with Chic!

Downloads

24

Readme

chic

Chic is a tiny assistant for helping make browser console.log() output prettier.

The information on MDN about styling console output applies to browser-based uses. Attempting to use Chic in NodeJS will result in the styling being entirely stripped, due to the lack of CSS support. Chic is expected (but not guaranteed) to still output text to the console for NodeJS, but there are no attempts to convert potentially available CSS styles into console-compatible command sequences. If you need something to bring styling to your NodeJS console messages, consider chalk.

version license types publish size install size minzipped size Libraries.io dependency status for latest release, scoped npm package

Getting Started

Chic is meant to be used and viewed in the browser, and so it is assumed that you will either be importing directly from a CDN or using a bundler (such as webpack/rollup/snowpack/vite/esbuild/...). The easiest way to get started is via CDN. Since Chic is publically available through NPM, you can use one of the CDN URLs provided by jsdelivr:

https://cdn.jsdelivr.net/npm/@studiokeywi/chic/dist/index.min.js

Example:

<script type="module">
  import { chic } from 'https://cdn.jsdelivr.net/npm/@studiokeywi/chic/dist/index.min.js';

  chic.log`Hello, World!${chic.fontSize._2rem()}`;
</script>

If you are using a modern front end framework or bundler for front end, then you can download and install via npm:

npm i @studiokeywi/chic (or use npm i -D @studiokeywi/chic if your bundler/compiler will manage development dependencies).

And then import it at the top of your file(s):

import { chic } from '@studiokeywi/chic';

chic.log`Hello, World!${chic.fontSize._2rem()}`;

If you want a preview without requiring a project to embed or install Chic, you can open up your browser's console and use the following snippet:

window.chic = (await import('https://cdn.jsdelivr.net/npm/@studiokeywi/chic/dist/index.min.js')).chic;

chic.log`Hello, World!${chic.fontSize._2rem()}`;

API

CSS Tagged Template Literal Logging

NOTE: If you have Chic embedded in a project or loaded into the browser as described above, you can run any of these examples below to see what the styled output looks like.

Chic wraps around the styleable logging methods provided by the browser's console object, but with a tagged template. This syntax means that styled logging is performed in a slightly different fashion than traditional methods:

chic.log`Hello World`;

Each section of text can receive it's own styling. Simply interpolate the style string directly afterwards the text with the CSS Builder syntax:

chic.log`Hello World${chic.background.darkslategray.color.lightgray()}`;
chic.log`Hello${chic.color.red()} World${chic.color.blue()}`;

Templates without interpolated style strings will be unstyled, as will any text that follows the final style string in a template:

chic.log`Hello${chic['font-size']['1rem']()} World`;

What About Styled Variable Interpolation?

Since Chic assumes that values passed through interpolation are styles, you may be wondering how to apply styles to variables. The traditional function call for tagged templates take in an array-like for the first param, and then all styles as the remaining params:

const someUsername = 'Gary Garrison';
chic.log(['User: ', someUsername], chic['font-weight'].bolder.padding['1rem'](), chic.color.yellow());

NOTE: Different browsers may offer different styling options. See the list on MDN about styling console output for a list of potentially available CSS properties for your browser

Behind the scenes, Chic uses a JavaScript Proxy object. This allows the use of object property access notations to be converted into CSS-friendly strings, while allowing access to dedicated Chic properties (eg logging functions, the inject and fix functions, or use of the plugin object).

As seen above, the simplest way to use this syntax is with simple text values. You can build up a new style string by alternating between CSS properties and values via property access on the Chic object, then executing a function. For instance, to build the style string color: green;, you can use chic.color.green().

Since CSS styles often require characters that are invalid in JavaScript identifiers, there are two options available. The first is to use bracket notation for property access (as used in previous examples):

chic.background['#c0c0c0']['border-radius']['0.5rem'].border['0.125rem solid blue']();
// returns 'background:#c0c0c0;border-radius:0.5rem;border:0.125rem solid blue'

The second is to use special formatting as described in this chart:

| Special Formatting | Replacement | | --------------------------------- | ----------------------------- | | Camel case text (eg sampleText) | Kebab case (eg sample-text) | | $ | # | | _ (at start of string) | (empty string) | | _ (in between digits) | . | | _ (other positions) | (single space) |

chic.background.$c0c0c0.borderRadius._0_5rem.border._0_125rem_solid_blue();
// returns 'background:#c0c0c0;border-radius:0.5rem;border:0.125rem solid blue'

NOTES:

  • As seen in the bracket syntax example, you can mix and match approaches based on your preference or needs. chic['color'].green() is the same as chic.color.$008000() for the final display purposes.
  • When using $ substitution, use lowercase characters in your hex to prevent the styling from being treated as camelCase for kebab-case conversion:
    // Don't Use
    chic.color.$C0C0C0(); // returns "color:#-c0-c0-c0"
    // Use Instead
    chic.color.$c0c0c0(); // returns "color:#c0c0c0"
  • Certain CSS properties can include commas and/or quotation marks, which do not have a variable substitution. However, bracket notation can allow these to be used:
    chic.fontFamily['"Fira Code", monospace']();
    // returns 'font-family:"Fira Code", monospace'
  • Due to the use of underscores in numbers, you cannot perform shorthand numeric definitions for properties (eg margin: 0 0.25rem 0 0) with this special syntax. As with quotation marks, bracket notation can allow these to be used:
    // Don't Use
    chic.margin._0_0_25rem_0_0(); // returns 'margin:0.0 25rem 0.0'
    // Use Instead
    chic.margin['0 0.25rem 0 0'](); // returns 'margin:0 0.25rem 0 0'
    • Using shorthand notation with units should work as expected:
      chic.margin._0rem_0_25rem_0rem_0rem(); // returns 'margin:0rem 0.25rem 0rem 0rem;'

If there are certain base styles you want to apply to multiple areas, you could start by building up a partial string and then append it to another style string manually:

const infoStyle = chic.background.$c0c0c0.color.white();
const boxStyle = chic.padding['1rem'].border['0.125rem solid blue']();
const infoBox = `${infoStyle};${boxStyle}`;
chic.log`Something to know${infoBox}`;

Using chic.fix() allows you to fix the current level of styling by returning a new Chic object so that you can more easily create style definitions with shared properties:

const infoStyle = chic.background.$c0c0c0.color.white.fix();
const infoBox = infoStyle.padding['1rem'].border['0.125rem solid blue']();
chic.log`Something to know${infoBox}`;

Sometimes, you may find yourself with several Chic styles that you may want to compose together. With the chic.inject() function, you can create new instances of Chic that merge together styles:

const borderBox = chic.border['0.125rem solid blue']();
const largeFont = chic.fontSize['2rem']();
const smallFont = chic.fontSize['1rem']();
const titleBox = chic.inject(borderBox).inject(largeFont)();
const textBox = chic.inject(borderBox, smallFont)();
chic.log`My Title${titleBox}
My Text${textBox}`;

Note About Fixing/Injecting Styles

Since chic.fix() and chic.inject() return a new Chic object, you can also use the return value as a logger itself; just don't forget to pass in the styles -- Chic will persist your fixed styles when creating new style strings, but does not know when to use them for logging:

const infoStyle = chic.background.$c0c0c0.color.white.fix();
const infoBox = infoStyle.padding['1rem'].border['0.125rem solid blue'].fix();
infoBox.log`Something to know${infoBox()}`;

const borderBox = chic.border['0.125rem solid blue']();
const largeFont = chic.fontSize['2rem']();
const boxLog = chic.inject(borderBox, largeFont);
boxLog.log`Another Title${boxLog()}`;

Advanced

Build

Beyond the default Chic object, you can also import the Chic builder function to have a more customized logger:

import { buildChic } from '@studiokeywi/chic';

const chic = buildChic();

/** Configuration for building Chic instances */
type ChicConfig = {
  /** Fixed styles to always apply when building style strings */
  fixed?: string[][];
  /** Plugins to extend Chic functionality */
  plugins?: ChicPlugin[];
};

buildChic takes an optional configuration object, with two optional properties: fixed and plugins. fixed is an array of strings representing a fixed portion of styling; internally, this is how the .fix() function continues styles to the new instance. plugins is an array of plugin objects (as defined in the section below).

NOTE: It's generally not recommended to pass fixed values to the buildChic config object as compared to using the .fix() function. If you want to manually pass values to fixed while using buildChic anyway, make sure that each entry in the array matches the pattern [cssProperty, cssValue]

Why would I want this?

The default Chic object installs certain plugins automatically. For smaller bundling, you may wish to omit these by building a custom instance.

Plugins

NOTE: Experimental. May disappear at any time

Plugins can be used to extend Chic functionality. Plugin objects can be assigned in the plugins param for buildChic:

// loggers.js
import { buildChic } from '@studiokeywi/chic';
import somePlugin from './plugins/myPlugin.js';

export const chic = buildChic({ plugins: [somePlugin] });

They can also be added to an existing instance after the fact:

import { chic } from './loggers.js';
import anotherPlugin from './plugins/anotherPlugin.js';

chic.plugins.install(anotherPlugin);
chic.plugins.doSomeThing(); // installed from `somePlugin`
chic.plugins.doAnotherThing(); // installed from `anotherPlugin`

See the plugins page for more information.