/gatsby-remark-design-system

🎨 Create your design system with Gatsby in Markdown

Primary LanguageJavaScriptMIT LicenseMIT

GitHub license npm package LekoArts Homepage

gatsby-remark-design-system

🎨 Create your design system with Gatsby in Markdown

See it live in action! You can also have a look at the example repo.

Scope of this plugin

gatsby-remark-design-system (inspired by Catalog) is a plugin that sits on top of Gatsby's remark transformer. You'll need to setup a Gatsby project and install at least the plugins gatsby-source-filesystem, gatsby-transformer-remark and gatsby-plugin-sass. You then can use the so called Specimens in your markdown files to create your design system or styleguide.

Writing content in markdown is easy and so should be creating a design system. Including this plugin into your project will help you create a design system from scratch in no time - and you can also include other plugins, e.g. gatsby-remark-prismjs to have syntax highlighted code.

Install

npm install gatsby-remark-design-system

How to use

Note: If you're unsure about the instructions take a look at the implementation of the example repo!

// In your gatsby-config.js
plugins: [
  {
    resolve: 'gatsby-transformer-remark',
    options: {
      plugins: [
        {
          resolve: 'gatsby-remark-design-system',
          options: {
            // Class prefix for all elements of the design system specimens
            // This prefix also needs to be set on wrapper components in your Gatsby project
            // Default value is 'grds' - so if you want you can leave out this option entirely
            classPrefix: 'grds',
          }
        }
      ],
    },
  },
],

Include CSS

The plugin ships with a theme that you can easily include in your Gatsby project, or you can build your own theme by copying and modyfing the example. To load the theme, just require its SCSS, e.g.

// layouts/index.js
require('gatsby-remark-design-system/theme/gatsby-remark-design-system-theme.scss');

If you just want to change the classPrefix or other SCSS variables (but otherwise want to use the preconfigured theme) you should overwrite the variables like so:

// Create a empty scss file that gets imported into your project (e.g. base.scss)

$prefix: cool;
$primary: #c93a3c;

// Import your other scss files if necessary
// .......

// Import the theme
@import '~gatsby-remark-design-system/theme/gatsby-remark-design-system-theme.scss';

Specimens

You can use the specimens by using three backticks followed by the name. The content of the specimen then gets defined in the code block.

```name|option
content
```

Audio

Options

autoplay: boolean Default: false loop: boolean Default: false name: string span: number[1-6] Width of the specimen src: string The path/url to the file. Needs to be in quotes

Example

```audio
autoplay: false
loop: false
name: Sound File #1
src: "/sound.mp3"
span: 3
```

Color

Options

color: string Define the color (in HEX, e.g. #b0f6ff) name: string

Example

```color
name: Smaragd
color: #939d7b
```

Color-Palette

Options

name: string, color: string Each line represents a color. First define the name then after a comma the HEX value

Example

```color-palette
T400 - Shabby, #448c6c
T300 - Legendary, #dca114
T200 - Smoke, #6c3b0b
```

Download

Options

color: string Define the background color (in HEX, e.g. white) of the preview box image: boolean If true the image will be shown below span: number[1-6] Width of the specimen src: string The path/url to the file. Needs to be in quotes subtitle: string The filesize or other information title: string width: string The width of the preview image (default: 200px)

Example

```download
color: white
image: true
span: 3
src: "/logo.png"
subtitle: 8KB
title: Avatar Social
width: 250px
```

Example

Options

None

Example

```example
<button>You can insert your HTML here</button>
```

Hint

Options

directive Green, positive note for showing Dos warning Red, warning note for showing Don'ts neutral Neutral note (Default)

Example

```hint|directive
Make it so!
```

```hint
Neutral Hint
```

```hint|warning
nooooooooo, not this way
```

Typography

Options

size: number|weight: number|metrics: string|weightDesc: string|usage: string Each line represents a type. You have to define the values in the mentioned order and seperate with |

Example

```typography
42|700|Display|42, line height is 1.1x|Bold, 700|Display type is used for visual impact and emphasis
32|400|Page title|32, line height is 1.1x|Normal, 400|Page title is used to provide hiearchy
```

Video

Options

autoplay: boolean Default: false loop: boolean Default: false muted: boolean Default: false name: string src: string The path/url to the file. Needs to be in quotes

Example

```video
autoplay: false
loop: false
muted: false
name: Animation Video
src: "https://www.w3schools.com/html/mov_bbb.mp4"
span: 3
```