Skip to content

Latest commit

 

History

History
63 lines (46 loc) · 2.31 KB

README.md

File metadata and controls

63 lines (46 loc) · 2.31 KB

Sphinx-Doc theme for Crafter CMS

This repo contains the necessary assets to develop and deploy the python package that powers the Crafter CMS Sphinx Docs theme.

A Gulp-powered build helps local development without make html to view the every change, making it easier to work on the front end of the theme. This system as the following features:

  • Handlebars HTML templates with Panini
  • Sass compilation and prefixing
  • JavaScript module bundling with webpack
  • Built-in BrowserSync server
  • For production builds:
    • CSS compression
    • JavaScript compression
    • Image compression

Local Theme Development

Prerequisites

To use this, you need:

  • NodeJS (0.12 or greater)
  • Git
  • Yarn
  • Python, twine and pip
  • Foundation cli: yarn global add foundation-cli
  • Run yarn to initialize the project (FYI. this is the equivalent to npm install in the yarn world)

Running the dev server

Run foundation watch

Development

The above will start the dev server and watch for changes. The important files to get started and understanding are src/layouts/default.html and src/pages/index.html. These two are the markup that renders what you see as soon as you run the watch. Index is what contains the test content to work on styling.

At src/assets/* you'll find the other important parts ([s]css, js, imgs).

As for the sphinx theme itself, see src/sphinx.

Build

  • Run yarn crafter. This will update the craftercms_sphinx_theme directory which is the python package to be built and published to PyPI
  • Run python setup.py sdist to create a "source distribution"
    • This will create dist/ and inside with a .tar.gz
  • Run python setup.py bdist_wheel --universal to create a "universal wheel"
    • This will create a .whl inside of dist/ and a build/
  • To upload project to PyPI — with twine:
    • Set up your account
    • If you haven't already, pip install twine & pip install wheel
    • twine upload dist/*
  • Visit PyPI to manage the package
  • Tada! Done.

Extra credit

https://packaging.python.org/tutorials/distributing-packages