Skip to content

Commit

Permalink
docs(quick-starts): Updates design guidelines.
Browse files Browse the repository at this point in the history
  • Loading branch information
edonehoo committed Sep 16, 2024
1 parent 3f88fe2 commit dab3886
Show file tree
Hide file tree
Showing 5 changed files with 21,732 additions and 15,711 deletions.
Binary file added .yarn/install-state.gz
Binary file not shown.
4 changes: 2 additions & 2 deletions packages/dev/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,12 @@
"i18next-browser-languagedetector": "^8.0.0",
"i18next-parser": "^9.0.0",
"i18next-pseudo": "^2.2.0",
"lodash-es": "^4.17.21",
"react": "^18.2.0",
"react-dom": "^18.2.0",
"react-i18next": "^11.7.3",
"react-router-dom": "^6.11.2",
"showdown": "2.1.0",
"lodash-es": "^4.17.21"
"showdown": "2.1.0"
},
"devDependencies": {
"@types/react": "^18.2.79",
Expand Down
6 changes: 3 additions & 3 deletions packages/module/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -57,12 +57,12 @@
"devDependencies": {
"@patternfly/documentation-framework": "6.0.0-alpha.64",
"@patternfly/patternfly": "6.0.0-alpha.205",
"@patternfly/react-code-editor": "6.0.0-alpha.100",
"@patternfly/react-core": "6.0.0-alpha.100",
"@patternfly/react-icons": "6.0.0-alpha.35",
"@patternfly/react-styles": "6.0.0-alpha.34",
"@patternfly/react-tokens": "6.0.0-alpha.34",
"@patternfly/react-table": "6.0.0-alpha.101",
"@patternfly/react-code-editor": "6.0.0-alpha.100",
"@patternfly/react-core": "6.0.0-alpha.100",
"@patternfly/react-tokens": "6.0.0-alpha.34",
"@rollup/plugin-commonjs": "^17.0.0",
"@rollup/plugin-json": "^4.1.0",
"@rollup/plugin-node-resolve": "^11.1.0",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,97 +10,163 @@ source: design-guidelines
sourceLink: https://github.com/patternfly/patternfly-quickstarts/blob/main/packages/module/patternfly-docs/content/extensions/quick-starts/design-guidelines/design-guidelines.md
---

# Quick starts
## Elements
### Card
# Elements

Quick starts are usually surfaced within a [catalog](https://www.patternfly.org/v4/components/card/design-guidelines/#cards-in-catalog-views) as clickable cards.
## Quick start screen

<img src="./img/card-elements.png" alt="Elements of a card" width="370"/>

1. **Icon:** An icon associated with the quick start topic can be included on the card. If no specific icon exists, use the rocket icon.
2. **Title:** The title briefly communicates what the quick start covers.
3. **Labels:** [Filled labels](https://www.patternfly.org/v4/components/label) communicate the estimated completion time and status. If the quick start is presented in a mixed catalog of resources, a label can indicate the type of resource.
4. **Description:** The description summarizes the quick start outcome in four lines or fewer.
5. **Prerequisites (optional):** Prerequisites communicate user requirements before starting the quick start. They’re displayed in a popover, and they’re organized into a bulleted list. The total number of prerequisites is listed in parentheses on the quick start card.
<img src="./img/qs-context.png" alt="A quick start in context of a UI" width="1680"/>

<img src="./img/prerequisites.png" alt="Example of prerequisites" width="395"/>
Quick start screens contain a few different components:
- [Catalog view](/#catalog-view)
- [Cards](/#cards)
- [Drawer:](/#drawer) Contains an introduction screen, tasks, and a “check your work” module.

### Catalog
Multiple quick starts are often presented to users in a catalog.
## Catalog view
Multiple quick starts are often presented to users in a catalog view of multiple cards.

<img src="./img/catalog-elements.png" alt="quick start catalog" width="1680"/>

Catalogs with 14 or fewer quick starts should include a simple toolbar with the following elements:
Catalogs with 14 or fewer quick starts should include a simple toolbar with the following elements:
1. Keyword filter
2. Status filter
3. Item count

Catalogs with 15 or more quick starts should include filtering functionality presented as vertical filters on the left side of the page instead of a simple toolbar.
1. Status filter
1. Item count

For quick starts in a mixed catalog of resources, we recommend including an action link on the card so that users can easily recognize how to interact with it:
Catalogs with 15 or more quick starts should include a more complex toolbar with filtering functionality, presented as vertical filters on the side of the page.

* **Start:** Use if the quick start hasn't been started yet
* **Continue:** Use if the quick start is in progress
* **Restart:** Use if the quick start has already been completed
For quick starts in a mixed catalog of resources, we recommend including 1 of the following action links on the card, so that users can easily recognize how to interact with it. Only display 1 action on a card at a time:

There should only be one action displayed on a card at a time.
- **Start:** Use if the quick start hasn't been started yet.
- **Continue:** Use if the quick start is in progress.
- **Restart:** Use if the quick start has already been completed.

<img src="./img/mixed-catalog.png" alt="Mixed resource catalog" width="1062"/>

### Side panel
Quick starts use the [drawer component](https://www.patternfly.org/v4/components/drawer), which contains all the step-by-step instructions and tasks.
## Card

Quick starts are usually surfaced within a catalog as [clickable cards.](/components/card)

<img src="./img/card-elements.png" alt="Elements of a card" width="370"/>

1. **Icon:** An icon associated with the quick start topic. If no specific icon exists, use the rocket icon.
1. **Title:** The title (or display name) that briefly identifies the function that the quick start accomplishes. Avoid using the phrase “how to,” and instead begin the title with a gerund (verbs that end in ‘ing’).
Example: “Creating a Jupyter notebook”
1. **Labels:** [Filled labels](/components/label#filled-labels) communicate the estimated completion time and status of a quick start. If the quick start is presented in a mixed catalog of resources, a label can indicate the type of resource.
1. **Description:** A description that summarizes the quick start outcome in 4 lines or fewer, without truncating. Begin the description with an action verb.
Example: “Connect to Red Hat OpenShift Streams for Apache Kafka from a Jupyter notebook.”
1. **Prerequisites (optional):** A bulleted list of prerequisites, displayed in a popover, which outlines permissions needed to complete the tasks, and anything that must be pre-configured before starting the quick start. Avoid phrasing prerequisites as questions. The total number of prerequisites is listed in parentheses on the quick start card.
Example: “You have completed the "Getting started with Red Hat OpenShift Streams for Apache Kafka" quick start”

<img src="./img/prerequisites.png" alt="Example of prerequisites" width="395"/>

## Drawer
Quick starts use the [drawer component](/components/drawer) to contain all step-by-step instructions and tasks.

<img src="./img/side-panel-elements.png" alt="Side panel elements" width="449"/>

1. **Quick start title:** The quick start title that is shown on the card.
2. **Duration:** The estimated amount of time the quick start will take to complete.
3. **Close:** The close button allows the user to close the quick start at any time.
4. **Button bar:** The button bar allows the user to advance between quick start tasks. For task screens, the buttons are **Next**, **Back**, and **Restart**. For the intro screen, the only button is the **Start** button. On the completion screen, the buttons are **Close**, **Back**, and **Restart**.


3. **Close:** The close button, which allows users to exit the quick start at any time.
4. **Button bar:** The button bar, which allows users to advance between quick start tasks.
- For task screens, the buttons are **Next**, **Back**, and **Restart**.
- For the intro screen, the only button is the **Start** button.
- On the completion screen, the buttons are **Close**, **Back**, and **Restart**.

Everything is contained in the drawer and remains anchored to the right, allowing the user to follow the steps without blocking any parts of the UI. The drawer does not overlay the UI and instead pushes it to the left, including the masthead. This prevents any modals or side panels within the UI from covering the quick start instructions. The side panel is also resizable.
The drawer does not overlay the UI and instead pushes it to the left, including the masthead. It can be resized as needed. Everything is contained in the drawer and remains anchored to the right, allowing the user to follow the steps without blocking any parts of the UI. This prevents any modals or side panels within the UI from covering the quick start instructions.

<img src="./img/side-panel.png" alt="Side panel" width="1680"/>

<img src="./img/side-panel-resized.png" alt="Resized side panel" width="1680"/>

#### Introduction screen
### Introduction screen
The first screen of any quick start is the introductory screen, which includes most of the information from the quick start card.

A quick start introduction provides a concise and informative description of what the quick start accomplishes. A long introduction can overwhelm the user. Keep the introduction to a maximum of 4-5 sentences.

Write about what the user will do, not about the quick start itself. For example, instead of “This quick start will teach you how to deploy an application”, write “You will complete an application deployment in this quick start”.

<img src="./img/introduction-screen.png" alt="Introduction screen" width="449"/>

#### Tasks
Tasks consist of 2-10 steps, which walk the user through the UI to complete the goal of the task.
### Tasks
Tasks are high-level objectives users complete to accomplish the quick start’s overall goal. Task components include the title, description, failed task help, and a summary. Each task consists of 2-10 steps that help users navigate through the UI to complete the task goal.

<img src="./img/task.png" alt="Example task" width="449"/>

#### Check your work
The check your work module is shown at the bottom of the side panel for each task and helps the user validate that they have completed the task. You can choose to make the check your work module required or optional. Validation questions should be yes/no questions, allowing the user to select the radio button with the appropriate response.
#### Task title

Each individual task must have a title. When naming a specific task, the title reflects what it accomplishes. Write the title as a statement (rather than a “how to” tutorial). Each title should begin with an action verb (such as connect, save, remove, create, launch, and so on) that indicates the specific action the task completes, followed by the title of the product it concerns.

#### Task description

In the task description, explain the importance of the task for the user. When writing a task description, begin with a call to action, or a statement that identifies a desired action or outcome. Then write a brief statement that explains how the user will accomplish the task and introduces the task’s steps.

**Example:** Notebooks and applications need the connection information for your {product-title} instance. Follow these steps to save the required information for later use… To obtain connection information to {product-title}:”

Keep your product terminology capitalization consistent.

#### Task steps

Steps are a sequenced list of actions to guide the user through completing a larger task. Make the steps concise and easy to follow, beginning where the user is when they access the quick start in the user interface. For example, you don’t need to instruct the user to log into the tool, because they are already logged in and interacting with the quick start.

When writing individual steps, use the word “click” to refer to buttons and labels, and use “select” to refer to check-boxes, drop-down menus, and radio buttons.

**Example:** “Select an application from the options provided in the drop-down menu.”

#### Task instructions

Instructions refers to a line in the quick start template that allows the user to verify if they’ve completed the task successfully.

Remember to clearly distinguish between a user action and additional information on product functionality. Instructions are written as a question, and users should be given context to how it relates back to the task at hand.

**Example:** “To verify that you have launched the Jupyter notebook: Do you see a message in the page that says **The server is starting up**?“

#### Failed task help

Failed task help refers to a line in the quick start template where you can add a failed task message. The text you enter here alerts a user to an incomplete or failed portion of their task. A failed task notification can simply say, “This task is not verified yet. Try the task again.”, or it can include more context.

#### Task summary

Quick starts have 2 potential task summaries: success or failure. You can either congratulate the user on completing their task, or notify the user that something is impeding their completion and to try again.

**Success:** Write a short sentence that tells the user that they have finished their task. It is best to use the personal pronoun ‘you’ in these statements. For example, “Congratulations, you have launched JupyterHub.”

**Failure:** Notify the user that their task failed, and encourage them to try the task again. Avoid using the personal pronoun ‘you,’ because it places unnecessary blame on the user. If possible, provide the user with a brief suggestion as to why their task may not have succeeded, or a suggestion as to what they can check if it continues to fail. For example, “Try these steps again.”


### “Check your work” module

The “check your work” module, which can be required or optional, helps users confirm that they’ve completed a task. The module is shown at the bottom of the side panel for each task. Validation questions should be yes/no questions, allowing the user to select the radio button with the appropriate response.

<img src="./img/check-your-work.png" alt="Check your work module" width="431"/>

If a user selects **Yes**, the check your work module and associated task header turn green. The task header icon becomes a checkmark.
If a user selects **Yes**, the module and associated task header turn green. The task header icon becomes a checkmark.

<img src="./img/task-yes.png" alt="Check your work module with Yes selected" width="449"/>

If a user selects **No**, the check your work module and associated task header turn red. The task header icon becomes an **X**. When possible, explain what a user must do to complete the task, or link to relevant documentation.
If a user selects **No**, the module and associated task header turn red. The task header icon becomes an **X**. When possible, explain what a user must do to complete the task, or link to relevant documentation.

<img src="./img/task-no.png" alt="Check your work module with No selected" width="449"/>

## Content guidelines
Here are some general guidelines to follow when authoring quick start content:
* Clearly state the outcome at the beginning of the quick start and provide brief context to explain why the user is completing the tasks.
* Avoid screen captures. They require regular maintenance and can potentially lead to issues around accessibility and page loading.
* Keep content minimal to avoid a wall of text that can overwhelm users and prevent easy skimming.
* (Optional) As needed, provide a carefully curated set of links at specific points in the quick start:
* Provide links within a quick start task if the user is likely to need or want more conceptual or reference information.
* Provide links at the end of quick starts if the user is likely to need or want additional technical information upon completion.
* Provide links in the check your work module when a user answers **No** if more robust information can help the user understand what actions they must take to complete the task.
## Content considerations

For more specific quick start content guidelines, refer to _Best practices for writing quick starts_ on [UXD Hub](https://www.uxd-hub.com/entries/resource/best-practices-for-writing-quick-starts). The [Red Hat OpenShift documentation](https://docs.openshift.com/container-platform/4.16/web_console/creating-quick-start-tutorials.html) contains similar guidelines geared toward Red Hat OpenShift.
Quick starts can use a more conversational, informal tone. Aim for a “fairly conversational” style, which is authoritative but encouraging and approachable.

## Quick starts in context
To achieve a more conversational tone, try the following:

<img src="./img/qs-context.png" alt="A quick start in context of a UI" width="1680"/>
- Use the second person (“you”).
- Example: “In minutes, you can set dates, document your first user story, assign a task or two, and dive into the code.
- Write shorter, simpler sentences, and keep content minimal to support easy skimming and avoid overwhelming users.
- Avoid unnecessary technical jargon, and define terms and phrases that might be unfamiliar to new users.
- Use contractions (you’ll, can’t, you’ve) to strike an informal tone, and to save space.
- Avoid sentence fragments, poor grammar, and excessive punctuation, which can distract from the task.

In addition to being conversational, you should adhere to the following guidelines to ensure that your quick start is useful and effective for all users:

- Always keep in mind that your content must be appropriate for a global audience.
- Clearly state the outcome at the beginning of the quick start and provide brief context to explain why the user is completing the tasks.
- Avoid screen captures. They require regular maintenance and can potentially lead to issues around accessibility and page loading.
- (Optional) Help users stay in the quick start by including necessary information within the quickstart and avoiding outbound links. As needed, provide a carefully curated set of links at specific points in the quick start. You may want to provide links:
- Within a quick start task, if users could benefit from additional conceptual or reference information.
- At the end of quick starts, if users could benefit from additional technical information upon completion.
- Within the [“check your work” module](#check-your-work-module), after a user answers **No**, if more robust information can help them understand the actions they must take to complete the task.

For more specific quick start content guidelines, refer to [“Best practices for writing quick starts” on UXD Hub](https://www.uxd-hub.com/entries/resource/best-practices-for-writing-quick-starts). The [Red Hat OpenShift documentation](https://docs.openshift.com/container-platform/4.16/web_console/creating-quick-start-tutorials.html) contains similar guidelines, specifically for Red Hat OpenShift.
Loading

0 comments on commit dab3886

Please sign in to comment.