2014-05-25 23:08:02 +07:00

242 lines
4.7 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.
*
* @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\Style;
/**
* Table cell style
*/
class Cell extends Border
{
/**
* Vertical alignment constants
*
* @const string
*/
const VALIGN_TOP = 'top';
const VALIGN_CENTER = 'center';
const VALIGN_BOTTOM = 'bottom';
const VALIGN_BOTH = 'both';
/**
* Text direction constants
*
* @const string
*/
const TEXT_DIR_BTLR = 'btLr';
const TEXT_DIR_TBRL = 'tbRl';
/**
* Vertical merge (rowspan) constants
*
* @const string
*/
const VMERGE_RESTART = 'restart';
const VMERGE_CONTINUE = 'continue';
/**
* Default border color
*
* @const string
*/
const DEFAULT_BORDER_COLOR = '000000';
/**
* Vertical align (top, center, both, bottom)
*
* @var string
*/
private $vAlign;
/**
* Text Direction
*
* @var string
*/
private $textDirection;
/**
* colspan
*
* @var integer
*/
private $gridSpan;
/**
* rowspan (restart, continue)
*
* - restart: Start/restart merged region
* - continue: Continue merged region
*
* @var string
*/
private $vMerge;
/**
* Shading
*
* @var \PhpOffice\PhpWord\Style\Shading
*/
private $shading;
/**
* Get vertical align
*/
public function getVAlign()
{
return $this->vAlign;
}
/**
* Set vertical align
*
* @param string $value
* @return self
*/
public function setVAlign($value = null)
{
$enum = array(self::VALIGN_TOP, self::VALIGN_CENTER, self::VALIGN_BOTTOM, self::VALIGN_BOTH);
$this->vAlign = $this->setEnumVal($value, $enum, $this->vAlign);
return $this;
}
/**
* Get text direction
*/
public function getTextDirection()
{
return $this->textDirection;
}
/**
* Set text direction
*
* @param string $value
* @return self
*/
public function setTextDirection($value = null)
{
$enum = array(self::TEXT_DIR_BTLR, self::TEXT_DIR_TBRL);
$this->textDirection = $this->setEnumVal($value, $enum, $this->textDirection);
return $this;
}
/**
* Get background
*
* @return string
*/
public function getBgColor()
{
if ($this->shading !== null) {
return $this->shading->getFill();
} else {
return null;
}
}
/**
* Set background
*
* @param string $value
* @return self
*/
public function setBgColor($value = null)
{
return $this->setShading(array('fill' => $value));
}
/**
* Get grid span (colspan)
*/
public function getGridSpan()
{
return $this->gridSpan;
}
/**
* Set grid span (colspan)
*
* @param int $value
* @return self
*/
public function setGridSpan($value = null)
{
$this->gridSpan = $this->setIntVal($value, $this->gridSpan);
return $this;
}
/**
* Get vertical merge (rowspan)
*/
public function getVMerge()
{
return $this->vMerge;
}
/**
* Set vertical merge (rowspan)
*
* @param string $value
* @return self
*/
public function setVMerge($value = null)
{
$enum = array(self::VMERGE_RESTART, self::VMERGE_CONTINUE);
$this->vMerge = $this->setEnumVal($value, $enum, $this->vMerge);
return $this;
}
/**
* Get shading
*
* @return \PhpOffice\PhpWord\Style\Shading
*/
public function getShading()
{
return $this->shading;
}
/**
* Set shading
*
* @param mixed $value
* @return self
*/
public function setShading($value = null)
{
$this->setObjectVal($value, 'Shading', $this->shading);
return $this;
}
/**
* Get default border color
*
* @deprecated 0.10.0
* @codeCoverageIgnore
*/
public function getDefaultBorderColor()
{
return self::DEFAULT_BORDER_COLOR;
}
}