Skip to content

An interactive price component using HTML slider, accessible toggle and aria-live regions || HTML + SCSS + Vanilla JS || Frontend Mentor challenge

Notifications You must be signed in to change notification settings

AgataLiberska/interactive-pricing-component

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Frontend Mentor - Interactive pricing component solution

This is a solution to the Interactive pricing component challenge on Frontend Mentor. Frontend Mentor challenges help you improve your coding skills by building realistic projects.

Table of contents

Overview

The challenge

Users should be able to:

  • View the optimal layout for the app depending on their device's screen size
  • See hover states for all interactive elements on the page
  • Use the slider and toggle to see prices for different page view numbers

Screenshot

Links

My process

Built with

  • Semantic HTML5 markup
  • ARIA attributes for accessibility
  • CSS custom properties
  • Flexbox
  • CSS Grid
  • Mobile-first workflow
  • Vanilla JavaScript

What I learned

  • How to create an accessible toggle using input type="radio"

  • How to add custom styles to input type="range" to ensure they work across major browsers:

@mixin track() {
	width: 100%;
	height: 0.5rem;
	border-color: transparent;
	border-radius: 5px;
	color: transparent;
	cursor: pointer;
}

@mixin thumb() {
	-webkit-appearance: none;
	height: $thumb-size;
	width: $thumb-size;
	margin-top: calc(#{$track-height} / 2 - #{$thumb-size} / 2);
	background-color: $slider-thumb;
	background-image: url('/images/icon-slider.svg');
	background-repeat: no-repeat;
	background-position: center;
	border: none;
	border-radius: 50%;
	cursor: pointer;
}
  • How to add custom focus style to the slider to ensure they work across major browsers:
.pricing__slider {
    &:focus {
        outline: 0;
    }

    &:focus::-webkit-slider-thumb {
        background-color: $slider-thumb-active;
        box-shadow: 0 0 0 1px #fff, 0 0 0 0.25rem $slider-bar;
    }

    &:focus::-moz-range-thumb {
        background-color: $slider-thumb-active;
        box-shadow: 0 0 0 1px #fff, 0 0 0 0.25rem $slider-bar;
    }
}
  • How to use ARIA live regions to let screen reader users know about changes on the page. I think I now understand better how to approach accesibility issues. Initially, I used aria-live attributes on the elements which where dynamically updated. This caused certain issues: for example, the number of page views was not read out correctly, and the price was read as dollar {number} slash month. Of course, this is better than nothing, but could be confusing to screen reader users. Then, I added aria-labels to those elements which were dynamically updated with the content, which was an improvement, however some issues remained. Namely, when the billing frequency was switched from monthly to annual (or the other way round), the price would be updated and the change was read out, but pageviews did not change and so would not be read out. Again, this may not be a crucial issue but it would mean that the page would be more difficult to navigate for screen reader users than for sighted users. I decided to hide the visible dynamic content to screen reader and add a visually hidden element to hold that data to ensure that it is read correctly and that when any change is made within the form, full information is accessible to screen reader users.

Continued development

I would like to continue learning about accessibility on the web and ARIA attributes.

Useful resources

The following CSS Tricks articles helped me style the range input:

I learnt how to create an accessible toggle based on this Frontend Mentor Solution by @GraceSnow:

Author

Acknowledgments

Massive thanks to Grace Snow who made the effort to answer my many questions about making this accessible!

About

An interactive price component using HTML slider, accessible toggle and aria-live regions || HTML + SCSS + Vanilla JS || Frontend Mentor challenge

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published