Your search did not match any results.
Common

Right-to-Left Support

DevExtreme HTML5 Data Editor widgets fully support RTL languages. As is illustrated in this demo, Editor widgets are able to display their contents in a right-to-left direction and fully mirror associated UI elements. Use the language drop-down menu (change from English to Arabic) to explore the differences between default and RTL modes available in DevExtreme.
Copy to CodePen
Apply
Reset
var DemoApp = angular.module('DemoApp', ['dx']); DemoApp.controller('DemoController', function DemoController($scope) { var languages = [ "Arabic: Right-to-Left direction", "English: Left-to-Right direction" ]; $scope.displayExpr = "nameEn"; $scope.rtlEnabled = false; $scope.textBoxValue = "text"; $scope.textAreaValue = "text"; $scope.checkBoxValue = "text"; $scope.europeanUnion = europeanUnion; $scope.checkBoxOptions = { value: true, bindingOptions: { text: "checkBoxValue", rtlEnabled: "rtlEnabled" } }; $scope.switchBoxOptions = { bindingOptions: { rtlEnabled: "rtlEnabled" } }; $scope.textBoxOptions = { showClearButton: true, bindingOptions: { text: "textBoxValue", rtlEnabled: "rtlEnabled" } }; $scope.numberBoxOptions = { showSpinButtons: true, value: "123", bindingOptions: { rtlEnabled: "rtlEnabled" } }; $scope.selectBoxOptions = { items: europeanUnion, value: europeanUnion[0], bindingOptions: { displayExpr: "displayExpr", rtlEnabled: "rtlEnabled" } }; $scope.tagBoxOptions = { items: europeanUnion, value: [europeanUnion[0].id], placeholder: "...", valueExpr: "id", bindingOptions: { displayExpr: "displayExpr", rtlEnabled: "rtlEnabled" } }; $scope.textAreaOptions = { bindingOptions: { text: "textAreaValue", rtlEnabled: "rtlEnabled" } }; $scope.autocompleteOptions = { items: europeanUnion, bindingOptions: { valueExpr: "displayExpr", rtlEnabled: "rtlEnabled" } }; $scope.selectLanguageOptions = { items: languages, value: languages[1], bindingOptions: { rtlEnabled: "rtlEnabled" }, onValueChanged: function(data) { var rtl = data.value === languages[0]; var text = rtl ? "نص" : "text"; $scope.displayExpr = rtl ? "nameAr" : "nameEn"; $scope.rtlEnabled = rtl; $scope.textBoxValue = text; $scope.textAreaValue = text; $scope.checkBoxValue = text; } }; });
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <title>DevExtreme Demo</title> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" /> <script src="js/jquery-3.1.0.min.js"></script> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/17.1.7/css/dx.spa.css" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/17.1.7/css/dx.common.css" /> <link rel="dx-theme" data-theme="generic.light" href="https://cdn3.devexpress.com/jslib/17.1.7/css/dx.light.css" /> <link rel="dx-theme" data-theme="android5.light" href="https://cdn3.devexpress.com/jslib/17.1.7/css/dx.android5.light.css" /> <link rel="dx-theme" data-theme="ios7.default" href="https://cdn3.devexpress.com/jslib/17.1.7/css/dx.ios7.default.css" /> <link rel="dx-theme" data-theme="win10.black" href="https://cdn3.devexpress.com/jslib/17.1.7/css/dx.win10.black.css" /> <link rel="dx-theme" data-theme="win10.white" href="https://cdn3.devexpress.com/jslib/17.1.7/css/dx.win10.white.css" /> <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.16/angular.min.js"></script> <script>window.angular || document.write(decodeURIComponent('%3Cscript src="js/angular.min.js"%3E%3C\/script%3E'))</script> <script src="https://cdn3.devexpress.com/jslib/17.1.7/js/dx.all.js"></script> <script src="data.js"></script> <link rel="stylesheet" type ="text/css" href ="styles.css" /> <script src="index.js"></script> </head> <body class="dx-viewport"> <div class="demo-container" ng-app="DemoApp" ng-controller="DemoController"> <div id="form" ng-class="{ 'dx-rtl': rtlEnabled }"> <div class="options"> <div class="caption">Options</div> <div class="dx-fieldset"> <div class="dx-field"> <div class="dx-field-label">Language</div> <div class="dx-field-value"> <div dx-select-box="selectLanguageOptions"></div> </div> </div> </div> </div> <div class="dx-fieldset"> <div class="dx-field"> <div class="dx-field-label">Text Box</div> <div class="dx-field-value"> <div dx-text-box="textBoxOptions"></div> </div> </div> <div class="dx-field"> <div class="dx-field-label">Number Box</div> <div class="dx-field-value"> <div dx-number-box="numberBoxOptions"></div> </div> </div> <div class="dx-field"> <div class="dx-field-label">Select Box</div> <div class="dx-field-value"> <div dx-select-box="selectBoxOptions"></div> </div> </div> <div class="dx-field"> <div class="dx-field-label">Tag Box</div> <div class="dx-field-value"> <div dx-tag-box="tagBoxOptions"></div> </div> </div> <div class="dx-field"> <div class="dx-field-label">Text Area</div> <div class="dx-field-value"> <div dx-text-area="textAreaOptions"></div> </div> </div> <div class="dx-field"> <div class="dx-field-label">Autocomplete</div> <div class="dx-field-value"> <div dx-autocomplete="autocompleteOptions"></div> </div> </div> <div class="dx-field"> <div class="dx-field-label">Check Box</div> <div class="dx-field-value"> <div dx-check-box="checkBoxOptions"></div> </div> </div> <div class="dx-field"> <div class="dx-field-label">Switch</div> <div class="dx-field-value"> <div dx-switch="switchBoxOptions"></div> </div> </div> </div> </div> </div> </body> </html>
#form { min-height: 587px; } .options { padding: 20px; background-color: #f5f5f5; } .options .dx-fieldset { margin: 0; } .option { margin-top: 10px; } .caption { font-size: 18px; font-weight: 500; padding-right: 15px; } .option > span { margin-right: 10px; } .option > .dx-widget { display: inline-block; vertical-align: middle; }
var europeanUnion = [{ id: 1, nameAr: "النمسا", nameEn: "Austria" }, { id: 2, nameAr: "بلجيكا", nameEn: "Belgium" }, { id: 3, nameAr: "بلغاريا", nameEn: "Bulgaria" }, { id: 4, nameAr: "كرواتيا", nameEn: "Croatia" }, { id: 5, nameAr: "قبرص", nameEn: "Cyprus" }, { id: 6, nameAr: "الجمهورية التشيكية", nameEn: "Czech Republic" }, { id: 7, nameAr: "الدنمارك", nameEn: "Denmark" }, { id: 8, nameAr: "استونيا", nameEn: "Estonia" }, { id: 9, nameAr: "فنلندا", nameEn: "Finland" }, { id: 10, nameAr: "فرنسا", nameEn: "France" }, { id: 11, nameAr: "ألمانيا", nameEn: "Germany" }, { id: 12, nameAr: "يونان", nameEn: "Greece" }, { id: 13, nameAr: "هنغاريا", nameEn: "Hungary" }, { id: 14, nameAr: "أيرلندا", nameEn: "Ireland" }, { id: 15, nameAr: "إيطاليا", nameEn: "Italy" }, { id: 16, nameAr: "لاتفيا", nameEn: "Latvia" }, { id: 17, nameAr: "ليتوانيا", nameEn: "Lithuania" }, { id: 18, nameAr: "لوكسمبورغ", nameEn: "Luxembourg" }, { id: 19, nameAr: "مالطا", nameEn: "Malta" }, { id: 20, nameAr: "هولندا", nameEn: "Netherlands" }, { id: 21, nameAr: "بولندا", nameEn: "Poland" }, { id: 22, nameAr: "البرتغال", nameEn: "Portugal" }, { id: 23, nameAr: "رومانيا", nameEn: "Romania" }, { id: 24, nameAr: "سلوفاكيا", nameEn: "Slovakia" }, { id: 25, nameAr: "سلوفينيا", nameEn: "Slovenia" }, { id: 26, nameAr: "إسبانيا", nameEn: "Spain" }, { id: 27, nameAr: "السويد", nameEn: "Sweden" }, { id: 28, nameAr: "المملكة المتحدة", nameEn: "United Kingdom" }];