Skip to content

Latest commit

 

History

History
208 lines (151 loc) · 8.27 KB

contributing.md

File metadata and controls

208 lines (151 loc) · 8.27 KB

Table of contents

Content

Create new Topic

Create new folder

Create a new folder under docs. Folder names should be lower case and seperated by hyphen (-, e.g. my-new-folder). Create an index.md. This is the overview page that gives an overview of the topic. If you want to use images, create an extra image folder named img. All other pages that are subordinate to this topic should also be named lowerCamelCase.

Metadata in pages

There are various metadata with which various things are influenced.

  • default: this is the default layout, please use only this
  • title: this name will be visible in the sidebar
  • permalink (only index page): between two slashes, insert the name in ´lowerCamelCase´ here again
  • has_children
    • If the index page has children, it must be true
    • It´s also possible that child pages have child pages themselves
  • nav_order
    • if page is an index page: Look at the other pages and add the corresponding number that fits here "alphabetically"
    • if page is a child page: Defines the order within the topic
  • sample_branch (optional)
    • If an example app exists in the sample repository, the branch name can be inserted here
    • can be used on all pages
    • will create a button to the sample app in the other repository

Example:

---
layout: default
title: i18n
permalink: /i18n/
has_children: true
nav_order: 40
sample_branch: i18n
---

Add Images

The individual topics are each in a subfolder. For pictures, create a separate subfolder with the name img, e.g. here:

https://github.com/1DSAG/UI5-Best-Practice/tree/main/docs/i18n

To display the pictures with a subtitle and an alternative text, create a table in markdown like this:

Picture in Documentation

Markdown in GitHub

Raw in GitHub

| ![Usage of Placeholder in i18n in XML Views](img/i18n_PlaceholderXMLViews.png) |
| :--: |
| *Usage of Placeholder in i18n in XML Views* |

Create sample app

It is possible to create a sample app for the topics. There is a seperate repository for this. The individual topics have their own branches. If necessary, several branches can be created for one topic. To start, use the boiler plate code in the main branch. To integrate the sample app, the easiest way is to simply link to the branch.

The boiler plate code makes it easy to use codesandbox.io, so a user can not only execute directly, but also edit the code. If you want to include the example via iframe, be sure to link directly to the branch. You can see this example for the sample branch i18n:

<iframe src="https://codesandbox.io/embed/github/1DSAG/UI5-Best-Practice-samples/tree/i18n/?fontsize=14&hidenavigation=1&module=%2Fsrc%2Fview%2FMainView.view.xml&theme=dark&view=editor"
     style="width:100%; height:500px; border:0; border-radius: 4px; overflow:hidden;"
     title="ui5-sandbox"
     allow="accelerometer; ambient-light-sensor; camera; encrypted-media; geolocation; gyroscope; hid; microphone; midi; payment; usb; vr; xr-spatial-tracking"
     sandbox="allow-forms allow-modals allow-popups allow-presentation allow-same-origin allow-scripts">
</iframe>

To automatically display a button at the beginning of the page, for example, the metadata tag ´sample_branch´ can be used. Example here .

Add Emojis

In this project we use the Jekyll plugin jemoji. This allows the use of emojis. An overview of all emojis can be found here.

Developing

How to git commit messages

commit messages are linted in order to allow for automatic later processing into CHANGELOG et al documents.
The linting occurs against the standards defined in the "conventional commit" guidelines, based on the Angular project ones.

The structure of a "conventional commit" message looks like:

<type>[optional scope]: <description>

[optional body]

[optional footer(s)]

<type> can be any of

  • build
  • ci
  • chore
  • docs
  • feat
  • fix
  • perf
  • refactor
  • revert
  • style
  • test

So a minimal commit message could look like...

feat: added basic testing chapter

…while a maxed out one might look like:

fix: correct minor typos in code

see the issue for details on typos fixed.
additionally, replaced the dreaded ortho-""
with straight/standard ones.

Reviewed-by: Z
Closes #133

Please refer to the conventional commits website for more details on all the possibilities of formatting a git commit message.

Contributing

How to use Pull Requests in GitHub

  1. fork the repo
    fork a github project

  2. clone your fork into your local development environment
    clone the forked project

  3. create a new local git branch
    create new local git branch

  4. write, edit, code (most likely markdown content in /docs/**/*.
    👨‍💻
    repeat.

    note: we're using github flavoured markdown (gfm) that allows for extended markdown formatting

    git commit early, git commit often
    → watch out for the commit linting (see git commit messages)
    → enjoy the convenience of auto-markdown-linting (see linting of markdown content)

  5. if applicable, clean up your git commit history

  6. push the local branch to your fork

  7. submit a pull request (PR)
    create a pull request on github

  8. write the PR message similar to the git commit messages, so squash-merging gets easy for the maintainers
    nice pull request message if applicable, referenc open issues in your commit message (https://docs.github.com/en/free-pro-team@latest/github/managing-your-work-on-github/linking-a-pull-request-to-an-issue#linking-a-pull-request-to-an-issue-using-a-keyword)

  9. add a reviewer to the PR
    add a reviewer to the pull request

  10. Changes necessary after the PR was created?
    Simply commit to the branch of your fork
    → the PR gets updated automatically
    → move the PR into draft mode until ready (then move to ready for review)

  11. PR review process successfully completed?
    Then the PR will be merged by any of the maintainers and it’s time for 🎉

linting of markdown content

Any markdown content (in /docs/**/*) is linted via markdownlint both for quality assurance and convenience.
For quality assurance, to have the markdown-files max standard compliant, so subsequent processing and exporting is possible without running into formatting issues.
For convenience, because small markdown formatting mistakes are automatically fixed via the markdownlint upon commit - the markdownlint cli injects those fixes prior to the git commit, so don’t be surprised 😉