Limited-time offer for the first 100 customers in 2025. Use code 2025SKY25 at checkout.
RTL
Learn how to enable support for right-to-left text in CoreUI for Bootstrap across our layout, components, and utilities.
Get familiar
We recommend getting familiar with CoreUI for Bootstrap first by reading through our Getting Started Introduction page. Once you’ve run through it, continue reading here for how to enable RTL.
You may also want to read up on the RTLCSS project, as it powers our approach to RTL.
Required HTML
There are two strict requirements for enabling RTL in Bootstrap-powered pages.
- Set
dir="rtl"
on the<html>
element. - Add an appropriate
lang
attribute, likelang="ar"
, on the<html>
element.
From there, you’ll need to include an RTL version of our CSS. For example, here’s the stylesheet for our compiled and minified CSS with RTL enabled:
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@coreui/[email protected]/dist/css/coreui.rtl.min.css" integrity="sha384-7gVs7bHSlfinuL2gDQSC2Q43rBtZh/WRIFxLlix0FP6sE5myH/LE3YpyQRsi4Zis" crossorigin="anonymous">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@coreui/[email protected]/dist/css/coreui.rtl.min.css" integrity="sha384-p9x4ABD+lFSqqwvbvPsdn4XfzjVwlINOHN2n1tKyFYzs3IwCvSPPS4YVCbnWha6T" crossorigin="anonymous">
Starter template
You can see the above requirements reflected in this modified RTL starter template.
<!doctype html>
<html lang="ar" dir="rtl">
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- Option 1: CoreUI for Bootstrap CSS -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@coreui/[email protected]/dist/css/coreui.rtl.min.css" integrity="sha384-7gVs7bHSlfinuL2gDQSC2Q43rBtZh/WRIFxLlix0FP6sE5myH/LE3YpyQRsi4Zis" crossorigin="anonymous">
<!-- Option 2: CoreUI PRO for Bootstrap CSS -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@coreui/[email protected]/dist/css/coreui.rtl.min.css" integrity="sha384-p9x4ABD+lFSqqwvbvPsdn4XfzjVwlINOHN2n1tKyFYzs3IwCvSPPS4YVCbnWha6T" crossorigin="anonymous">
<title>مرحبا بالعالم!</title>
</head>
<body>
<h1>مرحبا بالعالم!</h1>
<!-- Optional JavaScript; choose one of the two! -->
<!-- Option 1: CoreUI for Bootstrap Bundle with Popper -->
<script src="https://cdn.jsdelivr.net/npm/@coreui/[email protected]/dist/js/coreui.bundle.min.js" integrity="sha384-JdRP5GRWP6APhoVS1OM/pOKMWe7q9q8hpl+J2nhCfVJKoS+yzGtELC5REIYKrymn" crossorigin="anonymous"></script>
<!-- Option 2: CoreUI PRO for Bootstrap Bundle with Popper -->
<!--
<script src="https://cdn.jsdelivr.net/npm/@coreui/[email protected]/dist/js/coreui.bundle.min.js" integrity="sha384-XdSQk/ZjKuv9tj9ytdSleLWzwx2LfqEmk1fS0MI6SdZvPSU+h+G09HaUNTEbR5m5" crossorigin="anonymous"></script>
-->
<!-- Option 3: Separate Popper and CoreUI for Bootstrap JS -->
<!--
<script src="https://cdn.jsdelivr.net/npm/@popperjs/[email protected]/dist/umd/popper.min.js" integrity="sha384-I7E8VVD/ismYTF4hNIPjVp/Zjvgyol6VFvRkX/vR+Vc4jQkC+hVqc2pM8ODewa9r" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/@coreui/[email protected]/dist/js/coreui.min.js" integrity="sha384-c4nHOtHRPhkHqJsqK5SH1UkyoL2HUUhzGfzGkchJjwIrAlaYVBv+yeU8EYYxW6h5" crossorigin="anonymous"></script>
-->
</body>
</html>
Approach
Our approach to building RTL support into CoreUI comes with two important decisions that impact how we write and use our CSS:
-
First, as in CoreUI 3 we decided to build it with our own mixins This gives us full control and allows us to generate LTR and RTL separately, or if needed one stylesheet with both versions without any style’s duplicates.
-
Second, in CoreUI 3 we introduced a handful of directional classes ex.
mfs-auto
, but in CoreUI 4 we’ve simplified them ex.ms-auto
, and renamed all directional classes to adopt a logical properties approach. Most of you have already interacted with logical properties thanks to our flex utilities—they replace direction properties likeleft
andright
in favorstart
andend
. That makes the class names and values appropriate for LTR and RTL without any overhead.
For example, instead of .ml-3
for margin-left
, use .ms-3
.
Working with RTL, through our source Sass or compiled CSS, shouldn’t be much different from our default LTR though.
Customize from source
When it comes to customization, the preferred way is to take advantage of variables, maps, and mixins.
LTR and RTL at the same time
Need both LTR and RTL on the same page? All you have to do is set following variables:
$enable-ltr: true;
$enable-rtl: true;
After running Sass, each selector in your CSS files will be prepended by html:not([dir=rtl])
, and *[dir=rtl]
for RTL files. Now you’re able to use both files on the same page.
RTL only
By default LTR is enable and RTL is disable, but you can easily change it and use only RTL.
$enable-ltr: false;
$enable-rtl: true;