Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[FEATURE] Document new init command #477

Merged
merged 3 commits into from
Dec 17, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
109 changes: 30 additions & 79 deletions Documentation/Howto/WritingDocForExtension/Index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
.. include:: /Includes.rst.txt
.. index:: Documentation; Extension
.. _writing-doc-for-ext-start:
.. _how-to-start-docs-extension:
.. _extension-documentation-files:
.. _write-doc-extensions-intro:

Expand All @@ -16,97 +15,49 @@ This chapter explains how to write documentation for a new extension.
This guide uses the `example extension manual <https://github.com/TYPO3-Documentation/TYPO3CMS-Example-ExtensionManual>`__
as a template for starting out.

Rendering the documentation locally
-----------------------------------

Docker is required to run the rendering toolchain locally. By rendering the documentation this way, proofreading and
checking for typos and testing links can be carried out before the documentation is committed. The
:ref:`render-documenation-with-docker` has more information on how this toolchain is set up and configured.

Using the documentation-draft branch to preview changes
-------------------------------------------------------

Alternatively, a `documentation-draft` branch can be created in the documentation repository.
Once committed, this will render the documentation and make it available publicly, but it will only be visible
when the "draft" drop-down is selected when viewing the rendered documentation. Documentation under the draft branch will not be indexed
by search engines. Visit the :ref:`supported-branches` section for more information.

Creating extension documentation using the sample manual
--------------------------------------------------------

.. rst-class:: bignums-xxl

#. Clone the sample extension manual

In a temporary directory, clone the GitHub project
`sample extension manual <https://github.com/TYPO3-Documentation/TYPO3CMS-Example-ExtensionManual>`__

.. code-block:: bash

git clone https://github.com/TYPO3-Documentation/TYPO3CMS-Example-ExtensionManual.git
.. _write-doc-extensions-intro-rendering:

Copy the entire :file:`Documentation` directory, so that it
is a subdirectory located within your extension, for example:

.. code-block:: bash

cp -r TYPO3CMS-Example-ExtensionManual/Documentation <my-extension-directory>/

#. Add or modify additional files

* Make sure :ref:`t3coreapi:composer-json` is up to date. (*required*)
* Make sure :ref:`settings-cfg` is up to date. (*required*)
* A .gitignore is useful, in order to
prevent accidentally committing the generated documentation in
:file:`Documentation-GENERATED-temp` to the Git repository. (*recommended*)
* An .editorconfig is useful, so the
recommended :ref:`Coding Guidelines <format-rest-cgl>` will be used within
an editor or IDE.

.. code-block:: bash

# cp .gitignore (make sure you don't accidentally overwrite existing one though!)
cp -n TYPO3CMS-Example-ExtensionManual/.gitignore <my-extension-directory>/.gitignore
# cp .editorconfig (make sure you don't accidentally overwrite existing one though!)
cp -n TYPO3CMS-Example-ExtensionManual/.editorconfig <my-extension-directory>/.editorconfig

If you plan to host your extension on a public repository, consider
adding a CONTRIBUTING.rst
and :ref:`README.rst <readme-rst>` to help guide any future
contributors.


#. Start adding documentation
Rendering the documentation locally
===================================

Now it's time to start adding content. Reviewing existing guides can help you structure your own documentation.
The `news extension <https://docs.typo3.org/p/georgringer/news/main/en-us/Index.html>`__ is a strong example of how extension
documentation should be written and structured.
Use the following Docker command to render your documentation guide locally:

#. Populate composer.json
.. include:: /_Includes/_LocalRendering.rst.txt

Complete the :file:`composer.json` as described in :ref:`t3coreapi:composer-json`.
The :ref:`render-documenation-with-docker` has more information.

#. Populate guides.xml
.. _how-to-start-docs-extension:

Complete the :file:`guides.xml` as described in :ref:`settings-guides-xml`.
Use the init command to create the Documentation folder
=======================================================

#. Render documentation
The following Docker command helps you to create some basic documentation
including the required configuration file :file:`Documentation/guides.xml`:

