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

fix(pie-docs): DSW-2327 content update changes in text input documentation #1962

Merged
merged 6 commits into from
Oct 8, 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
5 changes: 5 additions & 0 deletions .changeset/gorgeous-squids-design.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"pie-docs": patch
---

[Fixed] - Content update changes in the text input documentation
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
76 changes: 50 additions & 26 deletions apps/pie-docs/src/components/text-input/overview/overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ An icon, text, or symbol can be added to visually support the input. Leading and

#### Alphanumeric

Use when text input requires clarification of the input format, such as a symbol or unit of measure.
Use when text input requires clarification of the input format, such as a symbol or unit of measure. It is recommended to use less than 4 characters in leading or trailing content.

{% contentLayout %}
{% contentItem %}
Expand Down Expand Up @@ -127,8 +127,13 @@ Use when text input requires clarification of the input format, such as a symbol
Payment method is only available in trailing content.
Use when a text input requires a card number to be entered, and reflect the card entered by the user.

{% notification {
type: "warning",
message: "This modifier only exists in design, not in development. The functionality can be handled by consumers if required."
} %}

{% contentPageImage {
src:"../../../assets/img/components/text-input/modifiers-paymentmethod.svg",
src:"../../../assets/img/components/text-input/modifiers-payment-method.svg",
alt: "Text input with payment method modifier.",
width: "256px"
} %}
Expand Down Expand Up @@ -222,12 +227,28 @@ In forms, aim to standardise widths for text inputs to enhance readability for u

### Placeholder

Use clear placeholder text for the text input trigger so that users understand the purpose.
Placeholder text is optional, it should not contain important information, and should only be displayed if it is useful to the user.
- Use clear placeholder text for the text input trigger so that users understand its purpose, e.g. example of the input data.
- Placeholder text should not be used as a label
- For additional information or instruction, use [assistive text](/components/assistive-text/) instead.

