add element bookmark and allow links to internal bookmarks in Word2007
This commit is contained in:
parent
47a17a33e8
commit
d54a674b97
@ -22,6 +22,7 @@ namespace PhpOffice\PhpWord\Element;
|
|||||||
*
|
*
|
||||||
* @method Text addText(string $text, mixed $fStyle = null, mixed $pStyle = null)
|
* @method Text addText(string $text, mixed $fStyle = null, mixed $pStyle = null)
|
||||||
* @method TextRun addTextRun(mixed $pStyle = null)
|
* @method TextRun addTextRun(mixed $pStyle = null)
|
||||||
|
* @method Bookmark addBookmark(string $name)
|
||||||
* @method Link addLink(string $target, string $text = null, mixed $fStyle = null, mixed $pStyle = null)
|
* @method Link addLink(string $target, string $text = null, mixed $fStyle = null, mixed $pStyle = null)
|
||||||
* @method PreserveText addPreserveText(string $text, mixed $fStyle = null, mixed $pStyle = null)
|
* @method PreserveText addPreserveText(string $text, mixed $fStyle = null, mixed $pStyle = null)
|
||||||
* @method void addTextBreak(int $count = 1, mixed $fStyle = null, mixed $pStyle = null)
|
* @method void addTextBreak(int $count = 1, mixed $fStyle = null, mixed $pStyle = null)
|
||||||
@ -78,7 +79,7 @@ abstract class AbstractContainer extends AbstractElement
|
|||||||
public function __call($function, $args)
|
public function __call($function, $args)
|
||||||
{
|
{
|
||||||
$elements = array(
|
$elements = array(
|
||||||
'Text', 'TextRun', 'Link', 'PreserveText', 'TextBreak',
|
'Text', 'TextRun', 'Bookmark', 'Link', 'PreserveText', 'TextBreak',
|
||||||
'ListItem', 'ListItemRun', 'Table', 'Image', 'Object',
|
'ListItem', 'ListItemRun', 'Table', 'Image', 'Object',
|
||||||
'Footnote', 'Endnote', 'CheckBox', 'TextBox', 'Field',
|
'Footnote', 'Endnote', 'CheckBox', 'TextBox', 'Field',
|
||||||
'Line', 'Shape', 'Title', 'TOC', 'PageBreak',
|
'Line', 'Shape', 'Title', 'TOC', 'PageBreak',
|
||||||
@ -189,6 +190,7 @@ abstract class AbstractContainer extends AbstractElement
|
|||||||
);
|
);
|
||||||
$validContainers = array(
|
$validContainers = array(
|
||||||
'Text' => $allContainers,
|
'Text' => $allContainers,
|
||||||
|
'Bookmark' => $allContainers,
|
||||||
'Link' => $allContainers,
|
'Link' => $allContainers,
|
||||||
'TextBreak' => $allContainers,
|
'TextBreak' => $allContainers,
|
||||||
'Image' => $allContainers,
|
'Image' => $allContainers,
|
||||||
|
|||||||
64
src/PhpWord/Element/Bookmark.php
Normal file
64
src/PhpWord/Element/Bookmark.php
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
<?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\Element;
|
||||||
|
|
||||||
|
use PhpOffice\PhpWord\Shared\String;
|
||||||
|
use PhpOffice\PhpWord\Style;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Bookmark element
|
||||||
|
*/
|
||||||
|
class Bookmark extends AbstractElement
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Bookmark Name
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private $name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Is part of collection
|
||||||
|
*
|
||||||
|
* @var bool
|
||||||
|
*/
|
||||||
|
protected $collectionRelation = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new Bookmark Element
|
||||||
|
*
|
||||||
|
* @param string $name
|
||||||
|
*/
|
||||||
|
public function __construct($name)
|
||||||
|
{
|
||||||
|
|
||||||
|
$this->name = String::toUTF8($name);
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get Bookmark name
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getName()
|
||||||
|
{
|
||||||
|
return $this->name;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@ -61,6 +61,13 @@ class Link extends AbstractElement
|
|||||||
*/
|
*/
|
||||||
protected $mediaRelation = true;
|
protected $mediaRelation = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Has internal flag - anchor to internal bookmark
|
||||||
|
*
|
||||||
|
* @var bool
|
||||||
|
*/
|
||||||
|
protected $internal = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new Link Element
|
* Create a new Link Element
|
||||||
*
|
*
|
||||||
@ -69,13 +76,13 @@ class Link extends AbstractElement
|
|||||||
* @param mixed $fontStyle
|
* @param mixed $fontStyle
|
||||||
* @param mixed $paragraphStyle
|
* @param mixed $paragraphStyle
|
||||||
*/
|
*/
|
||||||
public function __construct($source, $text = null, $fontStyle = null, $paragraphStyle = null)
|
public function __construct($source, $text = null, $fontStyle = null, $paragraphStyle = null, $internal = false)
|
||||||
{
|
{
|
||||||
$this->source = String::toUTF8($source);
|
$this->source = String::toUTF8($source);
|
||||||
$this->text = is_null($text) ? $this->source : String::toUTF8($text);
|
$this->text = is_null($text) ? $this->source : String::toUTF8($text);
|
||||||
$this->fontStyle = $this->setNewStyle(new Font('text'), $fontStyle);
|
$this->fontStyle = $this->setNewStyle(new Font('text'), $fontStyle);
|
||||||
$this->paragraphStyle = $this->setNewStyle(new Paragraph(), $paragraphStyle);
|
$this->paragraphStyle = $this->setNewStyle(new Paragraph(), $paragraphStyle);
|
||||||
|
$this->internal = $internal;
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,4 +161,14 @@ class Link extends AbstractElement
|
|||||||
{
|
{
|
||||||
return $this->getText();
|
return $this->getText();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* is internal
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function isInternal()
|
||||||
|
{
|
||||||
|
return $this->internal;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -27,6 +27,7 @@ use PhpOffice\PhpWord\Exception\Exception;
|
|||||||
* @method Collection\Footnotes getFootnotes()
|
* @method Collection\Footnotes getFootnotes()
|
||||||
* @method Collection\Endnotes getEndnotes()
|
* @method Collection\Endnotes getEndnotes()
|
||||||
* @method Collection\Charts getCharts()
|
* @method Collection\Charts getCharts()
|
||||||
|
* @method int addBookmark(Element\Bookmark $bookmark)
|
||||||
* @method int addTitle(Element\Title $title)
|
* @method int addTitle(Element\Title $title)
|
||||||
* @method int addFootnote(Element\Footnote $footnote)
|
* @method int addFootnote(Element\Footnote $footnote)
|
||||||
* @method int addEndnote(Element\Endnote $endnote)
|
* @method int addEndnote(Element\Endnote $endnote)
|
||||||
@ -82,7 +83,7 @@ class PhpWord
|
|||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
// Collection
|
// Collection
|
||||||
$collections = array('Titles', 'Footnotes', 'Endnotes', 'Charts');
|
$collections = array('Bookmarks', 'Titles', 'Footnotes', 'Endnotes', 'Charts');
|
||||||
foreach ($collections as $collection) {
|
foreach ($collections as $collection) {
|
||||||
$class = 'PhpOffice\\PhpWord\\Collection\\' . $collection;
|
$class = 'PhpOffice\\PhpWord\\Collection\\' . $collection;
|
||||||
$this->collections[$collection] = new $class();
|
$this->collections[$collection] = new $class();
|
||||||
@ -113,7 +114,7 @@ class PhpWord
|
|||||||
$addCollection = array();
|
$addCollection = array();
|
||||||
$addStyle = array();
|
$addStyle = array();
|
||||||
|
|
||||||
$collections = array('Title', 'Footnote', 'Endnote', 'Chart');
|
$collections = array('Bookmark', 'Title', 'Footnote', 'Endnote', 'Chart');
|
||||||
foreach ($collections as $collection) {
|
foreach ($collections as $collection) {
|
||||||
$getCollection[] = strtolower("get{$collection}s");
|
$getCollection[] = strtolower("get{$collection}s");
|
||||||
$addCollection[] = strtolower("add{$collection}");
|
$addCollection[] = strtolower("add{$collection}");
|
||||||
@ -218,10 +219,9 @@ class PhpWord
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set default font name.
|
* Set default font name
|
||||||
*
|
*
|
||||||
* @param string $fontName
|
* @param string $fontName
|
||||||
* @return void
|
|
||||||
*/
|
*/
|
||||||
public function setDefaultFontName($fontName)
|
public function setDefaultFontName($fontName)
|
||||||
{
|
{
|
||||||
@ -239,10 +239,9 @@ class PhpWord
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set default font size.
|
* Set default font size
|
||||||
*
|
*
|
||||||
* @param int $fontSize
|
* @param int $fontSize
|
||||||
* @return void
|
|
||||||
*/
|
*/
|
||||||
public function setDefaultFontSize($fontSize)
|
public function setDefaultFontSize($fontSize)
|
||||||
{
|
{
|
||||||
|
|||||||
49
src/PhpWord/Writer/Word2007/Element/Bookmark.php
Normal file
49
src/PhpWord/Writer/Word2007/Element/Bookmark.php
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
<?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\Word2007\Element;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Bookmark element writer
|
||||||
|
*
|
||||||
|
* @since 0.12.0
|
||||||
|
*/
|
||||||
|
class Bookmark extends AbstractElement
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Write bookmark element
|
||||||
|
*/
|
||||||
|
public function write()
|
||||||
|
{
|
||||||
|
$xmlWriter = $this->getXmlWriter();
|
||||||
|
$element = $this->getElement();
|
||||||
|
if (!$element instanceof \PhpOffice\PhpWord\Element\Bookmark) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$rId = $element->getRelationId();
|
||||||
|
|
||||||
|
$xmlWriter->startElement('w:bookmarkStart');
|
||||||
|
$xmlWriter->writeAttribute('w:id', $rId);
|
||||||
|
$xmlWriter->writeAttribute('w:name', $element->getName());
|
||||||
|
$xmlWriter->endElement();
|
||||||
|
|
||||||
|
$xmlWriter->startElement('w:bookmarkEnd');
|
||||||
|
$xmlWriter->writeAttribute('w:id', $rId);
|
||||||
|
$xmlWriter->endElement();
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -25,9 +25,7 @@ namespace PhpOffice\PhpWord\Writer\Word2007\Element;
|
|||||||
class Link extends Text
|
class Link extends Text
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Write link element.
|
* Write link element
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
*/
|
||||||
public function write()
|
public function write()
|
||||||
{
|
{
|
||||||
@ -42,7 +40,11 @@ class Link extends Text
|
|||||||
$this->startElementP();
|
$this->startElementP();
|
||||||
|
|
||||||
$xmlWriter->startElement('w:hyperlink');
|
$xmlWriter->startElement('w:hyperlink');
|
||||||
$xmlWriter->writeAttribute('r:id', 'rId' . $rId);
|
if($element->isInternal()) {
|
||||||
|
$xmlWriter->writeAttribute('w:anchor', $element->getSource());
|
||||||
|
}else {
|
||||||
|
$xmlWriter->writeAttribute('r:id', 'rId' . $rId);
|
||||||
|
}
|
||||||
$xmlWriter->writeAttribute('w:history', '1');
|
$xmlWriter->writeAttribute('w:history', '1');
|
||||||
$xmlWriter->startElement('w:r');
|
$xmlWriter->startElement('w:r');
|
||||||
|
|
||||||
|
|||||||
@ -25,9 +25,7 @@ namespace PhpOffice\PhpWord\Writer\Word2007\Element;
|
|||||||
class Title extends AbstractElement
|
class Title extends AbstractElement
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Write title element.
|
* Write title element
|
||||||
*
|
|
||||||
* @return void
|
|
||||||
*/
|
*/
|
||||||
public function write()
|
public function write()
|
||||||
{
|
{
|
||||||
@ -50,10 +48,11 @@ class Title extends AbstractElement
|
|||||||
}
|
}
|
||||||
|
|
||||||
$rId = $element->getRelationId();
|
$rId = $element->getRelationId();
|
||||||
|
$bookmarkRId = $element->getPhpWord()->addBookmark();
|
||||||
|
|
||||||
// Bookmark start for TOC
|
// Bookmark start for TOC
|
||||||
$xmlWriter->startElement('w:bookmarkStart');
|
$xmlWriter->startElement('w:bookmarkStart');
|
||||||
$xmlWriter->writeAttribute('w:id', $rId);
|
$xmlWriter->writeAttribute('w:id', $bookmarkRId);
|
||||||
$xmlWriter->writeAttribute('w:name', "_Toc{$rId}");
|
$xmlWriter->writeAttribute('w:name', "_Toc{$rId}");
|
||||||
$xmlWriter->endElement();
|
$xmlWriter->endElement();
|
||||||
|
|
||||||
@ -66,7 +65,7 @@ class Title extends AbstractElement
|
|||||||
|
|
||||||
// Bookmark end
|
// Bookmark end
|
||||||
$xmlWriter->startElement('w:bookmarkEnd');
|
$xmlWriter->startElement('w:bookmarkEnd');
|
||||||
$xmlWriter->writeAttribute('w:id', $rId);
|
$xmlWriter->writeAttribute('w:id', $bookmarkRId);
|
||||||
$xmlWriter->endElement();
|
$xmlWriter->endElement();
|
||||||
|
|
||||||
$xmlWriter->endElement();
|
$xmlWriter->endElement();
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user