This repository contains comprehensive documentation on how to author different forms of content on the DataCamp platform. It has been built by collating content from different github repositories, wikis, and Google documents. The objective is for all authoring related documentation to live in one place that authors can easily access and search. The authoring documentation can be found online at https://authoring.datacamp.com/
This repository uses GitBook to generate clean, user-friendly documentation that can be easily hosted
In order to start working on the gitbook locally you will need to have node and npm installed on your machine.
To check whether you have them installed try typing:
node -v && npm -v
The result should be similar to:
v7.10.1
4.2.0
If this isn't the case, you can follow these steps:
-
Open your terminal
-
Install the Node version manager by executing:
wget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.6/install.sh | bash
-
Install the node version
8
nvm install 8 && nvm use 8
-
Restart your terminal
-
Execute
node -v && npm -v
. You should see the versions printed out.
To preview the GitBook website on your machine, you will need to do the following:
-
Install GitBook
npm install gitbook-cli -g
-
Clone repository
# for ssh git clone [email protected]:datacamp/authoring.git # for https git clone https://github.com/datacamp/authoring.git
-
Start the GitBook
cd authoring && npm start
Your GitBook should be acessible on http://localhost:4000. Every time you update a file, the
gitbook
CLI will reload the page, making your changes visible immediately. GitBook uses the same Markdown flavor as GitHub.
The official GitBook documentation provides a nice starting point for more information.
There are a few folders and files which have special meaning / tasks:
docs/
- All the markdown files which are being used to create a static documentation site. Place all your markdown in the folders.docs/courses
- All the content related to coursesdocs/projects
- All the content related to projectsdocs/challenges
- All the content related to challengesdocs/mobile
- All the content related to mobiledocs/interface
- All the content related to the teach interfacedocs/image
- All the image files should be placed in this folder depending on the content type (courses
,projects
, etc..)SUMMARY.md
- Represents the left menu and the structure of the content. Usually nicely maps withdocs/
structure.books.json
- Lists all the plugins gitbook is currently using. (emojis etc.)
Before you start working locally on your gitbook be sure to branch out to a new branch as pushing to master
will cause the documentation to build and it WILL be available in production.
Flow for creating content:
- Create a markdown file in one of folders (
docs/courses
,docs/projects
,docs/challenges
,docs/mobile
,docs/interface
) - Add the markdown
- If you want to add the markdown file to the left menu edit the docs/SUMMARY.md
Once you are done with the work create a pull request to master and merge after reviewing.
Linking should always be absolute, which means that you should specify the whole path. The reason behind that decision is search and replace as relative paths could lead to broken links.
Examples on how to import images or create links:
![Image description](/images/interface/teach-editor.png) # Will create an image
[A link](/courses/README.md) # Will create a link
A link to [part of the page](/courses/exercises/multiple-choice-exercise.md#pure-mce) # Will link to exercises page scrolling down to pure multiple choice exercise