Files
main-website/ruty/mails/vendor/roundcube/rtf-html-php/README.md
T
2024-03-11 00:57:00 +01:00

47 lines
1.7 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
# rtf-html-php
_An RTF to HTML converter in PHP_
In a recent project, I desperately needed an RTF to HTML converter written in PHP. Googling around turned up some matches, but I could not get them to work properly. Also, one of them called `passthru()` to use a RTF2HTML executable, which is something I didnt want. I was looking for an RTF to HTML converter written purely in PHP.
Since I couldnt find anything ready-made, I sat down and coded one up myself. Its short, and it works, implementing the subset of RTF tags that youll need in HTML and ignoring the rest. As it turns out, the RTF format isnt that complicated when you really look at it, but it isnt something you code a parser for in 15 minutes either.
## How to use it
Install this package using composer. Then do this:
```php
use RtfHtmlPhp\Document;
$rtf = file_get_contents("test.rtf");
$document = new Document($rtf); // or use a string directly
```
`Document` will raise an exception if the RTF document could not be parsed.
If youd like to see what the parser read (for debug purposes), then call this:
```php
echo $document;
```
To convert the parsers parse tree to HTML, call this (but only if the RTF was successfully parsed):
```php
use RtfHtmlPhp\Html\HtmlFormatter;
$formatter = new HtmlFormatter();
echo $formatter->format($document);
```
For enhanced compatibility the default character encoding of the converted RTF unicode characters is set to `HTML-ENTITIES`. To change the default encoding, you can initialize the `Html` object with the desired encoding supported by `mb_list_encodings()`: ex. `UTF-8`
```php
$formatter = new HtmlFormatter('UTF-8');
```
## Install via Composer
```shell
composer require roundcube/rtf-to-html
```