mirror of
https://gitlab.archlinux.org/archlinux/aurweb.git
synced 2025-02-03 10:43:03 +01:00
Instead of converting package comments from plain text to HTML code when they are displayed, do the conversion when the comment is posted and store the rendered result in the database. The conversion itself is done by a Python script which uses Bleach for sanitizing the text. Signed-off-by: Lukas Fleischer <lfleischer@archlinux.org>
156 lines
6.9 KiB
PHP
156 lines
6.9 KiB
PHP
<?php
|
|
if (!isset($count)) {
|
|
$count = pkgbase_comments_count($base_id, $include_deleted);
|
|
}
|
|
?>
|
|
<div id="news">
|
|
<h3>
|
|
<?php if (!isset($comments)): ?>
|
|
<?php $comments = $pinned ?>
|
|
<a href="<?= htmlentities(get_pkgbase_uri($pkgbase_name), ENT_QUOTES) . '?' . mkurl('comments=all') ?>" title="<?= __('View all comments' , $count) ?> (<?= $count ?>)"><?= __('Pinned Comments') ?></a>
|
|
<span class="arrow"></span>
|
|
<?php else: ?>
|
|
<a href="<?= htmlentities(get_pkgbase_uri($pkgbase_name), ENT_QUOTES) . '?' . mkurl('comments=all') ?>" title="<?= __('View all comments' , $count) ?> (<?= $count ?>)"><?= __('Latest Comments') ?></a>
|
|
<span class="arrow"></span>
|
|
<?php endif; ?>
|
|
</h3>
|
|
|
|
<?php while (list($indx, $row) = each($comments)): ?>
|
|
<?php
|
|
$date_fmtd = date('Y-m-d H:i', $row['CommentTS']);
|
|
if ($row['UserName']) {
|
|
$user_fmtd = html_format_username($row['UserName']);
|
|
$heading = __('%s commented on %s', $user_fmtd, $date_fmtd);
|
|
} else {
|
|
$heading = __('Anonymous comment on %s', $date_fmtd);
|
|
}
|
|
|
|
$is_deleted = $row['DelTS'];
|
|
$is_edited = $row['EditedTS'];
|
|
$is_pinned = $row['PinnedTS'];
|
|
|
|
if ($uid && $is_deleted) {
|
|
$date_fmtd = date('Y-m-d H:i', $row['DelTS']);
|
|
$heading .= ' <span class="edited">(';
|
|
if ($row['DelUserName']) {
|
|
$user_fmtd = html_format_username($row['DelUserName']);
|
|
$heading .= __('deleted on %s by %s', $date_fmtd, $user_fmtd);
|
|
} else {
|
|
$heading .= __('deleted on %s', $date_fmtd);
|
|
}
|
|
$heading .= ')</span>';
|
|
} elseif ($uid && $is_edited) {
|
|
$date_fmtd = date('Y-m-d H:i', $row['EditedTS']);
|
|
$heading .= ' <span class="edited">(';
|
|
if ($row['EditUserName']) {
|
|
$user_fmtd = html_format_username($row['EditUserName']);
|
|
$heading .= __('edited on %s by %s', $date_fmtd, $user_fmtd);
|
|
} else {
|
|
$heading .= __('edited on %s', $date_fmtd);
|
|
}
|
|
$heading .= ')</span>';
|
|
}
|
|
?>
|
|
<h4 id="<?= isset($pinned) ? "pinned-" : "comment-" ?><?= $row['ID'] ?>"<?php if ($is_deleted): ?> class="comment-deleted"<?php endif; ?>>
|
|
<?= $heading ?>
|
|
<?php if ($is_deleted && has_credential(CRED_COMMENT_UNDELETE)): ?>
|
|
<form class="undelete-comment-form" method="post" action="<?= htmlspecialchars(get_pkgbase_uri($pkgbase_name), ENT_QUOTES); ?>">
|
|
<fieldset style="display:inline;">
|
|
<input type="hidden" name="action" value="do_UndeleteComment" />
|
|
<input type="hidden" name="comment_id" value="<?= $row['ID'] ?>" />
|
|
<input type="hidden" name="token" value="<?= htmlspecialchars($_COOKIE['AURSID']) ?>" />
|
|
<input type="image" class="undelete-comment" src="/images/action-undo.min.svg" width="11" height="11" alt="<?= __('Undelete comment') ?>" title="<?= __('Undelete comment') ?>" name="submit" value="1" />
|
|
</fieldset>
|
|
</form>
|
|
<?php endif;?>
|
|
|
|
<?php if (!$is_deleted && can_delete_comment_array($row)): ?>
|
|
<form class="delete-comment-form" method="post" action="<?= htmlspecialchars(get_pkgbase_uri($pkgbase_name), ENT_QUOTES); ?>">
|
|
<fieldset style="display:inline;">
|
|
<input type="hidden" name="action" value="do_DeleteComment" />
|
|
<input type="hidden" name="comment_id" value="<?= $row['ID'] ?>" />
|
|
<input type="hidden" name="token" value="<?= htmlspecialchars($_COOKIE['AURSID']) ?>" />
|
|
<input type="image" class="delete-comment" src="/images/x.min.svg" width="11" height="11" alt="<?= __('Delete comment') ?>" title="<?= __('Delete comment') ?>" name="submit" value="1" />
|
|
</fieldset>
|
|
</form>
|
|
<?php endif; ?>
|
|
|
|
<?php if (!$is_deleted && can_edit_comment_array($row)): ?>
|
|
<a href="<?= htmlspecialchars(get_pkgbase_uri($pkgbase_name) . 'edit-comment/?comment_id=' . $row['ID'], ENT_QUOTES) ?>" class="edit-comment" title="<?= __('Edit comment') ?>"><img src="/images/pencil.min.svg" alt="<?= __('Edit comment') ?>" width="11" height="11"></a>
|
|
<?php endif; ?>
|
|
|
|
<?php if (!$is_deleted && !$is_pinned && can_pin_comment_array($row) && !(pkgbase_comments_count($base_id, false, true) >= 5)): ?>
|
|
<form class="pin-comment-form" method="post" action="<?= htmlspecialchars(get_pkgbase_uri($pkgbase_name), ENT_QUOTES); ?>">
|
|
<fieldset style="display:inline;">
|
|
<input type="hidden" name="action" value="do_PinComment" />
|
|
<input type="hidden" name="comment_id" value="<?= $row['ID'] ?>" />
|
|
<input type="hidden" name="package_base" value="<?= $base_id ?>" />
|
|
<input type="hidden" name="token" value="<?= htmlspecialchars($_COOKIE['AURSID']) ?>" />
|
|
<input type="image" class="pin-comment" src="/images/pin.min.svg" width="11" height="11" alt="<?= __('Pin comment') ?>" title="<?= __('Pin comment') ?>" name="submit" value="1" />
|
|
</fieldset>
|
|
</form>
|
|
<?php endif; ?>
|
|
|
|
<?php if (!$is_deleted && $is_pinned && can_pin_comment_array($row)): ?>
|
|
<form class="pin-comment-form" method="post" action="<?= htmlspecialchars(get_pkgbase_uri($pkgbase_name), ENT_QUOTES); ?>">
|
|
<fieldset style="display:inline;">
|
|
<input type="hidden" name="action" value="do_UnpinComment" />
|
|
<input type="hidden" name="comment_id" value="<?= $row['ID'] ?>" />
|
|
<input type="hidden" name="token" value="<?= htmlspecialchars($_COOKIE['AURSID']) ?>" />
|
|
<input type="image" class="pin-comment" src="/images/unpin.min.svg" width="11" height="11" alt="<?= __('Unpin comment') ?>" title="<?= __('Unpin comment') ?>" name="submit" value="1" />
|
|
</fieldset>
|
|
</form>
|
|
<?php endif; ?>
|
|
</h4>
|
|
<div id="<?= isset($pinned) ? "pinned-" : "comment-" ?><?= $row['ID'] ?>-content" class="article-content<?php if ($is_deleted): ?> comment-deleted<?php endif; ?>">
|
|
<?php if (!empty($row['RenderedComment'])): ?>
|
|
<?= $row['RenderedComment'] ?>
|
|
<?php else: ?>
|
|
<p>
|
|
<?= parse_comment($row['Comments']) ?>
|
|
</p>
|
|
<?php endif; ?>
|
|
</div>
|
|
<?php endwhile; ?>
|
|
|
|
<?php if ($count > 10 && !isset($_GET['comments']) && !isset($pinned)): ?>
|
|
<h3>
|
|
<a href="<?= htmlentities(get_pkgbase_uri($pkgbase_name), ENT_QUOTES) . '?' . mkurl('comments=all') ?>" title="<?= __('View all comments') ?> (<?= $count ?>)"><?= __('All comments', $count) ?></a>
|
|
</h3>
|
|
<?php endif; ?>
|
|
</div>
|
|
<script>
|
|
$(document).ready(function() {
|
|
$('.edit-comment').click(function () {
|
|
var parent_element = this.parentElement,
|
|
parent_id = parent_element.id,
|
|
comment_id = parent_id.substr(parent_id.indexOf('-') + 1),
|
|
edit_form = $(parent_element).next(),
|
|
_this = $(this);
|
|
add_busy_indicator(_this);
|
|
$.getJSON('<?= get_uri('/rpc') ?>', {
|
|
type: 'get-comment-form',
|
|
arg: comment_id,
|
|
base_id: <?= intval($base_id) ?>,
|
|
pkgbase_name: <?= json_encode($pkgbase_name) ?>
|
|
}, function (data) {
|
|
remove_busy_indicator(_this);
|
|
if (data.success) {
|
|
edit_form.html(data.form);
|
|
edit_form.find('textarea').focus();
|
|
} else {
|
|
alert(data.error);
|
|
}
|
|
});
|
|
return false;
|
|
});
|
|
|
|
function add_busy_indicator(sibling) {
|
|
sibling.after('<img src="/images/ajax-loader.gif" class="ajax-loader" width="16" height="11" alt="Busy…" />');
|
|
}
|
|
|
|
function remove_busy_indicator(sibling) {
|
|
sibling.next().remove();
|
|
}
|
|
});
|
|
</script>
|