#245: Basic table support in RTF writer
This commit is contained in:
parent
e7540c079e
commit
2205377259
@ -34,6 +34,7 @@ This release marked the change of PHPWord license from LGPL 2.1 to LGPL 3. Four
|
|||||||
- Element: New `Line` element - @basjan GH-253
|
- Element: New `Line` element - @basjan GH-253
|
||||||
- Title: Ability to apply numbering in heading - @ivanlanin GH-193
|
- Title: Ability to apply numbering in heading - @ivanlanin GH-193
|
||||||
- HTML Reader: Basic HTML reader - @ivanlanin GH-80 GH-254
|
- HTML Reader: Basic HTML reader - @ivanlanin GH-80 GH-254
|
||||||
|
- RTF Writer: Basic table writing - @ivanlanin GH-245
|
||||||
|
|
||||||
### Bugfixes
|
### Bugfixes
|
||||||
|
|
||||||
|
|||||||
@ -25,7 +25,7 @@ column shows the containers while the rows lists the elements.
|
|||||||
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
||||||
| 8 | List | v | v | v | v | - | - |
|
| 8 | List | v | v | v | v | - | - |
|
||||||
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
||||||
| 9 | Table | v | v | v | ? | - | - |
|
| 9 | Table | v | v | v | v | - | - |
|
||||||
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
||||||
| 10 | Image | v | v | v | v | v | v |
|
| 10 | Image | v | v | v | v | v | v |
|
||||||
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
+-------+-----------------+-----------+----------+----------+---------+------------+------------+
|
||||||
|
|||||||
@ -81,7 +81,7 @@ Writers
|
|||||||
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
||||||
| | List | ✓ | | | | |
|
| | List | ✓ | | | | |
|
||||||
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
||||||
| | Table | ✓ | ✓ | | ✓ | ✓ |
|
| | Table | ✓ | ✓ | ✓ | ✓ | ✓ |
|
||||||
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
||||||
| | Image | ✓ | ✓ | ✓ | ✓ | |
|
| | Image | ✓ | ✓ | ✓ | ✓ | |
|
||||||
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
+---------------------------+----------------------+--------+-------+-------+--------+-------+
|
||||||
|
|||||||
@ -92,7 +92,7 @@ Below are the supported features for each file formats.
|
|||||||
| | Text Break | ✓ | ✓ | ✓ | ✓ | ✓ |
|
| | Text Break | ✓ | ✓ | ✓ | ✓ | ✓ |
|
||||||
| | Page Break | ✓ | | ✓ | | |
|
| | Page Break | ✓ | | ✓ | | |
|
||||||
| | List | ✓ | | | | |
|
| | List | ✓ | | | | |
|
||||||
| | Table | ✓ | ✓ | | ✓ | ✓ |
|
| | Table | ✓ | ✓ | ✓ | ✓ | ✓ |
|
||||||
| | Image | ✓ | ✓ | ✓ | ✓ | |
|
| | Image | ✓ | ✓ | ✓ | ✓ | |
|
||||||
| | Object | ✓ | | | | |
|
| | Object | ✓ | | | | |
|
||||||
| | Watermark | ✓ | | | | |
|
| | Watermark | ✓ | | | | |
|
||||||
@ -454,7 +454,7 @@ Below are the matrix of element availability in each container. The column shows
|
|||||||
| 6 | Text Break | v | v | v | v | v | v |
|
| 6 | Text Break | v | v | v | v | v | v |
|
||||||
| 7 | Page Break | v | - | - | - | - | - |
|
| 7 | Page Break | v | - | - | - | - | - |
|
||||||
| 8 | List | v | v | v | v | - | - |
|
| 8 | List | v | v | v | v | - | - |
|
||||||
| 9 | Table | v | v | v | ? | - | - |
|
| 9 | Table | v | v | v | v | - | - |
|
||||||
| 10 | Image | v | v | v | v | v | v |
|
| 10 | Image | v | v | v | v | v | v |
|
||||||
| 11 | Watermark | - | v | - | - | - | - |
|
| 11 | Watermark | - | v | - | - | - | - |
|
||||||
| 12 | Object | v | v | v | v | v | v |
|
| 12 | Object | v | v | v | v | v | v |
|
||||||
|
|||||||
@ -98,6 +98,7 @@ abstract class AbstractElement extends HTMLAbstractElement
|
|||||||
}
|
}
|
||||||
|
|
||||||
$styleWriter = new ParagraphStyleWriter($this->paragraphStyle);
|
$styleWriter = new ParagraphStyleWriter($this->paragraphStyle);
|
||||||
|
$styleWriter->setNestedLevel($this->element->getNestedLevel());
|
||||||
return $styleWriter->write();
|
return $styleWriter->write();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
142
src/PhpWord/Writer/RTF/Element/Table.php
Normal file
142
src/PhpWord/Writer/RTF/Element/Table.php
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
<?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.
|
||||||
|
*
|
||||||
|
* @link https://github.com/PHPOffice/PHPWord
|
||||||
|
* @copyright 2010-2014 PHPWord contributors
|
||||||
|
* @license http://www.gnu.org/licenses/lgpl.txt LGPL version 3
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace PhpOffice\PhpWord\Writer\RTF\Element;
|
||||||
|
|
||||||
|
use PhpOffice\PhpWord\Element\Cell as CellElement;
|
||||||
|
use PhpOffice\PhpWord\Element\Row as RowElement;
|
||||||
|
use PhpOffice\PhpWord\Element\Table as TableElement;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Table element RTF writer
|
||||||
|
*
|
||||||
|
* @since 0.11.0
|
||||||
|
*/
|
||||||
|
class Table extends AbstractElement
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Write element
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function write()
|
||||||
|
{
|
||||||
|
if (!$this->element instanceof TableElement) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
$element = $this->element;
|
||||||
|
// No nesting table for now
|
||||||
|
if ($element->getNestedLevel() >= 1) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$content = '';
|
||||||
|
$rows = $element->getRows();
|
||||||
|
$rowCount = count($rows);
|
||||||
|
|
||||||
|
if ($rowCount > 0) {
|
||||||
|
$content .= '\pard' . PHP_EOL;
|
||||||
|
|
||||||
|
for ($i = 0; $i < $rowCount; $i++) {
|
||||||
|
$content .= '\trowd ';
|
||||||
|
$content .= $this->writeRowDef($rows[$i]);
|
||||||
|
$content .= PHP_EOL;
|
||||||
|
$content .= $this->writeRow($rows[$i]);
|
||||||
|
$content .= '\row' . PHP_EOL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $content;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write column
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
private function writeRowDef(RowElement $row)
|
||||||
|
{
|
||||||
|
$content = '';
|
||||||
|
|
||||||
|
$rightMargin = 0;
|
||||||
|
foreach ($row->getCells() as $cell) {
|
||||||
|
$width = $cell->getWidth();
|
||||||
|
$vMerge = $this->getVMerge($cell->getStyle()->getVMerge());
|
||||||
|
if ($width === null) {
|
||||||
|
$width = 720; // Arbitrary default width
|
||||||
|
}
|
||||||
|
$rightMargin += $width;
|
||||||
|
$content .= "{$vMerge}\cellx{$rightMargin} ";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $content;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write row
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
private function writeRow(RowElement $row)
|
||||||
|
{
|
||||||
|
$content = '';
|
||||||
|
|
||||||
|
// Write cells
|
||||||
|
foreach ($row->getCells() as $cell) {
|
||||||
|
$content .= $this->writeCell($cell);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $content;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write cell
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
private function writeCell(CellElement $cell)
|
||||||
|
{
|
||||||
|
$content = '\intbl' . PHP_EOL;
|
||||||
|
|
||||||
|
// Write content
|
||||||
|
$writer = new Container($this->parentWriter, $cell);
|
||||||
|
$content .= $writer->write();
|
||||||
|
|
||||||
|
$content .= '\cell' . PHP_EOL;
|
||||||
|
|
||||||
|
return $content;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get vertical merge style
|
||||||
|
*
|
||||||
|
* @param string $value
|
||||||
|
* @return string
|
||||||
|
* @todo Move to style
|
||||||
|
*/
|
||||||
|
private function getVMerge($value)
|
||||||
|
{
|
||||||
|
$style = '';
|
||||||
|
if ($value == 'restart') {
|
||||||
|
$style = '\clvmgf';
|
||||||
|
} elseif ($value == 'continue') {
|
||||||
|
$style = '\clvmrg';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $style;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -35,6 +35,6 @@ class TextBreak extends AbstractElement
|
|||||||
$parentWriter = $this->parentWriter;
|
$parentWriter = $this->parentWriter;
|
||||||
$parentWriter->setLastParagraphStyle();
|
$parentWriter->setLastParagraphStyle();
|
||||||
|
|
||||||
return '\par' . PHP_EOL;
|
return '\pard\par' . PHP_EOL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -26,6 +26,16 @@ use PhpOffice\PhpWord\Style\Alignment;
|
|||||||
*/
|
*/
|
||||||
class Paragraph extends AbstractStyle
|
class Paragraph extends AbstractStyle
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Depth of table container nested level; Primarily used for RTF writer/reader
|
||||||
|
*
|
||||||
|
* 0 = Not in a table; 1 = in a table; 2 = in a table inside another table, etc.
|
||||||
|
*
|
||||||
|
* @var int
|
||||||
|
*/
|
||||||
|
private $nestedLevel = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Write style
|
* Write style
|
||||||
*
|
*
|
||||||
@ -49,7 +59,10 @@ class Paragraph extends AbstractStyle
|
|||||||
$spaceAfter = $style->getSpaceAfter();
|
$spaceAfter = $style->getSpaceAfter();
|
||||||
$spaceBefore = $style->getSpaceBefore();
|
$spaceBefore = $style->getSpaceBefore();
|
||||||
|
|
||||||
$content = '\pard\nowidctlpar';
|
$content = '';
|
||||||
|
if ($this->nestedLevel == 0) {
|
||||||
|
$content .= '\pard\nowidctlpar ';
|
||||||
|
}
|
||||||
if (isset($alignments[$align])) {
|
if (isset($alignments[$align])) {
|
||||||
$content .= $alignments[$align];
|
$content .= $alignments[$align];
|
||||||
}
|
}
|
||||||
@ -58,4 +71,14 @@ class Paragraph extends AbstractStyle
|
|||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set nested level
|
||||||
|
*
|
||||||
|
* @param int $value
|
||||||
|
*/
|
||||||
|
public function setNestedLevel($value)
|
||||||
|
{
|
||||||
|
$this->nestedLevel = $value;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -79,7 +79,7 @@ class ODTextTest extends \PHPUnit_Framework_TestCase
|
|||||||
$section->addLink('http://test.com');
|
$section->addLink('http://test.com');
|
||||||
$section->addTitle('Test', 1);
|
$section->addTitle('Test', 1);
|
||||||
$section->addPageBreak();
|
$section->addPageBreak();
|
||||||
$section->addTable();
|
$section->addTable()->addRow()->addCell()->addText('Test');
|
||||||
$section->addListItem('Test');
|
$section->addListItem('Test');
|
||||||
$section->addImage($imageSrc);
|
$section->addImage($imageSrc);
|
||||||
$section->addObject($objectSrc);
|
$section->addObject($objectSrc);
|
||||||
|
|||||||
@ -28,7 +28,7 @@ class ElementTest extends \PHPUnit_Framework_TestCase
|
|||||||
*/
|
*/
|
||||||
public function testUnmatchedElements()
|
public function testUnmatchedElements()
|
||||||
{
|
{
|
||||||
$elements = array('Container', 'Text', 'Title', 'Link');
|
$elements = array('Container', 'Text', 'Title', 'Link', 'Table');
|
||||||
foreach ($elements as $element) {
|
foreach ($elements as $element) {
|
||||||
$objectClass = 'PhpOffice\\PhpWord\\Writer\\RTF\\Element\\' . $element;
|
$objectClass = 'PhpOffice\\PhpWord\\Writer\\RTF\\Element\\' . $element;
|
||||||
$parentWriter = new RTF();
|
$parentWriter = new RTF();
|
||||||
|
|||||||
@ -68,7 +68,7 @@ class RTFTest extends \PHPUnit_Framework_TestCase
|
|||||||
$section->addLink('http://test.com');
|
$section->addLink('http://test.com');
|
||||||
$section->addTitle('Test', 1);
|
$section->addTitle('Test', 1);
|
||||||
$section->addPageBreak();
|
$section->addPageBreak();
|
||||||
$section->addTable();
|
$section->addTable()->addRow()->addCell()->addText('Test');
|
||||||
$section->addListItem('Test');
|
$section->addListItem('Test');
|
||||||
$section->addImage($imageSrc);
|
$section->addImage($imageSrc);
|
||||||
$section->addObject($objectSrc);
|
$section->addObject($objectSrc);
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user