5 A PhpWiki plugin that allows insertion of tables using a Mediawiki-like
9 * Copyright (C) 2003 Sameer D. Sahasrabuddhe
10 * Copyright (C) 2005 $ThePhpWikiProgrammingTeam
11 * Copyright (C) 2008-2009 Alcatel-Lucent
13 * This file is part of PhpWiki.
15 * PhpWiki is free software; you can redistribute it and/or modify
16 * it under the terms of the GNU General Public License as published by
17 * the Free Software Foundation; either version 2 of the License, or
18 * (at your option) any later version.
20 * PhpWiki is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 * GNU General Public License for more details.
25 * You should have received a copy of the GNU General Public License
26 * along with PhpWiki; if not, write to the Free Software
27 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
31 * Standard Alcatel-Lucent disclaimer for contributing to open source
33 * "The MediawikiTablePlugin ("Contribution") has not been tested and/or
34 * validated for release as or in products, combinations with products or
35 * other commercial use. Any use of the Contribution is entirely made at
36 * the user's own responsibility and the user can not rely on any features,
37 * functionalities or performances Alcatel-Lucent has attributed to the
40 * THE CONTRIBUTION BY ALCATEL-LUCENT IS PROVIDED AS IS, WITHOUT WARRANTY
41 * OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
42 * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, COMPLIANCE,
43 * NON-INTERFERENCE AND/OR INTERWORKING WITH THE SOFTWARE TO WHICH THE
44 * CONTRIBUTION HAS BEEN MADE, TITLE AND NON-INFRINGEMENT. IN NO EVENT SHALL
45 * ALCATEL-LUCENT BE LIABLE FOR ANY DAMAGES OR OTHER LIABLITY, WHETHER IN
46 * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
47 * CONTRIBUTION OR THE USE OR OTHER DEALINGS IN THE CONTRIBUTION, WHETHER
48 * TOGETHER WITH THE SOFTWARE TO WHICH THE CONTRIBUTION RELATES OR ON A STAND
52 class WikiPlugin_MediawikiTable
56 return _("MediawikiTable");
59 function getDescription() {
60 return _("Layout tables using a Mediawiki-like markup style.");
63 function getDefaultArguments() {
67 function getVersion() {
68 return preg_replace("/[Revision: $]/", '',
72 function run($dbi, $argstr, &$request, $basepage) {
74 include_once("lib/BlockParser.php");
75 // MediawikiTablePlugin markup is new.
78 // We allow the compact Mediawiki syntax with:
79 // - multiple cells on the same line (separated by "||"),
80 // - multiple header cells on the same line (separated by "!!").
81 $argstr = str_replace("||", "\n| ", $argstr);
82 $argstr = str_replace("!!", "\n! ", $argstr);
84 $lines = preg_split('/\n/', $argstr);
85 $table = HTML::table();
87 // We always generate an Id for the table.
88 // This is convenient for tables of class "sortable".
89 // If user provides an Id, the generated Id will be overwritten below.
90 $table->setAttr("id", GenerateId("MediawikiTable"));
92 if (substr($lines[0],0,2) == "{|") {
94 $lines[0] = substr($lines[0],2);
96 if (($lines[0][0] != '|') and ($lines[0][0] != '!')) {
97 $line = array_shift($lines);
98 $attrs = parse_attributes($line);
99 foreach ($attrs as $key => $value) {
100 if (in_array ($key, array("id", "class", "title", "style",
101 "bgcolor", "frame", "rules", "border",
102 "cellspacing", "cellpadding",
103 "summary", "align", "width"))) {
104 $table->setAttr($key, $value);
109 foreach ($lines as $line){
110 if (substr($line,0,2) == "|}") {
114 if (substr($line,0,2) == "|-") {
117 if (isset($content)) {
118 if (is_numeric(trim($content))) {
119 $cell->pushContent(HTML::p(array('style' => "text-align:right"), trim($content)));
121 $cell->pushContent(TransformText(trim($content), $markup, $basepage));
125 $row->pushContent($cell);
129 $thead->pushContent($row);
130 $table->pushContent($thead);
132 $tbody = HTML::tbody();
134 $tbody->pushContent($row);
138 $attrs = parse_attributes(substr($line,2));
139 foreach ($attrs as $key => $value) {
140 if (in_array ($key, array("id", "class", "title", "style",
141 "bgcolor", "align", "valign"))) {
142 $row->setAttr($key, $value);
149 if (substr($line,0,2) == "|=") {
150 $line = substr($line,2);
151 $table->setAttr("summary", trim($line));
155 if (substr($line,0,2) == "|+") {
157 $caption = HTML::caption();
158 $line = substr($line,2);
159 $pospipe = strpos($line, "|");
160 $posbracket = strpos($line, "[");
161 if (($pospipe !== false) && (($posbracket === false) || ($posbracket > $pospipe))) {
162 $attrs = parse_attributes(substr($line, 0, $pospipe));
163 foreach ($attrs as $key => $value) {
164 if (in_array ($key, array("id", "class", "title", "style",
166 $caption->setAttr($key, $value);
169 $line=substr($line, $pospipe+1);
172 $caption->pushContent(trim($line));
173 $table->pushContent($caption);
176 if (((substr($line,0,1) == "|") or (substr($line,0,1) == "!")) and isset($row)) {
178 if (isset ($content)) {
179 if (is_numeric(trim($content))) {
180 $cell->pushContent(HTML::p(array('style' => "text-align:right"), trim($content)));
182 $cell->pushContent(TransformText(trim($content), $markup, $basepage));
186 $row->pushContent($cell);
188 if (substr($line,0,1) == "!") {
189 $cell = HTML::th(); // Header
190 $thead = HTML::thead();
193 if (!isset($tbody)) $tbody = HTML::tbody();
195 $line = substr($line, 1);
197 // If there is a "|" in the line, the start of line
198 // (before the "|") is made of attributes.
199 // The end of the line (after the "|") is the cell content
200 // This is not true if the pipe is inside []
202 // The following cases must work:
205 // | class="xxx" | foo
206 // | class="xxx" | [foo|bar]
207 $pospipe = strpos($line, "|");
208 $posbracket = strpos($line, "[");
209 if (($pospipe !== false) && (($posbracket === false) || ($posbracket > $pospipe))) {
210 $attrs = parse_attributes(substr($line, 0, $pospipe));
211 foreach ($attrs as $key => $value) {
212 if (in_array ($key, array("id", "class", "title", "style",
213 "colspan", "rowspan", "width", "height",
214 "bgcolor", "align", "valign"))) {
215 $cell->setAttr($key, $value);
218 $line=substr($line, $pospipe+1);
219 if (is_numeric(trim($line))) {
220 $cell->pushContent(HTML::p(array('style' => "text-align:right"), trim($line)));
222 $cell->pushContent(TransformText(trim($line), $markup, $basepage));
227 if (isset($row) and isset($cell)) {
228 $line = str_replace("?\>", "?>", $line);
229 $line = str_replace("\~", "~", $line);
230 if (empty($content)) $content = '';
231 $content .= $line . "\n";
236 if (isset($content)) {
237 if (is_numeric(trim($content))) {
238 $cell->pushContent(HTML::p(array('style' => "text-align:right"), trim($content)));
240 $cell->pushContent(TransformText(trim($content), $markup, $basepage));
244 $row->pushContent($cell);
246 $tbody->pushContent($row);
247 $table->pushContent($tbody);
258 // c-hanging-comment-ender-p: nil
259 // indent-tabs-mode: nil