liubinas/upvote-bundle
Composer 安装命令:
composer require liubinas/upvote-bundle
包简介
Upvote and downvote (aka thumbs up) bundle for Symfony project
README 文档
README
LtUpvoteBundle is upvote and downvote (thumbs up and thumbs down) component for Symfony 3.0 project
Features
- Configurable vote permissions
- Automatically limit unauthenticated upvotes/downvotes by IP
- Optionally hide upvote/downvote button
- Pure JavaScript frontend component implementation
- Unit tested
System requirements
- Symfony 3.0
- Doctrine bundle with configured database connection
Installation
- Require LtUpvoteBundle over composer in your existing Symfony project:
composer require liubinas/upvote-bundle
- Initialize it in the app/AppKernel.php file:
$bundles[] = new Lt\UpvoteBundle\LtUpvoteBundle();
- Import LtUpvoteBundle routing:
# app/config/routing.yml lt-upvote: resource: "@LtUpvoteBundle/Resources/config/routing.xml"
- Create required database tables:
$ bin/console doctrine:schema:update
Configuration
The following is an example configuration defining basic context types blog-post and
comment:
# app/config/config.yml lt-upvote-bundle: types: blog-post: # Custom context type show_upvote: true show_downvote: true allow_unauthenticated_upvote: true allow_unauthenticated_downvote: false comment # Custom context type having the default values all true
Test run
Start web server:
$ bin/console server:start
Test page could be accessed by navigating to
http://<dev-host>/lt-upvote-test on your dev environment.
Front-end
Front-end functionality is implemented in a single dependency free JavaScript file. Styles are defined in CSS file which could be used out of the box or adopted according to custom requirements.
JavaScript
- Include JavaScrip module file (Twig syntax):
<script src="{{asset('/bundles/ltupvote/js/lt-upvote.js')}}"></script>
- Initialize JavaScript module in your HTML page:
<script language="JavaScript"><!-- ltupvote.init(); //--> </script>
CSS
- Include basic CSS file in your html
<head>section:
<link rel="stylesheet" type="text/css" href="{{ asset('/bundles/ltupvote/css/lt-upvote.css') }}">
Twig
- Include one or more front end components into your page rendered over Controller
{{ render(
controller(
'lt_upvote_bundle.controller.default:renderVoteComponent',
{
'subjectType': '[TYPE]',
'subjectId': '[ID]',
'css_class': '[CLASS]'
}
)
) }}
Where:
[TYPE]is context type value.[ID]is Subject ID value.[CLASS]is component specific styling CSS class. Predefined styles areStyle1,Style2.
See test.html.twig file for example implementation.
JavaScript Custom Event handling
On each upvote/downvote action JavaScript event is dispatched.
This action could be handled by adding custom event listener for ltu event type.
An example code for unauthenticated downvote handling:
addEventListener('ltu', function(event) { if (event.detail.unauthenticatedError) { alert('This action is permitted for the logged in visitors only.'); } })
The following properties describing performed action could be accessed from even.detail data object: id, type, counter, action, unauthentificated, unauthentificatedError.
License
This bundle is under the MIT license. See the complete license in LICENSE file. f
统计信息
- 总下载量: 16
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 3
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2018-05-07