Main project site
Go to file
2025-01-08 17:03:19 +02:00
.idea feat: Switch to docsy 2023-01-11 19:53:46 +03:00
_vendor fix: Issues on new Hugo version 2024-12-13 15:06:28 +03:00
assets fix: move screenshots to assets 2024-12-11 20:27:24 +03:00
content fix: typo 2025-01-08 17:03:19 +02:00
i18n feat: Add fediverse and forum links 2024-09-06 16:01:21 +03:00
layouts feat: responsive image shortcode 2024-12-11 21:46:52 +03:00
static fix: move screenshots to assets 2024-12-11 20:27:24 +03:00
.drone.yml ci: Add installation of postcss-cli 2023-01-24 19:31:24 +03:00
.gitignore feat: Switch to docsy 2023-01-11 19:53:46 +03:00
.nvmrc feat: Switch to docsy 2023-01-11 19:53:46 +03:00
config.toml fix favicon (#196) 2024-10-15 20:34:20 +03:00
docker-compose.yaml feat: Switch to docsy 2023-01-11 19:53:46 +03:00
Dockerfile feat: Switch to docsy 2023-01-11 19:53:46 +03:00
go.mod feat: upgrade theme 2024-04-22 21:13:55 +03:00
go.sum feat: upgrade theme 2024-04-22 21:13:55 +03:00
LICENSE feat: Switch to docsy 2023-01-11 19:53:46 +03:00
netlify.toml feat: Switch to docsy 2023-01-11 19:53:46 +03:00
package.json Update layout (#102) 2024-04-18 21:41:36 +03:00
README.md fix: update readme 2024-10-17 03:36:24 +03:00

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

  1. Clone this repo with git clone https://git.selfprivacy.org/SelfPrivacy/selfprivacy.org.git
  2. Run hugo server
  3. 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

  1. Create a new folder
  2. Create a file called _index.md in that folder.
  3. 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.

  1. Build the docker image

    docker-compose build
    
  2. Run the built image

    docker-compose up
    

    NOTE: You can run both commands at once with docker-compose up --build.

  3. 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.