<?php
    /* Libchart - PHP chart library
     * Copyright (C) 2005-2011 Jean-Marc Trémeaux (jm.tremeaux at gmail.com)
     * 
     * This program is free software: you can redistribute it and/or modify
     * it under the terms of the GNU 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 General Public License for more details.
     *
     * You should have received a copy of the GNU General Public License
     * along with this program.  If not, see <http://www.gnu.org/licenses/>.
     * 
     */
    
    /*! \mainpage Libchart
     *
     * This is the reference API, automatically compiled by <a href="http://www.stack.nl/~dimitri/doxygen/">Doxygen</a>.
     * You can find here information that is not covered by the <a href="../samplecode/">tutorial</a>.
     *
     */

    /**
     * Base chart class.
     *
     * @author Jean-Marc Trémeaux (jm.tremeaux at gmail.com)
     */
    abstract class Chart {
        /**
         * The chart configuration.
         */
        protected $config;
    
        /**
         * The data set.
         */
        protected $dataSet;
    
        /**
         * Plot (holds graphical attributes).
         */
        protected $plot;

        /**
         * Abstract constructor of Chart.
         *
         * @param integer width of the image
         * @param integer height of the image
         */
        protected function Chart($width, $height) {
            // Initialize the configuration
            $this->config = new ChartConfig();
            
            // Creates the plot
            $this->plot = new Plot($width, $height);
            $this->plot->setTitle("Untitled chart");
        }

        /**
         * Checks the data model before rendering the graph.
         */
        protected function checkDataModel() {
            // Check if a dataset was defined
            if (!$this->dataSet) {
                die("Error: No dataset defined.");
            }
            
            // Maybe no points are defined, but that's ok. This will yield and empty graph with default boundaries.
        }
        
        /**
         * Create the image.
         */
        protected function createImage() {
            $this->plot->createImage();
        }

        /**
         * Sets the data set.
         *
         * @param dataSet The data set
         */
        public function setDataSet($dataSet) {
            $this->dataSet = $dataSet;
        }
        
        /**
         * Return the chart configuration.
         *
         * @return configuration : ChartConfig
         */
        public function getConfig() {
            return $this->config;
        }
        
        /**
         * Return the plot.
         *
         * @return plot
         */
        public function getPlot() {
            return $this->plot;
        }
        
        /**
         * Sets the title.
         *
         * @param string New title
         */
        public function setTitle($title) {
            $this->plot->setTitle($title);
        }
    }
?>