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

docs: add TRG for UX/UI styleguide #865

Merged
merged 5 commits into from
Jul 25, 2024
Merged
Show file tree
Hide file tree
Changes from 4 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
42 changes: 0 additions & 42 deletions docs/release/trg-0/trg-1-09.md

This file was deleted.

3 changes: 3 additions & 0 deletions docs/release/trg-9/_category_.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"label": "TRG 9 - UX/UX Styleguide"
}
76 changes: 76 additions & 0 deletions docs/release/trg-9/trg-9-01.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
---
title: TRG 9.01 - UX consistency / Styleguide for UI
sidebar_position: 1
---

| Status | Created | Post-History |
|--------|---------------|----------------------------------------------------------|
| Active | 22-Jul-2024 | Finalize TRG |
| Draft | 25-April-2024 | Added new styleguide criteria - initial version |
| Draft | 10-Jan-2024 | Transferred from Release Acceptance Criteria into TRG |

## Introduction

The purpose of this guideline is to ensure that business applications with user interfaces adhere to the established UI/UX styleguide which is collected in the [Portal Shared Components](https://github.com/eclipse-tractusx/portal-shared-components.git). It outlines all the relevant criteria that must be checked when releasing a new product version. A crosscheck with every pull request is not just optional, but it is a "MUST" criteria to ensure the quality and consistency of the user interfaces of each product/component. This step is crucial in maintaining the overall standard and enhancing as well as standardizing the user experience.

## Objective

The objective is to ensure consistency, usability, and adherence to design standards across all user interfaces within the business application.

## Criteria (Basic)

### Styleguide Compliance

- All user interface elements must match the predefined styles. This includes fonts, colors, button styles, input fields, and layout grids.
- [Storybook](https://eclipse-tractusx.github.io/portal-shared-components)
matbmoser marked this conversation as resolved.
Show resolved Hide resolved
- Icons and imagery should be consistent (note that images and icons must be open source compliant and license files are needed)
- [Image, Graphics & Diagrams](https://github.com/eclipse-tractusx/portal-assets/blob/v2.0.0/docs/developer/Technical%20Documentation/Others/Images%2C%20Graphics%20and%20Diagrams.md)

### Responsiveness and Compatibility

- The application must be fully responsive and provide a seamless experience across different devices and screen sizes.
- The application must be tested with multiple browsers - in case any browsers are not supported, the same must be documented.

### Accessibility

- The application must meet the minimum accessibility standards (e.g., WCAG 2.1).
- Optional: All user interface components must be navigable and usable with keyboard-only controls.
- Optional: Screen reader compatibility must be tested and ensured.

### User Experience

- The application's user flow must align with the user experience outlined in the styleguide.
- Interactive elements must provide feedback to the user, such as hover states, active states, and disabled states, as per the styleguide.
matbmoser marked this conversation as resolved.
Show resolved Hide resolved
- The application must have a user help area which is linked to the current deployed application version.
- The application must have a loading state or spinner component that indicates when data is being fetched or processed.
- The application must have a mechanism in place to prevent the user interface from being triggered a second time by the user while running loading processes (POST Data). This is important to avoid any unintended actions or disruptions caused by multiple triggers. By implementing this safeguard, the application can ensure a smooth and reliable user experience during loading processes.
- The application must have a notification or alert component that displays important messages or updates to the user (success as well as errors).

### Typography and Readability

- Text must adhere to the styleguide's typography standards, including font sizes, line heights, and font weights.
- Text contrast must meet the minimum contrast ratios for readability.

### Localization and Internationalization

- The application/user interface must support multiple languages, allowing users to switch between different language options.
matbmoser marked this conversation as resolved.
Show resolved Hide resolved
- Text in the user interface must be properly localized and displayed in the correct format for the target audience.

### Animation and Transitions

- Any animations or transitions must be smooth, enhance the user experience, and conform to the styleguide's principles.

### Others

- The application should include a footer component that contains important links, such as terms of service, privacy policy, and contact information.
matbmoser marked this conversation as resolved.
Show resolved Hide resolved

---

### STYLEGUIDE RELATED LINKS

> - [Storybook](https://eclipse-tractusx.github.io/portal-shared-components)
> - [NPM library](https://www.npmjs.com/package/@catena-x/portal-shared-components)
> - [Source code](https://github.com/eclipse-tractusx/portal-shared-components.git)
> - [Image, Graphics & Diagrams](https://github.com/eclipse-tractusx/portal-assets/blob/v2.0.0/docs/developer/Technical%20Documentation/Others/Images%2C%20Graphics%20and%20Diagrams.md)

Please note, you can use the publicly available [Portal Shared Components NPM library](https://www.npmjs.com/package/@catena-x/portal-shared-components) (React supported) to easily develop applications that are in-line with the Tractus-X style guidelines.
Loading