{% contentPageImage {
src:"../../../assets/img/components/text-input/content-placeholder.svg",
alt: "Text input with placeholder content.",
width: "256px"
{% usage {
do: {
type: usageTypes.image,
items: [{
src: "../../../assets/img/components/text-input/content-placeholder-do.svg",
width: "176px",
alt: "Example of a properly used placeholder: 'MM/YY' for an expiry date field."
}]
},
dont: {
type: usageTypes.image,
items: [{
src: "../../../assets/img/components/text-input/content-placeholder-dont.svg",
width: "234px",
alt: "Example of an incorrectly used placeholder: 'Username' and 'Must contain 8 characters' as labels for input fields"
}]
}
} %}

### Input types
Expand All @@ -237,16 +258,16 @@ Use clear placeholder text for the text input trigger so that users understand t
<h4>Alphanumeric</h4>
<p>Both letters, numbers and certain special characters are allowed, for the majority of use-cases this will be used.</p>
{% contentPageImage {
src: "../../../assets/img/components/text-input/content-inputtypes-alphanumeric.svg",
src: "../../../assets/img/components/text-input/content-input-types-alphanumeric.svg",
width: "256px",
alt: "Text input with alphanumeric content."
} %}
{% endcontentItem %}
{% contentItem %}
<h4>Numeric</h4>
<p>Only numeric values can be entered, for use-cases such as zip code, phone number, card number.</p>
<p>Only numeric values can be entered, for use-cases such as zip code, phone number, card number. However, some browsers accept dots, commas and the letter 'e' in numeric input.</p>
{% contentPageImage {
src: "../../../assets/img/components/text-input/content-inputtypes-numeric.svg",
src: "../../../assets/img/components/text-input/content-input-types-numeric.svg",
width: "135px",
alt: "Text input with numeric content."
} %}
Expand All @@ -255,7 +276,7 @@ Use clear placeholder text for the text input trigger so that users understand t
<h4>Password</h4>
<p>Characters are replaced with dots that hide the password text by default.</p>
{% contentPageImage {
src: "../../../assets/img/components/text-input/content-inputtypes-password.svg",
src: "../../../assets/img/components/text-input/content-input-types-password.svg",
width: "256px",
alt: "Text input with password content."
} %}
Expand All @@ -264,6 +285,11 @@ Use clear placeholder text for the text input trigger so that users understand t

### Formatting

{% notification {
type: "warning",
message: "This is the suggested pattern for development. The functionality can be handled by consumers if required."
} %}

#### Date

A date format can be applied to date entries such as DOB, expiry date, start/end date - a slash is automatically displayed when the user enters a value that fits a date format. The user can only enter numeric values in a date text input.
Expand All @@ -281,7 +307,7 @@ Specifically for card number entry, the card number is displayed in groups of 4
The user can enter a maximum of 19 digits.

{% contentPageImage {
src:"../../../assets/img/components/text-input/content-formatting-cardnumber.svg",
src:"../../../assets/img/components/text-input/content-formatting-card-number.svg",
alt: "Text input with date formatting.",
width: "790px"
} %}
Expand Down Expand Up @@ -311,30 +337,30 @@ If the string exceeds its available visible bound, the content overflows to the

---

## Behavior
## Behaviour

### Assistive text

If space is limited, long assistive text may wrap to multiple lines, especially if there are multiple text inputs sitting side by side. Every text input should have its own assistive text, even if the content is identical.

{% contentPageImage {
src:"../../../assets/img/components/text-input/behaviour-assistivetext.svg",
alt: "Example of assistive text behavior.",
src:"../../../assets/img/components/text-input/behaviour-assistive-text.svg",
alt: "Example of assistive text behaviour.",
width: "300px"
} %}

### Payment method

{% notification {
type: "warning",
message: "This is the suggested pattern for development. This functionality, if required, is handled by pillar engineers."
message: "This is the suggested pattern for development. The functionality can be handled by consumers if required."
} %}

When using the payment method, the specific card icon will appear as soon as the system detects the type of card entered by the user.

{% contentPageImage {
src:"../../../assets/img/components/text-input/behaviour-paymentmethod.svg",
alt: "Example of payment method behavior.",
src:"../../../assets/img/components/text-input/behaviour-payment-method.svg",
alt: "Example of payment method behaviour.",
width: "884px"
} %}

Expand All @@ -348,31 +374,31 @@ Outlines the atomic level interactive elements for the component.
{% contentItem %}
<h4>Default</h4>
{% contentPageImage {
src: "../../../assets/img/components/text-input/interactivestates-default.svg",
src: "../../../assets/img/components/text-input/interactive-states-default.svg",
width: "256px",
alt: "Default interactive state example."
} %}
{% endcontentItem %}
{% contentItem %}
<h4>Hover</h4>
{% contentPageImage {
src: "../../../assets/img/components/text-input/interactivestates-hover.svg",
src: "../../../assets/img/components/text-input/interactive-states-hover.svg",
width: "256px",
alt: "Interactive state example when input is hovered over."
} %}
{% endcontentItem %}
{% contentItem %}
<h4>Focus</h4>
{% contentPageImage {
src: "../../../assets/img/components/text-input/interactivestates-focus.svg",
src: "../../../assets/img/components/text-input/interactive-states-focus.svg",
width: "256px",
alt: "Interactive state example when input is focused."
} %}
{% endcontentItem %}
{% contentItem %}
<h4>Disabled</h4>
{% contentPageImage {
src: "../../../assets/img/components/text-input/interactivestates-disabled.svg",
src: "../../../assets/img/components/text-input/interactive-states-disabled.svg",
width: "256px",
alt: "Interactive state example when input is disabled.",
variant: "secondary"
Expand All @@ -381,15 +407,15 @@ Outlines the atomic level interactive elements for the component.
{% contentItem %}
<h4>Read only</h4>
{% contentPageImage {
src: "../../../assets/img/components/text-input/interactivestates-readonly.svg",
src: "../../../assets/img/components/text-input/interactive-states-readonly.svg",
width: "256px",
alt: "Interactive state example in read only mode."
} %}
{% endcontentItem %}
{% contentItem %}
<h4>Error</h4>
{% contentPageImage {
src: "../../../assets/img/components/text-input/interactivestates-error.svg",
src: "../../../assets/img/components/text-input/interactive-states-error.svg",
width: "256px",
alt: "Interactive state example showing an error."
} %}
Expand All @@ -400,8 +426,6 @@ Outlines the atomic level interactive elements for the component.

## Examples

Outlines the atomic level interactive elements for the component.

### LTR examples

Here are some examples of text inputs in a left-to-right context:
Expand Down
Loading