4 * Copyright 2004,2007 $ThePhpWikiProgrammingTeam
6 * This file is part of PhpWiki.
8 * PhpWiki is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * PhpWiki is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License along
19 * with PhpWiki; if not, write to the Free Software Foundation, Inc.,
20 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24 * Append text to an existing page.
26 * @Author: Pascal Giard <evilynux@gmail.com>
28 * See http://sourceforge.net/mailarchive/message.php?msg_id=10141823
29 * why not to use "text" as parameter. Nasty mozilla bug with mult. radio rows.
31 * Todo: multiple pages. e.g. AppendText s=~[CategoryINtime~] page=<!plugin TitleSearch intime !>
33 class WikiPlugin_AppendText
36 function getDescription()
38 return _("Append text to any page in this wiki.");
41 function getDefaultArguments()
43 return array('page' => '[pagename]',
45 's' => '', // Text to append.
46 'before' => '', // Add before (ignores after if defined)
47 'after' => '', // Add after line beginning with this
48 'redirect' => false // Redirect to modified page
52 private function fallback($addtext, $oldtext, $notfound, &$message)
54 $message->pushContent(sprintf(_("ā%sā not found"), $notfound) . ". " .
55 _("Appending at the end.") . "\n");
56 return $oldtext . "\n" . $addtext;
61 * @param string $argstr
62 * @param WikiRequest $request
63 * @param string $basepage
66 function run($dbi, $argstr, &$request, $basepage)
69 $args = $this->getArgs($argstr, $request);
70 if (!$args['pages'] or !$request->isPost()) {
71 return $this->work($args['page'], $args, $dbi, $request);
74 if ($args['page'] != $basepage)
75 $html->pushContent(_("pages argument overrides page argument. ignored."), HTML::br());
76 foreach ($args['pages'] as $pagename) {
77 $html->pushContent($this->work($pagename, $args, $dbi, $request));
83 private function work($pagename, $args, $dbi, &$request)
85 if (empty($args['s'])) {
86 if ($request->isPost()) {
87 if ($pagename != _("AppendText"))
88 return HTML($request->redirect(WikiURL($pagename, array(), 'absurl'), false));
93 $page = $dbi->getPage($pagename);
96 if (!$page->exists()) { // We might want to create it?
97 $message->pushContent(sprintf(_("Page could not be updated. %s doesn't exist!"),
102 $current = $page->getCurrentRevision();
103 $oldtext = $current->getPackedContent();
106 // If a "before" or "after" is specified but not found, we simply append text to the end.
107 if (!empty($args['before'])) {
108 $before = preg_quote($args['before'], "/");
110 $newtext = preg_match("/\n${before}/", $oldtext)
111 ? preg_replace("/(\n${before})/",
112 "\n" . preg_quote($text, "/") . "\\1",
114 : $this->fallback($text, $oldtext, $args['before'], $message);
115 } elseif (!empty($args['after'])) {
117 $after = preg_quote($args['after'], "/");
118 $newtext = preg_match("/\n${after}/", $oldtext)
119 ? preg_replace("/(\n${after})/",
120 "\\1\n" . preg_quote($text, "/"),
122 : $this->fallback($text, $oldtext, $args['after'], $message);
125 $newtext = $oldtext .
129 require_once 'lib/loadsave.php';
130 $meta = $current->_data;
131 $meta['summary'] = sprintf(_("AppendText to %s"), $pagename);
132 if ($page->save($newtext, $current->getVersion() + 1, $meta)) {
133 $message->pushContent(HTML::p(array('class' => 'feedback'),
134 _("Page successfully updated.")));
137 // AppendText has been called from the same page that got modified
138 // so we directly show the page.
139 if ($request->getArg($pagename) == $pagename) {
140 // TODO: Just invalidate the cache, if AppendText didn't
141 // change anything before.
143 return $request->redirect(WikiURL($pagename, array(), 'absurl'), false);
145 // The user asked to be redirected to the modified page
146 } elseif ($args['redirect']) {
147 return $request->redirect(WikiURL($pagename, array(), 'absurl'), false);
150 $link = HTML::em(WikiLink($pagename));
151 $message->pushContent(HTML::raw(sprintf(_("Go to %s."), $link->asXml())));
162 // c-hanging-comment-ender-p: nil
163 // indent-tabs-mode: nil