Bi-directionality
Digital experiences in bi-directional languages, also commonly referred to as "RTL" (right-to-left) languages, often require mirroring the interface to accommodate the right-to-left reading pattern.
data:image/s3,"s3://crabby-images/e15f6/e15f67e1e03d90e7105eb498056d4de2eaff92f5" alt="Image illustrating bi-directional guidelines in mirrored right-to-left and left-to-right languages."
Table of contents#
Introduction#
In digital experiences, languages that are based on Latin script (e.g., English and French), Cyrillic script (e.g., Russian and Bulgarian), Chinese and Japanese* are consistently read and written from left to right. Languages that are based on certain writing systems like Arabic (e.g., Arabic, Persian, and Urdu) and Hebrew (Hebrew and Yiddish), are mostly read and written from right to left. These languages are called “bi-directional,” or are also commonly referred to as “RTL” (“right-to-left”) languages.
Digital experiences for these languages should be mirrored to follow the same right-to-left reading pattern. UI mirroring is the process of positioning components in the opposite side of the interface, which creates, as the term suggests, a mirror-like effect.
*Chinese and Japanese, especially in printing, books, and publications, maintain their top-to-bottom, right-to-left writing/reading patterns, but are mainly using the left-to-right system in digital experiences.
User interface mirroring#
Mirror individual components#
Components and their constituting parts are affected by user interface mirroring. Mirroring guidelines for each component are available on their respective pages, when applicable.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/1ee68/1ee682b4b8f12848a75b43a5bbdf5580369053ea" alt="Key example showing the correct usage of a bi-directional component."
Don't mirror components that represent time#
Components that are used to represent the concept of time should not be mirrored (e.g., a video player).
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/882e1/882e130ad92d158bd513c7f6e582fb2da472672b" alt="Key example showing the incorrect usage of a bi-directional component."
Mirror composite images with directional flow#
Composite images that depict a directional flow or convey a linear narrative require a dedicated bi-directional version since the sense of the narrative, reading from right to left, could appear reversed.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/60399/60399117938212747968fc747b55f6ad902efb5e" alt="Key example of correct usage of bi-directional flow in a linear narrative."
Iconography mirroring#
Mirror icons that represent movement#
Icons that depict horizontal movement (e.g., back icon) should be mirrored to follow the flow of the right-to-left interface.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/41b42/41b429d6dc7f25869c7e7f795d6fd8f29e20e37c" alt="Key examples of mirror icons that represent movement."
Don't mirror icons that represent time#
Icons that refer to the passage of time (e.g., clock icon) should not be mirrored in right-to-left interfaces.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/fe559/fe5598f34c77da5d20cf396806545ba5600aba45" alt="Key example of incorrectly mirroring icons that represent time."
Don't mirror checkmarks#
Checkmarks are never mirrored in right-to-left interfaces.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/a8920/a89201a1a0c6bead87840e9dbc634faf70ca970d" alt="Key example of illustrating not to mirror the checkmark component."
Don't mirror slashes#
Slashes are never mirrored in right-to-left interfaces.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/b84b0/b84b0a99210ac9247385b7b797a5854fc562bf12" alt="Key example illustrating not to mirror slash marks."