iwb-serenity-password
v0.3.0
Published
A Vue password component for iwb_serenity
Downloads
16
Maintainers
Readme
Password
A password field as a form of a Vue component for Serenity (Immoweb’s design system).
It includes a password reveal button.
Table of contents
Summary usage
In a Vue component:
<template>
<form>
<!-- fields, buttons… -->
<iw-password
v-model="password"
name="login-password"
label="Password"
show-password-label="Show password"
password-shown-text="Password is shown"
password-hidden-text="Password is hidden"
/>
</form>
</template>
<script>
import Vue from "vue";
import iwPassword from "iwb-serenity-password";
export default Vue.extend({
data: function() {
return {
password: "", // bound to component with `v-model`
};
},
});
</script>
Additionally, you can check the demo app.
Installation
This component works in project including:
- Vue 3 (for other versions of Vue, see
iwb-serenity-password
) - Serenity 2, for the base CSS used by this package styles.
- Run this command in your terminal:
npm install iwb-serenity-password
- Register the component in the
<script>
part of a Vue component:
import { defineComponent } from 'vue'
import iwPassword from "iwb-serenity-password";
export default defineComponent({
components: {
iwPassword: Password, // register <iw-password>
},
});
- Add the styles after an import of Serenity:
$public-path: "/public";
@import "iwb_serenity/src/scss/serenity";
@import "iwb-serenity-password"; // this import the styles
⚠️ Projects bundled with Vite should use @import "iwb-serenity-password/scss";
(because Vite doesn’t seem to handle sass
nor style
fields in libraries package.json
).
Props
The attributes accepted by the component.
- Mandatory:
v-model
,name
,label
,show-password-label
,hide-password-label
. - Optional:
in-modal
,error
.
v-model
(string)
Learn more about v-model
in Vue’s documentation.
name
(?string)
The name
parameter in <input type="password" name="this-value">
. It defaults to password
.
autocomplete
(?string)
The autocomplete
parameter in <input type="password" autocomplete="this-value">
. It defaults to current-password
, as it’s the most common use case. For a new password or a password change, new-password
is recommended.
label
(string)
The displayed label of the field.
show-password-label
(string)
The label of the password revealer button.
password-hidden-text
(string) and password-shown-text
(string)
The text announced by screen readers when the password isn’t revealed (password-hidden-text
) or revealed (password-shown-text
).
in-modal
(?boolean)
Default value: false
.
When set to true
, changes the field background from white to primary-blue-llll
.
error
(?string)
Default value: an empty string.
When non-empty, an error message associated to the password field.
Events
You don’t need to listen to any event (@input="someAction"
) when using v-model
.
If you still need to listent to its unique event (input
), be aware that the component only emits it when its internal <input type="password">
element fires the native change
event.
Typically, this happens on blur
, when the field loses its focus
. The component doesn’t fire an event for each key the user types.
Accessibility
A password is always a required field, so the user expects it to be required. To indicate that requirement to assistive technologies, the component is using aria-required
.
The required
attribute was dismissed for two reasons:
- It has accessibility flaws: when submiting a login form with an empty password, the password field is focused and the screen reader (VoiceOver) announces “please fill this field” but doesn’t announce the name of the field.
- Currently, our apps only rely on server-side validation.
The field is marked as invalid (using aria-invalid
) only when an error message is provided. When it is, the error message is appended to the field accessible label (using aria-labelledby
).
The password reveal button is only visible (and focusable) when the field isn’t empty. Its label never changes (“show password”), but the announcement varies when the password is shown/hidden:
- the
<button>
makes use ofaria-pressed
; - a live region (
aria-live="polite"
) is explicit about the state: (e.g. “The password is visible|hidden”).
More background, resources and discussions in the pull request.
Changelog
See CHANGELOG.md.
Development
- Clone the repository:
git clone [email protected]:axel-springer-kugawana/iwb_serenity.git
- Go to this folder:
cd iwb_serenity/packages/vue-password
- Install dependencies:
npm install
- You can help preview your changes made in
/src
by running the demo app:
npm run serve
You can also test the local version of the package in a local app by using the npm link
feature, as described in the instructions in the root repository documentation.
Be aware that it may not work for testing the styles, and that the project that will use the local version of the package will need to update its symlinks configuration. When using vue-cli
, in config.vue.js
:
module.exports = {
// many things…
// add this:
configureWebpack: {
/**
* Fix double Vue (or other packages) import when developing and
* locally testing a component (using `npm link`) meant to be
* packaged. A warning was printed in the browser console:
*
* `[Vue warn]: Invalid VNode type: Symbol(Comment)`
*
* https://github.com/vuejs/core/issues/2064#issuecomment-797365133
*/
resolve: {
symlinks: false,
alias: {
vue: path.resolve('./node_modules/vue')
},
},
},
}
(to be documented: add tests)
Submit your changes by opening a pull request.
License
The iwb-serenity-password package is open-sourced software licensed under the MIT license.