Thank you for contributing!
Spectacle is actively maintained by @carlos-kelly and @kale-stew from within @FormidableLabs.
We prefer to use yarn
.
Install all dependencies by running:
$ yarn
Our examples are spread out across multiple projects depending on where the core technology lies. We publish most of these to npm
for use in spectacle-cli
project to either use with the CLI (spectacle
) or generate a fresh project boilerplate (spectacle-boilerplate
).
spectacle
spectacle-mdx-loader
spectacle-cli
examples/cli-mdx-babel
: Not published
We have various deck scenarios in examples
in this repository that are part of the development process.
We follow the convention of start:NAME
to run an in-memory dev server for a specific
example, but we also have a yarn build-examples
script task to make sure we're actually
producing non-broken sample presentations as a CI / assurance test.
A basic deck with JSX and JavaScript:
# start the dev server
$ yarn start:js
# open the browser
$ open http://localhost:3000/
Note: The files index.{js,html}
, slides.md
are published and used by spectacle-cli
.
A basic deck written in markdown:
# In one terminal open dev server
$ yarn start:md
# In another open a browser to 3100
$ open http://localhost:3100/
Note: The files index.{js,html}
, slides.md
are published and used by spectacle-cli
.
A self-contained single web page that uses Spectacle, React, and htm
for a "no build" presentation!
# [optional] build the library -
# comment out the unpkg dependency in
# one-page.html and use the local dist/
$ yarn build
# open the browser
$ open examples/one-page.html
or use the single line:
$ yarn start:one-page
Note: This file is published and used by spectacle-cli
.
Development Note: This JS code portion of this file is programmatically updated from the source in examples/js/index.js
directly into one-page.html
. Rather than editing directly, please run yarn build-one-page
and verify changes look good.
spectacle-cli
uses our js,md,one-page
examples in the CLI and boilerplate tools. To check that changes to these files don't break spectacle-cli
upstream, check with something like the following:
# In `spectacle` repo
$ yarn link
# In `spectacle-cli` repo
$ yarn link spectacle
# Check all MDX, MD examples per https://github.com/FormidableLabs/spectacle-cli/blob/main/CONTRIBUTING.md#examples
$ yarn start:examples
# (In another shell) Check mdx:5000, mdx+babel:5001, md:5100
$ open http://localhost:5000/ http://localhost:5001/ http://localhost:5100/
# Check all JS, MDX, MD boilerplates per https://github.com/FormidableLabs/spectacle-cli/blob/main/CONTRIBUTING.md#boilerplate
$ yarn clean:boilerplate
$ yarn boilerplate:generate
$ yarn boilerplate:install
$ yarn start:boilerplate
# (In another shell) Check mdx:6300, md:6100, js:6200
#
# **Note**: These `yarn install` internally so will use latest published
# `spectacle`, so results may be not entirely accurage. You may need to manually
# update the installed contents in generated project `node_modules`.
$ open http://localhost:6300/ http://localhost:6100/ http://localhost:6200/
To run all tests:
$ yarn test
To check (and fix) code:
$ yarn lint
$ yarn lint-fix
To check (and fix) formatting of MD, JSON, and code:
$ yarn prettier-check
$ yarn prettier-fix
We also have a simple one-liner for running both of these fix-checks back-to-back:
$ yarn format
Note that there is duplication for JS code in prettier
doing the same style changes,
but both should be harmonious and run together.
Thanks for taking the time to help us make Spectacle even better! Before you go ahead and submit a PR, make sure that you have done the following:
- Run all checks using
yarn check-ci
. - Run
yarn build-one-page
and check + commit changes toexamples/one-page.html
- Check that both the core library and all examples build:
yarn build && yarn build-examples
. - Update the type definitions for anything that modifies the Spectacle API, like breaking changes or new features.
- Everything else included in our pull request checklist.
Only for project administrators
# (1) Update the Changelog, following format from previous versions
# and commit those changes independently of other updates
$ git add CHANGELOG.md && git commit -m "Changes for v<version>"
# (2) Run tests, lint, build published dir, update package.json
$ npm version [patch|minor|major|<version>]
# (3) If all is well, publish the new version to the npm registry
$ npm publish
# (4) Then, update github with the associated tag
$ git push --tags && git push
Then, go and manually draft a release for your recently pushed tag with notes in the Github UI.
In the interest of fostering an open and welcoming environment, we as contributors and maintainers pledge to making participation in our project and our community a harassment-free experience for everyone, regardless of age, body size, disability, ethnicity, gender identity and expression, level of experience, nationality, personal appearance, race, religion, or sexual identity and orientation.
Examples of behavior that contributes to creating a positive environment include:
- Using welcoming and inclusive language
- Being respectful of differing viewpoints and experiences
- Gracefully accepting constructive criticism
- Focusing on what is best for the community
- Showing empathy towards other community members
Examples of unacceptable behavior by participants include:
- The use of sexualized language or imagery and unwelcome sexual attention or advances
- Trolling, insulting/derogatory comments, and personal or political attacks
- Public or private harassment
- Publishing others' private information, such as a physical or electronic address, without explicit permission
- Other conduct which could reasonably be considered inappropriate in a professional setting
Project maintainers are responsible for clarifying the standards of acceptable behavior and are expected to take appropriate and fair corrective action in response to any instances of unacceptable behavior.
Project maintainers have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, or to ban temporarily or permanently any contributor for other behaviors that they deem inappropriate, threatening, offensive, or harmful.
This Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or its community. Examples of representing a project or community include using an official project e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event. Representation of a project may be further defined and clarified by project maintainers.
Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by contacting the project team at [email protected]. All complaints will be reviewed and investigated and will result in a response that is deemed necessary and appropriate to the circumstances. The project team is obligated to maintain confidentiality with regard to the reporter of an incident. Further details of specific enforcement policies may be posted separately.
Project maintainers who do not follow or enforce the Code of Conduct in good faith may face temporary or permanent repercussions as determined by other members of the project's leadership.
This Code of Conduct is adapted from the Contributor Covenant, version 2.0, available at https://www.contributor-covenant.org/version/2/0