No description
Find a file
rakekniven c4bf78af73
Merge pull request #13807 from nextcloud/dependabot/pip/master/charset-normalizer-3.4.4
chore(deps): Bump charset-normalizer from 3.4.3 to 3.4.4
2025-10-23 21:02:13 +02:00
.devcontainer fix(devcontainer): Fix missing xelatex dependency 2025-09-09 09:25:08 +00:00
.github fix: update other forum ref 2025-10-10 07:32:49 -04:00
_ext
_shared_assets fix(developer): make WebDAV property table smaller 2025-04-22 16:48:25 +02:00
admin_manual chore(administration): Generate system config documentation from config.sample.php 2025-10-23 13:42:39 +00:00
build build: Copy merged OpenAPI spec from server sources 2025-03-24 18:14:34 +01:00
developer_manual chore: add removal of OCA.Sharing.ExternalLinkActions 2025-10-13 15:29:25 +02:00
static
user_manual feat: meeting proposals 2025-10-23 17:53:15 +02:00
.codespellignore fix: Update .codespellignore 2024-10-01 15:48:56 +02:00
.codespellrc feat: hello codespell 2024-07-23 13:04:10 +02:00
.gitignore
conf.py Merge pull request #13647 from nextcloud/jtr/feat/eol-warning-banner 2025-09-17 17:30:05 +02:00
COPYING
go.php fix: update go link for admin-php-modules 2025-09-01 09:23:20 -04:00
index.html fix(branches): Stable is 32 now 2025-10-01 10:05:44 +02:00
Makefile build: Copy merged OpenAPI spec from server sources 2025-03-24 18:14:34 +01:00
README.rst chore: update transifex links 2025-09-10 17:56:23 +02:00
requirements.txt chore(deps): Bump charset-normalizer from 3.4.3 to 3.4.4 2025-10-23 20:57:43 +02:00
style_guide.rst standardize occ command documentation 2025-04-29 13:21:08 +02:00
user_manual_index.html chore: Cleanup developer manual 2024-09-05 22:15:51 +02:00

=======================
Nextcloud Documentation
=======================

Documentation is published on `<https://docs.nextcloud.com>`_.
To edit it yourself, you need to tinker a bit with Git and Sphinx.
See the `Style Guide <https://github.com/nextcloud/documentation/blob/master/style_guide.rst>`_ for formatting and style conventions.

Manuals
-------

This repository hosts three manuals:

* **Users' Manual**
* **Administration Manual**
* **Developers Manual**

Please work in the appropriate branch: ``stable``-branches are for the respective release (e.g. 14.0 or 15.0), ``master`` is the latest version.

Please wrap lines at 80 characters.

.. note:: ``configuration_server/config_sample_php_parameters.rst`` is auto-generated from the core
   config.sample.php file; changes to this file must be made in core `<https://github.com/nextcloud/server/tree/master/config>`_

Spelling and Capitalization Conventions
---------------------------------------

As this grows it may be moved to its own page.

* Nextcloud App Store
* synchronize
* Web (Web page, Web site)

License
-------

All documentation in this repository is licensed under the Creative Commons
Attribution 3.0 Unported license (`CC BY 3.0`_).

.. _CC BY 3.0: https://creativecommons.org/licenses/by/3.0/deed.en_US

Style
-----

Source files are written using the `Sphinx Documentation Generator
<https://www.sphinx-doc.org/en/master/>`_. The syntax follows the `reStructuredText
<http://docutils.sourceforge.net/rst.html>`_ style, and can also be edited
from GitHub.

Structure
---------

Of course, think about structure. Keep in mind that we try NOT to move or rename
pages once they are created! Lots of external sources link to our documentation,
including the indexing by search engines of course. So once you create a page with a certain
name, it has to stay in that location and with that name. Think of it as API stability
- we have to ensure things stay as they are as much as possible. Renaming or moving
is only allowed in exceptional circumstances and only when a redirect is put in place.

Editing
-------

Contributing to the documentation requires a GitHub account. Make sure you are
working in the correct branch for your version of Nextcloud or client apps.
If your edits pertain to multiple manual versions, be prepared to backport as
needed.

To edit a document, you can edit the .rst files on your local system, or work
directly on GitHub. The latter is only suitable for small fixes and improvements
because substantial editing efforts can better be controlled on your local PC.

.. tip::
   If you're getting to know our documentation syntax, `give Documatt Snippets
   <https://snippets.documatt.com/>`_ a try. This online editor is a great way 
   to practice with reStructuredText and Sphinx, and it provides a more accurate
   preview of your work than GitHub does.

The best way is to install a complete Sphinx build environment and work on your
local PC. You will be able to make your own local builds, which is the fastest
and best way to preview for errors. Sphinx will report syntax errors, missing
images, and formatting errors. The GitHub preview is not complete and misses
many mistakes. Create a new branch against the master or stable branch you are
editing, make your edits, then push your new branch to GitHub and open a new PR.

To edit on GitHub, fork the repository (see top-right of the screen, under
your username). You will then be able to make changes easily. Once done,
you can create a pull request and get the changes reviewed and back into
the official repository.

When editing either on your own local PC or on GitHub, be sure to sign of
commits, to certify adherence to the Developer Certificate of Origin,
see https://github.com/probot/dco . Your commit messages need to have,
the name and email address of the contributor.

  Signed-off-by: Awesome Contributor <awesome.contributor@reach.me>

