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 🙏

© 2024 – Pkg Stats / Ryan Hefner

kattcss

v0.1.1

Published

A CSS framework built upon and extending inuitcss

Downloads

1

Readme

kattcss

Short about kattcss

kattcss is a fork and extension of inuitcss, a superb framework with a great ideology, that we at Agigen have used quite a lot throughout the years.

The primary goal with kattcss was essentially to make it easier and more hassle-free to use inuitcss in a whole lot of different projects, by primarily reducing the setup time. We've also made some minor changes, most of which have to do with consistency when it comes to class names, but we've also gone away from inuitcss' way to use multiple repositories to use one, single repository.

You can read more about the differences from inuitcss in the license file

In the future we want to build kattcss into something more of our own, and less of a bundle of different inuit modules, but we'll probably not stray too much from the architecture of inuitcss 5/itcss. We aim to keep kattcss as somewhat a living organism, that's extended and updated on a regular basis. kattcss, as well as this readme, is very much a work in progress, and we won't promise it won't break your heart.

Setting up a kattcss project

// Essential functions and settings
@import 'kattcss/collections/collections.core';

// Essential responsive functions and settings
@import 'kattcss/collections/collections.responsive';

// Settings and functions for a objects and trumps concerning
// layout and skin
@import 'kattcss/collections/collections.layout-skin';

// Import all generic files from kattcss
@import 'kattcss/collections/collections.generic';

@import 'kattcss/base/base.page';

@import 'kattcss/objects/objects.layout';

// Import your components
@import 'components.page-head';
@import 'components.page-foot';

// Import kattcss and inuitcss trumps
@import 'kattcss/trumps/trumps.widths';
@import 'kattcss/trumps/trumps.show-hide';

Import order

Borrowed from inuitcss' readme

Because inuitcss is broken apart into lots of small, composable modules, it is important that you as the developer piece things together in the correct order. That order is:

  • Settings: Global variables, site-wide settings, config switches, etc.
  • Tools: Site-wide mixins and functions.
  • Generic: Low-specificity, far-reaching rulesets (e.g. resets).
  • Base: Unclassed HTML elements (e.g. a {}, blockquote {}, address {}).
  • Objects: Objects, abstractions, and design patterns (e.g. .media {}).
  • Components: Discrete, complete chunks of UI (e.g. .carousel {}). This is the one layer that inuitcss doesn’t get involved with.
  • Trumps: High-specificity, very explicit selectors. Overrides and helper classes (e.g. .hidden {}).

The order of partials within each layer is fairly open; it is the sections themselves that are important to get in the correct order.

N.B. All partials—including your own—follow the <section>.<file> naming convention, e.g. _objects.box.scss, _components.carousel.scss.


Collections is a new concept introduced in kattcss: collections are modules that simply import other modules. They provide a great way to get started without having to dig deep into the framework for finding out what you might need for your project. All of the collection modules included in kattcss only import settings and tools, except the generic collection that imports all generic files, so most of the time you won't have to worry about including a collection and getting a lot of junk you might not need in your CSS.

Toggling modules

In inuitcss, the only way for a developer to completely disable a module is to not import it. In kattcss, you can import all modules provided, and if you'd later on feel the need to disable them, you can simply disable them by the module variables:

$katt-enable-module-trumps-show-hide: false;
$katt-enable-module-objects-buttons: false;

Variable index, settings

Variables in inuitcss are set up in each module; for example, for finding the variables for trumps.spacing, you need to navigate through your bower components to find the folder for trumps.spacing, and within there find the variables your searching for. In kattcss, we decided to keep all variables in settings files stored in the settings folder, to make it easier to find these.

Also included is an index of all variables that are used in kattcss:

kattcss/_vars.scss

This file is never to be included (even though it is safe for you to do so since the variables are tightly shut in an impossible if statement).

Module documentation

trumps.spacing

trumps.spacing contains helper classes for margins and paddings. By default, the margin and padding values ($katt-margin and $katt-padding) are based upon the $katt-base-spacing-unit.

The helpers are named m for margins, and p for paddings, with their classes prefixed with the utility prefix u-. They all come with a set of suffixes for the placement of the margin and padding helpers: t for top, r for right, b for bottom, l for left, h for horizontal, and v for vertical.

These suffixes can in turn be suffixed with how large the margin or padding should be: /4 for tiny margins and paddings, /2 for small, 0 for no margin or padding, 2 for large, and 4 for huge spacing.

The margin helpers can also be prefixed with n for negative margins.

The classes will in the end look like this (these are only a few examples, not a complete list):

  • .u-m - margin: $katt-margin
  • .u-mt - margin-top: $katt-margin
  • .u-mr - margin-right: $katt-margin
  • .u-mb - margin-bottom: $katt-margin
  • .u-ml - margin-left: $katt-margin
  • .u-mh - margin-left: $katt-margin; margin-right: $katt-margin;
  • .u-mv - margin-top: $katt-margin; $margin-top: $katt-margin;
  • .u-m/4 - margin: $katt-margin / 4
  • .u-mt/4 - margin-top: $katt-margin / 4
  • .u-mh/4 - margin-left: $katt-margin / 4; margin-right: $katt-margin / 4
  • .u-mr/2 - margin-right: $katt-margin / 2
  • .u-mv/2 - margin-top: $katt-margin / 2; margin-bottom: $katt-margin / 2
  • .u-m0 - margin: 0
  • .u-mb0 - margin-bottom: 0
  • .u-mt2 - margin-top: $katt-margin * 2
  • .u-mh2 - margin-left: $katt-margin * 2; margin-right: $katt-margin * 2
  • .u-m4 - margin: $katt-margin * 4
  • .u-ml4 - margin-left: $katt-margin * 4
  • .u-nm/4 - margin: -$katt-margin / 4
  • .u-nml - margin-left: -$katt-margin`
  • .u-nmh4 - margin-left: -$katt-margin * 4; margin-right: -$katt-margin * 4
  • .u-p - padding: $katt-padding
  • .u-pt - padding-top: $katt-padding
  • .u-pl/4 - padding-left: $katt-padding / 4
  • .u-pt/2 - padding-top: $katt-padding / 2
  • .u-pb0 - padding-bottom: 0
  • .u-pl2 - padding-left: $katt-padding * 2
  • .u-ph4 - padding-left: $katt-padding * 4; padding-right: $katt-padding * 4

All of these can also be suffixed with responsive aliases, to only use the helpers in specific breakpoints, such as:

  • .u-m/4-portable
  • .u-pt4-lap-and-up
  • .u-mt2-palm
  • .u-pl/2-desk
  • .u-p0-portable

The variables to enable these features of kattcss can be found in settings.spacing, or in vars