This GitHub repository represents Talkable’s documentation site, located at docs.talkable.com.
The Talkable documentation uses reStructuredText as its markup language and is built using Sphinx.
For more details see The Sphinx Documentation.
For more details see The reST Quickref.
Section headings are very flexible in reST. We use the following convention in the Talkable documentation:
#
for module headings=
for sections-
for subsections.
for subsubsections
Sections that may be cross-referenced across the documentation should be marked with a reference.
To mark a section use .. _ref-name:
before the section heading.
The section can then be linked with :ref:`ref-name`
. These are unique references across the entire documentation.
For example:
.. _talkable-module:
Talkable Module
###############
This is the module documentation.
.. _talkable-section:
Talkable Section
================
Talkable Subsection
-------------------
Talkable Subsubsection
......................
Here is a reference to "talkable section": :ref:`talkable-section` which will have the
name "Talkable Section".
Directives (..
syntax):
-
All directives starting with
..
(e.g.,.. image::
,.. note::
) must have 2 spaces indentation for their content. Examples:.. meta:: :description: This is an example of a meta directive. .. image:: /_static/img/example.jpg :alt: Example Image .. note:: This is an important note. .. code-block:: html <h1>Hello world!</h1>
Always ensure there is a blank line at the end of each file to adhere to formatting standards.
First install Sphinx. See below.
-
Install Homebrew.
-
Install Ruby and Bundler, and run
bundle install
to install dependencies. -
Install Python (>= 3.9) and pip:
brew install python
More information in case of trouble: https://docs.brew.sh/Homebrew-and-Python
-
Install dependencies:
pip3 install -r requirements.txt --break-system-package
If you have problems, try adding
-I
flag (--ignore-installed
) to thepip install
command.
If you get the error "unknown locale: UTF-8" when generating the documentation, the solution is to define the following environment variables:
export LANG=en_US.UTF-8
export LC_ALL=en_US.UTF-8
Run rake preview
from "master" branch.
Run rake server
from "master" branch and open http://localhost:5000
in browser.
If you’re deploying for the first time make sure you have gh-pages
branch locally. Otherwise run the following command to create it: git checkout -b gh-pages origin/gh-pages
.
General flow:
- Pull changes from master
- Checkout your new branch from master
- Make changes
- Deploy your changes to staging (see the instruction below)
- Create a Pull Request to "master" branch, providing the demo URL to the changed page in Pull Request’s description.
- Merge pull request once it passes the review
- Deploy
If you did everything right, deploying is as easy as rake deploy
from "master" branch.
If it’s your first time deploying to staging, run rake setup
to setup git remote.
- Switch to local branch "void" and pull the latest changes from the remote:
git checkout void; git pull
- Merge your branch into local branch "void":
git merge YOUR_BRANCH_NAME
- Push the changes to the remote branch "void":
git push origin void
- Deploy:
rake deploy:staging
See "master" branch: https://github.com/talkable/talkable-docs
See "gh-pages" branch: https://github.com/talkable/talkable-docs/tree/gh-pages
See GitHub Page (auto generated): https://docs.talkable.com