Skip to content

Latest commit

 

History

History
250 lines (159 loc) · 9.73 KB

CONTRIBUTING.md

File metadata and controls

250 lines (159 loc) · 9.73 KB

Contributing to Bonita documentation

The following is a set of guidelines for contributing to Bonita documentation.

Help us to be more visible for search engine

To help us, try to verify if your contribution have a clear title on the top of the page.
Also verify if new or updated pages have a summary of content directly after the title. This summary must have less than 140 characters. When updating an already existing page with no summary, try to write a little summary.

# Bonita overview

Bonita is a powerful BPM-based application platform for building highly engaging, personalized, process-based business applications to get things done.

Pull requests

Each minor version of Bonita has its own Git branch to manage its related documentation. (Minor version means X.Y, for example 7.4 or 7.5). For instance, the 7.4 branch is where you have to open pull requests when your contribution applies to all 7.4 versions of Bonita.

A branch should be name in kebab case prefixed by the type of the feature the branch has been created for (feat, fix, style, tr, chore, howto,...).
For instance, for a branch fixing a typo in the User REST API, its name should be fix/user-delete-rest-api-typo.

If your contribution applies to multiple minor versions of Bonita, then open a pull request on the lowest applicable version branch. Then add all applicable minor versions in your pull request comment and we will do the rest :-)

Example: Your contribution applies to versions 7.4 and 7.5. Therefore submit your pull request on branch 7.4 with a comment like:

My awesome contribution to Bonita documentation.
Versions: 7.4, 7.5

Ideally, a pull request, at first, should contain a single commit containing the changes you want to suggest. Other commits may be added after reviews. Having a single commit allows GitHub to use the commit title as pull request name.

The commit message format should be the following :

# Commit title / format: <type>(<scope>): <subject> 
# type in (feat, fix, style, howto, tr, ...)
 
 
# Explain why this change is being made
 
 
# Provide links to any relevant tickets, articles or other resources

For instance, when adding an warning alert inside the User DELETE REST API method

fix(api): add alert on the User REST API DELETE action

Allows users to be warned about the consequences to DELETE a user
instead of deactivating it.

Convention for Contribution

A contribution is composed of a TITLE and a DESCRIPTION

  • TITLE must NOT exceed 80 characters, for readability in Github interface.
  • DESCRIPTION is not limited to any number of characters and can extend to several lines.

Title

TITLE MUST respect the following format: <type>(<scope>): <subject>

<Type> is the nature of the change. Can be a value in (feat, fix, style, refactor, ...)

(feat: feature, fix: correction, style: appearance correction, refactor: rewriting of the article, ...)

<scope> is the business domain on which the change is done

<subject> is a short description of the change

  • E.g. "style(Business Data): fix display of the supported RDBMS matrix table"
  • E.g. "feat(APIs): provide code sample to show usage of Living Application creation"
  • E.g. "feat(dates): describe step by step tutorial on Date types in Bonita"

Description

If needed, description allow a more detailed explanation on why this change is being made. You can write as many lines of description as needed:

  • E.g.: "This change is part of a larger scale rewriting of how to deal with Dates in Bonita. Usage has proven that the feature was not correctly understood.
    This article tends to start over on the date notions and how to use them."

Useful links

Please provide links to any relevant tickets, articles or other resources if available

How to update an existing page?

In this case, edit the appropriate .md file and the build process will do the rest.

Example: To edit the ?page=actors page in version 7.4, edit the md/actors.md file and submit a pull request on 7.4 branch.

How to add a new page?

Create a new page

Checkout a branch from the version you want this page to be available in and create the .md file in the md folder.

Example: To add a new Manage form control/validation tutorial in 7.4, checkout a new branch from the 7.4 branch and create a new manage-control-in-forms.md file in the md folder.

You can check its content once committed on the GitHub site (Simple view) or using the web server (Advanced view).

Add page to taxonomy (navigation)

Your new page is not yet referenced in documentation site's taxonomy. So you will not be able to find your new page in the navigation tree unless you know the URL. Therefore you need to add your new page to the taxonomy to be able to find it the navigation tree.

The taxonomy is created from the taxonomy.md file. In our case, we also want to add a Howto section in the taxonomy tree. So we first create a new item inside the taxonomy.md. Then we create a entry point for our new tutorial inside the Howto section:

* [Howtos](_howtos.md)
  * [Manage form control/validation](manage-control-in-forms.md)

Note: We need to reference a _howtos.md page with the list of items of this section. However you don't need to create the _howtos.md file as it is automatically generated at build time.

Now starting from the visualization of the taxonomy.md page, we can browse to the manage-control-in-forms.md page.

Variables

During markdown to HTML conversion, some predefined variables located in the variables.json file are replaced.

For instance, the varVersion variable matches the current documentation version. To reference this variable, use the ${varVersion} notation in .md files.

Markdown titles

In markdown, lines starting with # are converted to <hx> tags where x is the number of # :

  • use # for h1 tag
  • use ## for h2 tag
  • use ### for h3 tag
  • etc... up to h6

Checkout the markdown cheatsheet for more information.

Table of content

A table of content (ToC) is automatically generated on each page from ## and ### titles (converted as h2 and h3 html tags).

It will be placed right before the first h2 title.

Quick note on "howtos"

When you create howtos make sure that:

  • In the taxonomy, their titles start with verbs, so it finishes the sentence "how to...", like "Manage multiple references in Business Objects".
  • In the file itself, the title includes the "how to" phrase, like "How to manage multiple references in Business Objects".
  • You reference the how to page in other descriptive pages of the existing taxonomy, to optimize its discoverability.
  • Howtos are a step by step guide to manage a use case. This use case should be described briefly as an introduction (following the page title but without its own title) for the user to understand the goal of the howto.

Markdown syntax

Current conversion to html is done with markdown-it with the Github-flavored Markdown. Checkout the cheatsheet for more information.

How to add images?

All images must be added to the md/images folder.

Images

Use exclusively the Markdown syntax to insert images. Using the HTML <img> syntax is not supported by the build process.

Example:

![optionalImageCaption](images/mandatoryImageFileName.ext)

Anchors

In the page to navigate to, add the following:

<a id="section-Name" />

In the page to navigate from, use the following:

[textToDescribeTheLink](pageName.md#section-Name)

If anchor is in the same page , use the following:

[textToDescribeTheLink](#section-Name)

Font Awesome

The markdown-it-fontawesome plugin has been activated and you can use Font Awesome icons with their name surrounded by colons.

Example:

:fa-flag:

will produce

<i class="fa fa-flag"></i>

Bootstrap alerts

In order to reproduce Bootstrap alerts that were present in former documentation site, we introduced markdown-it-alerts. It allows to recreate a div block with custom classes.

We added 5 types of container :

  • danger: used to highlight error prone use cases
  • warning: used to alert the user of aftermath
  • info: used to highlight short relevant information
  • success: used to validate good pratices

To use them create a block surrounded with 3 colons.

Example:

::: danger
Both Windows and Mac have default security settings that will prevent execution of Bonita. See below for further details about what you can do to bypass those security protections
:::

will be rendered as :

danger alert example

Decorate

If you want to decorate the md elements with html attributes like classes or title, we added the markdown-it-decorator to do so. Using <!--{}--> pattern at the end of a block will convert the content of {} to html attributes. Use CSS notation to decorate with classes.

Example:

This is some text.
<!--{.center}-->

will be converted to

<p class='center'>This is some text.</p>

Smart arrows

We added the use of the markdown-it-smart-arrows plugin to convert arrows to html entities :

--> →
<-- ←
<--> ↔
==> ⇒
<== ⇐
<==> ⇔