Skip to content

Commit

Permalink
Update docs to material theme (#341)
Browse files Browse the repository at this point in the history
* update docs to material theme

* update style and logo

* rearrange and update content

* docs/requirements.txt

* update workflow to skip if docs-only change, remove netlify config
  • Loading branch information
chrisjkuch authored Jan 14, 2024
1 parent 8aa2417 commit 0f5c33b
Show file tree
Hide file tree
Showing 9 changed files with 120 additions and 36 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,10 @@ name: tests
on:
push:
branches: [master, v2]
paths-ignore: "docs/**"
pull_request:
branches: [master, v2]
paths-ignore: "docs/**"
schedule:
# Run every Sunday
- cron: "0 0 * * 0"
Expand Down
2 changes: 1 addition & 1 deletion dev-requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ chardet
flake8
isort
mkdocs
mkdocs-cinder
mkdocs-material
mkdocs-gen-files
mkdocs-include-markdown-plugin
pexpect
Expand Down
30 changes: 24 additions & 6 deletions docs/docs/css/extra.css
Original file line number Diff line number Diff line change
@@ -1,24 +1,42 @@
h1, h2, h3 {
margin-top: 77px;
.md-typeset h1 {
font-weight: 800;
color: #222;
margin-bottom: -0.25rem;
}

.md-typeset h2,
.md-typeset h3 {
font-weight: 600;
color: #222;
}

.md-sidebar--secondary {
order: 0;
}

.md-grid {
max-width: 1080px;
}

#termynal {
height: 80ex !important; /* 40 lines of 2ex */
/* 40 lines of 2ex */
height: 80ex !important;
min-height: 80ex !important;
max-height: 80ex !important;
overflow: scroll !important;
font-size: 1.5ex !important;
}

[data-ty] {
line-height: 2ex !important;
line-height: 2ex !important;
white-space: pre;
}

.newline {
line-height: 0 !important;
}

.inline-input, .default-text {
.inline-input,
.default-text {
display: inline-block !important;
}
}
Binary file modified docs/docs/favicon.ico
Binary file not shown.
66 changes: 62 additions & 4 deletions docs/docs/index.md
Original file line number Diff line number Diff line change
@@ -1,12 +1,61 @@
---
hide:
- navigation
---
# Cookiecutter Data Science

_A logical, reasonably standardized but flexible project structure for doing and sharing data science work._
_A logical, flexible, and reasonably standardized project structure for doing and sharing data science work._

[![tests](https://github.com/drivendata/cookiecutter-data-science/workflows/tests/badge.svg?branch=v2)](https://github.com/drivendata/cookiecutter-data-science/actions/workflows/tests.yml?query=branch%3Av2)


## Quickstart

!!! info "Changes in v2"

Cookiecutter Data Science v2 now requires installing the new `cookiecutter-data-science` Python package, which extends the functionality of the [`cookiecutter`](https://cookiecutter.readthedocs.io/en/stable/README.html) templating utility. Use the provided `ccds` command-line program instead of `cookiecutter`.

=== "With pipx (recommended)"

```bash
pipx install cookiecutter-data-science

# From the parent directory where you want your project
ccds https://github.com/drivendata/cookiecutter-data-science
```

=== "With pip"

```bash
pip install cookiecutter-data-science
`
# From the parent directory where you want your project
ccds https://github.com/drivendata/cookiecutter-data-science
```

=== "With conda (coming soon!)"

```bash
# conda install cookiecutter-data-science -c conda-forge

# From the parent directory where you want your project
# ccds https://github.com/drivendata/cookiecutter-data-science
```

=== "Use the v1 template"

```bash
pip install cookiecutter

# From the parent directory where you want your project
cookiecutter https://github.com/drivendata/cookiecutter-data-science -c v1
```

## Why use this project structure?

> We're not talking about bikeshedding the indentation aesthetics or pedantic formatting standards — ultimately, data science code quality is about correctness and reproducibility.
When we think about data analysis, we often think just about the resulting reports, insights, or visualizations. While these end products are generally the main event, it's easy to focus on making the products _look nice_ and ignore the _quality of the code that generates them_. Because these end products are created programmatically, **code quality is still important**! And we're not talking about bikeshedding the indentation aesthetics or pedantic formatting standards — ultimately, data science code quality is about correctness and reproducibility.
When we think about data analysis, we often think just about the resulting reports, insights, or visualizations. While these end products are generally the main event, it's easy to focus on making the products _look nice_ and ignore the _quality of the code that generates them_. Because these end products are created programmatically, **code quality is still important**! And we're not talking about bikeshedding the indentation aesthetics or pedantic formatting standards — ultimately, **data science code quality is about correctness and reproducibility**.

It's no secret that good analyses are often the result of very scattershot and serendipitous explorations. Tentative experiments and rapidly testing approaches that might not work out are all part of the process for getting to the good stuff, and there is no magic bullet to turn data exploration into a simple, linear progression.

Expand Down Expand Up @@ -56,7 +105,6 @@ Disagree with a couple of the default folder names? Working on a project that's

With this in mind, we've created a data science cookiecutter template for projects in Python. Your analysis doesn't have to be in Python, but the template does provide some Python boilerplate that you'd want to remove (in the `{{ cookiecutter.module_name }}` folder for example, and the mkdocs documentation skeleton in `docs`).

> ℹ️ Cookiecutter Data Science v2 has changed from v1. It now requires installing the new cookiecutter-data-science Python package, which extends the functionality of the [cookiecutter](https://cookiecutter.readthedocs.io/en/stable/README.html) templating utility. Use the provided `ccds` command-line program instead of `cookiecutter`.

### Installation

Expand Down Expand Up @@ -142,6 +190,16 @@ The directory structure of your new project will look something like this (depen
└── visualize.py
```

## Using the v1 template

If you want to use the old v1 project template, you need to have either the cookiecutter-data-science package or cookiecutter package installed. Then, use either command-line program with the `-c v1` option:

```bash
ccds https://github.com/drivendata/cookiecutter-data-science -c v1
# or equivalently
cookiecutter https://github.com/drivendata/cookiecutter-data-science -c v1
```

## Opinions

There are some opinions implicit in the project structure that have grown out of our experience with what works and what doesn't when collaborating on data science projects. Some of the opinions are about workflows, and some of the opinions are about tools that make life easier. Here are some of the beliefs which this project is built on—if you've got thoughts, please [contribute or share them](#contributing).
Expand All @@ -164,7 +222,7 @@ Since notebooks are challenging objects for source control (e.g., diffs of the `

Now by default we turn the project into a Python package (see the `setup.py` file). You can import your code and use it in notebooks with a cell like the following:

```
```python
# OPTIONAL: Load the "autoreload" extension so that code can change
%load_ext autoreload

Expand Down
13 changes: 13 additions & 0 deletions docs/docs/logo.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
24 changes: 18 additions & 6 deletions docs/mkdocs.yml
Original file line number Diff line number Diff line change
@@ -1,21 +1,33 @@
site_name: Cookiecutter Data Science
site_description: A project template and directory structure for Python data science projects.
site_favicon: favicon.ico
site_url: https://cookiecutter-data-science.drivendata.org
repo_url: https://github.com/drivendata/cookiecutter-data-science
edit_uri: edit/master/docs/docs
copyright: Project maintained by the friendly folks at <a target=_blanks href="https://www.drivendata.org">DrivenData</a>.
google_analytics: ['UA-54096005-4', 'auto']
theme: cinder
theme:
favicon: favicon.ico
logo: logo.svg
name: material
palette:
primary: black
extra_css:
- css/extra.css
extra_javascript:
- js/extra.js
nav:
- Home: index.md

exclude_docs: |
_partials/termynal.md
markdown_extensions:
- admonition
- pymdownx.details
- pymdownx.superfences
- pymdownx.tabbed:
alternate_style: true
slugify: !!python/object/apply:pymdownx.slugs.slugify
kwds:
case: lower
- toc:
toc_depth: 3
plugins:
- include-markdown
- termynal:
Expand Down
2 changes: 0 additions & 2 deletions docs/requirements.txt

This file was deleted.

17 changes: 0 additions & 17 deletions netlify.toml

This file was deleted.

0 comments on commit 0f5c33b

Please sign in to comment.