yii2mod / yii2-comments
为 Yii2 的评论模块
2.0
2018-10-29 07:31 UTC
Requires
- php: >=5.6
- asofter/yii2-imperavi-redactor: *
- paulzi/yii2-adjacency-list: ^2.0
- yii2mod/yii2-behaviors: *
- yii2mod/yii2-editable: *
- yii2mod/yii2-enum: *
- yii2mod/yii2-moderation: *
- yiisoft/yii2: >=2.0.8
Requires (Dev)
- friendsofphp/php-cs-fixer: ~2.0
- phpunit/phpunit: ~6.0
This package is auto-updated.
Last update: 2024-08-29 03:41:57 UTC
README
Yii2 Comments 扩展
本模块提供了一套评论管理系统。
支持我们
您的业务依赖于我们的贡献吗?联系并支持我们在 Patreon。所有承诺都将用于分配人力进行维护和开发新功能。
安装
安装此扩展的首选方式是通过 composer。
运行以下命令
php composer.phar require --prefer-dist yii2mod/yii2-comments "*"
或者添加以下内容到您的 composer.json 的 require 部分。
"yii2mod/yii2-comments": "*"
配置
数据库迁移
在开始使用 Comments Widget 之前,我们还需要准备数据库。
模块设置
php yii migrate --migrationPath=@vendor/yii2mod/yii2-comments/migrations
要访问模块,您需要在应用程序配置中添加以下代码
注意:模块 ID 必须为 comment
,而不能是其他。这是因为代码中某个地方使用了这样的名称。欢迎提交 PR 来修复它,以便使用配置的模块 ID。
'modules' => [ 'comment' => [ 'class' => 'yii2mod\comments\Module', ], ]
现在您可以通过以下 URL 访问管理部分: http://localhost/path/to/index.php?r=comments/index
默认情况下,只有具有 admin
角色的用户可以访问评论管理部分。但是,您可以覆盖 ManageController 的 accessControlConfig
属性。
注意
删除按钮仅对具有 admin
角色的用户可见。
- 删除评论时,所有嵌套评论都将被标记为
已删除
。
- 您可以通过更改 Comment Module 中的
commentModelClass
属性来覆盖默认的 CommentModel 类。
- 您可以在
userIdentityClass
中实现自己的getAvatar
和getUsername
方法。只需在您的 User 模型中创建这些方法即可。例如
- 使用
public function getAvatar() { // your custom code } public function getUsername() { // your custom code }
基本示例
您可以为渲染评论使用自己的模板
// the model to which are added comments, for example: $model = Post::find()->where(['title' => 'some post title'])->one(); <?php echo \yii2mod\comments\widgets\Comment::widget([ 'model' => $model, ]); ?>
在同一页面上使用多个小部件的以下代码
<?php echo \yii2mod\comments\widgets\Comment::widget([ 'model' => $model, 'commentView' => '@app/views/site/comments/index' // path to your template ]); ?>
要启用评论列表的分页,请使用以下代码
<?php echo \yii2mod\comments\widgets\Comment::widget([ 'model' => $model, ]); ?> <?php echo \yii2mod\comments\widgets\Comment::widget([ 'model' => $model2, 'formId' => 'comment-form2', 'pjaxContainerId' => 'unique-pjax-container-id' ]); ?>
高级示例
<?php echo \yii2mod\comments\widgets\Comment::widget([ 'model' => $model, 'dataProviderConfig' => [ 'pagination' => [ 'pageSize' => 10 ], ] ]); ?>
使用事件
<?php echo \yii2mod\comments\widgets\Comment::widget([ 'model' => $model, 'relatedTo' => 'User ' . \Yii::$app->user->identity->username . ' commented on the page ' . \yii\helpers\Url::current(), 'maxLevel' => 2, 'dataProviderConfig' => [ 'pagination' => [ 'pageSize' => 10 ], ], 'listViewConfig' => [ 'emptyText' => Yii::t('app', 'No comments found.'), ], ]); ?>
使用事件
您可以使用以下事件
'modules' => [ 'comment' => [ 'class' => 'yii2mod\comments\Module', 'controllerMap' => [ 'default' => [ 'class' => 'yii2mod\comments\controllers\DefaultController', 'on beforeCreate' => function ($event) { $event->getCommentModel(); // your custom code }, 'on afterCreate' => function ($event) { $event->getCommentModel(); // your custom code }, 'on beforeDelete' => function ($event) { $event->getCommentModel(); // your custom code }, 'on afterDelete' => function ($event) { $event->getCommentModel(); // your custom code }, ] ] ] ]
使用评论插件事件
$(document).on('beforeCreate', '#comment-form', function (e) { if (!confirm("Everything is correct. Submit?")) { return false; } return true; });
可用事件如下
- beforeCreate
- afterCreate
- beforeDelete
- afterDelete
- beforeReply
- afterReply
国际化
此扩展中引入的所有文本和信息都可以在 'yii2mod.comments' 类别下进行翻译。您可以使用以下应用程序配置使用此扩展提供的翻译
return [ 'components' => [ 'i18n' => [ 'translations' => [ 'yii2mod.comments' => [ 'class' => 'yii\i18n\PhpMessageSource', 'basePath' => '@yii2mod/comments/messages', ], // ... ], ], // ... ], // ... ];