1   2   3   4   5   6   7   8   9  10  11  12  13  14  15  16  17  18  19  20  21  22  23  24  25  26  27  28  29  30  31  32  33  34  35  36  37  38  39  40  41  42  43  44  45  46  47  48  49  50  51  52  53  54  55  56  57  58  59  60  61  62  63  64  65  66  67  68  69  70  71  72  73  74  75  76  77  78  79  80  81  82  83  84  85  86  87  88  89  90  91  92  93  94  95  96  97  98  99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 
<?php

/* --------------------------------------------------------------
   SlideImageAreaRepositoryReader.inc.php 2016-12-07
   Gambio GmbH
   http://www.gambio.de
   Copyright (c) 2016 Gambio GmbH
   Released under the GNU General Public License (Version 2)
   [http://www.gnu.org/licenses/gpl-2.0.html]
   --------------------------------------------------------------
*/

MainFactory::load_class('SlideImageAreaRepositoryReaderInterface');

/**
 * Class SlideImageAreaRepositoryReader
 *
 * @category   System
 * @package    Slider
 * @subpackage Repositories
 */
class SlideImageAreaRepositoryReader implements SlideImageAreaRepositoryReaderInterface
{
    /**
     * Table name
     *
     * @var string
     */
    protected $table = 'slide_image_areas';
    
    /**
     * Query builder.
     *
     * @var CI_DB_query_builder
     */
    protected $db;
    
    
    /**
     * SlideImageAreaRepositoryReader constructor.
     *
     * @param CI_DB_query_builder $db Query builder.
     */
    public function __construct(CI_DB_query_builder $db)
    {
        $this->db = $db;
    }
    
    
    /**
     * Returns a SlideImageAreaCollection instance by the given slide image ID.
     *
     * @param IdType $slideImageId ID of the slide image to get.
     *
     * @return SlideImageAreaCollection
     */
    public function getBySlideImageId(IdType $slideImageId)
    {
        $slideImageAreasArray = [];
        
        $result = $this->db->get_where($this->table, ['slide_images_id' => $slideImageId->asInt()]);
        
        foreach($result->result_array() as $row)
        {
            $slideImageArea = MainFactory::create('SlideImageArea');
            
            $this->_setDbValues($slideImageArea, $row);
            
            $slideImageAreasArray[] = $slideImageArea;
        }
        
        return MainFactory::create('SlideImageAreaCollection', $slideImageAreasArray);
    }
    
    
    /**
     * Returns a SlideImageArea instance by the given slide image area ID.
     *
     * @param IdType $slideImageAreaId
     *
     * @throws UnexpectedValueException
     * @throws InvalidArgumentException
     *
     * @return SlideImageAreaInterface
     */
    public function getById(IdType $slideImageAreaId)
    {
        $slideImageAreaData = $this->db->get_where($this->table, ['id' => $slideImageAreaId->asInt()])->row_array();
        
        if($slideImageAreaData === null)
        {
            throw new UnexpectedValueException('The requested slide image area was not found in the database (ID:'
                                               . $slideImageAreaId->asInt() . ')');
        }
        
        $slideImageArea = MainFactory::create('SlideImageArea');
        $this->_setDbValues($slideImageArea, $slideImageAreaData);
        
        return $slideImageArea;
    }
    
    
    /**
     * Assign the SlideImageArea values via the setter.
     *
     * @param SlideImageArea $slideImageArea
     * @param array          $row
     *
     * @throws InvalidArgumentException If $row contains invalid values.
     */
    protected function _setDbValues(SlideImageArea $slideImageArea, array $row)
    {
        $slideImageArea->setId(new IdType($row['id']));
        $slideImageArea->setLinkTitle(new StringType((string)$row['link_title']));
        $slideImageArea->setLinkUrl(new StringType($row['link_url']));
        $slideImageArea->setLinkTarget(new NonEmptyStringType($row['link_target']));
        $slideImageArea->setCoordinates(new NonEmptyStringType($row['coordinates']));
    }
}