RTLCSS is a framework for converting Left-To-Right (LTR) Cascading Style Sheets(CSS) to Right-To-Left (RTL).
Add the library to your composer.json
{
"repositories": [{
"type": "vcs",
"url": "https://github.com/moodlehq/rtlcss-php"
}],
"require-dev": {
"moodlehq/rtlcss-php": "*"
}
}
$parser = new Sabberworm\CSS\Parser($css);
$tree = $parser->parse()
$rtlcss = new MoodleHQ\RTLCSS\RTLCSS($tree);
$rtlcss->flip();
echo $tree->render();
For parsing options and rendering, refer to Sabberworm/PHP-CSS-Parser.
.div {
direction: ltr;
left: 10px;
border: 10px 5px 0px 2px;
float: left;
}
Becomes:
.div {
direction: rtl;
right: 10px;
border: 10px 2px 0px 5px;
float: right;
}
You can prefix your CSS with comments starting with /*rtl:*/
for special handling.
Prepend with /*rtl:ignore*/
, or wrap within /*rtl:begin:ignore*/
and /*rtl:end:ignore*/
.
.div {
/*rtl:ignore*/
float: left;
left: 10px;
}
.div {
direction: ltr;
/*rtl:begin:ignore*/
float: left;
left: 10px;
/*rtl:end:ignore*/
}
Becomes:
.div {
float: left;
right: 10px;
}
.div {
direction: rtl;
float: left;
left: 10px;
}
Prepend with /*rtl:remove*/
, wrap within /*rtl:begin:remove*/
and /*rtl:end:remove*/
.
.div {
/*rtl:remove*/
float: left;
left: 10px;
}
.div {
direction: ltr;
/*rtl:begin:remove*/
float: left;
left: 10px;
/*rtl:end:remove*/
}
Becomes:
.div {
right: 10px;
}
.div {
direction: rtl;
}
Write the CSS in a content starting with /*rtl:raw:
.
.div {
/*rtl:raw:
text-align: left;
*/
float: left;
}
Becomes:
.div {
text-align: left;
float: right;
}
Currently the comments must always precede a statement, they will not work if they are not followed by anything.
Valid:
.div {
/*rtl:raw:
text-align: left;
*/
float: left;
}
Invalid:
.div {
float: left;
/*rtl:raw:
text-align: left;
*/
}
A lot of common CSS rules are supported, however a few complex ones are not. To get a grasp of what is supported and what isn't, please refer to the test cases. Unsupported scenarios are marked to be skipped.
This tool is very heavily inspired by MohammadYounes/rtlcss, even though at this stage it does not include all of its features. See this library as a partial port of the latter.
- MohammadYounes/rtlcss for being the example we followed.
- Sabberworm/PHP-CSS-Parser for parsing CSS in PHP.
Licensed under the MIT License.