@striblab/generator-striblab
v1.2.0
Published
Project generators for the Star Tribune newsroom projects
Downloads
35
Keywords
Readme
Strib Lab Generators
Yeoman-based project generators for (some of) the Star Tribune newsroom projects.
Install
- Install NodeJS.
- On a Mac, install Homebrew and do:
brew install node
- Make sure you are using the latest version of Node 8 or later.
- On a Mac, install Homebrew and do:
- Install Yeoman, and Gulp command line tools:
npm install -g yo gulp-cli
- Install generator:
npm install -g @striblab/generator-striblab
Usage
- Make a new directory and enter it:
mkdir new-project && cd new-project
- (Recommended, but not necessary) Create a repo on Github first and check that out.
- Run Yeoman:
yo
- It is suggested to use just
yo
, since it will tell you if a new version of a generator is available. - If you are creating a new series-article project, use the command
yo @striblab/striblab:series
to generate that scaffolding.
- It is suggested to use just
- Answer questions and wait for install to finish up.
- A
README.md
will be generated describing the project and its parts.
yo @striblab/striblab Questions
When answering the questions, you may see something like the following right after the question: (my-project)
. This is the default value for the question and if you just hit Enter, then this value will be used.
Name: The identifier for the project. This should be similar to the folder name that project is in, ideally all lowercase and using hyphens, no spaces. This gets used when publishing up to S3.
Title: The title of the project. This is used as default metadata fora project which is important for standalone projects.
Description: Description of the project. Same use as Title.
Author name: This is pulled from your Git config by default. This is put into the
package.json
and put into default metadata.Author email: This is pulled from your Git config by default. This is put into the
package.json
.Type of project:
- A standalone embed is a bundled up project without external dependencies meant to be embedded in an article with an iframe.
- The CMS integration version changes the way the application gets hosted to work with the Star Tribune CMS and focuses on creating JS, CSS, and other supporting assets.
For CMS integration projects:
- Strib Styles selector: The custom selector to use with Strib Styles. This ensures that any Strib Styles or project styles won't affect the site styles.
- CMS IDs: List of CMS article IDs that the project will publish to. This can be left blank and filled in later.
- CMS LCD IDs: List of CMS article IDs that the project will publish to. This can be left blank and filled in later.
Data analysis templates: Whether or not to include the data analysis templates, which is a folder for data analysis and an example Drake workflow file.
yo @striblab/striblab:series Questions
The series-article workflow is now a subgenerator within generator-striblab. This means that you won't be able to access it directly by simply using the command yo
. Generate scaffolding for a series-article project by using this command: yo @striblab/striblab:series
. You'll be prompted to answer a few questions:
- Project Name: The name of the project. This defaults to the name of the enclosing folder.
- Description: A short description of the project. This will get put in the README.md.
- Article ID(s): Clickability Article IDs for the project. This will be put in
./ids.txt
to make it easier to keep track of past projects. - LCD ID(s): Clickability LCD IDs for the project. This value will also be put in
./ids.txt
, making it easier to track down old LCDs.
Outside of that, the series-article workflow works exactly the same as before. You'll still need to generate your own LCD fields in Clickability and copy/paste your content manually.
More documentation on the series-article structure lives in the README.md of your project.
Development
- Get this codebase:
git clone https://github.com/striblab/generator-striblab.git && cd generator-striblab
- Install dependencies and link:
npm install && npm link
Each directory is a template, while files in common/
are used across templates.
Testing
Automated testing can be run with the following command. Note that it will take a minute, since it runs and builds the whole project.
npm run test
Manual testing can be done with these helpful commands.
- Make directory and install:
mkdir -p generator-test && cd generator-test && yo "@striblab/striblab"
; - Re-install (assumes the previous step was done and you are in that directory):
cd ..; rm -rv generator-test && mkdir -p generator-test && cd generator-test && yo "@striblab/striblab"
- Debug:
cd ..; rm -rv generator-test && mkdir generator-test && cd generator-test && DEBUG=yeoman:* yo "@striblab/striblab"
- Debug:
Publishing
Publish to npm.
- Run tests, and do manual testing as the automated tests are very basic.
- Update version,
X.X.X
, inpackage.json
and then runnpm install
- Commit changes, i.e.
git commit -m "Updated version."
- Tag with the same version number:
git tag X.X.X
- Push up to Github:
git push origin --tags
- Publish to npm:
npm publish --access public
Credits
Favicons
Favicons for front-end template generated manually with Real Favicon Generator.