Skip to content

PasswordInput ⚠️ Experimental

The PasswordInput component can be used imported from:

Playground

Parameters

Events

This component has events. Check the documentation about how to use the events.

NamePayloadDescription
changestringReturns the new value of the model
entervoidTriggered when "Enter" in pressed
restartedvoidEmitted on value reset
blurvoidEmitted on blur
validatedbooleanEmitted when the validation status changes

Slots

This component has slots. Check the documentation about how to use the slots.

NameTagsDescription
defaultspan

Parameters use

Check the documentation about how to use the parameters.

config

The config parameter is used to set the shape of the input between lined and shaped. Being omitted will render the default shaped shape.

label

The label parameter is used to set the text label of the component. Make sure you always use it.

Can also use the label slot:

Password input

model

Attention!

If you hardcode this value, it will not be reactive and the selection won't change. Use a variable instead and, ideally, a closed loop.

The model parameter is used to set the value for the input

name

The name parameter is used to set the name of the component. This is useful when the component is part of a form.

help-text

The help-text parameter is used to provide additional assistance to the user.

It can also use the help-text slot:

Help text

Flags

disabled

The disabled parameter is used to block the interaction with the component. Not to be confused with readonly.

required

The required parameter is used to set the component as required.

The default text adapts to the localization:

readonly

The readonly parameter is used to set the input in a read-only state. It's commonly used to display information.

invalid ⚠️ Experimental

The invalid parameter is used to force the component to be invalid.

The default text adapts to the localization:

Special uses

Security level UI

We can use some extra Javascript and CSS to achieve a more visual validation interface for our password inputs. In this case we bind the input model and we use the help-text slot to present a discretized progress made with <div> tags that are activated with a data-active attributed that is set depending of the model length. We make the input invalid if the model length is 0.

So with some extra JavaScript added to this HTML:

And some SCSS styling, we achieve the functionality:

scss
---
title: PasswordInput
titleTemplate: Guidelines
description: ZDS components
---

<!-- markdownlint-disable MD025 -->

# PasswordInput

<script setup>
  import { useGuidelinesImports } from '../_fragments/guidelines_imports';
  
  import { meta } from './password_input.meta';

  import '~web/inputs/z-password-input';
  
  const {
    DocsParams,
    DocsCardsCarousel,
    DocsCodeAndRender,
    DocsImplementationSelector,
    DocsImplementationTable,
    DocsCustomTokens,
  } = useGuidelinesImports();
</script>

<style lang="scss" scoped>
  #header-sample {
    background-color: #fafafa;
    padding: var(--zs-300);
  }
</style>

<docs-implementation-selector :meta/>

<section id="header-sample" z-center>
  <z-password-input label="Password input"/>
</section>

Password input provide a way for the user to securely enter a password. The element is presented as a one-line
plain text editor control in which the text is obscured so that it cannot be read, usually by replacing each
character with a symbol such as the asterisk ("*") or a dot ("•").

## Implementations

<docs-implementation-table :meta/>

## Parameters

<!--@include: ../_fragments/params_info.md-->

<docs-params :meta>
<!--@include: ../_fragments/input_config_param.md-->
<!--@include: ../_fragments/base_input_params.md-->
</docs-params>

## From Figma to code

...

<!-- ![alt text](./assets/Button/FigmaProps.png)

  - `z-theme`: Default (`light`) or Alternate (`dark`) -->

## Customization

<!--@include: ../_fragments/customization.md-->

<!-- <docs-code-and-render sameCode :lang z-flex="col:100">
</docs-code-and-render> -->

## Accessibility

...

<!--@include: ../_fragments/related_components.md-->

Methods

reset()

We can all the reset() method of the WebComponent in order to reset the value. This will clean the internal states and emit the nullable value with the change event, plus a restarted event:

In this example, the button triggers the method:

Value:  undefined

Browser support

Detected engine:  

  • Chromium

  • Webkit

  • Gecko

HTML Examples

CodeSandbox example