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

piedmont

v0.2.0

Published

Creates Living Styleguide from Frontend Prototype and its Source Files.

Downloads

47

Readme

Piedmont Build Status

Generate a Living Styleguide based on a Frontend Prototype.

Getting started

npm install piedmont --save-dev

Create Living Styleguide

var piedmont = require('piedmont');

piedmont(options, callback);

While the callback function isn't really used for now, you can omit the argument.

Options

cwd

Type: String Default value: __dirname

dest, src and styles are relative to the base path.

dest

Type: String Default value: './test/result/styling-guidelines'

Destination path of the generated living styleguide. Path is relative to cwd.

docs

Type: Boolean, String Default value: ./test/fixtures/docs

Source path of markdown files that will be parsed and converted to content pages. Piedmont uses a glob pattern to get the files: ./test/fixtures/docs/*.md.

Path is relative to cwd. See the Documents section for further details.

Set to false if creating a styleguide is not required.

inventory

Type: Boolean Default value: true

Building a component inventory based on the frontend prototype in the src directory. Set to false if creating a component inventory is not required.

src

Type: String Default value: './test/fixtures/build'

Path of the built frontend prototype. Path is relative to cwd.

styles

Type: Boolean, String Default value: './test/fixtures/styles'

Path to the annotated stylesheet files. Currently only Sass files are supported, so you have to specify the path only. Piedmont uses a glob pattern to get the files: ./src/sass/**/*.scss.

Path is relative to cwd.

Set to false if creating a styleguide is not required.

theme

Type: String Default value: './theme/default'

Path to the theme directory.

tmp

Type: String Default value: './tmp'

Temporary files directory.

Component Inventory

The component inventory (or interface inventory) is built on top of extracted partials. Partials are representations of components as markup.
Partials need to be wrapped in specific HTML comments. Where <!-- extract:Name of the partial --> intrduces a partial, <!-- endextract --> defines the end.

<!-- extract:Figure -->
<figure>
  <img src="http://placehold.it/640/480" alt="Unknown image content" width="640" height="480">
  <figcaption>
    <p>Random picture</p>
  </figcaption>  
</figure>
<!-- endextract -->

Properties (Options)

Properties are part of the introducing comments. Property name and value are separeated by colons: property:value. While colons are protected characters, property values must not contain them.
Most properties are single value properties, some properties have multiple values. Multiple values are separated by colons too: property:value A:value B.

category

Single value property. Sets the partial category.

<!-- extract:News teaser category:Teaser -->
...
<!-- endextract -->

<!-- extract:Event teaser category:Teaser -->
...
<!-- endextract -->

name

Single value property. Sets the partial name explicitly. Overrides the value of the extract property.

<!-- extract:A common partial name:A special partial -->
...
<!-- endextract -->

The partial name will be A special partial.

wrap

Multiple value property. For rendering purposes in the component inventory you might wrap the partial code in additional markup. While components should be independent of their context, it is necessary to show how they behave in several contexts, e.g. content sections in grid layout.

<!-- extract:Teaser wrap:<div class="row"><div class="col-8-of-12">:</div></div> -->
<article class="teaser">
  <h3 class="teaser__title">Arthurs Towel</h3>
  ...
</article>
<!-- endextract -->

<!-- extract:Teaser in Sidebar wrap:<div class="row"><div class="col-4-of-12">:</div></div> -->
<article class="teaser">
  <h3 class="teaser__title">Arthurs Towel</h3>
  ...
</article>
<!-- endextract -->

In both cases the partial code is the same. The markup that is used to render the component in the component inventory differs.

Teaser

<div class="row">
  <div class="col-6-of-9">
    <article class="teaser">
      <h3 class="teaser__title">Arthurs Towel</h3>
      ...
    </article>
  </div>
</div>

Teaser in Sidebar

<div class="row">
  <div class="col-3-of-9">
    <article class="teaser">
      <h3 class="teaser__title">Arthurs Towel</h3>
      ...
    </article>
  </div>
</div>

Styleguide

The styleguide section is based on annotated stylesheets.

General annotations

@value

Override the value that is extracted by the parser. This should be an option if the value is an expression or the value is not a digestable CSS property value.

/// @color Overlay background  
/// @value rgba(0, 0, 0, 0.6)  
$transparent-dark: transparentize($dark, 0.4);  

Specific annotations

@boxShadow

/// @boxShadow Dropshadow  
$dropshadow: 1px 2px 9px rgba(30, 30, 30, 0.3);   

@color

Color value. Use the optional @group to group colors. Groups might be Main, Decoration, Notice, Buttons, Transparencies, etc.

/// @color Primary
/// @group Main
$color-primary: rebeccapurple;   

@font

Single font name. Use @fontWeight to specify the available font weights.

/// @font FFDin
/// @fontWeight 300
/// @fontWeight 400
/// @fontWeight 700
$font-ffdin: FFDin;   

@fontFamily

Font family cascade.

/// @fontFamily Headline
$font-family: Times, "Times New Roman", serif;   

@fontSize

Font size value.

/// @fontSize Small
$font-size-meta: 1.4rem;

@gradient

Gradient type is specified in @type. Valid values are linear and radial.

/// @gradient Purple fade
$gradient-purple: linear-gradient(to bottom, rgba(102,51,153,1) 12%,rgba(102,51,153,0.5) 54%,rgba(222,71,172,0) 100%);

@lineHeight

Line height value.

/// @lineHeight Base
$base-line-height: 1.5;

@spacing

Spacing value. Use the optional @group to group spacings. Groups might be Layout, Component, Form, etc.

/// @spacing Base
/// @group Layout
$spacing-layout: 2rem;   

@timing

Duration of animations and transitions.

/// @timing Sluggish
$duration-sluggish: 1.4s;

@transition

Transition value.

/// @transition Fade
/// @value opacity 0.6s 0s ease
$transition-fade: opacity $duration-slow 0s ease;

Documents

Additional pages besides styleguide and component inventory will be created based on markdown files in the docs directory. The markdown documents will be converted to HTML via marked. These files will be converted to handlebars templates digestable by Assemble. While Piedmont does some parsing, you can override the poster data of the handlebars page template right in the markdown document. Possible values are

  • title: Document title and navigation label
  • class: Classname of the <body>
  • parent: Set another document as parent. The value equals the parents filename without extension.

An example of a poster is shown below. Assume the following page structure.

docs/
- engines.md
- rocket.md
- steam.md

The content of docs/rocket.md looks like:


---
title: Rockets are looking for the stars
class: 
parent: engines
---

# Those Rockets Are Looking For The Stars

...

Release History

(Nothing yet)

License

Copyright (c) 2015 Tilman Justen. Licensed under the MIT license.