HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/pragmaticsng.org/wp-content/plugins/e2pdf/vendors/svggraph/
Upload File :
Current File : /home/dhnidqcz/pragmaticsng.org/wp-content/plugins/e2pdf/vendors/svggraph/MultiGraph.php
<?php
/**
 * Copyright (C) 2011-2022 Graham Breach
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
/**
 * For more information, please contact <[email protected]>
 */

namespace Goat1000\SVGGraph;

class MultiGraph implements \Countable, \ArrayAccess, \Iterator {

  private $values;
  private $datasets = 0;
  private $enabled_datasets = null;
  private $force_assoc;
  private $datetime_keys;
  private $max_key = null;
  private $min_key = null;
  private $max_value = null;
  private $min_value = null;
  private $max_sum_value = null;
  private $min_sum_value = null;
  private $item_list = [];
  private $position = 0;
  private $item_cache = [];
  private $item_cache_pos = -1;

  public function __construct($values, $force_assoc, $datetime_keys, $int_keys)
  {
    $this->values =& $values;
    $this->force_assoc = $force_assoc;
    $this->datetime_keys = $datetime_keys;
    $keys = [];

    // convert unstructured data to structured
    if(count($values) > 1 && $this->values instanceof Data) {
      $this->values = StructuredData::convertFrom($values, $force_assoc,
        $datetime_keys, $int_keys);
    }
    $this->datasets = count($this->values);
    $this->enabled_datasets = range(0, $this->datasets - 1);
  }

  /**
   * Sets the list of datasets that are enabled
   */
  public function setEnabledDatasets($datasets)
  {
    if($datasets === null)
      $datasets = range(0, $this->datasets - 1);
    if(!is_array($datasets))
      $datasets = [$datasets];

    $enabled = [];
    foreach($datasets as $d)
      if($d >= 0 && $d < $this->datasets)
        $enabled[] = $d;
    $this->enabled_datasets = $enabled;
  }

  /**
   * Returns the list of enabled datasets
   */
  public function getEnabledDatasets()
  {
    return $this->enabled_datasets;
  }

  /**
   * Pass all unhandled functions through to the structured data instance
   */
  public function __call($name, $arguments)
  {
    return call_user_func_array([$this->values, $name], $arguments);
  }

  /**
   * Implement Iterator interface
   */
  #[\ReturnTypeWillChange]
  public function current()
  {
    if($this->item_cache_pos != $this->position) {
      $this->item_cache[0] = $this->values[0]->getItemByIndex($this->position);

      // use NewFrom to create other data items quicker
      for($i = 1; $i < $this->datasets; ++$i)
        $this->item_cache[$i] = $this->item_cache[0]->newFrom($i);
      $this->item_cache_pos = $this->position;
    }
    return $this->item_cache;
  }
  #[\ReturnTypeWillChange]
  public function key()
  {
    return $this->position;
  }
  #[\ReturnTypeWillChange]
  public function next()
  {
    ++$this->position;
  }
  #[\ReturnTypeWillChange]
  public function rewind()
  {
    $this->position = 0;
  }
  #[\ReturnTypeWillChange]
  public function valid()
  {
    return $this->position < $this->itemsCount();
  }

  /**
   * ArrayAccess methods
   */
  #[\ReturnTypeWillChange]
  public function offsetExists($offset)
  {
    return ($offset >= 0 && $offset < $this->datasets);
  }

  #[\ReturnTypeWillChange]
  public function offsetGet($offset)
  {
    return $this->values[$offset];
  }

  /**
   * Don't allow writing to the data
   */
  #[\ReturnTypeWillChange]
  public function offsetSet($offset, $value)
  {
    throw new \Exception('Read-only');
  }
  #[\ReturnTypeWillChange]
  public function offsetUnset($offset)
  {
    throw new \Exception('Read-only');
  }

  /**
   * Countable method
   */
  #[\ReturnTypeWillChange]
  public function count()
  {
    return $this->datasets;
  }

  /**
   * Returns the number of items
   */
  public function itemsCount()
  {
    // use -1 for all items
    return $this->values->itemsCount(-1);
  }

  /**
   * Returns the maximum value
   */
  public function getMaxValue()
  {
    if($this->max_value !== null)
      return $this->max_value;
    $maxima = [];
    $chunk_count = count($this->values);
    for($i = 0; $i < $chunk_count; ++$i) {
      if(!in_array($i, $this->enabled_datasets))
        continue;
      $maxima[] = $this->values->getMaxValue($i);
    }

    $this->max_value = count($maxima) ? max($maxima) : null;
    return $this->max_value;
  }


  /**
   * Returns the minimum value
   */
  public function getMinValue()
  {
    if($this->min_value !== null)
      return $this->min_value;
    $minima = [];
    $chunk_count = count($this->values);
    for($i = 0; $i < $chunk_count; ++$i) {
      if(!in_array($i, $this->enabled_datasets))
        continue;
      $min_val = $this->values->getMinValue($i);
      if($min_val !== null)
        $minima[] = $min_val;
    }

    $this->min_value = count($minima) ? min($minima) : null;
    return $this->min_value;
  }


  /**
   * Returns the maximum key value
   */
  public function getMaxKey()
  {
    if($this->max_key !== null)
      return $this->max_key;

    $max = [];
    for($i = 0; $i < $this->datasets; ++$i) {
      if(!in_array($i, $this->enabled_datasets))
        continue;
      $max[] = $this->values->getMaxKey($i);
    }
    $this->max_key = count($max) ? max($max) : null;
    return $this->max_key;
  }

  /**
   * Returns the minimum key value
   */
  public function getMinKey()
  {
    if($this->min_key !== null)
      return $this->min_key;

    $min = [];
    for($i = 0; $i < $this->datasets; ++$i) {
      if(!in_array($i, $this->enabled_datasets))
        continue;
      $min[] = $this->values->getMinKey($i);
    }
    $this->min_key = count($min) ? min($min) : null;
    return $this->min_key;
  }

  /**
   * Returns the maximum sum value
   */
  public function getMaxSumValue()
  {
    if($this->max_sum_value === null)
      $this->calcMinMaxSumValues();
    return $this->max_sum_value;
  }

  /**
   * Returns the minimum sum value (the negative part)
   */
  public function getMinSumValue()
  {
    if($this->min_sum_value === null)
      $this->calcMinMaxSumValues();
    return $this->min_sum_value;
  }


  /**
   * Calculates the minimum and maximum sum values
   */
  public function calcMinMaxSumValues()
  {
    list($this->min_sum_value, $this->max_sum_value) =
      $this->values->getMinMaxSumValuesFor($this->enabled_datasets);
  }

  /**
   * Access to the structured data values
   */
  public function &getValues()
  {
    return $this->values;
  }

  /**
   * Pass through to the structured data values
   */
  public function getData($index, $name, &$value)
  {
    // the reference means __call can't handle this
    return $this->values->getData($index, $name, $value);
  }
}