Skip to content

Latest commit

 

History

History
63 lines (44 loc) · 4.65 KB

README.md

File metadata and controls

63 lines (44 loc) · 4.65 KB

postcss-squeaky-clean Build Status

A series of PostCSS plugins to transition global SCSS stylesheets into CSS modules

Overview

The main goal is to allow new features to be written like services, old features to be broken apart into smaller pieces which both allows for faster deliverables since dependencies and the affected surfaces will be clearer.

Additionally, note that the squeaky (namespaced) clean parser uses regex to replace classes such that the following patterns will generally be search/replaced:

  • class=whatever in a scss/css
  • js variable names like: <FOO>ClassName in javascript
  • (add|remove|toggle)Class in javascript, and any values in the string passed to these method calls will get converted

Additionally, the parser goes after:

  • klasses
  • className
  • _class

Temporary variable names

Also note, that in order for the parser / regex mechanism to work, it needs a pattern to match against. Thus, string interpolation in SCSS should be refactored in to explicit and exposed names; and in JS interpolation and similar should be broken out in to a helper method where the values have been exposed and put in to a temp variable with the suffix ClassName convention. All this may seem counter intuitive, but the goal is that all these styles will get removed and converted to localized and composed styles that are trackable within our dependency graph.

Goals

The end goal is to have all legacy stylesheets converted into CSS modules, complete with generic style names and explicit dependency chains. The extra namespacing in the stylesheets and additions to the DOM will eventually be cleaned up. Consider them to be "braces" for the codebase.

Road map

The namespacing described above is a technical walkthrough of what's considered Phase 1. The step following that is to flatten (i.e. remove the nesting) in the stylesheets to move them towards the CSS modules methodology that modern components follow (Phase 2). In doing so, the selectors need to be determined where they're actually used so heuristics are used to determine where the selectors are used (Phase 3). Finally, the namespaces can be cleaned up and the stylesheet is directly imported into the view files that use them (Phase 4).

All phases will be as automated as possible to allow for a straightforward transition between old global level code to compartmentalized components with dependency chains for a clear idea of where the files are used and allow for styles to be reused via CSS composition.

Why RegExps?

The academically inclined would point towards an AST for each file format to be able to properly target all class selectors. This would be costly for the following reasons:

  1. Number of file formats needed to be parsed
  2. Overhead to run + maintain + understand each of those parsers
  3. Additional parsing of class selectors from string tokens extracted from files

To balance delivering results and provide reasonable script runtime, regular expressions are leveraged and have served quite well for the features that have run and the heavy conventions that exist within the files. If performance ever becomes an issue, ASTs can be revisited.

Why bash in node?

You may have noticed that sprinkled within the node plugins, there are helpers that spawn bash shell commands to run logic that could've been done within node. The choice for this is to take advantage of the declarative, straight-forwardness of built in bash commands to handle a bulk of the heavy lifting in the plugins. The majority of the logic that bash is used for is to do find/replace within files which given the magnitude of files that can be touched allows for better performance than the context switch from spawning an external node process.

How can I use this?!

See the docs or example script!

What's up with the name?

The first iteration of this concept was to try to create a layout/environment for pages that was empty of style dependencies so that features could be built anew without any outside styling influence. There was a need to setup some reset/normalization styles which were needed to establish a "clean room". This plugin has been a second-wind approach to embodying the spirit of the previous attempt by trying to make layouts, even cleaner. Squeaky clean in fact!