The styling for this repo is broken up into two different parts: gulp + browsersync + sass and vanilla css.
It is recommended to use something to create a local server environment such as MAMP Pro which allows you to set virtual hosts (e.g.: http://api.plotly.dev)
This repo is set up to run with a gulp + sass + browsersync workflow. Essentially what this does is leverages a local server to display the site and when you make updates to the scss files they will be live injected into the site to see the immediate effects of your changes.
The scss and jekyll instance have been separated to allow for faster updates to the scss independent of the markup.
Once the repo has been cloned successfully (see Contributing.md), run $ npm install
to install gulp and the necessary dependencies.
Generally it's best to work with two instances of terminal, one to use for anything related to $ jekyll
and then another to keep the $ gulp
task running.
- run
$ jekyll serve --config _config_dev.yml
to create a local server @ http://localhost:4000 that browsersync leverages (see gulpfile.js to adjust as needed)
OR
- run
$ jekyll build --config _config_dev.yml
and leverage a local server @ http://api.plotly.dev through a service like MAMP Pro that browsersync leverages (see gulpfile.js to adjust as needed) - run
$ gulp
- make any updates to the scss files
It's a bit of a hassle to make concurrent updates to markup and scss. Anytime you update an html/js file you'll have to run a $ jekyll build
command or $ jekyll serve
and have jekyll watching for changes. I have found issues with jekyll's watch being too sensitive and have opted to build when I choose to prevent long hangs because of the size of the repo.
When you run a $ jekyll
you need to update any scss file as jekyll will automatically replace the styles.css file. e.g.: if you modify any scss file and save it, it will overwrite the file jekyll has produced.
-
scss/
- _abstract/ (variables, mixins, resets, etc)
- _abstract.scss
- _normalize.scss
- _components/ (ui components)
- _base.scss
- _breadcrumb.scss
- _foot.scss
- _header.scss
- _helpbox.scss
- _highlighting.scss
- _sidebar.scss
- _pages/ (page specific layout styles)
- _getting-started.scss
- _home.scss
- _tutorial-index.scss
- _tutorial-single.scss
- main.scss (bringing it all together)
- _abstract/ (variables, mixins, resets, etc)
-
all_static/css/
- main.css (the css conversion of main.scss)
- Run
gulp build
in the root of the documentation repo after making any scss edits. This will updatemain.css
as well as the verion which is used to prevent css caching. git add
the files you've changed as well as the generatedmain.css
andcache_bust_css.yml
files,git commit -m 'message about update'
, andgit push origin source-design-merge
to add your updates to the repo.- run
rake deploy
to deploy changes.
If there's no need or desire to utilize the scss workflow, there's a separate css file added to add quick and simple fixes or updates to the repo.
/all_static/css/css.css
Last updated: 05.09.2016