Revisiting form elements in Vanilla Framework
Lyubomir Popov
on 12 December 2022
Over the years, we’ve identified a number of areas for improvement when it comes to the basic building blocks of a form – inputs, buttons, etc:
- Long-standing complaints that inputs and buttons are too similar and therefore hard to distinguish
- “Noisiness” of long forms caused by the presence of borders around all sides of inputs and buttons
Last cycle, our proposal for updated form elements was discussed and approved, and in this iteration, we worked on implementing it in Vanilla, our front-end framework.
Before Vanilla 3.9:
After Vanilla 3.9:
- We’ve reduced the number of borders (all around) to the minimum required to satisfy WCAG contrast ratio requirements for interactive elements
- We’ve removed round corners from buttons and other elements, as part of a wider push to align better with the work of our Brand team
- We’ve introduced subtle transitions when interacting with form elements
This update also affects components that build on the functionality of form elements, like our search and Filter component:
The updated style was released as part of Vanilla 3.9.0 release.
Version 3.9.0 has just been released. You can see the updated form elements in action here
Talk to us today
Interested in running Ubuntu in your organisation?
Newsletter signup
Related posts
A look into Ubuntu Core 26: Cloud-powered edge computing with AWS IoT Greengrass and Azure IoT Edge
Welcome to this blog series which explores innovative uses of Ubuntu Core. Throughout this series, Canonical’s Engineers will show what you can build with...
CVE-2026-46333 (ssh-keysign-pwn) Linux kernel vulnerability mitigations
An information disclosure security vulnerability in the Linux kernel was publicly disclosed on May 15th, 2026. The vulnerability was reported by Qualys and...
Canonical launches Ubuntu Core 26
Ubuntu Core 26 introduces precise Linux builds, optimized OTA updates, live kernel patching, and enhanced hardware-backed protection for mission-critical...