1. Converter is currently expecting colors as strings of hex digits, but PhpWord allows specification of colors by named constant, so result is random when one of those is used. This change handles all the named colors. 2. Table needs \pard at end; formatting may be wrong without it. 3. RTF writer will no longer ignore paragraph style for TextRun. 4. RTF writer will no longer ignore paragraph and font style for Title. 5. Add support for RTF headers and footers. 6. Add support for right-to-left in font. 7. Add support for PageBreakBefore and LineHeight for paragraphs. 8. Add support for PageNumberingStart for sections. There are test cases for all of these changes.
90 lines
2.3 KiB
PHP
90 lines
2.3 KiB
PHP
<?php
|
|
/**
|
|
* This file is part of PHPWord - A pure PHP library for reading and writing
|
|
* word processing documents.
|
|
*
|
|
* PHPWord is free software distributed under the terms of the GNU Lesser
|
|
* General Public License version 3 as published by the Free Software Foundation.
|
|
*
|
|
* For the full copyright and license information, please read the LICENSE
|
|
* file that was distributed with this source code. For the full list of
|
|
* contributors, visit https://github.com/PHPOffice/PHPWord/contributors.
|
|
*
|
|
* @see https://github.com/PHPOffice/PHPWord
|
|
* @copyright 2010-2018 PHPWord contributors
|
|
* @license http://www.gnu.org/licenses/lgpl.txt LGPL version 3
|
|
*/
|
|
|
|
namespace PhpOffice\PhpWord\Writer\RTF\Style;
|
|
|
|
use PhpOffice\PhpWord\Style\Font as FontStyle;
|
|
|
|
/**
|
|
* RTF font style writer
|
|
*
|
|
* @since 0.11.0
|
|
*/
|
|
class Font extends AbstractStyle
|
|
{
|
|
/**
|
|
* @var int Font name index
|
|
*/
|
|
private $nameIndex = 0;
|
|
|
|
/**
|
|
* @var int Font color index
|
|
*/
|
|
private $colorIndex = 0;
|
|
|
|
/**
|
|
* Write style
|
|
*
|
|
* @return string
|
|
*/
|
|
public function write()
|
|
{
|
|
$style = $this->getStyle();
|
|
if (!$style instanceof FontStyle) {
|
|
return '';
|
|
}
|
|
|
|
$content = '';
|
|
$content .= $this->getValueIf($style->isRTL(), '\rtlch');
|
|
$content .= '\cf' . $this->colorIndex;
|
|
$content .= '\f' . $this->nameIndex;
|
|
|
|
$size = $style->getSize();
|
|
$content .= $this->getValueIf(is_numeric($size), '\fs' . round($size * 2));
|
|
|
|
$content .= $this->getValueIf($style->isBold(), '\b');
|
|
$content .= $this->getValueIf($style->isItalic(), '\i');
|
|
$content .= $this->getValueIf($style->getUnderline() != FontStyle::UNDERLINE_NONE, '\ul');
|
|
$content .= $this->getValueIf($style->isStrikethrough(), '\strike');
|
|
$content .= $this->getValueIf($style->isSuperScript(), '\super');
|
|
$content .= $this->getValueIf($style->isSubScript(), '\sub');
|
|
|
|
return $content . ' ';
|
|
}
|
|
|
|
/**
|
|
* Set font name index.
|
|
*
|
|
*
|
|
* @param int $value
|
|
*/
|
|
public function setNameIndex($value = 0)
|
|
{
|
|
$this->nameIndex = $value;
|
|
}
|
|
|
|
/**
|
|
* Set font color index.
|
|
*
|
|
* @param int $value
|
|
*/
|
|
public function setColorIndex($value = 0)
|
|
{
|
|
$this->colorIndex = $value;
|
|
}
|
|
}
|