1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2025-01-18 09:04:44 +01:00

[EDIT] basic edit support

This commit is contained in:
asiekierka 2013-01-08 07:52:13 +01:00 committed by Michael Save
parent 153fb156fe
commit 940e6c657b
3 changed files with 43 additions and 31 deletions

View File

@ -921,7 +921,7 @@
// View whether a thread has been bumplocked ("-1" to allow non-mods to see too) // View whether a thread has been bumplocked ("-1" to allow non-mods to see too)
$config['mod']['view_bumplock'] = MOD; $config['mod']['view_bumplock'] = MOD;
// Edit posts (EXPERIMENTAL) // Edit posts (EXPERIMENTAL)
$config['mod']['editpost'] = DISABLED; $config['mod']['editpost'] = MOD;
// "Move" a thread to another board (EXPERIMENTAL; has some known bugs) // "Move" a thread to another board (EXPERIMENTAL; has some known bugs)
$config['mod']['move'] = DISABLED; $config['mod']['move'] = DISABLED;
// Bypass "field_disable_*" (forced anonymity, etc.) // Bypass "field_disable_*" (forced anonymity, etc.)

View File

@ -995,11 +995,38 @@ function mod_edit_post($board, $post) {
if (!hasPermission($config['mod']['editpost'], $board)) if (!hasPermission($config['mod']['editpost'], $board))
error($config['error']['noaccess']); error($config['error']['noaccess']);
// error("Unimplemented!"); $security_token = make_secure_link_token($board . '/ban/' . $post);
$args = array(
'test' => 1 $query = prepare(sprintf('SELECT * FROM `posts_%s` WHERE `id` = :id', $board));
); $query->bindValue(':id', $post);
mod_page(_('Edit post'), 'mod/edit_post_form.html', $args); $query->execute() or error(db_error($query));
if (!$_post = $query->fetch(PDO::FETCH_ASSOC))
error($config['error']['404']);
if(isset($_POST['mode']) && $_POST['mode'] == "edit")
{
$query = prepare(sprintf("UPDATE `posts_%s` SET `name` = :name,`email` = :email,`subject` = :subject,`body` = :body WHERE `id` = :id",$board));
$query->bindValue(':id', $post);
$query->bindValue('name', $_POST['name']);
$query->bindValue(':email', $_POST['email']);
$query->bindValue(':subject', $_POST['subject']);
$query->bindValue(':body', $_POST['body']);
$query->execute() or error(db_error($query));
header('Location: ?/' . sprintf($config['board_path'], $board) . $config['file_index'], true, $config['redirect_http']);
} else {
$args = array(
'token' => $security_token,
'name' => $_post['name'],
'email' => $_post['email'],
'subject' => $_post['subject'],
'body' => $_post['body'],
'mode' => "edit"
);
mod_page(_('Edit post'), 'mod/edit_post_form.html', $args);
}
} }
function mod_delete($board, $post) { function mod_delete($board, $post) {

View File

@ -1,27 +1,27 @@
<form name="post" enctype="multipart/form-data" action="{{ action }}" method="post"> <form name="post" enctype="multipart/form-data" action="{{ action }}" method="post">
<table> <table>
{% if not config.field_disable_name or (mod and post.mod|hasPermission(config.mod.bypass_field_disable, board.uri)) %}<tr> <tr>
<th> <th>
{% trans %}Name{% endtrans %} {% trans %}Name{% endtrans %}
</th> </th>
<td> <td>
<input type="text" name="name" size="25" maxlength="35" autocomplete="off"> <input type="text" name="name" size="25" maxlength="35" autocomplete="off" value="{{ name }}">
</td> </td>
</tr>{% endif %} </tr>
{% if not config.field_disable_email or (mod and post.mod|hasPermission(config.mod.bypass_field_disable, board.uri)) %}<tr> <tr>
<th> <th>
{% trans %}Email{% endtrans %} {% trans %}Email{% endtrans %}
</th> </th>
<td> <td>
<input type="text" name="email" size="25" maxlength="40" autocomplete="off"> <input type="text" name="email" size="25" maxlength="40" autocomplete="off" value="{{ email }}">
</td> </td>
</tr>{% endif %} </tr>
<tr> <tr>
<th> <th>
{% trans %}Subject{% endtrans %} {% trans %}Subject{% endtrans %}
</th> </th>
<td> <td>
<input style="float:left;" type="text" name="subject" size="25" maxlength="100" autocomplete="off"> <input style="float:left;" type="text" name="subject" size="25" maxlength="100" autocomplete="off" value="{{ subject }}">
</td> </td>
</tr> </tr>
<tr> <tr>
@ -29,27 +29,12 @@
{% trans %}Comment{% endtrans %} {% trans %}Comment{% endtrans %}
</th> </th>
<td> <td>
<textarea name="body" id="body" rows="5" cols="35"></textarea> <textarea name="body" id="body" rows="5" cols="35">{{ body }}</textarea>
</td> </td>
</tr> </tr>
<tr> <tr>
<th> <th><input type="hidden" name="mode" value="{{ mode }}"></th>
{% trans %}Flags{% endtrans %} <td><input name="sub" type="submit" value="{% trans 'Submit' %}"></td>
</th>
<td>
{% if not id and post.mod|hasPermission(config.mod.sticky, board.uri) %}<div>
<label for="sticky">{% trans %}Sticky{% endtrans %}</label>
<input title="{% trans %}Sticky{% endtrans %}" type="checkbox" name="sticky" id="sticky"><br>
</div>{% endif %}
{% if not id and post.mod|hasPermission(config.mod.lock, board.uri) %}<div>
<label for="lock">{% trans %}Lock{% endtrans %}</label><br>
<input title="{% trans %}Lock{% endtrans %}" type="checkbox" name="lock" id="lock">
</div>{% endif %}
{% if post.mod|hasPermission(config.mod.rawhtml, board.uri) %}<div>
<label for="raw">{% trans %}Raw HTML{% endtrans %}</label><br>
<input title="{% trans %}Raw HTML{% endtrans %}" type="checkbox" name="raw" id="raw">
</div>{% endif %}
</td>
</tr> </tr>
</table> </table>
</form> </form>