You are here

class PHPExcel_NamedRange in Loft Data Grids 6.2

Same name and namespace in other branches
  1. 7.2 vendor/phpoffice/phpexcel/Classes/PHPExcel/NamedRange.php \PHPExcel_NamedRange

PHPExcel_NamedRange

@category PHPExcel @package PHPExcel @copyright Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel)

Hierarchy

Expanded class hierarchy of PHPExcel_NamedRange

File

vendor/phpoffice/phpexcel/Classes/PHPExcel/NamedRange.php, line 36

View source
class PHPExcel_NamedRange {

  /**
   * Range name
   *
   * @var string
   */
  private $_name;

  /**
   * Worksheet on which the named range can be resolved
   *
   * @var PHPExcel_Worksheet
   */
  private $_worksheet;

  /**
   * Range of the referenced cells
   *
   * @var string
   */
  private $_range;

  /**
   * Is the named range local? (i.e. can only be used on $this->_worksheet)
   *
   * @var bool
   */
  private $_localOnly;

  /**
   * Scope
   *
   * @var PHPExcel_Worksheet
   */
  private $_scope;

  /**
   * Create a new NamedRange
   *
   * @param string $pName
   * @param PHPExcel_Worksheet $pWorksheet
   * @param string $pRange
   * @param bool $pLocalOnly
   * @param PHPExcel_Worksheet|null $pScope	Scope. Only applies when $pLocalOnly = true. Null for global scope.
   * @throws PHPExcel_Exception
   */
  public function __construct($pName = null, PHPExcel_Worksheet $pWorksheet, $pRange = 'A1', $pLocalOnly = false, $pScope = null) {

    // Validate data
    if ($pName === NULL || $pWorksheet === NULL || $pRange === NULL) {
      throw new PHPExcel_Exception('Parameters can not be null.');
    }

    // Set local members
    $this->_name = $pName;
    $this->_worksheet = $pWorksheet;
    $this->_range = $pRange;
    $this->_localOnly = $pLocalOnly;
    $this->_scope = $pLocalOnly == true ? $pScope == null ? $pWorksheet : $pScope : null;
  }

  /**
   * Get name
   *
   * @return string
   */
  public function getName() {
    return $this->_name;
  }

  /**
   * Set name
   *
   * @param string $value
   * @return PHPExcel_NamedRange
   */
  public function setName($value = null) {
    if ($value !== NULL) {

      // Old title
      $oldTitle = $this->_name;

      // Re-attach
      if ($this->_worksheet !== NULL) {
        $this->_worksheet
          ->getParent()
          ->removeNamedRange($this->_name, $this->_worksheet);
      }
      $this->_name = $value;
      if ($this->_worksheet !== NULL) {
        $this->_worksheet
          ->getParent()
          ->addNamedRange($this);
      }

      // New title
      $newTitle = $this->_name;
      PHPExcel_ReferenceHelper::getInstance()
        ->updateNamedFormulas($this->_worksheet
        ->getParent(), $oldTitle, $newTitle);
    }
    return $this;
  }

  /**
   * Get worksheet
   *
   * @return PHPExcel_Worksheet
   */
  public function getWorksheet() {
    return $this->_worksheet;
  }

  /**
   * Set worksheet
   *
   * @param PHPExcel_Worksheet $value
   * @return PHPExcel_NamedRange
   */
  public function setWorksheet(PHPExcel_Worksheet $value = null) {
    if ($value !== NULL) {
      $this->_worksheet = $value;
    }
    return $this;
  }

  /**
   * Get range
   *
   * @return string
   */
  public function getRange() {
    return $this->_range;
  }

  /**
   * Set range
   *
   * @param string $value
   * @return PHPExcel_NamedRange
   */
  public function setRange($value = null) {
    if ($value !== NULL) {
      $this->_range = $value;
    }
    return $this;
  }

  /**
   * Get localOnly
   *
   * @return bool
   */
  public function getLocalOnly() {
    return $this->_localOnly;
  }

  /**
   * Set localOnly
   *
   * @param bool $value
   * @return PHPExcel_NamedRange
   */
  public function setLocalOnly($value = false) {
    $this->_localOnly = $value;
    $this->_scope = $value ? $this->_worksheet : null;
    return $this;
  }

  /**
   * Get scope
   *
   * @return PHPExcel_Worksheet|null
   */
  public function getScope() {
    return $this->_scope;
  }

  /**
   * Set scope
   *
   * @param PHPExcel_Worksheet|null $value
   * @return PHPExcel_NamedRange
   */
  public function setScope(PHPExcel_Worksheet $value = null) {
    $this->_scope = $value;
    $this->_localOnly = $value == null ? false : true;
    return $this;
  }

  /**
   * Resolve a named range to a regular cell range
   *
   * @param string $pNamedRange Named range
   * @param PHPExcel_Worksheet|null $pSheet Scope. Use null for global scope
   * @return PHPExcel_NamedRange
   */
  public static function resolveRange($pNamedRange = '', PHPExcel_Worksheet $pSheet) {
    return $pSheet
      ->getParent()
      ->getNamedRange($pNamedRange, $pSheet);
  }

  /**
   * Implement PHP __clone to create a deep clone, not just a shallow copy.
   */
  public function __clone() {
    $vars = get_object_vars($this);
    foreach ($vars as $key => $value) {
      if (is_object($value)) {
        $this->{$key} = clone $value;
      }
      else {
        $this->{$key} = $value;
      }
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
PHPExcel_NamedRange::$_localOnly private property * Is the named range local? (i.e. can only be used on $this->_worksheet) * *
PHPExcel_NamedRange::$_name private property * Range name * *
PHPExcel_NamedRange::$_range private property * Range of the referenced cells * *
PHPExcel_NamedRange::$_scope private property * Scope * *
PHPExcel_NamedRange::$_worksheet private property * Worksheet on which the named range can be resolved * *
PHPExcel_NamedRange::getLocalOnly public function Get localOnly
PHPExcel_NamedRange::getName public function Get name
PHPExcel_NamedRange::getRange public function Get range
PHPExcel_NamedRange::getScope public function Get scope
PHPExcel_NamedRange::getWorksheet public function Get worksheet
PHPExcel_NamedRange::resolveRange public static function Resolve a named range to a regular cell range
PHPExcel_NamedRange::setLocalOnly public function Set localOnly
PHPExcel_NamedRange::setName public function Set name
PHPExcel_NamedRange::setRange public function Set range
PHPExcel_NamedRange::setScope public function Set scope
PHPExcel_NamedRange::setWorksheet public function Set worksheet
PHPExcel_NamedRange::__clone public function * Implement PHP __clone to create a deep clone, not just a shallow copy.
PHPExcel_NamedRange::__construct public function Create a new NamedRange