If using the command line and your name and email are configured, you can use

  git commit -s -m 'Commit message'

In both settings be sure that your email address matches that in your GitHub profile,
which if you have privacy enabled will be github.username@users.noreply.github.com


Translations
------------

`Help translate the documentation <https://explore.transifex.com/nextcloud/nextcloud-user-documentation/>`_.

For developers that want to ease the translation process, please read `this documentation <https://docs.transifex.com/integrations/sphinx-doc>`_.

Building
--------

Nightly Automated Build Steps
=============================

1.  **Fetch sources**
   1.  ``git clone https://github.com/nextcloud/documentation.git``
   2.  ``cd documentation``
   3.  ``git checkout <branch name>``
2.  **Install**
   1.  ``npm install svgexport -g --unsafe-perm=true``
   2.  ``pip3 install -r requirements.txt``
   3.  ``make all``


Building HTML
=============

Using pipenv
^^^^^^^^^^^^

1. Install ``pipenv`` - https://pipenv.readthedocs.io/en/latest/
2. Change into the environment: ``pipenv shell``
3. Install the dependencies ``pip install -r requirements.txt``
4. Now you can use ``make ...`` to build all the stuff - for example ``make html`` to build the HTML flavor of all manuals
   The build assets will be put into the individual documentation subdirectories like ``developer_manual/_build/html/com``

To change into this environment you need to run ``pipenv shell`` to launch the shell and to exit you can use either ``exit`` or ``Ctrl`` + ``D``.

Using venv
^^^^^^^^^^

1. Install ``python3-venv``
2. Only once: Create a venv (typically inside this repository): ``python -m venv venv``
3. Activate the environment (inside this repository): ``source venv/bin/activate``
4. Install the dependencies ``pip install -r requirements.txt``
5. Now you can use ``make ...`` to build all the stuff - for example ``make html`` to build the HTML flavor of all manuals
   The build assets will be put into the individual documentation subdirectories like ``developer_manual/_build/html/com``

Building translated versions
^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Only available in user_manual:

1. Build the english version as described above before
2. Create translation files: ``../build/change_file_extension.sh``
3. Create German (``de``) version: ``make html-lang-de``
4. Find the HTML files in ``_build/html/de/index.html``
5. Before building another language you have to delete the complete ``_build`` directory

Autobuilding
^^^^^^^^^^^^

When editing the documentation installing ``sphinx-autobuild`` though pip can be helpful. This will watch file changes and automatically reload the html preview:

1. Install ``pip install sphinx-autobuild``
2. When building the developer documentation make sure to execute ``make openapi-spec`` in the repository root
3. Enter the documentation section ``cd user_manual``
4. Watch for file changes ``make SPHINXBUILD=sphinx-autobuild html``
5. Open http://127.0.0.1:8000 in the browser and start editing

Building PDF
============

Building inside docker
^^^^^^^^^^^^^^^^^^^^^^

1. Create a docker:: ``docker run --platform linux/amd64 --volume .:/docs --interactive --tty --name nextcloud-docs ghcr.io/nextcloud/continuous-integration-documentation:documentation-15 bash``
2. Change into the documentation directory: ``cd /docs``
3. Only once: Create a venv: ``python -m venv venv``
4. Activate the environment: ``source venv/bin/activate``
5. Install the dependencies ``pip install -r requirements.txt``
6. Change into the documentation of choice (admin, developer, user): ``cd /docs/user_manual``
7. To build the English version: ``make latexpdf``
8. To build the translated version (only available in user_manual):
   1. Create translation files: ``../build/change_file_extension.sh``
   2. Create German (``de``) version: ``make latexpdf-lang-de``
   3. Find the file in ``_build/latex/Nextcloud_User_Manual.pdf``
   4. Before building another language you have to delete the complete ``_build`` directory

Building locally
^^^^^^^^^^^^^^^^

.. note:: Because of the many dependencies LaTeX and the other tools bring in, it is not recommended to install the tools locally.

1. Follow instructions for "Building HTML" above
2. Install ``latexmk`` and ``texlive-latex-extra`` - https://pipenv.readthedocs.io/en/latest/
3. Create a Python environment (typically inside this repository): ``pipenv --python 3.9``
4. Change into the environment: ``pipenv shell``
5. Install the dependencies ``pip install -r requirements.txt``
6. Now you can use ``make ...`` to build all the stuff - for example ``make pdf`` to build the PDF flavor of all manuals

Using the VSCode DevContainer
=============================

This repository contains a full-featured `VSCode DevContainer <https://code.visualstudio.com/docs/devcontainers/containers>`_.
You can use it in your local development environment or via `GitHub Codespaces <https://github.com/features/codespaces>`_.
Just open the container an use one of the commands from above to build the project. For example ``make`` to build the full
documentation, ``make html`` to build the HTML documentation or ``make pdf`` to build the PDF documentation. You can also use
``make SPHINXBUILD=sphinx-autobuild html`` in combination with `port forwarding <https://code.visualstudio.com/docs/devcontainers/containers#_forwarding-or-publishing-a-port>`_
to  watch file changes and automatically reload the html preview.

Icons
-----

To compile and update the icons list in the designer manual, you will also need

1. inkscape
2. sass
3. unzip
4. wget

.. _CC BY 3.0: https://creativecommons.org/licenses/by/3.0/deed.en_US
.. _`Xcode command line tools`: https://stackoverflow.com/questions/9329243/xcode-install-command-line-tools