.idea | ||
_vendor | ||
assets | ||
content | ||
i18n | ||
layouts | ||
static | ||
.drone.yml | ||
.gitignore | ||
.nvmrc | ||
config.toml | ||
docker-compose.yaml | ||
Dockerfile | ||
go.mod | ||
go.sum | ||
LICENSE | ||
netlify.toml | ||
package.json | ||
README.md |
This is a repository for the SelfPrivacy website, available at https://selfprivacy.org/
This website is statically generated using Hugo and uses a customised version of the Docsy theme. It is available in English and Russian.
Getting started
- Clone this repo with
git clone https://git.selfprivacy.org/SelfPrivacy/selfprivacy.org.git
- Run
hugo server
- Open
http://localhost:1313/
in your browser
If it doesn't work, check if you have Hugo and dependencies installed.
If 1313
is already used for something else, Hugo will use a different port. Check your console to find out which one.
Folder structure
content/ source files in .md and .html
assets/ assets that require preprocessing
Dockerfile
i18n/ UI translation strings
layouts/ copied customised theme files
LICENSE
node_modules/
public/ generated .html files
resources/ generated assets
static/ static assets
_vendor/ customisable theme files
package.json
package-lock.json
README.md <- you're here
go.mod
go.sum
config.toml website settings
netlify.toml
docker-compose.yaml
In the content/
folder, there are two folders, one per each language. Language folders have similar contents:
blog/ blog and releases
docs/ documentation
download/ download page
privacy-policy/ privacy policy
_index.html the landing page
search.md
...other landing page files
To add a new section or subsection
- Create a new folder
- Create a file called
_index.md
in that folder. - Add more files if needed; put images and videos in the same folder
To add an image to the docs article
To add an image to an article, create a new folder and put the article and it's illustrations in that folder.
In the text use imgproc
shortcode with explicit width and height:
{{< imgproc filename Fill "1001x808" />}}
To change layout
Go to the _vendor/github.com/google/docsy/layouts
and change files there. Do not copy files to the project's layouts/
folder, it was used before the theme was vendored and will be removed later.
To change styles
Change the assets/scss/_styles_project.scss
. Use variables defined in the _variables_project.scss
.
If you want to change the style of the Docsy theme components, navigate to _vendor/github.com/google/docsy/assets/scss
and change files there instead.
To reorder documentation pages
In all of markdown files, change the weight
number in the metadata.
Running the website locally
Building and running the site locally requires a recent extended
version of Hugo.
You can find out more about how to install Hugo for your environment in the Docsy Getting started guide.
Once you've made your working copy of the site repo, from the repo root folder, run:
hugo server
You can view your site copy on any device connected to the same network. For example, if you're working on a laptop with address 192.168.1.99
, run:
hugo server --bind 192.168.1.99
The site will be available at 192.168.1.99:1313
, which you can also visit from another device, like your smartphone. If it doesn't work, check if your firewall blocks incoming connections over port 1313
. To use a different port, like 8080
, add --port 8080
.
Running a container locally
You can run docsy-example inside a Docker
container, the container runs with a volume bound to the docsy-example
folder. This approach doesn't require you to install any dependencies other
than Docker Desktop on
Windows and Mac, and Docker Compose
on Linux.
-
Build the docker image
docker-compose build
-
Run the built image
docker-compose up
NOTE: You can run both commands at once with
docker-compose up --build
. -
Verify that the service is working.
Open your web browser and type
http://localhost:1313
in your navigation bar, This opens a local instance of the docsy-example homepage. You can now make changes to the docsy example and those changes will immediately show up in your browser after you save.
Cleanup
To stop Docker Compose, on your terminal window, press Ctrl + C.
To remove the produced images run:
docker-compose rm
For more information see the Docker Compose documentation.
Troubleshooting
As you run the website locally, you may run into the following error:
➜ hugo server
INFO 2021/01/21 21:07:55 Using config file:
Building sites … INFO 2021/01/21 21:07:55 syncing static files to /
Built in 288 ms
Error: Error building site: TOCSS: failed to transform "scss/main.scss" (text/x-scss): resource "scss/scss/main.scss_9fadf33d895a46083cdd64396b57ef68" not found in file cache
This error occurs if you have not installed the extended version of Hugo.
Or you may encounter the following error:
➜ hugo server
Error: failed to download modules: binary with name "go" not found
This error occurs if you have not installed the go
programming language on your system.