Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: add Get started: Developers #1439

Merged
merged 16 commits into from
Apr 18, 2024
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ importElements:
- rh-subnav
- rh-tag
- rh-badge
- rh-code-block
---

{% include 'component/header.njk' %}
Expand All @@ -16,10 +17,11 @@ importElements:
<header class="l-main__header l-main__header--palette-lighter">
<div class="container header has-subnav">
<h1 id="{{ heading or title }}" class="page-title">{{ heading or title }}</h1>
<rh-subnav>{% for tab in collections.sortedColor %}
<a {{ 'active' if tab.url == page.url }} href="{{ tab.url }}">
{{ tab.data.title }}
</a>{% endfor %}
<rh-subnav>
{% for tab in collections.sortedColor %}
<a {{ 'active' if tab.url == page.url }} href="{{ tab.url }}">
{{ tab.data.title }}</a>
{% endfor %}
</rh-subnav>
</div>
</header>
Expand Down
7 changes: 7 additions & 0 deletions docs/_plugins/rhds.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -209,6 +209,13 @@ module.exports = function(eleventyConfig, { tagsToAlphabetize }) {
});
});

eleventyConfig.addCollection('sortedDevelopers', async function(collectionApi) {
const developersCollection = collectionApi.getFilteredByTags('developers');
return developersCollection.sort((a, b) => {
if (a.data.order > b.data.order) { return 1; } else if (a.data.order < b.data.order) { return -1; } else { return 0; }
});
});

