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

[CSS-in-JS] [Breaking] Better Getting Started page #5299

Merged
Merged
Show file tree
Hide file tree
Changes from all 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
27 changes: 7 additions & 20 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,25 +2,13 @@

# Elastic UI Framework

> The Elastic UI Framework is a collection of React UI components for quickly building user interfaces
> at Elastic. Not using React? No problem! You can still use the CSS behind each component.
> The Elastic UI Framework is a collection of React UI components for quickly building user interfaces at Elastic.

You should check out our [living style guide][docs], which contains many examples of components in the EUI framework aesthetic, and how to use them in your products. We also have a [FAQ][faq] that covers common usage questions.
## Installation and usage

## Installation

To install the Elastic UI Framework into an existing project, use the `yarn` CLI (`npm` is not supported).

```
yarn add @elastic/eui
```

Note that EUI has [several `peerDependencies` requirements](package.json) that will also need to be installed if starting with a blank project. You can read more about other ways to [consume EUI][consuming].

```
yarn add @elastic/eui @elastic/datemath moment prop-types
```
You should check out our [living style guide][docs], which contains project installation instructions, theming details, and many examples of all the EUI components and how to use them in your products. We also have a [FAQ][faq] that covers common usage questions. You can read more about the ways to [consume EUI][consuming].

The rest of this doc will detail how to run and contribute to the **EUI documentation** site locally.

## Running Locally

Expand All @@ -32,22 +20,22 @@ You will probably want to install a node version manager. [nvm](https://github.c

To install and use the correct node version with `nvm`:

```
```bash
nvm install
```

### Documentation

You can run the documentation locally at [http://localhost:8030/](http://localhost:8030/) by running the following.

```
```bash
yarn
yarn start
```

If another process is already listening on port 8030, the next free port will be used. Alternatively, you can specify a port:

```
```bash
yarn start --port 9000
```

Expand Down Expand Up @@ -76,7 +64,6 @@ directly in the code. And unit test coverage for the UI components allows us to
* [Creating components manually](wiki/creating-components-manually.md)
* [Creating components with Yeoman](wiki/creating-components-yeoman.md)
* [Creating icons](wiki/creating-icons.md)
* [Theming](wiki/theming.md)
* [Testing](wiki/testing.md)
* [Accessibility Testing](wiki/automated-accessibility-testing.md)
* [Documentation](wiki/documentation-guidelines.md)
Expand Down
17 changes: 8 additions & 9 deletions src-docs/src/routes.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { EuiErrorBoundary } from '../../src/components';
import { playgroundCreator } from './services/playground';

// Guidelines
const GettingStarted = require('!!raw-loader!./views/guidelines/getting_started.md');
import { GettingStarted } from './views/guidelines/getting_started/getting_started';

import AccessibilityGuidelines from './views/guidelines/accessibility';

Expand Down Expand Up @@ -305,8 +305,9 @@ const createExample = (example, customTitle) => {
};
};

const createMarkdownExample = (example, title) => {
const headings = example.default.match(/^(##) (.*)/gm);
// eslint-disable-next-line @typescript-eslint/no-unused-vars
const createMarkdownExample = ({ file, name, intro }) => {
const headings = file.default.match(/^(##) (.*)/gm);

const sections = headings.map((heading) => {
const title = heading.replace('## ', '');
Expand All @@ -315,12 +316,10 @@ const createMarkdownExample = (example, title) => {
});

return {
name: title,
name,
component: () => (
<GuidePage title={title}>
<GuideMarkdownFormat grow={false}>
{example.default}
</GuideMarkdownFormat>
<GuidePage title={name}>
<GuideMarkdownFormat grow={false}>{file.default}</GuideMarkdownFormat>
</GuidePage>
),
sections: sections,
Expand All @@ -331,7 +330,7 @@ const navigation = [
{
name: 'Guidelines',
items: [
createMarkdownExample(GettingStarted, 'Getting started'),
createExample(GettingStarted, 'Getting started'),
createExample(AccessibilityGuidelines, 'Accessibility'),
{
name: 'Colors',
Expand Down
11 changes: 6 additions & 5 deletions src-docs/src/views/guidelines/_get_sass_vars.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import lightColors from '!!sass-vars-to-js-loader!../../../../src/global_styling/variables/_colors.scss';
import lightColors from '!!sass-vars-to-js-loader!../../../../src/themes/legacy/_colors_light.scss';
import darkColors from '!!sass-vars-to-js-loader!../../../../src/themes/legacy/_colors_dark.scss';
import lightAmsterdamColors from '!!sass-vars-to-js-loader!../../../../src/themes/amsterdam/_colors_light.scss';
import darkAmsterdamColors from '!!sass-vars-to-js-loader!../../../../src/themes/amsterdam/_colors_dark.scss';
import visColors from '!!sass-vars-to-js-loader!../../../../src/global_styling/variables/_colors_vis.scss';
import { useContext } from 'react';
import { ThemeContext } from '../../components';
import { LEGACY_NAME_KEY } from '../../../../src/themes';
Expand All @@ -11,16 +12,16 @@ export const useSassVars = () => {
let palette;
switch (themeContext.theme) {
case `${LEGACY_NAME_KEY}_light`:
palette = lightColors;
palette = { ...lightColors, ...visColors };
break;
case `${LEGACY_NAME_KEY}_dark`:
palette = { ...lightColors, ...darkColors };
palette = { ...darkColors, ...visColors };
break;
case 'dark':
palette = { ...lightColors, ...darkColors, ...darkAmsterdamColors };
palette = { ...darkAmsterdamColors, ...visColors };
break;
default:
palette = { ...lightColors, ...lightAmsterdamColors };
palette = { ...lightAmsterdamColors, ...visColors };
break;
}

Expand Down
252 changes: 0 additions & 252 deletions src-docs/src/views/guidelines/getting_started.md

This file was deleted.

Loading