/** * Tests the xAxis format options for the linear type */ public function testFormatOptions() { $data = new Data(); $data->addSeries('Test', array('01-08-2012' => 18, '02-08-2012' => 4, '03-08-2012' => 12)); $chart = new Chart(); $chart->setData($data); $chart->setRenderer(new Area()); $linear = new Linear(); $formatOptions = $linear->getFormatOptions($chart); $this->assertInstanceOf('Phighchart\\Options\\Container', $formatOptions); $expected = new \StdClass(); //for linear format the xAxis labels are set as categories $expected->categories = array('01-08-2012', '02-08-2012', '03-08-2012'); $this->assertEquals($expected, $formatOptions->getOptions()); $this->assertSame('xAxis', $formatOptions->getOptionsType()); }
public function testRenderWithoutExtendedOptions() { $options = new OptionsContainer('chart'); $options->setRenderTo('chart_example_59'); $options->setMarginRight(130); $options->setMarginBottom(25); $titleOptions = new OptionsContainer('title'); $titleOptions->setText('Monthly Details'); $titleOptions->setX(-20); $data = new Data(); $data->addCount('Apples', 32); $data->addCount('Oranges', 68); // put it all together $chart = new Chart(); $chart->addOptions($options); $chart->addOptions($titleOptions); $chart->setData($data); $chart->setRenderer(new Pie()); // test the full expected output $this->assertSame('var chart_example_59; chart_example_59 = new Highcharts.Chart({"chart":{"renderTo":"chart_example_59","marginRight":130,"marginBottom":25},"title":{"text":"Monthly Details","x":-20},"series":[{"type":"pie","data":[{"name":"Apples","y":32},{"name":"Oranges","y":68}]}]});', $chart->render()); $this->assertSame('<div id="chart_example_59"></div>', $chart->renderContainer()); }
public function testAreaRenderWithCustomDateTimeFormat() { $options = new OptionsContainer('chart'); $options->setRenderTo('chart_example_59'); $options->setMarginRight(130); $options->setMarginBottom(25); $titleOptions = new OptionsContainer('title'); $titleOptions->setText('Monthly Details'); $titleOptions->setX(-20); $data = new Data(); $data->addSeries('Apples', array('1st May, 2012 00:00:00' => 12, '2nd May, 2012 00:00:00' => 3, '3rd May, 2012 00:00:00' => 33))->addSeries('Oranges', array('1st May, 2012 00:00:00' => 32, '2nd May, 2012 00:00:00' => 36, '3rd May, 2012 00:00:00' => 18)); $format = new DatetimeFormat(); $format->setDateTimeFormat('jS F, Y H:i:s'); // put it all together $chart = new Chart(); $chart->addOptions($options); $chart->addOptions($titleOptions); $chart->setData($data); $chart->setFormat($format); $chart->setRenderer(new Area()); // test the full expected output $this->assertSame('var chart_example_59; chart_example_59 = new Highcharts.Chart({"chart":{"renderTo":"chart_example_59","marginRight":130,"marginBottom":25,"type":"area"},"title":{"text":"Monthly Details","x":-20},"xAxis":{"type":"datetime"},"series":[{"name":"Apples","data":[[Date.UTC(2012,4,01,00,00,00),12],[Date.UTC(2012,4,02,00,00,00),3],[Date.UTC(2012,4,03,00,00,00),33]]},{"name":"Oranges","data":[[Date.UTC(2012,4,01,00,00,00),32],[Date.UTC(2012,4,02,00,00,00),36],[Date.UTC(2012,4,03,00,00,00),18]]}]});', $chart->render()); $this->assertSame('<div id="chart_example_59"></div>', $chart->renderContainer()); }
/** * @expectedException InvalidArgumentException */ public function testInvalidSeries() { $data = new Data(); $seoDataSeries = array('2010-01-01' => 10, '2010-01-02' => '3', '2010-01-03' => 17); $data->addSeries('seo', $seoDataSeries); }
$loader = new UniversalClassLoader(); $loader->register(); $loader->registerNamespaces(array('Phighchart' => __DIR__ . '/../classes')); use Phighchart\Chart; use Phighchart\Options\Container as OptionsContainer; use Phighchart\Options\ExtendedContainer as ExtendedOptionsContainer; use Phighchart\Data; use Phighchart\Renderer\Pie; use Phighchart\Renderer\Line; $extOptions = new ExtendedOptionsContainer(); $extOptions->setStickyColour('apples', '#629632'); $extOptions->setStickyColour('oranges', '#CD3700'); $options = new OptionsContainer('chart'); $options->setRenderTo('chart_example_59'); $options->setMarginRight(130); $options->setMarginBottom(25); $titleOptions = new OptionsContainer('title'); $titleOptions->setText('Monthly Details'); $titleOptions->setX(-20); $data = new Data(); $data->addCount('Apples', 32)->addCount('Oranges', 68)->addSeries('Apples', array('2012-05-01' => 12, '2012-05-02' => 3, '2012-05-03' => 33))->addSeries('Oranges', array('2012-05-01' => 32, '2012-05-02' => 36, '2012-05-03' => 18)); // put it all together $chart = new Chart(); $chart->addOptions($options)->addOptions($titleOptions)->addOptions($extOptions)->setData($data)->setRenderer(new Pie()); // a line chart is similiar, and our data container holds series data for this $lineChart = clone $chart; $options = new OptionsContainer('chart'); $options->setRenderTo('chart_example_60'); $options->setMarginRight(130); $options->setMarginBottom(25); $lineChart->addOptions($options)->setRenderer(new Line());