eleventyConfig.addCollection('elementDocs', async function(collectionApi) {
const { pfeconfig } = eleventyConfig?.globalData ?? {};
/**
Expand Down
2 changes: 1 addition & 1 deletion docs/foundations/color/accessibility.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
layout: layout-foundations.njk
layout: layout-with-subnav.njk
title: Accessibility
heading: Color
tags:
Expand Down
2 changes: 1 addition & 1 deletion docs/foundations/color/index.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
layout: layout-foundations.njk
layout: layout-with-subnav.njk
title: Overview
heading: Color
tags:
Expand Down
2 changes: 1 addition & 1 deletion docs/foundations/color/usage.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
---
layout: layout-foundations.njk
layout: layout-with-subnav.njk
title: Usage
heading: Color
tags:
Expand Down
48 changes: 48 additions & 0 deletions docs/get-started/developers/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
---
layout: layout-with-subnav.njk
title: Overview
heading: Developers
tags:
- getstarted
- developers
permalink: /get-started/developers/index.html
order: 00
bodyClasses: element-docs
---

## Introduction

<!-- ADD CONTENT -->


## Learn about our design system

Our design system libraries and the documentation website offer assets and guidance needed to create digital experiences. Please use these resources to have a better understanding of how to use our design system.

<div class="multi-column--min-400-wide">
<div>
<h3>Foundations</h3>
<p><a href="foundations">Foundations</a> are how we express our brand through color, space, typography, etc.</p>
</div>
<div>
<h3>Design tokens</h3>
<p><a href="tokens">Design tokens</a> are how we translate our design language decisions into code.</p>
</div>
<div>
<h3>Documentation</h3>
<p>This website offers guidance about how to use our <a href="elements">elements</a> and <a href="patterns">patterns</a> correctly.</p>
</div>
<div>
<h3>GitHub repositories</h3>
<p>Explore our code, roadmaps, and discussions in the <a href="https://github.com/RedHat-UX/red-hat-design-system">Red Hat Design System repo</a> and the <a href="https://github.com/RedHat-UX/red-hat-design-tokens">Red Hat Design Tokens repo</a>.</p>
</div>
</div>

## About Web Components

<!-- ADD CONTENT -->

{% feedback %}
<h2>Designers</h2>
<p>To get started using our design system as a designer, go to the <a href="get-started/designers">Designers</a> page.</p>
{% endfeedback %}
116 changes: 116 additions & 0 deletions docs/get-started/developers/installation.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,116 @@
---
layout: layout-with-subnav.njk
title: Installation
heading: Developers
tags:
- developers
permalink: /get-started/developers/installation/index.html
order: 10
bodyClasses: element-docs
---

## How to install
marionnegp marked this conversation as resolved.
Show resolved Hide resolved

To develop components or design system documentation, you must first install some required software, namely node.js. We use [nvm](https://github.com/nvm-sh/nvm) to ensure a uniform development environment.

### Step 1: Install node

**Fedora/RHEL users** should install nvm for bash directly from GitHub.

<rh-code-block>
<script type="text/sample-javascript">
bennypowers marked this conversation as resolved.
Show resolved Hide resolved
curl https://raw.githubusercontent.com/creationix/nvm/master/install.sh | bash
</script>
</rh-code-block>

**Mac users** should install Homebrew. Go to the website or run this command (takes 5-10 minutes).

<rh-code-block>
<script type="text/sample-javascript">
/bin/bash -c "$(curl -fsSL
https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
</script>
</rh-code-block>
bennypowers marked this conversation as resolved.
Show resolved Hide resolved

Then use that to install `nvm`:

<rh-code-block>
<script type="text/sample-javascript">
brew install nvm
</script>
</rh-code-block>

### Step 2: Clone the repository

Clone the repository and change the directory to it:

<rh-code-block>
<script type="text/sample-javascript">
git clone [email protected]:redhat-ux/red-hat-design-system
cd red-hat-design-system
</script>
</rh-code-block>

### Step 3: Install dependencies

Install the right node version using `nvm`, then install the `node_modules` dependencies:

<rh-code-block>
<script type="text/sample-javascript">
nvm use
npm ci
</script>
</rh-code-block>

## How to generate an element

Run the following command to begin the scaffolding process:

<rh-code-block>
<script type="text/sample-javascript">
npm run new
</script>
</rh-code-block>

The generator will prompt you for the following:

What is the element tag name?

- Your element should be lower case and needs to contain at least one hyphen to adhere to the [Custom Elements](https://html.spec.whatwg.org/multipage/custom-elements.html) standard naming convention.
- Red Hat Design System elements should begin prefixed by `rh-`. However if you are creating an element for use outside this project prefix your element as you see fit.

After answering the script will generate a bootstrapped element in the `elements/your-element` directory complete with a`demo` and `test` directory.

## Run the dev server

Run the dev server to develop components:

<rh-code-block>
<script type="text/sample-javascript">
npm start
</script>
</rh-code-block>

This starts a local dev server at http://localhost:8000 and the 11ty dev server for the docs site at http://localhost:8080. Your changes will automatically refresh the browser window.

To run only the components dev server, first run the build, and then run the dev server:

<rh-code-block>
<script type="text/sample-javascript">
npm-run-dev
</script>
</rh-code-block>

To run only the docs dev server, first run the build, then 11ty:

<rh-code-block>
<script type="text/sample-javascript">
npm run build
npx eleventy --serve --incremental
</script>
</rh-code-block>

{% feedback %}
<h2>Designers</h2>
<p>To get started using our design system as a designer, go to the <a href="get-started/designers">Designers</a> page.</p>
{% endfeedback %}
154 changes: 154 additions & 0 deletions docs/get-started/developers/tokens.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,154 @@
---
layout: layout-with-subnav.njk
title: Tokens
heading: Developers
tags:
- developers
permalink: /get-started/developers/tokens/index.html
order: 30
bodyClasses: element-docs
---

## How to install tokens

Run the following git command to install RHDS tokens:

<rh-code-block>
<script type="text/sample-javascript">
npm i @rhds/tokens
</script>
</rh-code-block>

## Usage

We use [style-dictionary](https://amzn.github.io/style-dictionary/) to transform our tokens into multiple formats and helpers.

### Import global CSS

Apply defaults to the document root by importing the global stylesheet:

<rh-code-block>
<script type="text/html">
<link rel="stylesheet" href="/url/to/@rhds/tokens/css/global.css">
<style>
:is(h1, h2, h3, h4, h5, h6) {
font-family: var(--rh-font-family-heading);
}
</style>
</script>
</rh-code-block>

### Reset the shadowroot

Reset a component's styles (preventing inheritance) by adding resetStyles to its static Constructible Style Sheet list:

<rh-code-block>
<script type="text/sample-javascript">
import { resetStyles } from '@rhds/tokens/css/reset.css.js';
import style from './rh-jazz-hands.css';

@customElement('rh-jazz-hands')
export class RhJazzHands extends LitElement {
static readonly styles = [resetStyles, style];
marionnegp marked this conversation as resolved.
Show resolved Hide resolved
}
</script>
</rh-code-block>

### Import tokens as JavaScript objects

{% alert title="Note", state="info" %}
We strongly recommend using CSS variables (and accompanying snippets), instead of importing tokens as JavaScript objects.
{% endalert %}

Import tokens as JavaScript objects:

<rh-code-block>
<script type="text/sample-javascript">
import { tokens } from '@rhds/tokens';

html`<span style="color: ${tokens.get('--rh-color-blue-300')}">I'm blue</span>`;
</script>
</rh-code-block>

or for tree-shakable imports:

<rh-code-block>
<script type="text/sample-javascript">
import { ColorBlue300 } from '@rhds/tokens/values.js';

html`<span style="color: ${ColorBlue300}">I'm blue</span>`;
</script>
</rh-code-block>

## Plugins

### Using editor snippets

Editor snippets complete prefixes like `--rh-color-brand` to their CSS custom properties, complete with fallback.
bennypowers marked this conversation as resolved.
Show resolved Hide resolved

<rh-code-block>
<script type="text/css">
color: var(--rh-color-brand, #ee0000);
</script>
</rh-code-block>

They also provide reverse lookup. For example, if you want to choose between all the tokens with the value `#e00`, you can do so by completing the prefix `e00`.

#### Load snippets in VSCode

Download the VSIX bundle that’s linked at the bottom of our [“Release v1.0.0”](https://github.com/RedHat-UX/red-hat-design-tokens/releases/tag/v1.0.0) page.
bennypowers marked this conversation as resolved.
Show resolved Hide resolved

#### Load snippets in Neovim

Use LunaSnip to load snippets in Neovim:
bennypowers marked this conversation as resolved.
Show resolved Hide resolved

<rh-code-block>
<script type="text/sample-javascript">
require 'luasnip.loaders.from_vscode'.lazy_load { paths = {
-- Path to the built project, perhaps in your `node_modules`
'~/Developer/redhat-ux/red-hat-design-tokens/editor/vscode'
} }
</script>
</rh-code-block>

### Stylelint plugin

Install the stylelint plugin to automatically correct token values in your files.

See the [Stylelint Plugin README](https://github.com/RedHat-UX/red-hat-design-tokens/blob/main/plugins/stylelint/README.md) for more info.

### 11ty plugin

The experimental 11ty plugin lets you display token values in an 11ty site.

### vim-hexokinase

Vim users can load the [vim-hexokinase](https://github.com/RRethy/vim-hexokinase) plugin to display color swatches next to their encoded values in their editor.

Use the following config (lua syntax, for Neovim users) to configure hexokinase to display color values next to color aliases like `{color.brand.red}`.

<rh-code-block>
<script type="text/sample-javascript">
vim.g.Hexokinase_optInPatterns = {
'full_hex', 'triple_hex',
'rgb', 'rgba',
'hsl', 'hsla',
'colour_names',
}

vim.g.Hexokinase_ftOptOutPatterns = {
json = { 'colour_names' },
yaml = { 'colour_names' },
}

vim.g.Hexokinase_palettes = {
-- replace with path to the built tokens package on your drive
vim.fn.expand'~/Developer/redhat-ux/red-hat-design-tokens/editor/neovim/hexokinase.json'
}
</script>
</rh-code-block>

{% feedback %}
<h2>Designers</h2>
<p>To get started using our design system as a designer, go to the <a href="get-started/designers">Designers</a> page.</p>
{% endfeedback %}
Loading
Loading