Before publishing changes, make sure the documentation is rendered correctly, either
by :ref:`rendering it locally <render-documenation-with-docker>` or by using the :ref:`draft branch <migrate-branches>`
to preview the changes.
.. include:: /_Includes/_InitCommand.rst.txt

#. Publish when ready
The command creates a folder :path:`Documentation` in the directory it is called
from. This should be the root directory of your extension containing the
`composer.json <https://docs.typo3.org/permalink/t3coreapi:files-composer-json>`_.

The documentation needs to be :ref:`made publicly available <t3coreapi:publish-extension>`.
Follow the interactive dialoge. We suggest to use the option ReStructuredText (rst)
as this format provides the full power of the TYPO3 documentation theme. Using
Markdown (md) is an option for simple and quick one page documentation.

In order to trigger the documentation rendering process, a :ref:`webhook needs to be added <webhook>`.
If your extension offers a main `Site set <https://docs.typo3.org/permalink/t3coreapi:site-sets>`_
enter its name and path when prompted. This will regenerate ready to use
documentation about configuration for you. If you have more then one set you
can document the other sets manually. If you have no set, you need to write
the chapter your self.

.. tip::
Make changes and try :ref:`rendering <rendering-docs>` the new documentation.

Consider hosting your extension repository on either GitHub, Bitbucket or GitLab.
That way others can report issues and assist you by creating change requests to help
improve both the extensions documentation and the code.
To publish your documentation to https://docs.typo3.org
a :ref:`webhook needs to be added <webhook>` on GitHub, Bitbucket or GitLab.
A member of the Documentation Team has to approve your new documentation guide
for publishing. In case the Team has questions, please follow the thread
generated for your extension in the `TYPO3 slack organization <https://typo3.org/community/meet/chat-slack>`_
in channel `#typo3-documentation <https://typo3.slack.com/archives/C028JEPJL>`_.

Version numbers
===============
Expand Down
22 changes: 18 additions & 4 deletions Documentation/Reference/GuidesXml.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,19 +9,33 @@ Configuration of the rendering - guides.xml
This XML file contains meta information and configuration used during rendering
of a manual.

.. rubric:: Example:

.. literalinclude:: _guides-simple.xml
:caption: Documentation/guides.xml

.. contents:: Table of Contents:
:local:

.. _guides-xml-init:

Init new guides.xml
linawolf marked this conversation as resolved.
Show resolved Hide resolved
===================

If you start a new documentation guide, for example in a TYPO3 extension, use the
`init` command:

.. include:: /_Includes/_InitCommand.rst.txt

And follow the interactive question.

.. hint::
If you are migrating from the legacy Sphinx-based rendering and still have
a :file:`Documentation/Settings.cfg` you can use an automatic migration
tool to :ref:`migrate the Settings.cfg into a guides.xml <migrate_guides_xml>`

.. contents:: Table of Contents:
:local:
.. _guides-xml-api:

guides.xml API
==============

.. confval-menu::
:display: tree
Expand Down
12 changes: 11 additions & 1 deletion Documentation/Reference/RenderingContainer.rst
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,14 @@ contains the :path:`Documentation` folder:

.. include:: /_Includes/_LocalRendering.rst.txt

.. todo: Document rendering container options here
.. _init-command:

The init command
================

Use the `init` command to start writing TYPO3 documentation.

.. include:: /_Includes/_InitCommand.rst.txt

This command creates a `guides.xml <https://docs.typo3.org/permalink/h2document:guides-xml>`_
configuration file and some example pages in folder :path:`Documentation`.
4 changes: 4 additions & 0 deletions Documentation/_Includes/_InitCommand.rst.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
.. code-block:: bash
:caption: Execute in extension root, the directory that contains your extensions composer.json

docker run --rm --pull always -v $(pwd):/project -it ghcr.io/typo3-documentation/render-guides:latest init
1 change: 1 addition & 0 deletions Documentation/_Includes/_LocalRendering.rst.txt
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
.. code-block:: bash
:caption: Execute in extension root, the directory that contains your extensions composer.json

docker run --rm --pull always -v $(pwd):/project -it ghcr.io/typo3-documentation/render-guides:latest --config=Documentation

Expand Down
Loading