4 * Copyright 2007 $ThePhpWikiProgrammingTeam
5 * Copyright 2009 Marc-Etienne Vargenau, Alcatel-Lucent
7 * This file is part of PhpWiki.
9 * PhpWiki is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * PhpWiki is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License along
20 * with PhpWiki; if not, write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
25 * Standard Alcatel-Lucent disclaimer for contributing to open source
27 * "The ChartPlugin ("Contribution") has not been tested and/or
28 * validated for release as or in products, combinations with products or
29 * other commercial use. Any use of the Contribution is entirely made at
30 * the user's own responsibility and the user can not rely on any features,
31 * functionalities or performances Alcatel-Lucent has attributed to the
34 * THE CONTRIBUTION BY ALCATEL-LUCENT IS PROVIDED AS IS, WITHOUT WARRANTY
35 * OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
36 * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, COMPLIANCE,
37 * NON-INTERFERENCE AND/OR INTERWORKING WITH THE SOFTWARE TO WHICH THE
38 * CONTRIBUTION HAS BEEN MADE, TITLE AND NON-INFRINGEMENT. IN NO EVENT SHALL
39 * ALCATEL-LUCENT BE LIABLE FOR ANY DAMAGES OR OTHER LIABLITY, WHETHER IN
40 * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
41 * CONTRIBUTION OR THE USE OR OTHER DEALINGS IN THE CONTRIBUTION, WHETHER
42 * TOGETHER WITH THE SOFTWARE TO WHICH THE CONTRIBUTION RELATES OR ON A STAND
46 class WikiPlugin_Chart
49 function getDescription()
51 return _("Render SVG charts.");
54 function getDefaultArguments()
56 return array('width' => 200,
58 'type' => 'line', // or 'area', 'bar', 'pie'
59 // 'xlabel' => 'x', // TODO
60 // 'ylabel' => 'y', // TODO
62 // 'legend' => false, // TODO
63 'data' => false // required
67 function handle_plugin_args_cruft(&$argstr, &$args)
69 $this->source = $argstr;
72 function run($dbi, $argstr, &$request, $basepage)
76 $args = $this->getArgs($argstr, $request);
78 return $this->error(sprintf(_("A required argument ā%sā is missing."), 'data'));
83 $js = JavaScript('', array('src' => $WikiTheme->_findData('ASCIIsvg.js')));
84 $html->pushContent($js);
86 $values = explode(",", $data);
89 // x_max = number of elements in data
90 // y_min = 0 or smallest element in data if negative
91 // y_max = biggest element in data
93 $x_max = sizeof($values) + 1;
94 $y_min = min($values);
98 $y_max = max($values);
99 // sum is used for the pie only, so we ignore negative values
101 foreach ($values as $value) {
107 $source = 'initPicture(0,' . $x_max . ',' . $y_min . ',' . $y_max . '); axes(); stroke = "' . $color . '"; strokewidth = 5;';
109 if ($type == "bar") {
111 $source .= 'strokewidth = 10; ';
112 foreach ($values as $value) {
113 $source .= 'point1 = [' . $abscisse . ', 0];'
114 . 'point2 = [' . $abscisse . ',' . $value . '];'
115 . 'line(point1, point2);';
118 } elseif ($type == "line") {
120 $source .= 'strokewidth = 3; p = []; ';
121 foreach ($values as $value) {
122 $source .= 'for (t = 1; t < 1.01; t += 1) p[p.length] = ['
129 $source .= 'path(p);';
130 } elseif ($type == "pie") {
131 $source = 'initPicture(-1.1,1.1,-1.1,1.1); stroke = "' . $color . '"; strokewidth = 1;'
132 . 'center = [0, 0]; circle(center, 1);'
133 . 'point = [1, 0]; line(center, point);';
135 foreach ($values as $value) {
137 $angle += $value / $sum;
138 $source .= 'point = [cos(2*pi*' . $angle . '), sin(2*pi*' . $angle . ')]; line(center, point);';
143 $embedargs = array('width' => $args['width'],
144 'height' => $args['height'],
145 'script' => $source);
146 $embed = new SVG_HTML("embed", $embedargs);
147 $html->pushContent($embed);
152 class SVG_HTML extends HtmlElement
156 $start = "<" . $this->_tag;
157 $this->_setClasses();
158 foreach ($this->_attr as $attr => $val) {
164 $qval = str_replace("\"", '"', $this->_quote((string)$val));
165 if ($attr == 'script')
167 $start .= " $attr='$qval'";
169 $start .= " $attr=\"$qval\"";
180 // c-hanging-comment-ender-p: nil
181 // indent-tabs-mode: nil