Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/willmendesneto/generator-poi


https://github.com/willmendesneto/generator-poi

Last synced: about 2 months ago
JSON representation

Awesome Lists containing this project

README

        

# PoiJS - Yeoman generator

[![Greenkeeper badge](https://badges.greenkeeper.io/willmendesneto/generator-poi.svg)](https://greenkeeper.io/)
[![npm version](https://badge.fury.io/js/generator-poi.svg)](http://badge.fury.io/js/generator-poi) [![npm downloads](https://img.shields.io/npm/dm/generator-poi.svg)](https://npmjs.org/generator-poi)

[![Build Status](https://travis-ci.org/willmendesneto/generator-poi.svg?branch=master)](https://travis-ci.org/willmendesneto/generator-poi)
[![Dependency Status](https://david-dm.org/willmendesneto/generator-poi.svg)](https://david-dm.org/willmendesneto/generator-poi)

[![NPM](https://nodei.co/npm/generator-poi.png?downloads=true&downloadRank=true&stars=true)](https://npmjs.org/generator-poi)
[![NPM](https://nodei.co/npm-dl/generator-poi.png?height=3&months=3)](https://npmjs.org/generator-poi)

![Yeoman](./assets/yeoman-masthead.png)

This is a yo generator for building react frontend components. Install it, run it and start building components!

For information on the project it generates, see _[About This
Project](/app/templates/README.md#about-this-project)_.

## How to use

[Make sure you are using `npm@>=5.2.0`](https://docs.npmjs.com/getting-started/installing-node)

```
npm install -g yo generator-poi
mkdir co-my-component && cd co-my-component
yo poi
```

_[`yarn` failing?](#yarn-failing)_

Then answer the questions truthfully (_it'll know if you're lying_)

#### Update your boilerplate

> Repositories built with `generator-poi`
> can be upgraded to the latest version via CLI using the [NPM package `update-yeoman-generator`](https://github.com/willmendesneto/update-yeoman-generator). 🚀

Make sure you have `npm@>=5.2.0`:

```
npm install -g npm@latest
```

After that, install [NPM package `update-yeoman-generator`](https://github.com/willmendesneto/update-yeoman-generator) globally

```
npm install -g update-yeoman-generator
```

Inside the existing boilerplate generated repository run this command:

```
update-yeoman-generator --generator willmendesneto/generator-poi \
--github-token \
--ejs-open 0_- \
--ejs-close -_0
```

`update-yeoman-generator` command will apply the changes from the latest version of boilerplate as a git style merge - so you'll still need to manually fix conflicts. If you want to understand the reasons why you should pass specific parameters, please check [`update-yeoman-generator` README.md](<(https://github.com/willmendesneto/update-yeoman-generator)>) with all the options.

## Editing the generator

To create a template file whos filename is replaced by one of the user-entered
variables, use the delimiters `_-` and `-_` instead of the ejs style `<%` and
`%>` (`<` and `>` are not allowed on Windows).

## Code architecture

Here is a selection of the interesting parts:


.
├── .nvmrc
├── .editorconfig
├── CHANGELOG.md
├── src
│   ├── js
│   | ├── components
│   │   │   ├── component-name.js
│   ├── scss
│   │ └── styles.scss
│   ├── export.js
└── test
└── *.js

#### `CHANGELOG.md`

> The purpose of a commit is to document one atomic step in the process by which
> the code evolves from one state to another.
> The purpose of a change log is to document the noteworthy differences between
> these states.

> As is the difference between good comments and the code itself,
> so is the difference between a change log and the commit log:
> one describes the why,
> the other the how.

- _[keepachangelog.com](http://keepachangelog.com/)_

Keep a log of the significant changes in this file under the `Unreleased`
heading,
and tooling will ensure it's versioned.

#### `src/js/components/component-name.js`

This is the main component of this module. If your module exports multiple
components, edit a copy of this file, and add that export to `export.js`.

#### `src/js/export.js`

This is the export of the module. Usually is a simple import/export to
expose any components this module may contain.

#### `src/scss/`

Contains all the style info for this component.

`styles.scss` is the entry point for the main stylesheet associated with this
component. This entry point is the equivalent to both the `export.js` and
`index.js` but for styles, rolled into one (due to the way sass works).

Styling is split up into _helpers_, and logical groupings, where each grouping
has their own _structure_, and _state_:

```
└── scss
├── styles.scss
├── _variables.scss (or _mixins.scss or other "helpers")
├── some-grouping
│ ├── _some-grouping-structure.scss
│ └── _some-grouping-state.scss
└── another-group
├── _another-group-structure.scss
└── _another-group-state.scss
```

The groupings follow the naming pattern:

`-structure.scss`: The BEM named styles that setup the base visuals for the
component.
`-state.scss`: For classes that are used when states change within the
component (eg; `.is-selected`, `.is-active`, etc).

The _helpers_ are the things which don't really fall into the groupings.

#### `test/*.js`

Start writing your tests here. You can make multiple files in this folder, and
they will all be executed.

### `yarn` failing?

Make sure you're on the [latest version of `yarn`](https://yarnpkg.com/en/docs/install).

You may be seeing a 404 error, something along the lines of:

```
error An unexpected error occurred: "https://registry.yarnpkg.com/@{ORG}/{PACKAGE}/-/{PACKAGE}-1.0.0.tgz: Request failed \"404 Not Found\"".
```

Try out [these steps](https://github.com/yarnpkg/yarn/issues/521#issuecomment-280565157) to fix things:

```shell
npm logout
yarn logout

mv ~/.npmrc ~/.npmrc.bak
mv ~/.yarnrc ~/.yarnrc.bak

npm login
yarn login
```

## Code Coverage

The [nyc](https://github.com/istanbuljs/nyc) command-line-client for Istanbul has been setup.
It will run by default while running tests but minimum coverage is not enforced (as it defaults to 0).
You can also see full html coverage reports by running:

```shell
yarn run coverage
or
npm run coverage
```

To enforce coverage on the component, edit the `nyc` section in the `package.json` file
and include the minimum `lines`, `statements`, `functions` and `branches` values.
See [Configuring nyc](https://github.com/istanbuljs/nyc#configuring-nyc) for more info.

## Publishing the package

This project is using `np` as publisher helper. For more information, please check [`np` documentation](https://github.com/sindresorhus/np#readme)

## Changes

See [CHANGELOG.md](./CHANGELOG.md).

## Author

**Wilson Mendes (willmendesneto)**

-
-
-